fullstackllc/novaspatiepermissions

Laravel Nova 工具,用于在 Laravel Nova 包中管理 spaties 角色/权限。

v1.0.0 2024-05-30 20:59 UTC

This package is not auto-updated.

Last update: 2024-09-20 20:36:39 UTC


README

License Latest Stable Version Total Downloads

Nova 工具允许您

  • 在 Nova 仪表板上管理角色和权限
  • 为 Nova 资源使用基于权限的授权

屏幕截图

要求 & 依赖

除了 Laravel Nova v4 包和 Spatie Permission v5 包之外,没有 PHP 依赖。

安装

您可以使用 composer 将此工具安装到使用 Nova 的 Laravel 应用程序中

composer require fullstackllc/novaspatiepermissions

接下来,如果您尚未启用包发现,您需要将提供程序注册到 config/app.php 文件中。

'providers' => [
    ...,
    Fullstackllc\Novaspatiepermissions\NovaSpatiePermissionsServiceProvider::class,
]

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

// in app/Providers/NovaServiceProvider.php
use Fullstackllc\Novaspatiepermissions\Novaspatiepermissions;

public function tools()
{
    return [
        // ...
        Novaspatiepermissions::make(),
    ];
}

接下来,向您的 app/Nova/User 资源添加 MorphToMany 字段

use Laravel\Nova\Fields\MorphToMany;

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

最后,将 ForgetCachedPermissions 类添加到您的 config/nova.php 中间件中,如下所示

// in config/nova.php
'middleware' => [
	'web',
	Authenticate::class,
	DispatchServingNovaEvent::class,
	BootTools::class,
	Authorize::class,
	 \Fullstackllc\Novaspatiepermissions\ForgetCachedPermissions::class,
],

本地化

您可以使用 artisan 命令行工具发布本地化文件

php artisan vendor:publish --provider=" \Fullstackllc\Novaspatiepermissions\NovaPermissionServiceProvider"

Nova 资源基于权限的授权

默认情况下,Laravel Nova 使用基于策略的授权来授权 Nova 资源。如果您正在使用 Spatie Permission 库,您可能会想将其更改为基于权限的授权,而无需定义授权策略。

为此,您可以使用 PermissionsBasedAuthTrait 并在您的 Nova 资源类中定义一个 permissionsForAbilities 静态数组属性,如下所示

// in app/Nova/YourNovaResource.php

class YourNovaResource extends Resource
{
    use \Fullstackllc\Novaspatiepermissions\PermissionsBasedAuthTrait;

    public static $permissionsForAbilities = [
      'all' => 'manage products',
    ];
}

上面的示例意味着具有“管理产品”权限的用户可以执行此资源上的所有操作。您也可以像这样为每个操作定义单独的权限

    public static $permissionsForAbilities = [
      'viewAny' => 'view products',
      'view' => 'view products',
      'create' => 'create products',
      'update' => 'update products',
      'delete' => 'delete products',
      'restore' => 'restore products',
      'forceDelete' => 'forceDelete products',
      'addAttribute' => 'add product attributes',
      'attachAttribute' => 'attach product attributes',
      'detachAttribute' => 'detach product attributes',
    ];

关系

要允许您的用户在模型上指定关系,您需要在模型上添加另一个权限。例如,如果您的 Product 属于 User,请在 app/Nova/User.php 上添加以下权限。

    public static $permissionsForAbilities = [
      'addProduct' => 'add user on products'
    ];

贡献

欢迎贡献,解释您想要解决的问题/功能,并使用测试来支持您的代码。祝您编码愉快!

许可证

此包最初由 https://github.com/insenseanalytics/laravel-nova-permission 开发,但他们已放弃此包。MIT 许可证 (MIT)。有关更多信息,请参阅 许可证文件