微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

rego_type_error:未定义的函数

如何解决rego_type_error:未定义的函数

我是 OPA 和 rego 文件的新手。我创建了一个这样的 rego 文件

package sample.access
import data.myaccess

default allow = false
allow = true {
    myaccess.is_user_allowed(input.user)
}

而且,我已经创建了这样的测试 rego 文件

package sample.access

test_allow_positive{
    allow with input as {
        "user": "user1"
    } with data.myaccess as {
        {
            {"user": "user1"},{"user": "user2"}
        }
            
    }
}

当我运行这个测试用例时,我收到类似 "rego_type_error: undefined function data.myaccess.is_user_allowed"错误。帮我解决这个问题。谢谢

解决方法

我认为这就是你想要做的:

创建规则 allow,如果 true 来自调用时传递的一组用户,则返回 input.user。为此,您可以使用以下规则:

package sample.access

allow {
    data.allowed[input.user]
}

相应的单元测试:

package sample.access

test_allow {
    allow with input as {
        "user": "user1"
    } with data.allowed as {"user1","user2"}
}

test_deny {
    not allow with input as {
        "user": "user3"
    } with data.allowed as {"user1","user2"}
}

请注意,您不需要显式导入将在运行时传递的参数。

如果您的输入数据需要采用 {"user": "id"} 列表的形式,那么您应该使用 set comprehension

package sample.access

allow {
    is_user_allowed = {user | user = data.allowed[_].user}

    is_user_allowed[input.user]
}

然后你的单元测试需要像这样修改:

package sample.access

test_allow {
    allow with input as {
        "user": "user1"
    } with data.allowed as {
        {"user": "user1"},{"user": "user2"}
    }
}

test_deny {
    not allow with input as {
        "user": "user3"
    } with data.allowed as {
         {"user": "user1"},{"user": "user2"}
    }
}

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。