mirror of
https://github.com/minio/minio.git
synced 2025-01-12 07:23:23 -05:00
GetKVS should add new keys automatically, preserve order (#8612)
This commit is contained in:
parent
3df7285c3c
commit
97deba2a7c
@ -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.
|
||||||
|
Loading…
Reference in New Issue
Block a user