129: Index multivalued attributes. #128

Merged
telackey merged 4 commits from telackey/tags into main 2023-12-19 06:55:12 +00:00
Showing only changes of commit 911f4ec252 - Show all commits

View File

@ -351,10 +351,7 @@ 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 {
attr := record.Attributes[key] attr := record.Attributes[key]
rt := reflect.TypeOf(attr) if reflect.Slice == reflect.TypeOf(attr).Kind() {
switch rt.Kind() {
case reflect.Slice:
{
av := attr.([]interface{}) av := attr.([]interface{})
for i := range av { for i := range av {
indexKey := GetAttributesIndexKey(key, av[i]) indexKey := GetAttributesIndexKey(key, av[i])
@ -362,9 +359,7 @@ func (k Keeper) ProcessAttributes(ctx sdk.Context, record types.RecordType) erro
return err return err
} }
} }
} } else {
default:
{
indexKey := GetAttributesIndexKey(key, attr) indexKey := GetAttributesIndexKey(key, attr)
if err := k.SetAttributeMapping(ctx, indexKey, record.ID); err != nil { if err := k.SetAttributeMapping(ctx, indexKey, record.ID); err != nil {
return err return err
@ -372,7 +367,6 @@ func (k Keeper) ProcessAttributes(ctx sdk.Context, record types.RecordType) erro
} }
} }
} }
}
default: default:
return fmt.Errorf("unsupported record type %s", record.Attributes["type"]) return fmt.Errorf("unsupported record type %s", record.Attributes["type"])
} }