mirror of
https://github.com/yggdrasil-network/yggdrasil-go.git
synced 2025-04-28 22:25:07 +03:00
Don't leak interface name via multicast, ensure zone is always correct when dialling link-local
This commit is contained in:
parent
a0e6edd219
commit
03eec4b14d
2 changed files with 17 additions and 9 deletions
|
@ -259,6 +259,16 @@ func (t *tcp) call(saddr string, options interface{}, sintf string) {
|
|||
}
|
||||
t.handler(conn, false, dialerdst.String())
|
||||
} else {
|
||||
dst, err := net.ResolveTCPAddr("tcp", saddr)
|
||||
if err != nil {
|
||||
return
|
||||
}
|
||||
if dst.IP.IsLinkLocalUnicast() {
|
||||
dst.Zone = sintf
|
||||
if dst.Zone == "" {
|
||||
return
|
||||
}
|
||||
}
|
||||
dialer := net.Dialer{
|
||||
Control: t.tcpContext,
|
||||
}
|
||||
|
@ -272,10 +282,6 @@ func (t *tcp) call(saddr string, options interface{}, sintf string) {
|
|||
}
|
||||
addrs, err := ief.Addrs()
|
||||
if err == nil {
|
||||
dst, err := net.ResolveTCPAddr("tcp", saddr)
|
||||
if err != nil {
|
||||
return
|
||||
}
|
||||
for addrindex, addr := range addrs {
|
||||
src, _, err := net.ParseCIDR(addr.String())
|
||||
if err != nil {
|
||||
|
@ -309,9 +315,9 @@ func (t *tcp) call(saddr string, options interface{}, sintf string) {
|
|||
}
|
||||
}
|
||||
}
|
||||
|
||||
conn, err = dialer.Dial("tcp", saddr)
|
||||
conn, err = dialer.Dial("tcp", dst.String())
|
||||
if err != nil {
|
||||
t.link.core.log.Debugln("Failed to dial TCP:", err)
|
||||
return
|
||||
}
|
||||
t.handler(conn, false, nil)
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue