38 lines
1.0 KiB
TypeScript
38 lines
1.0 KiB
TypeScript
import { execute, queryOne } from '../../../../utils/db'
|
|
|
|
/**
|
|
* 주간보고 제출
|
|
* POST /api/report/weekly/[id]/submit
|
|
*/
|
|
export default defineEventHandler(async (event) => {
|
|
const userId = getCookie(event, 'user_id')
|
|
if (!userId) {
|
|
throw createError({ statusCode: 401, message: '로그인이 필요합니다.' })
|
|
}
|
|
|
|
const reportId = getRouterParam(event, 'id')
|
|
|
|
// 보고서 조회 및 권한 확인
|
|
const report = await queryOne<any>(`
|
|
SELECT * FROM wr_weekly_report_detail WHERE report_id = $1
|
|
`, [reportId])
|
|
|
|
if (!report) {
|
|
throw createError({ statusCode: 404, message: '보고서를 찾을 수 없습니다.' })
|
|
}
|
|
|
|
if (report.author_id !== parseInt(userId)) {
|
|
throw createError({ statusCode: 403, message: '본인의 보고서만 제출할 수 있습니다.' })
|
|
}
|
|
|
|
await execute(`
|
|
UPDATE wr_weekly_report_detail SET
|
|
report_status = 'SUBMITTED',
|
|
submitted_at = NOW(),
|
|
updated_at = NOW()
|
|
WHERE report_id = $1
|
|
`, [reportId])
|
|
|
|
return { success: true }
|
|
})
|