1
0
mirror of https://github.com/fumiama/WireGold.git synced 2026-06-11 12:10:26 +08:00
This commit is contained in:
fumiama
2021-10-24 20:56:16 +08:00
parent fa1608165b
commit d9138df3cd
3 changed files with 53 additions and 51 deletions

View File

@@ -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)
} }

View File

@@ -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
}

View File

@@ -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
}