forgetCachedPermissions(); /*$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) { if ($role->name == 'administrator') { $role->givePermissionTo($permission); } else { if ($permission->name == 'user.read' || $permission->name == 'role.read' || $permission->name == 'permission.read') { $role->givePermissionTo($permission); } } } }*/ $roles = Role::all(); foreach ($roles as $role) { $data = $this->data($role->name); foreach ($data as $value) { $permission = Permission::updateOrCreate([ 'name' => $value['name'], 'guard_name' => 'web' // or 'api ], [ 'permission_group_id' => $value['group'] ]); if($role->name=='ao' && explode('.',$value['name'])[0]=='document'){ if($permission->name=='document.read'){ $role->givePermissionTo($permission); } } else{ $role->givePermissionTo($permission); } } } } public function data($role) { $data = []; // list of model permission if($role == 'administrator'){ $model = ['user', 'role', 'permission','system','master','document','setting','Logs']; } elseif($role == 'ad'){ $model = ['system','document','setting','Logs']; } elseif($role == 'dd'){ $model = ['system','master','document','setting']; } elseif($role == 'eo'){ $model = ['document']; } $i = 1; foreach ($model as $value) { foreach ($this->crudActions($value) as $action) { $data[] = ['name' => $action, 'group' => $i]; } $i++; } return $data; } public function crudActions($name) { $actions = []; // list of permission actions $crud = ['create', 'read', 'update', 'delete','authorize','report']; foreach ($crud as $value) { $actions[] = $name . '.' . $value; } return $actions; } }