RoleManager API
RoleManager
RoleManager предоставляет интерфейс для определения операций для управления ролями. Добавление функции сопоставления в ролевой менеджер позволяет использовать маски в имени роли и домене.
AddNamedMatchingFunc()
AddNamedMatchingFunc добавить MatchingFunc по ptype RoleManager. MatchingFunc будет работать при совпадении ролей.
e.AddNamedMatchingFunc("g", "", util.KeyMatch)
_, _ = e.AddGroupingPolicies([][]string{{"*", "admin", "domain1"}})
_, _ = e.GetRoleManager().HasLink("bob", "admin", "domain1") // -> true, nil
await e.addNamedMatchingFunc('g', Util.keyMatchFunc);
await e.addGroupingPolicies([['*', 'admin', 'domain1']]);
await e.getRoleManager().hasLink('bob', 'admin', 'domain1');
Например:
e, _ := casbin.NewEnforcer("path/to/model", "path/to/policy")
e.AddNamedMatchingFunc("g", "", util.MatchKey)
const e = await newEnforcer('path/to/model', 'path/to/policy');
await e.addNamedMatchingFunc('g', Util.keyMatchFunc);
AddNamedDomainMatchingFunc()
AddNamedDomainMatchingFunc добавить MatchingFunc по ptype в RoleManager. DomainMatchingFunc
похож на MatchingFunc
, перечисленный выше.
Например:
e, _ := casbin.NewEnforcer("path/to/model", "path/to/policy")
e.AddNamedDomainMatchingFunc("g", "", util.MatchKey)
const e = await newEnforcer('path/to/model', 'path/to/policy');
await e.addNamedDomainMatchingFunc('g', Util.keyMatchFunc);
GetRoleManager()
GetRoleManager получает текущий ролевой менеджер для г
.
Например:
rm := e.GetRoleManager()
const rm = await e.getRoleManager();
rm = e.get_role_manager()
Clear()
Очистить все сохраненные данные и сбросить менеджер ролей в начальное состояние.
Например:
rm.Clear()
await rm.clear();
rm.clear()
AddLink()
AddLink добавляет связь наследования между двумя ролями. роль: название и роль: имя2. Домен является префиксом к ролям (может использоваться для других целей).
Например:
rm.AddLink("u1", "g1", "domain1")
await rm.addLink('u1', 'g1', 'domain1');
rm.add_link("u1", "g1", "domain1")
DeleteLink()
DeleteLink удаляет связь наследования между двумя ролями. роль: название и роль: имя2. Домен является префиксом к ролям (может использоваться для других целей).
Например:
rm.DeleteLink("u1", "g1", "domain1")
await rm.deleteLink('u1', 'g1', 'domain1');
rm.delete_link("u1", "g1", "domain1")
HasLink()
HasLink определяет, существует ли связь между двумя ролями. роль: имя1 наследует роль: имя2. Домен является префиксом к ролям (может использоваться для других целей).
Например:
rm.HasLink("u1", "g1", "domain1")
await rm.hasLink('u1', 'g1', 'domain1');
rm.has_link("u1", "g1", "domain1")
GetRoles()
GetRoles получает роли, которые пользователь наследует. Домен является префиксом к ролям (может использоваться для других целей).
Например:
rm.GetRoles("u1", "domain1")
await rm.getRoles('u1', 'domain1');
rm.get_roles("u1", "domain")
GetUsers()
GetUsers получает пользователей, которые наследуют роль. Домен - это префикс для пользователей (может быть использован для других целей).
Например:
rm.GetUsers("g1")
await rm.getUsers('g1');
rm.get_users("g1")
PrintRoles()
PrintRoles печатает все роли для журнала.
Например:
rm.PrintRoles()
await rm.printRoles();
rm.print_roles()
SetLogger()
SetLogger задает журналирование ролей менеджера.
Например:
logger := log.DefaultLogger{}
logger.EnableLog(true)
rm.SetLogger(&logger)
_ = rm.PrintRoles()
GetDomains()
GetDomains получает домены, которые есть у пользователя
Например:
result, err := rm.GetDomains(name)