93 lines
3.0 KiB
PHP
93 lines
3.0 KiB
PHP
<?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');
|
|
}
|
|
}
|