socks_test.go 9.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372
  1. package scenarios
  2. import (
  3. "testing"
  4. "time"
  5. xproxy "golang.org/x/net/proxy"
  6. "google.golang.org/protobuf/types/known/anypb"
  7. socks4 "h12.io/socks"
  8. core "github.com/v2fly/v2ray-core/v4"
  9. "github.com/v2fly/v2ray-core/v4/app/proxyman"
  10. "github.com/v2fly/v2ray-core/v4/app/router"
  11. "github.com/v2fly/v2ray-core/v4/common"
  12. "github.com/v2fly/v2ray-core/v4/common/net"
  13. "github.com/v2fly/v2ray-core/v4/common/protocol"
  14. "github.com/v2fly/v2ray-core/v4/common/serial"
  15. "github.com/v2fly/v2ray-core/v4/proxy/blackhole"
  16. "github.com/v2fly/v2ray-core/v4/proxy/dokodemo"
  17. "github.com/v2fly/v2ray-core/v4/proxy/freedom"
  18. "github.com/v2fly/v2ray-core/v4/proxy/socks"
  19. "github.com/v2fly/v2ray-core/v4/testing/servers/tcp"
  20. "github.com/v2fly/v2ray-core/v4/testing/servers/udp"
  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. 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. 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. NetworkList: &net.NetworkList{
  65. Network: []net.Network{net.Network_TCP},
  66. },
  67. }),
  68. },
  69. },
  70. Outbound: []*core.OutboundHandlerConfig{
  71. {
  72. ProxySettings: serial.ToTypedMessage(&socks.ClientConfig{
  73. Server: []*protocol.ServerEndpoint{
  74. {
  75. Address: net.NewIPOrDomain(net.LocalHostIP),
  76. Port: uint32(serverPort),
  77. User: []*protocol.User{
  78. {
  79. Account: serial.ToTypedMessage(&socks.Account{
  80. Username: "Test Account",
  81. Password: "Test Password",
  82. }),
  83. },
  84. },
  85. },
  86. },
  87. }),
  88. },
  89. },
  90. }
  91. servers, err := InitializeServerConfigs(serverConfig, clientConfig)
  92. common.Must(err)
  93. defer CloseAllServers(servers)
  94. if err := testTCPConn(clientPort, 1024, time.Second*2)(); err != nil {
  95. t.Error(err)
  96. }
  97. }
  98. func TestSocksBridageUDP(t *testing.T) {
  99. udpServer := udp.Server{
  100. MsgProcessor: xor,
  101. }
  102. dest, err := udpServer.Start()
  103. common.Must(err)
  104. defer udpServer.Close()
  105. serverPort := tcp.PickPort()
  106. serverConfig := &core.Config{
  107. Inbound: []*core.InboundHandlerConfig{
  108. {
  109. ReceiverSettings: serial.ToTypedMessage(&proxyman.ReceiverConfig{
  110. PortRange: net.SinglePortRange(serverPort),
  111. Listen: net.NewIPOrDomain(net.LocalHostIP),
  112. }),
  113. ProxySettings: serial.ToTypedMessage(&socks.ServerConfig{
  114. AuthType: socks.AuthType_PASSWORD,
  115. Accounts: map[string]string{
  116. "Test Account": "Test Password",
  117. },
  118. Address: net.NewIPOrDomain(net.LocalHostIP),
  119. UdpEnabled: true,
  120. }),
  121. },
  122. },
  123. Outbound: []*core.OutboundHandlerConfig{
  124. {
  125. ProxySettings: serial.ToTypedMessage(&freedom.Config{}),
  126. },
  127. },
  128. }
  129. clientPort := tcp.PickPort()
  130. clientConfig := &core.Config{
  131. Inbound: []*core.InboundHandlerConfig{
  132. {
  133. ReceiverSettings: serial.ToTypedMessage(&proxyman.ReceiverConfig{
  134. PortRange: net.SinglePortRange(clientPort),
  135. Listen: net.NewIPOrDomain(net.LocalHostIP),
  136. }),
  137. ProxySettings: serial.ToTypedMessage(&dokodemo.Config{
  138. Address: net.NewIPOrDomain(dest.Address),
  139. Port: uint32(dest.Port),
  140. NetworkList: &net.NetworkList{
  141. Network: []net.Network{net.Network_TCP, net.Network_UDP},
  142. },
  143. }),
  144. },
  145. },
  146. Outbound: []*core.OutboundHandlerConfig{
  147. {
  148. ProxySettings: serial.ToTypedMessage(&socks.ClientConfig{
  149. Server: []*protocol.ServerEndpoint{
  150. {
  151. Address: net.NewIPOrDomain(net.LocalHostIP),
  152. Port: uint32(serverPort),
  153. User: []*protocol.User{
  154. {
  155. Account: serial.ToTypedMessage(&socks.Account{
  156. Username: "Test Account",
  157. Password: "Test Password",
  158. }),
  159. },
  160. },
  161. },
  162. },
  163. }),
  164. },
  165. },
  166. }
  167. servers, err := InitializeServerConfigs(serverConfig, clientConfig)
  168. common.Must(err)
  169. defer CloseAllServers(servers)
  170. if err := testUDPConn(clientPort, 1024, time.Second*5)(); err != nil {
  171. t.Error(err)
  172. }
  173. }
  174. func TestSocksBridageUDPWithRouting(t *testing.T) {
  175. udpServer := udp.Server{
  176. MsgProcessor: xor,
  177. }
  178. dest, err := udpServer.Start()
  179. common.Must(err)
  180. defer udpServer.Close()
  181. serverPort := tcp.PickPort()
  182. serverConfig := &core.Config{
  183. App: []*anypb.Any{
  184. serial.ToTypedMessage(&router.Config{
  185. Rule: []*router.RoutingRule{
  186. {
  187. TargetTag: &router.RoutingRule_Tag{
  188. Tag: "out",
  189. },
  190. InboundTag: []string{"socks"},
  191. },
  192. },
  193. }),
  194. },
  195. Inbound: []*core.InboundHandlerConfig{
  196. {
  197. Tag: "socks",
  198. ReceiverSettings: serial.ToTypedMessage(&proxyman.ReceiverConfig{
  199. PortRange: net.SinglePortRange(serverPort),
  200. Listen: net.NewIPOrDomain(net.LocalHostIP),
  201. }),
  202. ProxySettings: serial.ToTypedMessage(&socks.ServerConfig{
  203. AuthType: socks.AuthType_NO_AUTH,
  204. Address: net.NewIPOrDomain(net.LocalHostIP),
  205. UdpEnabled: true,
  206. }),
  207. },
  208. },
  209. Outbound: []*core.OutboundHandlerConfig{
  210. {
  211. ProxySettings: serial.ToTypedMessage(&blackhole.Config{}),
  212. },
  213. {
  214. Tag: "out",
  215. ProxySettings: serial.ToTypedMessage(&freedom.Config{}),
  216. },
  217. },
  218. }
  219. clientPort := tcp.PickPort()
  220. clientConfig := &core.Config{
  221. Inbound: []*core.InboundHandlerConfig{
  222. {
  223. ReceiverSettings: serial.ToTypedMessage(&proxyman.ReceiverConfig{
  224. PortRange: net.SinglePortRange(clientPort),
  225. Listen: net.NewIPOrDomain(net.LocalHostIP),
  226. }),
  227. ProxySettings: serial.ToTypedMessage(&dokodemo.Config{
  228. Address: net.NewIPOrDomain(dest.Address),
  229. Port: uint32(dest.Port),
  230. NetworkList: &net.NetworkList{
  231. Network: []net.Network{net.Network_TCP, net.Network_UDP},
  232. },
  233. }),
  234. },
  235. },
  236. Outbound: []*core.OutboundHandlerConfig{
  237. {
  238. ProxySettings: serial.ToTypedMessage(&socks.ClientConfig{
  239. Server: []*protocol.ServerEndpoint{
  240. {
  241. Address: net.NewIPOrDomain(net.LocalHostIP),
  242. Port: uint32(serverPort),
  243. },
  244. },
  245. }),
  246. },
  247. },
  248. }
  249. servers, err := InitializeServerConfigs(serverConfig, clientConfig)
  250. common.Must(err)
  251. defer CloseAllServers(servers)
  252. if err := testUDPConn(clientPort, 1024, time.Second*5)(); err != nil {
  253. t.Error(err)
  254. }
  255. }
  256. func TestSocksConformanceMod(t *testing.T) {
  257. tcpServer := tcp.Server{
  258. MsgProcessor: xor,
  259. }
  260. dest, err := tcpServer.Start()
  261. common.Must(err)
  262. defer tcpServer.Close()
  263. authPort := tcp.PickPort()
  264. noAuthPort := tcp.PickPort()
  265. serverConfig := &core.Config{
  266. Inbound: []*core.InboundHandlerConfig{
  267. {
  268. ReceiverSettings: serial.ToTypedMessage(&proxyman.ReceiverConfig{
  269. PortRange: net.SinglePortRange(authPort),
  270. Listen: net.NewIPOrDomain(net.LocalHostIP),
  271. }),
  272. ProxySettings: serial.ToTypedMessage(&socks.ServerConfig{
  273. AuthType: socks.AuthType_PASSWORD,
  274. Accounts: map[string]string{
  275. "Test Account": "Test Password",
  276. },
  277. Address: net.NewIPOrDomain(net.LocalHostIP),
  278. UdpEnabled: false,
  279. }),
  280. },
  281. {
  282. ReceiverSettings: serial.ToTypedMessage(&proxyman.ReceiverConfig{
  283. PortRange: net.SinglePortRange(noAuthPort),
  284. Listen: net.NewIPOrDomain(net.LocalHostIP),
  285. }),
  286. ProxySettings: serial.ToTypedMessage(&socks.ServerConfig{
  287. AuthType: socks.AuthType_NO_AUTH,
  288. Accounts: map[string]string{
  289. "Test Account": "Test Password",
  290. },
  291. Address: net.NewIPOrDomain(net.LocalHostIP),
  292. UdpEnabled: false,
  293. }),
  294. },
  295. },
  296. Outbound: []*core.OutboundHandlerConfig{
  297. {
  298. ProxySettings: serial.ToTypedMessage(&freedom.Config{}),
  299. },
  300. },
  301. }
  302. servers, err := InitializeServerConfigs(serverConfig)
  303. common.Must(err)
  304. defer CloseAllServers(servers)
  305. {
  306. noAuthDialer, err := xproxy.SOCKS5("tcp", net.TCPDestination(net.LocalHostIP, noAuthPort).NetAddr(), nil, xproxy.Direct)
  307. common.Must(err)
  308. conn, err := noAuthDialer.Dial("tcp", dest.NetAddr())
  309. common.Must(err)
  310. defer conn.Close()
  311. if err := testTCPConn2(conn, 1024, time.Second*5)(); err != nil {
  312. t.Error(err)
  313. }
  314. }
  315. {
  316. authDialer, err := xproxy.SOCKS5("tcp", net.TCPDestination(net.LocalHostIP, authPort).NetAddr(), &xproxy.Auth{User: "Test Account", Password: "Test Password"}, xproxy.Direct)
  317. common.Must(err)
  318. conn, err := authDialer.Dial("tcp", dest.NetAddr())
  319. common.Must(err)
  320. defer conn.Close()
  321. if err := testTCPConn2(conn, 1024, time.Second*5)(); err != nil {
  322. t.Error(err)
  323. }
  324. }
  325. {
  326. dialer := socks4.Dial("socks4://" + net.TCPDestination(net.LocalHostIP, noAuthPort).NetAddr())
  327. conn, err := dialer("tcp", dest.NetAddr())
  328. common.Must(err)
  329. defer conn.Close()
  330. if err := testTCPConn2(conn, 1024, time.Second*5)(); err != nil {
  331. t.Error(err)
  332. }
  333. }
  334. {
  335. dialer := socks4.Dial("socks4://" + net.TCPDestination(net.LocalHostIP, noAuthPort).NetAddr())
  336. conn, err := dialer("tcp", net.TCPDestination(net.LocalHostIP, tcpServer.Port).NetAddr())
  337. common.Must(err)
  338. defer conn.Close()
  339. if err := testTCPConn2(conn, 1024, time.Second*5)(); err != nil {
  340. t.Error(err)
  341. }
  342. }
  343. }