Gate setup and admin navigation
All checks were successful
Build / build (push) Successful in 9m18s
Template Compliance / compliance (push) Successful in 6s
Release Dry Run / release-dry-run (push) Successful in 1m28s

This commit is contained in:
MrSphay
2026-05-15 17:32:26 +02:00
parent 4dbd595061
commit 035a255125
11 changed files with 98 additions and 30 deletions

View File

@@ -1,5 +1,6 @@
import { createHmac, timingSafeEqual } from "node:crypto";
import { cookies } from "next/headers";
import { redirect } from "next/navigation";
import { prisma } from "./prisma";
const COOKIE_NAME = "watchlink_session";
@@ -49,3 +50,15 @@ export async function getCurrentUser() {
include: { roles: { include: { role: true } } }
});
}
export function userIsAdmin(user: Awaited<ReturnType<typeof getCurrentUser>>) {
return Boolean(user?.roles.some((userRole) => userRole.role.name === "admin"));
}
export async function requireCurrentUser() {
const user = await getCurrentUser();
if (!user) {
redirect("/login");
}
return user;
}

20
src/lib/setup.ts Normal file
View File

@@ -0,0 +1,20 @@
import { redirect } from "next/navigation";
import { prisma } from "./prisma";
export async function hasAdminUser() {
try {
const admin = await prisma.userRole.findFirst({
where: { role: { name: "admin" } },
select: { userId: true }
});
return Boolean(admin);
} catch {
return false;
}
}
export async function requireInitialSetup() {
if (!(await hasAdminUser())) {
redirect("/setup");
}
}