Backend: - monthly_work_confirmations 테이블 마이그레이션 - monthlyComparisonModel: 비교 쿼리 8개 (보고서/근태/확인 병렬 조회) - monthlyComparisonController: 5 API (my-records/records/confirm/all-status/export) - 일별 7상태 판정 (match/mismatch/report_only/attend_only/vacation/holiday/none) - 확인/반려 UPSERT + 반려 시 알림 (단일 트랜잭션) - 엑셀 2시트 (exceljs) + 헤더 스타일 + 불일치/휴가 행 색상 - support_team+ 권한 체크 (all-status, export) - exceljs 의존성 추가 Frontend: - monthly-comparison.js MOCK_ENABLED = false (API 연결) Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
33 lines
1.1 KiB
JavaScript
33 lines
1.1 KiB
JavaScript
const express = require('express');
|
|
const router = express.Router();
|
|
const ctrl = require('../controllers/monthlyComparisonController');
|
|
const { createRequirePage } = require('../../../shared/middleware/pagePermission');
|
|
const { getDb } = require('../dbPool');
|
|
const requirePage = createRequirePage(getDb);
|
|
|
|
const ADMIN_ROLES = ['support_team', 'admin', 'system'];
|
|
function requireSupportTeam(req, res, next) {
|
|
const role = (req.user?.role || '').toLowerCase();
|
|
if (!ADMIN_ROLES.includes(role)) {
|
|
return res.status(403).json({ success: false, message: '지원팀 이상 권한이 필요합니다.' });
|
|
}
|
|
next();
|
|
}
|
|
|
|
// 본인 월간 비교
|
|
router.get('/my-records', ctrl.getMyRecords);
|
|
|
|
// 특정 작업자 비교 (내부에서 권한 체크)
|
|
router.get('/records', ctrl.getRecords);
|
|
|
|
// 확인/반려
|
|
router.post('/confirm', ctrl.confirm);
|
|
|
|
// 전체 현황 (support_team+)
|
|
router.get('/all-status', requireSupportTeam, ctrl.getAllStatus);
|
|
|
|
// 엑셀 다운로드 (support_team+)
|
|
router.get('/export', requireSupportTeam, ctrl.exportExcel);
|
|
|
|
module.exports = router;
|