Merge pull request #2281 from lucifer9/fixudpv6

fix tproxy udp "unable to get destination" in IPv6 environment
pull/2287/head
Kslr 5 years ago committed by GitHub
commit 333d20d7d9
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

@ -3,6 +3,7 @@ package internet
import ( import (
"net" "net"
"syscall" "syscall"
"golang.org/x/sys/unix" "golang.org/x/sys/unix"
) )
@ -99,8 +100,10 @@ func applyInboundSocketOptions(network string, fd uintptr, config *SocketConfig)
} }
if config.ReceiveOriginalDestAddress && isUDPSocket(network) { if config.ReceiveOriginalDestAddress && isUDPSocket(network) {
if err := syscall.SetsockoptInt(int(fd), syscall.SOL_IP, syscall.IP_RECVORIGDSTADDR, 1); err != nil { if err := syscall.SetsockoptInt(int(fd), syscall.SOL_IPV6, unix.IPV6_RECVORIGDSTADDR, 1); err != nil {
return err if err := syscall.SetsockoptInt(int(fd), syscall.SOL_IP, syscall.IP_RECVORIGDSTADDR, 1); err != nil {
return err
}
} }
} }

@ -5,6 +5,7 @@ package udp
import ( import (
"syscall" "syscall"
"golang.org/x/sys/unix"
"v2ray.com/core/common/net" "v2ray.com/core/common/net"
) )
@ -18,7 +19,7 @@ func RetrieveOriginalDest(oob []byte) net.Destination {
ip := net.IPAddress(msg.Data[4:8]) ip := net.IPAddress(msg.Data[4:8])
port := net.PortFromBytes(msg.Data[2:4]) port := net.PortFromBytes(msg.Data[2:4])
return net.UDPDestination(ip, port) return net.UDPDestination(ip, port)
} else if msg.Header.Level == syscall.SOL_IPV6 && msg.Header.Type == syscall.IP_RECVORIGDSTADDR { } else if msg.Header.Level == syscall.SOL_IPV6 && msg.Header.Type == unix.IPV6_RECVORIGDSTADDR {
ip := net.IPAddress(msg.Data[8:24]) ip := net.IPAddress(msg.Data[8:24])
port := net.PortFromBytes(msg.Data[2:4]) port := net.PortFromBytes(msg.Data[2:4])
return net.UDPDestination(ip, port) return net.UDPDestination(ip, port)

Loading…
Cancel
Save