mirror of
https://github.com/linsa-io/linsa.git
synced 2026-01-12 12:20:23 +01:00
chore: refactor clerk middleware and add readme for route protection (#147)
This commit is contained in:
@@ -1,23 +1,32 @@
|
||||
import { clerkMiddleware, createRouteMatcher } from '@clerk/nextjs/server'
|
||||
import { clerkMiddleware, createRouteMatcher } from "@clerk/nextjs/server"
|
||||
|
||||
const isPublicRoute = createRouteMatcher([
|
||||
'/sign-in(.*)',
|
||||
'/sign-up(.*)',
|
||||
'/',
|
||||
'/:topicName(.*)'
|
||||
])
|
||||
const ROUTE_PATTERNS = {
|
||||
public: ["/sign-in(.*)", "/sign-up(.*)", "/", "/:topicName(.*)"],
|
||||
protected: [
|
||||
"/edit-profile(.*)",
|
||||
"/links(.*)",
|
||||
"/pages(.*)",
|
||||
"/profile(.*)",
|
||||
"/search(.*)",
|
||||
"/settings(.*)",
|
||||
"/tauri(.*)"
|
||||
]
|
||||
}
|
||||
|
||||
const isPublicRoute = createRouteMatcher(ROUTE_PATTERNS.public)
|
||||
const isProtectedRoute = createRouteMatcher(ROUTE_PATTERNS.protected)
|
||||
|
||||
export default clerkMiddleware((auth, request) => {
|
||||
if (!isPublicRoute(request)) {
|
||||
auth().protect()
|
||||
}
|
||||
if (isProtectedRoute(request) || !isPublicRoute(request)) {
|
||||
auth().protect()
|
||||
}
|
||||
})
|
||||
|
||||
export const config = {
|
||||
matcher: [
|
||||
// Skip Next.js internals and all static files, unless found in search params
|
||||
'/((?!_next|[^?]*\\.(?:html?|css|js(?!on)|jpe?g|webp|png|gif|svg|ttf|woff2?|ico|csv|docx?|xlsx?|zip|webmanifest)).*)',
|
||||
// Always run for API routes
|
||||
'/(api|trpc)(.*)'
|
||||
]
|
||||
matcher: [
|
||||
// Skip Next.js internals and all static files, unless found in search params
|
||||
"/((?!_next|[^?]*\\.(?:html?|css|js(?!on)|jpe?g|webp|png|gif|svg|ttf|woff2?|ico|csv|docx?|xlsx?|zip|webmanifest)).*)",
|
||||
// Always run for API routes
|
||||
"/(api|trpc)(.*)"
|
||||
]
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user