Initial commit
This commit is contained in:
92
database/seeders/AdvancedPermissionsSeeder.php
Normal file
92
database/seeders/AdvancedPermissionsSeeder.php
Normal file
@@ -0,0 +1,92 @@
|
||||
<?php
|
||||
|
||||
namespace Database\Seeders;
|
||||
|
||||
use Illuminate\Database\Console\Seeds\WithoutModelEvents;
|
||||
use Illuminate\Database\Seeder;
|
||||
use Spatie\Permission\Models\Permission;
|
||||
use Spatie\Permission\Models\Role;
|
||||
|
||||
class AdvancedPermissionsSeeder extends Seeder
|
||||
{
|
||||
/**
|
||||
* Run the database seeds.
|
||||
*/
|
||||
public function run(): void
|
||||
{
|
||||
// Create advanced document feature permissions
|
||||
$permissions = [
|
||||
[
|
||||
'name' => 'manage_system_settings',
|
||||
'description' => 'Access and modify system settings pages'
|
||||
],
|
||||
[
|
||||
'name' => 'use_bulk_import',
|
||||
'description' => 'Use document bulk import feature'
|
||||
],
|
||||
[
|
||||
'name' => 'use_qr_codes',
|
||||
'description' => 'Generate QR codes for documents'
|
||||
],
|
||||
[
|
||||
'name' => 'view_document_statistics',
|
||||
'description' => 'Access document statistics dashboard'
|
||||
],
|
||||
[
|
||||
'name' => 'manage_document_tags',
|
||||
'description' => 'Create, edit, and delete document tags'
|
||||
],
|
||||
[
|
||||
'name' => 'manage_document_expiration',
|
||||
'description' => 'Set expiration dates and configure auto-archive rules'
|
||||
],
|
||||
[
|
||||
'name' => 'export_documents',
|
||||
'description' => 'Export document lists and reports'
|
||||
],
|
||||
];
|
||||
|
||||
foreach ($permissions as $permissionData) {
|
||||
Permission::firstOrCreate(
|
||||
['name' => $permissionData['name']],
|
||||
['guard_name' => 'web']
|
||||
);
|
||||
}
|
||||
|
||||
// Assign all advanced permissions to 'admin' role
|
||||
$adminRole = Role::where('name', 'admin')->first();
|
||||
|
||||
if ($adminRole) {
|
||||
foreach ($permissions as $permissionData) {
|
||||
$permission = Permission::where('name', $permissionData['name'])->first();
|
||||
if ($permission && !$adminRole->hasPermissionTo($permission)) {
|
||||
$adminRole->givePermissionTo($permission);
|
||||
}
|
||||
}
|
||||
|
||||
$this->command->info('Advanced permissions assigned to admin role');
|
||||
}
|
||||
|
||||
// Optionally assign some permissions to 'staff' role
|
||||
$staffRole = Role::where('name', 'staff')->first();
|
||||
|
||||
if ($staffRole) {
|
||||
$staffPermissions = [
|
||||
'use_qr_codes',
|
||||
'view_document_statistics',
|
||||
'export_documents',
|
||||
];
|
||||
|
||||
foreach ($staffPermissions as $permissionName) {
|
||||
$permission = Permission::where('name', $permissionName)->first();
|
||||
if ($permission && !$staffRole->hasPermissionTo($permission)) {
|
||||
$staffRole->givePermissionTo($permission);
|
||||
}
|
||||
}
|
||||
|
||||
$this->command->info('Selected permissions assigned to staff role');
|
||||
}
|
||||
|
||||
$this->command->info('Advanced permissions seeded successfully');
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user