| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273 | package tcpimport (	"net"	"crypto/tls"	"v2ray.com/core/common/log"	v2net "v2ray.com/core/common/net"	"v2ray.com/core/transport/internet"	v2tls "v2ray.com/core/transport/internet/tls")var (	globalCache = NewConnectionCache())func Dial(src v2net.Address, dest v2net.Destination, options internet.DialerOptions) (internet.Connection, error) {	log.Info("Dailing TCP to ", dest)	if src == nil {		src = v2net.AnyIP	}	networkSettings, err := options.Stream.GetEffectiveNetworkSettings()	if err != nil {		return nil, err	}	tcpSettings := networkSettings.(*Config)	id := src.String() + "-" + dest.NetAddr()	var conn net.Conn	if dest.Network == v2net.Network_TCP && tcpSettings.ConnectionReuse.IsEnabled() {		conn = globalCache.Get(id)	}	if conn == nil {		var err error		conn, err = internet.DialToDest(src, dest)		if err != nil {			return nil, err		}	}	if options.Stream != nil && options.Stream.HasSecuritySettings() {		securitySettings, err := options.Stream.GetEffectiveSecuritySettings()		if err != nil {			log.Error("TCP: Failed to get security settings: ", err)			return nil, err		}		tlsConfig, ok := securitySettings.(*v2tls.Config)		if ok {			config := tlsConfig.GetTLSConfig()			if dest.Address.Family().IsDomain() {				config.ServerName = dest.Address.Domain()			}			conn = tls.Client(conn, config)		}	}	return NewConnection(id, conn, globalCache, tcpSettings), nil}func DialRaw(src v2net.Address, dest v2net.Destination, options internet.DialerOptions) (internet.Connection, error) {	log.Info("Dailing Raw TCP to ", dest)	conn, err := internet.DialToDest(src, dest)	if err != nil {		return nil, err	}	// TODO: handle dialer options	return &RawConnection{		TCPConn: *conn.(*net.TCPConn),	}, nil}func init() {	internet.TCPDialer = Dial	internet.RawTCPDialer = DialRaw}
 |