| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970 |
- // +build json
- package shadowsocks
- import (
- "encoding/json"
- "github.com/v2ray/v2ray-core/common/log"
- "github.com/v2ray/v2ray-core/common/protocol"
- "github.com/v2ray/v2ray-core/common/serial"
- "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 serial.StringLiteral `json:"method"`
- Password serial.StringLiteral `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 = jsonConfig.Cipher.ToLower()
- switch jsonConfig.Cipher.String() {
- 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.String(), 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
- })
- }
|