From 89b14ebaee6ca7a0b47646c0e89ad60cd1b5ef03 Mon Sep 17 00:00:00 2001 From: Cong Ding Date: Thu, 19 May 2016 13:12:44 -0500 Subject: [PATCH] allow non-changed addr in test1 (fix #9) --- stun/discover.go | 9 +++++++-- 1 file changed, 7 insertions(+), 2 deletions(-) diff --git a/stun/discover.go b/stun/discover.go index c5f2588..8006465 100644 --- a/stun/discover.go +++ b/stun/discover.go @@ -116,16 +116,17 @@ func test1(conn net.PacketConn, addr net.Addr, softwareName string) (*packet, ne } } + identical := isLocalAddress(conn.LocalAddr().String(), hostMappedAddr.TransportAddr()) + hostChangedAddr := packet.changedAddr() if hostChangedAddr == nil { - return nil, nil, false, nil, errors.New("No changed address.") + return packet, nil, identical, hostMappedAddr, nil } changeAddrStr := hostChangedAddr.TransportAddr() changeAddr, err := net.ResolveUDPAddr("udp", changeAddrStr) if err != nil { return nil, nil, false, nil, errors.New("Failed to resolve changed address.") } - identical := isLocalAddress(conn.LocalAddr().String(), hostMappedAddr.TransportAddr()) return packet, changeAddr, identical, hostMappedAddr, nil } @@ -208,6 +209,10 @@ func discover(conn net.PacketConn, addr net.Addr, softwareName string) (NATType, return NAT_ERROR, nil, err } + if changeAddr == nil { + return NAT_ERROR, host, errors.New("No changed address.") + } + packet, _, identical, _, err = test1(otherConn, changeAddr, softwareName) if err != nil { return NAT_ERROR, host, err