2022-11-11 19:17:44 -08:00
|
|
|
import { getToken } from "next-auth/jwt"
|
|
|
|
import { withAuth } from "next-auth/middleware"
|
|
|
|
import { NextResponse } from "next/server"
|
2022-03-21 00:46:15 -07:00
|
|
|
|
2022-11-11 19:17:44 -08:00
|
|
|
export default withAuth(
|
|
|
|
async function middleware(req) {
|
|
|
|
const token = await getToken({ req })
|
2022-11-13 23:02:31 -08:00
|
|
|
|
2022-11-11 19:17:44 -08:00
|
|
|
const isAuth = !!token
|
|
|
|
const isAuthPage =
|
|
|
|
req.nextUrl.pathname.startsWith("/signup") ||
|
|
|
|
req.nextUrl.pathname.startsWith("/signin")
|
2022-03-21 00:46:15 -07:00
|
|
|
|
2022-11-11 19:17:44 -08:00
|
|
|
if (isAuthPage) {
|
|
|
|
if (isAuth) {
|
|
|
|
return NextResponse.redirect(new URL("/new", req.url))
|
|
|
|
}
|
2022-03-21 00:46:15 -07:00
|
|
|
|
2022-11-11 19:17:44 -08:00
|
|
|
return null
|
2022-04-09 17:48:19 -07:00
|
|
|
}
|
2022-04-12 16:54:02 -07:00
|
|
|
|
2022-11-11 19:17:44 -08:00
|
|
|
if (!isAuth) {
|
|
|
|
return NextResponse.redirect(new URL("/signin", req.url))
|
|
|
|
}
|
|
|
|
},
|
|
|
|
{
|
|
|
|
callbacks: {
|
|
|
|
async authorized() {
|
|
|
|
// This is a work-around for handling redirect on auth pages.
|
|
|
|
// We return true here so that the middleware function above
|
|
|
|
// is always called.
|
|
|
|
return true
|
|
|
|
}
|
2022-04-12 16:54:02 -07:00
|
|
|
}
|
2022-04-09 17:48:19 -07:00
|
|
|
}
|
2022-11-11 19:17:44 -08:00
|
|
|
)
|
2022-11-08 00:23:28 -08:00
|
|
|
|
|
|
|
export const config = {
|
2022-11-14 18:39:42 -08:00
|
|
|
matcher: [
|
2022-11-09 23:11:36 -08:00
|
|
|
// "/signout",
|
2022-11-09 18:38:05 -08:00
|
|
|
// "/",
|
2022-11-08 00:23:28 -08:00
|
|
|
"/signin",
|
|
|
|
"/signup",
|
|
|
|
"/new",
|
|
|
|
]
|
|
|
|
}
|