shadowtls_test.go 4.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156
  1. package scenarios
  2. import (
  3. "crypto/rand"
  4. "encoding/base64"
  5. "testing"
  6. "time"
  7. "github.com/sagernet/sing-shadowsocks/shadowaead_2022"
  8. "github.com/xtls/xray-core/app/log"
  9. "github.com/xtls/xray-core/app/proxyman"
  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/serial"
  14. "github.com/xtls/xray-core/core"
  15. "github.com/xtls/xray-core/proxy/dokodemo"
  16. "github.com/xtls/xray-core/proxy/freedom"
  17. "github.com/xtls/xray-core/proxy/shadowsocks_2022"
  18. "github.com/xtls/xray-core/proxy/shadowtls"
  19. "github.com/xtls/xray-core/testing/servers/tcp"
  20. "github.com/xtls/xray-core/transport/internet"
  21. "github.com/xtls/xray-core/transport/internet/tls"
  22. "golang.org/x/sync/errgroup"
  23. )
  24. func TestShadowTLSTcp(t *testing.T) {
  25. password := make([]byte, 32)
  26. rand.Read(password)
  27. testShadowTLSTcp(t, shadowaead_2022.List[0], base64.StdEncoding.EncodeToString(password))
  28. }
  29. func testShadowTLSTcp(t *testing.T, method string, password string) {
  30. tcpServer := tcp.Server{
  31. MsgProcessor: xor,
  32. }
  33. dest, err := tcpServer.Start()
  34. common.Must(err)
  35. defer tcpServer.Close()
  36. serverPort := tcp.PickPort()
  37. serverPort = 18462
  38. serverConfig := &core.Config{
  39. App: []*serial.TypedMessage{
  40. serial.ToTypedMessage(&log.Config{
  41. ErrorLogLevel: clog.Severity_Debug,
  42. ErrorLogType: log.LogType_Console,
  43. }),
  44. },
  45. Inbound: []*core.InboundHandlerConfig{
  46. {
  47. ReceiverSettings: serial.ToTypedMessage(&proxyman.ReceiverConfig{
  48. PortList: &net.PortList{Range: []*net.PortRange{net.SinglePortRange(serverPort)}},
  49. Listen: net.NewIPOrDomain(net.LocalHostIP),
  50. }),
  51. ProxySettings: serial.ToTypedMessage(&shadowtls.ServerConfig{
  52. Version: 3,
  53. Users: []*shadowtls.User{{Password: password}},
  54. Handshake: &shadowtls.HandshakeConfig{
  55. Address: net.NewIPOrDomain(net.DomainAddress("google.com")),
  56. Port: 443,
  57. },
  58. Detour: "detour",
  59. }),
  60. },
  61. {
  62. Tag: "detour",
  63. ReceiverSettings: serial.ToTypedMessage(&proxyman.ReceiverConfig{
  64. PortList: &net.PortList{Range: []*net.PortRange{net.SinglePortRange(serverPort + 1)}},
  65. Listen: net.NewIPOrDomain(net.LocalHostIP),
  66. }),
  67. ProxySettings: serial.ToTypedMessage(&shadowsocks_2022.ServerConfig{
  68. Method: method,
  69. Key: password,
  70. Network: []net.Network{net.Network_TCP},
  71. }),
  72. },
  73. },
  74. Outbound: []*core.OutboundHandlerConfig{
  75. {
  76. ProxySettings: serial.ToTypedMessage(&freedom.Config{}),
  77. },
  78. },
  79. }
  80. clientPort := tcp.PickPort()
  81. clientPort = 12434
  82. clientConfig := &core.Config{
  83. App: []*serial.TypedMessage{
  84. serial.ToTypedMessage(&log.Config{
  85. ErrorLogLevel: clog.Severity_Debug,
  86. ErrorLogType: log.LogType_Console,
  87. }),
  88. },
  89. Inbound: []*core.InboundHandlerConfig{
  90. {
  91. ReceiverSettings: serial.ToTypedMessage(&proxyman.ReceiverConfig{
  92. PortList: &net.PortList{Range: []*net.PortRange{net.SinglePortRange(clientPort)}},
  93. Listen: net.NewIPOrDomain(net.LocalHostIP),
  94. }),
  95. ProxySettings: serial.ToTypedMessage(&dokodemo.Config{
  96. Address: net.NewIPOrDomain(dest.Address),
  97. Port: uint32(dest.Port),
  98. Networks: []net.Network{net.Network_TCP},
  99. }),
  100. },
  101. },
  102. Outbound: []*core.OutboundHandlerConfig{
  103. {
  104. ProxySettings: serial.ToTypedMessage(&shadowsocks_2022.ClientConfig{
  105. Address: net.NewIPOrDomain(net.LocalHostIP),
  106. Port: uint32(serverPort),
  107. Method: method,
  108. Key: password,
  109. }),
  110. SenderSettings: serial.ToTypedMessage(&proxyman.SenderConfig{
  111. ProxySettings: &internet.ProxyConfig{
  112. Tag: "detour",
  113. },
  114. }),
  115. },
  116. {
  117. Tag: "detour",
  118. ProxySettings: serial.ToTypedMessage(&shadowtls.ClientConfig{
  119. Address: net.NewIPOrDomain(net.LocalHostIP),
  120. Port: uint32(serverPort),
  121. Version: 3,
  122. Password: password,
  123. }),
  124. SenderSettings: serial.ToTypedMessage(&proxyman.SenderConfig{
  125. StreamSettings: &internet.StreamConfig{
  126. SecurityType: serial.GetMessageType(&tls.Config{}),
  127. SecuritySettings: []*serial.TypedMessage{
  128. serial.ToTypedMessage(&tls.Config{
  129. ServerName: "google.com",
  130. }),
  131. },
  132. },
  133. }),
  134. },
  135. },
  136. }
  137. servers, err := InitializeServerConfigs(serverConfig, clientConfig)
  138. common.Must(err)
  139. defer CloseAllServers(servers)
  140. var errGroup errgroup.Group
  141. for i := 0; i < 10; i++ {
  142. errGroup.Go(testTCPConn(clientPort, 10240*1024, time.Second*20))
  143. }
  144. if err := errGroup.Wait(); err != nil {
  145. t.Error(err)
  146. }
  147. }