rbac

package
v0.0.0-...-5c3d8b3 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Feb 4, 2022 License: MIT Imports: 2 Imported by: 0

Documentation

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

This section is empty.

Types

type Service

type Service struct{}

Service is RBAC application service

func (*Service) EnforceRole

func (s *Service) EnforceRole(c context.Context, r twisk.AccessRole) bool

EnforceRole authorizes request by AccessRole

func (*Service) EnforceTenant

func (s *Service) EnforceTenant(c context.Context, ID int32) bool

EnforceTenant checks whether the request to apply change to tenant data is done by the user belonging to the that tenant and that the user has role tenantAdmin. If user has admin role, the check for tenant doesn't need to pass.

func (*Service) EnforceTenantAdmin

func (s *Service) EnforceTenantAdmin(c context.Context, ID int32) bool

EnforceTenantAdmin checks tenant admin

func (*Service) EnforceTenantAndRole

func (s *Service) EnforceTenantAndRole(c context.Context, roleID twisk.AccessRole, tenantID int32) bool

EnforceTenantAndRole performs auth check for same tenant and lower role. Used for user creation, deletion etc.

func (*Service) EnforceUser

func (s *Service) EnforceUser(c context.Context, ID int64) bool

EnforceUser checks whether the request to change user data is done by the same user

func (*Service) IsLowerRole

func (s *Service) IsLowerRole(c context.Context, r twisk.AccessRole) bool

IsLowerRole checks whether the requesting user has higher role than the user it wants to change Used for account creation/deletion

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL