Skip to main content

Typed async Python SDK for daimon MCP services.

Project description

daimon-sdk

Typed async Python SDK for processd-mcp and processd-sandbox-manager.

daimon-sdk wraps the raw MCP tool surface exposed by processd-mcp and presents it as grouped Python APIs such as client.files.read() and client.exec.start_session(). The SDK keeps processd-standalone as the contract source of truth and focuses on:

  • connection and token wiring
  • manager sandbox lifecycle helpers
  • typed request/response handling
  • structured tool error mapping
  • interactive session helpers
  • compatibility tests against a real processd-mcp binary

Install

pip install daimon-sdk

For local development:

pip install -e ".[dev]"

Quickstart

With a sandbox manager:

import asyncio

from daimon_sdk import DaimonManagerClient


async def main() -> None:
    async with DaimonManagerClient("http://127.0.0.1:18080") as manager:
        async with manager.sandbox() as sandbox:
            runtime = await sandbox.runtime.get_context()
            print(runtime.base_workdir)

            result = await sandbox.exec.bash("python3 --version")
            print(result.stdout or result.stderr)


asyncio.run(main())

If you already have a sandbox MCP URL and token, connect directly to MCP:

import asyncio

from daimon_sdk import DaimonClient


async def main() -> None:
    async with DaimonClient("http://127.0.0.1:8080/mcp") as client:
        runtime = await client.runtime.get_context()
        print(runtime.base_workdir)

        result = await client.files.glob("**/*.rs", path=runtime.base_workdir)
        print(result.filenames[:5])

        bash = await client.exec.bash("printf 'hello from processd\\n'")
        print(bash.stdout)


asyncio.run(main())

Raw MCP vs SDK

Raw MCP:

payload = await mcp_client.call_tool("Read", {"file_path": "/tmp/demo.txt"})

SDK:

read = await client.files.read("/tmp/demo.txt")
print(read.file.content)

API Overview

  • DaimonClient(base_url, access_token=None, timeout_s=30.0)
  • await client.connect() / await client.close()
  • async with DaimonClient(...) as client
  • client.runtime.get_context()
  • client.files.read() / write() / edit() / glob() / grep()
  • client.exec.bash() / start_session()
  • SessionHandle.write() / poll() / wait_for_exit() / close()
  • client.web.fetch()
  • client.raw.call_tool()
  • DaimonManagerClient(base_url, access_token=None, timeout_s=30.0)
  • await manager.health()
  • await manager.capacity()
  • await manager.create_sandbox()
  • await manager.find_sandbox(labels={"thread_id": thread_id})
  • await manager.find_or_create_sandbox(labels={"thread_id": thread_id})
  • await manager.get_sandbox(id)
  • await manager.start_sandbox(id) / stop_sandbox(id) / delete_sandbox(id)
  • await manager.update_sandbox(id, ttl_seconds=...)
  • async with manager.sandbox() as sandbox
  • await sandbox.set_ttl(ttl_seconds)
  • sandbox.service_ports
  • sandbox.get_service_port(port)
  • sandbox.runtime/files/exec/web/raw

manager.sandbox() creates a sandbox, connects to its MCP endpoint, and deletes it on context exit by default. Use delete_on_exit=False or create_sandbox() when the workspace should survive beyond the context. ttl_seconds=0 marks a sandbox as immediately expired so the next manager reaper loop deletes it.

Sandbox Service Ports

When a sandbox runs a service on a manager-configured port, the SDK exposes the connection information and leaves the request itself to your HTTP or WebSocket client:

import httpx

async with manager.sandbox() as sandbox:
    web = sandbox.get_service_port(3000)

    response = httpx.get(web.url + "hello.txt", headers=web.headers)
    print(response.text)

ServicePortInfo contains only port, url, token, and headers.

Local Testing

The SDK compatibility tests expect a sibling checkout of processd-standalone:

e2b-project/
  processd-standalone/
  processd-sdk/

Run tests with an environment that already has the dev dependencies installed:

PYTHONPATH=src python -m pytest -q

The E2E suite builds and launches ../processd-standalone/target/debug/processd-mcp.

Manager E2E uses the sibling processd-standalone Docker manager compose path:

PROCESSD_SDK_MANAGER_E2E=1 PYTHONPATH=src python -m pytest -q -m manager_e2e

Release

Releases are published from GitHub Actions when a tag matching v* is pushed.

git tag v0.4.0
git push origin v0.4.0

The tag version must match pyproject.toml's project version.

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

daimon_sdk-0.4.6.tar.gz (75.0 kB view details)

Uploaded Source

Built Distribution

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

daimon_sdk-0.4.6-py3-none-any.whl (14.4 kB view details)

Uploaded Python 3

File details

Details for the file daimon_sdk-0.4.6.tar.gz.

File metadata

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

File hashes

Hashes for daimon_sdk-0.4.6.tar.gz
Algorithm Hash digest
SHA256 302f70c8c7ad901956b11f89721b53fc30e9383e429be814c8bc73b5ea422eb1
MD5 9424ef3c5abdd9b8ddf173876f82b03a
BLAKE2b-256 8c67b25fcf5fcb2aced4c3fb0328d6867c71e6d94ba4a4b94a652e0190570dba

See more details on using hashes here.

Provenance

The following attestation bundles were made for daimon_sdk-0.4.6.tar.gz:

Publisher: publish.yml on daimon-hq/processd-sdk

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

File details

Details for the file daimon_sdk-0.4.6-py3-none-any.whl.

File metadata

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

File hashes

Hashes for daimon_sdk-0.4.6-py3-none-any.whl
Algorithm Hash digest
SHA256 65e14b5e0f2e275d1bfb2b7cbcd1c60d739847f191c4a0dd4eb78978396ba9e0
MD5 805c00cdc6bec3ff7facf60f244aa053
BLAKE2b-256 868148960bf7a26a551f730b19af40b4c2ebea6e711d3a18523aa3961603d0f6

See more details on using hashes here.

Provenance

The following attestation bundles were made for daimon_sdk-0.4.6-py3-none-any.whl:

Publisher: publish.yml on daimon-hq/processd-sdk

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