24 lines
990 B
TypeScript
24 lines
990 B
TypeScript
import { NextRequest, NextResponse } from "next/server";
|
|
import { db } from "@/lib/db";
|
|
import { getServerSession } from "next-auth";
|
|
import { authOptions } from "@/lib/auth";
|
|
|
|
export async function PUT(req: NextRequest, { params }: { params: { id: string } }) {
|
|
const session = await getServerSession(authOptions);
|
|
if (!session || (session.user as any).role !== "ADMIN")
|
|
return NextResponse.json({ error: "Unauthorized" }, { status: 401 });
|
|
|
|
const body = await req.json();
|
|
const country = await db.country.update({ where: { id: params.id }, data: body });
|
|
return NextResponse.json(country);
|
|
}
|
|
|
|
export async function DELETE(_: NextRequest, { params }: { params: { id: string } }) {
|
|
const session = await getServerSession(authOptions);
|
|
if (!session || (session.user as any).role !== "ADMIN")
|
|
return NextResponse.json({ error: "Unauthorized" }, { status: 401 });
|
|
|
|
await db.country.delete({ where: { id: params.id } });
|
|
return NextResponse.json({ success: true });
|
|
}
|