mirror of
https://github.com/status-im/status-go.git
synced 2025-01-20 19:52:42 +00:00
eeca435064
Update vendor Integrate rendezvous into status node Add a test with failover using rendezvous Use multiple servers in client Use discovery V5 by default and test that node can be started with rendezvous discovet Fix linter Update rendezvous client to one with instrumented stream Address feedback Fix test with updated topic limits Apply several suggestions Change log to debug for request errors because we continue execution Remove web3js after rebase Update rendezvous package
78 lines
1.8 KiB
Go
78 lines
1.8 KiB
Go
package log
|
|
|
|
import (
|
|
"encoding/json"
|
|
"errors"
|
|
"reflect"
|
|
)
|
|
|
|
// Metadata is a convenience type for generic maps
|
|
type Metadata map[string]interface{}
|
|
|
|
// DeepMerge merges the second Metadata parameter into the first.
|
|
// Nested Metadata are merged recursively. Primitives are over-written.
|
|
func DeepMerge(b, a Metadata) Metadata {
|
|
out := Metadata{}
|
|
for k, v := range b {
|
|
out[k] = v
|
|
}
|
|
for k, v := range a {
|
|
|
|
maybe, err := Metadatify(v)
|
|
if err != nil {
|
|
// if the new value is not meta. just overwrite the dest vaue
|
|
if out[k] != nil {
|
|
log.Debugf("Overwriting key: %s, old: %s, new: %s", k, out[k], v)
|
|
}
|
|
out[k] = v
|
|
continue
|
|
}
|
|
|
|
// it is meta. What about dest?
|
|
outv, exists := out[k]
|
|
if !exists {
|
|
// the new value is meta, but there's no dest value. just write it
|
|
out[k] = v
|
|
continue
|
|
}
|
|
|
|
outMetadataValue, err := Metadatify(outv)
|
|
if err != nil {
|
|
// the new value is meta and there's a dest value, but the dest
|
|
// value isn't meta. just overwrite
|
|
out[k] = v
|
|
continue
|
|
}
|
|
|
|
// both are meta. merge them.
|
|
out[k] = DeepMerge(outMetadataValue, maybe)
|
|
}
|
|
return out
|
|
}
|
|
|
|
// Loggable implements the Loggable interface.
|
|
func (m Metadata) Loggable() map[string]interface{} {
|
|
// NB: method defined on value to avoid de-referencing nil Metadata
|
|
return m
|
|
}
|
|
|
|
// JsonString returns the marshaled JSON string for the metadata.
|
|
func (m Metadata) JsonString() (string, error) {
|
|
// NB: method defined on value
|
|
b, err := json.Marshal(m)
|
|
return string(b), err
|
|
}
|
|
|
|
// Metadatify converts maps into Metadata.
|
|
func Metadatify(i interface{}) (Metadata, error) {
|
|
value := reflect.ValueOf(i)
|
|
if value.Kind() == reflect.Map {
|
|
m := map[string]interface{}{}
|
|
for _, k := range value.MapKeys() {
|
|
m[k.String()] = value.MapIndex(k).Interface()
|
|
}
|
|
return Metadata(m), nil
|
|
}
|
|
return nil, errors.New("is not a map")
|
|
}
|