gurinder / laravel-acl
Laravel 角色与权限 UI
1.0.11
2018-07-06 22:49 UTC
Requires
- php: ^7.1.3
- illuminate/auth: ^5.6
- illuminate/cache: ^5.6
- illuminate/container: ^5.6
- illuminate/contracts: ^5.6
- illuminate/database: ^5.6
- illuminate/events: ^5.6
- illuminate/pagination: ^5.6
- illuminate/routing: ^5.6
- illuminate/validation: ^5.6
- illuminate/view: ^5.6
Requires (Dev)
- phpunit/phpunit: ^7.0
README
安装
步骤 1
通过 Composer 包含
composer require gurinder/laravel-acl
步骤 2
发布迁移(如需自定义视图)、配置(可选)
php artisan vendor:publish --tag="acl::migrations" // Optional php artisan vendor:publish --tag="acl::views" // Optional php artisan vendor:publish --tag="acl::config"
步骤 3
运行迁移
php artisan migrate
步骤 4 - 配置文件
配置文件信息
return [ // Cache key to store acl data 'cache_key' => 'gurinder.laravel-acl', // Cache Exiration time 'cache_expiration_time' => 60 * 24, // Route prefix e.g. 'example.com/admin 'route_prefix' => 'admin', // Route name as e.g use -> route('admin.roles.index') 'route_as' => 'admin.', // Master roles - All new permission will be added to these roles automatically. 'master_roles' => ['admin'], // Roles which are not editable 'freezed_roles' => ['admin'], // Permissions which are not editable 'freezed_permissions' => ['manage-acl', 'manage-users'], // Link back to dashboard or anywhere else 'back_link' => [ 'label' => 'Dashboard', 'url' => '/home' ], // Search column on user models 'user_search_columns' => [ 'id', 'name', 'email' ] ];
步骤 5 - 添加函数
将所需函数添加到您的 helpers.php 文件中
if (!function_exists('isAdmin')) { /** * Check if user is admin admin * * @param \App\Models\User|null $user * @return bool */ function isAdmin(\App\Models\User $user = null) { return $user ? $user->isAdmin() : (auth()->check() && auth()->user()->isAdmin()); } }
步骤 6 - 添加中间件
protected $routeMiddleware = [ // ... 'permissions' => \Gurinder\LaravelAcl\Middlewares\PermissionsMiddleware::class, 'roles' => \Gurinder\LaravelAcl\Middlewares\RolesMiddleware::class ];
用法
将 AclGuarded 特性添加到您的用户模型中,并将 isAdmin() 添加到 User 模型中
use Illuminate\Notifications\Notifiable; use Illuminate\Foundation\Auth\User as Authenticatable; use Gurinder\LaravelAcl\Traits\AclGuarded; class User extends Authenticatable { use Notifiable, AclGuarded; ... }
检查用户是否有角色或权限
Gurinder\LaravelAcl\Package\Models\Role Gurinder\LaravelAcl\Package\Models\Permission $user->hasRole($role) // $role can be string, ID, or Role Model instance $user->hasPermission($permission) // $permission can be string, ID, or Permission Model instance
您还可以在 blade 指令中使用权限
@can('manage-acl') // The Current User Can Manage Acl @elsecan('manage-users') // The Current User Can Manage Users @endcan // OR @if (Auth::user()->can('manage-acl')) // The Current User Can Manage Acl @endif
数据库播种
为角色和模型创建工厂
use Faker\Generator as Faker; $factory->define(\Gurinder\LaravelAcl\Package\Models\Role::class, function (Faker $faker) { return [ 'name' => $faker->word ]; }); $factory->define(\Gurinder\LaravelAcl\Package\Models\Permission::class, function (Faker $faker) { return [ 'name' => $faker->word ]; });
创建 Seeder 类
use Gurinder\LaravelAcl\Package\Models\Permission; use Gurinder\LaravelAcl\Package\Models\Role; use Illuminate\Database\Seeder; class AccessControlListTableSeeder extends Seeder { protected $roles = [ 'admin','editor']; protected $permissions = [ 'manage users', 'manage acl', 'manage posts' ]; /** * Run the database seeds. * * @return void */ public function run() { $roles = $this->seedRoles(); $permissionsIds = $this->seedPermissions(); $roles['admin']->syncPermissions($permissionsIds); } /** * @return array */ protected function seedRoles() { $roles = []; foreach ($this->roles as $role) { $role = factory(Role::class)->create(['name' => $role, 'slug' => str_slug($role)]); $roles[$role->slug] = $role; } return $roles; } protected function seedPermissions() { $ids = []; foreach ($this->permissions as $label) { $ids[] = factory(Permission::class)->create(['name' => $label, 'slug' => str_slug($label)])->id; } return $ids; } }
在路由中
Route::group(['middleware' => ['role:super-admin']], function () { // }); Route::group(['middleware' => ['permission:manage-users']], function () { // }); // Multiple Route::group(['middleware' => ['role:super-admin|admin','permission:manage-users|manage-posts']], function () { // });
许可证
MIT 许可证(MIT)。请参阅 许可证文件 获取更多信息。