67 lines
1.1 KiB
Go
67 lines
1.1 KiB
Go
package conf
|
|
|
|
import (
|
|
"encoding/json"
|
|
"fmt"
|
|
)
|
|
|
|
// Encryption is the encryption parameter.
|
|
type Encryption int
|
|
|
|
// supported encryption policies.
|
|
const (
|
|
EncryptionNo Encryption = iota
|
|
EncryptionOptional
|
|
EncryptionStrict
|
|
)
|
|
|
|
// MarshalJSON implements json.Marshaler.
|
|
func (d Encryption) MarshalJSON() ([]byte, error) {
|
|
var out string
|
|
|
|
switch d {
|
|
case EncryptionNo:
|
|
out = "no"
|
|
|
|
case EncryptionOptional:
|
|
out = "optional"
|
|
|
|
case EncryptionStrict:
|
|
out = "strict"
|
|
|
|
default:
|
|
return nil, fmt.Errorf("invalid encryption: %v", d)
|
|
}
|
|
|
|
return json.Marshal(out)
|
|
}
|
|
|
|
// UnmarshalJSON implements json.Unmarshaler.
|
|
func (d *Encryption) UnmarshalJSON(b []byte) error {
|
|
var in string
|
|
if err := json.Unmarshal(b, &in); err != nil {
|
|
return err
|
|
}
|
|
|
|
switch in {
|
|
case "no", "false":
|
|
*d = EncryptionNo
|
|
|
|
case "optional":
|
|
*d = EncryptionOptional
|
|
|
|
case "strict", "yes", "true":
|
|
*d = EncryptionStrict
|
|
|
|
default:
|
|
return fmt.Errorf("invalid encryption: '%s'", in)
|
|
}
|
|
|
|
return nil
|
|
}
|
|
|
|
// UnmarshalEnv implements envUnmarshaler.
|
|
func (d *Encryption) UnmarshalEnv(s string) error {
|
|
return d.UnmarshalJSON([]byte(`"` + s + `"`))
|
|
}
|