reverse_test.go 10 KB

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