| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244 |
- package conf
- import (
- "encoding/json"
- "fmt"
- "io/ioutil"
- "strings"
- "v2ray.com/core/common/errors"
- "v2ray.com/core/common/loader"
- v2net "v2ray.com/core/common/net"
- "v2ray.com/core/transport/internet"
- "v2ray.com/core/transport/internet/kcp"
- "v2ray.com/core/transport/internet/tcp"
- "v2ray.com/core/transport/internet/tls"
- "v2ray.com/core/transport/internet/ws"
- )
- var (
- kcpHeaderLoader = NewJSONConfigLoader(ConfigCreatorCache{
- "none": func() interface{} { return new(NoOpAuthenticator) },
- "srtp": func() interface{} { return new(SRTPAuthenticator) },
- "utp": func() interface{} { return new(UTPAuthenticator) },
- }, "type", "")
- tcpHeaderLoader = NewJSONConfigLoader(ConfigCreatorCache{
- "none": func() interface{} { return new(NoOpConnectionAuthenticator) },
- "http": func() interface{} { return new(HTTPAuthenticator) },
- }, "type", "")
- )
- type KCPConfig struct {
- Mtu *uint32 `json:"mtu"`
- Tti *uint32 `json:"tti"`
- UpCap *uint32 `json:"uplinkCapacity"`
- DownCap *uint32 `json:"downlinkCapacity"`
- Congestion *bool `json:"congestion"`
- ReadBufferSize *uint32 `json:"readBufferSize"`
- WriteBufferSize *uint32 `json:"writeBufferSize"`
- HeaderConfig json.RawMessage `json:"header"`
- }
- func (v *KCPConfig) Build() (*loader.TypedSettings, error) {
- config := new(kcp.Config)
- if v.Mtu != nil {
- mtu := *v.Mtu
- if mtu < 576 || mtu > 1460 {
- return nil, fmt.Errorf("KCP|Config: Invalid MTU size: %d", mtu)
- }
- config.Mtu = &kcp.MTU{Value: mtu}
- }
- if v.Tti != nil {
- tti := *v.Tti
- if tti < 10 || tti > 100 {
- return nil, fmt.Errorf("KCP|Config: Invalid TTI: %d", tti)
- }
- config.Tti = &kcp.TTI{Value: tti}
- }
- if v.UpCap != nil {
- config.UplinkCapacity = &kcp.UplinkCapacity{Value: *v.UpCap}
- }
- if v.DownCap != nil {
- config.DownlinkCapacity = &kcp.DownlinkCapacity{Value: *v.DownCap}
- }
- if v.Congestion != nil {
- config.Congestion = *v.Congestion
- }
- if v.ReadBufferSize != nil {
- size := *v.ReadBufferSize
- if size > 0 {
- config.ReadBuffer = &kcp.ReadBuffer{Size: size * 1024 * 1024}
- } else {
- config.ReadBuffer = &kcp.ReadBuffer{Size: 512 * 1024}
- }
- }
- if v.WriteBufferSize != nil {
- size := *v.WriteBufferSize
- if size > 0 {
- config.WriteBuffer = &kcp.WriteBuffer{Size: size * 1024 * 1024}
- } else {
- config.WriteBuffer = &kcp.WriteBuffer{Size: 512 * 1024}
- }
- }
- if len(v.HeaderConfig) > 0 {
- headerConfig, _, err := kcpHeaderLoader.Load(v.HeaderConfig)
- if err != nil {
- return nil, errors.Base(err).Message("Invalid mKCP header config.")
- }
- ts, err := headerConfig.(Buildable).Build()
- if err != nil {
- return nil, errors.Base(err).Message("Invalid mKCP header config.")
- }
- config.HeaderConfig = ts
- }
- return loader.NewTypedSettings(config), nil
- }
- type TCPConfig struct {
- ConnectionReuse *bool `json:"connectionReuse"`
- HeaderConfig json.RawMessage `json:"header"`
- }
- func (v *TCPConfig) Build() (*loader.TypedSettings, error) {
- config := new(tcp.Config)
- if v.ConnectionReuse != nil {
- config.ConnectionReuse = &tcp.ConnectionReuse{
- Enable: *v.ConnectionReuse,
- }
- }
- if len(v.HeaderConfig) > 0 {
- headerConfig, _, err := tcpHeaderLoader.Load(v.HeaderConfig)
- if err != nil {
- return nil, errors.Base(err).Message("Invalid TCP header config.")
- }
- ts, err := headerConfig.(Buildable).Build()
- if err != nil {
- return nil, errors.Base(err).Message("Invalid TCP header config.")
- }
- config.HeaderSettings = ts
- }
- return loader.NewTypedSettings(config), nil
- }
- type WebSocketConfig struct {
- ConnectionReuse *bool `json:"connectionReuse"`
- Path string `json:"Path"`
- }
- func (v *WebSocketConfig) Build() (*loader.TypedSettings, error) {
- config := &ws.Config{
- Path: v.Path,
- }
- if v.ConnectionReuse != nil {
- config.ConnectionReuse = &ws.ConnectionReuse{
- Enable: *v.ConnectionReuse,
- }
- }
- return loader.NewTypedSettings(config), nil
- }
- type TLSCertConfig struct {
- CertFile string `json:"certificateFile"`
- KeyFile string `json:"keyFile"`
- }
- type TLSConfig struct {
- Insecure bool `json:"allowInsecure"`
- Certs []*TLSCertConfig `json:"certificates"`
- }
- func (v *TLSConfig) Build() (*loader.TypedSettings, error) {
- config := new(tls.Config)
- config.Certificate = make([]*tls.Certificate, len(v.Certs))
- for idx, certConf := range v.Certs {
- cert, err := ioutil.ReadFile(certConf.CertFile)
- if err != nil {
- return nil, errors.Base(err).Message("Failed to load TLS certificate file: ", certConf.CertFile)
- }
- key, err := ioutil.ReadFile(certConf.KeyFile)
- if err != nil {
- return nil, errors.Base(err).Message("Failed to load TLS key file: ", certConf.KeyFile)
- }
- config.Certificate[idx] = &tls.Certificate{
- Key: key,
- Certificate: cert,
- }
- }
- config.AllowInsecure = v.Insecure
- return loader.NewTypedSettings(config), nil
- }
- type StreamConfig struct {
- Network *Network `json:"network"`
- Security string `json:"security"`
- TLSSettings *TLSConfig `json:"tlsSettings"`
- TCPSettings *TCPConfig `json:"tcpSettings"`
- KCPSettings *KCPConfig `json:"kcpSettings"`
- WSSettings *WebSocketConfig `json:"wsSettings"`
- }
- func (v *StreamConfig) Build() (*internet.StreamConfig, error) {
- config := &internet.StreamConfig{
- Network: v2net.Network_RawTCP,
- }
- if v.Network != nil {
- config.Network = (*v.Network).Build()
- }
- if strings.ToLower(v.Security) == "tls" {
- tlsSettings := v.TLSSettings
- if tlsSettings == nil {
- tlsSettings = &TLSConfig{}
- }
- ts, err := tlsSettings.Build()
- if err != nil {
- return nil, errors.Base(err).Message("Failed to build TLS config.")
- }
- config.SecuritySettings = append(config.SecuritySettings, ts)
- }
- if v.TCPSettings != nil {
- ts, err := v.TCPSettings.Build()
- if err != nil {
- return nil, errors.Base(err).Message("Failed to build TCP config.")
- }
- config.NetworkSettings = append(config.NetworkSettings, &internet.NetworkSettings{
- Network: v2net.Network_TCP,
- Settings: ts,
- })
- }
- if v.KCPSettings != nil {
- ts, err := v.KCPSettings.Build()
- if err != nil {
- return nil, errors.Base(err).Message("Failed to build mKCP config.")
- }
- config.NetworkSettings = append(config.NetworkSettings, &internet.NetworkSettings{
- Network: v2net.Network_KCP,
- Settings: ts,
- })
- }
- if v.WSSettings != nil {
- ts, err := v.WSSettings.Build()
- if err != nil {
- return nil, errors.Base(err).Message("Failed to build WebSocket config.")
- }
- config.NetworkSettings = append(config.NetworkSettings, &internet.NetworkSettings{
- Network: v2net.Network_WebSocket,
- Settings: ts,
- })
- }
- return config, nil
- }
- type ProxyConfig struct {
- Tag string `json:"tag"`
- }
- func (v *ProxyConfig) Build() (*internet.ProxyConfig, error) {
- if len(v.Tag) == 0 {
- return nil, errors.New("Proxy tag is not set.")
- }
- return &internet.ProxyConfig{
- Tag: v.Tag,
- }, nil
- }
|