laravilt / users
User and Role management plugin for Laravilt - Full RBAC system with impersonation support
Fund package maintenance!
fadymondy
Installs: 0
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 0
Forks: 0
Open Issues: 0
pkg:composer/laravilt/users
Requires
- php: ^8.3|^8.4
- laravilt/laravilt: ^1.0
- spatie/laravel-medialibrary: ^11.0
- spatie/laravel-package-tools: ^1.14
- spatie/laravel-permission: ^6.0
Requires (Dev)
- larastan/larastan: ^2.9||^3.0
- laravel/pint: ^1.14
- nunomaduro/collision: ^8.1.1||^7.10.0
- orchestra/testbench: ^10.0
- pestphp/pest: ^3.0
- pestphp/pest-plugin-arch: ^3.0
- pestphp/pest-plugin-laravel: ^3.0
- pestphp/pest-plugin-livewire: ^3.0
- pestphp/pest-plugin-type-coverage: ^3.5
- phpstan/extension-installer: ^1.3||^2.0
- phpstan/phpstan-deprecation-rules: ^1.1||^2.0
- phpstan/phpstan-phpunit: ^1.3||^2.0
This package is auto-updated.
Last update: 2025-12-22 03:50:11 UTC
README
Laravilt Users
Complete User and Role management plugin for Laravilt with full RBAC (Role-Based Access Control) system and impersonation support.
Features
User Management
- Full CRUD Operations - Create, read, update, and delete users
- Avatar Support - Optional user avatars with fallback to UI Avatars
- Email Verification - Track email verification status
- Role Assignment - Assign multiple roles to users
- Search & Filters - Filter users by role, search by name/email
Role Management
- Complete RBAC - Full Role-Based Access Control system
- Permission Groups - Permissions grouped by resource
- Bulk Selection - Select all permissions for a resource
- Guard Support - Multiple auth guards support
Impersonation
- User Impersonation - Login as any user for debugging/support
- Session Preservation - Original session saved during impersonation
- Banner Notification - Visual indicator when impersonating
- Security Controls - Cannot impersonate self or super admins
Localization
- Multi-language - Full English and Arabic translations
- RTL Support - Right-to-left layout support for Arabic
- Translatable Labels - All fields, actions, and messages translated
Requirements
- PHP 8.3+
- Laravel 12+
- Laravilt 1.0+
- Spatie Laravel Permission 6.0+
Installation
composer require laravilt/users
The service provider is auto-discovered and will register automatically.
Run Migrations
php artisan migrate
Install Plugin
php artisan laravilt:users:install
This command will:
- Publish configuration file
- Set up default permissions
- Create default roles (Super Admin, Admin, User)
Configuration
Publish the configuration file:
php artisan vendor:publish --tag=laravilt-users-config
Configure in config/laravilt-users.php:
return [ // Default guard for permissions 'guard_name' => 'web', // Features (opt-in) 'features' => [ 'impersonation' => false, // Enable user impersonation 'avatar' => false, // Enable user avatars 'teams' => false, // Enable team support 'email_verification' => true, ], // Navigation settings 'navigation' => [ 'group' => 'Users & Roles', 'sort' => 1, ], // Impersonation settings 'impersonation' => [ 'redirect_to' => '/admin', 'leave_redirect_to' => '/admin', ], ];
Usage
Register Plugin with Panel
use Laravilt\Users\UsersPlugin; class AdminPanelProvider extends PanelProvider { public function panel(Panel $panel): Panel { return $panel ->plugins([ UsersPlugin::make() ->navigationGroup('Settings') ->navigationSort(10) ->avatar() // Enable avatars ->impersonation(), // Enable impersonation ]); } }
Plugin Methods
UsersPlugin::make() // Navigation ->navigationGroup('Custom Group') // Set navigation group ->navigationSort(5) // Set navigation order // Features (opt-in) ->avatar() // Enable avatar feature ->impersonation() // Enable impersonation feature
User Model Setup
Add the required traits to your User model:
use Laravilt\Users\Concerns\HasRolesAndPermissions; use Laravilt\Users\Concerns\HasAvatar; class User extends Authenticatable { use HasRolesAndPermissions; use HasAvatar; // Optional, for avatar support // For impersonation support public function canImpersonate(): bool { return $this->hasRole('super_admin'); } public function canBeImpersonated(): bool { return !$this->hasRole('super_admin'); } }
Setting Up Permissions
Run the setup command to create permissions for all resources:
php artisan laravilt:secure
This creates permissions like:
view_any_user,view_user,create_user,update_user,delete_userview_any_role,view_role,create_role,update_role,delete_role
Impersonation
Enable Impersonation
UsersPlugin::make()->impersonation()
Add Middleware
Add the impersonation banner middleware to your panel:
use Laravilt\Users\Http\Middleware\ImpersonationBanner; $panel->middleware([ ImpersonationBanner::class, ]);
Stop Impersonation
Users can stop impersonation via:
- The banner "Stop Impersonation" button
- Route:
GET /admin/impersonation/leave
Resources
UserResource
Manages users with:
- Avatar (optional)
- Name and Email
- Password management
- Role assignment
- Email verification status
- Created/Updated timestamps
RoleResource
Manages roles with:
- Role name
- Guard name
- Permission assignment (grouped by resource)
- User count
Translations
All strings are translatable. Translation files are located in:
lang/en/users.php- English translationslang/ar/users.php- Arabic translations
Documentation
Comprehensive documentation is available in the docs/ directory:
Testing
composer test
Code Style
composer format
Static Analysis
composer analyse
Contributing
Please see CONTRIBUTING.md for details.
Security
If you discover any security-related issues, please email info@3x1.io instead of using the issue tracker.
Changelog
Please see CHANGELOG.md for recent changes.
License
The MIT License (MIT). Please see License File for more information.
Credits
- Fady Mondy
- Spatie for Laravel Permission
- All Contributors
Sponsors
Support this project via GitHub Sponsors.
