Skip to main content

Python SDK for the Hot Dev API

Project description

hot-dev

Official Python SDK for the Hot Dev API.

  • PyPI distribution: hot-dev
  • Import package: hot
  • Tested on Python 3.10, 3.11, 3.12, 3.13

Install

pip install hot-dev

Quick Start

import os

from hot import HotClient

hot = HotClient(token=os.environ["HOT_API_KEY"])

# base_url defaults to https://api.hot.dev.
# For local development with `hot dev`, pass base_url="http://localhost:4681".

for event in hot.streams.subscribe_with_event(
    {
        "event_type": "team-agent:ask",
        "event_data": {
            "session_id": "web:chat:demo",
            "user_id": "web:user:demo",
            "user_name": "Demo User",
            "question": "what is blocking launch?",
        },
    }
):
    if event["type"] == "stream:data":
        print(event["data_type"], event.get("payload"))

    if event["type"] == "run:stop":
        print(event.get("run", {}).get("result"))
        break

The client closes its underlying HTTP connection cleanly when used as a context manager:

with HotClient(token=os.environ["HOT_API_KEY"]) as hot:
    event = hot.events.publish(
        {
            "event_type": "team-agent:ask",
            "event_data": {"question": "what changed?"},
        }
    )
    print(event["stream_id"])

Authenticated clients should run server-side. Browser apps and public notebooks should call your own backend route instead of exposing a Hot API key.

Async Usage

import os

from hot import AsyncHotClient

async with AsyncHotClient(token=os.environ["HOT_API_KEY"]) as hot:
    event = await hot.events.publish(
        {
            "event_type": "team-agent:ask",
            "event_data": {"question": "what changed?"},
        }
    )
    print(event["stream_id"])

Async streaming is supported the same way:

async with AsyncHotClient(token=os.environ["HOT_API_KEY"]) as hot:
    async for event in hot.streams.subscribe_with_event(
        {
            "event_type": "team-agent:ask",
            "event_data": {"question": "what changed?"},
        }
    ):
        print(event["type"], event)

Errors

Non-2xx API responses raise HotApiError with structured fields:

from hot import HotApiError

try:
    hot.projects.get("missing-project")
except HotApiError as error:
    print(error.status_code, error.code, error.request_id)

Resources

HotClient mirrors the Hot API v1 resources:

  • hot.events — publish, list, get, and inspect event runs
  • hot.streams — subscribe to run streams and publish events atomically (reconnects automatically across the 5-minute SSE timeout; pass reconnect=False to opt out)
  • hot.runs — list, inspect, and view run stats
  • hot.files — upload, download, list, and delete files (including multipart uploads)
  • hot.projects — create, list, update, activate, deactivate, and delete projects
  • hot.builds — upload, download, deploy, and look up live/deployed builds
  • hot.context — manage encrypted project context variables
  • hot.domains — register, verify, list, and delete custom domains
  • hot.sessions — create and revoke scoped sessions
  • hot.service_keys — create and revoke scoped service keys
  • hot.org — view usage and limits
  • hot.env — read environment info and subscribe to environment events

Use hot.request(...) or hot.request_raw(...) as an escape hatch for API endpoints that do not yet have a resource helper.

Customizing the HTTP Client

HotClient and AsyncHotClient accept an httpx.Client (or httpx.AsyncClient) via the client= argument. Use this to configure retries, proxies, or custom transports:

import httpx

from hot import HotClient

http_client = httpx.Client(
    timeout=httpx.Timeout(connect=5.0, read=60.0, write=30.0, pool=5.0),
    transport=httpx.HTTPTransport(retries=3),
)

hot = HotClient(token=os.environ["HOT_API_KEY"], client=http_client)

When you pass your own client, the SDK does not close it on exit.

Casing Policy

Core API request and response payloads use the Hot API wire format: event_type, event_data, stream_id, and so on. SDK-only options use Python style names such as base_url and timeout.

The SDK never transforms user-owned payloads such as event_data.

Type Hints

The package ships with py.typed, so editors and type checkers will pick up the public API. Request and response payloads are currently typed as plain dict[str, Any] — keys follow the Hot API wire format documented above. Strict TypedDict shapes generated from the Hot API OpenAPI spec are planned for a future release.

Local Development

python -m venv .venv
source .venv/bin/activate
python -m pip install -e ".[dev]"
ruff check .
pytest
python -m build

Related

License

Apache-2.0

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

hot_dev-1.1.0.tar.gz (15.1 kB view details)

Uploaded Source

Built Distribution

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

hot_dev-1.1.0-py3-none-any.whl (14.3 kB view details)

Uploaded Python 3

File details

Details for the file hot_dev-1.1.0.tar.gz.

File metadata

  • Download URL: hot_dev-1.1.0.tar.gz
  • Upload date:
  • Size: 15.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for hot_dev-1.1.0.tar.gz
Algorithm Hash digest
SHA256 c3f30afc45f3875766f68f2188bf50187ce7cebc4d4fdc71f7c28875b3535165
MD5 0804f74f7fde17b21199f744c0abd0a5
BLAKE2b-256 1c8b7a9351ca03527647981d2070c6d8502b7bdf25d89f158230d14f67112817

See more details on using hashes here.

Provenance

The following attestation bundles were made for hot_dev-1.1.0.tar.gz:

Publisher: release.yml on hot-dev/hot-python

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

File details

Details for the file hot_dev-1.1.0-py3-none-any.whl.

File metadata

  • Download URL: hot_dev-1.1.0-py3-none-any.whl
  • Upload date:
  • Size: 14.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for hot_dev-1.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 8e82f486c84303709ad96bb65e9841b42c8abe5c5d1fb13398229c7aab44a052
MD5 78b51483b74a7747f34fcd3daaff7f47
BLAKE2b-256 8b5dc037d06fdf29584b54df840765864c126fa67368ee22682ba903992bd039

See more details on using hashes here.

Provenance

The following attestation bundles were made for hot_dev-1.1.0-py3-none-any.whl:

Publisher: release.yml on hot-dev/hot-python

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