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>
22 lines
1.0 KiB
JavaScript
22 lines
1.0 KiB
JavaScript
const express = require('express');
|
|
const router = express.Router();
|
|
const locationsController = require('../controllers/locationsController');
|
|
const { strictLimiter, conditionalTempLimiter } = require('../middleware/rateLimiter');
|
|
const { requireAuth, requireDeletePermission } = require('../middleware/auth');
|
|
|
|
// Get all locations (apply stricter rate limiting for temp users)
|
|
router.get('/', conditionalTempLimiter, locationsController.getAll);
|
|
|
|
// Get single location (apply stricter rate limiting for temp users)
|
|
router.get('/:id', conditionalTempLimiter, locationsController.getById);
|
|
|
|
// Create location (requires authentication)
|
|
router.post('/', requireAuth, strictLimiter, locationsController.create);
|
|
|
|
// Update location (requires authentication)
|
|
router.put('/:id', requireAuth, strictLimiter, locationsController.update);
|
|
|
|
// Delete location (requires authentication and delete permission)
|
|
router.delete('/:id', requireAuth, requireDeletePermission, strictLimiter, locationsController.delete);
|
|
|
|
module.exports = router; |