reverse_test.go 9.5 KB

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