socks_test.go 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481
  1. package scenarios
  2. import (
  3. "testing"
  4. "time"
  5. "github.com/xtls/xray-core/app/proxyman"
  6. "github.com/xtls/xray-core/app/router"
  7. "github.com/xtls/xray-core/common"
  8. "github.com/xtls/xray-core/common/net"
  9. "github.com/xtls/xray-core/common/protocol"
  10. "github.com/xtls/xray-core/common/serial"
  11. "github.com/xtls/xray-core/core"
  12. "github.com/xtls/xray-core/proxy/blackhole"
  13. "github.com/xtls/xray-core/proxy/dokodemo"
  14. "github.com/xtls/xray-core/proxy/freedom"
  15. "github.com/xtls/xray-core/proxy/http"
  16. "github.com/xtls/xray-core/proxy/socks"
  17. "github.com/xtls/xray-core/testing/servers/tcp"
  18. "github.com/xtls/xray-core/testing/servers/udp"
  19. xproxy "golang.org/x/net/proxy"
  20. socks4 "h12.io/socks"
  21. )
  22. func TestSocksBridgeTCP(t *testing.T) {
  23. tcpServer := tcp.Server{
  24. MsgProcessor: xor,
  25. }
  26. dest, err := tcpServer.Start()
  27. common.Must(err)
  28. defer tcpServer.Close()
  29. serverPort := tcp.PickPort()
  30. serverConfig := &core.Config{
  31. Inbound: []*core.InboundHandlerConfig{
  32. {
  33. ReceiverSettings: serial.ToTypedMessage(&proxyman.ReceiverConfig{
  34. PortList: &net.PortList{Range: []*net.PortRange{net.SinglePortRange(serverPort)}},
  35. Listen: net.NewIPOrDomain(net.LocalHostIP),
  36. }),
  37. ProxySettings: serial.ToTypedMessage(&socks.ServerConfig{
  38. AuthType: socks.AuthType_PASSWORD,
  39. Accounts: map[string]string{
  40. "Test Account": "Test Password",
  41. },
  42. Address: net.NewIPOrDomain(net.LocalHostIP),
  43. UdpEnabled: false,
  44. }),
  45. },
  46. },
  47. Outbound: []*core.OutboundHandlerConfig{
  48. {
  49. ProxySettings: serial.ToTypedMessage(&freedom.Config{}),
  50. },
  51. },
  52. }
  53. clientPort := tcp.PickPort()
  54. clientConfig := &core.Config{
  55. Inbound: []*core.InboundHandlerConfig{
  56. {
  57. ReceiverSettings: serial.ToTypedMessage(&proxyman.ReceiverConfig{
  58. PortList: &net.PortList{Range: []*net.PortRange{net.SinglePortRange(clientPort)}},
  59. Listen: net.NewIPOrDomain(net.LocalHostIP),
  60. }),
  61. ProxySettings: serial.ToTypedMessage(&dokodemo.Config{
  62. Address: net.NewIPOrDomain(dest.Address),
  63. Port: uint32(dest.Port),
  64. Networks: []net.Network{net.Network_TCP},
  65. }),
  66. },
  67. },
  68. Outbound: []*core.OutboundHandlerConfig{
  69. {
  70. ProxySettings: serial.ToTypedMessage(&socks.ClientConfig{
  71. Server: &protocol.ServerEndpoint{
  72. Address: net.NewIPOrDomain(net.LocalHostIP),
  73. Port: uint32(serverPort),
  74. User: &protocol.User{
  75. Account: serial.ToTypedMessage(&socks.Account{
  76. Username: "Test Account",
  77. Password: "Test Password",
  78. }),
  79. },
  80. },
  81. }),
  82. },
  83. },
  84. }
  85. servers, err := InitializeServerConfigs(serverConfig, clientConfig)
  86. common.Must(err)
  87. defer CloseAllServers(servers)
  88. if err := testTCPConn(clientPort, 1024, time.Second*2)(); err != nil {
  89. t.Error(err)
  90. }
  91. }
  92. func TestSocksWithHttpRequest(t *testing.T) {
  93. tcpServer := tcp.Server{
  94. MsgProcessor: xor,
  95. }
  96. dest, err := tcpServer.Start()
  97. common.Must(err)
  98. defer tcpServer.Close()
  99. serverPort := tcp.PickPort()
  100. serverConfig := &core.Config{
  101. Inbound: []*core.InboundHandlerConfig{
  102. {
  103. ReceiverSettings: serial.ToTypedMessage(&proxyman.ReceiverConfig{
  104. PortList: &net.PortList{Range: []*net.PortRange{net.SinglePortRange(serverPort)}},
  105. Listen: net.NewIPOrDomain(net.LocalHostIP),
  106. }),
  107. ProxySettings: serial.ToTypedMessage(&socks.ServerConfig{
  108. AuthType: socks.AuthType_PASSWORD,
  109. Accounts: map[string]string{
  110. "Test Account": "Test Password",
  111. },
  112. Address: net.NewIPOrDomain(net.LocalHostIP),
  113. UdpEnabled: false,
  114. }),
  115. },
  116. },
  117. Outbound: []*core.OutboundHandlerConfig{
  118. {
  119. ProxySettings: serial.ToTypedMessage(&freedom.Config{}),
  120. },
  121. },
  122. }
  123. clientPort := tcp.PickPort()
  124. clientConfig := &core.Config{
  125. Inbound: []*core.InboundHandlerConfig{
  126. {
  127. ReceiverSettings: serial.ToTypedMessage(&proxyman.ReceiverConfig{
  128. PortList: &net.PortList{Range: []*net.PortRange{net.SinglePortRange(clientPort)}},
  129. Listen: net.NewIPOrDomain(net.LocalHostIP),
  130. }),
  131. ProxySettings: serial.ToTypedMessage(&dokodemo.Config{
  132. Address: net.NewIPOrDomain(dest.Address),
  133. Port: uint32(dest.Port),
  134. Networks: []net.Network{net.Network_TCP},
  135. }),
  136. },
  137. },
  138. Outbound: []*core.OutboundHandlerConfig{
  139. {
  140. ProxySettings: serial.ToTypedMessage(&http.ClientConfig{
  141. Server: &protocol.ServerEndpoint{
  142. Address: net.NewIPOrDomain(net.LocalHostIP),
  143. Port: uint32(serverPort),
  144. User: &protocol.User{
  145. Account: serial.ToTypedMessage(&http.Account{
  146. Username: "Test Account",
  147. Password: "Test Password",
  148. }),
  149. },
  150. },
  151. }),
  152. },
  153. },
  154. }
  155. servers, err := InitializeServerConfigs(serverConfig, clientConfig)
  156. common.Must(err)
  157. defer CloseAllServers(servers)
  158. if err := testTCPConn(clientPort, 1024, time.Second*2)(); err != nil {
  159. t.Error(err)
  160. }
  161. }
  162. func TestSocksBridageUDP(t *testing.T) {
  163. udpServer := udp.Server{
  164. MsgProcessor: xor,
  165. }
  166. dest, err := udpServer.Start()
  167. common.Must(err)
  168. defer udpServer.Close()
  169. retry := 1
  170. serverPort := tcp.PickPort()
  171. for {
  172. serverConfig := &core.Config{
  173. Inbound: []*core.InboundHandlerConfig{
  174. {
  175. ReceiverSettings: serial.ToTypedMessage(&proxyman.ReceiverConfig{
  176. PortList: &net.PortList{Range: []*net.PortRange{net.SinglePortRange(serverPort)}},
  177. Listen: net.NewIPOrDomain(net.LocalHostIP),
  178. }),
  179. ProxySettings: serial.ToTypedMessage(&socks.ServerConfig{
  180. AuthType: socks.AuthType_PASSWORD,
  181. Accounts: map[string]string{
  182. "Test Account": "Test Password",
  183. },
  184. Address: net.NewIPOrDomain(net.LocalHostIP),
  185. UdpEnabled: true,
  186. }),
  187. },
  188. {
  189. ReceiverSettings: serial.ToTypedMessage(&proxyman.ReceiverConfig{
  190. PortList: &net.PortList{Range: []*net.PortRange{net.SinglePortRange(serverPort + 1)}},
  191. Listen: net.NewIPOrDomain(net.LocalHostIP),
  192. }),
  193. ProxySettings: serial.ToTypedMessage(&dokodemo.Config{
  194. Address: net.NewIPOrDomain(dest.Address),
  195. Port: uint32(dest.Port),
  196. Networks: []net.Network{net.Network_UDP},
  197. }),
  198. },
  199. },
  200. Outbound: []*core.OutboundHandlerConfig{
  201. {
  202. ProxySettings: serial.ToTypedMessage(&freedom.Config{}),
  203. },
  204. },
  205. }
  206. server, _ := InitializeServerConfig(serverConfig)
  207. if server != nil && WaitConnAvailableWithTest(t, testUDPConn(serverPort+1, 1024, time.Second*2)) {
  208. defer CloseServer(server)
  209. break
  210. }
  211. retry++
  212. if retry > 5 {
  213. t.Fatal("All attempts failed to start server")
  214. }
  215. serverPort = tcp.PickPort()
  216. }
  217. clientPort := udp.PickPort()
  218. clientConfig := &core.Config{
  219. Inbound: []*core.InboundHandlerConfig{
  220. {
  221. ReceiverSettings: serial.ToTypedMessage(&proxyman.ReceiverConfig{
  222. PortList: &net.PortList{Range: []*net.PortRange{net.SinglePortRange(clientPort)}},
  223. Listen: net.NewIPOrDomain(net.LocalHostIP),
  224. }),
  225. ProxySettings: serial.ToTypedMessage(&dokodemo.Config{
  226. Address: net.NewIPOrDomain(dest.Address),
  227. Port: uint32(dest.Port),
  228. Networks: []net.Network{net.Network_UDP},
  229. }),
  230. },
  231. },
  232. Outbound: []*core.OutboundHandlerConfig{
  233. {
  234. ProxySettings: serial.ToTypedMessage(&socks.ClientConfig{
  235. Server: &protocol.ServerEndpoint{
  236. Address: net.NewIPOrDomain(net.LocalHostIP),
  237. Port: uint32(serverPort),
  238. User: &protocol.User{
  239. Account: serial.ToTypedMessage(&socks.Account{
  240. Username: "Test Account",
  241. Password: "Test Password",
  242. }),
  243. },
  244. },
  245. }),
  246. },
  247. },
  248. }
  249. server, err := InitializeServerConfig(clientConfig)
  250. common.Must(err)
  251. defer CloseServer(server)
  252. if !WaitConnAvailableWithTest(t, testUDPConn(clientPort, 1024, time.Second*2)) {
  253. t.Fail()
  254. }
  255. }
  256. func TestSocksBridageUDPWithRouting(t *testing.T) {
  257. udpServer := udp.Server{
  258. MsgProcessor: xor,
  259. }
  260. dest, err := udpServer.Start()
  261. common.Must(err)
  262. defer udpServer.Close()
  263. retry := 1
  264. serverPort := tcp.PickPort()
  265. for {
  266. serverConfig := &core.Config{
  267. App: []*serial.TypedMessage{
  268. serial.ToTypedMessage(&router.Config{
  269. Rule: []*router.RoutingRule{
  270. {
  271. TargetTag: &router.RoutingRule_Tag{
  272. Tag: "out",
  273. },
  274. InboundTag: []string{"socks", "dokodemo"},
  275. },
  276. },
  277. }),
  278. },
  279. Inbound: []*core.InboundHandlerConfig{
  280. {
  281. Tag: "socks",
  282. ReceiverSettings: serial.ToTypedMessage(&proxyman.ReceiverConfig{
  283. PortList: &net.PortList{Range: []*net.PortRange{net.SinglePortRange(serverPort)}},
  284. Listen: net.NewIPOrDomain(net.LocalHostIP),
  285. }),
  286. ProxySettings: serial.ToTypedMessage(&socks.ServerConfig{
  287. AuthType: socks.AuthType_NO_AUTH,
  288. Address: net.NewIPOrDomain(net.LocalHostIP),
  289. UdpEnabled: true,
  290. }),
  291. },
  292. {
  293. Tag: "dokodemo",
  294. ReceiverSettings: serial.ToTypedMessage(&proxyman.ReceiverConfig{
  295. PortList: &net.PortList{Range: []*net.PortRange{net.SinglePortRange(serverPort + 1)}},
  296. Listen: net.NewIPOrDomain(net.LocalHostIP),
  297. }),
  298. ProxySettings: serial.ToTypedMessage(&dokodemo.Config{
  299. Address: net.NewIPOrDomain(dest.Address),
  300. Port: uint32(dest.Port),
  301. Networks: []net.Network{net.Network_UDP},
  302. }),
  303. },
  304. },
  305. Outbound: []*core.OutboundHandlerConfig{
  306. {
  307. ProxySettings: serial.ToTypedMessage(&blackhole.Config{}),
  308. },
  309. {
  310. Tag: "out",
  311. ProxySettings: serial.ToTypedMessage(&freedom.Config{}),
  312. },
  313. },
  314. }
  315. server, _ := InitializeServerConfig(serverConfig)
  316. if server != nil && WaitConnAvailableWithTest(t, testUDPConn(serverPort+1, 1024, time.Second*2)) {
  317. defer CloseServer(server)
  318. break
  319. }
  320. retry++
  321. if retry > 5 {
  322. t.Fatal("All attempts failed to start server")
  323. }
  324. serverPort = tcp.PickPort()
  325. }
  326. clientPort := udp.PickPort()
  327. clientConfig := &core.Config{
  328. Inbound: []*core.InboundHandlerConfig{
  329. {
  330. ReceiverSettings: serial.ToTypedMessage(&proxyman.ReceiverConfig{
  331. PortList: &net.PortList{Range: []*net.PortRange{net.SinglePortRange(clientPort)}},
  332. Listen: net.NewIPOrDomain(net.LocalHostIP),
  333. }),
  334. ProxySettings: serial.ToTypedMessage(&dokodemo.Config{
  335. Address: net.NewIPOrDomain(dest.Address),
  336. Port: uint32(dest.Port),
  337. Networks: []net.Network{net.Network_UDP},
  338. }),
  339. },
  340. },
  341. Outbound: []*core.OutboundHandlerConfig{
  342. {
  343. ProxySettings: serial.ToTypedMessage(&socks.ClientConfig{
  344. Server: &protocol.ServerEndpoint{
  345. Address: net.NewIPOrDomain(net.LocalHostIP),
  346. Port: uint32(serverPort),
  347. },
  348. }),
  349. },
  350. },
  351. }
  352. server, err := InitializeServerConfig(clientConfig)
  353. common.Must(err)
  354. defer CloseServer(server)
  355. if !WaitConnAvailableWithTest(t, testUDPConn(clientPort, 1024, time.Second*2)) {
  356. t.Fail()
  357. }
  358. }
  359. func TestSocksConformanceMod(t *testing.T) {
  360. tcpServer := tcp.Server{
  361. MsgProcessor: xor,
  362. }
  363. dest, err := tcpServer.Start()
  364. common.Must(err)
  365. defer tcpServer.Close()
  366. authPort := tcp.PickPort()
  367. noAuthPort := tcp.PickPort()
  368. serverConfig := &core.Config{
  369. Inbound: []*core.InboundHandlerConfig{
  370. {
  371. ReceiverSettings: serial.ToTypedMessage(&proxyman.ReceiverConfig{
  372. PortList: &net.PortList{Range: []*net.PortRange{net.SinglePortRange(authPort)}},
  373. Listen: net.NewIPOrDomain(net.LocalHostIP),
  374. }),
  375. ProxySettings: serial.ToTypedMessage(&socks.ServerConfig{
  376. AuthType: socks.AuthType_PASSWORD,
  377. Accounts: map[string]string{
  378. "Test Account": "Test Password",
  379. },
  380. Address: net.NewIPOrDomain(net.LocalHostIP),
  381. UdpEnabled: false,
  382. }),
  383. },
  384. {
  385. ReceiverSettings: serial.ToTypedMessage(&proxyman.ReceiverConfig{
  386. PortList: &net.PortList{Range: []*net.PortRange{net.SinglePortRange(noAuthPort)}},
  387. Listen: net.NewIPOrDomain(net.LocalHostIP),
  388. }),
  389. ProxySettings: serial.ToTypedMessage(&socks.ServerConfig{
  390. AuthType: socks.AuthType_NO_AUTH,
  391. Accounts: map[string]string{
  392. "Test Account": "Test Password",
  393. },
  394. Address: net.NewIPOrDomain(net.LocalHostIP),
  395. UdpEnabled: false,
  396. }),
  397. },
  398. },
  399. Outbound: []*core.OutboundHandlerConfig{
  400. {
  401. ProxySettings: serial.ToTypedMessage(&freedom.Config{}),
  402. },
  403. },
  404. }
  405. servers, err := InitializeServerConfigs(serverConfig)
  406. common.Must(err)
  407. defer CloseAllServers(servers)
  408. {
  409. noAuthDialer, err := xproxy.SOCKS5("tcp", net.TCPDestination(net.LocalHostIP, noAuthPort).NetAddr(), nil, xproxy.Direct)
  410. common.Must(err)
  411. conn, err := noAuthDialer.Dial("tcp", dest.NetAddr())
  412. common.Must(err)
  413. defer conn.Close()
  414. if err := testTCPConn2(conn, 1024, time.Second*5)(); err != nil {
  415. t.Error(err)
  416. }
  417. }
  418. {
  419. authDialer, err := xproxy.SOCKS5("tcp", net.TCPDestination(net.LocalHostIP, authPort).NetAddr(), &xproxy.Auth{User: "Test Account", Password: "Test Password"}, xproxy.Direct)
  420. common.Must(err)
  421. conn, err := authDialer.Dial("tcp", dest.NetAddr())
  422. common.Must(err)
  423. defer conn.Close()
  424. if err := testTCPConn2(conn, 1024, time.Second*5)(); err != nil {
  425. t.Error(err)
  426. }
  427. }
  428. {
  429. dialer := socks4.Dial("socks4://" + net.TCPDestination(net.LocalHostIP, noAuthPort).NetAddr())
  430. conn, err := dialer("tcp", dest.NetAddr())
  431. common.Must(err)
  432. defer conn.Close()
  433. if err := testTCPConn2(conn, 1024, time.Second*5)(); err != nil {
  434. t.Error(err)
  435. }
  436. }
  437. {
  438. dialer := socks4.Dial("socks4://" + net.TCPDestination(net.LocalHostIP, noAuthPort).NetAddr())
  439. conn, err := dialer("tcp", net.TCPDestination(net.LocalHostIP, tcpServer.Port).NetAddr())
  440. common.Must(err)
  441. defer conn.Close()
  442. if err := testTCPConn2(conn, 1024, time.Second*5)(); err != nil {
  443. t.Error(err)
  444. }
  445. }
  446. }