Agregar botones de debug temporales para gestión de BD
All checks were successful
build-and-deploy / build-and-deploy (push) Successful in 16s
All checks were successful
build-and-deploy / build-and-deploy (push) Successful in 16s
⚠️ CÓDIGO TEMPORAL - NO ELIMINAR SIN CONSULTAR ⚠️ Backend: - POST /api/debug/reset-database - Borra todos los datos - POST /api/debug/seed-database - Carga datos de ejemplo Frontend: - Card rojo con advertencias notorias - Botones: 🗑️ BORRAR TODA LA BD y 🌱 CARGAR DATOS DE EJEMPLO - Confirmación antes de resetear - Estados de loading - Alertas de éxito/error Todos los archivos marcados con comentarios muy visibles: ⚠️⚠️⚠️ NO ELIMINAR SIN CONSULTAR A DARIO/DRAGANEL/NUCLEO000 ⚠️⚠️⚠️ Útil para desarrollo y debugging del sistema de trazabilidad.
This commit is contained in:
52
nuxt4/server/api/debug/reset-database.post.ts
Normal file
52
nuxt4/server/api/debug/reset-database.post.ts
Normal file
@@ -0,0 +1,52 @@
|
||||
/**
|
||||
* ⚠️ ⚠️ ⚠️ ENDPOINT DE DEBUG - TEMPORAL ⚠️ ⚠️ ⚠️
|
||||
*
|
||||
* POST /api/debug/reset-database
|
||||
*
|
||||
* BORRA COMPLETAMENTE TODOS LOS DATOS DE LA BASE DE DATOS
|
||||
*
|
||||
* ⚠️ NO ELIMINAR SIN CONSULTAR A DARIO/DRAGANEL/NUCLEO000 ⚠️
|
||||
*
|
||||
* Este endpoint fue creado para desarrollo y debugging.
|
||||
* Antes de eliminarlo, preguntar si todavía es necesario.
|
||||
*/
|
||||
|
||||
import { query, getClient } from '../../utils/db'
|
||||
|
||||
export default defineEventHandler(async (event) => {
|
||||
try {
|
||||
console.log('⚠️ RESET DATABASE - Borrando todos los datos...')
|
||||
|
||||
const client = await getClient()
|
||||
|
||||
try {
|
||||
await client.query('BEGIN')
|
||||
|
||||
// Truncar todas las tablas en orden
|
||||
await client.query('TRUNCATE TABLE operacion_lotes CASCADE')
|
||||
await client.query('TRUNCATE TABLE operaciones CASCADE')
|
||||
await client.query('TRUNCATE TABLE lotes CASCADE')
|
||||
|
||||
await client.query('COMMIT')
|
||||
|
||||
console.log('✅ Base de datos reseteada exitosamente')
|
||||
|
||||
return {
|
||||
success: true,
|
||||
message: 'Base de datos reseteada. Todas las tablas están vacías.',
|
||||
}
|
||||
} catch (error) {
|
||||
await client.query('ROLLBACK')
|
||||
throw error
|
||||
} finally {
|
||||
client.release()
|
||||
}
|
||||
} catch (error: any) {
|
||||
console.error('❌ Error reseteando base de datos:', error)
|
||||
throw createError({
|
||||
statusCode: 500,
|
||||
statusMessage: 'Error reseteando base de datos',
|
||||
data: { message: error.message },
|
||||
})
|
||||
}
|
||||
})
|
||||
Reference in New Issue
Block a user