by Tharinda Rodrigo
Resources for Roles and Permissions. Generate Permissions based on Models and Resources. Generate Policies. Manage Permissions for teams.
This plugin is built on top of Spatie's Permission package.
Provides Resources for Roles and Permissions
Permission and Policy generations
config/filament-spatie-roles-permissions-config.php
Supports permissions for teams
teams attribute in the app/permission.php file is set to true
After performing a composer update, run
php artisan vendor:publish --tag="filament-spatie-roles-permissions-config" --forceNote that your existing settings will be overriden
You can install the package via composer:
composer require althinect/filament-spatie-roles-permissionsSince the package depends on Spatie's Permission package. You have to publish the migrations by running:
php artisan vendor:publish --provider="Spatie\Permission\PermissionServiceProvider"Now you should add any other configurations needed for the Spatie-Permission package.
Note: This will override your existing config file. You can publish the config file of the package with:
php artisan vendor:publish --tag="filament-spatie-roles-permissions-config" --forceYou can add the following to your form method in your UserResource
return $form->schema([    Select::make('roles')->multiple()->relationship('roles', 'name')])In addition to the field added to the UserResource. There will be 2 Resources published under Roles and Permissions. You can use these resources manage roles and permissions.
You can generate Permissions by running
php artisan permissions:syncThis will not delete any existing permissions. However, if you want to delete all existing permissions, run
php artisan permissions:sync -C|--cleanIf you have a Post model, it will generate the following permissions
view-any Postview Postcreate Postupdate Postdelete Postrestore Postforce-delete Postreplicate Postreorder PostPolicies will be generated with the respective permission. This won't replace any existing policies
php artisan permissions:sync -P|--policiesThis will override existing policy classes
php artisan permissions:sync -O|--oepYou can ignore any prompts by add the flag -Y or --yes-to-all
Recommended only for new projects as it will replace Policy files
php artisan permissions:sync -COPYSuper Admin and assign the role to a Useruse Althinect\FilamentSpatieRolesPermissions\Concerns\HasSuperAdmin; class User extends Authenticatable{ ...use HasSuperAdmin;boot method of the AuthServiceProvider add the followingGate::before(function (User $user, string $ability) {    return $user->isSuperAdmin() ? true: null;});In the filament-spatie-roles-permissions.php config file, you can customize the permission generation
If you discover any security related issues, please create an issue.
The MIT License (MIT). Please see License File for more information.
This package was generated using the Laravel Package Boilerplate.