129: Index multivalued attributes. #128
@ -4,6 +4,7 @@ import (
|
|||||||
"bytes"
|
"bytes"
|
||||||
"encoding/json"
|
"encoding/json"
|
||||||
"fmt"
|
"fmt"
|
||||||
|
"reflect"
|
||||||
"sort"
|
"sort"
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
@ -349,11 +350,26 @@ func (k Keeper) ProcessAttributes(ctx sdk.Context, record types.RecordType) erro
|
|||||||
{
|
{
|
||||||
// #nosec G705
|
// #nosec G705
|
||||||
for key := range record.Attributes {
|
for key := range record.Attributes {
|
||||||
indexKey := GetAttributesIndexKey(key, record.Attributes[key])
|
attr := record.Attributes[key]
|
||||||
|
rt := reflect.TypeOf(attr)
|
||||||
|
switch rt.Kind() {
|
||||||
|
case reflect.Slice:
|
||||||
|
av := attr.([]interface{})
|
||||||
|
for i := range av {
|
||||||
|
indexKey := GetAttributesIndexKey(key, av[i])
|
||||||
|
k.Logger(ctx).Error(fmt.Sprintf("attr indexKey: %s", indexKey))
|
||||||
if err := k.SetAttributeMapping(ctx, indexKey, record.ID); err != nil {
|
if err := k.SetAttributeMapping(ctx, indexKey, record.ID); err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
default:
|
||||||
|
indexKey := GetAttributesIndexKey(key, attr)
|
||||||
|
k.Logger(ctx).Error(fmt.Sprintf("attr indexKey: %s", indexKey))
|
||||||
|
if err := k.SetAttributeMapping(ctx, indexKey, record.ID); err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
default:
|
default:
|
||||||
return fmt.Errorf("unsupported record type %s", record.Attributes["type"])
|
return fmt.Errorf("unsupported record type %s", record.Attributes["type"])
|
||||||
|
Loading…
Reference in New Issue
Block a user