Files
ficheagent/database/seeders/SaaSTenantSeeder.php

47 lines
1.5 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;
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'];
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]
);
$this->command->info('Migration vers le mode SaaS terminée. Structure par défaut : CABM.');
}
}