system_dialer.go 4.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181
  1. package internet
  2. import (
  3. "context"
  4. "syscall"
  5. "time"
  6. "v2ray.com/core/common/net"
  7. "v2ray.com/core/common/session"
  8. )
  9. var (
  10. effectiveSystemDialer SystemDialer = &DefaultSystemDialer{}
  11. )
  12. type SystemDialer interface {
  13. Dial(ctx context.Context, source net.Address, destination net.Destination, sockopt *SocketConfig) (net.Conn, error)
  14. }
  15. type DefaultSystemDialer struct {
  16. controllers []controller
  17. }
  18. func resolveSrcAddr(network net.Network, src net.Address) net.Addr {
  19. if src == nil || src == net.AnyIP {
  20. return nil
  21. }
  22. if network == net.Network_TCP {
  23. return &net.TCPAddr{
  24. IP: src.IP(),
  25. Port: 0,
  26. }
  27. }
  28. return &net.UDPAddr{
  29. IP: src.IP(),
  30. Port: 0,
  31. }
  32. }
  33. func (d *DefaultSystemDialer) Dial(ctx context.Context, src net.Address, dest net.Destination, sockopt *SocketConfig) (net.Conn, error) {
  34. if dest.Network == net.Network_UDP {
  35. srcAddr := resolveSrcAddr(net.Network_UDP, src)
  36. if srcAddr == nil {
  37. srcAddr = &net.UDPAddr{
  38. IP: []byte{0, 0, 0, 0},
  39. Port: 0,
  40. }
  41. }
  42. packetConn, err := ListenSystemPacket(ctx, srcAddr, sockopt)
  43. if err != nil {
  44. return nil, err
  45. }
  46. destAddr, err := net.ResolveUDPAddr("udp", dest.NetAddr())
  47. if err != nil {
  48. return nil, err
  49. }
  50. return &packetConnWrapper{
  51. conn: packetConn,
  52. dest: destAddr,
  53. }, nil
  54. }
  55. dialer := &net.Dialer{
  56. Timeout: time.Second * 60,
  57. DualStack: true,
  58. LocalAddr: resolveSrcAddr(dest.Network, src),
  59. }
  60. if sockopt != nil || len(d.controllers) > 0 {
  61. dialer.Control = func(network, address string, c syscall.RawConn) error {
  62. return c.Control(func(fd uintptr) {
  63. if sockopt != nil {
  64. if err := applyOutboundSocketOptions(network, address, fd, sockopt); err != nil {
  65. newError("failed to apply socket options").Base(err).WriteToLog(session.ExportIDToError(ctx))
  66. }
  67. if dest.Network == net.Network_UDP && len(sockopt.BindAddress) > 0 && sockopt.BindPort > 0 {
  68. if err := bindAddr(fd, sockopt.BindAddress, sockopt.BindPort); err != nil {
  69. newError("failed to bind source address to ", sockopt.BindAddress).Base(err).WriteToLog(session.ExportIDToError(ctx))
  70. }
  71. }
  72. }
  73. for _, ctl := range d.controllers {
  74. if err := ctl(network, address, fd); err != nil {
  75. newError("failed to apply external controller").Base(err).WriteToLog(session.ExportIDToError(ctx))
  76. }
  77. }
  78. })
  79. }
  80. }
  81. return dialer.DialContext(ctx, dest.Network.SystemString(), dest.NetAddr())
  82. }
  83. type packetConnWrapper struct {
  84. conn net.PacketConn
  85. dest net.Addr
  86. }
  87. func (c *packetConnWrapper) Close() error {
  88. return c.conn.Close()
  89. }
  90. func (c *packetConnWrapper) LocalAddr() net.Addr {
  91. return c.conn.LocalAddr()
  92. }
  93. func (c *packetConnWrapper) RemoteAddr() net.Addr {
  94. return c.dest
  95. }
  96. func (c *packetConnWrapper) Write(p []byte) (int, error) {
  97. return c.conn.WriteTo(p, c.dest)
  98. }
  99. func (c *packetConnWrapper) Read(p []byte) (int, error) {
  100. n, _, err := c.conn.ReadFrom(p)
  101. return n, err
  102. }
  103. func (c *packetConnWrapper) SetDeadline(t time.Time) error {
  104. return c.conn.SetDeadline(t)
  105. }
  106. func (c *packetConnWrapper) SetReadDeadline(t time.Time) error {
  107. return c.conn.SetReadDeadline(t)
  108. }
  109. func (c *packetConnWrapper) SetWriteDeadline(t time.Time) error {
  110. return c.conn.SetWriteDeadline(t)
  111. }
  112. type SystemDialerAdapter interface {
  113. Dial(network string, address string) (net.Conn, error)
  114. }
  115. type SimpleSystemDialer struct {
  116. adapter SystemDialerAdapter
  117. }
  118. func WithAdapter(dialer SystemDialerAdapter) SystemDialer {
  119. return &SimpleSystemDialer{
  120. adapter: dialer,
  121. }
  122. }
  123. func (v *SimpleSystemDialer) Dial(ctx context.Context, src net.Address, dest net.Destination, sockopt *SocketConfig) (net.Conn, error) {
  124. return v.adapter.Dial(dest.Network.SystemString(), dest.NetAddr())
  125. }
  126. // UseAlternativeSystemDialer replaces the current system dialer with a given one.
  127. // Caller must ensure there is no race condition.
  128. //
  129. // v2ray:api:stable
  130. func UseAlternativeSystemDialer(dialer SystemDialer) {
  131. if dialer == nil {
  132. effectiveSystemDialer = &DefaultSystemDialer{}
  133. }
  134. effectiveSystemDialer = dialer
  135. }
  136. // RegisterDialerController adds a controller to the effective system dialer.
  137. // The controller can be used to operate on file descriptors before they are put into use.
  138. // It only works when effective dialer is the default dialer.
  139. //
  140. // v2ray:api:beta
  141. func RegisterDialerController(ctl func(network, address string, fd uintptr) error) error {
  142. if ctl == nil {
  143. return newError("nil listener controller")
  144. }
  145. dialer, ok := effectiveSystemDialer.(*DefaultSystemDialer)
  146. if !ok {
  147. return newError("RegisterListenerController not supported in custom dialer")
  148. }
  149. dialer.controllers = append(dialer.controllers, ctl)
  150. return nil
  151. }