Files
caddy-proxy-manager/app/(dashboard)/audit-log/page.tsx
akanealw 99819b70ff
Some checks failed
Build and Push Docker Images (Trusted) / build-and-push (., docker/caddy/Dockerfile, caddy) (push) Has been cancelled
Build and Push Docker Images (Trusted) / build-and-push (., docker/l4-port-manager/Dockerfile, l4-port-manager) (push) Has been cancelled
Build and Push Docker Images (Trusted) / build-and-push (., docker/web/Dockerfile, web) (push) Has been cancelled
Tests / test (push) Has been cancelled
added caddy-proxy-manager for testing
2026-04-21 22:49:08 +00:00

44 lines
1.3 KiB
TypeScript
Executable File

import AuditLogClient from "./AuditLogClient";
import { listAuditEvents, countAuditEvents } from "@/src/lib/models/audit";
import { listUsers } from "@/src/lib/models/user";
import { requireAdmin } from "@/src/lib/auth";
const PER_PAGE = 50;
interface PageProps {
searchParams: Promise<{ page?: string; search?: string }>;
}
export default async function AuditLogPage({ searchParams }: PageProps) {
await requireAdmin();
const { page: pageParam, search: searchParam } = await searchParams;
const page = Math.max(1, parseInt(pageParam ?? "1", 10) || 1);
const search = searchParam?.trim() || undefined;
const offset = (page - 1) * PER_PAGE;
const [events, total, users] = await Promise.all([
listAuditEvents(PER_PAGE, offset, search),
countAuditEvents(search),
listUsers(),
]);
const userMap = new Map(users.map((user) => [user.id, user]));
return (
<AuditLogClient
events={events.map((event) => ({
id: event.id,
createdAt: event.createdAt,
summary: event.summary ?? `${event.action} on ${event.entityType}`,
user: event.userId
? userMap.get(event.userId)?.name ??
userMap.get(event.userId)?.email ??
"System"
: "System",
}))}
pagination={{ total, page, perPage: PER_PAGE }}
initialSearch={search ?? ""}
/>
);
}