add: migración para roles y permisos
This commit is contained in:
parent
04c9fe2d5a
commit
2717176373
1564
composer.lock
generated
1564
composer.lock
generated
File diff suppressed because it is too large
Load Diff
@ -0,0 +1,61 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
use Database\Seeders\RoleSeeder;
|
||||||
|
use Illuminate\Database\Migrations\Migration;
|
||||||
|
use Illuminate\Support\Facades\DB;
|
||||||
|
|
||||||
|
return new class extends Migration
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* Run the migrations.
|
||||||
|
*/
|
||||||
|
public function up(): void
|
||||||
|
{
|
||||||
|
// Guardar las asignaciones actuales de usuarios a roles (con nombres de roles)
|
||||||
|
$userRoleAssignments = DB::table('model_has_roles')
|
||||||
|
->join('roles', 'model_has_roles.role_id', '=', 'roles.id')
|
||||||
|
->select('model_has_roles.model_id', 'model_has_roles.model_type', 'roles.name as role_name')
|
||||||
|
->get()
|
||||||
|
->toArray();
|
||||||
|
|
||||||
|
// Desactivar temporalmente las verificaciones de foreign keys
|
||||||
|
DB::statement('SET FOREIGN_KEY_CHECKS=0;');
|
||||||
|
|
||||||
|
// Eliminar datos de las tablas de Spatie en orden (por las foreign keys)
|
||||||
|
DB::table('model_has_roles')->truncate();
|
||||||
|
DB::table('model_has_permissions')->truncate();
|
||||||
|
DB::table('role_has_permissions')->truncate();
|
||||||
|
DB::table('permissions')->truncate();
|
||||||
|
DB::table('roles')->truncate();
|
||||||
|
DB::table('permission_types')->truncate();
|
||||||
|
|
||||||
|
// Reactivar las verificaciones de foreign keys
|
||||||
|
DB::statement('SET FOREIGN_KEY_CHECKS=1;');
|
||||||
|
|
||||||
|
// Resembrar roles y permisos
|
||||||
|
$seeder = new RoleSeeder();
|
||||||
|
$seeder->run();
|
||||||
|
|
||||||
|
// Restaurar las asignaciones de usuarios a roles
|
||||||
|
foreach ($userRoleAssignments as $assignment) {
|
||||||
|
$newRole = DB::table('roles')->where('name', $assignment->role_name)->first();
|
||||||
|
|
||||||
|
if ($newRole) {
|
||||||
|
DB::table('model_has_roles')->insert([
|
||||||
|
'role_id' => $newRole->id,
|
||||||
|
'model_type' => $assignment->model_type,
|
||||||
|
'model_id' => $assignment->model_id,
|
||||||
|
]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Reverse the migrations.
|
||||||
|
*/
|
||||||
|
public function down(): void
|
||||||
|
{
|
||||||
|
// No se puede revertir la eliminación de datos sin un backup
|
||||||
|
// Si necesitas revertir, restaura desde un backup de la base de datos
|
||||||
|
}
|
||||||
|
};
|
||||||
Loading…
x
Reference in New Issue
Block a user