feat: usernames

also change userId to number
This commit is contained in:
trafficlunar 2025-03-30 17:36:49 +01:00
parent 9344f2f315
commit 9d35d93d9e
15 changed files with 200 additions and 78 deletions

View file

@ -0,0 +1,38 @@
import { z } from "zod";
import { auth } from "@/lib/auth";
import { prisma } from "@/lib/prisma";
const usernameSchema = z
.string()
.min(3, "Username must be at least 3 characters long")
.max(20, "Username cannot be more than 20 characters long")
.regex(/^[a-zA-Z0-9_]+$/, "Username can only contain letters, numbers, and underscores");
export async function GET() {
const session = await auth();
if (!session) return Response.json({ error: "Unauthorized" }, { status: 401 });
return Response.json({ username: session.user.username });
}
export async function PATCH(request: Request) {
const session = await auth();
if (!session) return Response.json({ error: "Unauthorized" }, { status: 401 });
const { username } = await request.json();
if (!username) return Response.json({ error: "Username is required" }, { status: 400 });
const validation = usernameSchema.safeParse(username);
if (!validation.success) return Response.json({ error: validation.error.errors[0].message }, { status: 400 });
const existingUser = await prisma.user.findUnique({ where: { username } });
if (existingUser) return Response.json({ error: "Username is already taken" }, { status: 400 });
await prisma.user.update({
where: { email: session.user?.email ?? undefined },
data: { username },
});
return Response.json({ success: true });
}