system_dialer.go 7.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282
  1. package internet
  2. import (
  3. "context"
  4. "math/rand"
  5. "syscall"
  6. "time"
  7. "github.com/sagernet/sing/common/control"
  8. "github.com/xtls/xray-core/common/errors"
  9. "github.com/xtls/xray-core/common/net"
  10. "github.com/xtls/xray-core/features/dns"
  11. "github.com/xtls/xray-core/features/outbound"
  12. )
  13. var effectiveSystemDialer SystemDialer = &DefaultSystemDialer{}
  14. type SystemDialer interface {
  15. Dial(ctx context.Context, source net.Address, destination net.Destination, sockopt *SocketConfig) (net.Conn, error)
  16. DestIpAddress() net.IP
  17. }
  18. type DefaultSystemDialer struct {
  19. controllers []control.Func
  20. dns dns.Client
  21. obm outbound.Manager
  22. }
  23. func resolveSrcAddr(network net.Network, src net.Address) net.Addr {
  24. if src == nil || src == net.AnyIP {
  25. return nil
  26. }
  27. if network == net.Network_TCP {
  28. return &net.TCPAddr{
  29. IP: src.IP(),
  30. Port: 0,
  31. }
  32. }
  33. return &net.UDPAddr{
  34. IP: src.IP(),
  35. Port: 0,
  36. }
  37. }
  38. func hasBindAddr(sockopt *SocketConfig) bool {
  39. return sockopt != nil && len(sockopt.BindAddress) > 0 && sockopt.BindPort > 0
  40. }
  41. func (d *DefaultSystemDialer) Dial(ctx context.Context, src net.Address, dest net.Destination, sockopt *SocketConfig) (net.Conn, error) {
  42. errors.LogDebug(ctx, "dialing to "+dest.String())
  43. if dest.Network == net.Network_UDP && !hasBindAddr(sockopt) {
  44. srcAddr := resolveSrcAddr(net.Network_UDP, src)
  45. if srcAddr == nil {
  46. srcAddr = &net.UDPAddr{
  47. IP: []byte{0, 0, 0, 0},
  48. Port: 0,
  49. }
  50. }
  51. var lc net.ListenConfig
  52. destAddr, err := net.ResolveUDPAddr("udp", dest.NetAddr())
  53. if err != nil {
  54. return nil, err
  55. }
  56. lc.Control = func(network, address string, c syscall.RawConn) error {
  57. for _, ctl := range d.controllers {
  58. if err := ctl(network, address, c); err != nil {
  59. errors.LogInfoInner(ctx, err, "failed to apply external controller")
  60. }
  61. }
  62. return c.Control(func(fd uintptr) {
  63. if sockopt != nil {
  64. if err := applyOutboundSocketOptions(network, destAddr.String(), fd, sockopt); err != nil {
  65. errors.LogInfo(ctx, err, "failed to apply socket options")
  66. }
  67. }
  68. })
  69. }
  70. packetConn, err := lc.ListenPacket(ctx, srcAddr.Network(), srcAddr.String())
  71. if err != nil {
  72. return nil, err
  73. }
  74. return &PacketConnWrapper{
  75. Conn: packetConn,
  76. Dest: destAddr,
  77. }, nil
  78. }
  79. // Chrome defaults
  80. keepAliveConfig := net.KeepAliveConfig{
  81. Enable: true,
  82. Idle: 45 * time.Second,
  83. Interval: 45 * time.Second,
  84. Count: -1,
  85. }
  86. keepAlive := time.Duration(0)
  87. if sockopt != nil {
  88. if sockopt.TcpKeepAliveIdle*sockopt.TcpKeepAliveInterval < 0 {
  89. return nil, errors.New("invalid TcpKeepAliveIdle or TcpKeepAliveInterval value: ", sockopt.TcpKeepAliveIdle, " ", sockopt.TcpKeepAliveInterval)
  90. }
  91. if sockopt.TcpKeepAliveIdle < 0 || sockopt.TcpKeepAliveInterval < 0 {
  92. keepAlive = -1
  93. keepAliveConfig.Enable = false
  94. }
  95. if sockopt.TcpKeepAliveIdle > 0 {
  96. keepAliveConfig.Idle = time.Duration(sockopt.TcpKeepAliveIdle) * time.Second
  97. }
  98. if sockopt.TcpKeepAliveInterval > 0 {
  99. keepAliveConfig.Interval = time.Duration(sockopt.TcpKeepAliveInterval) * time.Second
  100. }
  101. }
  102. dialer := &net.Dialer{
  103. Timeout: time.Second * 16,
  104. LocalAddr: resolveSrcAddr(dest.Network, src),
  105. KeepAlive: keepAlive,
  106. KeepAliveConfig: keepAliveConfig,
  107. }
  108. if sockopt != nil || len(d.controllers) > 0 {
  109. if sockopt != nil && sockopt.TcpMptcp {
  110. dialer.SetMultipathTCP(true)
  111. }
  112. dialer.Control = func(network, address string, c syscall.RawConn) error {
  113. for _, ctl := range d.controllers {
  114. if err := ctl(network, address, c); err != nil {
  115. errors.LogInfoInner(ctx, err, "failed to apply external controller")
  116. }
  117. }
  118. return c.Control(func(fd uintptr) {
  119. if sockopt != nil {
  120. if err := applyOutboundSocketOptions(network, address, fd, sockopt); err != nil {
  121. errors.LogInfoInner(ctx, err, "failed to apply socket options")
  122. }
  123. if dest.Network == net.Network_UDP && hasBindAddr(sockopt) {
  124. if err := bindAddr(fd, sockopt.BindAddress, sockopt.BindPort); err != nil {
  125. errors.LogInfoInner(ctx, err, "failed to bind source address to ", sockopt.BindAddress)
  126. }
  127. }
  128. }
  129. })
  130. }
  131. }
  132. return dialer.DialContext(ctx, dest.Network.SystemString(), dest.NetAddr())
  133. }
  134. func (d *DefaultSystemDialer) DestIpAddress() net.IP {
  135. return nil
  136. }
  137. type PacketConnWrapper struct {
  138. Conn net.PacketConn
  139. Dest net.Addr
  140. }
  141. func (c *PacketConnWrapper) Close() error {
  142. return c.Conn.Close()
  143. }
  144. func (c *PacketConnWrapper) LocalAddr() net.Addr {
  145. return c.Conn.LocalAddr()
  146. }
  147. func (c *PacketConnWrapper) RemoteAddr() net.Addr {
  148. return c.Dest
  149. }
  150. func (c *PacketConnWrapper) Write(p []byte) (int, error) {
  151. return c.Conn.WriteTo(p, c.Dest)
  152. }
  153. func (c *PacketConnWrapper) Read(p []byte) (int, error) {
  154. n, _, err := c.Conn.ReadFrom(p)
  155. return n, err
  156. }
  157. func (c *PacketConnWrapper) WriteTo(p []byte, d net.Addr) (int, error) {
  158. return c.Conn.WriteTo(p, d)
  159. }
  160. func (c *PacketConnWrapper) ReadFrom(p []byte) (int, net.Addr, error) {
  161. return c.Conn.ReadFrom(p)
  162. }
  163. func (c *PacketConnWrapper) SetDeadline(t time.Time) error {
  164. return c.Conn.SetDeadline(t)
  165. }
  166. func (c *PacketConnWrapper) SetReadDeadline(t time.Time) error {
  167. return c.Conn.SetReadDeadline(t)
  168. }
  169. func (c *PacketConnWrapper) SetWriteDeadline(t time.Time) error {
  170. return c.Conn.SetWriteDeadline(t)
  171. }
  172. func (c *PacketConnWrapper) SyscallConn() (syscall.RawConn, error) {
  173. sc, ok := c.Conn.(syscall.Conn)
  174. if !ok {
  175. return nil, syscall.EINVAL
  176. }
  177. return sc.SyscallConn()
  178. }
  179. type SystemDialerAdapter interface {
  180. Dial(network string, address string) (net.Conn, error)
  181. }
  182. type SimpleSystemDialer struct {
  183. adapter SystemDialerAdapter
  184. }
  185. func WithAdapter(dialer SystemDialerAdapter) SystemDialer {
  186. return &SimpleSystemDialer{
  187. adapter: dialer,
  188. }
  189. }
  190. func (v *SimpleSystemDialer) Dial(ctx context.Context, src net.Address, dest net.Destination, sockopt *SocketConfig) (net.Conn, error) {
  191. return v.adapter.Dial(dest.Network.SystemString(), dest.NetAddr())
  192. }
  193. func (d *SimpleSystemDialer) DestIpAddress() net.IP {
  194. return nil
  195. }
  196. // UseAlternativeSystemDialer replaces the current system dialer with a given one.
  197. // Caller must ensure there is no race condition.
  198. //
  199. // xray:api:stable
  200. func UseAlternativeSystemDialer(dialer SystemDialer) {
  201. if dialer == nil {
  202. dialer = &DefaultSystemDialer{}
  203. }
  204. effectiveSystemDialer = dialer
  205. }
  206. // RegisterDialerController adds a controller to the effective system dialer.
  207. // The controller can be used to operate on file descriptors before they are put into use.
  208. // It only works when effective dialer is the default dialer.
  209. //
  210. // xray:api:beta
  211. func RegisterDialerController(ctl control.Func) error {
  212. if ctl == nil {
  213. return errors.New("nil listener controller")
  214. }
  215. dialer, ok := effectiveSystemDialer.(*DefaultSystemDialer)
  216. if !ok {
  217. return errors.New("RegisterListenerController not supported in custom dialer")
  218. }
  219. dialer.controllers = append(dialer.controllers, ctl)
  220. return nil
  221. }
  222. type FakePacketConn struct {
  223. net.Conn
  224. }
  225. func (c *FakePacketConn) ReadFrom(p []byte) (n int, addr net.Addr, err error) {
  226. n, err = c.Read(p)
  227. return n, c.RemoteAddr(), err
  228. }
  229. func (c *FakePacketConn) WriteTo(p []byte, _ net.Addr) (n int, err error) {
  230. return c.Write(p)
  231. }
  232. func (c *FakePacketConn) LocalAddr() net.Addr {
  233. return &net.TCPAddr{
  234. IP: net.IP{byte(rand.Intn(256)), byte(rand.Intn(256)), byte(rand.Intn(256)), byte(rand.Intn(256))},
  235. Port: rand.Intn(65536),
  236. }
  237. }
  238. func (c *FakePacketConn) SetReadBuffer(bytes int) error {
  239. // do nothing, this function is only there to suppress quic-go printing
  240. // random warnings about UDP buffers to stdout
  241. return nil
  242. }