Access-Management
This is total different concept on handle role and permission. A RBAC permission control through spatie/laravel-permission.
Author:
Solution Forest
Documentation
- Installation
- Publish Configs, Views, Translations and Migrations
- Migration
- Usage
- Routing control
- Super Administrator
- Advance Usage
- Changelog
- Contributing
- Security Vulnerabilities
- Credits
- License
This is an authentication plugin for Filament Admin with Laravel-permission
#Installation
-
Ensure you have already installed the Filament panel.
-
You can install the package via composer:
composer require solution-forest/filament-access-management -
Add the necessary trait to your User model:
use SolutionForest\FilamentAccessManagement\Concerns\FilamentUserHelpers; class User extends Authenticatable { use FilamentUserHelpers; } -
Clear your config cache:
php artisan optimize:clear # or php artisan config:clear -
Register the plugin in your Panel provider:
Important: Register the plugin in your Panel provider after version 2.x
use SolutionForest\FilamentAccessManagement\FilamentAccessManagementPanel; public function panel(Panel $panel): Panel { return $panel ->plugin(FilamentAccessManagementPanel::make()); } -
Then execute the following commands:
php artisan filament-access-management:installIf you don't already have a user named
admin, this command creates a Super Admin User with the following credentials:- Name: admin
- E-mail address: admin@("slug" pattern from config("app.name")).com
- Password: admin
You can also create the super admin user with:
php artisan make:super-admin-user -
Call upgrade command to upgrade data after version 2.2.0
php artisan filament-access-management:upgrade
#Publish Configs, Views, Translations and Migrations
You can publish the configs, views, translations and migrations with:
php artisan vendor:publish --tag="filament-access-management-config"
php artisan vendor:publish --tag="filament-access-management-views"
php artisan vendor:publish --tag="filament-access-management-translations"
php artisan vendor:publish --tag="filament-access-management-migrations"
#Migration
php artisan migrate
#Usage
Upon installation, "Menu", "Users", "Roles" and "Permissions" pages will be created. Each user have roles and each role have permissions.

Manage Menu:

Manage Users and their roles:

Manage Roles and their permissions:

Manage Permissions:

#Routing control
In this plugin, permissions and routes are bound together, set the routes that the current permissions can access in the edit permissions page, select the method to access the routes in the HTTP method select box, and fill in the path that can be accessed in the HTTP path.
For example, if you want to add a permission, which can access the path /admin/users by GET, then HTTP method select GET, and HTTP path fill in /users.
If you want to access all the paths prefixed with /admin/users, then HTTP path fill in /users*; if you want to access the edit page, then HTTP path fill in /users/*/edit; if the method of each path in multiple paths is different, then HTTP path fill in GET:users/*'. .
If the above method is not sufficient, HTTP path also supports routing aliases, such as admin.users.show.
#Super Administrator
Create super admin user:
php artisan make:super-admin-user
Check permission:
# Check by permission's name
\SolutionForest\FilamentAccessManagement\Http\Auth\Permission::check($name)
# Check by http_path
\SolutionForest\FilamentAccessManagement\Http\Auth\Permission::checkPermission($path)
Get current user:
\SolutionForest\FilamentAccessManagement\Facades\FilamentAuthenticate::user();
#Advance Usage
In default, the menu created will co-exist with the original menu of filament. To override the original menu with the menu from this package, modify /config/filament-access-management.php as following:
- Set
filament.navigation.enabled => true
'filament' => [
...
'navigation' => [
/**
* Using db based filament navigation if true.
*/
'enabled' => true,
/**
* Table name db based filament navigation.
*/
'table_name' => 'filament_menu',
/**
* Filament Menu Model.
*/
'model' => Models\Menu::class,
]
...
]
#Changelog
Please see CHANGELOG for more information on what has changed recently.
#Contributing
Please see CONTRIBUTING for details.
#Security Vulnerabilities
Please review our security policy on how to report security vulnerabilities.
#Credits
#License
The MIT License (MIT). Please see License File for more information.
The author
From the same author
Email 2FA
This package seamlessly integrates two-factor authentication (2FA) into your application using email verification codes. Enhance the security of your user accounts and protect sensitive data.
Author:
Solution Forest
Tree
This plugin creates model management page with heritage tree structure view for Filament Admin. It could be used to create menu, etc.
Author:
Solution Forest
Inspire CMS
InspireCMS is a flexible, un-opinionated content engine for Laravel, built on Filament.
Author:
Solution Forest
Simple Contact Form
A lightweight, customizable contact form plugin for FilamentPHP that provides an easy-to-use alternative to Contact Form 7. Build and manage contact forms with a simple, intuitive interface directly from your Filament admin panel.
Author:
Solution Forest
Featured Plugins
A selection of plugins curated by the Filament team
Custom Dashboards
Let your users build and share their own dashboards with a drag-and-drop interface. Define your data sources in PHP and let them do the rest.
Filament
Data Lens
Advanced Data Visualization for Laravel Filament - a premium reporting solution enabling custom column creation, sophisticated filtering, and enterprise-grade data insights within admin panels.
Padmission
Advanced Tables (formerly Filter Sets)
Supercharge your tables with powerful features like user-customizable views, quick filters, multi-column sorting, advanced table searching, convenient view management, and more. Compatible with Resource Panel Tables, Relation Managers, Table Widgets, and Table Builder!
Kenneth Sese