Fix middleware: skip homepage to prevent empty response
Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
This commit is contained in:
@@ -8,16 +8,22 @@ const protectedRoutes = ['/dashboard', '/settings', '/subscription']
|
|||||||
const authRoutes = ['/login', '/register']
|
const authRoutes = ['/login', '/register']
|
||||||
|
|
||||||
export async function middleware(request: NextRequest) {
|
export async function middleware(request: NextRequest) {
|
||||||
const { supabaseResponse, user } = await updateSession(request)
|
|
||||||
const { pathname } = request.nextUrl
|
const { pathname } = request.nextUrl
|
||||||
|
|
||||||
|
// Skip middleware for homepage - let it render statically
|
||||||
|
if (pathname === '/' || pathname === '') {
|
||||||
|
return NextResponse.next()
|
||||||
|
}
|
||||||
|
|
||||||
|
const { supabaseResponse, user } = await updateSession(request)
|
||||||
|
|
||||||
// Check if trying to access protected route without auth
|
// Check if trying to access protected route without auth
|
||||||
const isProtectedRoute = protectedRoutes.some(route =>
|
const isProtectedRoute = protectedRoutes.some(route =>
|
||||||
pathname.startsWith(route)
|
pathname.startsWith(route)
|
||||||
)
|
)
|
||||||
|
|
||||||
if (isProtectedRoute && !user) {
|
if (isProtectedRoute && !user) {
|
||||||
const redirectUrl = new URL('/login', request.url)
|
const redirectUrl = new URL('/login/', request.url)
|
||||||
// Save the original URL to redirect back after login
|
// Save the original URL to redirect back after login
|
||||||
redirectUrl.searchParams.set('redirectTo', pathname)
|
redirectUrl.searchParams.set('redirectTo', pathname)
|
||||||
return NextResponse.redirect(redirectUrl)
|
return NextResponse.redirect(redirectUrl)
|
||||||
@@ -29,7 +35,7 @@ export async function middleware(request: NextRequest) {
|
|||||||
)
|
)
|
||||||
|
|
||||||
if (isAuthRoute && user) {
|
if (isAuthRoute && user) {
|
||||||
return NextResponse.redirect(new URL('/dashboard', request.url))
|
return NextResponse.redirect(new URL('/dashboard/', request.url))
|
||||||
}
|
}
|
||||||
|
|
||||||
return supabaseResponse
|
return supabaseResponse
|
||||||
Reference in New Issue
Block a user