casbin
Version:
An authorization library that supports access control models like ACL, RBAC, ABAC in Node.JS
50 lines (49 loc) • 1.84 kB
TypeScript
import { RoleManager } from './roleManager';
export declare class DefaultRoleManager implements RoleManager {
private allRoles;
private maxHierarchyLevel;
/**
* DefaultRoleManager is the constructor for creating an instance of the
* default RoleManager implementation.
*
* @param maxHierarchyLevel the maximized allowed RBAC hierarchy level.
*/
constructor(maxHierarchyLevel: number);
/**
* addLink adds the inheritance link between role: name1 and role: name2.
* aka role: name1 inherits role: name2.
* domain is a prefix to the roles.
*/
addLink(name1: string, name2: string, ...domain: string[]): void;
/**
* clear clears all stored data and resets the role manager to the initial state.
*/
clear(): void;
/**
* deleteLink deletes the inheritance link between role: name1 and role: name2.
* aka role: name1 does not inherit role: name2 any more.
* domain is a prefix to the roles.
*/
deleteLink(name1: string, name2: string, ...domain: string[]): void;
/**
* getRoles gets the roles that a subject inherits.
* domain is a prefix to the roles.
*/
getRoles(name: string, ...domain: string[]): string[];
/**
* getUsers gets the users that inherits a subject.
* domain is an unreferenced parameter here, may be used in other implementations.
*/
getUsers(name: string, ...domain: string[]): string[];
/**
* hasLink determines whether role: name1 inherits role: name2.
* domain is a prefix to the roles.
*/
hasLink(name1: string, name2: string, ...domain: string[]): boolean;
/**
* printRoles prints all the roles to log.
*/
printRoles(): void;
private createRole;
private hasRole;
}