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

1.0.0 2025-12-21 15:20 UTC

This package is auto-updated.

Last update: 2025-12-22 03:50:11 UTC


README

Users

Laravilt Users

Latest Stable Version License Downloads Dependabot Updates PHP Code Styling Tests

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_user
  • view_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 translations
  • lang/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

Sponsors

Support this project via GitHub Sponsors.