Files
website/astro/src/pages/sitemap/projects.xml.ts
2026-03-07 21:00:47 +01:00

48 lines
1.3 KiB
TypeScript

import { getSettings } from "@/content/settings/settings";
import type { APIRoute } from "astro";
import minifyXML from "minify-xml";
export const GET = (async () => {
const settings = await getSettings();
if (!settings.blog.enabled) {
return new Response(null, {
status: 204,
statusText: "Not Found"
});
}
const projectCount = 250;
const perPage = settings.sitemap.perPage;
const pages = Math.ceil(projectCount / perPage);
let sitemaps: SitemapIndex[] = [];
for (let i = 0; i < pages; i++) {
sitemaps.push({
url: `/sitemap/projects-${i + 1}.xml`,
lastModified: new Date()
});
}
let sitemapContent = `
<?xml version="1.0" encoding="UTF-8"?>
<sitemapindex xmlns="http://www.sitemaps.org/schemas/sitemap/0.9">
${sitemaps.map((item) => `
<sitemap>
<loc>${settings.website.domainName}${item.url}</loc>
<lastmod>${item.lastModified.toISOString()}</lastmod>
</sitemap>
`).join('')}
</sitemapindex>
`;
return new Response(minifyXML(sitemapContent), {
status: 200,
statusText: "OK",
headers: {
"Content-Type": "application/xml"
}
});
}) satisfies APIRoute;