codigo0/backend/dist/config/database.js
planetazuzu 5d7a6500fe refactor: Fase 1 - Clean Architecture, refactorización modular y eliminación de duplicidades
-  Ticket 1.1: Estructura Clean Architecture en backend
-  Ticket 1.2: Schemas Zod compartidos
-  Ticket 1.3: Refactorización drugs.ts (1362 → 8 archivos modulares)
-  Ticket 1.4: Refactorización procedures.ts (3583 → 6 archivos modulares)
-  Ticket 1.5: Eliminación de duplicidades (~50 líneas)

Cambios principales:
- Creada estructura Clean Architecture en backend/src/
- Schemas Zod compartidos en backend/src/shared/schemas/
- Refactorización modular de drugs y procedures
- Utilidades genéricas en src/utils/ (filter, validation)
- Eliminados scripts obsoletos y documentación antigua
- Corregidos errores: QueryClient, import test-error-handling
- Build verificado y funcionando correctamente
2026-01-25 21:09:47 +01:00

53 lines
1.4 KiB
JavaScript

/**
* Configuración de conexión a PostgreSQL
*
* FASE 1: Infraestructura Base
*
* IMPORTANTE: Usar variables de entorno para credenciales
*/
import pg from 'pg';
import dotenv from 'dotenv';
dotenv.config();
const { Pool } = pg;
/**
* Pool de conexiones a PostgreSQL
*/
export const pool = new Pool({
host: process.env.DB_HOST || 'localhost',
port: parseInt(process.env.DB_PORT || '5432', 10),
database: process.env.DB_NAME || 'emerges_tes',
user: process.env.DB_USER || 'postgres',
password: process.env.DB_PASSWORD || '',
max: 20, // Máximo de conexiones en el pool
idleTimeoutMillis: 30000,
connectionTimeoutMillis: 2000,
});
/**
* Test de conexión
*/
export async function testConnection() {
try {
const result = await pool.query('SELECT NOW()');
console.log('✅ Conexión a PostgreSQL exitosa:', result.rows[0].now);
return true;
}
catch (error) {
const errorMessage = error instanceof Error ? error.message : 'Unknown error';
console.error('❌ Error conectando a PostgreSQL:', errorMessage);
return false;
}
}
/**
* Función helper para ejecutar queries
* Envuelve pool.query para mantener compatibilidad
*/
export async function query(text, params) {
return await pool.query(text, params);
}
/**
* Cerrar pool de conexiones
*/
export async function closePool() {
await pool.end();
}
//# sourceMappingURL=database.js.map