36 lines
996 B
TypeScript
36 lines
996 B
TypeScript
import { NextResponse } from "next/server";
|
|
import { cookies } from "next/headers";
|
|
|
|
const BE_BASE_URL = process.env.BE_BASE_URL || "http://localhost:8583";
|
|
const COOKIE_NAME = "auth_token";
|
|
|
|
export async function POST() {
|
|
const cookieStore = await cookies();
|
|
const token = cookieStore.get(COOKIE_NAME)?.value;
|
|
|
|
if (!token) {
|
|
return NextResponse.json({ valid: false }, { status: 401 });
|
|
}
|
|
|
|
try {
|
|
const resp = await fetch(`${BE_BASE_URL}/api/v1/auth/validate`, {
|
|
method: "POST",
|
|
headers: {
|
|
"Content-Type": "application/json",
|
|
Authorization: `Bearer ${token}`,
|
|
},
|
|
body: JSON.stringify({ token }),
|
|
});
|
|
|
|
const data = await resp.json();
|
|
|
|
return NextResponse.json(data, { status: resp.status });
|
|
} catch (err: unknown) {
|
|
const message = err instanceof Error ? err.message : "Unknown error";
|
|
return NextResponse.json(
|
|
{ valid: false, message: "Validation failed", error: message },
|
|
{ status: 500 }
|
|
);
|
|
}
|
|
}
|