Skip to main content

Async Python client for the Ghost Admin API

Project description

aioghost

Async Python client for the Ghost Admin API.

Installation

pip install aioghost

Quick Start

import asyncio
from aioghost import GhostAdminAPI

async def main():
    async with GhostAdminAPI(
        api_url="https://your-site.ghost.io",
        admin_api_key="your-admin-api-key"
    ) as api:
        # Get site info
        site = await api.get_site()
        print(f"Site: {site['title']}")

        # Get member counts
        members = await api.get_members_count()
        print(f"Total members: {members['total']}")
        print(f"Paid members: {members['paid']}")

        # Get MRR
        mrr = await api.get_mrr()
        print(f"MRR: ${mrr.get('usd', 0) / 100:.2f}")

asyncio.run(main())

Features

  • Fully async — Built on aiohttp for non-blocking I/O
  • Type hints — Full type annotations for IDE support
  • Context manager — Automatic session cleanup with async with
  • Parallel requests — Uses asyncio.gather() for efficient batching
  • Proper exceptions — Typed exceptions for different error cases

API Coverage

Endpoint Method
Site info get_site()
Posts count get_posts_count()
Latest post get_latest_post()
Members count get_members_count()
MRR get_mrr()
Newsletters get_newsletters()
Latest email get_latest_email()
Comments count get_comments_count()
Tiers get_tiers()
ActivityPub stats get_activitypub_stats()
Webhooks create_webhook(), delete_webhook()
Validate credentials validate_credentials()

Getting Your Admin API Key

  1. Log in to your Ghost Admin panel
  2. Go to Settings → Integrations
  3. Click Add custom integration
  4. Copy the Admin API Key (format: id:secret)

Exceptions

from aioghost import (
    GhostError,           # Base exception
    GhostAuthError,       # Invalid API key
    GhostConnectionError, # Network error
    GhostNotFoundError,   # 404 response
    GhostValidationError, # Invalid request
)

Passing Your Own Session

If you want to reuse an existing aiohttp.ClientSession:

import aiohttp
from aioghost import GhostAdminAPI

async def main():
    async with aiohttp.ClientSession() as session:
        api = GhostAdminAPI(
            api_url="https://your-site.ghost.io",
            admin_api_key="your-key",
            session=session,
        )
        site = await api.get_site()
        # Session is NOT closed when api goes out of scope

 

Copyright & license

Copyright (c) 2013-2026 Ghost Foundation - Released under the MIT license. Ghost and the Ghost Logo are trademarks of Ghost Foundation Ltd. Please see our trademark policy for info on acceptable usage.

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

aioghost-0.3.0.tar.gz (87.8 kB view details)

Uploaded Source

Built Distribution

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

aioghost-0.3.0-py3-none-any.whl (8.0 kB view details)

Uploaded Python 3

File details

Details for the file aioghost-0.3.0.tar.gz.

File metadata

  • Download URL: aioghost-0.3.0.tar.gz
  • Upload date:
  • Size: 87.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for aioghost-0.3.0.tar.gz
Algorithm Hash digest
SHA256 cf30d6e37afd45221c3fde9cc3c6cbd5777a1e4c5c484d8c7819e6e3fd042fae
MD5 f775d7d19f38242f65219ea0f3570431
BLAKE2b-256 397261ff29c220c9296f66db6e352502a945dac7f4ebf9e5299ee4c3bbc95856

See more details on using hashes here.

Provenance

The following attestation bundles were made for aioghost-0.3.0.tar.gz:

Publisher: publish.yml on TryGhost/aioghost

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

File details

Details for the file aioghost-0.3.0-py3-none-any.whl.

File metadata

  • Download URL: aioghost-0.3.0-py3-none-any.whl
  • Upload date:
  • Size: 8.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for aioghost-0.3.0-py3-none-any.whl
Algorithm Hash digest
SHA256 4a318f0c8fb843f6b0ce6ae0fddabb6bddfe80aa259b95c9a932b6834e27d006
MD5 3da9fd7ceb76bd0acdc84454856716e5
BLAKE2b-256 8463ad85f9fd9360c65541afb7b4097f39958f68d72091de4139f019e1eeae50

See more details on using hashes here.

Provenance

The following attestation bundles were made for aioghost-0.3.0-py3-none-any.whl:

Publisher: publish.yml on TryGhost/aioghost

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