|
|
@@ -8,7 +8,6 @@ import (
|
|
|
"github.com/v2ray/v2ray-core/common/log"
|
|
|
v2net "github.com/v2ray/v2ray-core/common/net"
|
|
|
"github.com/v2ray/v2ray-core/proxy/internal"
|
|
|
- "github.com/v2ray/v2ray-core/proxy/internal/config"
|
|
|
)
|
|
|
|
|
|
const (
|
|
|
@@ -16,48 +15,48 @@ const (
|
|
|
AuthMethodUserPass = "password"
|
|
|
)
|
|
|
|
|
|
+func (this *Config) UnmarshalJSON(data []byte) error {
|
|
|
+ type SocksAccount struct {
|
|
|
+ Username string `json:"user"`
|
|
|
+ Password string `json:"pass"`
|
|
|
+ }
|
|
|
+
|
|
|
+ type SocksConfig struct {
|
|
|
+ AuthMethod string `json:"auth"`
|
|
|
+ Accounts []*SocksAccount `json:"accounts"`
|
|
|
+ UDP bool `json:"udp"`
|
|
|
+ Host *v2net.AddressJson `json:"ip"`
|
|
|
+ }
|
|
|
+
|
|
|
+ rawConfig := new(SocksConfig)
|
|
|
+ if err := json.Unmarshal(data, rawConfig); err != nil {
|
|
|
+ return err
|
|
|
+ }
|
|
|
+ if rawConfig.AuthMethod == AuthMethodNoAuth {
|
|
|
+ this.AuthType = AuthTypeNoAuth
|
|
|
+ } else if rawConfig.AuthMethod == AuthMethodUserPass {
|
|
|
+ this.AuthType = AuthTypePassword
|
|
|
+ } else {
|
|
|
+ log.Error("Socks: Unknown auth method: ", rawConfig.AuthMethod)
|
|
|
+ return internal.ErrorBadConfiguration
|
|
|
+ }
|
|
|
+
|
|
|
+ if len(rawConfig.Accounts) > 0 {
|
|
|
+ this.Accounts = make(map[string]string, len(rawConfig.Accounts))
|
|
|
+ for _, account := range rawConfig.Accounts {
|
|
|
+ this.Accounts[account.Username] = account.Password
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ this.UDPEnabled = rawConfig.UDP
|
|
|
+ if rawConfig.Host != nil {
|
|
|
+ this.Address = rawConfig.Host.Address
|
|
|
+ } else {
|
|
|
+ this.Address = v2net.LocalHostIP
|
|
|
+ }
|
|
|
+ return nil
|
|
|
+}
|
|
|
+
|
|
|
func init() {
|
|
|
- config.RegisterInboundConfig("socks",
|
|
|
- func(data []byte) (interface{}, error) {
|
|
|
- type SocksAccount struct {
|
|
|
- Username string `json:"user"`
|
|
|
- Password string `json:"pass"`
|
|
|
- }
|
|
|
-
|
|
|
- type SocksConfig struct {
|
|
|
- AuthMethod string `json:"auth"`
|
|
|
- Accounts []*SocksAccount `json:"accounts"`
|
|
|
- UDP bool `json:"udp"`
|
|
|
- Host *v2net.AddressJson `json:"ip"`
|
|
|
- }
|
|
|
-
|
|
|
- rawConfig := new(SocksConfig)
|
|
|
- if err := json.Unmarshal(data, rawConfig); err != nil {
|
|
|
- return nil, err
|
|
|
- }
|
|
|
- socksConfig := new(Config)
|
|
|
- if rawConfig.AuthMethod == AuthMethodNoAuth {
|
|
|
- socksConfig.AuthType = AuthTypeNoAuth
|
|
|
- } else if rawConfig.AuthMethod == AuthMethodUserPass {
|
|
|
- socksConfig.AuthType = AuthTypePassword
|
|
|
- } else {
|
|
|
- log.Error("Socks: Unknown auth method: ", rawConfig.AuthMethod)
|
|
|
- return nil, internal.ErrorBadConfiguration
|
|
|
- }
|
|
|
-
|
|
|
- if len(rawConfig.Accounts) > 0 {
|
|
|
- socksConfig.Accounts = make(map[string]string, len(rawConfig.Accounts))
|
|
|
- for _, account := range rawConfig.Accounts {
|
|
|
- socksConfig.Accounts[account.Username] = account.Password
|
|
|
- }
|
|
|
- }
|
|
|
-
|
|
|
- socksConfig.UDPEnabled = rawConfig.UDP
|
|
|
- if rawConfig.Host != nil {
|
|
|
- socksConfig.Address = rawConfig.Host.Address
|
|
|
- } else {
|
|
|
- socksConfig.Address = v2net.LocalHostIP
|
|
|
- }
|
|
|
- return socksConfig, nil
|
|
|
- })
|
|
|
+ internal.RegisterInboundConfig("socks", func() interface{} { return new(Config) })
|
|
|
}
|