| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546 | 
							- // +build json
 
- package shadowsocks
 
- import (
 
- 	"encoding/json"
 
-   
 
-   "github.com/v2ray/v2ray-core/common/log"
 
-   "github.com/v2ray/v2ray-core/common/serial"
 
-   "github.com/v2ray/v2ray-core/proxy/internal"
 
- )
 
- func (this *Config) UnmarshalJSON(data []byte) error {
 
- 	type JsonConfig struct {
 
- 		Cipher   *serial.StringLiteral `json:"method"`
 
- 		Password *serial.StringLiteral `json:"password"`
 
- 	}
 
- 	jsonConfig := new(JsonConfig)
 
- 	if err := json.Unmarshal(data, jsonConfig); err != nil {
 
- 		return err
 
- 	}
 
-   if this.Password == nil {
 
-     log.Error("Shadowsocks: Password is not specified.")
 
-     return internal.ErrorBadConfiguration
 
-   }
 
-   this.Password = jsonConfig.Password.String()
 
-   if this.Cipher == nil {
 
-     log.Error("Shadowsocks: Cipher method is not specified.")
 
-     return internal.ErrorBadConfiguration
 
-   }
 
-   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: 32
 
-     }
 
-     default:
 
-     log.Error("Shadowsocks: Unknown cipher method: ", jsonConfig.Cipher)
 
-     return internal.ErrorBadConfiguration
 
-   }
 
-   return nil
 
- }
 
 
  |