feat(usermanagement): fix permission seeder structure and ensure module column populated correctly

- Updated PermissionGroupSeeder to seed consistent permission group definitions
- Updated PermissionsSeeder to generate proper permission records with correct module mapping
- Ensured permission creation uses dynamically generated module value based on group name
- Fixed undefined array key "module" issue by restructuring data() output
- Applied permission assignment to all roles for each generated permission
- Improved overall seeder stability and idempotency

To apply the updates, run the following commands:

php artisan module:seed Usermanagement --class="PermissionGroupSeeder"
php artisan module:seed Usermanagement --class="PermissionsSeeder"
This commit is contained in:
Sholahuddin Al Ayubi
2025-12-03 18:28:51 +07:00
parent 4270f152d2
commit f3872e0665
2 changed files with 56 additions and 54 deletions

View File

@@ -28,6 +28,10 @@
public function data() public function data()
{ {
return [ return [
['name' => 'adk'],
['name' => 'basicdata'],
['name' => 'location'],
['name' => 'logs'],
['name' => 'usermanagement'] ['name' => 'usermanagement']
]; ];
} }

View File

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