codigo0/backend/crear-usuario-y-bd.sh
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

55 lines
1.6 KiB
Bash
Executable file

#!/bin/bash
# Script para crear usuario y base de datos PostgreSQL
# Ejecutar: bash crear-usuario-y-bd.sh
echo "🔧 Creando usuario y base de datos PostgreSQL..."
echo ""
# Copiar SQL a /tmp para que postgres pueda acceder
cat > /tmp/create-user-emerges.sql << 'SQL'
-- Crear usuario si no existe
DO $$
BEGIN
IF NOT EXISTS (SELECT FROM pg_user WHERE usename = '${DB_USER:-planetazuzu}') THEN
CREATE USER ${DB_USER:-planetazuzu} WITH PASSWORD '${DB_PASSWORD}';
RAISE NOTICE 'Usuario ${DB_USER:-planetazuzu} creado';
ELSE
RAISE NOTICE 'Usuario ${DB_USER:-planetazuzu} ya existe';
ALTER USER ${DB_USER:-planetazuzu} WITH PASSWORD '${DB_PASSWORD}';
END IF;
END
$$;
-- Crear base de datos si no existe
SELECT 'CREATE DATABASE emerges_tes OWNER planetazuzu'
WHERE NOT EXISTS (SELECT FROM pg_database WHERE datname = 'emerges_tes')\gexec
-- Dar permisos
GRANT ALL PRIVILEGES ON DATABASE emerges_tes TO planetazuzu;
-- Conectar a la base de datos y dar permisos en el esquema
\c emerges_tes
-- Crear esquema si no existe
CREATE SCHEMA IF NOT EXISTS emerges_content;
-- Dar permisos en el esquema
GRANT ALL ON SCHEMA emerges_content TO planetazuzu;
ALTER DEFAULT PRIVILEGES IN SCHEMA emerges_content GRANT ALL ON TABLES TO planetazuzu;
ALTER DEFAULT PRIVILEGES IN SCHEMA emerges_content GRANT ALL ON SEQUENCES TO planetazuzu;
\q
SQL
# Ejecutar con sudo
echo "Ejecutando SQL (requiere contraseña de sudo)..."
sudo -u postgres psql -f /tmp/create-user-emerges.sql
# Limpiar
rm -f /tmp/create-user-emerges.sql
echo ""
echo "✅ Proceso completado"
echo ""
echo "Verificar con: cd backend && npm run verify"