我正在使用Laravel开发Web应用程序。我正在使用Nova作为管理面板。现在,我正在使用文档中提到的策略来授权资源。但似乎不起作用。到目前为止,这是我所做的。我已经创建了这样的新星资源。
class Item extends Resource
{
/**
* The model the resource corresponds to.
*
* @var string
*/
public static $model = \App\Models\Item::class;
/**
* The single value that should be used to represent the resource when being displayed.
*
* @var string
*/
public static $title = 'id';
/**
* The columns that should be searched.
*
* @var array
*/
public static $search = [
'id',
];
/**
* Get the fields displayed by the resource.
*
* @param \Illuminate\Http\Request $request
* @return array
*/
public function fields(Request $request)
{
return [
ID::make()->sortable(),
];
}
/**
* Get the cards available for the request.
*
* @param \Illuminate\Http\Request $request
* @return array
*/
public function cards(Request $request)
{
return [];
}
/**
* Get the filters available for the resource.
*
* @param \Illuminate\Http\Request $request
* @return array
*/
public function filters(Request $request)
{
return [];
}
/**
* Get the lenses available for the resource.
*
* @param \Illuminate\Http\Request $request
* @return array
*/
public function lenses(Request $request)
{
return [];
}
/**
* Get the actions available for the resource.
*
* @param \Illuminate\Http\Request $request
* @return array
*/
public function actions(Request $request)
{
return [];
}
}
然后,我为该资源创建了一个Laravel Model类,名称为Item。
然后我创建了政策。
class ItemPolicy
{
use HandlesAuthorization;
public function viewAny(User $user)
{
return true;
}
public function view(User $user, $item)
{
return true;
}
public function create(User $user)
{
return false;
}
public function update(User $user, $item)
{
return false;
}
public function delete(User $user, $item)
{
return false;
}
public function restore(User $user, $item)
{
return false;
}
public function forceDelete(User $user, $item)
{
return false;
}
}
我在AuthServiceProvider中注册了策略。
protected $policies = [
Item::class => ItemPolicy::class,
];
当我在nova管理面板中看到项目列表时,我仍然可以创建该项目。怎么了?创建项目的选项应隐藏。
答案 0 :(得分:1)
将以下内容添加到您的Nova资源类中:
public static function authorizable()
{
return true;
}
答案 1 :(得分:0)
从viewAny()
类中删除ItemPolicyPolicy
方法
答案 2 :(得分:0)
再次检查AuthServiceProvider。
定义策略映射数组的位置:
protected $policies = [
Item::class => ItemPolicy::class,
];
项目-应该是您的模型,而不是 Nova资源
答案 3 :(得分:0)
使用rolePolicy或PermissionPolicy方法定义策略
// in app/Providers/NovaServiceProvider.php
// ...
public function tools()
{
return [
// ...
\Vyuldashev\NovaPermission\NovaPermissionTool::make()
->rolePolicy(RolePolicy::class)
->permissionPolicy(PermissionPolicy::class),
];
}
答案 4 :(得分:0)
您的保单注册错误
/**
* The policy mappings for the application.
*
* @var array
*/
protected $policies = [
// 'App\Model' => 'App\Policies\ModelPolicy',
'App\Item' => 'App\Policies\ItemPolicy',
];
答案 5 :(得分:-1)
也许是因为方法参数中缺少模型类型
在所有通过$ item的方法中添加Item $item
,如下所示:
public function update(User $user, Item $item)
{
return false;
}
您还可以排除所有您不希望使用的方法,默认情况下它们将被禁用