vmess_test.go 31 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219
  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 := pickPort()
  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. payload := make([]byte, 1024)
  1107. rand.Read(payload)
  1108. nBytes, err := conn.Write(payload)
  1109. assert.Error(err).IsNil()
  1110. assert.Int(nBytes).Equals(len(payload))
  1111. response := readFrom(conn, time.Second*5, 1024)
  1112. assert.Bytes(response).Equals(xor(payload))
  1113. assert.Error(conn.Close()).IsNil()
  1114. wg.Done()
  1115. }()
  1116. }
  1117. wg.Wait()
  1118. time.Sleep(time.Second)
  1119. }
  1120. CloseAllServers()
  1121. }