63 lines
2.1 KiB
PHP
63 lines
2.1 KiB
PHP
<?php
|
|
|
|
namespace Database\Seeders;
|
|
|
|
use App\Models\Structure;
|
|
use App\Models\User;
|
|
use App\Models\Role;
|
|
use Illuminate\Database\Seeder;
|
|
use Illuminate\Support\Facades\Hash;
|
|
use Illuminate\Support\Facades\DB;
|
|
use Illuminate\Support\Facades\Schema;
|
|
|
|
class SaaSTenantSeeder extends Seeder
|
|
{
|
|
/**
|
|
* Run the database seeds.
|
|
*/
|
|
public function run(): void
|
|
{
|
|
// 1. Créer la structure principale (votre agence CABM par défaut)
|
|
$cabm = Structure::firstOrCreate([
|
|
'slug' => 'cabm'
|
|
], [
|
|
'name' => 'CABM',
|
|
'is_active' => true,
|
|
]);
|
|
|
|
// 2. Mettre à jour tous les agents orphelins vers cette structure
|
|
DB::table('agents')->whereNull('structure_id')->update(['structure_id' => $cabm->id]);
|
|
|
|
// 3. Mettre à jour tous les services, templates, users, etc. vers cette structure
|
|
$tables = ['services', 'integration_templates', 'integration_requests', 'users', 'service_tasks', 'comments'];
|
|
foreach ($tables as $table) {
|
|
if (Schema::hasColumn($table, 'structure_id')) {
|
|
DB::table($table)->whereNull('structure_id')->update(['structure_id' => $cabm->id]);
|
|
}
|
|
}
|
|
|
|
// 4. S'assurer que le rôle SuperAdmin existe globalement
|
|
$superAdminRole = Role::withoutGlobalScope('structure')->updateOrCreate(
|
|
['name' => 'SuperAdmin'],
|
|
['guard_name' => 'web', 'structure_id' => null]
|
|
);
|
|
|
|
// 5. Créer l'utilisateur Admin par défaut s'il n'existe pas
|
|
$admin = User::withoutGlobalScope('structure')->firstOrCreate(
|
|
['email' => 'admin@admin.com'],
|
|
[
|
|
'name' => 'Super Admin',
|
|
'password' => Hash::make('password'),
|
|
'structure_id' => $cabm->id
|
|
]
|
|
);
|
|
|
|
// Lui assigner le rôle SuperAdmin
|
|
if (!$admin->hasRole('SuperAdmin')) {
|
|
$admin->assignRole($superAdminRole);
|
|
}
|
|
|
|
$this->command->info('Migration vers le mode SaaS terminée. Structure par défaut : CABM.');
|
|
}
|
|
}
|