mirror of
https://github.com/fumiama/WireGold.git
synced 2026-06-11 20:20:27 +08:00
init
This commit is contained in:
@@ -45,11 +45,11 @@ func (l *Link) Read() *head.Packet {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (l *Link) Write(p *head.Packet) (n int, err error) {
|
func (l *Link) Write(p *head.Packet) (n int, err error) {
|
||||||
var d []byte
|
p.Data, err = l.Encode(p.Data)
|
||||||
d, err = p.Mashal(me.String(), l.peerip.String())
|
|
||||||
logrus.Debugln("[link] write data", string(d))
|
|
||||||
if err == nil {
|
if err == nil {
|
||||||
d, err = l.Encode(d)
|
var d []byte
|
||||||
|
d, err = p.Mashal(me.String(), l.peerip.String())
|
||||||
|
logrus.Debugln("[link] write data", string(d))
|
||||||
if err == nil {
|
if err == nil {
|
||||||
n, err = myconn.WriteToUDP(d, l.endpoint)
|
n, err = myconn.WriteToUDP(d, l.endpoint)
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -45,33 +45,30 @@ func listen() (conn *net.UDPConn, err error) {
|
|||||||
n, addr, err := conn.ReadFromUDP(lbf)
|
n, addr, err := conn.ReadFromUDP(lbf)
|
||||||
if err == nil {
|
if err == nil {
|
||||||
lbf = lbf[:n]
|
lbf = lbf[:n]
|
||||||
p, ok := IsEndpointInPeer(addr.String())
|
packet := head.Packet{}
|
||||||
logrus.Infoln("[link] recv from endpoint", addr)
|
err = packet.UnMashal(lbf)
|
||||||
logrus.Debugln("[link] recv:", string(lbf))
|
if err == nil {
|
||||||
if ok {
|
r := int(packet.DataSZ) - len(packet.Data)
|
||||||
packet := head.Packet{}
|
if r > 0 {
|
||||||
d, err := p.Decode(lbf)
|
remain, err := readAll(conn, r)
|
||||||
if err == nil {
|
if err == nil {
|
||||||
packet.UnMashal(d)
|
|
||||||
r := packet.DataSZ - uint32(len(packet.Data))
|
|
||||||
if r > 0 {
|
|
||||||
i := 0
|
|
||||||
n := 0
|
|
||||||
remain := make([]byte, r)
|
|
||||||
for r > 0 {
|
|
||||||
n, _, err = conn.ReadFromUDP(remain[i:])
|
|
||||||
if err == nil {
|
|
||||||
i += n
|
|
||||||
r -= uint32(n)
|
|
||||||
} else {
|
|
||||||
logrus.Errorln("[link.listen]", err)
|
|
||||||
return
|
|
||||||
}
|
|
||||||
}
|
|
||||||
packet.Data = append(packet.Data, remain...)
|
packet.Data = append(packet.Data, remain...)
|
||||||
}
|
}
|
||||||
logrus.Infoln("[link] deliver to", p.peerip)
|
}
|
||||||
p.pipe <- &packet
|
p, ok := IsInPeer(packet.Src)
|
||||||
|
logrus.Infoln("[link] recv from endpoint", addr, "src", packet.Src, "dst", packet.Dst)
|
||||||
|
logrus.Debugln("[link] recv:", string(lbf))
|
||||||
|
if ok {
|
||||||
|
packet.Data, err = p.Decode(packet.Data)
|
||||||
|
if err == nil {
|
||||||
|
logrus.Infoln("[link] deliver to", p.peerip)
|
||||||
|
if p.EndPoint == "" {
|
||||||
|
logrus.Infoln("[link] set endpoint of peer", p.peerip, "to", addr.String())
|
||||||
|
p.endpoint = addr
|
||||||
|
p.EndPoint = addr.String()
|
||||||
|
}
|
||||||
|
p.pipe <- &packet
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -80,3 +77,22 @@ func listen() (conn *net.UDPConn, err error) {
|
|||||||
}
|
}
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func readAll(conn *net.UDPConn, sz int) ([]byte, error) {
|
||||||
|
i := 0
|
||||||
|
n := 0
|
||||||
|
r := sz
|
||||||
|
var err error
|
||||||
|
remain := make([]byte, r)
|
||||||
|
for sz > 0 {
|
||||||
|
n, _, err = conn.ReadFromUDP(remain[i:])
|
||||||
|
if err == nil {
|
||||||
|
i += n
|
||||||
|
r -= n
|
||||||
|
} else {
|
||||||
|
logrus.Errorln("[link] read all err:", err)
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return remain, nil
|
||||||
|
}
|
||||||
|
|||||||
@@ -2,16 +2,10 @@ package link
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"net"
|
"net"
|
||||||
"sync"
|
|
||||||
|
|
||||||
"github.com/fumiama/WireGold/gold/head"
|
"github.com/fumiama/WireGold/gold/head"
|
||||||
)
|
)
|
||||||
|
|
||||||
var (
|
|
||||||
eps = make(map[string]*Link)
|
|
||||||
epmu sync.RWMutex
|
|
||||||
)
|
|
||||||
|
|
||||||
func AddPeer(peerip string, pubicKey [32]byte, endPoint string, keepAlive int64) (l *Link) {
|
func AddPeer(peerip string, pubicKey [32]byte, endPoint string, keepAlive int64) (l *Link) {
|
||||||
peerip = net.ParseIP(peerip).String()
|
peerip = net.ParseIP(peerip).String()
|
||||||
var ok bool
|
var ok bool
|
||||||
@@ -19,24 +13,23 @@ func AddPeer(peerip string, pubicKey [32]byte, endPoint string, keepAlive int64)
|
|||||||
if ok {
|
if ok {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
e, err := net.ResolveUDPAddr("udp", endPoint)
|
|
||||||
if err != nil {
|
|
||||||
panic(err)
|
|
||||||
}
|
|
||||||
l = &Link{
|
l = &Link{
|
||||||
PubicKey: pubicKey,
|
PubicKey: pubicKey,
|
||||||
EndPoint: endPoint,
|
|
||||||
KeepAlive: keepAlive,
|
KeepAlive: keepAlive,
|
||||||
pipe: make(chan *head.Packet, 32),
|
pipe: make(chan *head.Packet, 32),
|
||||||
peerip: net.ParseIP(peerip),
|
peerip: net.ParseIP(peerip),
|
||||||
endpoint: e,
|
}
|
||||||
|
if endPoint != "" {
|
||||||
|
e, err := net.ResolveUDPAddr("udp", endPoint)
|
||||||
|
if err != nil {
|
||||||
|
panic(err)
|
||||||
|
}
|
||||||
|
l.EndPoint = endPoint
|
||||||
|
l.endpoint = e
|
||||||
}
|
}
|
||||||
connmapmu.Lock()
|
connmapmu.Lock()
|
||||||
epmu.Lock()
|
|
||||||
connections[peerip] = l
|
connections[peerip] = l
|
||||||
eps[endPoint] = l
|
|
||||||
connmapmu.Unlock()
|
connmapmu.Unlock()
|
||||||
epmu.Unlock()
|
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -46,10 +39,3 @@ func IsInPeer(peer string) (p *Link, ok bool) {
|
|||||||
connmapmu.RUnlock()
|
connmapmu.RUnlock()
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
func IsEndpointInPeer(ep string) (p *Link, ok bool) {
|
|
||||||
epmu.RLock()
|
|
||||||
p, ok = eps[ep]
|
|
||||||
epmu.RUnlock()
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|||||||
Reference in New Issue
Block a user