fix(auth): use redirectToSignIn in Clerk middleware

This commit is contained in:
Ishaan (OpenClaw)
2026-02-07 20:04:23 +00:00
parent ed2556c871
commit 7b4c40ae0b

View File

@@ -12,10 +12,16 @@ const isClerkEnabled = () =>
const isPublicRoute = createRouteMatcher(["/sign-in(.*)"]);
export default isClerkEnabled()
? clerkMiddleware(async (auth, req) => {
? clerkMiddleware((auth, req) => {
if (isPublicRoute(req)) return NextResponse.next();
const session = await auth();
session.protect();
// Clerk typings in App Router return SessionAuthWithRedirect.
// Use redirectToSignIn() instead of protect(). Keep middleware callback sync.
const { userId, redirectToSignIn } = auth();
if (!userId) {
return redirectToSignIn({ returnBackUrl: req.url });
}
return NextResponse.next();
})
: () => NextResponse.next();