Merge pull request #311 from neilalexander/sintf

Fix source address selection when sintf specified
This commit is contained in:
Neil Alexander 2019-01-16 14:59:20 +00:00 committed by GitHub
commit 4b6c925cb4
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -230,35 +230,38 @@ func (iface *tcpInterface) call(saddr string, socksaddr *string, sintf string) {
ief, err := net.InterfaceByName(sintf) ief, err := net.InterfaceByName(sintf)
if err != nil { if err != nil {
return return
} else { }
if ief.Flags&net.FlagUp == 0 { if ief.Flags&net.FlagUp == 0 {
return
}
addrs, err := ief.Addrs()
if err == nil {
dst, err := net.ResolveTCPAddr("tcp", saddr)
if err != nil {
return return
} }
addrs, err := ief.Addrs() for addrindex, addr := range addrs {
if err == nil { src, _, err := net.ParseCIDR(addr.String())
dst, err := net.ResolveTCPAddr("tcp", saddr)
if err != nil { if err != nil {
return continue
} }
for _, addr := range addrs { if (src.To4() != nil) == (dst.IP.To4() != nil) {
src, _, err := net.ParseCIDR(addr.String()) if addrindex == len(addrs)-1 || src.IsGlobalUnicast() {
if err != nil {
continue
}
if (src.To4() != nil) == (dst.IP.To4() != nil) && src.IsGlobalUnicast() {
dialer.LocalAddr = &net.TCPAddr{ dialer.LocalAddr = &net.TCPAddr{
IP: src, IP: src,
Port: 0, Port: 0,
Zone: sintf,
} }
break break
} }
} }
if dialer.LocalAddr == nil { }
return if dialer.LocalAddr == nil {
} return
} }
} }
} }
conn, err = dialer.Dial("tcp", saddr) conn, err = dialer.Dial("tcp", saddr)
if err != nil { if err != nil {
return return