198 lines
6.7 KiB
JavaScript

"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
exports.shiftsVolunteerRouter = exports.shiftsPublicRouter = exports.shiftsAdminRouter = void 0;
const express_1 = require("express");
const client_1 = require("@prisma/client");
const shifts_service_1 = require("./shifts.service");
const shifts_schemas_1 = require("./shifts.schemas");
const validate_1 = require("../../../middleware/validate");
const auth_middleware_1 = require("../../../middleware/auth.middleware");
const rbac_middleware_1 = require("../../../middleware/rbac.middleware");
const rate_limit_1 = require("../../../middleware/rate-limit");
const MAP_ADMIN_ROLES = [client_1.UserRole.SUPER_ADMIN, client_1.UserRole.MAP_ADMIN];
// --- Admin Router ---
const adminRouter = (0, express_1.Router)();
exports.shiftsAdminRouter = adminRouter;
adminRouter.use(auth_middleware_1.authenticate);
adminRouter.use((0, rbac_middleware_1.requireRole)(...MAP_ADMIN_ROLES));
// GET /api/map/shifts — list paginated
adminRouter.get('/', (0, validate_1.validate)(shifts_schemas_1.listShiftsSchema, 'query'), async (req, res, next) => {
try {
const result = await shifts_service_1.shiftsService.findAll(req.query);
res.json(result);
}
catch (err) {
next(err);
}
});
// GET /api/map/shifts/stats — statistics
adminRouter.get('/stats', async (_req, res, next) => {
try {
const stats = await shifts_service_1.shiftsService.getStats();
res.json(stats);
}
catch (err) {
next(err);
}
});
// GET /api/map/shifts/calendar — calendar data
adminRouter.get('/calendar', async (req, res, next) => {
try {
const { startDate, endDate } = req.query;
if (!startDate || !endDate) {
return res.status(400).json({ error: 'startDate and endDate required' });
}
const data = await shifts_service_1.shiftsService.getCalendarData(startDate, endDate);
res.json(data);
}
catch (err) {
next(err);
}
});
// GET /api/map/shifts/:id — single shift with signups
adminRouter.get('/:id', async (req, res, next) => {
try {
const id = req.params.id;
const shift = await shifts_service_1.shiftsService.findById(id);
res.json(shift);
}
catch (err) {
next(err);
}
});
// POST /api/map/shifts — create
adminRouter.post('/', (0, validate_1.validate)(shifts_schemas_1.createShiftSchema), async (req, res, next) => {
try {
const shift = await shifts_service_1.shiftsService.create(req.body, req.user.id);
res.status(201).json(shift);
}
catch (err) {
next(err);
}
});
// PUT /api/map/shifts/:id — update
adminRouter.put('/:id', (0, validate_1.validate)(shifts_schemas_1.updateShiftSchema), async (req, res, next) => {
try {
const id = req.params.id;
const shift = await shifts_service_1.shiftsService.update(id, req.body);
res.json(shift);
}
catch (err) {
next(err);
}
});
// DELETE /api/map/shifts/:id — delete
adminRouter.delete('/:id', async (req, res, next) => {
try {
const id = req.params.id;
await shifts_service_1.shiftsService.delete(id);
res.status(204).send();
}
catch (err) {
next(err);
}
});
// POST /api/map/shifts/:id/signups — admin add volunteer
adminRouter.post('/:id/signups', (0, validate_1.validate)(shifts_schemas_1.addSignupSchema), async (req, res, next) => {
try {
const id = req.params.id;
const signup = await shifts_service_1.shiftsService.addSignup(id, req.body);
res.status(201).json(signup);
}
catch (err) {
next(err);
}
});
// DELETE /api/map/shifts/:id/signups/:signupId — admin remove volunteer
adminRouter.delete('/:id/signups/:signupId', async (req, res, next) => {
try {
const signupId = req.params.signupId;
await shifts_service_1.shiftsService.removeSignup(signupId);
res.status(204).send();
}
catch (err) {
next(err);
}
});
// POST /api/map/shifts/:id/email-details — email all volunteers
adminRouter.post('/:id/email-details', async (req, res, next) => {
try {
const id = req.params.id;
const result = await shifts_service_1.shiftsService.emailShiftDetails(id);
res.json(result);
}
catch (err) {
next(err);
}
});
// --- Volunteer Router ---
const volunteerRouter = (0, express_1.Router)();
exports.shiftsVolunteerRouter = volunteerRouter;
volunteerRouter.use(auth_middleware_1.authenticate);
// GET /api/map/shifts/volunteer/upcoming — upcoming shifts with signup status
volunteerRouter.get('/volunteer/upcoming', async (req, res, next) => {
try {
const shifts = await shifts_service_1.shiftsService.getUpcomingForVolunteer(req.user.id);
res.json(shifts);
}
catch (err) {
next(err);
}
});
// GET /api/map/shifts/volunteer/my-signups — own confirmed signups
volunteerRouter.get('/volunteer/my-signups', async (req, res, next) => {
try {
const signups = await shifts_service_1.shiftsService.getMySignups(req.user.id);
res.json(signups);
}
catch (err) {
next(err);
}
});
// POST /api/map/shifts/volunteer/:id/signup — sign up for shift
volunteerRouter.post('/volunteer/:id/signup', rate_limit_1.shiftSignupRateLimit, async (req, res, next) => {
try {
const id = req.params.id;
const signup = await shifts_service_1.shiftsService.volunteerSignup(id, req.user.id);
res.status(201).json(signup);
}
catch (err) {
next(err);
}
});
// DELETE /api/map/shifts/volunteer/:id/signup — cancel own signup
volunteerRouter.delete('/volunteer/:id/signup', async (req, res, next) => {
try {
const id = req.params.id;
await shifts_service_1.shiftsService.cancelVolunteerSignup(id, req.user.id);
res.status(204).send();
}
catch (err) {
next(err);
}
});
// --- Public Router ---
const publicRouter = (0, express_1.Router)();
exports.shiftsPublicRouter = publicRouter;
// GET /api/map/shifts/public — list upcoming public shifts
publicRouter.get('/public', async (_req, res, next) => {
try {
const shifts = await shifts_service_1.shiftsService.getPublicShifts();
res.json(shifts);
}
catch (err) {
next(err);
}
});
// POST /api/map/shifts/public/:id/signup — public signup
publicRouter.post('/public/:id/signup', rate_limit_1.shiftSignupRateLimit, (0, validate_1.validate)(shifts_schemas_1.publicSignupSchema), async (req, res, next) => {
try {
const id = req.params.id;
const result = await shifts_service_1.shiftsService.publicSignup(id, req.body);
res.status(201).json(result);
}
catch (err) {
next(err);
}
});
//# sourceMappingURL=shifts.routes.js.map