29 lines
751 B
TypeScript
29 lines
751 B
TypeScript
import { NextRequest, NextResponse } from "next/server";
|
|
|
|
const ALLOWED_ACTIONS = ["start", "stop", "restart"];
|
|
|
|
export async function POST(
|
|
req: NextRequest,
|
|
{ params }: { params: { service: string; action: string } },
|
|
) {
|
|
const token = req.cookies.get("token")?.value;
|
|
if (!token) {
|
|
return NextResponse.json({ error: "Unauthorized" }, { status: 401 });
|
|
}
|
|
|
|
if (!ALLOWED_ACTIONS.includes(params.action)) {
|
|
return NextResponse.json({ error: "Invalid action" }, { status: 400 });
|
|
}
|
|
|
|
const res = await fetch(
|
|
`http://localhost:3001/services/${params.service}/${params.action}`,
|
|
{
|
|
method: "POST",
|
|
headers: {
|
|
Authorization: `Bearer ${token}`,
|
|
},
|
|
},
|
|
);
|
|
|
|
return NextResponse.json(await res.json(), { status: res.status });
|
|
}
|