Initial commit
This commit is contained in:
154
database/seeders/PermissionRoleSeeder.php
Normal file
154
database/seeders/PermissionRoleSeeder.php
Normal file
@@ -0,0 +1,154 @@
|
||||
<?php
|
||||
|
||||
namespace Database\Seeders;
|
||||
|
||||
use Illuminate\Database\Seeder;
|
||||
use Illuminate\Support\Facades\DB;
|
||||
use Spatie\Permission\Models\Permission;
|
||||
use Spatie\Permission\Models\Role;
|
||||
use Spatie\Permission\PermissionRegistrar;
|
||||
|
||||
class PermissionRoleSeeder extends Seeder
|
||||
{
|
||||
/**
|
||||
* Create the initial roles and permissions.
|
||||
* To re-seed this PermissionRoleSeeder after any changes use:
|
||||
* php artisan db:seed --class=PermissionRoleSeeder
|
||||
*
|
||||
* @return void
|
||||
*/
|
||||
public function run()
|
||||
{
|
||||
// Reset cached roles and permissions
|
||||
app()[PermissionRegistrar::class]->forgetCachedPermissions();
|
||||
|
||||
// Disable foreign key constraints
|
||||
DB::statement('SET FOREIGN_KEY_CHECKS=0;');
|
||||
|
||||
// Truncate the tables in case you are re-seeding
|
||||
DB::table('role_has_permissions')->truncate();
|
||||
DB::table('roles')->truncate();
|
||||
DB::table('permissions')->truncate();
|
||||
// Comment line below to preserve the existing roles attached to the models
|
||||
//DB::table('model_has_roles')->truncate();
|
||||
// Comment line below to preserve the existing permissions attached to the models
|
||||
//DB::table('model_has_permissions')->truncate();
|
||||
|
||||
// Re-enable foreign key constraints
|
||||
DB::statement('SET FOREIGN_KEY_CHECKS=1;');
|
||||
|
||||
// create permissions
|
||||
Permission::create(['name' => 'create posts']);
|
||||
Permission::create(['name' => 'update posts']);
|
||||
Permission::create(['name' => 'delete posts']);
|
||||
Permission::create(['name' => 'publish posts']);
|
||||
Permission::create(['name' => 'unpublish posts']);
|
||||
Permission::create(['name' => 'manage posts']); // all permissions regarding posts
|
||||
|
||||
Permission::create(['name' => 'create tags']);
|
||||
Permission::create(['name' => 'update tags']);
|
||||
Permission::create(['name' => 'delete tags']);
|
||||
Permission::create(['name' => 'manage tags']); // all permissions regarding tags
|
||||
|
||||
Permission::create(['name' => 'create categories']);
|
||||
Permission::create(['name' => 'update categories']);
|
||||
Permission::create(['name' => 'delete categories']);
|
||||
Permission::create(['name' => 'manage categories']); // all permissions regarding categories
|
||||
|
||||
Permission::create(['name' => 'create mailings']);
|
||||
Permission::create(['name' => 'update mailings']);
|
||||
Permission::create(['name' => 'delete mailings']);
|
||||
Permission::create(['name' => 'manage mailings']); // all permissions regarding mailings
|
||||
|
||||
Permission::create(['name' => 'create users']);
|
||||
Permission::create(['name' => 'update users']);
|
||||
Permission::create(['name' => 'delete users']);
|
||||
Permission::create(['name' => 'manage users']); // all permissions regarding users
|
||||
|
||||
Permission::create(['name' => 'create user_projects']);
|
||||
Permission::create(['name' => 'update user_projects']);
|
||||
Permission::create(['name' => 'delete user_projects']);
|
||||
Permission::create(['name' => 'manage user_projects']); // all permissions regarding user_projects
|
||||
|
||||
Permission::create(['name' => 'create organizations']);
|
||||
Permission::create(['name' => 'update organizations']);
|
||||
Permission::create(['name' => 'delete organizations']);
|
||||
Permission::create(['name' => 'manage organizations']); // all permissions regarding organizations
|
||||
|
||||
Permission::create(['name' => 'create banks']);
|
||||
Permission::create(['name' => 'update banks']);
|
||||
Permission::create(['name' => 'delete banks']);
|
||||
Permission::create(['name' => 'manage banks']); // all permissions regarding banks
|
||||
|
||||
Permission::create(['name' => 'create admins']);
|
||||
Permission::create(['name' => 'update admins']);
|
||||
Permission::create(['name' => 'delete admins']);
|
||||
Permission::create(['name' => 'manage admins']); // all permissions regarding admins
|
||||
|
||||
Permission::create(['name' => 'create accounts']);
|
||||
Permission::create(['name' => 'update accounts']);
|
||||
Permission::create(['name' => 'delete accounts']);
|
||||
Permission::create(['name' => 'manage accounts']); // all permissions regarding accounts
|
||||
|
||||
Permission::create(['name' => 'manage profiles']); // all permissions regarding all profiles (users, organizations, banks, admins)
|
||||
Permission::create(['name' => 'manage permissions']); // all permissions regarding permissions
|
||||
Permission::create(['name' => 'manage roles']); // all permissions regarding roles
|
||||
|
||||
// create roles and assign existing permissions
|
||||
$siteEditor = Role::create(['name' => 'site-editor']);
|
||||
$siteEditor->givePermissionTo('manage posts');
|
||||
$siteEditor->givePermissionTo('manage tags');
|
||||
$siteEditor->givePermissionTo('manage categories');
|
||||
|
||||
$bankAdmin = Role::create(['name' => 'bank-manager']);
|
||||
$bankAdmin->givePermissionTo('manage users');
|
||||
$bankAdmin->givePermissionTo('manage user_projects');
|
||||
$bankAdmin->givePermissionTo('manage organizations');
|
||||
$bankAdmin->givePermissionTo('manage accounts');
|
||||
|
||||
$admin = Role::create(['name' => 'admin']);
|
||||
$admin->givePermissionTo('manage posts');
|
||||
$admin->givePermissionTo('manage tags');
|
||||
$admin->givePermissionTo('manage categories');
|
||||
$admin->givePermissionTo('manage mailings');
|
||||
$admin->givePermissionTo('manage users');
|
||||
$admin->givePermissionTo('manage user_projects');
|
||||
$admin->givePermissionTo('manage organizations');
|
||||
$admin->givePermissionTo('manage banks');
|
||||
$admin->givePermissionTo('manage admins');
|
||||
$admin->givePermissionTo('manage profiles');
|
||||
$admin->givePermissionTo('manage accounts');
|
||||
$admin->givePermissionTo('manage permissions');
|
||||
$admin->givePermissionTo('manage roles');
|
||||
|
||||
|
||||
$organizationCoordinator = Role::create(['name' => 'organization-coordinator']);
|
||||
$organizationCoordinator->givePermissionTo('manage organizations');
|
||||
|
||||
$bankCoordinator = Role::create(['name' => 'bank-coordinator']);
|
||||
$bankCoordinator->givePermissionTo('manage banks');
|
||||
|
||||
$superAdmin = Role::create(['name' => 'super-admin']);
|
||||
// Gets all permissions via Gate::before rule; see AuthServiceProvider
|
||||
|
||||
|
||||
// // create demo users
|
||||
// $user = \App\Models\User::factory()->create([
|
||||
// 'name' => 'Example User',
|
||||
// 'email' => 'test@example.com',
|
||||
// ]);
|
||||
// $user->assignRole($siteEditor);
|
||||
|
||||
// $user = \App\Models\User::factory()->create([
|
||||
// 'name' => 'Example Admin User',
|
||||
// 'email' => 'admin@example.com',
|
||||
// ]);
|
||||
// $user->assignRole($bankAdmin);
|
||||
|
||||
// $user = \App\Models\User::factory()->create([
|
||||
// 'name' => 'Example Super-Admin User',
|
||||
// 'email' => 'superadmin@example.com',
|
||||
// ]);
|
||||
// $user->assignRole($role3);
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user