123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122 |
- package util
- import (
- "strings"
- "sync"
- "github.com/spf13/viper"
- "github.com/seaweedfs/seaweedfs/weed/glog"
- )
- var (
- ConfigurationFileDirectory DirectoryValueType
- loadSecurityConfigOnce sync.Once
- )
- type DirectoryValueType string
- func (s *DirectoryValueType) Set(value string) error {
- *s = DirectoryValueType(value)
- return nil
- }
- func (s *DirectoryValueType) String() string {
- return string(*s)
- }
- type Configuration interface {
- GetString(key string) string
- GetBool(key string) bool
- GetInt(key string) int
- GetStringSlice(key string) []string
- SetDefault(key string, value interface{})
- }
- func LoadSecurityConfiguration() {
- loadSecurityConfigOnce.Do(func() {
- LoadConfiguration("security", false)
- })
- }
- func LoadConfiguration(configFileName string, required bool) (loaded bool) {
- // find a filer store
- viper.SetConfigName(configFileName) // name of config file (without extension)
- viper.AddConfigPath(ResolvePath(ConfigurationFileDirectory.String())) // path to look for the config file in
- viper.AddConfigPath(".") // optionally look for config in the working directory
- viper.AddConfigPath("$HOME/.seaweedfs") // call multiple times to add many search paths
- viper.AddConfigPath("/usr/local/etc/seaweedfs/") // search path for bsd-style config directory in
- viper.AddConfigPath("/etc/seaweedfs/") // path to look for the config file in
- if err := viper.MergeInConfig(); err != nil { // Handle errors reading the config file
- if strings.Contains(err.Error(), "Not Found") {
- glog.V(1).Infof("Reading %s: %v", viper.ConfigFileUsed(), err)
- } else {
- glog.Fatalf("Reading %s: %v", viper.ConfigFileUsed(), err)
- }
- if required {
- glog.Fatalf("Failed to load %s.toml file from current directory, or $HOME/.seaweedfs/, or /etc/seaweedfs/"+
- "\n\nPlease use this command to generate the default %s.toml file\n"+
- " weed scaffold -config=%s -output=.\n\n\n",
- configFileName, configFileName, configFileName)
- } else {
- return false
- }
- }
- glog.V(1).Infof("Reading %s.toml from %s", configFileName, viper.ConfigFileUsed())
- return true
- }
- type ViperProxy struct {
- *viper.Viper
- sync.Mutex
- }
- var (
- vp = &ViperProxy{}
- )
- func (vp *ViperProxy) SetDefault(key string, value interface{}) {
- vp.Lock()
- defer vp.Unlock()
- vp.Viper.SetDefault(key, value)
- }
- func (vp *ViperProxy) GetString(key string) string {
- vp.Lock()
- defer vp.Unlock()
- return vp.Viper.GetString(key)
- }
- func (vp *ViperProxy) GetBool(key string) bool {
- vp.Lock()
- defer vp.Unlock()
- return vp.Viper.GetBool(key)
- }
- func (vp *ViperProxy) GetInt(key string) int {
- vp.Lock()
- defer vp.Unlock()
- return vp.Viper.GetInt(key)
- }
- func (vp *ViperProxy) GetStringSlice(key string) []string {
- vp.Lock()
- defer vp.Unlock()
- return vp.Viper.GetStringSlice(key)
- }
- func GetViper() *ViperProxy {
- vp.Lock()
- defer vp.Unlock()
- if vp.Viper == nil {
- vp.Viper = viper.GetViper()
- vp.AutomaticEnv()
- vp.SetEnvPrefix("weed")
- vp.SetEnvKeyReplacer(strings.NewReplacer(".", "_"))
- }
- return vp
- }
|