ㅋㅓ밋

This commit is contained in:
2026-01-05 03:09:11 +09:00
parent 615a221aa5
commit cfbd9e71ca
9 changed files with 729 additions and 1 deletions

View File

@@ -0,0 +1,39 @@
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: '삭제되었습니다.'
}
})

View File

@@ -0,0 +1,66 @@
import { query, execute, queryOne } from '../../../utils/db'
/**
* 개선의견 공감 토글
* POST /api/feedback/[id]/like
*/
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 feedback_id FROM wr_feedback WHERE feedback_id = $1
`, [feedbackId])
if (!feedback[0]) {
throw createError({ statusCode: 404, message: '의견을 찾을 수 없습니다.' })
}
// 이미 공감했는지 확인
const existing = await query<any>(`
SELECT 1 FROM wr_feedback_like WHERE feedback_id = $1 AND employee_id = $2
`, [feedbackId, userId])
let isLiked: boolean
let likeCount: number
if (existing[0]) {
// 공감 취소
await execute(`
DELETE FROM wr_feedback_like WHERE feedback_id = $1 AND employee_id = $2
`, [feedbackId, userId])
await execute(`
UPDATE wr_feedback SET like_count = like_count - 1 WHERE feedback_id = $1
`, [feedbackId])
isLiked = false
} else {
// 공감 추가
await execute(`
INSERT INTO wr_feedback_like (feedback_id, employee_id) VALUES ($1, $2)
`, [feedbackId, userId])
await execute(`
UPDATE wr_feedback SET like_count = like_count + 1 WHERE feedback_id = $1
`, [feedbackId])
isLiked = true
}
// 최신 카운트 조회
const updated = await queryOne<any>(`
SELECT like_count FROM wr_feedback WHERE feedback_id = $1
`, [feedbackId])
likeCount = updated.like_count
return {
success: true,
isLiked,
likeCount
}
})

View File

@@ -0,0 +1,57 @@
import { query, execute } from '../../../utils/db'
/**
* 개선의견 수정
* PUT /api/feedback/[id]/update
*/
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: '본인의 의견만 수정할 수 있습니다.' })
}
const body = await readBody<{
category?: string
content?: string
}>(event)
if (!body.content?.trim()) {
throw createError({ statusCode: 400, message: '내용을 입력해주세요.' })
}
const validCategories = ['FEATURE', 'UI', 'BUG', 'ETC']
if (body.category && !validCategories.includes(body.category)) {
throw createError({ statusCode: 400, message: '올바른 카테고리를 선택해주세요.' })
}
await execute(`
UPDATE wr_feedback
SET category = COALESCE($1, category),
content = $2,
updated_at = NOW()
WHERE feedback_id = $3
`, [body.category, body.content.trim(), feedbackId])
return {
success: true,
message: '수정되었습니다.'
}
})