Agregar botones de debug temporales para gestión de BD
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:
2025-11-21 19:43:04 -06:00
parent 0f8891f77d
commit 3a1c3fb7a2
3 changed files with 202 additions and 0 deletions

View 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 },
})
}
})