5

我正在使用 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 [];
    }
}

然后我为该资源创建了一个名为 Item 的 Laravel 模型类。

然后我创建了策略。

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 管理面板中看到项目列表时,我仍然可以创建项目。怎么了?应该隐藏创建项目的选项。

4

6 回答 6

3

将以下内容添加到您的 Nova 资源类中:

public static function authorizable()
{
    return true;
}
于 2018-12-15T01:29:46.010 回答
1

再次检查 AuthServiceProvider。

您在其中定义策略映射数组:

protected $policies = [
    Item::class => ItemPolicy::class,
];

项目- 应该是您的模型,不是Nova 资源

于 2019-01-07T23:20:10.073 回答
0

使用 rolePolicy 或 permissionPolicy 方法定义策略

// in app/Providers/NovaServiceProvider.php

// ...

public function tools()
{
    return [
        // ...
        \Vyuldashev\NovaPermission\NovaPermissionTool::make()
            ->rolePolicy(RolePolicy::class)
            ->permissionPolicy(PermissionPolicy::class),
    ];
}
于 2020-05-02T14:51:01.903 回答
0

从类中删除viewAny()方法ItemPolicyPolicy

于 2018-12-30T03:25:36.297 回答
0

您注册的保单错误

/**
 * The policy mappings for the application.
 *
 * @var array
 */
protected $policies = [
    // 'App\Model' => 'App\Policies\ModelPolicy',
    'App\Item' => 'App\Policies\ItemPolicy',
];
于 2020-09-16T20:49:46.617 回答
-1

可能是因为您在方法参数中缺少模型类型

添加Item $item传递 $item 的所有方法,如下所示:

public function update(User $user, Item $item)
{
    return false;
}

您也可以排除所有您希望不可用的方法,默认情况下它们将被禁用

于 2018-10-31T23:34:21.250 回答