feat(sprint-004): 월간 비교·확인·정산 백엔드 (Section A) + Mock 해제
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>
This commit is contained in:
32
system1-factory/api/routes/monthlyComparisonRoutes.js
Normal file
32
system1-factory/api/routes/monthlyComparisonRoutes.js
Normal file
@@ -0,0 +1,32 @@
|
||||
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;
|
||||
Reference in New Issue
Block a user