7.6 익명/비밀댓글/비댓 해시 처리 o
This commit is contained in:
@@ -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 });
|
||||||
|
|||||||
@@ -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 });
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@@ -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 일반 카테고리 설정 매핑(공지/가입인사/버그건의/이벤트/소통방/자유/무엇이든/마사지꿀팁/관리사찾아요/청와대/방문후기[승인])
|
||||||
|
|||||||
Reference in New Issue
Block a user