我正在使用Zizaco/entrust laravel包作为我的项目的ACL管理器。
我知道通过中间件限制访问路由组并为其分配角色(或权限),我应该这样做:
Route::group(['prefix' => 'admin', 'middleware' => ['role:admin']], function() {
....
});
但我想为资源控制器的不同路由(方法)分配单独的权限。
我知道如何才能为整个资源提供但我不能为每个控制器方法实现它:
Route::group(['prefix' => 'admin', 'middleware' => ['role:admin']], function() {
Route::resource('/post', ['middleware' => ['permission:manage-posts'], 'uses' => 'PostController']);
});
我想将此权限授予相关方法:
'post-create' => public function create ()
'post-edit' => public function edit()
等等。
答案 0 :(得分:3)
您可以在控制器的构造函数中分配中间件:
class Foo extends Conroller
{
public function __construct() {
$this->middleware('post-create', ['only' => ['create']]);
$this->middleware('post-edit', ['only' => ['edit']]);
}
}