✅ FASE 1 COMPLETADA: Fundamentos y Core del Backend
- API REST completa con Node.js + Express + TypeScript - Autenticación JWT con roles (Player/Admin) - CRUD completo de canchas - Sistema de reservas con validaciones - Base de datos SQLite con Prisma ORM - Notificaciones por email (Nodemailer) - Seed de datos de prueba - Documentación de arquitectura Endpoints implementados: - Auth: register, login, refresh, me - Courts: CRUD + disponibilidad - Bookings: CRUD + confirmación/cancelación Credenciales de prueba: - admin@padel.com / admin123 - user@padel.com / user123
This commit is contained in:
35
backend/.env.example
Normal file
35
backend/.env.example
Normal file
@@ -0,0 +1,35 @@
|
||||
# ============================================
|
||||
# Configuración de la Base de Datos
|
||||
# ============================================
|
||||
DATABASE_URL="postgresql://postgres:password@localhost:5432/app_padel?schema=public"
|
||||
|
||||
# ============================================
|
||||
# Configuración del Servidor
|
||||
# ============================================
|
||||
NODE_ENV=development
|
||||
PORT=3000
|
||||
API_URL=http://localhost:3000
|
||||
FRONTEND_URL=http://localhost:5173
|
||||
|
||||
# ============================================
|
||||
# Configuración de JWT
|
||||
# ============================================
|
||||
JWT_SECRET=tu_clave_secreta_super_segura_cambiar_en_produccion
|
||||
JWT_EXPIRES_IN=7d
|
||||
JWT_REFRESH_SECRET=otra_clave_secreta_para_refresh_token
|
||||
JWT_REFRESH_EXPIRES_IN=30d
|
||||
|
||||
# ============================================
|
||||
# Configuración de Email (SMTP)
|
||||
# ============================================
|
||||
SMTP_HOST=smtp.gmail.com
|
||||
SMTP_PORT=587
|
||||
SMTP_USER=tu_email@gmail.com
|
||||
SMTP_PASS=tu_password_app
|
||||
EMAIL_FROM="Canchas Padel <noreply@tudominio.com>"
|
||||
|
||||
# ============================================
|
||||
# Configuración de Rate Limiting
|
||||
# ============================================
|
||||
RATE_LIMIT_WINDOW_MS=900000
|
||||
RATE_LIMIT_MAX_REQUESTS=100
|
||||
Reference in New Issue
Block a user