From 0b528a9303511b84d40a48a3aa66205e9b6fbc50 Mon Sep 17 00:00:00 2001 From: Vijay Srinivas Date: Fri, 17 Nov 2023 01:13:15 +0530 Subject: [PATCH] feat(coverage) : improve accuracy for evaluating permission conditions - initial --- pkg/development/coverage/coverage.go | 39 ++++++++++++++++++++++++++++ 1 file changed, 39 insertions(+) diff --git a/pkg/development/coverage/coverage.go b/pkg/development/coverage/coverage.go index a55ad7243..0a591852a 100644 --- a/pkg/development/coverage/coverage.go +++ b/pkg/development/coverage/coverage.go @@ -239,11 +239,50 @@ func references(entity *base.EntityDefinition) (coverage SchemaCoverage) { // Format and append the permission to the coverage struct formattedPermission := fmt.Sprintf("%s#%s", entity.GetName(), permission.GetName()) coverage.Assertions = append(coverage.Assertions, formattedPermission) + conditionsAssertions(permission.GetChild(), entity.GetName(), &coverage.Assertions) } // Return the coverage struct return } +// Get assertions from permission condition +func conditionsAssertions(child *base.Child, entityName string, assertions *[]string) { + leaf := child.GetLeaf() + if leaf != nil { + compUserSet := leaf.GetComputedUserSet() + if compUserSet != nil { + relation := fmt.Sprintf("%s#%s", entityName, compUserSet.GetRelation()) + if !slices.Contains(*assertions, relation) { + *assertions = append(*assertions, relation) + } + } + tupleToUserSet := leaf.GetTupleToUserSet() + if tupleToUserSet != nil { + tupComp := tupleToUserSet.GetComputed() + if tupComp != nil { + relation := fmt.Sprintf("%s#%s", entityName, tupComp.GetRelation()) + if !slices.Contains(*assertions, relation) { + *assertions = append(*assertions, relation) + } + } + tupSet := tupleToUserSet.GetTupleSet() + if tupSet != nil { + relation := fmt.Sprintf("%s#%s", entityName, tupSet.GetRelation()) + if !slices.Contains(*assertions, relation) { + *assertions = append(*assertions, relation) + } + } + } + } + rewrite := child.GetRewrite() + if rewrite != nil { + children := rewrite.GetChildren() + for _, child := range children { + conditionsAssertions(child, entityName, assertions) + } + } +} + // relationships - Get relationships for a given entity func relationships(en string, relationships []string) []string { var rels []string