import { FreshContext, Handlers } from "$fresh/server.ts"; import { db } from "$root/databases/db.ts"; import { students } from "$root/databases/schema.ts"; import { AuthenticatedState } from "$root/defaults/interfaces.ts"; import { eq } from "npm:drizzle-orm"; export const handler: Handlers = { // #7 GET /students async GET( request: Request, context: FreshContext, ): Promise { if (context.state.session.eduPersonPrimaryAffiliation !== "employee") { return new Response(JSON.stringify([]), { headers: { "content-type": "application/json" }, }); } const url = new URL(request.url); const idPromo = url.searchParams.get("idPromo"); const rows = idPromo ? await db.select().from(students).where(eq(students.idPromo, idPromo)) : await db.select().from(students); return new Response(JSON.stringify(rows), { headers: { "content-type": "application/json" }, }); }, // #8 POST /students async POST( request: Request, context: FreshContext, ): Promise { if (context.state.session.eduPersonPrimaryAffiliation !== "employee") { return new Response(null, { status: 403 }); } const body: { numEtud: number; nom: string; prenom: string; idPromo: string } = await request.json(); if (!body.nom || !body.prenom || !body.idPromo) { return new Response(null, { status: 400 }); } const [created] = await db .insert(students) .values({ nom: body.nom, prenom: body.prenom, idPromo: body.idPromo }) .returning(); return new Response(JSON.stringify(created), { status: 201, headers: { "content-type": "application/json" }, }); }, };