Files
website/astro/src/pages/sitemap/albums.xml.ts
2026-03-08 22:38:18 +01:00

69 lines
1.9 KiB
TypeScript

import { getAllAlbums } from "@/content/photos/albums";
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.photo.enabled) {
return new Response(null, {
status: 204,
statusText: "Not Found"
});
}
const albums = await getAllAlbums(settings);
const albumCount = albums.length;
const perPage = settings.sitemap.perPage;
const pages = Math.ceil(albumCount / perPage);
let sitemaps: SitemapIndex[] = [];
for (let i = 0; i < pages; i++) {
const selectedProjects = albums.slice(
((Number(i + 1) - 1) * settings.sitemap.perPage),
Number(i + 1) * settings.sitemap.perPage - 1
);
let dates = [
settings.sitemap.lastModified,
settings.photo.lastModified,
settings.website.lastModified
];
selectedProjects.forEach((project) => {
dates.push(project.lastModified);
});
const lastModified = dates.sort((a: Date, b: Date) => {
return b.getTime() - a.getTime();
});
sitemaps.push({
url: `/sitemap/albums-${i + 1}.xml`,
lastModified: lastModified[0]
});
}
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;