Phase 1-14 complete: - Unified Express.js API (TypeScript, Prisma ORM, PostgreSQL 16) - React Admin GUI (Vite + Ant Design + Zustand) - JWT auth with refresh tokens - Influence: Campaigns, Representatives, Responses, Email Queue - Map: Locations, Cuts, Shifts, Canvassing System - NAR data import infrastructure (2025 format) - Listmonk newsletter integration - Landing page builder (GrapesJS) - MkDocs + Code Server integration - Volunteer portal with GPS tracking - Monitoring stack (Prometheus, Grafana, Alertmanager) - Pangolin tunnel integration Co-Authored-By: Claude Sonnet 4.5 <noreply@anthropic.com>
25 lines
884 B
JavaScript
25 lines
884 B
JavaScript
const express = require('express');
|
|
const router = express.Router();
|
|
const authController = require('../controllers/authController');
|
|
const passwordRecoveryController = require('../controllers/passwordRecoveryController');
|
|
const { authLimiter } = require('../middleware/rateLimiter');
|
|
const config = require('../config');
|
|
|
|
// Login route with rate limiting
|
|
router.post('/login', authLimiter, authController.login);
|
|
|
|
// Debug login route without rate limiting (only in development or for testing)
|
|
if (!config.isProduction) {
|
|
router.post('/debug-login', authController.login);
|
|
}
|
|
|
|
// Password recovery route with rate limiting
|
|
router.post('/recover-password', authLimiter, passwordRecoveryController.requestPassword);
|
|
|
|
// Logout route
|
|
router.post('/logout', authController.logout);
|
|
|
|
// Check authentication status
|
|
router.get('/check', authController.check);
|
|
|
|
module.exports = router; |