refactor getReferences #103

Closed
0xmuralik wants to merge 3 commits from murali/gql into murali/record-attributes
2 changed files with 16 additions and 11 deletions

View File

@ -19,6 +19,9 @@ test/
tests/
*_test.go
# false positive
testutil/network/network.go
# Semgrep rules folder
.semgrep

View File

@ -164,24 +164,26 @@ func GetGQLAuction(auction *auctiontypes.Auction, bids []*auctiontypes.Bid) (*Au
}
func getReferences(ctx context.Context, resolver QueryResolver, r *registrytypes.RecordType) ([]*Record, error) {
ids := getIds(r.Attributes)
return resolver.GetRecordsByIds(ctx, ids)
}
func getIds(obj map[string]interface{}) []string {
var ids []string
// #nosec G705
for key := range r.Attributes {
//nolint: all
switch r.Attributes[key].(type) {
case interface{}:
if obj, ok := r.Attributes[key].(map[string]interface{}); ok {
if _, ok := obj["/"]; ok && len(obj) == 1 {
if _, ok := obj["/"].(string); ok {
ids = append(ids, obj["/"].(string))
for key := range obj {
if innerObj, ok := obj[key].(map[string]interface{}); ok {
if _, ok := innerObj["/"]; ok && len(innerObj) == 1 {
if _, ok := innerObj["/"].(string); ok {
ids = append(ids, innerObj["/"].(string))
}
} else {
ids = append(ids, getIds(innerObj)...)
}
}
aleem1314 commented 2023-04-03 10:26:38 +00:00 (Migrated from github.com)
Review

Can you add few test cases.

Can you add few test cases.
}
}
}
return resolver.GetRecordsByIds(ctx, ids)
return ids
}
func getAttributes(r *registrytypes.RecordType) ([]*KeyValue, error) {