transport_internet.go 7.2 KB

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