Skip to main content

OpenGraph and Twitter meta-tag emission for Sphinx — matplotlib-free

Project description

sphinx-gp-opengraph

OpenGraph meta-tag emission for Sphinx — a drop-in replacement for sphinxext-opengraph that ships every ogp_* config key the upstream supports, minus the matplotlib-based social-card generator. No image-rendering dependencies, no system-fontconfig surprises.

Part of the gp-sphinx documentation platform.

Install

$ pip install sphinx-gp-opengraph

When you depend on gp-sphinx, this extension is already loaded — see Auto-derived values below. The full config-key reference is auto-generated on the package docs page from the live app.add_config_value() registrations.

Minimum viable conf.py

extensions = [
    "sphinx_gp_opengraph",
]
ogp_site_url = "https://example.com/"
ogp_image = "_static/og-default.png"

A 1200×630 PNG works on Slack, Facebook, LinkedIn, and X/Twitter unfurlers. With these three values set, every page rendered by an HTML-family builder gains og:title, og:type, og:url, og:site_name, og:description, og:image, and og:image:alt. A matching <meta name="description"> is emitted when the page does not already define one.

Auto-derived values when used with gp-sphinx

Projects that build through {py:func}gp_sphinx.config.merge_sphinx_config do not need to set ogp_site_url, ogp_site_name, or ogp_image manually. Pass docs_url= to merge_sphinx_config() and gp-sphinx fills all three from that one value. See the sphinx-gp-opengraph package page for the integration story and configuration.md for the canonical mapping table.

Per-page overrides

Set front-matter fields to override the site-wide defaults on a single page. MyST syntax shown; reST field-list syntax behaves the same way.

---
ogp_description_length: 160
og:image: _static/og/this-page.png
og:image:alt: A tailored hero for this page
---

# Page title

Body paragraph that becomes og:description.
Field Effect
og:image Replace the site-default image for this page
og:image:alt Replace the alt text for this page
ogp_description_length Override the description-length cap for this page
ogp_disable: true Skip OpenGraph emission entirely on this page

Any other og:* field-list entry is forwarded to the page head verbatim, so og:type, og:audio, etc. work without code changes.

Twitter cards

sphinx-gp-opengraph does not register a separate twitter_* namespace; crawlers fall back to og:* for most fields. Append explicit Twitter markup through ogp_custom_meta_tags when you need it:

ogp_custom_meta_tags = [
    '<meta name="twitter:card" content="summary_large_image" />',
    '<meta property="og:image:width" content="1200" />',
    '<meta property="og:image:height" content="630" />',
]

Migration from sphinxext-opengraph

Configuration is drop-in compatible — every ogp_* key is registered with the same name, type, and default — with one behavioural change:

  • ogp_social_cards is accepted but ignored. sphinx-gp-opengraph does not bundle the matplotlib-based card generator the upstream ships. Setting the value emits one WARNING at config-inited:

    sphinx-gp-opengraph: ogp_social_cards ignored — sphinx-gp-opengraph ships no card generator
    

    Grep your build log for ogp_social_cards ignored to find this warning. The replacement workflow lives in the next section.

The recommended replacement is one static PNG per page. Drop them under _static/og/ and point the per-page og:image field-list entry at each one. The downstream UX is the same as upstream's auto-generated cards — just explicit, and with no build-time dependency on matplotlib or PIL.

docs/
├── _static/
│   └── og/
│       ├── default.png
│       ├── quickstart.png
│       └── reference.png
├── quickstart.md
└── reference.md
---
og:image: _static/og/quickstart.png
---

# Quickstart

See also

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

sphinx_gp_opengraph-0.0.1a11.tar.gz (11.8 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

sphinx_gp_opengraph-0.0.1a11-py3-none-any.whl (12.2 kB view details)

Uploaded Python 3

File details

Details for the file sphinx_gp_opengraph-0.0.1a11.tar.gz.

File metadata

  • Download URL: sphinx_gp_opengraph-0.0.1a11.tar.gz
  • Upload date:
  • Size: 11.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for sphinx_gp_opengraph-0.0.1a11.tar.gz
Algorithm Hash digest
SHA256 39ee8ae7a02c52f9fb87ea4c40c034d6b0c47576c06e7cab2e78b9c438ecc85c
MD5 5b71de94cbb3d175dac3928ae770107d
BLAKE2b-256 bf496b658ee64f71f14b2c9b08bf4d206d9bfe0e2a3685d879181a0423720b40

See more details on using hashes here.

Provenance

The following attestation bundles were made for sphinx_gp_opengraph-0.0.1a11.tar.gz:

Publisher: release.yml on git-pull/gp-sphinx

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file sphinx_gp_opengraph-0.0.1a11-py3-none-any.whl.

File metadata

File hashes

Hashes for sphinx_gp_opengraph-0.0.1a11-py3-none-any.whl
Algorithm Hash digest
SHA256 d86a12dac6a400ac8ef8a5a8e6a6187a696ae08db047fcd03ae1bdbc2a59416a
MD5 6bbcd2e9842d3a140a02f5420f0f9b30
BLAKE2b-256 60f49a3d1919030c83a84c273941ba79eab6b18417ac8f48eac6ea4ac5478f53

See more details on using hashes here.

Provenance

The following attestation bundles were made for sphinx_gp_opengraph-0.0.1a11-py3-none-any.whl:

Publisher: release.yml on git-pull/gp-sphinx

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page