Files
web/middlewares/cmsContent.ts
Simon.Emanuelsson 67239b5a8f Merged in fix/current-content-page-searchparams (pull request #186)
fix: uri was never added to searchParams for current content page resulting in 404

Approved-by: Michael Zetterberg
2024-05-20 11:19:07 +00:00

86 lines
2.3 KiB
TypeScript

import { headers } from "next/headers"
import { NextResponse } from "next/server"
import { findLang } from "@/constants/languages"
import { notFound } from "@/server/errors/next"
import { resolve as resolveEntry } from "@/utils/entry"
import { getDefaultRequestHeaders } from "./utils"
import type { NextMiddleware } from "next/server"
import { MiddlewareMatcher } from "@/types/middleware"
export const middleware: NextMiddleware = async (request) => {
const { nextUrl } = request
const lang = findLang(nextUrl.pathname)!
const pathNameWithoutLang = nextUrl.pathname.replace(`/${lang}`, "")
const searchParams = new URLSearchParams(request.nextUrl.searchParams)
const { contentType, uid } = await resolveEntry(pathNameWithoutLang, lang)
if (!contentType || !uid) {
throw notFound(
`Unable to resolve CMS entry for locale "${lang}": ${pathNameWithoutLang}`
)
}
const headers = getDefaultRequestHeaders(request)
headers.set("x-uid", uid)
const isCurrent = contentType ? contentType.indexOf("current") >= 0 : false
if (request.nextUrl.pathname.includes("/preview")) {
if (isCurrent) {
searchParams.set("uri", pathNameWithoutLang.replace("/preview", ""))
return NextResponse.rewrite(
new URL(`/${lang}/preview-current?${searchParams.toString()}`, nextUrl)
)
}
return NextResponse.rewrite(
new URL(
`/${lang}/preview/${contentType}/${uid}?${searchParams.toString()}`,
nextUrl
),
{
request: {
headers,
},
}
)
}
if (isCurrent) {
searchParams.set("uri", pathNameWithoutLang)
return NextResponse.rewrite(
new URL(
`/${lang}/current-content-page?${searchParams.toString()}`,
nextUrl
)
)
}
return NextResponse.rewrite(
new URL(
`/${lang}/${contentType}/${uid}?${searchParams.toString()}`,
nextUrl
),
{
request: {
headers,
},
}
)
}
export const matcher: MiddlewareMatcher = (request) => {
// Do not process paths with file extension.
// Only looking for dot might be too brute force/give false positives.
// It works right now but adjust accordingly when new use cases/data emerges.
const lastPathnameSegment = request.nextUrl.pathname.split("/").pop()
return lastPathnameSegment?.indexOf(".") === -1
}