2025-04-11 22:55:17 +02:00
|
|
|
import { NextResponse, NextRequest } from "next/server";
|
2025-04-13 21:10:17 +02:00
|
|
|
import { prisma } from "@/lib/prisma";
|
2025-04-11 22:55:17 +02:00
|
|
|
|
2025-04-13 21:10:17 +02:00
|
|
|
interface PostRequest {
|
|
|
|
|
page?: number;
|
|
|
|
|
ITEMS_PER_PAGE?: number;
|
2025-04-11 22:55:17 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
export async function POST(request: NextRequest) {
|
2025-04-13 21:10:17 +02:00
|
|
|
try {
|
|
|
|
|
const body: PostRequest = await request.json();
|
|
|
|
|
const page = Math.max(1, body.page || 1);
|
|
|
|
|
const ITEMS_PER_PAGE = body.ITEMS_PER_PAGE || 10;
|
|
|
|
|
|
|
|
|
|
const [applications, totalCount, servers_all] = await Promise.all([
|
|
|
|
|
prisma.application.findMany({
|
|
|
|
|
skip: (page - 1) * ITEMS_PER_PAGE,
|
|
|
|
|
take: ITEMS_PER_PAGE,
|
|
|
|
|
orderBy: { name: "asc" }
|
|
|
|
|
}),
|
|
|
|
|
prisma.application.count(),
|
|
|
|
|
prisma.server.findMany()
|
|
|
|
|
]);
|
|
|
|
|
|
|
|
|
|
const serverIds = applications
|
|
|
|
|
.map((app: { serverId: number | null }) => app.serverId)
|
|
|
|
|
.filter((id:any): id is number => id !== null);
|
|
|
|
|
|
|
|
|
|
const servers = await prisma.server.findMany({
|
|
|
|
|
where: { id: { in: serverIds } }
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
const applicationsWithServers = applications.map((app: any) => ({
|
|
|
|
|
...app,
|
|
|
|
|
server: servers.find((s: any) => s.id === app.serverId)?.name || "No server"
|
|
|
|
|
}));
|
|
|
|
|
|
|
|
|
|
const maxPage = Math.ceil(totalCount / ITEMS_PER_PAGE);
|
|
|
|
|
|
|
|
|
|
return NextResponse.json({
|
|
|
|
|
applications: applicationsWithServers,
|
|
|
|
|
servers: servers_all,
|
|
|
|
|
maxPage
|
|
|
|
|
});
|
|
|
|
|
} catch (error: unknown) {
|
|
|
|
|
const message = error instanceof Error ? error.message : "Unknown error";
|
|
|
|
|
return NextResponse.json({ error: message }, { status: 500 });
|
|
|
|
|
}
|
2025-04-11 22:55:17 +02:00
|
|
|
}
|