reverse_test.go 10.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421
  1. package scenarios
  2. import (
  3. "crypto/rand"
  4. "sync"
  5. "testing"
  6. "time"
  7. "v2ray.com/core"
  8. "v2ray.com/core/app/log"
  9. "v2ray.com/core/app/policy"
  10. "v2ray.com/core/app/proxyman"
  11. "v2ray.com/core/app/reverse"
  12. "v2ray.com/core/app/router"
  13. "v2ray.com/core/common"
  14. "v2ray.com/core/common/compare"
  15. clog "v2ray.com/core/common/log"
  16. "v2ray.com/core/common/net"
  17. "v2ray.com/core/common/protocol"
  18. "v2ray.com/core/common/serial"
  19. "v2ray.com/core/common/uuid"
  20. "v2ray.com/core/proxy/blackhole"
  21. "v2ray.com/core/proxy/dokodemo"
  22. "v2ray.com/core/proxy/freedom"
  23. "v2ray.com/core/proxy/vmess"
  24. "v2ray.com/core/proxy/vmess/inbound"
  25. "v2ray.com/core/proxy/vmess/outbound"
  26. "v2ray.com/core/testing/servers/tcp"
  27. )
  28. func TestReverseProxy(t *testing.T) {
  29. tcpServer := tcp.Server{
  30. MsgProcessor: xor,
  31. }
  32. dest, err := tcpServer.Start()
  33. common.Must(err)
  34. defer tcpServer.Close()
  35. userID := protocol.NewID(uuid.New())
  36. externalPort := tcp.PickPort()
  37. reversePort := tcp.PickPort()
  38. serverConfig := &core.Config{
  39. App: []*serial.TypedMessage{
  40. serial.ToTypedMessage(&reverse.Config{
  41. PortalConfig: []*reverse.PortalConfig{
  42. {
  43. Tag: "portal",
  44. Domain: "test.v2ray.com",
  45. },
  46. },
  47. }),
  48. serial.ToTypedMessage(&router.Config{
  49. Rule: []*router.RoutingRule{
  50. {
  51. Domain: []*router.Domain{
  52. {Type: router.Domain_Full, Value: "test.v2ray.com"},
  53. },
  54. Tag: "portal",
  55. },
  56. {
  57. InboundTag: []string{"external"},
  58. Tag: "portal",
  59. },
  60. },
  61. }),
  62. },
  63. Inbound: []*core.InboundHandlerConfig{
  64. {
  65. Tag: "external",
  66. ReceiverSettings: serial.ToTypedMessage(&proxyman.ReceiverConfig{
  67. PortRange: net.SinglePortRange(externalPort),
  68. Listen: net.NewIPOrDomain(net.LocalHostIP),
  69. }),
  70. ProxySettings: serial.ToTypedMessage(&dokodemo.Config{
  71. Address: net.NewIPOrDomain(dest.Address),
  72. Port: uint32(dest.Port),
  73. NetworkList: &net.NetworkList{
  74. Network: []net.Network{net.Network_TCP},
  75. },
  76. }),
  77. },
  78. {
  79. ReceiverSettings: serial.ToTypedMessage(&proxyman.ReceiverConfig{
  80. PortRange: net.SinglePortRange(reversePort),
  81. Listen: net.NewIPOrDomain(net.LocalHostIP),
  82. }),
  83. ProxySettings: serial.ToTypedMessage(&inbound.Config{
  84. User: []*protocol.User{
  85. {
  86. Account: serial.ToTypedMessage(&vmess.Account{
  87. Id: userID.String(),
  88. AlterId: 64,
  89. }),
  90. },
  91. },
  92. }),
  93. },
  94. },
  95. Outbound: []*core.OutboundHandlerConfig{
  96. {
  97. ProxySettings: serial.ToTypedMessage(&blackhole.Config{}),
  98. },
  99. },
  100. }
  101. clientPort := tcp.PickPort()
  102. clientConfig := &core.Config{
  103. App: []*serial.TypedMessage{
  104. serial.ToTypedMessage(&reverse.Config{
  105. BridgeConfig: []*reverse.BridgeConfig{
  106. {
  107. Tag: "bridge",
  108. Domain: "test.v2ray.com",
  109. },
  110. },
  111. }),
  112. serial.ToTypedMessage(&router.Config{
  113. Rule: []*router.RoutingRule{
  114. {
  115. Domain: []*router.Domain{
  116. {Type: router.Domain_Full, Value: "test.v2ray.com"},
  117. },
  118. Tag: "reverse",
  119. },
  120. {
  121. InboundTag: []string{"bridge"},
  122. Tag: "freedom",
  123. },
  124. },
  125. }),
  126. },
  127. Inbound: []*core.InboundHandlerConfig{
  128. {
  129. ReceiverSettings: serial.ToTypedMessage(&proxyman.ReceiverConfig{
  130. PortRange: net.SinglePortRange(clientPort),
  131. Listen: net.NewIPOrDomain(net.LocalHostIP),
  132. }),
  133. ProxySettings: serial.ToTypedMessage(&dokodemo.Config{
  134. Address: net.NewIPOrDomain(dest.Address),
  135. Port: uint32(dest.Port),
  136. NetworkList: &net.NetworkList{
  137. Network: []net.Network{net.Network_TCP},
  138. },
  139. }),
  140. },
  141. },
  142. Outbound: []*core.OutboundHandlerConfig{
  143. {
  144. Tag: "freedom",
  145. ProxySettings: serial.ToTypedMessage(&freedom.Config{}),
  146. },
  147. {
  148. Tag: "reverse",
  149. ProxySettings: serial.ToTypedMessage(&outbound.Config{
  150. Receiver: []*protocol.ServerEndpoint{
  151. {
  152. Address: net.NewIPOrDomain(net.LocalHostIP),
  153. Port: uint32(reversePort),
  154. User: []*protocol.User{
  155. {
  156. Account: serial.ToTypedMessage(&vmess.Account{
  157. Id: userID.String(),
  158. AlterId: 64,
  159. SecuritySettings: &protocol.SecurityConfig{
  160. Type: protocol.SecurityType_AES128_GCM,
  161. },
  162. }),
  163. },
  164. },
  165. },
  166. },
  167. }),
  168. },
  169. },
  170. }
  171. servers, err := InitializeServerConfigs(serverConfig, clientConfig)
  172. common.Must(err)
  173. defer CloseAllServers(servers)
  174. var wg sync.WaitGroup
  175. wg.Add(32)
  176. for i := 0; i < 32; i++ {
  177. go func() {
  178. defer wg.Done()
  179. conn, err := net.DialTCP("tcp", nil, &net.TCPAddr{
  180. IP: []byte{127, 0, 0, 1},
  181. Port: int(externalPort),
  182. })
  183. common.Must(err)
  184. defer conn.Close()
  185. payload := make([]byte, 10240*1024)
  186. rand.Read(payload)
  187. nBytes, err := conn.Write([]byte(payload))
  188. common.Must(err)
  189. if nBytes != len(payload) {
  190. t.Error("only part of payload is written: ", nBytes)
  191. }
  192. response := readFrom(conn, time.Second*20, 10240*1024)
  193. if err := compare.BytesEqualWithDetail(response, xor([]byte(payload))); err != nil {
  194. t.Error(err)
  195. }
  196. }()
  197. }
  198. wg.Wait()
  199. }
  200. func TestReverseProxyLongRunning(t *testing.T) {
  201. tcpServer := tcp.Server{
  202. MsgProcessor: xor,
  203. }
  204. dest, err := tcpServer.Start()
  205. common.Must(err)
  206. defer tcpServer.Close()
  207. userID := protocol.NewID(uuid.New())
  208. externalPort := tcp.PickPort()
  209. reversePort := tcp.PickPort()
  210. serverConfig := &core.Config{
  211. App: []*serial.TypedMessage{
  212. serial.ToTypedMessage(&log.Config{
  213. ErrorLogLevel: clog.Severity_Warning,
  214. ErrorLogType: log.LogType_Console,
  215. }),
  216. serial.ToTypedMessage(&policy.Config{
  217. Level: map[uint32]*policy.Policy{
  218. 0: {
  219. Timeout: &policy.Policy_Timeout{
  220. UplinkOnly: &policy.Second{Value: 0},
  221. DownlinkOnly: &policy.Second{Value: 0},
  222. },
  223. },
  224. },
  225. }),
  226. serial.ToTypedMessage(&reverse.Config{
  227. PortalConfig: []*reverse.PortalConfig{
  228. {
  229. Tag: "portal",
  230. Domain: "test.v2ray.com",
  231. },
  232. },
  233. }),
  234. serial.ToTypedMessage(&router.Config{
  235. Rule: []*router.RoutingRule{
  236. {
  237. Domain: []*router.Domain{
  238. {Type: router.Domain_Full, Value: "test.v2ray.com"},
  239. },
  240. Tag: "portal",
  241. },
  242. {
  243. InboundTag: []string{"external"},
  244. Tag: "portal",
  245. },
  246. },
  247. }),
  248. },
  249. Inbound: []*core.InboundHandlerConfig{
  250. {
  251. Tag: "external",
  252. ReceiverSettings: serial.ToTypedMessage(&proxyman.ReceiverConfig{
  253. PortRange: net.SinglePortRange(externalPort),
  254. Listen: net.NewIPOrDomain(net.LocalHostIP),
  255. }),
  256. ProxySettings: serial.ToTypedMessage(&dokodemo.Config{
  257. Address: net.NewIPOrDomain(dest.Address),
  258. Port: uint32(dest.Port),
  259. NetworkList: &net.NetworkList{
  260. Network: []net.Network{net.Network_TCP},
  261. },
  262. }),
  263. },
  264. {
  265. ReceiverSettings: serial.ToTypedMessage(&proxyman.ReceiverConfig{
  266. PortRange: net.SinglePortRange(reversePort),
  267. Listen: net.NewIPOrDomain(net.LocalHostIP),
  268. }),
  269. ProxySettings: serial.ToTypedMessage(&inbound.Config{
  270. User: []*protocol.User{
  271. {
  272. Account: serial.ToTypedMessage(&vmess.Account{
  273. Id: userID.String(),
  274. AlterId: 64,
  275. }),
  276. },
  277. },
  278. }),
  279. },
  280. },
  281. Outbound: []*core.OutboundHandlerConfig{
  282. {
  283. ProxySettings: serial.ToTypedMessage(&blackhole.Config{}),
  284. },
  285. },
  286. }
  287. clientPort := tcp.PickPort()
  288. clientConfig := &core.Config{
  289. App: []*serial.TypedMessage{
  290. serial.ToTypedMessage(&log.Config{
  291. ErrorLogLevel: clog.Severity_Warning,
  292. ErrorLogType: log.LogType_Console,
  293. }),
  294. serial.ToTypedMessage(&policy.Config{
  295. Level: map[uint32]*policy.Policy{
  296. 0: {
  297. Timeout: &policy.Policy_Timeout{
  298. UplinkOnly: &policy.Second{Value: 0},
  299. DownlinkOnly: &policy.Second{Value: 0},
  300. },
  301. },
  302. },
  303. }),
  304. serial.ToTypedMessage(&reverse.Config{
  305. BridgeConfig: []*reverse.BridgeConfig{
  306. {
  307. Tag: "bridge",
  308. Domain: "test.v2ray.com",
  309. },
  310. },
  311. }),
  312. serial.ToTypedMessage(&router.Config{
  313. Rule: []*router.RoutingRule{
  314. {
  315. Domain: []*router.Domain{
  316. {Type: router.Domain_Full, Value: "test.v2ray.com"},
  317. },
  318. Tag: "reverse",
  319. },
  320. {
  321. InboundTag: []string{"bridge"},
  322. Tag: "freedom",
  323. },
  324. },
  325. }),
  326. },
  327. Inbound: []*core.InboundHandlerConfig{
  328. {
  329. ReceiverSettings: serial.ToTypedMessage(&proxyman.ReceiverConfig{
  330. PortRange: net.SinglePortRange(clientPort),
  331. Listen: net.NewIPOrDomain(net.LocalHostIP),
  332. }),
  333. ProxySettings: serial.ToTypedMessage(&dokodemo.Config{
  334. Address: net.NewIPOrDomain(dest.Address),
  335. Port: uint32(dest.Port),
  336. NetworkList: &net.NetworkList{
  337. Network: []net.Network{net.Network_TCP},
  338. },
  339. }),
  340. },
  341. },
  342. Outbound: []*core.OutboundHandlerConfig{
  343. {
  344. Tag: "freedom",
  345. ProxySettings: serial.ToTypedMessage(&freedom.Config{}),
  346. },
  347. {
  348. Tag: "reverse",
  349. ProxySettings: serial.ToTypedMessage(&outbound.Config{
  350. Receiver: []*protocol.ServerEndpoint{
  351. {
  352. Address: net.NewIPOrDomain(net.LocalHostIP),
  353. Port: uint32(reversePort),
  354. User: []*protocol.User{
  355. {
  356. Account: serial.ToTypedMessage(&vmess.Account{
  357. Id: userID.String(),
  358. AlterId: 64,
  359. SecuritySettings: &protocol.SecurityConfig{
  360. Type: protocol.SecurityType_AES128_GCM,
  361. },
  362. }),
  363. },
  364. },
  365. },
  366. },
  367. }),
  368. },
  369. },
  370. }
  371. servers, err := InitializeServerConfigs(serverConfig, clientConfig)
  372. common.Must(err)
  373. defer CloseAllServers(servers)
  374. for i := 0; i < 4096; i++ {
  375. conn, err := net.DialTCP("tcp", nil, &net.TCPAddr{
  376. IP: []byte{127, 0, 0, 1},
  377. Port: int(externalPort),
  378. })
  379. common.Must(err)
  380. payload := make([]byte, 1024)
  381. rand.Read(payload)
  382. nBytes, err := conn.Write([]byte(payload))
  383. common.Must(err)
  384. if nBytes != len(payload) {
  385. t.Error("only part of payload is written: ", nBytes)
  386. }
  387. response := readFrom(conn, time.Second*5, 1024)
  388. if err := compare.BytesEqualWithDetail(response, xor([]byte(payload))); err != nil {
  389. t.Error(err)
  390. }
  391. conn.Close()
  392. }
  393. }