Skip to main content

Python client SDK for Sandbox Agent — universal API for automatic coding agents in sandboxes

Project description

sandboxagent

Python client SDK for Sandbox Agent — the universal API for automatic coding agents in sandboxes.

Installation

pip install sandbox-agent-sdk

Quick Start

import asyncio
from sandboxagent import SandboxAgent

async def main():
    # Connect to a running sandbox-agent server
    agent = await SandboxAgent.connect("http://localhost:2468")
    
    # Check health
    health = await agent.health()
    print(f"Health: {health}")
    
    # Filesystem operations
    await agent.write_file("/tmp/hello.txt", "Hello from Python!")
    content = await agent.read_file("/tmp/hello.txt")
    print(f"File content: {content}")
    
    # Run a process
    result = await agent.run_process({
        "command": "/bin/echo",
        "args": ["hello", "world"],
        "cwd": "/tmp"
    })
    print(f"stdout: {result['stdout']}")
    
    # List available agents
    agents = await agent.list_agents()
    print(f"Available agents: {[a['id'] for a in agents]}")
    
    # Get inspector URL
    print(f"Inspector: {agent.inspector_url}")
    
    await agent.dispose()

asyncio.run(main())

Starting a Local Server

from sandboxagent import SandboxAgent

# Download and start a local sandbox-agent binary
agent = await SandboxAgent.start()
print(f"Server running at {agent._base_url}")
print(f"Inspector: {agent.inspector_url}")

# ... use the agent ...

await agent.dispose()

ACP Sessions

# Create an ACP session with an agent
session = await agent.create_session(agent="claude")

# Send a prompt
response = await session.prompt("Write a Python function to calculate factorial")
print(response)

# Configure session settings
await session.set_model("claude-sonnet-4-20250514")
await session.set_mode("code")

# Destroy the session
await agent.destroy_session(session.id)

Workspace Configuration

Inject config files and environment variables into sandboxes during startup:

from sandboxagent import SandboxAgent
from sandboxagent.workspace_config import WorkspaceConfig

# Generate config content
auth_content = WorkspaceConfig.auth_json({
    "openai_api_key": "sk-...",
    "anthropic_api_key": "sk-ant-..."
})

# Start sandbox with workspace files
agent = await SandboxAgent.start(
    workspace_files={
        "auth.json": auth_content,
        ".env": "API_KEY=secret\nDEBUG=1"
    },
    workspace_env={"FOO": "bar"}
)

Git Repository Cloning

Clone git repositories at runtime or during sandbox startup:

Runtime Cloning

Clone repositories into a running sandbox using secure credential handling:

from sandboxagent import SandboxAgent, GitCloneError

# Clone public repository
result = await agent.clone_repo("https://github.com/owner/public-repo.git")

# Clone private repository with personal access token
result = await agent.clone_repo(
    "https://github.com/owner/private-repo.git",
    token=os.environ["GITHUB_TOKEN"],
    path="/workspace/my-project",
    branch="main",
    depth=1
)

# Handle errors
from sandboxagent import GitCloneError

try:
    await agent.clone_repo("https://github.com/owner/repo.git", token="ghp_xxx")
except GitCloneError as e:
    if e.category == "auth":
        print("Authentication failed - check your token")
    elif e.category == "not_found":
        print("Repository not found")
    elif e.category == "network":
        print("Network error - check connectivity")

Security features:

  • Token never appears in URLs or command-line arguments (uses GIT_ASKPASS)
  • Token is automatically redacted from error messages
  • Temporary credential script is deleted immediately after cloning

Bootstrap-time Cloning

Clone repositories during sandbox startup using workspace configuration:

from sandboxagent import SandboxAgent
from sandboxagent.workspace_config import WorkspaceConfig

# Generate git clone scripts
clone_script = WorkspaceConfig.git_clone_script([
    {"url": "https://github.com/owner/repo1.git", "path": "/workspace/r1", "branch": "main"},
    {"url": "https://github.com/owner/repo2.git", "path": "/workspace/r2", "depth": 1},
], token=os.environ.get("GITHUB_TOKEN"))

# Start sandbox with clone script
agent = await SandboxAgent.start(
    workspace_files={
        "clone-repos.sh": clone_script,
    }
)

# The script runs automatically on startup

Git Askpass Helper

Generate a standalone GIT_ASKPASS script for custom authentication flows:

from sandboxagent.workspace_config import WorkspaceConfig

# Create askpass script for git operations
askpass_script = WorkspaceConfig.git_askpass_script(token="ghp_xxx")
await agent.write_file("/workspace/.git-askpass", askpass_script)

# Use with any git command
result = await agent.run_process({
    "command": "git",
    "args": ["clone", "https://github.com/owner/private.git"],
    "env": {
        "GIT_ASKPASS": "/workspace/.git-askpass",
        "GIT_TOKEN": "ghp_xxx",
        "GIT_TERMINAL_PROMPT": "0"
    }
})

API Coverage

Core APIs

  • Health: health(), wait_for_health()
  • Filesystem: read_file(), write_file(), list_entries(), stat(), move(), delete_entry(), mkdir_fs()
  • Processes: create_process(), run_process(), list_processes(), get_process(), stop_process(), kill_process(), delete_process()
  • Git: clone_repo() — Clone repositories with secure token handling
  • Agents: list_agents(), get_agent(), install_agent()
  • Config: get_mcp_config(), set_mcp_config(), get_skills_config(), set_skills_config(), get_process_config(), set_process_config()

Session Management

  • create_session(), resume_session(), destroy_session(), list_sessions(), get_session()
  • Session helpers: prompt(), set_model(), set_mode(), set_thought_level(), set_config_option()

Process Helpers

  • Logs: follow_process_logs() — SSE streaming with log subscription
  • Terminal: connect_process_terminal() — WebSocket interactive terminal

Sandbox Lifecycle

  • pause_sandbox(), resume_sandbox(), restart_sandbox(), destroy_sandbox(), kill_sandbox()

Workspace Configuration Helpers

  • WorkspaceConfig.auth_json() — Generate auth.json content
  • WorkspaceConfig.git_askpass_script() — Generate GIT_ASKPASS script
  • WorkspaceConfig.git_clone_script() — Generate multi-repo clone script
  • WorkspaceConfig.oh_my_openagent_config() — Generate oh-my-openagent.jsonc
  • WorkspaceConfig.opencode_config() — Generate opencode.json

Development

# Setup
uv sync

# Run tests
uv run pytest

# Run integration tests (requires local server)
uv run pytest -m integration

# Lint and format
uv run ruff check
uv run ruff format

# Type check
uv run mypy sandboxagent

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

sandbox_agent_sdk-0.1.5.tar.gz (102.7 kB view details)

Uploaded Source

Built Distribution

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

sandbox_agent_sdk-0.1.5-py3-none-any.whl (84.6 kB view details)

Uploaded Python 3

File details

Details for the file sandbox_agent_sdk-0.1.5.tar.gz.

File metadata

  • Download URL: sandbox_agent_sdk-0.1.5.tar.gz
  • Upload date:
  • Size: 102.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.11.1 {"installer":{"name":"uv","version":"0.11.1","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"macOS","version":null,"id":null,"libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for sandbox_agent_sdk-0.1.5.tar.gz
Algorithm Hash digest
SHA256 5e80b63eeff0e58f3e987ed52d24b4736fc32ce4decae5904d3be651ebe8407f
MD5 8bbaf61d4d5ddeb5ce74b6ba664c679f
BLAKE2b-256 72e181a0d7c1a6416e3fd9c7cd38816978e7018591d8cca388e92300e2500eee

See more details on using hashes here.

File details

Details for the file sandbox_agent_sdk-0.1.5-py3-none-any.whl.

File metadata

  • Download URL: sandbox_agent_sdk-0.1.5-py3-none-any.whl
  • Upload date:
  • Size: 84.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.11.1 {"installer":{"name":"uv","version":"0.11.1","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"macOS","version":null,"id":null,"libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for sandbox_agent_sdk-0.1.5-py3-none-any.whl
Algorithm Hash digest
SHA256 230e1956e31afa886787b86169bb2832427b780ca05257f4b88f63d8decdd423
MD5 16faba6d03f1ea82323f8fed385efc6b
BLAKE2b-256 082378cb701238ba664881a0ab6143e87c46bc774cc05bfba92b82253bab915d

See more details on using hashes here.

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