alifcoder / permissions
A simple role and permission management package for Laravel.
Requires
- php: >=8.2
- illuminate/support: ^11.0 || ^12.0
Requires (Dev)
- laravel/framework: ^v12.14.1
README
A simple, flexible role and permission management system for Laravel applications โ designed to support
Gate::before
, SUPER ADMIN
logic, modular apps (nwidart/laravel-modules
), and dynamic user model resolution.
โจ Features
- Role and permission management with pivot tables
SUPER ADMIN
bypass support usingGate::before()
HasRoles
trait for easy user integration- Dynamically configurable user model
- Language file localization (EN, customizable)
- Clean service provider with publishable config and migrations
- Works with modular Laravel apps (like
nwidart/laravel-modules
)
๐ฆ Requirements
- PHP
>=8.2
- Laravel
^11.0 || ^12.0
๐ Installation
composer require alifcoder/permissions
Then publish the config, translations, and migrations:
php artisan vendor:publish --tag=permissions php artisan migrate
This will publish:
lang/vendor/permissions
config/permission.php
database/migrations/xxxx_xx_xx_xxxxxx_create_permissions_table.php
โ๏ธ Configuration
Inside config/permissions.php
:
return [ 'models' => [ 'role' => \Alif\Permissions\Models\Role::class, 'permission' => \Alif\Permissions\Models\Permission::class, ], 'cacheable' => true, 'is_model_uuid' => true, ];
You can override the default user model or super-admin slug here.
๐งฌ Traits
In your User
model, add the trait:
use Alif\Permissions\Traits\HasRoles; class User extends Authenticatable { use HasRoles; }
๐ Super Admin Access
Add this in your app (e.g., AuthServiceProvider
) โ or it's auto-registered by the package:
Gate::before(function ($user, $ability) { return $user->isSuperAdmin() ? true : null; });
This lets super-admin
users bypass all policy/gate checks.
๐ง Usage
Assign Roles & Permissions
$admin = Role::create(['name' => 'Admin', 's_code' => 'admin']); $edit = Permission::create(['name' => 'products.update']); $admin->permissions()->attach($edit->id); $user->syncRoles($admin->id);
Check Permissions
$user->hasAllRoles('admin'); // true $user->hasAnyRoles('admin'); // true $user->hasPermission('products.update'); // true $user->isSuperAdmin(); // true or false
๐ Localization
The package includes English (en
) translations. To override or translate:
Then add resources/lang/vendor/permissions/{locale}/permissions.php
.
๐งโ๐ป Usage macro
Also you can use Route macro to check permissions and roles:
Route::put('/products/{product}', function () { // Your logic here })->permission('products.update'); Route::put('/admin', function () { // Your logic here })->role('admin');
๐งฉ Folder Structure
src/
โโโ Models/
โ โโโ Role.php
โ โโโ Permission.php
โโโ Traits/
โ โโโ HasRoles.php
โโโ Middleware/
โโโ Console/
โโโ PermissionServiceProvider.php
config/
โโโ permissions.php
resources/
โโโ lang/en/permissions.php
database/
โโโ migrations/
๐งน Clear permission caches
Run this command to clear the permission cache:
php artisan permission:cache:clear
๐งน Uninstall (Clean Up)
Run this command before removing the package:
php artisan permission:uninstall
๐ License
MIT ยฉ Shukhratjon Yuldashev
๐ Contributing
Pull requests and suggestions are welcome!