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

License

MIT License - see LICENSE for details.

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.2.0.tar.gz (71.1 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.2.0-py3-none-any.whl (7.7 kB view details)

Uploaded Python 3

File details

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

File metadata

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

File hashes

Hashes for aioghost-0.2.0.tar.gz
Algorithm Hash digest
SHA256 6280fc0b506ba41b3487fd60d4f08e6df6200db0bda89527c59c47ba2825bb34
MD5 e649c73bf0a4ba2ca76cf9e8a585daed
BLAKE2b-256 768d49bed67d433184bdd264ad2fa033da1843f2790c33f55e75b9f974e72774

See more details on using hashes here.

Provenance

The following attestation bundles were made for aioghost-0.2.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.2.0-py3-none-any.whl.

File metadata

  • Download URL: aioghost-0.2.0-py3-none-any.whl
  • Upload date:
  • Size: 7.7 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.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 b3d1a57b55776a61685d2c36eac993e4b5a90cf37ebe583f2e239940ba5e8567
MD5 cdaf58abc6090cd0fe5806a31bc048e4
BLAKE2b-256 72022f48ff99e84d334237c0258a6ddc0de587637849b66281c0622fd2cecd30

See more details on using hashes here.

Provenance

The following attestation bundles were made for aioghost-0.2.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