Penambahan Seeder

- Add Initial Permission Group
- Add Initial Role
- Add Initial Permission
- Add Initial Users
This commit is contained in:
Daeng Deni Mardaeni
2024-10-27 15:44:29 +07:00
parent cbe8989e0e
commit 849509b441
5 changed files with 177 additions and 1 deletions

View File

@@ -0,0 +1,40 @@
<?php
namespace Modules\Usermanagement\Database\Seeders;
use Illuminate\Database\Seeder;
use Illuminate\Support\Str;
use Modules\Usermanagement\Models\PermissionGroup;
class PermissionGroupSeeder extends Seeder
{
/**
* Run the database seeds.
*
* @return void
*/
public function run()
{
$data = $this->data();
foreach ($data as $value) {
PermissionGroup::updateOrCreate([
'name' => $value['name'],
'slug' => Str::slug($value['name'])
]);
}
}
public function data()
{
return [
['name' => 'usermanagement'],
['name' => 'basic-data'],
['name' => 'permohonan'],
['name' => 'admin'],
['name' => 'senior-officer'],
['name' => 'penilai'],
['name' => 'surveyor']
];
}
}

View File

@@ -0,0 +1,65 @@
<?php
namespace Modules\Usermanagement\Database\Seeders;
use Illuminate\Database\Seeder;
use Modules\Usermanagement\Models\PermissionGroup;
use Spatie\Permission\Models\Permission;
use Spatie\Permission\Models\Role;
class PermissionsSeeder extends Seeder
{
/**
* Run the database seeds.
*
* @return void
*/
public function run()
{
$data = $this->data();
foreach ($data as $value) {
$permission = Permission::updateOrCreate([
'name' => $value['name'],
'guard_name' => 'web' // or 'api
], [
'permission_group_id' => $value['group']
]);
$roles = Role::all();
foreach ($roles as $role) {
$role->givePermissionTo($permission);
}
}
}
public function data()
{
$data = [];
// list of model permission
$groups = PermissionGroup::all();
foreach ($groups as $group) {
foreach ($this->crudActions($group->name) as $action) {
$data[] = ['name' => $action, 'group' => $group->id];
}
}
return $data;
}
public function crudActions($name)
{
$actions = [];
// list of permission actions
$crud = ['create', 'read', 'update', 'delete','export', 'authorize', 'report'];
foreach ($crud as $value) {
$actions[] = $name . '.' . $value;
}
return $actions;
}
}

View File

@@ -0,0 +1,33 @@
<?php
namespace Modules\Usermanagement\Database\Seeders;
use Illuminate\Database\Seeder;
use Spatie\Permission\Models\Role;
class RolesSeeder extends Seeder
{
/**
* Run the database seeds.
*
* @return void
*/
public function run()
{
$data = $this->data();
foreach ($data as $value) {
Role::create([
'name' => $value['name'],
'guard_name' => 'web',
]);
}
}
public function data()
{
return [
['name' => 'administrator']
];
}
}

View File

@@ -11,6 +11,11 @@ class UsermanagementDatabaseSeeder extends Seeder
*/
public function run(): void
{
// $this->call([]);
$this->call([
PermissionGroupSeeder::class,
RolesSeeder::class,
PermissionsSeeder::class,
UsersSeeder::class,
]);
}
}

View File

@@ -0,0 +1,33 @@
<?php
namespace Modules\Usermanagement\Database\Seeders;
use Faker\Generator;
use Illuminate\Database\Seeder;
use Illuminate\Support\Facades\Hash;
use Modules\Usermanagement\Models\User;
use Spatie\Permission\Models\Role;
class UsersSeeder extends Seeder
{
/**
* Run the database seeds.
*
* @return void
*/
public function run(Generator $faker)
{
$roles = Role::all();
foreach ($roles as $role) {
$user = User::create([
'name' => $role->name,
'email' => $role->name . '@lpj.id',
'password' => Hash::make('lpj'),
'email_verified_at' => now(),
]);
$user->assignRole($role);
}
}
}