saeidsharafi / laravel-permission-generator
Generate Permission Enums and sync with spatie/laravel-permission based on a config file.
Installs: 168
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 1
Forks: 0
Open Issues: 0
Type:laravel-package
pkg:composer/saeidsharafi/laravel-permission-generator
Requires
- php: ^8.1
- illuminate/console: ^9.0|^10.0|^11.0|^12.0
- illuminate/filesystem: ^9.0|^10.0|^11.0|^12.0
- illuminate/support: ^9.0|^10.0|^11.0|^12.0
- spatie/laravel-permission: ^5.5|^6.0
Requires (Dev)
- laravel/pint: ^1.0
- orchestra/testbench: ^7.0|^8.0
- pestphp/pest: ^2.0
- pestphp/pest-plugin-laravel: ^2.0
This package is auto-updated.
Last update: 2025-12-17 13:29:00 UTC
README
Generate a PHP Permission Enum class for your Laravel application based on a configuration file and keep it synchronized with your spatie/laravel-permission database tables.
Stop manually defining permission strings everywhere and prevent typos!
Features
- Define permission structure (resources, actions, custom permissions) in a single config file.
- Generate a PHP 8.1+ backed Enum class containing all your permissions.
- Provides IDE auto-completion and type safety when referencing permissions.
- Includes an Artisan command to sync the generated permissions with your database (using
spatie/laravel-permission). - Handles common permission patterns (e.g.,
view_scopedstring generatesresource.view_anyandresource.view). - Supports custom actions and standalone permissions defined via strings or custom Enums.
- Optionally syncs all permissions to a designated "Super Admin" role.
- Optionally cleans up stale permissions from the database.
- Customizable enum template through published stubs.
- Automatically generates the enum file if missing during permissions sync.
- Configurable enum class namespace.
Requirements
- PHP >= 8.1
- Laravel >= 9.0
spatie/laravel-permission>= 5.5
Installation
Install the package via Composer:
composer require saeidsharafi/laravel-permission-generator
Setup
-
Publish the configuration file:
php artisan vendor:publish --provider="SaeidSharafi\LaravelPermissionGenerator\PermissionGeneratorServiceProvider" --tag="permission-generator-config"
This creates
config/permission-generator.phpin your application. -
Customize the Configuration: Open
config/permission-generator.phpand define:output_enum: The path where yourPermissionEnum.phpfile will be created (e.g.,app_path('Enums/PermissionEnum.php')).enum_class: The fully qualified class name of your enum (e.g.,App\Enums\PermissionEnum).resources: List your application resources (e.g., 'user', 'post') and their associated actions. Define actions using:- Strings (Recommended): Use simple strings like
'view_scoped','create','update_scoped', or custom action names like'publish','manage_roles'. The generator recognizes specific string values like'view_scoped'to automatically create_anyand simple/_ownversions. Other strings generate literalresource.actionpermissions. PermissionActionEnum (Optional): For standard patterns recognized by the generator, you can optionallyuse SaeidSharafi\LaravelPermissionGenerator\Enums\PermissionAction;and use constants likePermissionAction::VIEW_SCOPEDfor clarity.- Your Own Backed Enums (Advanced): You can use constants from your application's own
BackedEnumclasses (e.g.,App\Enums\MyActions::APPROVE). The generator will use the Enum case's value. Important: Special logic (like_scopedgenerating two permissions) is only triggered by specific string values recognized by the package (like'view_scoped'), not by the structure of your custom Enum.
- Strings (Recommended): Use simple strings like
custom_permissions: (Optional) Define standalone permissions not tied to a resource.super_admin_role: (Optional) Name of the role to grant all permissions.remove_stale_permissions: (Optional) Set totrueto enable cleanup of old permissions during sync (use with caution).
-
Customize Enum Templates (Optional):
php artisan vendor:publish --provider="SaeidSharafi\LaravelPermissionGenerator\PermissionGeneratorServiceProvider" --tag="permission-generator-stubs"
This publishes the enum template to
stubs/vendor/permission-generator/enum.stubwhere you can customize it.
Usage Workflow
-
Configure: Define your desired permission structure in
config/permission-generator.php. -
Generate Enum: Create or update your
PermissionEnum.phpfile:php artisan permissions:generate-enum
- Use
--forceto overwrite without confirmation.
- Use
-
Sync Database: Ensure the permissions defined in your Enum exist in the database for
spatie/laravel-permission:php artisan permissions:sync
- Use
--freshwith extreme caution to delete all existing permissions and their assignments before syncing. - Use
--yesor-Yto skip confirmation prompts.
- Use
-
Use the Enum: Import and use your generated Enum (e.g.,
App\Enums\PermissionEnum) in your code (Policies, Middleware, Controllers, Filament, etc.) for type safety and auto-completion.use App\Enums\PermissionEnum; // Adjust namespace if you changed the output path // Example Policy public function updateAny(User $user): bool { return $user->hasPermissionTo(PermissionEnum::POST_UPDATE_ANY->value); } // Example Middleware or Controller Check if (! Auth::user()?->can(PermissionEnum::ACCESS_ADMIN_DASHBOARD->value)) { abort(403); }
Streamlined Workflow
The package now supports a more streamlined workflow:
- If you run
permissions:syncwithout first generating the enum file, it will automatically runpermissions:generate-enumfor you. - This makes it easier to get started with minimal setup - just configure your permissions and run
php artisan permissions:sync.
Configuration Details
See the comments within the published config/permission-generator.php file for detailed explanations of each option and how to define resources and actions using strings or Enums.
Development (Linking Local Package)
If you want to contribute or modify the package locally:
- Clone the package repository separately.
- In your main Laravel project's
composer.json, add arepositoriessection:"repositories": [ { "type": "path", "url": "../path/to/your/local/laravel-permission-generator" } ],
- Require the package with
@devstability in your project'scomposer.json:"require": { "saeidsharafi/laravel-permission-generator": "@dev", // ... other requires ... }
- Run
composer update saeidsharafi/laravel-permission-generator.
License
The MIT License (MIT). Please see the LICENSE file for more information.