7 // MultiLevelFieldReader reads from other field readers,
8 // merging their results along the way in a specific order. You can specify
9 // "levels" and name them in order to read only an exact level or up to
12 // This is useful for saying things such as "read the field from the state
13 // and config and merge them" or "read the latest value of the field".
14 type MultiLevelFieldReader struct {
15 Readers map[string]FieldReader
19 func (r *MultiLevelFieldReader) ReadField(address []string) (FieldReadResult, error) {
20 return r.ReadFieldMerge(address, r.Levels[len(r.Levels)-1])
23 func (r *MultiLevelFieldReader) ReadFieldExact(
24 address []string, level string) (FieldReadResult, error) {
25 reader, ok := r.Readers[level]
27 return FieldReadResult{}, fmt.Errorf(
28 "Unknown reader level: %s", level)
31 result, err := reader.ReadField(address)
33 return FieldReadResult{}, fmt.Errorf(
34 "Error reading level %s: %s", level, err)
40 func (r *MultiLevelFieldReader) ReadFieldMerge(
41 address []string, level string) (FieldReadResult, error) {
42 var result FieldReadResult
43 for _, l := range r.Levels {
44 if r, ok := r.Readers[l]; ok {
45 out, err := r.ReadField(address)
47 return FieldReadResult{}, fmt.Errorf(
48 "Error reading level %s: %s", l, err)