7.6 익명/비밀댓글/비댓 해시 처리 o

This commit is contained in:
koreacomp5
2025-10-09 17:07:28 +09:00
parent 6d37881dd7
commit 15f30c1bc7
3 changed files with 16 additions and 3 deletions

View File

@@ -1,6 +1,7 @@
import { NextResponse } from "next/server"; import { NextResponse } from "next/server";
import prisma from "@/lib/prisma"; import prisma from "@/lib/prisma";
import { z } from "zod"; import { z } from "zod";
import { hashPassword } from "@/lib/password";
const createCommentSchema = z.object({ const createCommentSchema = z.object({
postId: z.string().min(1), postId: z.string().min(1),
@@ -8,6 +9,7 @@ const createCommentSchema = z.object({
content: z.string().min(1), content: z.string().min(1),
isAnonymous: z.boolean().optional(), isAnonymous: z.boolean().optional(),
isSecret: z.boolean().optional(), isSecret: z.boolean().optional(),
secretPassword: z.string().min(1).optional(), // 비회원 비밀번호(옵션)
}); });
export async function POST(req: Request) { export async function POST(req: Request) {
@@ -16,7 +18,8 @@ export async function POST(req: Request) {
if (!parsed.success) { if (!parsed.success) {
return NextResponse.json({ error: parsed.error.flatten() }, { status: 400 }); return NextResponse.json({ error: parsed.error.flatten() }, { status: 400 });
} }
const { postId, authorId, content, isAnonymous, isSecret } = parsed.data; const { postId, authorId, content, isAnonymous, isSecret, secretPassword } = parsed.data;
const secretPasswordHash = secretPassword ? hashPassword(secretPassword) : null;
const comment = await prisma.comment.create({ const comment = await prisma.comment.create({
data: { data: {
postId, postId,
@@ -24,6 +27,7 @@ export async function POST(req: Request) {
content, content,
isAnonymous: !!isAnonymous, isAnonymous: !!isAnonymous,
isSecret: !!isSecret, isSecret: !!isSecret,
secretPasswordHash,
}, },
}); });
return NextResponse.json({ comment }, { status: 201 }); return NextResponse.json({ comment }, { status: 201 });

View File

@@ -11,10 +11,19 @@ export async function GET(_: Request, context: { params: Promise<{ id: string }>
content: true, content: true,
isAnonymous: true, isAnonymous: true,
isSecret: true, isSecret: true,
secretPasswordHash: true,
createdAt: true, createdAt: true,
}, },
}); });
return NextResponse.json({ comments }); const presented = comments.map((c) => ({
id: c.id,
content: c.isSecret ? "비밀댓글입니다." : c.content,
isAnonymous: c.isAnonymous,
isSecret: c.isSecret,
anonId: c.isAnonymous ? c.id.slice(-6) : undefined,
createdAt: c.createdAt,
}));
return NextResponse.json({ comments: presented });
} }

View File

@@ -45,7 +45,7 @@
7.3 태그/카테고리 모델 및 UI o 7.3 태그/카테고리 모델 및 UI o
7.4 첨부 업로드 및 본문 삽입 o 7.4 첨부 업로드 및 본문 삽입 o
7.5 추천/신고, 조회수 카운트 o 7.5 추천/신고, 조회수 카운트 o
7.6 익명/비밀댓글/비댓 해시 처리 7.6 익명/비밀댓글/비댓 해시 처리 o
7.7 신고→알림→블라인드 자동화 훅 7.7 신고→알림→블라인드 자동화 훅
7.8 일반 게시판 공용 폼/라우트 템플릿 생성 7.8 일반 게시판 공용 폼/라우트 템플릿 생성
7.9 일반 카테고리 설정 매핑(공지/가입인사/버그건의/이벤트/소통방/자유/무엇이든/마사지꿀팁/관리사찾아요/청와대/방문후기[승인]) 7.9 일반 카테고리 설정 매핑(공지/가입인사/버그건의/이벤트/소통방/자유/무엇이든/마사지꿀팁/관리사찾아요/청와대/방문후기[승인])