fiddy/apps/web/app/api/auth/register/route.ts
2026-02-11 23:45:15 -08:00

39 lines
1.4 KiB
TypeScript

import { NextResponse } from "next/server";
import { cookies } from "next/headers";
import { getSessionCookieName, getSessionTtlMs } from "@/lib/server/auth";
import { registerUser } from "@/lib/server/auth-service";
import { toErrorResponse } from "@/lib/server/errors";
export async function POST(req: Request) {
const body = await req.json().catch(() => null);
const email = String(body?.email || "").trim().toLowerCase();
const password = String(body?.password || "");
const displayName = String(body?.displayName || "").trim();
if (!email || !email.includes("@"))
return NextResponse.json({ error: { code: "INVALID_EMAIL", message: "Invalid email" } }, { status: 400 });
if (password.length < 8)
return NextResponse.json({ error: { code: "PASSWORD_TOO_SHORT", message: "Password too short" } }, { status: 400 });
let user;
let session;
try {
const result = await registerUser({ email, password, displayName });
user = result.user;
session = result.session;
} catch (e) {
const { status, body } = toErrorResponse(e, "POST /api/auth/register");
return NextResponse.json(body, { status });
}
const cookieStore = await cookies();
cookieStore.set(getSessionCookieName(), session.token, {
httpOnly: true,
sameSite: "lax",
secure: process.env.NODE_ENV === "production",
maxAge: Math.floor(getSessionTtlMs() / 1000),
path: "/"
});
return NextResponse.json({ user });
}