| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465 |
- package tcp
- import (
- "context"
- "crypto/tls"
- "net"
- "v2ray.com/core/app/log"
- "v2ray.com/core/common"
- "v2ray.com/core/common/errors"
- v2net "v2ray.com/core/common/net"
- "v2ray.com/core/transport/internet"
- "v2ray.com/core/transport/internet/internal"
- v2tls "v2ray.com/core/transport/internet/tls"
- )
- var (
- globalCache = internal.NewConnectionPool()
- )
- func Dial(ctx context.Context, dest v2net.Destination) (internet.Connection, error) {
- log.Info("Internet|TCP: Dailing TCP to ", dest)
- src := internet.DialerSourceFromContext(ctx)
- tcpSettings := internet.TransportSettingsFromContext(ctx).(*Config)
- id := internal.NewConnectionID(src, dest)
- var conn net.Conn
- if dest.Network == v2net.Network_TCP && tcpSettings.IsConnectionReuse() {
- conn = globalCache.Get(id)
- }
- if conn == nil {
- var err error
- conn, err = internet.DialSystem(src, dest)
- if err != nil {
- return nil, err
- }
- if securitySettings := internet.SecuritySettingsFromContext(ctx); securitySettings != nil {
- 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)
- }
- }
- if tcpSettings.HeaderSettings != nil {
- headerConfig, err := tcpSettings.HeaderSettings.GetInstance()
- if err != nil {
- return nil, errors.Base(err).Message("Interent|TCP: Failed to get header settings.")
- }
- auth, err := internet.CreateConnectionAuthenticator(headerConfig)
- if err != nil {
- return nil, errors.Base(err).Message("Internet|TCP: Failed to create header authenticator.")
- }
- conn = auth.Client(conn)
- }
- }
- return internal.NewConnection(id, conn, globalCache, internal.ReuseConnection(tcpSettings.IsConnectionReuse())), nil
- }
- func init() {
- common.Must(internet.RegisterTransportDialer(internet.TransportProtocol_TCP, Dial))
- }
|