1
0
mirror of https://github.com/v2fly/v2ray-core.git synced 2025-01-08 10:27:10 -05:00

fix getting sys fd

This commit is contained in:
Darien Raymond 2017-04-18 12:02:43 +02:00
parent 35acdb8385
commit 40f890e638
No known key found for this signature in database
GPG Key ID: 7251FFA14BB18169
3 changed files with 38 additions and 13 deletions

View File

@ -6,7 +6,7 @@ import (
) )
var ( var (
errInvalidConn = newError("Invalid Connection.") errInvalidConn = newError("not a net.Conn")
) )
// GetSysFd returns the underlying fd of a connection. // GetSysFd returns the underlying fd of a connection.

View File

@ -3,33 +3,30 @@
package tcp package tcp
import ( import (
"net"
"syscall" "syscall"
"v2ray.com/core/app/log" "v2ray.com/core/app/log"
"v2ray.com/core/common/net" v2net "v2ray.com/core/common/net"
"v2ray.com/core/transport/internet" "v2ray.com/core/transport/internet"
"v2ray.com/core/transport/internet/internal"
) )
const SO_ORIGINAL_DST = 80 const SO_ORIGINAL_DST = 80
func GetOriginalDestination(conn internet.Connection) net.Destination { func GetOriginalDestination(conn internet.Connection) v2net.Destination {
tcpConn, ok := conn.(internet.SysFd) fd, err := internal.GetSysFd(conn.(net.Conn))
if !ok {
log.Trace(newError("failed to get sys fd"))
return net.Destination{}
}
fd, err := tcpConn.SysFd()
if err != nil { if err != nil {
log.Trace(newError("failed to get original destination").Base(err)) log.Trace(newError("failed to get original destination").Base(err))
return net.Destination{} return v2net.Destination{}
} }
addr, err := syscall.GetsockoptIPv6Mreq(fd, syscall.IPPROTO_IP, SO_ORIGINAL_DST) addr, err := syscall.GetsockoptIPv6Mreq(fd, syscall.IPPROTO_IP, SO_ORIGINAL_DST)
if err != nil { if err != nil {
log.Trace(newError("failed to call getsockopt").Base(err)) log.Trace(newError("failed to call getsockopt").Base(err))
return net.Destination{} return v2net.Destination{}
} }
ip := net.IPAddress(addr.Multiaddr[4:8]) ip := v2net.IPAddress(addr.Multiaddr[4:8])
port := uint16(addr.Multiaddr[2])<<8 + uint16(addr.Multiaddr[3]) port := uint16(addr.Multiaddr[2])<<8 + uint16(addr.Multiaddr[3])
return net.TCPDestination(ip, net.Port(port)) return v2net.TCPDestination(ip, v2net.Port(port))
} }

View File

@ -0,0 +1,28 @@
// +build linux
package tcp_test
import (
"context"
"testing"
"v2ray.com/core/testing/assert"
"v2ray.com/core/testing/servers/tcp"
)
func TestGetOriginalDestination(t *testing.T) {
assert := assert.On(t)
tcpServer := tcp.Server{
MsgProcessor: xor,
}
dest, err := tcpServer.Start()
assert.Error(err).IsNil()
defer tcpServer.Close()
conn, err := Dial(context.Background(), dest)
assert.Error(err).IsNil()
_, err := GetOriginalDestination(conn)
assert.String(err.Error()).Contains("failed to call getsockopt")
}