chrisreedio / bastion
SSO Powered Access Control for Filament
Fund package maintenance!
chrisreedio
Requires
- php: ^8.1
- chrisreedio/filament-policy-generator: ^3.0.0
- filament/filament: ^3.0
- spatie/laravel-package-tools: ^1.15.0
- spatie/laravel-permission: ^6.0
Requires (Dev)
- laravel/pint: ^1.13
- nunomaduro/collision: ^7.10|^8.0
- nunomaduro/larastan: ^2.1.1
- orchestra/testbench: ^v8.22|^9.0
- pestphp/pest: ^2.0
- pestphp/pest-plugin-arch: ^2.0
- pestphp/pest-plugin-laravel: ^2.0
- phpstan/extension-installer: ^1.1
- phpstan/phpstan-deprecation-rules: ^1.0
- phpstan/phpstan-phpunit: ^1.3
- phpunit/phpunit: ^10.4.1
This package is auto-updated.
Last update: 2024-12-04 17:28:17 UTC
README
Bastion is a package/plugin for Filament and Laravel to quickly scaffold out access control for your application.
It's primary use case is with SSO and Azure Active Directory, but it can be used with any authentication provider.
Warning
This package is still in development and is not ready for production use.
Installation
You can install the package via composer:
composer require chrisreedio/bastion
Update your PanelProvider to include the plugin:
$panel ->plugins([ // ... Other Plugins \ChrisReedIO\Bastion\BastionPlugin::make(), ])
You can publish and run the migrations with:
php artisan vendor:publish --tag="bastion-migrations"
php artisan migrate
You can publish the config file with:
php artisan vendor:publish --tag="bastion-config"
This is the contents of the published config file:
return [ 'models' => [ 'permission' => \Spatie\Permission\Models\Permission::class, 'role' => \Spatie\Permission\Models\Role::class, 'user' => '\App\Models\User', ], 'permissions' => [ 'preload' => true, ], 'default_guard' => 'web', 'guards' => [ // value => 'Custom Label' 'web' => 'Web', 'api' => 'API', // Your other custom guards here ], 'sso' => [ 'enabled' => false, ], ];
You can publish the seeder(s) with:
php artisan vendor:publish --tag="bastion-seeders"
Optionally, you can publish the views using
php artisan vendor:publish --tag="bastion-views"
Usage
A super admin role may be defined by using the ->superAdminRole
method on the plugin.
$panel ->plugins([ // ... Other Plugins \ChrisReedIO\Bastion\BastionPlugin::make() ->superAdminRole('Developer'), ])
Testing
composer test
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
Special thanks to @Althinect and @bezhanSalleh for their packages and hard work. This is both inspired by and based on their work. This package would not be possible without them.
License
The MIT License (MIT). Please see License File for more information.