done
This commit is contained in:
parent
9bd0fb9125
commit
283c85d256
@ -379,9 +379,8 @@ func (n *network) processNetChan(listener tunnel.Listener) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// update peer links
|
// update peer links
|
||||||
log.Tracef("Network updating peer link %s for peer: %s", m.session.Link(), pbNetConnect.Node.Address)
|
|
||||||
|
|
||||||
if err := n.updatePeerLinks(pbNetConnect.Node.Address, m.session.Link()); err != nil {
|
if err := n.updatePeerLinks(pbNetConnect.Node.Address, m); err != nil {
|
||||||
log.Debugf("Network failed updating peer links: %s", err)
|
log.Debugf("Network failed updating peer links: %s", err)
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -443,9 +442,8 @@ func (n *network) processNetChan(listener tunnel.Listener) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// update peer links
|
// update peer links
|
||||||
log.Tracef("Network updating peer link %s for peer: %s", m.session.Link(), pbNetPeer.Node.Address)
|
|
||||||
|
|
||||||
if err := n.updatePeerLinks(pbNetPeer.Node.Address, m.session.Link()); err != nil {
|
if err := n.updatePeerLinks(pbNetPeer.Node.Address, m); err != nil {
|
||||||
log.Debugf("Network failed updating peer links: %s", err)
|
log.Debugf("Network failed updating peer links: %s", err)
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -680,10 +678,12 @@ func (n *network) sendMsg(method, channel string, msg proto.Message) error {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// updatePeerLinks updates link for a given peer
|
// updatePeerLinks updates link for a given peer
|
||||||
func (n *network) updatePeerLinks(peerAddr string, linkId string) error {
|
func (n *network) updatePeerLinks(peerAddr string, m *message) error {
|
||||||
n.Lock()
|
n.Lock()
|
||||||
defer n.Unlock()
|
defer n.Unlock()
|
||||||
|
|
||||||
|
linkId := m.msg.Header["Micro-Link"]
|
||||||
|
|
||||||
log.Tracef("Network looking up link %s in the peer links", linkId)
|
log.Tracef("Network looking up link %s in the peer links", linkId)
|
||||||
|
|
||||||
// lookup the peer link
|
// lookup the peer link
|
||||||
|
@ -266,7 +266,7 @@ func (t *tun) manageLinks() {
|
|||||||
for _, node := range connect {
|
for _, node := range connect {
|
||||||
wg.Add(1)
|
wg.Add(1)
|
||||||
|
|
||||||
go func() {
|
go func(node string) {
|
||||||
defer wg.Done()
|
defer wg.Done()
|
||||||
|
|
||||||
// create new link
|
// create new link
|
||||||
@ -280,7 +280,7 @@ func (t *tun) manageLinks() {
|
|||||||
t.Lock()
|
t.Lock()
|
||||||
t.links[node] = link
|
t.links[node] = link
|
||||||
t.Unlock()
|
t.Unlock()
|
||||||
}()
|
}(node)
|
||||||
}
|
}
|
||||||
|
|
||||||
// wait for all threads to finish
|
// wait for all threads to finish
|
||||||
@ -801,6 +801,7 @@ func (t *tun) setupLink(node string) (*link, error) {
|
|||||||
"Micro-Tunnel-Id": t.id,
|
"Micro-Tunnel-Id": t.id,
|
||||||
},
|
},
|
||||||
}); err != nil {
|
}); err != nil {
|
||||||
|
link.Close()
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -65,12 +65,24 @@ func (t *tunListener) process() {
|
|||||||
return
|
return
|
||||||
// receive a new message
|
// receive a new message
|
||||||
case m := <-t.session.recv:
|
case m := <-t.session.recv:
|
||||||
// session id
|
var sessionId string
|
||||||
sessionId := m.session
|
var linkId string
|
||||||
|
|
||||||
|
switch m.mode {
|
||||||
|
case Multicast:
|
||||||
|
sessionId = "multicast"
|
||||||
|
linkId = "multicast"
|
||||||
|
case Broadcast:
|
||||||
|
sessionId = "broadcast"
|
||||||
|
linkId = "broadcast"
|
||||||
|
default:
|
||||||
|
sessionId = m.session
|
||||||
|
linkId = m.link
|
||||||
|
}
|
||||||
|
|
||||||
// get a session
|
// get a session
|
||||||
sess, ok := conns[sessionId]
|
sess, ok := conns[sessionId]
|
||||||
log.Tracef("Tunnel listener received channel %s session %s type %s exists: %t", m.channel, sessionId, m.typ, ok)
|
log.Tracef("Tunnel listener received channel %s session %s type %s exists: %t", m.channel, m.session, m.typ, ok)
|
||||||
if !ok {
|
if !ok {
|
||||||
// we only process open and session types
|
// we only process open and session types
|
||||||
switch m.typ {
|
switch m.typ {
|
||||||
@ -92,7 +104,7 @@ func (t *tunListener) process() {
|
|||||||
// is loopback conn
|
// is loopback conn
|
||||||
loopback: m.loopback,
|
loopback: m.loopback,
|
||||||
// the link the message was received on
|
// the link the message was received on
|
||||||
link: m.link,
|
link: linkId,
|
||||||
// set the connection mode
|
// set the connection mode
|
||||||
mode: m.mode,
|
mode: m.mode,
|
||||||
// close chan
|
// close chan
|
||||||
|
@ -400,6 +400,12 @@ func (s *session) Recv(m *transport.Message) error {
|
|||||||
msg.data.Header[k] = string(val)
|
msg.data.Header[k] = string(val)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// set the link
|
||||||
|
// TODO: decruft, this is only for multicast
|
||||||
|
// since the session is now a single session
|
||||||
|
// likely provide as part of message.Link()
|
||||||
|
msg.data.Header["Micro-Link"] = msg.link
|
||||||
|
|
||||||
// set message
|
// set message
|
||||||
*m = *msg.data
|
*m = *msg.data
|
||||||
// return nil
|
// return nil
|
||||||
|
Loading…
x
Reference in New Issue
Block a user