vmess_test.go 31 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230
  1. package scenarios
  2. import (
  3. "crypto/rand"
  4. "net"
  5. "sync"
  6. "testing"
  7. "time"
  8. "v2ray.com/core"
  9. "v2ray.com/core/app/log"
  10. "v2ray.com/core/app/proxyman"
  11. v2net "v2ray.com/core/common/net"
  12. "v2ray.com/core/common/protocol"
  13. "v2ray.com/core/common/serial"
  14. "v2ray.com/core/common/uuid"
  15. "v2ray.com/core/proxy/dokodemo"
  16. "v2ray.com/core/proxy/freedom"
  17. "v2ray.com/core/proxy/vmess"
  18. "v2ray.com/core/proxy/vmess/inbound"
  19. "v2ray.com/core/proxy/vmess/outbound"
  20. "v2ray.com/core/testing/assert"
  21. "v2ray.com/core/testing/servers/tcp"
  22. "v2ray.com/core/testing/servers/udp"
  23. "v2ray.com/core/transport/internet"
  24. )
  25. func TestVMessDynamicPort(t *testing.T) {
  26. assert := assert.On(t)
  27. tcpServer := tcp.Server{
  28. MsgProcessor: xor,
  29. }
  30. dest, err := tcpServer.Start()
  31. assert.Error(err).IsNil()
  32. defer tcpServer.Close()
  33. userID := protocol.NewID(uuid.New())
  34. serverPort := pickPort()
  35. serverConfig := &core.Config{
  36. Inbound: []*proxyman.InboundHandlerConfig{
  37. {
  38. ReceiverSettings: serial.ToTypedMessage(&proxyman.ReceiverConfig{
  39. PortRange: v2net.SinglePortRange(serverPort),
  40. Listen: v2net.NewIPOrDomain(v2net.LocalHostIP),
  41. }),
  42. ProxySettings: serial.ToTypedMessage(&inbound.Config{
  43. User: []*protocol.User{
  44. {
  45. Account: serial.ToTypedMessage(&vmess.Account{
  46. Id: userID.String(),
  47. }),
  48. },
  49. },
  50. Detour: &inbound.DetourConfig{
  51. To: "detour",
  52. },
  53. }),
  54. },
  55. {
  56. ReceiverSettings: serial.ToTypedMessage(&proxyman.ReceiverConfig{
  57. PortRange: &v2net.PortRange{
  58. From: uint32(serverPort + 1),
  59. To: uint32(serverPort + 100),
  60. },
  61. Listen: v2net.NewIPOrDomain(v2net.LocalHostIP),
  62. AllocationStrategy: &proxyman.AllocationStrategy{
  63. Type: proxyman.AllocationStrategy_Random,
  64. Concurrency: &proxyman.AllocationStrategy_AllocationStrategyConcurrency{
  65. Value: 2,
  66. },
  67. Refresh: &proxyman.AllocationStrategy_AllocationStrategyRefresh{
  68. Value: 5,
  69. },
  70. },
  71. }),
  72. ProxySettings: serial.ToTypedMessage(&inbound.Config{}),
  73. Tag: "detour",
  74. },
  75. },
  76. Outbound: []*proxyman.OutboundHandlerConfig{
  77. {
  78. ProxySettings: serial.ToTypedMessage(&freedom.Config{}),
  79. },
  80. },
  81. App: []*serial.TypedMessage{
  82. serial.ToTypedMessage(&log.Config{
  83. ErrorLogLevel: log.LogLevel_Debug,
  84. ErrorLogType: log.LogType_Console,
  85. }),
  86. },
  87. }
  88. clientPort := pickPort()
  89. clientConfig := &core.Config{
  90. Inbound: []*proxyman.InboundHandlerConfig{
  91. {
  92. ReceiverSettings: serial.ToTypedMessage(&proxyman.ReceiverConfig{
  93. PortRange: v2net.SinglePortRange(clientPort),
  94. Listen: v2net.NewIPOrDomain(v2net.LocalHostIP),
  95. }),
  96. ProxySettings: serial.ToTypedMessage(&dokodemo.Config{
  97. Address: v2net.NewIPOrDomain(dest.Address),
  98. Port: uint32(dest.Port),
  99. NetworkList: &v2net.NetworkList{
  100. Network: []v2net.Network{v2net.Network_TCP},
  101. },
  102. }),
  103. },
  104. },
  105. Outbound: []*proxyman.OutboundHandlerConfig{
  106. {
  107. ProxySettings: serial.ToTypedMessage(&outbound.Config{
  108. Receiver: []*protocol.ServerEndpoint{
  109. {
  110. Address: v2net.NewIPOrDomain(v2net.LocalHostIP),
  111. Port: uint32(serverPort),
  112. User: []*protocol.User{
  113. {
  114. Account: serial.ToTypedMessage(&vmess.Account{
  115. Id: userID.String(),
  116. }),
  117. },
  118. },
  119. },
  120. },
  121. }),
  122. },
  123. },
  124. App: []*serial.TypedMessage{
  125. serial.ToTypedMessage(&log.Config{
  126. ErrorLogLevel: log.LogLevel_Debug,
  127. ErrorLogType: log.LogType_Console,
  128. }),
  129. },
  130. }
  131. assert.Error(InitializeServerConfig(serverConfig)).IsNil()
  132. assert.Error(InitializeServerConfig(clientConfig)).IsNil()
  133. for i := 0; i < 10; i++ {
  134. conn, err := net.DialTCP("tcp", nil, &net.TCPAddr{
  135. IP: []byte{127, 0, 0, 1},
  136. Port: int(clientPort),
  137. })
  138. assert.Error(err).IsNil()
  139. payload := "dokodemo request."
  140. nBytes, err := conn.Write([]byte(payload))
  141. assert.Error(err).IsNil()
  142. assert.Int(nBytes).Equals(len(payload))
  143. response := make([]byte, 1024)
  144. nBytes, err = conn.Read(response)
  145. assert.Error(err).IsNil()
  146. assert.Bytes(response[:nBytes]).Equals(xor([]byte(payload)))
  147. assert.Error(conn.Close()).IsNil()
  148. }
  149. CloseAllServers()
  150. }
  151. func TestVMessGCM(t *testing.T) {
  152. assert := assert.On(t)
  153. tcpServer := tcp.Server{
  154. MsgProcessor: xor,
  155. }
  156. dest, err := tcpServer.Start()
  157. assert.Error(err).IsNil()
  158. defer tcpServer.Close()
  159. userID := protocol.NewID(uuid.New())
  160. serverPort := pickPort()
  161. serverConfig := &core.Config{
  162. Inbound: []*proxyman.InboundHandlerConfig{
  163. {
  164. ReceiverSettings: serial.ToTypedMessage(&proxyman.ReceiverConfig{
  165. PortRange: v2net.SinglePortRange(serverPort),
  166. Listen: v2net.NewIPOrDomain(v2net.LocalHostIP),
  167. }),
  168. ProxySettings: serial.ToTypedMessage(&inbound.Config{
  169. User: []*protocol.User{
  170. {
  171. Account: serial.ToTypedMessage(&vmess.Account{
  172. Id: userID.String(),
  173. AlterId: 64,
  174. }),
  175. },
  176. },
  177. }),
  178. },
  179. },
  180. Outbound: []*proxyman.OutboundHandlerConfig{
  181. {
  182. ProxySettings: serial.ToTypedMessage(&freedom.Config{}),
  183. },
  184. },
  185. App: []*serial.TypedMessage{
  186. serial.ToTypedMessage(&log.Config{
  187. ErrorLogLevel: log.LogLevel_Debug,
  188. ErrorLogType: log.LogType_Console,
  189. }),
  190. },
  191. }
  192. clientPort := pickPort()
  193. clientConfig := &core.Config{
  194. Inbound: []*proxyman.InboundHandlerConfig{
  195. {
  196. ReceiverSettings: serial.ToTypedMessage(&proxyman.ReceiverConfig{
  197. PortRange: v2net.SinglePortRange(clientPort),
  198. Listen: v2net.NewIPOrDomain(v2net.LocalHostIP),
  199. }),
  200. ProxySettings: serial.ToTypedMessage(&dokodemo.Config{
  201. Address: v2net.NewIPOrDomain(dest.Address),
  202. Port: uint32(dest.Port),
  203. NetworkList: &v2net.NetworkList{
  204. Network: []v2net.Network{v2net.Network_TCP},
  205. },
  206. }),
  207. },
  208. },
  209. Outbound: []*proxyman.OutboundHandlerConfig{
  210. {
  211. ProxySettings: serial.ToTypedMessage(&outbound.Config{
  212. Receiver: []*protocol.ServerEndpoint{
  213. {
  214. Address: v2net.NewIPOrDomain(v2net.LocalHostIP),
  215. Port: uint32(serverPort),
  216. User: []*protocol.User{
  217. {
  218. Account: serial.ToTypedMessage(&vmess.Account{
  219. Id: userID.String(),
  220. AlterId: 64,
  221. SecuritySettings: &protocol.SecurityConfig{
  222. Type: protocol.SecurityType_AES128_GCM,
  223. },
  224. }),
  225. },
  226. },
  227. },
  228. },
  229. }),
  230. },
  231. },
  232. App: []*serial.TypedMessage{
  233. serial.ToTypedMessage(&log.Config{
  234. ErrorLogLevel: log.LogLevel_Debug,
  235. ErrorLogType: log.LogType_Console,
  236. }),
  237. },
  238. }
  239. assert.Error(InitializeServerConfig(serverConfig)).IsNil()
  240. assert.Error(InitializeServerConfig(clientConfig)).IsNil()
  241. var wg sync.WaitGroup
  242. wg.Add(10)
  243. for i := 0; i < 10; i++ {
  244. go func() {
  245. conn, err := net.DialTCP("tcp", nil, &net.TCPAddr{
  246. IP: []byte{127, 0, 0, 1},
  247. Port: int(clientPort),
  248. })
  249. assert.Error(err).IsNil()
  250. payload := make([]byte, 10240*1024)
  251. rand.Read(payload)
  252. nBytes, err := conn.Write([]byte(payload))
  253. assert.Error(err).IsNil()
  254. assert.Int(nBytes).Equals(len(payload))
  255. response := readFrom(conn, time.Second*20, 10240*1024)
  256. assert.Bytes(response).Equals(xor([]byte(payload)))
  257. assert.Error(conn.Close()).IsNil()
  258. wg.Done()
  259. }()
  260. }
  261. wg.Wait()
  262. CloseAllServers()
  263. }
  264. func TestVMessGCMUDP(t *testing.T) {
  265. assert := assert.On(t)
  266. udpServer := udp.Server{
  267. MsgProcessor: xor,
  268. }
  269. dest, err := udpServer.Start()
  270. assert.Error(err).IsNil()
  271. defer udpServer.Close()
  272. userID := protocol.NewID(uuid.New())
  273. serverPort := pickPort()
  274. serverConfig := &core.Config{
  275. Inbound: []*proxyman.InboundHandlerConfig{
  276. {
  277. ReceiverSettings: serial.ToTypedMessage(&proxyman.ReceiverConfig{
  278. PortRange: v2net.SinglePortRange(serverPort),
  279. Listen: v2net.NewIPOrDomain(v2net.LocalHostIP),
  280. }),
  281. ProxySettings: serial.ToTypedMessage(&inbound.Config{
  282. User: []*protocol.User{
  283. {
  284. Account: serial.ToTypedMessage(&vmess.Account{
  285. Id: userID.String(),
  286. AlterId: 64,
  287. }),
  288. },
  289. },
  290. }),
  291. },
  292. },
  293. Outbound: []*proxyman.OutboundHandlerConfig{
  294. {
  295. ProxySettings: serial.ToTypedMessage(&freedom.Config{}),
  296. },
  297. },
  298. App: []*serial.TypedMessage{
  299. serial.ToTypedMessage(&log.Config{
  300. ErrorLogLevel: log.LogLevel_Debug,
  301. ErrorLogType: log.LogType_Console,
  302. }),
  303. },
  304. }
  305. clientPort := pickPort()
  306. clientConfig := &core.Config{
  307. Inbound: []*proxyman.InboundHandlerConfig{
  308. {
  309. ReceiverSettings: serial.ToTypedMessage(&proxyman.ReceiverConfig{
  310. PortRange: v2net.SinglePortRange(clientPort),
  311. Listen: v2net.NewIPOrDomain(v2net.LocalHostIP),
  312. }),
  313. ProxySettings: serial.ToTypedMessage(&dokodemo.Config{
  314. Address: v2net.NewIPOrDomain(dest.Address),
  315. Port: uint32(dest.Port),
  316. NetworkList: &v2net.NetworkList{
  317. Network: []v2net.Network{v2net.Network_UDP},
  318. },
  319. }),
  320. },
  321. },
  322. Outbound: []*proxyman.OutboundHandlerConfig{
  323. {
  324. ProxySettings: serial.ToTypedMessage(&outbound.Config{
  325. Receiver: []*protocol.ServerEndpoint{
  326. {
  327. Address: v2net.NewIPOrDomain(v2net.LocalHostIP),
  328. Port: uint32(serverPort),
  329. User: []*protocol.User{
  330. {
  331. Account: serial.ToTypedMessage(&vmess.Account{
  332. Id: userID.String(),
  333. AlterId: 64,
  334. SecuritySettings: &protocol.SecurityConfig{
  335. Type: protocol.SecurityType_AES128_GCM,
  336. },
  337. }),
  338. },
  339. },
  340. },
  341. },
  342. }),
  343. },
  344. },
  345. App: []*serial.TypedMessage{
  346. serial.ToTypedMessage(&log.Config{
  347. ErrorLogLevel: log.LogLevel_Debug,
  348. ErrorLogType: log.LogType_Console,
  349. }),
  350. },
  351. }
  352. assert.Error(InitializeServerConfig(serverConfig)).IsNil()
  353. assert.Error(InitializeServerConfig(clientConfig)).IsNil()
  354. var wg sync.WaitGroup
  355. wg.Add(10)
  356. for i := 0; i < 10; i++ {
  357. go func() {
  358. conn, err := net.DialUDP("udp", nil, &net.UDPAddr{
  359. IP: []byte{127, 0, 0, 1},
  360. Port: int(clientPort),
  361. })
  362. assert.Error(err).IsNil()
  363. payload := make([]byte, 1024)
  364. rand.Read(payload)
  365. nBytes, err := conn.Write([]byte(payload))
  366. assert.Error(err).IsNil()
  367. assert.Int(nBytes).Equals(len(payload))
  368. payload1 := make([]byte, 1024)
  369. rand.Read(payload1)
  370. nBytes, err = conn.Write([]byte(payload1))
  371. assert.Error(err).IsNil()
  372. assert.Int(nBytes).Equals(len(payload1))
  373. response := readFrom(conn, time.Second*5, 1024)
  374. assert.Bytes(response).Equals(xor([]byte(payload)))
  375. response = readFrom(conn, time.Second*5, 1024)
  376. assert.Bytes(response).Equals(xor([]byte(payload1)))
  377. assert.Error(conn.Close()).IsNil()
  378. wg.Done()
  379. }()
  380. }
  381. wg.Wait()
  382. CloseAllServers()
  383. }
  384. func TestVMessChacha20(t *testing.T) {
  385. assert := assert.On(t)
  386. tcpServer := tcp.Server{
  387. MsgProcessor: xor,
  388. }
  389. dest, err := tcpServer.Start()
  390. assert.Error(err).IsNil()
  391. defer tcpServer.Close()
  392. userID := protocol.NewID(uuid.New())
  393. serverPort := pickPort()
  394. serverConfig := &core.Config{
  395. Inbound: []*proxyman.InboundHandlerConfig{
  396. {
  397. ReceiverSettings: serial.ToTypedMessage(&proxyman.ReceiverConfig{
  398. PortRange: v2net.SinglePortRange(serverPort),
  399. Listen: v2net.NewIPOrDomain(v2net.LocalHostIP),
  400. }),
  401. ProxySettings: serial.ToTypedMessage(&inbound.Config{
  402. User: []*protocol.User{
  403. {
  404. Account: serial.ToTypedMessage(&vmess.Account{
  405. Id: userID.String(),
  406. AlterId: 64,
  407. }),
  408. },
  409. },
  410. }),
  411. },
  412. },
  413. Outbound: []*proxyman.OutboundHandlerConfig{
  414. {
  415. ProxySettings: serial.ToTypedMessage(&freedom.Config{}),
  416. },
  417. },
  418. App: []*serial.TypedMessage{
  419. serial.ToTypedMessage(&log.Config{
  420. ErrorLogLevel: log.LogLevel_Debug,
  421. ErrorLogType: log.LogType_Console,
  422. }),
  423. },
  424. }
  425. clientPort := pickPort()
  426. clientConfig := &core.Config{
  427. Inbound: []*proxyman.InboundHandlerConfig{
  428. {
  429. ReceiverSettings: serial.ToTypedMessage(&proxyman.ReceiverConfig{
  430. PortRange: v2net.SinglePortRange(clientPort),
  431. Listen: v2net.NewIPOrDomain(v2net.LocalHostIP),
  432. }),
  433. ProxySettings: serial.ToTypedMessage(&dokodemo.Config{
  434. Address: v2net.NewIPOrDomain(dest.Address),
  435. Port: uint32(dest.Port),
  436. NetworkList: &v2net.NetworkList{
  437. Network: []v2net.Network{v2net.Network_TCP},
  438. },
  439. }),
  440. },
  441. },
  442. Outbound: []*proxyman.OutboundHandlerConfig{
  443. {
  444. ProxySettings: serial.ToTypedMessage(&outbound.Config{
  445. Receiver: []*protocol.ServerEndpoint{
  446. {
  447. Address: v2net.NewIPOrDomain(v2net.LocalHostIP),
  448. Port: uint32(serverPort),
  449. User: []*protocol.User{
  450. {
  451. Account: serial.ToTypedMessage(&vmess.Account{
  452. Id: userID.String(),
  453. AlterId: 64,
  454. SecuritySettings: &protocol.SecurityConfig{
  455. Type: protocol.SecurityType_CHACHA20_POLY1305,
  456. },
  457. }),
  458. },
  459. },
  460. },
  461. },
  462. }),
  463. },
  464. },
  465. App: []*serial.TypedMessage{
  466. serial.ToTypedMessage(&log.Config{
  467. ErrorLogLevel: log.LogLevel_Debug,
  468. ErrorLogType: log.LogType_Console,
  469. }),
  470. },
  471. }
  472. assert.Error(InitializeServerConfig(serverConfig)).IsNil()
  473. assert.Error(InitializeServerConfig(clientConfig)).IsNil()
  474. var wg sync.WaitGroup
  475. wg.Add(10)
  476. for i := 0; i < 10; i++ {
  477. go func() {
  478. conn, err := net.DialTCP("tcp", nil, &net.TCPAddr{
  479. IP: []byte{127, 0, 0, 1},
  480. Port: int(clientPort),
  481. })
  482. assert.Error(err).IsNil()
  483. payload := make([]byte, 10240*1024)
  484. rand.Read(payload)
  485. nBytes, err := conn.Write([]byte(payload))
  486. assert.Error(err).IsNil()
  487. assert.Int(nBytes).Equals(len(payload))
  488. response := readFrom(conn, time.Second*20, 10240*1024)
  489. assert.Bytes(response).Equals(xor([]byte(payload)))
  490. assert.Error(conn.Close()).IsNil()
  491. wg.Done()
  492. }()
  493. }
  494. wg.Wait()
  495. CloseAllServers()
  496. }
  497. func TestVMessNone(t *testing.T) {
  498. assert := assert.On(t)
  499. tcpServer := tcp.Server{
  500. MsgProcessor: xor,
  501. }
  502. dest, err := tcpServer.Start()
  503. assert.Error(err).IsNil()
  504. defer tcpServer.Close()
  505. userID := protocol.NewID(uuid.New())
  506. serverPort := pickPort()
  507. serverConfig := &core.Config{
  508. Inbound: []*proxyman.InboundHandlerConfig{
  509. {
  510. ReceiverSettings: serial.ToTypedMessage(&proxyman.ReceiverConfig{
  511. PortRange: v2net.SinglePortRange(serverPort),
  512. Listen: v2net.NewIPOrDomain(v2net.LocalHostIP),
  513. }),
  514. ProxySettings: serial.ToTypedMessage(&inbound.Config{
  515. User: []*protocol.User{
  516. {
  517. Account: serial.ToTypedMessage(&vmess.Account{
  518. Id: userID.String(),
  519. AlterId: 64,
  520. }),
  521. },
  522. },
  523. }),
  524. },
  525. },
  526. Outbound: []*proxyman.OutboundHandlerConfig{
  527. {
  528. ProxySettings: serial.ToTypedMessage(&freedom.Config{}),
  529. },
  530. },
  531. App: []*serial.TypedMessage{
  532. serial.ToTypedMessage(&log.Config{
  533. ErrorLogLevel: log.LogLevel_Debug,
  534. ErrorLogType: log.LogType_Console,
  535. }),
  536. },
  537. }
  538. clientPort := pickPort()
  539. clientConfig := &core.Config{
  540. Inbound: []*proxyman.InboundHandlerConfig{
  541. {
  542. ReceiverSettings: serial.ToTypedMessage(&proxyman.ReceiverConfig{
  543. PortRange: v2net.SinglePortRange(clientPort),
  544. Listen: v2net.NewIPOrDomain(v2net.LocalHostIP),
  545. }),
  546. ProxySettings: serial.ToTypedMessage(&dokodemo.Config{
  547. Address: v2net.NewIPOrDomain(dest.Address),
  548. Port: uint32(dest.Port),
  549. NetworkList: &v2net.NetworkList{
  550. Network: []v2net.Network{v2net.Network_TCP},
  551. },
  552. }),
  553. },
  554. },
  555. Outbound: []*proxyman.OutboundHandlerConfig{
  556. {
  557. ProxySettings: serial.ToTypedMessage(&outbound.Config{
  558. Receiver: []*protocol.ServerEndpoint{
  559. {
  560. Address: v2net.NewIPOrDomain(v2net.LocalHostIP),
  561. Port: uint32(serverPort),
  562. User: []*protocol.User{
  563. {
  564. Account: serial.ToTypedMessage(&vmess.Account{
  565. Id: userID.String(),
  566. AlterId: 64,
  567. SecuritySettings: &protocol.SecurityConfig{
  568. Type: protocol.SecurityType_NONE,
  569. },
  570. }),
  571. },
  572. },
  573. },
  574. },
  575. }),
  576. },
  577. },
  578. App: []*serial.TypedMessage{
  579. serial.ToTypedMessage(&log.Config{
  580. ErrorLogLevel: log.LogLevel_Debug,
  581. ErrorLogType: log.LogType_Console,
  582. }),
  583. },
  584. }
  585. assert.Error(InitializeServerConfig(serverConfig)).IsNil()
  586. assert.Error(InitializeServerConfig(clientConfig)).IsNil()
  587. var wg sync.WaitGroup
  588. wg.Add(10)
  589. for i := 0; i < 10; i++ {
  590. go func() {
  591. conn, err := net.DialTCP("tcp", nil, &net.TCPAddr{
  592. IP: []byte{127, 0, 0, 1},
  593. Port: int(clientPort),
  594. })
  595. assert.Error(err).IsNil()
  596. payload := make([]byte, 10240*1024)
  597. rand.Read(payload)
  598. nBytes, err := conn.Write(payload)
  599. assert.Error(err).IsNil()
  600. assert.Int(nBytes).Equals(len(payload))
  601. response := readFrom(conn, time.Second*20, 10240*1024)
  602. assert.Bytes(response).Equals(xor(payload))
  603. assert.Error(conn.Close()).IsNil()
  604. wg.Done()
  605. }()
  606. }
  607. wg.Wait()
  608. CloseAllServers()
  609. }
  610. func TestVMessKCP(t *testing.T) {
  611. assert := assert.On(t)
  612. tcpServer := tcp.Server{
  613. MsgProcessor: xor,
  614. }
  615. dest, err := tcpServer.Start()
  616. assert.Error(err).IsNil()
  617. defer tcpServer.Close()
  618. userID := protocol.NewID(uuid.New())
  619. serverPort := pickPort()
  620. serverConfig := &core.Config{
  621. Inbound: []*proxyman.InboundHandlerConfig{
  622. {
  623. ReceiverSettings: serial.ToTypedMessage(&proxyman.ReceiverConfig{
  624. PortRange: v2net.SinglePortRange(serverPort),
  625. Listen: v2net.NewIPOrDomain(v2net.LocalHostIP),
  626. StreamSettings: &internet.StreamConfig{
  627. Protocol: internet.TransportProtocol_MKCP,
  628. },
  629. }),
  630. ProxySettings: serial.ToTypedMessage(&inbound.Config{
  631. User: []*protocol.User{
  632. {
  633. Account: serial.ToTypedMessage(&vmess.Account{
  634. Id: userID.String(),
  635. AlterId: 64,
  636. }),
  637. },
  638. },
  639. }),
  640. },
  641. },
  642. Outbound: []*proxyman.OutboundHandlerConfig{
  643. {
  644. ProxySettings: serial.ToTypedMessage(&freedom.Config{}),
  645. },
  646. },
  647. App: []*serial.TypedMessage{
  648. serial.ToTypedMessage(&log.Config{
  649. ErrorLogLevel: log.LogLevel_Debug,
  650. ErrorLogType: log.LogType_Console,
  651. }),
  652. },
  653. }
  654. clientPort := pickPort()
  655. clientConfig := &core.Config{
  656. Inbound: []*proxyman.InboundHandlerConfig{
  657. {
  658. ReceiverSettings: serial.ToTypedMessage(&proxyman.ReceiverConfig{
  659. PortRange: v2net.SinglePortRange(clientPort),
  660. Listen: v2net.NewIPOrDomain(v2net.LocalHostIP),
  661. }),
  662. ProxySettings: serial.ToTypedMessage(&dokodemo.Config{
  663. Address: v2net.NewIPOrDomain(dest.Address),
  664. Port: uint32(dest.Port),
  665. NetworkList: &v2net.NetworkList{
  666. Network: []v2net.Network{v2net.Network_TCP},
  667. },
  668. }),
  669. },
  670. },
  671. Outbound: []*proxyman.OutboundHandlerConfig{
  672. {
  673. ProxySettings: serial.ToTypedMessage(&outbound.Config{
  674. Receiver: []*protocol.ServerEndpoint{
  675. {
  676. Address: v2net.NewIPOrDomain(v2net.LocalHostIP),
  677. Port: uint32(serverPort),
  678. User: []*protocol.User{
  679. {
  680. Account: serial.ToTypedMessage(&vmess.Account{
  681. Id: userID.String(),
  682. AlterId: 64,
  683. SecuritySettings: &protocol.SecurityConfig{
  684. Type: protocol.SecurityType_AES128_GCM,
  685. },
  686. }),
  687. },
  688. },
  689. },
  690. },
  691. }),
  692. SenderSettings: serial.ToTypedMessage(&proxyman.SenderConfig{
  693. StreamSettings: &internet.StreamConfig{
  694. Protocol: internet.TransportProtocol_MKCP,
  695. },
  696. }),
  697. },
  698. },
  699. App: []*serial.TypedMessage{
  700. serial.ToTypedMessage(&log.Config{
  701. ErrorLogLevel: log.LogLevel_Debug,
  702. ErrorLogType: log.LogType_Console,
  703. }),
  704. },
  705. }
  706. assert.Error(InitializeServerConfig(serverConfig)).IsNil()
  707. assert.Error(InitializeServerConfig(clientConfig)).IsNil()
  708. var wg sync.WaitGroup
  709. for i := 0; i < 10; i++ {
  710. wg.Add(1)
  711. go func() {
  712. conn, err := net.DialTCP("tcp", nil, &net.TCPAddr{
  713. IP: []byte{127, 0, 0, 1},
  714. Port: int(clientPort),
  715. })
  716. assert.Error(err).IsNil()
  717. payload := make([]byte, 10240*1024)
  718. rand.Read(payload)
  719. nBytes, err := conn.Write([]byte(payload))
  720. assert.Error(err).IsNil()
  721. assert.Int(nBytes).Equals(len(payload))
  722. response := readFrom(conn, time.Minute, 10240*1024)
  723. assert.Bytes(response).Equals(xor([]byte(payload)))
  724. assert.Error(conn.Close()).IsNil()
  725. wg.Done()
  726. }()
  727. }
  728. wg.Wait()
  729. CloseAllServers()
  730. }
  731. func TestVMessIPv6(t *testing.T) {
  732. t.SkipNow() // No IPv6 on travis-ci.
  733. assert := assert.On(t)
  734. tcpServer := tcp.Server{
  735. MsgProcessor: xor,
  736. Listen: v2net.LocalHostIPv6,
  737. }
  738. dest, err := tcpServer.Start()
  739. assert.Error(err).IsNil()
  740. defer tcpServer.Close()
  741. userID := protocol.NewID(uuid.New())
  742. serverPort := pickPort()
  743. serverConfig := &core.Config{
  744. Inbound: []*proxyman.InboundHandlerConfig{
  745. {
  746. ReceiverSettings: serial.ToTypedMessage(&proxyman.ReceiverConfig{
  747. PortRange: v2net.SinglePortRange(serverPort),
  748. Listen: v2net.NewIPOrDomain(v2net.LocalHostIPv6),
  749. }),
  750. ProxySettings: serial.ToTypedMessage(&inbound.Config{
  751. User: []*protocol.User{
  752. {
  753. Account: serial.ToTypedMessage(&vmess.Account{
  754. Id: userID.String(),
  755. AlterId: 64,
  756. }),
  757. },
  758. },
  759. }),
  760. },
  761. },
  762. Outbound: []*proxyman.OutboundHandlerConfig{
  763. {
  764. ProxySettings: serial.ToTypedMessage(&freedom.Config{}),
  765. },
  766. },
  767. App: []*serial.TypedMessage{
  768. serial.ToTypedMessage(&log.Config{
  769. ErrorLogLevel: log.LogLevel_Debug,
  770. ErrorLogType: log.LogType_Console,
  771. }),
  772. },
  773. }
  774. clientPort := pickPort()
  775. clientConfig := &core.Config{
  776. Inbound: []*proxyman.InboundHandlerConfig{
  777. {
  778. ReceiverSettings: serial.ToTypedMessage(&proxyman.ReceiverConfig{
  779. PortRange: v2net.SinglePortRange(clientPort),
  780. Listen: v2net.NewIPOrDomain(v2net.LocalHostIPv6),
  781. }),
  782. ProxySettings: serial.ToTypedMessage(&dokodemo.Config{
  783. Address: v2net.NewIPOrDomain(dest.Address),
  784. Port: uint32(dest.Port),
  785. NetworkList: &v2net.NetworkList{
  786. Network: []v2net.Network{v2net.Network_TCP},
  787. },
  788. }),
  789. },
  790. },
  791. Outbound: []*proxyman.OutboundHandlerConfig{
  792. {
  793. ProxySettings: serial.ToTypedMessage(&outbound.Config{
  794. Receiver: []*protocol.ServerEndpoint{
  795. {
  796. Address: v2net.NewIPOrDomain(v2net.LocalHostIPv6),
  797. Port: uint32(serverPort),
  798. User: []*protocol.User{
  799. {
  800. Account: serial.ToTypedMessage(&vmess.Account{
  801. Id: userID.String(),
  802. AlterId: 64,
  803. SecuritySettings: &protocol.SecurityConfig{
  804. Type: protocol.SecurityType_AES128_GCM,
  805. },
  806. }),
  807. },
  808. },
  809. },
  810. },
  811. }),
  812. },
  813. },
  814. App: []*serial.TypedMessage{
  815. serial.ToTypedMessage(&log.Config{
  816. ErrorLogLevel: log.LogLevel_Debug,
  817. ErrorLogType: log.LogType_Console,
  818. }),
  819. },
  820. }
  821. assert.Error(InitializeServerConfig(serverConfig)).IsNil()
  822. assert.Error(InitializeServerConfig(clientConfig)).IsNil()
  823. conn, err := net.DialTCP("tcp", nil, &net.TCPAddr{
  824. IP: v2net.LocalHostIPv6.IP(),
  825. Port: int(clientPort),
  826. })
  827. assert.Error(err).IsNil()
  828. payload := make([]byte, 1024)
  829. rand.Read(payload)
  830. nBytes, err := conn.Write([]byte(payload))
  831. assert.Error(err).IsNil()
  832. assert.Int(nBytes).Equals(len(payload))
  833. response := readFrom(conn, time.Second*20, 1024)
  834. assert.Bytes(response).Equals(xor([]byte(payload)))
  835. assert.Error(conn.Close()).IsNil()
  836. CloseAllServers()
  837. }
  838. func TestVMessGCMMux(t *testing.T) {
  839. assert := assert.On(t)
  840. tcpServer := tcp.Server{
  841. MsgProcessor: xor,
  842. }
  843. dest, err := tcpServer.Start()
  844. assert.Error(err).IsNil()
  845. defer tcpServer.Close()
  846. userID := protocol.NewID(uuid.New())
  847. serverPort := pickPort()
  848. serverConfig := &core.Config{
  849. Inbound: []*proxyman.InboundHandlerConfig{
  850. {
  851. ReceiverSettings: serial.ToTypedMessage(&proxyman.ReceiverConfig{
  852. PortRange: v2net.SinglePortRange(serverPort),
  853. Listen: v2net.NewIPOrDomain(v2net.LocalHostIP),
  854. }),
  855. ProxySettings: serial.ToTypedMessage(&inbound.Config{
  856. User: []*protocol.User{
  857. {
  858. Account: serial.ToTypedMessage(&vmess.Account{
  859. Id: userID.String(),
  860. AlterId: 64,
  861. }),
  862. },
  863. },
  864. }),
  865. },
  866. },
  867. Outbound: []*proxyman.OutboundHandlerConfig{
  868. {
  869. ProxySettings: serial.ToTypedMessage(&freedom.Config{}),
  870. },
  871. },
  872. App: []*serial.TypedMessage{
  873. serial.ToTypedMessage(&log.Config{
  874. ErrorLogLevel: log.LogLevel_Debug,
  875. ErrorLogType: log.LogType_Console,
  876. }),
  877. },
  878. }
  879. clientPort := pickPort()
  880. clientConfig := &core.Config{
  881. Inbound: []*proxyman.InboundHandlerConfig{
  882. {
  883. ReceiverSettings: serial.ToTypedMessage(&proxyman.ReceiverConfig{
  884. PortRange: v2net.SinglePortRange(clientPort),
  885. Listen: v2net.NewIPOrDomain(v2net.LocalHostIP),
  886. }),
  887. ProxySettings: serial.ToTypedMessage(&dokodemo.Config{
  888. Address: v2net.NewIPOrDomain(dest.Address),
  889. Port: uint32(dest.Port),
  890. NetworkList: &v2net.NetworkList{
  891. Network: []v2net.Network{v2net.Network_TCP},
  892. },
  893. }),
  894. },
  895. },
  896. Outbound: []*proxyman.OutboundHandlerConfig{
  897. {
  898. SenderSettings: serial.ToTypedMessage(&proxyman.SenderConfig{
  899. MultiplexSettings: &proxyman.MultiplexingConfig{
  900. Enabled: true,
  901. Concurrency: 4,
  902. },
  903. }),
  904. ProxySettings: serial.ToTypedMessage(&outbound.Config{
  905. Receiver: []*protocol.ServerEndpoint{
  906. {
  907. Address: v2net.NewIPOrDomain(v2net.LocalHostIP),
  908. Port: uint32(serverPort),
  909. User: []*protocol.User{
  910. {
  911. Account: serial.ToTypedMessage(&vmess.Account{
  912. Id: userID.String(),
  913. AlterId: 64,
  914. SecuritySettings: &protocol.SecurityConfig{
  915. Type: protocol.SecurityType_AES128_GCM,
  916. },
  917. }),
  918. },
  919. },
  920. },
  921. },
  922. }),
  923. },
  924. },
  925. App: []*serial.TypedMessage{
  926. serial.ToTypedMessage(&log.Config{
  927. ErrorLogLevel: log.LogLevel_Debug,
  928. ErrorLogType: log.LogType_Console,
  929. }),
  930. },
  931. }
  932. assert.Error(InitializeServerConfig(serverConfig)).IsNil()
  933. assert.Error(InitializeServerConfig(clientConfig)).IsNil()
  934. for range "abcd" {
  935. var wg sync.WaitGroup
  936. const nConnection = 16
  937. wg.Add(nConnection)
  938. for i := 0; i < nConnection; i++ {
  939. go func() {
  940. conn, err := net.DialTCP("tcp", nil, &net.TCPAddr{
  941. IP: []byte{127, 0, 0, 1},
  942. Port: int(clientPort),
  943. })
  944. assert.Error(err).IsNil()
  945. payload := make([]byte, 10240)
  946. rand.Read(payload)
  947. nBytes, err := conn.Write([]byte(payload))
  948. assert.Error(err).IsNil()
  949. assert.Int(nBytes).Equals(len(payload))
  950. response := readFrom(conn, time.Second*20, 10240)
  951. assert.Bytes(response).Equals(xor([]byte(payload)))
  952. assert.Error(conn.Close()).IsNil()
  953. wg.Done()
  954. }()
  955. }
  956. wg.Wait()
  957. time.Sleep(time.Second)
  958. }
  959. CloseAllServers()
  960. }
  961. func TestVMessGCMMuxUDP(t *testing.T) {
  962. assert := assert.On(t)
  963. tcpServer := tcp.Server{
  964. MsgProcessor: xor,
  965. }
  966. dest, err := tcpServer.Start()
  967. assert.Error(err).IsNil()
  968. defer tcpServer.Close()
  969. udpServer := udp.Server{
  970. MsgProcessor: xor,
  971. }
  972. udpDest, err := udpServer.Start()
  973. assert.Error(err).IsNil()
  974. defer udpServer.Close()
  975. userID := protocol.NewID(uuid.New())
  976. serverPort := pickPort()
  977. serverConfig := &core.Config{
  978. Inbound: []*proxyman.InboundHandlerConfig{
  979. {
  980. ReceiverSettings: serial.ToTypedMessage(&proxyman.ReceiverConfig{
  981. PortRange: v2net.SinglePortRange(serverPort),
  982. Listen: v2net.NewIPOrDomain(v2net.LocalHostIP),
  983. }),
  984. ProxySettings: serial.ToTypedMessage(&inbound.Config{
  985. User: []*protocol.User{
  986. {
  987. Account: serial.ToTypedMessage(&vmess.Account{
  988. Id: userID.String(),
  989. AlterId: 64,
  990. }),
  991. },
  992. },
  993. }),
  994. },
  995. },
  996. Outbound: []*proxyman.OutboundHandlerConfig{
  997. {
  998. ProxySettings: serial.ToTypedMessage(&freedom.Config{}),
  999. },
  1000. },
  1001. App: []*serial.TypedMessage{
  1002. serial.ToTypedMessage(&log.Config{
  1003. ErrorLogLevel: log.LogLevel_Debug,
  1004. ErrorLogType: log.LogType_Console,
  1005. }),
  1006. },
  1007. }
  1008. clientPort := pickPort()
  1009. clientUDPPort := pickUDPPort()
  1010. clientConfig := &core.Config{
  1011. Inbound: []*proxyman.InboundHandlerConfig{
  1012. {
  1013. ReceiverSettings: serial.ToTypedMessage(&proxyman.ReceiverConfig{
  1014. PortRange: v2net.SinglePortRange(clientPort),
  1015. Listen: v2net.NewIPOrDomain(v2net.LocalHostIP),
  1016. }),
  1017. ProxySettings: serial.ToTypedMessage(&dokodemo.Config{
  1018. Address: v2net.NewIPOrDomain(dest.Address),
  1019. Port: uint32(dest.Port),
  1020. NetworkList: &v2net.NetworkList{
  1021. Network: []v2net.Network{v2net.Network_TCP},
  1022. },
  1023. }),
  1024. },
  1025. {
  1026. ReceiverSettings: serial.ToTypedMessage(&proxyman.ReceiverConfig{
  1027. PortRange: v2net.SinglePortRange(clientUDPPort),
  1028. Listen: v2net.NewIPOrDomain(v2net.LocalHostIP),
  1029. }),
  1030. ProxySettings: serial.ToTypedMessage(&dokodemo.Config{
  1031. Address: v2net.NewIPOrDomain(udpDest.Address),
  1032. Port: uint32(udpDest.Port),
  1033. NetworkList: &v2net.NetworkList{
  1034. Network: []v2net.Network{v2net.Network_UDP},
  1035. },
  1036. }),
  1037. },
  1038. },
  1039. Outbound: []*proxyman.OutboundHandlerConfig{
  1040. {
  1041. SenderSettings: serial.ToTypedMessage(&proxyman.SenderConfig{
  1042. MultiplexSettings: &proxyman.MultiplexingConfig{
  1043. Enabled: true,
  1044. Concurrency: 4,
  1045. },
  1046. }),
  1047. ProxySettings: serial.ToTypedMessage(&outbound.Config{
  1048. Receiver: []*protocol.ServerEndpoint{
  1049. {
  1050. Address: v2net.NewIPOrDomain(v2net.LocalHostIP),
  1051. Port: uint32(serverPort),
  1052. User: []*protocol.User{
  1053. {
  1054. Account: serial.ToTypedMessage(&vmess.Account{
  1055. Id: userID.String(),
  1056. AlterId: 64,
  1057. SecuritySettings: &protocol.SecurityConfig{
  1058. Type: protocol.SecurityType_AES128_GCM,
  1059. },
  1060. }),
  1061. },
  1062. },
  1063. },
  1064. },
  1065. }),
  1066. },
  1067. },
  1068. App: []*serial.TypedMessage{
  1069. serial.ToTypedMessage(&log.Config{
  1070. ErrorLogLevel: log.LogLevel_Debug,
  1071. ErrorLogType: log.LogType_Console,
  1072. }),
  1073. },
  1074. }
  1075. assert.Error(InitializeServerConfig(serverConfig)).IsNil()
  1076. assert.Error(InitializeServerConfig(clientConfig)).IsNil()
  1077. for range "abcd" {
  1078. var wg sync.WaitGroup
  1079. const nConnection = 16
  1080. wg.Add(nConnection * 2)
  1081. for i := 0; i < nConnection; i++ {
  1082. go func() {
  1083. conn, err := net.DialTCP("tcp", nil, &net.TCPAddr{
  1084. IP: []byte{127, 0, 0, 1},
  1085. Port: int(clientPort),
  1086. })
  1087. assert.Error(err).IsNil()
  1088. payload := make([]byte, 10240)
  1089. rand.Read(payload)
  1090. nBytes, err := conn.Write([]byte(payload))
  1091. assert.Error(err).IsNil()
  1092. assert.Int(nBytes).Equals(len(payload))
  1093. response := readFrom(conn, time.Second*20, 10240)
  1094. assert.Bytes(response).Equals(xor([]byte(payload)))
  1095. assert.Error(conn.Close()).IsNil()
  1096. wg.Done()
  1097. }()
  1098. }
  1099. for i := 0; i < nConnection; i++ {
  1100. go func() {
  1101. conn, err := net.DialUDP("udp", nil, &net.UDPAddr{
  1102. IP: []byte{127, 0, 0, 1},
  1103. Port: int(clientUDPPort),
  1104. })
  1105. assert.Error(err).IsNil()
  1106. conn.SetDeadline(time.Now().Add(time.Second * 10))
  1107. payload := make([]byte, 1024)
  1108. rand.Read(payload)
  1109. for j := 0; j < 5; j++ {
  1110. nBytes, _, err := conn.WriteMsgUDP(payload, nil, nil)
  1111. assert.Error(err).IsNil()
  1112. assert.Int(nBytes).Equals(len(payload))
  1113. }
  1114. response := make([]byte, 1024)
  1115. oob := make([]byte, 16)
  1116. for j := 0; j < 5; j++ {
  1117. nBytes, _, _, _, err := conn.ReadMsgUDP(response, oob)
  1118. assert.Error(err).IsNil()
  1119. assert.Int(nBytes).Equals(1024)
  1120. assert.Bytes(response).Equals(xor(payload))
  1121. }
  1122. assert.Error(conn.Close()).IsNil()
  1123. wg.Done()
  1124. }()
  1125. }
  1126. wg.Wait()
  1127. time.Sleep(time.Second)
  1128. }
  1129. CloseAllServers()
  1130. }