transport_internet.go 7.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255
  1. package conf
  2. import (
  3. "encoding/json"
  4. "io/ioutil"
  5. "strings"
  6. "v2ray.com/core/common/serial"
  7. "v2ray.com/core/transport/internet"
  8. "v2ray.com/core/transport/internet/kcp"
  9. "v2ray.com/core/transport/internet/tcp"
  10. "v2ray.com/core/transport/internet/tls"
  11. "v2ray.com/core/transport/internet/websocket"
  12. )
  13. var (
  14. kcpHeaderLoader = NewJSONConfigLoader(ConfigCreatorCache{
  15. "none": func() interface{} { return new(NoOpAuthenticator) },
  16. "srtp": func() interface{} { return new(SRTPAuthenticator) },
  17. "utp": func() interface{} { return new(UTPAuthenticator) },
  18. "wechat-video": func() interface{} { return new(WechatVideoAuthenticator) },
  19. }, "type", "")
  20. tcpHeaderLoader = NewJSONConfigLoader(ConfigCreatorCache{
  21. "none": func() interface{} { return new(NoOpConnectionAuthenticator) },
  22. "http": func() interface{} { return new(HTTPAuthenticator) },
  23. }, "type", "")
  24. )
  25. type KCPConfig struct {
  26. Mtu *uint32 `json:"mtu"`
  27. Tti *uint32 `json:"tti"`
  28. UpCap *uint32 `json:"uplinkCapacity"`
  29. DownCap *uint32 `json:"downlinkCapacity"`
  30. Congestion *bool `json:"congestion"`
  31. ReadBufferSize *uint32 `json:"readBufferSize"`
  32. WriteBufferSize *uint32 `json:"writeBufferSize"`
  33. HeaderConfig json.RawMessage `json:"header"`
  34. }
  35. func (v *KCPConfig) Build() (*serial.TypedMessage, error) {
  36. config := new(kcp.Config)
  37. if v.Mtu != nil {
  38. mtu := *v.Mtu
  39. if mtu < 576 || mtu > 1460 {
  40. return nil, newError("invalid mKCP MTU size: ", mtu).AtError()
  41. }
  42. config.Mtu = &kcp.MTU{Value: mtu}
  43. }
  44. if v.Tti != nil {
  45. tti := *v.Tti
  46. if tti < 10 || tti > 100 {
  47. return nil, newError("invalid mKCP TTI: ", tti).AtError()
  48. }
  49. config.Tti = &kcp.TTI{Value: tti}
  50. }
  51. if v.UpCap != nil {
  52. config.UplinkCapacity = &kcp.UplinkCapacity{Value: *v.UpCap}
  53. }
  54. if v.DownCap != nil {
  55. config.DownlinkCapacity = &kcp.DownlinkCapacity{Value: *v.DownCap}
  56. }
  57. if v.Congestion != nil {
  58. config.Congestion = *v.Congestion
  59. }
  60. if v.ReadBufferSize != nil {
  61. size := *v.ReadBufferSize
  62. if size > 0 {
  63. config.ReadBuffer = &kcp.ReadBuffer{Size: size * 1024 * 1024}
  64. } else {
  65. config.ReadBuffer = &kcp.ReadBuffer{Size: 512 * 1024}
  66. }
  67. }
  68. if v.WriteBufferSize != nil {
  69. size := *v.WriteBufferSize
  70. if size > 0 {
  71. config.WriteBuffer = &kcp.WriteBuffer{Size: size * 1024 * 1024}
  72. } else {
  73. config.WriteBuffer = &kcp.WriteBuffer{Size: 512 * 1024}
  74. }
  75. }
  76. if len(v.HeaderConfig) > 0 {
  77. headerConfig, _, err := kcpHeaderLoader.Load(v.HeaderConfig)
  78. if err != nil {
  79. return nil, newError("invalid mKCP header config.").Base(err).AtError()
  80. }
  81. ts, err := headerConfig.(Buildable).Build()
  82. if err != nil {
  83. return nil, newError("invalid mKCP header config").Base(err).AtError()
  84. }
  85. config.HeaderConfig = ts
  86. }
  87. return serial.ToTypedMessage(config), nil
  88. }
  89. type TCPConfig struct {
  90. HeaderConfig json.RawMessage `json:"header"`
  91. }
  92. func (v *TCPConfig) Build() (*serial.TypedMessage, error) {
  93. config := new(tcp.Config)
  94. if len(v.HeaderConfig) > 0 {
  95. headerConfig, _, err := tcpHeaderLoader.Load(v.HeaderConfig)
  96. if err != nil {
  97. return nil, newError("invalid TCP header config").Base(err).AtError()
  98. }
  99. ts, err := headerConfig.(Buildable).Build()
  100. if err != nil {
  101. return nil, newError("invalid TCP header config").Base(err).AtError()
  102. }
  103. config.HeaderSettings = ts
  104. }
  105. return serial.ToTypedMessage(config), nil
  106. }
  107. type WebSocketConfig struct {
  108. Path string `json:"Path"`
  109. }
  110. func (v *WebSocketConfig) Build() (*serial.TypedMessage, error) {
  111. config := &websocket.Config{
  112. Path: v.Path,
  113. }
  114. return serial.ToTypedMessage(config), nil
  115. }
  116. type TLSCertConfig struct {
  117. CertFile string `json:"certificateFile"`
  118. KeyFile string `json:"keyFile"`
  119. }
  120. type TLSConfig struct {
  121. Insecure bool `json:"allowInsecure"`
  122. Certs []*TLSCertConfig `json:"certificates"`
  123. ServerName string `json:"serverName"`
  124. }
  125. func (v *TLSConfig) Build() (*serial.TypedMessage, error) {
  126. config := new(tls.Config)
  127. config.Certificate = make([]*tls.Certificate, len(v.Certs))
  128. for idx, certConf := range v.Certs {
  129. cert, err := ioutil.ReadFile(certConf.CertFile)
  130. if err != nil {
  131. return nil, newError("failed to load TLS certificate file: ", certConf.CertFile).Base(err).AtError()
  132. }
  133. key, err := ioutil.ReadFile(certConf.KeyFile)
  134. if err != nil {
  135. return nil, newError("failed to load TLS key file: ", certConf.KeyFile).Base(err).AtError()
  136. }
  137. config.Certificate[idx] = &tls.Certificate{
  138. Key: key,
  139. Certificate: cert,
  140. }
  141. }
  142. config.AllowInsecure = v.Insecure
  143. if len(v.ServerName) > 0 {
  144. config.ServerName = v.ServerName
  145. }
  146. return serial.ToTypedMessage(config), nil
  147. }
  148. type TransportProtocol string
  149. func (p TransportProtocol) Build() (internet.TransportProtocol, error) {
  150. switch strings.ToLower(string(p)) {
  151. case "tcp":
  152. return internet.TransportProtocol_TCP, nil
  153. case "kcp", "mkcp":
  154. return internet.TransportProtocol_MKCP, nil
  155. case "ws", "websocket":
  156. return internet.TransportProtocol_WebSocket, nil
  157. default:
  158. return internet.TransportProtocol_TCP, newError("Config: unknown transport protocol: ", p)
  159. }
  160. }
  161. type StreamConfig struct {
  162. Network *TransportProtocol `json:"network"`
  163. Security string `json:"security"`
  164. TLSSettings *TLSConfig `json:"tlsSettings"`
  165. TCPSettings *TCPConfig `json:"tcpSettings"`
  166. KCPSettings *KCPConfig `json:"kcpSettings"`
  167. WSSettings *WebSocketConfig `json:"wsSettings"`
  168. }
  169. func (v *StreamConfig) Build() (*internet.StreamConfig, error) {
  170. config := &internet.StreamConfig{
  171. Protocol: internet.TransportProtocol_TCP,
  172. }
  173. if v.Network != nil {
  174. protocol, err := (*v.Network).Build()
  175. if err != nil {
  176. return nil, err
  177. }
  178. config.Protocol = protocol
  179. }
  180. if strings.ToLower(v.Security) == "tls" {
  181. tlsSettings := v.TLSSettings
  182. if tlsSettings == nil {
  183. tlsSettings = &TLSConfig{}
  184. }
  185. ts, err := tlsSettings.Build()
  186. if err != nil {
  187. return nil, newError("Failed to build TLS config.").Base(err)
  188. }
  189. config.SecuritySettings = append(config.SecuritySettings, ts)
  190. config.SecurityType = ts.Type
  191. }
  192. if v.TCPSettings != nil {
  193. ts, err := v.TCPSettings.Build()
  194. if err != nil {
  195. return nil, newError("Failed to build TCP config.").Base(err)
  196. }
  197. config.TransportSettings = append(config.TransportSettings, &internet.TransportConfig{
  198. Protocol: internet.TransportProtocol_TCP,
  199. Settings: ts,
  200. })
  201. }
  202. if v.KCPSettings != nil {
  203. ts, err := v.KCPSettings.Build()
  204. if err != nil {
  205. return nil, newError("Failed to build mKCP config.").Base(err)
  206. }
  207. config.TransportSettings = append(config.TransportSettings, &internet.TransportConfig{
  208. Protocol: internet.TransportProtocol_MKCP,
  209. Settings: ts,
  210. })
  211. }
  212. if v.WSSettings != nil {
  213. ts, err := v.WSSettings.Build()
  214. if err != nil {
  215. return nil, newError("Failed to build WebSocket config.").Base(err)
  216. }
  217. config.TransportSettings = append(config.TransportSettings, &internet.TransportConfig{
  218. Protocol: internet.TransportProtocol_WebSocket,
  219. Settings: ts,
  220. })
  221. }
  222. return config, nil
  223. }
  224. type ProxyConfig struct {
  225. Tag string `json:"tag"`
  226. }
  227. func (v *ProxyConfig) Build() (*internet.ProxyConfig, error) {
  228. if len(v.Tag) == 0 {
  229. return nil, newError("Proxy tag is not set.")
  230. }
  231. return &internet.ProxyConfig{
  232. Tag: v.Tag,
  233. }, nil
  234. }