fix: add error handling to middleware to prevent INVOCATION_FAILED

- Check if Supabase env vars are configured before using them
- Wrap Supabase auth call in try/catch to prevent 500 crashes
- Graceful fallback: pass through on error instead of crashing

https://claude.ai/code/session_01H2aRGDaKgarPvhay2HxN6Y
This commit is contained in:
Claude
2026-02-08 14:06:42 +00:00
parent c9ff180959
commit 7a5871d344

View File

@@ -2,14 +2,37 @@ import { createServerClient } from "@supabase/ssr";
import { NextResponse, type NextRequest } from "next/server"; import { NextResponse, type NextRequest } from "next/server";
export async function middleware(request: NextRequest) { export async function middleware(request: NextRequest) {
let supabaseResponse = NextResponse.next({ // Si les env vars Supabase ne sont pas configurees, laisser passer
request, const supabaseUrl = process.env.NEXT_PUBLIC_SUPABASE_URL;
}); const supabaseAnonKey = process.env.NEXT_PUBLIC_SUPABASE_ANON_KEY;
const supabase = createServerClient( if (
process.env.NEXT_PUBLIC_SUPABASE_URL!, !supabaseUrl ||
process.env.NEXT_PUBLIC_SUPABASE_ANON_KEY!, !supabaseAnonKey ||
{ supabaseUrl.includes("your-project") ||
supabaseAnonKey === "your-anon-key"
) {
// Pas de Supabase configure : rediriger les routes protegees vers login
const protectedPaths = ["/dashboard", "/formations", "/profil"];
const isProtected = protectedPaths.some((p) =>
request.nextUrl.pathname.startsWith(p)
);
if (isProtected) {
const url = request.nextUrl.clone();
url.pathname = "/login";
return NextResponse.redirect(url);
}
return NextResponse.next();
}
try {
let supabaseResponse = NextResponse.next({
request,
});
const supabase = createServerClient(supabaseUrl, supabaseAnonKey, {
cookies: { cookies: {
getAll() { getAll() {
return request.cookies.getAll(); return request.cookies.getAll();
@@ -26,37 +49,41 @@ export async function middleware(request: NextRequest) {
); );
}, },
}, },
});
const {
data: { user },
} = await supabase.auth.getUser();
// Rediriger vers login si pas connecte et route protegee
if (
!user &&
(request.nextUrl.pathname.startsWith("/dashboard") ||
request.nextUrl.pathname.startsWith("/formations") ||
request.nextUrl.pathname.startsWith("/profil"))
) {
const url = request.nextUrl.clone();
url.pathname = "/login";
return NextResponse.redirect(url);
} }
);
const { // Rediriger vers dashboard si deja connecte et sur login/register
data: { user }, if (
} = await supabase.auth.getUser(); user &&
(request.nextUrl.pathname === "/login" ||
request.nextUrl.pathname === "/register")
) {
const url = request.nextUrl.clone();
url.pathname = "/dashboard";
return NextResponse.redirect(url);
}
// Rediriger vers login si pas connecte et route protegee return supabaseResponse;
if ( } catch (e) {
!user && console.error("Middleware error:", e);
(request.nextUrl.pathname.startsWith("/dashboard") || // En cas d'erreur, laisser passer la requete plutot que crasher
request.nextUrl.pathname.startsWith("/formations") || return NextResponse.next();
request.nextUrl.pathname.startsWith("/profil"))
) {
const url = request.nextUrl.clone();
url.pathname = "/login";
return NextResponse.redirect(url);
} }
// Rediriger vers dashboard si deja connecte et sur login/register
if (
user &&
(request.nextUrl.pathname === "/login" ||
request.nextUrl.pathname === "/register")
) {
const url = request.nextUrl.clone();
url.pathname = "/dashboard";
return NextResponse.redirect(url);
}
return supabaseResponse;
} }
export const config = { export const config = {