Distributed cache * cache deleteKey now uses an options object instead of a lonely argument variable fuzzy * merge * remove debug logs and cleanup * cleanup * add fault handling * add fault handling * add pid when logging redis client creation * add identifier when logging redis client creation * cleanup * feat: add redis-api as it's own app * feature: use http wrapper for redis * feat: add the possibility to fallback to unstable_cache * Add error handling if redis cache is unresponsive * add logging for unstable_cache * merge * don't cache errors * fix: metadatabase on branchdeploys * Handle when /en/destinations throws add ErrorBoundary * Add sentry-logging when ErrorBoundary catches exception * Fix error handling for distributed cache * cleanup code * Added Application Insights back * Update generateApiKeys script and remove duplicate * Merge branch 'feature/redis' of bitbucket.org:scandic-swap/web into feature/redis * merge Approved-by: Linus Flood
49 lines
1.5 KiB
TypeScript
49 lines
1.5 KiB
TypeScript
import { type NextMiddleware, NextResponse } from "next/server"
|
|
|
|
import { REDEMPTION, SEARCHTYPE } from "@/constants/booking"
|
|
import { login } from "@/constants/routes/handleAuth"
|
|
import { getPublicNextURL } from "@/server/utils"
|
|
|
|
import { auth } from "@/auth"
|
|
import { findLang } from "@/utils/languages"
|
|
|
|
import { getDefaultRequestHeaders } from "./utils"
|
|
|
|
import type { MiddlewareMatcher } from "@/types/middleware"
|
|
|
|
export const middleware: NextMiddleware = async (request) => {
|
|
// Redirect user to login if reward nights search and not logged in
|
|
const isRedemption =
|
|
request.nextUrl.searchParams.get(SEARCHTYPE) === REDEMPTION
|
|
const session = await auth() // Check for user session
|
|
if (isRedemption && (!session || session?.error)) {
|
|
const lang = findLang(request.nextUrl.pathname)!
|
|
const nextUrlPublic = getPublicNextURL(request)
|
|
const headers = new Headers()
|
|
headers.append(
|
|
"set-cookie",
|
|
`redirectTo=${encodeURIComponent(nextUrlPublic.href)}; Path=/; HttpOnly; SameSite=Lax`
|
|
)
|
|
|
|
const loginUrl = login[lang]
|
|
const redirectUrl = new URL(loginUrl, nextUrlPublic)
|
|
const redirectOpts = {
|
|
headers,
|
|
}
|
|
return NextResponse.redirect(redirectUrl, redirectOpts)
|
|
}
|
|
|
|
const headers = getDefaultRequestHeaders(request)
|
|
return NextResponse.next({
|
|
request: {
|
|
headers,
|
|
},
|
|
})
|
|
}
|
|
|
|
export const matcher: MiddlewareMatcher = (request) => {
|
|
return !!request.nextUrl.pathname.match(
|
|
/^\/(da|de|en|fi|no|sv)\/(hotelreservation)/
|
|
)
|
|
}
|