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 = params.page; 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 = ` ${pages.map((page) => ` ${settings.website.domainName}${page.url} ${page.lastModified.toISOString()} `).join('')} `; 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).toString() } }); } return items; }