Мне не понравилась стандартная реализация RBAC в Yii2, слишком уж они все усложнили. В частности, для не очень больших проектов, где прав доступа не очень много и они в процессе жизни приложения практически не меняются, этот подход на мой взгляд слишком громоздок. Поэтому я решил запилить реализацию RBAC на основе файлов, похожую на ту, что была в первом Yii.
Этот код служит только для проверки прав доступа. Здесь нет возможности программно создавать иерархию прав и сохранять ее. Иерархия описывается вручную в файле настроек.
Устанавливается с посощью composer.
Для установки выполняем команду
php composer.phar require --prefer-dist m00nk/yii2-rbac "*"
или добавляем
"m00nk/yii2-rbac": "*"
в разделе require
вашего composer.json файла.
'components' => [
...
'authManager' => [
'class' => 'm00nk\rbac\AuthManager',
'authFile' => '@app/config/auth.php' // путь к файлу с описанием иерархии прав доступа
],
...
],
return [
// PERMISSIONS
//-------------------------
'permCreatePost' => [
'type' => 0, // permission
'description' => 'право на создание поста в блоге'
],
'permUpdatePost' => [
'type' => 0,
'description' => 'право на редактирование поста в блоге'
],
// TASKS
//-------------------------
'permUpdateOwnPost' => [
'type' => 1, // task
'description' => 'право на редактирование СЫВОЕГО поста в блоге'
'rule' => 'return app\\models\\Post::mayEditPost($params["id"]);',
'children' => [
'permUpdatePost'
]
],
// ROLES
//-------------------------
'author' => [
'type' => 2, // role
'description' => 'автор - может только создавать посты и редактировать только свои'
'children' => [
'permCreatePost',
'permUpdateOwnPost'
]
],
'moderator' => [
'type' => 2, // role
'description' => 'модератор - может только редактировать посты, зато чьи угодно'
'children' => [
'permUpdatePost'
]
],
];
Начиная с версии 2.1.0 можно в качестве правил использовать инлайн-функции:
'rule' => function($params){ return app\models\Post::mayEditPost($params["id"]); },
Проверка осуществлается стандартным способом:
// проверяем, может ли юзер создавать посты
if(\Yii::$app->user->can('permCreatePost')) ...
// проверяем, может ли юзер редактировать текущий пост
// обратите внимание, что проверяется именно permUpdatePost, а не permUpdateOwnPost
if(\Yii::$app->user->can('permUpdatePost', ['id' => $post->id])) ...
Comments