Penambahan fitur checklist terms of service dan penambahan database blockuser Add: - prisma/migrations/20251124061947_add_terms_of_service_accepted/ - prisma/migrations/20251124081155_add_blocked_user_and_menu_feature/ - prisma/migrations/20251124083155_fix_master_kategori_app_and_delete_menu_feature/ - public/terms-of-service.html - src/app/api/auth/term-service/ Fix: - prisma/schema.prisma - src/app/api/auth/register/route.ts - src/app/api/auth/validasi/route.ts - src/app_modules/_global/fun/generate_seeder.ts - src/bin/seeder/master/master_kategori_app.json - src/bin/seeder/user_seeder.json - src/middleware.tsx ### No Issue
81 lines
1.9 KiB
TypeScript
81 lines
1.9 KiB
TypeScript
import { sessionCreate } from "@/app/(auth)/_lib/session_create";
|
|
import prisma from "@/lib/prisma";
|
|
import backendLogger from "@/util/backendLogger";
|
|
import { NextResponse } from "next/server";
|
|
|
|
export async function POST(req: Request) {
|
|
if (req.method !== "POST") {
|
|
return NextResponse.json(
|
|
{ success: false, message: "Method Not Allowed" },
|
|
{ status: 405 }
|
|
);
|
|
}
|
|
|
|
try {
|
|
const { data } = await req.json();
|
|
|
|
console.log("data >>", data);
|
|
|
|
const cekUsername = await prisma.user.findUnique({
|
|
where: {
|
|
username: data.username,
|
|
},
|
|
});
|
|
|
|
if (cekUsername)
|
|
return NextResponse.json({
|
|
success: false,
|
|
message: "Username sudah digunakan",
|
|
});
|
|
|
|
// ✅ Validasi wajib setuju Terms
|
|
if (data.termsOfServiceAccepted !== true) {
|
|
return NextResponse.json({
|
|
success: false,
|
|
message: "You must agree to the Terms of Service",
|
|
});
|
|
}
|
|
|
|
const createUser = await prisma.user.create({
|
|
data: {
|
|
username: data.username,
|
|
nomor: data.nomor,
|
|
active: false,
|
|
termsOfServiceAccepted: data.termsOfServiceAccepted,
|
|
},
|
|
});
|
|
|
|
if (!createUser)
|
|
return NextResponse.json(
|
|
{ success: false, message: "Gagal Registrasi" },
|
|
{ status: 500 }
|
|
);
|
|
|
|
const token = await sessionCreate({
|
|
sessionKey: process.env.NEXT_PUBLIC_BASE_SESSION_KEY!,
|
|
encodedKey: process.env.NEXT_PUBLIC_BASE_TOKEN_KEY!,
|
|
user: createUser as any,
|
|
});
|
|
|
|
return NextResponse.json(
|
|
{
|
|
success: true,
|
|
message: "Registrasi Berhasil, Anda Sedang Login",
|
|
token: token,
|
|
// data: createUser,x
|
|
},
|
|
{ status: 201 }
|
|
);
|
|
} catch (error) {
|
|
backendLogger.error("Error registrasi:", error);
|
|
return NextResponse.json(
|
|
{
|
|
success: false,
|
|
message: "Maaf, Terjadi Keselahan",
|
|
reason: (error as Error).message,
|
|
},
|
|
{ status: 500 }
|
|
);
|
|
}
|
|
}
|