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-mcpbinary
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 clientclient.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_or_create_sandbox(labels={"thread_id": thread_id})await manager.get_sandbox(id)await manager.start_sandbox(id) / stop_sandbox(id) / delete_sandbox(id)async with manager.sandbox() as sandboxsandbox.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.
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
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file daimon_sdk-0.4.0.tar.gz.
File metadata
- Download URL: daimon_sdk-0.4.0.tar.gz
- Upload date:
- Size: 15.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
78d3c8e6d3967df08afa70a2986d9a2c1631a3effee983ccc16119010ad1ce33
|
|
| MD5 |
7bfeaa993a90e7095a30ee336ba0b82e
|
|
| BLAKE2b-256 |
f155b10d53a420a9ea89f8175afa5d8138472c971c74c87407f397a38a884b2e
|
Provenance
The following attestation bundles were made for daimon_sdk-0.4.0.tar.gz:
Publisher:
publish.yml on daimon-hq/processd-sdk
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
daimon_sdk-0.4.0.tar.gz -
Subject digest:
78d3c8e6d3967df08afa70a2986d9a2c1631a3effee983ccc16119010ad1ce33 - Sigstore transparency entry: 1455872156
- Sigstore integration time:
-
Permalink:
daimon-hq/processd-sdk@7c5f0eb000b58a727d0c2c57cefd9d10b8b43f56 -
Branch / Tag:
refs/tags/v0.4.0 - Owner: https://github.com/daimon-hq
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@7c5f0eb000b58a727d0c2c57cefd9d10b8b43f56 -
Trigger Event:
push
-
Statement type:
File details
Details for the file daimon_sdk-0.4.0-py3-none-any.whl.
File metadata
- Download URL: daimon_sdk-0.4.0-py3-none-any.whl
- Upload date:
- Size: 13.0 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
4c8f6c071c0a108f0e040653fb04db2910655b72d80a289d4ec549f304a4ab56
|
|
| MD5 |
fd603edb496c9a81b446aa74d88f59f3
|
|
| BLAKE2b-256 |
c0ddc2c61cf989d9f84f9366b5f412136629aa1f5fedf3fb8259aced4fb4ffb5
|
Provenance
The following attestation bundles were made for daimon_sdk-0.4.0-py3-none-any.whl:
Publisher:
publish.yml on daimon-hq/processd-sdk
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
daimon_sdk-0.4.0-py3-none-any.whl -
Subject digest:
4c8f6c071c0a108f0e040653fb04db2910655b72d80a289d4ec549f304a4ab56 - Sigstore transparency entry: 1455872213
- Sigstore integration time:
-
Permalink:
daimon-hq/processd-sdk@7c5f0eb000b58a727d0c2c57cefd9d10b8b43f56 -
Branch / Tag:
refs/tags/v0.4.0 - Owner: https://github.com/daimon-hq
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@7c5f0eb000b58a727d0c2c57cefd9d10b8b43f56 -
Trigger Event:
push
-
Statement type: