xtract.bot

OG image generator

Try it interactively →
POST /api/og-image-generate

Generate Open Graph (og:image) share-card images dynamically. Configurable title, subtitle, theme, and accent colour. 1200×630 default — the standard OG size.

Generates Open Graph / Twitter share-card images at the standard 1200×630 resolution — the size every social network expects. Inputs: - `title`, `subtitle`: text content. - `theme`: visual style preset. - `accentColor`: hex colour used for highlights / accents. - `logo` (optional): a logo PNG to render in a corner. Use this in your CDN-cached `/og` route so each blog post, product, or page gets a unique share image without you having to design one in Figma.

Inputs

NameTypeDefaultDescription
title*stringBig headline (1–200 chars).
subtitlestringOptional subhead under the title (max 300 chars).
brandstringOptional brand label rendered bottom-left (max 64 chars).
backgroundstring"#0f172a"Background colour (CSS hex, e.g. #0f172a).
accentstring"#0ea5e9"Accent colour for the rule + brand mark.
titleColorstring"#ffffff"Title text colour.
subtitleColorstring"#cbd5e1"Subtitle text colour.
widthnumber (200…4000)1200Output width in px. 1200 = OpenGraph standard.
heightnumber (200…4000)630Output height in px. 630 = OpenGraph standard.

Response

Modes: binary, base64-json. Cache: yes (24h TTL).

Code samples

Built from the default example.


curl -X POST https://api.xtract.bot/api/og-image-generate \
  -H "Content-Type: application/json" \
  -H "Accept: application/octet-stream" \
  -H "X-Account-Id: $XTRACT_ACCOUNT_ID" \
  -H "X-Api-Key: $XTRACT_API_KEY" \
  -d '{
  "title": "xtract.bot — file conversion API for developers"
}'