-
Notifications
You must be signed in to change notification settings - Fork 38
/
Copy pathmiddleware-example.ts
45 lines (39 loc) · 1.17 KB
/
middleware-example.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
43
44
45
import authConfig from "@/auth.config"
import NextAuth from "next-auth"
import {
DEFAULT_LOGIN_REDIRECT,
apiAuthPrefix,
authRoutes,
publicRoutes,
} from "@/routes"
const { auth } = NextAuth(authConfig)
export default auth((req):any => {
const { nextUrl } = req;
const isLoggedIn = !!req.auth;
// api routes
const isApiAuthRoute = nextUrl.pathname.startsWith(apiAuthPrefix);
// non auth routes
const isPublicRoute = publicRoutes.includes(nextUrl.pathname);
//private routes
const isAuthRoute = authRoutes.includes(nextUrl.pathname);
// Allow every api route
if(isApiAuthRoute) {
return null;
}
// check if user is logged in, then reroute or display page based on status
if(isAuthRoute) {
if(isLoggedIn) {
return Response.redirect(new URL(DEFAULT_LOGIN_REDIRECT, nextUrl));
}
return null;
}
// if user is not logged in and route is not public, redirect to home page
if (!isLoggedIn && !isPublicRoute) {
return Response.redirect(new URL('/auth/register', nextUrl));
}
return null;
})
// Optionally, don't invoke Middleware on some paths
export const config = {
matcher: ['/((?!.+\\.[\\w]+$|_next).*)', '/', '/(api|trpc)(.*)'],
}