-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmiddleware.ts
42 lines (34 loc) · 1.7 KB
/
middleware.ts
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
import {authMiddleware, redirectToSignIn} from "@clerk/nextjs";
import {NextResponse} from "next/server";
// This example protects all routes including api/trpc routes
// Please edit this to allow other routes to be public as needed.
// See https://clerk.com/docs/references/nextjs/auth-middleware for more information about configuring your Middleware
export default authMiddleware({
publicRoutes: ["/","/api/v1/webhook"],
afterAuth(auth, req ) {
// If the user is logged in and is trying to access a public route, redirect them to the org selection page
if(auth.userId && auth.isPublicRoute) {
let path = "/select-org";
// If the user is already in an org, redirect them to that org
if(auth.orgId) {
path = `/organization/${auth.orgId}`;
}
const orgSelection = new URL(path, req.url);
return NextResponse.redirect(orgSelection.href);
}
// If the user is not logged in and is trying to access a protected route, redirect them to the sign-in page, then redirect them back to the protected route
if (!auth.userId && !auth.isPublicRoute) {
return redirectToSignIn({
returnBackUrl: req.url,
});
}
// If the user is logged in but does not have an org, and page path isn't select-org, redirect them to the org selection page
if (auth.userId && !auth.orgId && req.nextUrl.pathname !== "/select-org") {
const orgSelection = new URL("/select-org", req.url);
return NextResponse.redirect(orgSelection);
}
}
});
export const config = {
matcher: ['/((?!.+\\.[\\w]+$|_next).*)', '/', '/(api|trpc)(.*)'],
};