Some checks failed
Build & Deploy / 🔍 Prepare (push) Successful in 8s
Build & Deploy / 🧪 QA (push) Successful in 1m39s
Build & Deploy / 🏗️ Build (push) Successful in 2m59s
Build & Deploy / 🚀 Deploy (push) Successful in 27s
Build & Deploy / 🧪 Smoke Test (push) Failing after 52s
Build & Deploy / 🔔 Notify (push) Successful in 2s
- Added exhaustive PathRegexp whitelists in docker-compose.yml to bypass Gatekeeper. - Fixed TRAEFIK_HOST_RULE interpolation in deploy.yml. - Enhanced scripts/check-og-images.ts with header and body diagnostics. - Added server-side font loading logs in lib/og-helper.tsx.
47 lines
1.2 KiB
TypeScript
47 lines
1.2 KiB
TypeScript
import { readFileSync } from 'fs';
|
|
import { join } from 'path';
|
|
|
|
/**
|
|
* Loads the Inter fonts for use in Satori (Next.js OG Image generation).
|
|
* Since we are using runtime = 'nodejs', we can read them from the filesystem.
|
|
*/
|
|
export async function getOgFonts() {
|
|
const boldFontPath = join(process.cwd(), 'public/fonts/Inter-Bold.woff2');
|
|
const regularFontPath = join(process.cwd(), 'public/fonts/Inter-Regular.woff2');
|
|
|
|
try {
|
|
console.log(`[OG] Loading fonts: bold=${boldFontPath}, regular=${regularFontPath}`);
|
|
const boldFont = readFileSync(boldFontPath);
|
|
const regularFont = readFileSync(regularFontPath);
|
|
console.log(
|
|
`[OG] Fonts loaded successfully (${boldFont.length} and ${regularFont.length} bytes)`,
|
|
);
|
|
|
|
return [
|
|
{
|
|
name: 'Inter',
|
|
data: boldFont,
|
|
weight: 700 as const,
|
|
style: 'normal' as const,
|
|
},
|
|
{
|
|
name: 'Inter',
|
|
data: regularFont,
|
|
weight: 400 as const,
|
|
style: 'normal' as const,
|
|
},
|
|
];
|
|
} catch (error) {
|
|
console.error(`[OG] Failed to load fonts from ${process.cwd()}:`, error);
|
|
return [];
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Common configuration for OG images
|
|
*/
|
|
export const OG_IMAGE_SIZE = {
|
|
width: 1200,
|
|
height: 630,
|
|
};
|