kriratokatklian/nova-permission

一个用于Spatie权限库的Laravel Nova工具。

4.0.10 2024-05-21 08:46 UTC

README

Latest Version on Packagist Total Downloads

screenshot 1

注意

感谢 vyuldashev。由于原始包已有一段时间没有更新,且vyuldashev没有发布任何更新迹象,因此我创建了此分支,包含所有最新的更改。我主要在我的项目中使用它,但也欢迎您使用。欢迎提交PR。

版本兼容性

随着Nova 4.0的发布,现在有两个独立的Nova权限版本。不幸的是,由于更新性质,新的版本不向后兼容。因此,请根据需要选择版本。

安装

您可以通过composer将此包安装到使用Nova的Laravel项目中

composer require kiritokatklian/nova-permission

查看安装部分,以设置laravel-permission

接下来,您必须将工具与Nova注册。这通常在NovaServiceProvidertools方法中完成。

// in app/Providers/NovaServiceProvider.php

// ...

public function tools()
{
    return [
        // ...
        \Vyuldashev\NovaPermission\NovaPermissionTool::make(),
    ];
}

接下来,将中间件添加到config/nova.php

// in config/nova.php
'middleware' => [
    // ...
    \Vyuldashev\NovaPermission\ForgetCachedPermissions::class,
],

最后,将MorphToMany字段添加到您的app/Nova/User资源中

// ...
use Laravel\Nova\Fields\MorphToMany;

public function fields(Request $request)
{
    return [
        // ...
        MorphToMany::make('Roles', 'roles', \Vyuldashev\NovaPermission\Role::class),
        MorphToMany::make('Permissions', 'permissions', \Vyuldashev\NovaPermission\Permission::class),
    ];
}

或者,如果您想一次性添加多个权限,请使用RoleBooleanGroupPermissionBooleanGroup字段(需要至少Nova 2.6.0版本)

// ...
use Vyuldashev\NovaPermission\PermissionBooleanGroup;
use Vyuldashev\NovaPermission\RoleBooleanGroup;

public function fields(Request $request)
{
    return [
        // ...
        RoleBooleanGroup::make('Roles'),
        PermissionBooleanGroup::make('Permissions'),
    ];
}

如果您的User在任何给定时间可能只有一个角色,您可以使用RoleSelect字段。此字段将渲染一个标准选择框,您可以从中选择单个角色。

// ...
use Vyuldashev\NovaPermission\PermissionBooleanGroup;
use Vyuldashev\NovaPermission\RoleSelect;

public function fields(Request $request)
{
    return [
        // ...
        RoleSelect::make('Role', 'roles'),
    ];
}

定制

如果您想使用自定义资源类,您可以在注册工具时定义它们

// in app/Providers/NovaServiceProvider.php

// ...

public function tools()
{
    return [
        // ...
        \Vyuldashev\NovaPermission\NovaPermissionTool::make()
            ->roleResource(CustomRole::class)
            ->permissionResource(CustomPermission::class),
    ];
}

如果您想使用自定义标签显示您的角色和策略,您可以在实例化字段时设置$labelAttribute

// ...
use Vyuldashev\NovaPermission\PermissionBooleanGroup;
use Vyuldashev\NovaPermission\RoleSelect;

public function fields(Request $request)
{
    return [
        // ...
        RoleBooleanGroup::make('Roles', 'roles', null, 'description'),
        PermissionBooleanGroup::make('Permissions', 'permissions', null, 'description'),
        RoleSelect::make('Role', 'roles', null, 'description'),
    ];
}

定义策略

// in app/Providers/NovaServiceProvider.php

// ...

public function tools()
{
    return [
        // ...
        \Vyuldashev\NovaPermission\NovaPermissionTool::make()
            ->rolePolicy(RolePolicy::class)
            ->permissionPolicy(PermissionPolicy::class),
    ];
}

用法

安装此包后,您的Nova应用将出现一个名为“权限 & 角色”的新菜单项。