Documentation ¶
Overview ¶
Package iamcel provides primitives for using CEL expressions for access management.
Index ¶
- Constants
- func NewAfterEnv(method protoreflect.MethodDescriptor) (*cel.Env, error)
- func NewAncestorFunctionDeclaration() *expr.Decl
- func NewAncestorFunctionImplementation() *functions.Overload
- func NewBeforeEnv(method protoreflect.MethodDescriptor) (*cel.Env, error)
- func NewJoinFunctionDeclaration() *expr.Decl
- func NewJoinFunctionImplementation() *functions.Overload
- func NewMemberFunctionDeclaration() *expr.Decl
- func NewMemberFunctionImplementation() *functions.Overload
- func NewTestAllFunctionDeclaration() *expr.Decl
- func NewTestAllFunctionImplementation(options *iamv1.MethodAuthorizationOptions, tester PermissionTester) *functions.Overload
- func NewTestAnyFunctionDeclaration() *expr.Decl
- func NewTestAnyFunctionImplementation(options *iamv1.MethodAuthorizationOptions, tester PermissionTester) *functions.Overload
- func NewTestFunctionDeclaration() *expr.Decl
- func NewTestFunctionImplementation(options *iamv1.MethodAuthorizationOptions, tester PermissionTester) *functions.Overload
- type PermissionTester
Constants ¶
const AncestorFunction = "ancestor"
AncestorFunction is the name of the CEL ancestor function.
const JoinFunction = "join"
JoinFunction is the name of the CEL descendant function.
const MemberFunction = "member"
MemberFunction is the name of the CEL member function.
const TestAllFunction = "test_all"
TestAllFunction is the name of the function for testing that all resources have a specified permission.
const TestAnyFunction = "test_any"
TestAnyFunction is the name of the test_any permission function.
const TestFunction = "test"
TestFunction is the name of the test permission function.
Variables ¶
This section is empty.
Functions ¶
func NewAfterEnv ¶
func NewAfterEnv(method protoreflect.MethodDescriptor) (*cel.Env, error)
NewAfterEnv creates a new CEL environment for authorization checks that run after the request has been handled.
func NewAncestorFunctionDeclaration ¶
NewAncestorFunctionDeclaration creates a new declaration for the ancestor function.
func NewAncestorFunctionImplementation ¶
NewAncestorFunctionImplementation creates a new implementation for the ancestor function.
func NewBeforeEnv ¶
func NewBeforeEnv(method protoreflect.MethodDescriptor) (*cel.Env, error)
NewBeforeEnv creates a new CEL environment for authorization checks that run before the request has been handled.
func NewJoinFunctionDeclaration ¶ added in v0.52.0
NewJoinFunctionDeclaration creates a new declaration for the descendant function.
func NewJoinFunctionImplementation ¶ added in v0.52.0
NewJoinFunctionImplementation creates a new implementation for the descendant function.
func NewMemberFunctionDeclaration ¶ added in v0.51.0
NewMemberFunctionDeclaration creates a new declaration for the member function.
func NewMemberFunctionImplementation ¶ added in v0.51.0
NewMemberFunctionImplementation creates a new implementation for the member function.
func NewTestAllFunctionDeclaration ¶
NewTestAllFunctionDeclaration creates a new declaration for the test_all function.
func NewTestAllFunctionImplementation ¶
func NewTestAllFunctionImplementation( options *iamv1.MethodAuthorizationOptions, tester PermissionTester, ) *functions.Overload
NewTestAllFunctionImplementation creates a new implementation for the test_all function.
func NewTestAnyFunctionDeclaration ¶
NewTestAnyFunctionDeclaration creates a new declaration for the test_any function.
func NewTestAnyFunctionImplementation ¶
func NewTestAnyFunctionImplementation( options *iamv1.MethodAuthorizationOptions, tester PermissionTester, ) *functions.Overload
NewTestAnyFunctionImplementation creates a new implementation for the test_all function.
func NewTestFunctionDeclaration ¶
NewTestFunctionDeclaration creates a new declaration for the test permission function.
func NewTestFunctionImplementation ¶
func NewTestFunctionImplementation( options *iamv1.MethodAuthorizationOptions, tester PermissionTester, ) *functions.Overload
NewTestFunctionImplementation creates a new implementation for the test permission function.