CoastalCommitsPastes/src/middleware.ts

47 lines
916 B
TypeScript
Raw Normal View History

import { getToken } from "next-auth/jwt"
import { withAuth } from "next-auth/middleware"
import { NextResponse } from "next/server"
export default withAuth(
async function middleware(req) {
const token = await getToken({ req })
const isAuth = !!token
const isAuthPage =
req.nextUrl.pathname.startsWith("/signup") ||
req.nextUrl.pathname.startsWith("/signin")
if (isAuthPage) {
if (isAuth) {
return NextResponse.redirect(new URL("/new", req.url))
}
return null
2022-04-09 17:48:19 -07: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-09 17:48:19 -07: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
// "/",
"/signin",
"/signup",
"/new",
]
}