// Copyright © 2015 Steve Francia . // // Use of this source code is governed by an MIT-style // license that can be found in the LICENSE file. // Package remote integrates the remote features of Viper. package remote import ( "bytes" "github.com/spf13/viper" crypt "github.com/xordataexchange/crypt/config" "io" "os" ) type remoteConfigProvider struct{} func (rc remoteConfigProvider) Get(rp viper.RemoteProvider) (io.Reader, error) { cm, err := getConfigManager(rp) if err != nil { return nil, err } b, err := cm.Get(rp.Path()) if err != nil { return nil, err } return bytes.NewReader(b), nil } func (rc remoteConfigProvider) Watch(rp viper.RemoteProvider) (io.Reader, error) { cm, err := getConfigManager(rp) if err != nil { return nil, err } resp := <-cm.Watch(rp.Path(), nil) err = resp.Error if err != nil { return nil, err } return bytes.NewReader(resp.Value), nil } func getConfigManager(rp viper.RemoteProvider) (crypt.ConfigManager, error) { var cm crypt.ConfigManager var err error if rp.SecretKeyring() != "" { kr, err := os.Open(rp.SecretKeyring()) defer kr.Close() if err != nil { return nil, err } if rp.Provider() == "etcd" { cm, err = crypt.NewEtcdConfigManager([]string{rp.Endpoint()}, kr) } else { cm, err = crypt.NewConsulConfigManager([]string{rp.Endpoint()}, kr) } } else { if rp.Provider() == "etcd" { cm, err = crypt.NewStandardEtcdConfigManager([]string{rp.Endpoint()}) } else { cm, err = crypt.NewStandardConsulConfigManager([]string{rp.Endpoint()}) } } if err != nil { return nil, err } return cm, nil } func init() { viper.RemoteConfig = &remoteConfigProvider{} }