shasoft / rbac
PHP Role-Based Access Control
Installs: 1
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 0
Forks: 0
Open Issues: 0
pkg:composer/shasoft/rbac
Requires
- psr/cache: ^3
Requires (Dev)
This package is auto-updated.
Last update: 2025-10-23 20:00:36 UTC
README
Этот пакет содержит библиотеку RBAC для PHP
Введение
Роли и разрешения
У каждой роли могут быть дочерние роли а также разрешения. Родительские роли наследуют все разрешения дочерних ролей.
flowchart BT
admin([admin])
moderator([moderator])
user([user])
guest([guest])
forum.view(forum.view)
forum.edit(forum.edit)
forum.remove(forum.remove)
user.ban(user.ban)
moderator.assign(moderator.assign)
moderator --> admin
user --> moderator
guest --> user
forum.view --> guest
forum.edit --> user
forum.remove --> moderator
user.ban --> moderator
moderator.assign --> admin
classDef default fill:LightSalmon
classDef Permission fill:Khaki
class admin,moderator,user,guest Role
class forum.view,moderator.assign,forum.edit,forum.remove,user.ban Permission
Loading
В результате наследования разрешения каждой роли:
роль: разрешения
- admin: moderator.assign, user.ban, forum.remove, forum.edit, forum.view
- moderator: user.ban, forum.remove, forum.edit, forum.view
- user: forum.edit, forum.view
- guest: forum.view
Права пользователя
Каждому пользователю назначается список ролей и разрешений
flowchart BT
userAdmin@{ shape: curv-trap, label: "Admin" }
userModerator@{ shape: curv-trap, label: "Moderator" }
userUser1@{ shape: curv-trap, label: "User1" }
userUser2@{ shape: curv-trap, label: "User2" }
userGuest@{ shape: curv-trap, label: "Guest" }
admin([admin])
moderator([moderator])
forum.remove(forum.remove)
user([user])
guest([guest])
admin --> userAdmin
moderator --> userModerator
user --> userUser2
forum.remove --> userUser2
user --> userUser1
guest --> userGuest
classDef User fill:LightSkyBlue,stroke:Green,stroke-width:2px
classDef default fill:LightSalmon
classDef Permission fill:Khaki
class admin,moderator,user,guest Role
class forum.view,moderator.assign,forum.edit,forum.remove,user.ban Permission
class userAdmin,userModerator,userUser1,userUser2,userGuest User
Loading
Пример использования
Схема прав
flowchart BT
user@{ shape: curv-trap, label: "1" }
p1(p1)
p2(p2)
p3(p3)
p4(p4)
R1([R1])
R1 --> user
p2 --> user
p1 --> R1
p4 --> R1
classDef User fill:LightSkyBlue,stroke:Green,stroke-width:2px
classDef default fill:LightSalmon
classDef Permission fill:Khaki
class R1 Role
class p1,p2,p3,p4 Permission
class user User
Loading
Код использования схемы
// Создать сервис $rbac = new Rbac((new SQLiteDatabase('filename'))->create()); // Создать схему ролей и разрешений для пользователя $p1 = $rbac->permission('p1'); $p2 = $rbac->permission('p2'); $p3 = $rbac->permission('p3'); $p4 = $rbac->permission('p4')->setLinkToBan(true); // Связать с баном $R1 = $rbac->permission('R1')->permissionAdd($p1)->permissionAdd($p4); $user = $rbac->user(1)->roleAdd($R1)->permissionAdd($p2); // Сохранить данные в хранилище $rbac->flush(); // Выполнить проверки $user->can('p1'); // True $user->can('p2'); // True $user->can('p3'); // False $user->can('p4'); // True // Забанить пользователя на 5 часов $user->setBan(new \Datetime('+5 hours')); $rbac->flush(); // Выполнить проверки $user->can('p1'); // True $user->can('p2'); // True $user->can('p3'); // False $user->can('p4'); // False (так как разрешение связано с баном, то теперь оно не доступно)
Интерфейсы
interface IRbac { public function permission(string $name): IPermission; public function permissions(): array; public function role(string $name): IRole; public function roles(): array; public function user(int $userId): IUser; public function users(): array; public function reset(): IRbac; public function flush(): IRbac; } interface IUser { public function delete(): void; public function restore(): void; public function hasExists(): bool; public function id(): int; public function roleAdd(IRole|string $role): IUser; public function roleRemove(IRole|string $role): IUser; public function roles(bool $all = false): array; public function permissionAdd(IPermission|string $permission): IUser; public function permissionRemove(IPermission|string $permission): IUser; public function permissions(bool $all = false): array; public function can(string $permissionName): bool; public function hasRole(string $roleName): bool; public function ban(): bool; public function setBan(?\DateTime $dtTo): IUser; public function getBan(): ?\DateTime; public function values(string $prefix): array; } interface IRole { public function delete(): void; public function restore(): void; public function hasExists(): bool; public function name(): string; public function setDescription(string $value): IRole; public function description(): string; public function roleAdd(IRole|string $role): IRole; public function roleRemove(IRole|string $role): IRole; public function roles(bool $all = false): array; public function permissionAdd(IPermission|string $permission): IRole; public function permissionRemove(IPermission|string $permission): IRole; public function permissions(bool $all = false): array; } interface IPermission { public function delete(): void; public function restore(): void; public function hasExists(): bool; public function name(): string; public function setDescription(string $value): IPermission; public function description(): string; public function setLinkToBan(bool $value): IPermission; public function hasLinkToBan(): bool; public function setPrefixValue(string $value): IPermission; public function getPrefixValue(): string; }
Поддержка пользовательских хранилищ
Для создания своего хранилище необходимо реализовать следующий интерфейс.
interface IStorage { public function onFlush(array $actions): void; public function onReset(): void; public function onReadPermission(array $contexts): void; public function onReadAllPermission(int $maxRecords, callable $cb): void; public function onReadRole(array $contexts): void; public function onReadAllRole(int $maxRecords, callable $cb): void; public function onReadUser(array $contexts): void; public function onReadAllUser(int $maxRecords, callable $cb): void; public function onCacheRead(string $type, string $name): ?array; public function onCacheWrite(string $type, string $name, array $refs): void; public function onCacheGets(string $type, array $refs, int $maxRecords, callable $cb): void; public function onCacheRemove(string $type, array $names): void; }
По умолчанию в штатную поставку входит реализация хранилища для работы с sqlite