Files
tk-factory-services/user-management/api/routes/notificationRecipientRoutes.js
Hyungi Ahn a6724b2a20 feat(tkuser): requireAdmin → requireAdminOrPermission 전환 — 권한 기반 접근 제어
- 9개 라우트 파일의 쓰기 작업을 requireAdminOrPermission으로 전환
- 권한 관리에서 tkuser.* 권한 부여 시 일반 사용자도 해당 탭 접근 가능
- GET(참조 데이터)은 requireAuth 유지, permissionRoutes는 admin 전용 유지
- 기존 partnerRoutes.js 패턴과 동일한 방식 적용

Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
2026-03-25 14:29:28 +09:00

34 lines
1.3 KiB
JavaScript

// routes/notificationRecipientRoutes.js
const express = require('express');
const router = express.Router();
const controller = require('../controllers/notificationRecipientController');
const { requireAuth, requireAdminOrPermission } = require('../middleware/auth');
// 모든 라우트에 인증 필요
router.use(requireAuth);
// 알림 유형 목록
router.get('/types', controller.getTypes);
// 전체 수신자 목록 (유형별 그룹화)
router.get('/', controller.getAll);
// ntfy 구독 관리 (/:type보다 위에 배치해야 "ntfy"를 type으로 잡지 않음)
router.get('/ntfy', controller.getNtfySubscribers);
router.post('/ntfy/:userId', controller.addNtfySubscription);
router.delete('/ntfy/:userId', controller.removeNtfySubscription);
// 유형별 수신자 조회
router.get('/:type', controller.getByType);
// 수신자 추가 (본인: 모든 사용자, 타인: 관리자만 — 컨트롤러에서 검증)
router.post('/', controller.add);
// 유형별 수신자 일괄 설정 (관리자만)
router.put('/:type', requireAdminOrPermission('tkuser.notification_recipients'), controller.setRecipients);
// 수신자 제거 (본인: 모든 사용자, 타인: 관리자만 — 컨트롤러에서 검증)
router.delete('/:type/:userId', controller.remove);
module.exports = router;