Files
tk-factory-services/system1-factory/api/routes/dailyWorkReportRoutes.js
Hyungi Ahn abd7564e6b refactor: worker_id → user_id 전체 마이그레이션 (Phase 1-4)
sso_users.user_id를 단일 식별자로 통합. JWT에서 worker_id 제거,
department_id/is_production 추가. 백엔드 15개 모델, 11개 컨트롤러,
4개 서비스, 7개 라우트, 프론트엔드 32+ JS/11+ HTML 변환.

Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-03-05 13:13:10 +09:00

97 lines
4.4 KiB
JavaScript

// routes/dailyWorkReportRoutes.js - 누적입력 방식 + 모든 기존 기능 포함
const express = require('express');
const router = express.Router();
const dailyWorkReportController = require('../controllers/dailyWorkReportController');
const workReportController = require('../controllers/workReportController');
// 📋 마스터 데이터 조회 라우트들 (모든 인증된 사용자)
router.get('/work-types', dailyWorkReportController.getWorkTypes);
router.get('/work-status-types', dailyWorkReportController.getWorkStatusTypes);
router.get('/error-types', dailyWorkReportController.getErrorTypes);
// 📝 마스터 데이터 CRUD 라우트들 (관리자만)
// 작업 유형 CRUD
router.post('/work-types', dailyWorkReportController.createWorkType);
router.put('/work-types/:id', dailyWorkReportController.updateWorkType);
router.delete('/work-types/:id', dailyWorkReportController.deleteWorkType);
// 작업 상태 CRUD
router.post('/work-status-types', dailyWorkReportController.createWorkStatus);
router.put('/work-status-types/:id', dailyWorkReportController.updateWorkStatus);
router.delete('/work-status-types/:id', dailyWorkReportController.deleteWorkStatus);
// 오류 유형 CRUD
router.post('/error-types', dailyWorkReportController.createErrorType);
router.put('/error-types/:id', dailyWorkReportController.updateErrorType);
router.delete('/error-types/:id', dailyWorkReportController.deleteErrorType);
// 🔄 누적 관련 새로운 라우트들 (누적입력 시스템 전용)
router.get('/accumulated', dailyWorkReportController.getAccumulatedReports); // ?date=2024-06-16&user_id=1
router.get('/contributors', dailyWorkReportController.getContributorsSummary); // ?date=2024-06-16&user_id=1
router.get('/my-data', dailyWorkReportController.getMyAccumulatedData); // ?date=2024-06-16&user_id=1
// ✅ check-overwrite 엔드포인트 추가 (누락된 엔드포인트)
router.get('/check-overwrite', (req, res) => {
const { date, user_id } = req.query;
if (!date || !user_id) {
return res.status(400).json({
error: 'date와 user_id가 필요합니다.',
example: 'date=2025-06-16&user_id=1'
});
}
console.log(`🔍 덮어쓰기 권한 확인: 날짜=${date}, 작업자=${user_id} (누적입력모드)`);
// 누적입력 시스템에서는 항상 덮어쓰기 가능 (실제로는 누적만 함)
res.json({
canOverwrite: true,
reason: 'accumulate_mode',
message: '누적입력 모드에서는 항상 추가 가능합니다.',
date,
user_id,
timestamp: new Date().toISOString()
});
});
router.delete('/my-entry/:id', dailyWorkReportController.removeMyEntry); // 개별 항목 삭제 (본인 것만)
// 📅 월간 요약 (반드시 다른 라우트보다 먼저 정의)
router.get('/summary/monthly', dailyWorkReportController.getMonthlySummary);
// 📊 일일 근무 요약 조회
router.get('/summary', dailyWorkReportController.getDailySummary);
// 🔍 검색 (페이지네이션 포함)
router.get('/search', dailyWorkReportController.searchWorkReports);
// 📈 통계
router.get('/stats', dailyWorkReportController.getWorkReportStats);
// 📝 일일 작업보고서 생성 (누적 방식 - 덮어쓰기 없음!)
router.post('/', dailyWorkReportController.createDailyWorkReport);
// 📝 TBM 기반 작업보고서 생성
router.post('/from-tbm', dailyWorkReportController.createFromTbm);
// 📊 일일 작업보고서 조회 (날짜별 - 경로 파라미터)
router.get('/date/:date', dailyWorkReportController.getDailyWorkReportsByDate);
// 📊 일일 작업보고서 조회 (쿼리 파라미터 기반 - 작성자별 필터링)
router.get('/', dailyWorkReportController.getDailyWorkReports);
// ✏️ 작업보고서 수정
router.put('/:id', dailyWorkReportController.updateWorkReport);
// 🗑️ 작업자의 특정 날짜 전체 삭제
router.delete('/date/:date/worker/:user_id', dailyWorkReportController.removeDailyWorkReportByDateAndWorker);
// 🗑️ 특정 작업보고서 삭제 (항상 가장 마지막에 정의)
router.delete('/:id', dailyWorkReportController.removeDailyWorkReport);
// 📋 부적합 관리 (workReportController 사용)
router.get('/:reportId/defects', workReportController.getReportDefects);
router.put('/:reportId/defects', workReportController.saveReportDefects);
router.post('/:reportId/defects', workReportController.addReportDefect);
module.exports = router;