fix middleware
deskrispi: - perbaiki middleware untuk versi diatas 1.4.6 No Issuee
This commit is contained in:
38
src/app/api/auth/logout/route-v.1.4.5t.xt
Normal file
38
src/app/api/auth/logout/route-v.1.4.5t.xt
Normal file
@@ -0,0 +1,38 @@
|
||||
import { cookies } from "next/headers";
|
||||
import { NextResponse } from "next/server";
|
||||
|
||||
export const dynamic = "force-dynamic";
|
||||
|
||||
export async function GET() {
|
||||
const sessionKey = process.env.NEXT_PUBLIC_BASE_SESSION_KEY!; // Gunakan environment variable yang tidak diekspos ke client-side
|
||||
if (!sessionKey) {
|
||||
return NextResponse.json(
|
||||
{ success: false, message: "Session key tidak ditemukan" },
|
||||
{ status: 500 }
|
||||
);
|
||||
}
|
||||
|
||||
const cookieStore = cookies();
|
||||
const sessionCookie = cookieStore.get(sessionKey);
|
||||
|
||||
if (!sessionCookie) {
|
||||
return NextResponse.json(
|
||||
{ success: false, message: "Session tidak ditemukan" },
|
||||
{ status: 400 }
|
||||
);
|
||||
}
|
||||
|
||||
try {
|
||||
cookieStore.delete(sessionKey);
|
||||
return NextResponse.json(
|
||||
{ success: true, message: "Logout berhasil" },
|
||||
{ status: 200 }
|
||||
);
|
||||
} catch (error) {
|
||||
console.error("Gagal menghapus cookie:", error);
|
||||
return NextResponse.json(
|
||||
{ success: false, message: "Gagal melakukan logout" },
|
||||
{ status: 500 }
|
||||
);
|
||||
}
|
||||
}
|
||||
@@ -4,7 +4,7 @@ import { NextResponse } from "next/server";
|
||||
export const dynamic = "force-dynamic";
|
||||
|
||||
export async function GET() {
|
||||
const sessionKey = process.env.NEXT_PUBLIC_BASE_SESSION_KEY!; // Gunakan environment variable yang tidak diekspos ke client-side
|
||||
const sessionKey = process.env.NEXT_PUBLIC_BASE_SESSION_KEY!;
|
||||
if (!sessionKey) {
|
||||
return NextResponse.json(
|
||||
{ success: false, message: "Session key tidak ditemukan" },
|
||||
@@ -23,11 +23,20 @@ export async function GET() {
|
||||
}
|
||||
|
||||
try {
|
||||
cookieStore.delete(sessionKey);
|
||||
return NextResponse.json(
|
||||
{ success: true, message: "Logout berhasil" },
|
||||
{ status: 200 }
|
||||
);
|
||||
const response = NextResponse.json({
|
||||
success: true,
|
||||
message: "Logout berhasil",
|
||||
});
|
||||
|
||||
// Menghapus cookie dengan set maxAge 0
|
||||
response.cookies.set({
|
||||
name: sessionKey,
|
||||
value: "",
|
||||
path: "/",
|
||||
maxAge: 0,
|
||||
});
|
||||
|
||||
return response;
|
||||
} catch (error) {
|
||||
console.error("Gagal menghapus cookie:", error);
|
||||
return NextResponse.json(
|
||||
|
||||
Reference in New Issue
Block a user