GetKVS should add new keys automatically, preserve order (#8612)

This commit is contained in:
Harshavardhana 2019-12-06 02:43:10 -08:00 committed by Nitish Tiwari
parent 3df7285c3c
commit 97deba2a7c

View File

@ -318,16 +318,16 @@ func NewConfigWriteTo(cfg Config, key string) io.WriterTo {
// WriteTo - implements io.WriterTo interface implementation for config. // WriteTo - implements io.WriterTo interface implementation for config.
func (c *configWriteTo) WriteTo(w io.Writer) (int64, error) { func (c *configWriteTo) WriteTo(w io.Writer) (int64, error) {
kvs, err := c.GetKVS(c.filterByKey, DefaultKVS) kvsTargets, err := c.GetKVS(c.filterByKey, DefaultKVS)
if err != nil { if err != nil {
return 0, err return 0, err
} }
var n int var n int
for k, kv := range kvs { for _, target := range kvsTargets {
m1, _ := w.Write([]byte(k)) m1, _ := w.Write([]byte(target.SubSystem))
m2, _ := w.Write([]byte(KvSpaceSeparator)) m2, _ := w.Write([]byte(KvSpaceSeparator))
m3, _ := w.Write([]byte(kv.String())) m3, _ := w.Write([]byte(target.KVS.String()))
if len(kvs) > 1 { if len(kvsTargets) > 1 {
m4, _ := w.Write([]byte(KvNewline)) m4, _ := w.Write([]byte(KvNewline))
n += m1 + m2 + m3 + m4 n += m1 + m2 + m3 + m4
} else { } else {
@ -432,8 +432,17 @@ func New() Config {
return srvCfg return srvCfg
} }
// Target signifies an individual target
type Target struct {
SubSystem string
KVS KVS
}
// Targets sub-system targets
type Targets []Target
// GetKVS - get kvs from specific subsystem. // GetKVS - get kvs from specific subsystem.
func (c Config) GetKVS(s string, defaultKVS map[string]KVS) (map[string]KVS, error) { func (c Config) GetKVS(s string, defaultKVS map[string]KVS) (Targets, error) {
if len(s) == 0 { if len(s) == 0 {
return nil, Errorf(SafeModeKind, "input cannot be empty") return nil, Errorf(SafeModeKind, "input cannot be empty")
} }
@ -455,36 +464,55 @@ func (c Config) GetKVS(s string, defaultKVS map[string]KVS) (map[string]KVS, err
return nil, Errorf(SafeModeKind, "unknown sub-system %s", s) return nil, Errorf(SafeModeKind, "unknown sub-system %s", s)
} }
kvs := make(map[string]KVS) targets := Targets{}
var ok bool
subSysPrefix := subSystemValue[0] subSysPrefix := subSystemValue[0]
if len(subSystemValue) == 2 { if len(subSystemValue) == 2 {
if len(subSystemValue[1]) == 0 { if len(subSystemValue[1]) == 0 {
return nil, Errorf(SafeModeKind, "sub-system target '%s' cannot be empty", s) return nil, Errorf(SafeModeKind, "sub-system target '%s' cannot be empty", s)
} }
kvs[inputs[0]], ok = c[subSysPrefix][subSystemValue[1]] kvs, ok := c[subSysPrefix][subSystemValue[1]]
if !ok { if !ok {
return nil, Errorf(SafeModeKind, "sub-system target '%s' doesn't exist", s) return nil, Errorf(SafeModeKind, "sub-system target '%s' doesn't exist", s)
} }
for _, kv := range defaultKVS[subSysPrefix] {
_, ok = kvs.Lookup(kv.Key)
if !ok {
kvs.Set(kv.Key, kv.Value)
}
}
targets = append(targets, Target{
SubSystem: inputs[0],
KVS: kvs,
})
} else { } else {
for subSys, subSysTgts := range c { hkvs := HelpSubSysMap[""]
if !strings.HasPrefix(subSys, subSysPrefix) { // Use help for sub-system to preserve the order.
for _, hkv := range hkvs {
if !strings.HasPrefix(hkv.Key, subSysPrefix) {
continue continue
} }
for k, kv := range subSysTgts { for k, kvs := range c[hkv.Key] {
for _, dkv := range defaultKVS[subSysPrefix] {
_, ok := kvs.Lookup(dkv.Key)
if !ok {
kvs.Set(dkv.Key, dkv.Value)
}
}
if k != Default { if k != Default {
kvs[subSys+SubSystemSeparator+k] = kv targets = append(targets, Target{
SubSystem: hkv.Key + SubSystemSeparator + k,
KVS: kvs,
})
} else { } else {
kvs[subSys] = kv targets = append(targets, Target{
SubSystem: hkv.Key,
KVS: kvs,
})
} }
} }
} }
} }
if len(kvs) == 0 { return targets, nil
kvs[subSysPrefix] = defaultKVS[subSysPrefix]
return kvs, nil
}
return kvs, nil
} }
// DelKVS - delete a specific key. // DelKVS - delete a specific key.