Files
web/apps/scandic-web/app/sitemap/[sitemapId]/route.ts
Joakim Jäderberg daf765f3d5 Merged in feature/wrap-logging (pull request #2511)
Feature/wrap logging

* feat: change all logging to go through our own logger function so that we can control log levels

* move packages/trpc to using our own logger

* merge


Approved-by: Linus Flood
2025-07-03 12:37:04 +00:00

52 lines
1.4 KiB
TypeScript

import { notFound } from "next/navigation"
import { createLogger } from "@scandic-hotels/common/logger/createLogger"
import { getSitemapDataById } from "@/utils/sitemap"
import type { NextRequest } from "next/server"
export const dynamic = "force-dynamic"
const sitemapLogger = createLogger("sitemap")
export async function GET(
_request: NextRequest,
context: { params: Promise<{ sitemapId: string }> }
) {
const params = await context.params
const sitemapId = params.sitemapId
sitemapLogger.debug("Fetching sitemap by ID", sitemapId)
if (!sitemapId) {
return notFound()
}
const sitemapData = await getSitemapDataById(Number(sitemapId))
if (!sitemapData.length) {
return notFound()
}
const entries = sitemapData.map((entry) => {
const alternates = Object.entries(entry.alternates).map(
([lang, url]) =>
`<xhtml:link rel="alternate" hreflang="${lang}" href="${url}" />`
)
return `
<url>
<loc>${entry.url}</loc>
<lastmod>${entry.lastModified}</lastmod>
<changefreq>${entry.changeFrequency}</changefreq>
<priority>${entry.priority}</priority>
${alternates.join("")}
</url>`
})
const sitemapXML = `<?xml version="1.0" encoding="UTF-8"?>\n<urlset xmlns="http://www.sitemaps.org/schemas/sitemap/0.9" xmlns:xhtml="http://www.w3.org/1999/xhtml">${entries.join("")}\n</urlset>`
return new Response(sitemapXML, {
headers: { "Content-Type": "application/xml" },
})
}