jundayw / laravel-policy-permisession
laravel policy-permisession
v1.0.0
2020-05-31 11:07 UTC
Requires
- php: >=7.2.0
This package is auto-updated.
Last update: 2024-12-29 06:33:58 UTC
README
命令行下, 执行 composer 命令安装:
composer require jundayw/laravel-policy-permisession
使用方法
authentication package that is simple and enjoyable to use.
导出配置
php artisan vendor:publish --tag=permission-config
导出数据库迁移文件
php artisan vendor:publish --tag=permission-migrations
数据库迁移
php artisan migrate --path=/database/migrations/2020_05_31_074124_create_policy_table.php
导出数据库填充文件
php artisan vendor:publish --tag=permission-seeders
数据库填充
php artisan db:seed --class=PermissionTableSeeder
用户模型
use Jundayw\LaravelPolicyPermisession\Contracts\PermissionContracts;
use Jundayw\LaravelPolicyPermisession\Traits\PermissionTrait;
class User extends Authenticatable implements PermissionContracts
{
use PermissionTrait;
public function getPermissions($permission, $arguments)
{
//return Policy::all();
}
自定义中间件
请先调用Auth中间件,然后在调用自定义中间件
namespace App\Http\Middleware;
use Closure;
class Permisession
{
/**
* Handle an incoming request.
*
* @param \Illuminate\Http\Request $request
* @param \Closure $next
* @return mixed
*/
public function handle($request, Closure $next, $guards)
{
//$request->user()->can($request->route()->..., $guards)
return $next($request);
}
}
授权语句
[
{
"Effect": "Allow",
"Action": ["Admin.*"],
"Resource": "*",
"Condition":{
"ip":"0.0.0.0/0"
}
},{
"Effect": "Deny",
"Action": ["Admin.role.*"],
"Resource": "*"
}
]
$request->user('admin')->can('admin.manager.delete')
// true
$request->user('admin')->can('admin.role.delete')
// false