Files
website/astro/src/pages/sitemap/blogs-[page].xml.ts
2026-03-08 15:49:52 +01:00

71 lines
1.9 KiB
TypeScript

import { getAllBlogs } from "@/content/blogs/blogs";
import { getSettings } from "@/content/settings/settings";
import { getBlogRoute } from "@/lib/routing";
import type { APIRoute } from "astro";
import minifyXML from "minify-xml";
export const GET = (async ({ params }) => {
const settings = await getSettings();
if (!settings.blog.enabled) {
return new Response(null, {
status: 204,
statusText: "Not Found"
});
}
const currentPage = 1;
const blogs = await getAllBlogs(settings);
const selectedBlogs = blogs.slice(
((Number(currentPage) - 1) * settings.sitemap.perPage),
Number(currentPage) * settings.sitemap.perPage - 1
);
let pages: SitemapPage[] = [];
selectedBlogs.forEach((blog) => {
pages.push({
url: getBlogRoute(settings.blog, blog),
lastModified: blog.lastModified
});
})
let sitemapContent = `
<?xml version="1.0" encoding="UTF-8"?>
<sitemapindex xmlns="http://www.sitemaps.org/schemas/sitemap/0.9">
${pages.map((page) => `
<sitemap>
<loc>${settings.website.domainName}${page.url}</loc>
<lastmod>${page.lastModified.toISOString()}</lastmod>
</sitemap>
`).join('')}
</sitemapindex>
`;
return new Response(minifyXML(sitemapContent), {
status: 200,
statusText: "OK",
headers: {
"Content-Type": "application/xml"
}
});
}) satisfies APIRoute;
export async function getStaticPaths() {
const settings = await getSettings();
const blogs = await getAllBlogs(settings);
const blogCount = blogs.length;
const perPage = settings.sitemap.perPage;
const pages = Math.ceil(blogCount / perPage);
let items: any[] = [];
for (let i = 0; i < pages; i++) {
items.push({ params: { page: (i + 1) } });
}
return items;
}