Перейти до основного контенту

RBAC API

Більш дружній API для RBAC. Цей API є підмножиною API керування. Користувачі RBAC можуть використовувати цей API для спрощення коду.

Посилання

глобальна змінна e є примірником Enforcer.

e, err := NewEnforcer("examples/rbac_model.conf", "examples/rbac_policy.csv")

GetRolesForUser()

ОтриматиРоліДляКористувача отримує ролі, які має користувач.

Наприклад:

res := e.GetRolesForUser("alice")

GetUsersForRole()

ОтриматиКористувачівДляРолі отримує користувачів, які мають роль.

Наприклад:

res := e.GetUsersForRole("data1_admin")

HasRoleForUser()

МаєРольДляКористувача визначає, чи має користувач певну роль.

Наприклад:

res := e.HasRoleForUser("alice", "data1_admin")

AddRoleForUser()

AddRoleForUser додає роль для користувача. Повертає false, якщо користувач вже має цю роль (так зване не вплинуло).

Наприклад:

e.AddRoleForUser("alice", "data2_admin")

AddRolesForUser()

AddRolesForUser додає кілька ролей для користувача. Повертає false, якщо користувач вже має одну з цих ролей (так зване не вплинуло).

Наприклад:

var roles = []string{"data2_admin", "data1_admin"}
e.AddRolesForUser("alice", roles)

DeleteRoleForUser()

DeleteRoleForUser видаляє роль для користувача. Повертає false, якщо користувач не має цієї ролі (так зване не вплинуло).

Наприклад:

e.DeleteRoleForUser("alice", "data1_admin")

DeleteRolesForUser()

DeleteRolesForUser видаляє всі ролі для користувача. Повертає false, якщо у користувача немає жодних ролей (ака не зачеплено).

Наприклад:

e.DeleteRolesForUser("alice")

DeleteUser()

DeleteUser видаляє користувача. Повертає false, якщо користувача не існує (ака не зачеплено).

Наприклад:

e.DeleteUser("alice")

DeleteRole()

DeleteRole видаляє роль.

Наприклад:

e.DeleteRole("data2_admin")

DeletePermission()

DeletePermission видаляє дозвіл. Повертає false, якщо дозвіл не існує (ака не зачеплено).

Наприклад:

e.DeletePermission("read")

AddPermissionForUser()

AddPermissionForUser додає дозвіл для користувача або ролі. Повертає false, якщо користувач або роль вже має цей дозвіл (ака не зачеплено).

Наприклад:

e.AddPermissionForUser("bob", "read")

AddPermissionsForUser()

ДодатиДозволиДляКористувача додає кілька дозволів для користувача або ролі. Повертає false, якщо користувач або роль вже має один з дозволів (так зване не зачеплено).

Наприклад:

var permissions = [][]string{{"data1", "read"},{"data2","write"}}
for i := 0; i < len(permissions); i++ {
e.AddPermissionsForUser("alice", permissions[i])
}

DeletePermissionForUser()

ВидалитиДозвілДляКористувача видаляє дозвіл для користувача або ролі. Повертає false, якщо користувач або роль не має дозволу (так зване не зачеплено).

Наприклад:

e.DeletePermissionForUser("bob", "read")

DeletePermissionsForUser()

ВидалитиДозволиДляКористувача видаляє дозволи для користувача або ролі. Повертає false, якщо користувач або роль не мають жодних дозволів (так зване невпливове).

Наприклад:

e.DeletePermissionsForUser("bob")

GetPermissionsForUser()

GetPermissionsForUser отримує дозволи для користувача або ролі.

Наприклад:

e.GetPermissionsForUser("bob")

HasPermissionForUser()

HasPermissionForUser визначає, чи має користувач певний дозвіл.

Наприклад:

e.HasPermissionForUser("alice", []string{"read"})

GetImplicitRolesForUser()

GetImplicitRolesForUser отримує неявні ролі, які має користувач. На відміну від GetRolesForUser(), ця функція отримує непрямі ролі на додаток до прямих ролей.

Наприклад:

g, alice, role:admin  
g, role:admin, role:user

GetRolesForUser("alice") може отримати лише: ["role:admin"].\ Але GetImplicitRolesForUser("alice") отримає: ["role:admin", "role:user"].

Наприклад:

e.GetImplicitRolesForUser("alice")

GetImplicitUsersForRole()

GetImplicitUsersForRole отримує всіх користувачів, які успадковують роль. На відміну від GetUsersForRole(), ця функція отримує непрямих користувачів.

Наприклад:

g, alice, role:admin  
g, role:admin, role:user

GetUsersForRole("role:user") може отримати лише: ["role:admin"].\ Але GetImplicitUesrsForRole("role:user") отримає: ["role:admin", "alice"].

Наприклад:

users := e.GetImplicitUsersForRole("role:user")

GetImplicitPermissionsForUser()

GetImplicitPermissionsForUser отримує неявні дозволи для користувача або ролі.\ Порівняно з GetPermissionsForUser(), ця функція отримує дозволи для успадкованих ролей.

Наприклад:

p, admin, data1, read  
p, alice, data2, read
g, alice, admin

GetPermissionsForUser("alice") може отримати лише: [["alice", "data2", "read"]].\ Але GetImplicitPermissionsForUser("alice") отримає: [["admin", "data1", "read"], ["alice", "data2", "read"]].

Наприклад:

e.GetImplicitPermissionsForUser("alice")

GetNamedImplicitPermissionsForUser()

GetNamedImplicitPermissionsForUser отримує неявні дозволи для користувача або ролі за назвою політики

Наприклад:

p, admin, data1, read
p2, admin, create
g, alice, admin

GetImplicitPermissionsForUser("alice") отримає лише: [["admin", "data1", "read"]], чия політика є стандартною "p"

Але ви можете вказати політику як "p2", щоб отримати: [["admin", "create"]] за допомогою GetNamedImplicitPermissionsForUser("p2","alice")

Наприклад:

e.GetNamedImplicitPermissionsForUser("p2","alice")

GetDomainsForUser()

GetDomainsForUser отримує всі домени, які має користувач.

Наприклад:

p, admin, domain1, data1, read
p, admin, domain2, data2, read
p, admin, domain2, data2, write
g, alice, admin, domain1
g, alice, admin, domain2

GetDomainsForUser("alice") може отримати ["domain1", "domain2"]

Наприклад:

result, err := e.GetDomainsForUser("alice")

GetImplicitResourcesForUser()

GetImplicitResourcesForUser повертає всі політики, які мають бути істинними для користувача.

Наприклад:

p, alice, data1, read
p, bob, data2, write
p, data2_admin, data2, read
p, data2_admin, data2, write

g, alice, data2_admin

GetImplicitResourcesForUser("alice") поверне

resources, err := e.GetImplicitResourcesForUser("alice")

GetImplicitUsersForPermission()

GetImplicitUsersForPermission отримує неявних користувачів для дозволу.

Наприклад:

p, admin, data1, read
p, bob, data1, read
g, alice, admin

GetImplicitUsersForPermission("data1", "read") поверне: ["alice", "bob"].

Примітка: повертатимуться лише користувачі, ролі (2-й аргумент у "g") будуть виключені.

users, err := e.GetImplicitUsersForPermission("data1", "read")

GetAllowedObjectConditions()

GetAllowedObjectConditions повертає масив рядків умов об'єктів, до яких користувач може отримати доступ.

Наприклад:

p, alice, r.obj.price < 25, read
p, admin, r.obj.category_id = 2, read
p, bob, r.obj.author = bob, write

g, alice, admin

e.GetAllowedObjectConditions("alice", "read", "r.obj.") поверне ["price < 25", "category_id = 2"], nil

Примітка:

  1. префікс: Ви можете налаштувати префікс умов об'єктів, і "r.obj." зазвичай використовується як префікс. Після видалення префікса, решта частина є умовою об'єкта. Якщо є політика об'єкта, яка не відповідає вимогам префікса, буде повернено errors.ERR_OBJ_CONDITION.

  2. Якщо масив 'objectConditions' порожній, повертається errors.ERR_EMPTY_CONDITION

conditions, err := e.GetAllowedObjectConditions("alice", "read", "r.obj.")

GetImplicitUsersForResource()

GetImplicitUsersForResource повертає неявних користувачів на основі ресурсу.

Наприклад:

p, alice, data1, read
p, bob, data2, write
p, data2_admin, data2, read
p, data2_admin, data2, write
g, alice, data2_admin

GetImplicitUsersForResource("data2") поверне [["bob", "data2", "write"], ["alice", "data2", "read"] ["alice", "data2", "write"]], nil.

GetImplicitUsersForResource("data1") поверне [["alice", "data1", "read"]], nil.

ImplicitUsers, err := e.GetImplicitUsersForResource("data2")
примітка

Будуть повернуті тільки користувачі, ролі (2-й аргумент у "g") будуть виключені.