docs/installation-laravel.md
See the "Prerequisites" documentation page for compatibility details.
Consult the Prerequisites page for important considerations regarding your User models!
This package publishes a config/permission.php file. If you already have a file by that name, you must rename or remove it.
You can install the package via composer:
composer require spatie/laravel-permission
The Service Provider will automatically be registered; however, if you wish to manually register it, you can manually add the Spatie\Permission\PermissionServiceProvider::class service provider to the array in bootstrap/providers.php.
You should publish the migration and the config/permission.php config file with:
php artisan vendor:publish --provider="Spatie\Permission\PermissionServiceProvider"
BEFORE RUNNING MIGRATIONS
If you are using UUIDs, see the Advanced section of the docs on UUID steps, before you continue. It explains some changes you may want to make to the migrations and config file before continuing. It also mentions important considerations after extending this package's models for UUID capability.
If you are going to use the TEAMS features you must update your config/permission.php config file:
'teams' => true,team_foreign_key name in the config file if you want to use a custom foreign key in your database for teamsIf you are using MySQL 8+, look at the Prerequisites docs page for notes about MySQL 8+ to set/limit the index key length, and edit accordingly. If you get ERROR: 1071 Specified key was too long then you need to do this.
If you are using CACHE_STORE=database, be sure to install Laravel's cache migration, else you will encounter cache errors.
Clear your config cache. This package requires access to the permission config settings in order to run migrations. If you've been caching configurations locally, clear your config cache with either of these commands:
php artisan optimize:clear
# or
php artisan config:clear
Run the migrations: After the config and migration have been published and configured, you can create the tables for this package by running:
php artisan migrate
Add the necessary trait to your User model:
// The User model requires this trait
use HasRoles;
Consult the Basic Usage section of the docs to get started using the features of this package.
.
You can view the default config file contents at:
https://github.com/spatie/laravel-permission/blob/main/config/permission.php