- getAllStatus: daily_attendance_records JOIN으로 실제 근무일/시간 집계 - vacation_days: vacation_types.deduct_days SUM (반차 0.5 정확 반영) - admin_checked 컬럼 + POST /admin-check API (upsert 패턴) - 상태 뱃지 라벨: 미검토/확인요청/수정요청/반려/확인완료 Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
42 lines
1.4 KiB
JavaScript
42 lines
1.4 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);
|
|
|
|
// 관리자: 확인요청 발송 (pending → review_sent)
|
|
router.post('/review-send', requireSupportTeam, ctrl.reviewSend);
|
|
|
|
// 관리자: 수정요청 응답 (change_request → review_sent 또는 rejected)
|
|
router.post('/review-respond', requireSupportTeam, ctrl.reviewRespond);
|
|
|
|
// 관리자: 개별 검토 태깅
|
|
router.post('/admin-check', requireSupportTeam, ctrl.adminCheck);
|
|
|
|
// 전체 현황 (support_team+)
|
|
router.get('/all-status', requireSupportTeam, ctrl.getAllStatus);
|
|
|
|
// 엑셀 다운로드 (support_team+)
|
|
router.get('/export', requireSupportTeam, ctrl.exportExcel);
|
|
|
|
module.exports = router;
|