| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970 | // +build jsonpackage shadowsocksimport (	"encoding/json"	"strings"	"github.com/v2ray/v2ray-core/common/log"	"github.com/v2ray/v2ray-core/common/protocol"	"github.com/v2ray/v2ray-core/proxy/internal"	"github.com/v2ray/v2ray-core/proxy/internal/config")func (this *Config) UnmarshalJSON(data []byte) error {	type JsonConfig struct {		Cipher   string `json:"method"`		Password string `json:"password"`		UDP      bool   `json:"udp"`		Level    byte   `json:"level"`		Email    string `json:"email"`	}	jsonConfig := new(JsonConfig)	if err := json.Unmarshal(data, jsonConfig); err != nil {		return err	}	this.UDP = jsonConfig.UDP	jsonConfig.Cipher = strings.ToLower(jsonConfig.Cipher)	switch jsonConfig.Cipher {	case "aes-256-cfb":		this.Cipher = &AesCfb{			KeyBytes: 32,		}	case "aes-128-cfb":		this.Cipher = &AesCfb{			KeyBytes: 16,		}	case "chacha20":		this.Cipher = &ChaCha20{			IVBytes: 8,		}	case "chacha20-ietf":		this.Cipher = &ChaCha20{			IVBytes: 12,		}	default:		log.Error("Shadowsocks: Unknown cipher method: ", jsonConfig.Cipher)		return internal.ErrorBadConfiguration	}	if len(jsonConfig.Password) == 0 {		log.Error("Shadowsocks: Password is not specified.")		return internal.ErrorBadConfiguration	}	this.Key = PasswordToCipherKey(jsonConfig.Password, this.Cipher.KeySize())	this.Level = protocol.UserLevel(jsonConfig.Level)	this.Email = jsonConfig.Email	return nil}func init() {	config.RegisterInboundConfig("shadowsocks", func(data []byte) (interface{}, error) {		rawConfig := new(Config)		err := json.Unmarshal(data, rawConfig)		return rawConfig, err	})}
 |