Files
weeklyreport/backend/api/feedback/[id]/delete.delete.ts
2026-01-05 03:09:11 +09:00

40 lines
1.2 KiB
TypeScript

import { query, execute } from '../../../utils/db'
/**
* 개선의견 삭제
* DELETE /api/feedback/[id]/delete
*/
export default defineEventHandler(async (event) => {
const userId = getCookie(event, 'user_id')
if (!userId) {
throw createError({ statusCode: 401, message: '로그인이 필요합니다.' })
}
const feedbackId = getRouterParam(event, 'id')
if (!feedbackId) {
throw createError({ statusCode: 400, message: '피드백 ID가 필요합니다.' })
}
// 본인 확인
const feedback = await query<any>(`
SELECT author_id FROM wr_feedback WHERE feedback_id = $1
`, [feedbackId])
if (!feedback[0]) {
throw createError({ statusCode: 404, message: '의견을 찾을 수 없습니다.' })
}
if (feedback[0].author_id !== parseInt(userId)) {
throw createError({ statusCode: 403, message: '본인의 의견만 삭제할 수 있습니다.' })
}
// 공감 먼저 삭제 (CASCADE로 자동 삭제되지만 명시적으로)
await execute(`DELETE FROM wr_feedback_like WHERE feedback_id = $1`, [feedbackId])
await execute(`DELETE FROM wr_feedback WHERE feedback_id = $1`, [feedbackId])
return {
success: true,
message: '삭제되었습니다.'
}
})