28 lines
865 B
TypeScript
Raw Normal View History

2025-05-18 12:22:22 +02:00
import { NextRequest, NextResponse } from "next/server";
2025-05-18 12:12:49 +02:00
import prisma from "@/app/prisma";
2025-05-18 12:22:22 +02:00
interface QueryParams {
currentPage: number;
itemPerPage: number;
}
export async function GET(request: NextRequest) {
const { searchParams } = request.nextUrl;
const currentPage = Number(searchParams.get("currentPage")) || 1;
2025-05-18 12:32:50 +02:00
const itemPerPage = Number(searchParams.get("itemPerPage")) || 1;
2025-05-18 12:22:22 +02:00
2025-05-18 12:32:50 +02:00
const skip = (currentPage - 1) * itemPerPage;
2025-05-18 12:22:46 +02:00
const take = itemPerPage;
2025-05-18 12:32:50 +02:00
2025-05-18 12:12:49 +02:00
try {
2025-05-18 12:22:22 +02:00
const sites = await prisma.site.findMany({
skip,
take,
});
2025-05-18 12:22:46 +02:00
const total = await prisma.site.count();
2025-05-18 12:32:50 +02:00
return NextResponse.json({ sites, total, currentPage, itemPerPage }, { status: 200 });
2025-05-18 12:12:49 +02:00
} catch (error: any) {
return NextResponse.json({ error: "Internal Server Error" }, { status: 500 });
}
}