Files
sori.studio/server/routes/admin/api/posts.post.js
2026-06-09 17:10:16 +09:00

46 lines
1.3 KiB
JavaScript

import { createError, readBody } from 'h3'
import { requireAdminSession } from '../../../utils/admin-auth'
import { parseAdminPostInput } from '../../../utils/admin-post-input'
import { createAdminPost, getSiteSettings } from '../../../repositories/content-repository'
/**
* 관리자 게시물 생성 API
* @param {import('h3').H3Event} event - 요청 이벤트
* @returns {Promise<Object>} 생성된 게시물
*/
export default defineEventHandler(async (event) => {
const adminSession = requireAdminSession(event)
const parsedBody = parseAdminPostInput(await readBody(event))
if (!parsedBody.success) {
throw createError({
statusCode: 400,
message: '게시물 입력 형식이 올바르지 않습니다.'
})
}
const settings = await getSiteSettings()
const postTagLimit = Number(settings.postTagLimit || 5)
if (parsedBody.data.tags.length > postTagLimit) {
throw createError({
statusCode: 400,
message: `태그는 최대 ${postTagLimit}개까지 선택할 수 있습니다.`
})
}
try {
return await createAdminPost(parsedBody.data, adminSession.userId)
} catch (error) {
if (error?.code === '23505') {
throw createError({
statusCode: 409,
message: '이미 사용 중인 슬러그입니다.'
})
}
throw error
}
})