feat: 데이터베이스 및 웹 UI 대규모 리팩토링
- 삭제된 DB 테이블들과 관련 코드 정리: * 12개 사용하지 않는 테이블 삭제 (activity_logs, CuttingPlan, DailyIssueReports 등) * 관련 모델, 컨트롤러, 라우트 파일들 삭제 * index.js에서 삭제된 라우트들 제거 - 웹 UI 페이지 정리: * 21개 사용하지 않는 페이지 삭제 * issue-reports 폴더 전체 삭제 * 모든 사용자 권한을 그룹장 대시보드로 통일 - 데이터베이스 스키마 정리: * v1 스키마로 통일 (daily_work_reports 테이블) * JSON 데이터 임포트 스크립트 구현 * 외래키 관계 정리 및 데이터 일관성 확보 - 통합 Docker Compose 설정: * 모든 서비스를 단일 docker-compose.yml로 통합 * 20000번대 포트 유지 * JWT 시크릿 및 환경변수 설정 - 문서화: * DATABASE_SCHEMA.md: 현재 DB 스키마 문서화 * DELETED_TABLES.md: 삭제된 테이블 목록 * DELETED_PAGES.md: 삭제된 페이지 목록
This commit is contained in:
@@ -19,4 +19,71 @@ exports.verifyToken = (req, res, next) => {
|
||||
console.error('[verifyToken 오류]', err.message);
|
||||
return res.status(403).json({ error: '토큰 검증 실패', detail: err.message });
|
||||
}
|
||||
};
|
||||
|
||||
/**
|
||||
* Admin 등급 이상 권한 체크 미들웨어
|
||||
*/
|
||||
exports.requireAdmin = (req, res, next) => {
|
||||
try {
|
||||
if (!req.user) {
|
||||
return res.status(401).json({
|
||||
error: '인증 필요',
|
||||
message: '먼저 로그인해주세요.'
|
||||
});
|
||||
}
|
||||
|
||||
const userRole = req.user.role;
|
||||
const adminRoles = ['admin', 'system'];
|
||||
|
||||
if (!adminRoles.includes(userRole)) {
|
||||
return res.status(403).json({
|
||||
error: '권한 부족',
|
||||
message: '관리자 권한이 필요합니다.',
|
||||
required: 'admin 또는 system',
|
||||
current: userRole
|
||||
});
|
||||
}
|
||||
|
||||
console.log(`✅ Admin 권한 확인: ${req.user.username} (${userRole})`);
|
||||
next();
|
||||
} catch (err) {
|
||||
console.error('[requireAdmin 오류]', err.message);
|
||||
return res.status(500).json({
|
||||
error: '권한 확인 중 오류 발생',
|
||||
detail: err.message
|
||||
});
|
||||
}
|
||||
};
|
||||
|
||||
/**
|
||||
* System 등급 권한 체크 미들웨어
|
||||
*/
|
||||
exports.requireSystem = (req, res, next) => {
|
||||
try {
|
||||
if (!req.user) {
|
||||
return res.status(401).json({
|
||||
error: '인증 필요',
|
||||
message: '먼저 로그인해주세요.'
|
||||
});
|
||||
}
|
||||
|
||||
if (req.user.role !== 'system') {
|
||||
return res.status(403).json({
|
||||
error: '권한 부족',
|
||||
message: '시스템 관리자 권한이 필요합니다.',
|
||||
required: 'system',
|
||||
current: req.user.role
|
||||
});
|
||||
}
|
||||
|
||||
console.log(`✅ System 권한 확인: ${req.user.username}`);
|
||||
next();
|
||||
} catch (err) {
|
||||
console.error('[requireSystem 오류]', err.message);
|
||||
return res.status(500).json({
|
||||
error: '권한 확인 중 오류 발생',
|
||||
detail: err.message
|
||||
});
|
||||
}
|
||||
};
|
||||
Reference in New Issue
Block a user