You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
90 lines
2.6 KiB
90 lines
2.6 KiB
2 years ago
|
<?php
|
||
|
namespace Database\Seeders;
|
||
|
|
||
|
use Illuminate\Database\Seeder;
|
||
|
use Itstructure\LaRbac\Models\{Role, Permission};
|
||
|
|
||
|
/**
|
||
|
* Class RoleSeeder
|
||
|
*
|
||
|
* @author Andrey Girnik <girnikandrey@gmail.com>
|
||
|
*/
|
||
|
class RoleSeeder extends Seeder
|
||
|
{
|
||
|
/**
|
||
|
* Run the database seeds.
|
||
|
* @return void
|
||
|
*/
|
||
|
public function run()
|
||
|
{
|
||
|
$totalPermissionId = Permission::where('slug', Permission::ADMINISTRATE_PERMISSION)->firstOrFail()->id;
|
||
|
$viewPermissionId = Permission::where('slug', Permission::VIEW_RECORD_PERMISSION)->firstOrFail()->id;
|
||
|
$createPermissionId = Permission::where('slug', Permission::CREATE_RECORD_PERMISSION)->firstOrFail()->id;
|
||
|
$updatePermissionId = Permission::where('slug', Permission::UPDATE_RECORD_PERMISSION)->firstOrFail()->id;
|
||
|
$deletePermissionId = Permission::where('slug', Permission::DELETE_RECORD_PERMISSION)->firstOrFail()->id;
|
||
|
$publishPermissionId = Permission::where('slug', Permission::PUBLISH_RECORD_PERMISSION)->firstOrFail()->id;
|
||
|
|
||
|
$this->createRecord(
|
||
|
Role::ADMIN_ROLE,
|
||
|
'Administrator',
|
||
|
[
|
||
|
$totalPermissionId,
|
||
|
$viewPermissionId,
|
||
|
$createPermissionId,
|
||
|
$updatePermissionId,
|
||
|
$deletePermissionId,
|
||
|
$publishPermissionId
|
||
|
]
|
||
|
);
|
||
|
|
||
|
$this->createRecord(
|
||
|
Role::MANAGER_ROLE,
|
||
|
'Content manager',
|
||
|
[
|
||
|
$viewPermissionId,
|
||
|
$createPermissionId,
|
||
|
$updatePermissionId,
|
||
|
$deletePermissionId,
|
||
|
$publishPermissionId
|
||
|
]
|
||
|
);
|
||
|
|
||
|
$this->createRecord(
|
||
|
Role::EDITOR_ROLE,
|
||
|
'Record editor',
|
||
|
[
|
||
|
$viewPermissionId,
|
||
|
$createPermissionId,
|
||
|
$updatePermissionId,
|
||
|
$deletePermissionId,
|
||
|
$publishPermissionId
|
||
|
]
|
||
|
);
|
||
|
|
||
|
$this->createRecord(
|
||
|
Role::USER_ROLE,
|
||
|
'Simple user',
|
||
|
[
|
||
|
$viewPermissionId
|
||
|
]
|
||
|
);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Create role record in database.
|
||
|
* @param string $slug
|
||
|
* @param string $description
|
||
|
* @param array $permissions
|
||
|
* @return void
|
||
|
*/
|
||
|
private function createRecord(string $slug, string $description, array $permissions): void
|
||
|
{
|
||
|
Role::create([
|
||
|
'name' => ucfirst($slug),
|
||
|
'slug' => $slug,
|
||
|
'description' => $description,
|
||
|
])->permissions()
|
||
|
->attach($permissions);
|
||
|
}
|
||
|
}
|