aboutsummaryrefslogtreecommitdiff
path: root/src/integrations/ogImages.ts
blob: 5d9146cc864f7f6adca24d2bfd83f2e8be6f7ed2 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
import type { AstroIntegration } from "astro";
import { createOgImage } from "../utils/createOgImage";
import { globby } from "globby";
import fs from "fs/promises";
import matter from "gray-matter";
import path from "path";

const postsDir = path.resolve("./src/content/blog");
const outDir = path.resolve("./public/images/preview");

export default function ogImageGenerator(): AstroIntegration {
	return {
		name: "og-images",
		hooks: {
			"astro:build:setup": async ({ logger }) => {
				await fs.mkdir(outDir, { recursive: true });
				const mdFiles = await globby("*.md", { cwd: postsDir });
				logger.info(`${mdFiles.length} posts found`);

				const results = await Promise.allSettled(
					mdFiles.map(async (file) => {
						const slug = file.replace(/\.md$/, "");
						const content = await fs.readFile(path.join(postsDir, file), "utf-8");
						const { data } = matter(content);

						const png = await createOgImage(data.title, data.datePublished);
						const outPath = path.join(outDir, `${slug}.png`);
						await fs.writeFile(outPath, png);

						logger.info(`OG image created: ${slug}`);
					})
				);

				results.forEach((r) => {
					if (r.status === "rejected") {
						logger.error(`Error for ${r.reason.slug}: ${r.reason.message}`);
					}
				});

				const failures = results.filter((r) => r.status === "rejected");
				if (failures.length) {
					throw new Error(`Failed to generate OG images for ${failures.length} posts`);
				}
			},
		},
	};
}