summaryrefslogtreecommitdiff
path: root/plugins/config/plugin.go
diff options
context:
space:
mode:
Diffstat (limited to 'plugins/config/plugin.go')
-rwxr-xr-xplugins/config/plugin.go43
1 files changed, 43 insertions, 0 deletions
diff --git a/plugins/config/plugin.go b/plugins/config/plugin.go
index ce2baa85..ddb7fe88 100755
--- a/plugins/config/plugin.go
+++ b/plugins/config/plugin.go
@@ -2,6 +2,7 @@ package config
import (
"bytes"
+ "fmt"
"strings"
"github.com/spf13/viper"
@@ -14,6 +15,9 @@ type Viper struct {
Prefix string
Type string
ReadInCfg []byte
+ // user defined Flags in the form of <option>.<key> = <value>
+ // which overwrites initial config key
+ Flags []string
}
// Inits config provider.
@@ -40,6 +44,23 @@ func (v *Viper) Init() error {
v.viper.SetConfigFile(v.Path)
v.viper.SetEnvKeyReplacer(strings.NewReplacer(".", "_"))
+ err := v.viper.ReadInConfig()
+ if err != nil {
+ return errors.E(op, err)
+ }
+
+ // override config Flags
+ if len(v.Flags) > 0 {
+ for _, f := range v.Flags {
+ key, val, err := parseFlag(f)
+ if err != nil {
+ return errors.E(op, err)
+ }
+
+ v.viper.Set(key, val)
+ }
+ }
+
return v.viper.ReadInConfig()
}
@@ -82,3 +103,25 @@ func (v *Viper) Get(name string) interface{} {
func (v *Viper) Has(name string) bool {
return v.viper.IsSet(name)
}
+
+func parseFlag(flag string) (string, string, error) {
+ const op = errors.Op("parse_flag")
+ if !strings.Contains(flag, "=") {
+ return "", "", errors.E(op, errors.Errorf("invalid flag `%s`", flag))
+ }
+
+ parts := strings.SplitN(strings.TrimLeft(flag, " \"'`"), "=", 2)
+
+ return strings.Trim(parts[0], " \n\t"), parseValue(strings.Trim(parts[1], " \n\t")), nil
+}
+
+func parseValue(value string) string {
+ escape := []rune(value)[0]
+
+ if escape == '"' || escape == '\'' || escape == '`' {
+ value = strings.Trim(value, string(escape))
+ value = strings.ReplaceAll(value, fmt.Sprintf("\\%s", string(escape)), string(escape))
+ }
+
+ return value
+}