Prime Intellect Sandboxes SDK - Manage remote code execution environments
Project Links
Meta
Author: Prime Intellect
Requires Python: >=3.10
Classifiers
Development Status
- 4 - Beta
Intended Audience
- Developers
License
- OSI Approved :: MIT License
Operating System
- OS Independent
Programming Language
- Python :: 3
- Python :: 3.10
- Python :: 3.11
- Python :: 3.12
- Python :: 3.13
- Python :: 3.14
Topic
- Software Development :: Libraries :: Python Modules
Prime Sandboxes SDK
Lightweight Python SDK for managing Prime Intellect sandboxes - secure remote code execution environments.
Features
- Synchronous and async clients - Use with sync or async/await code
- Full sandbox lifecycle - Create, list, execute commands, upload/download files, delete
- Type-safe - Full type hints and Pydantic models
- Authentication caching - Automatic token management
- Bulk operations - Create and manage multiple sandboxes efficiently
- No CLI dependencies - Pure SDK, ~50KB installed
Installation
uv pip install prime-sandboxes
Or with pip:
pip install prime-sandboxes
Quick Start
from prime_sandboxes import APIClient, SandboxClient, CreateSandboxRequest
# Initialize
client = APIClient(api_key="your-api-key")
sandbox_client = SandboxClient(client)
# Create a sandbox
request = CreateSandboxRequest(
name="my-sandbox",
docker_image="python:3.11-slim",
cpu_cores=2,
memory_gb=4,
)
sandbox = sandbox_client.create(request)
print(f"Created: {sandbox.id}")
# Wait for it to be ready
sandbox_client.wait_for_creation(sandbox.id)
# Execute commands
result = sandbox_client.execute_command(sandbox.id, "python --version")
print(result.stdout)
# Clean up
sandbox_client.delete(sandbox.id)
Async Usage
import asyncio
from prime_sandboxes import AsyncSandboxClient, CreateSandboxRequest
async def main():
async with AsyncSandboxClient(api_key="your-api-key") as client:
# Create sandbox
sandbox = await client.create(CreateSandboxRequest(
name="async-sandbox",
docker_image="python:3.11-slim",
))
# Wait and execute
await client.wait_for_creation(sandbox.id)
result = await client.execute_command(sandbox.id, "echo 'Hello from async!'")
print(result.stdout)
# Clean up
await client.delete(sandbox.id)
asyncio.run(main())
Authentication
The SDK looks for credentials in this order:
- Direct parameter:
APIClient(api_key="sk-...") - Environment variable:
export PRIME_API_KEY="sk-..." - Config file:
~/.prime/config.json(created byprime loginCLI command)
Advanced Features
Environment Variables and Secrets
# Create sandbox with environment variables and secrets
request = CreateSandboxRequest(
name="my-sandbox",
docker_image="python:3.11-slim",
environment_vars={
"DEBUG": "true",
"LOG_LEVEL": "info"
},
secrets={
"API_KEY": "sk-secret-key-here",
"DATABASE_PASSWORD": "super-secret-password"
}
)
sandbox = sandbox_client.create(request)
Note: Secrets are never displayed in logs or outputs. When retrieving sandbox details, only the secret keys are shown with values masked as ***.
File Operations
# Upload a file
sandbox_client.upload_file(
sandbox_id=sandbox.id,
file_path="/app/script.py",
local_file_path="./local_script.py"
)
# Download a file
sandbox_client.download_file(
sandbox_id=sandbox.id,
file_path="/app/output.txt",
local_file_path="./output.txt"
)
Bulk Operations
# Create multiple sandboxes
sandbox_ids = []
for i in range(5):
sandbox = sandbox_client.create(CreateSandboxRequest(
name=f"sandbox-{i}",
docker_image="python:3.11-slim",
))
sandbox_ids.append(sandbox.id)
# Wait for all to be ready
statuses = sandbox_client.bulk_wait_for_creation(sandbox_ids)
# Delete by IDs or labels
sandbox_client.bulk_delete(sandbox_ids=sandbox_ids)
# OR by labels
sandbox_client.bulk_delete(labels=["experiment-1"])
Labels & Filtering
# Create with labels
sandbox = sandbox_client.create(CreateSandboxRequest(
name="labeled-sandbox",
docker_image="python:3.11-slim",
labels=["experiment", "ml-training"],
))
# List with filters
sandboxes = sandbox_client.list(
status="RUNNING",
labels=["experiment"],
page=1,
per_page=50,
)
for s in sandboxes.sandboxes:
print(f"{s.name}: {s.status}")
Long-Running Tasks
Use start_background_job to run long-running tasks that continue after the API call returns. Poll for completion with get_background_job.
from prime_sandboxes import SandboxClient, CreateSandboxRequest
sandbox_client = SandboxClient()
# Create sandbox with extended timeout
sandbox = sandbox_client.create(CreateSandboxRequest(
name="training-job",
docker_image="python:3.11-slim",
timeout_minutes=1440, # 24 hours
cpu_cores=4,
memory_gb=16,
))
sandbox_client.wait_for_creation(sandbox.id)
# Start a long-running job in the background
job = sandbox_client.start_background_job(
sandbox.id,
"python train.py --epochs 100"
)
print(f"Job started: {job.job_id}")
# Poll for completion
import time
while True:
status = sandbox_client.get_background_job(sandbox.id, job)
if status.completed:
print(f"Job finished with exit code: {status.exit_code}")
print(status.stdout)
break
print("Still running...")
time.sleep(30)
# Download results
sandbox_client.download_file(sandbox.id, "/app/model.pt", "./model.pt")
Async version
import asyncio
from prime_sandboxes import AsyncSandboxClient, CreateSandboxRequest
async def run_training():
async with AsyncSandboxClient() as client:
sandbox = await client.create(CreateSandboxRequest(
name="async-training",
docker_image="python:3.11-slim",
timeout_minutes=720,
))
await client.wait_for_creation(sandbox.id)
# Start background job
job = await client.start_background_job(
sandbox.id,
"python train.py"
)
# Poll until done
while True:
status = await client.get_background_job(sandbox.id, job)
if status.completed:
print(status.stdout)
break
await asyncio.sleep(30)
await client.delete(sandbox.id)
asyncio.run(run_training())
Documentation
Full API reference: https://github.com/PrimeIntellect-ai/prime-cli/tree/main/packages/prime-sandboxes
Related Packages
prime- Full CLI + SDK with pods, inference, and more (includes this package)
License
MIT License - see LICENSE file for details
0.2.26
May 12, 2026
0.2.25
May 11, 2026
0.2.24
May 09, 2026
0.2.23
May 07, 2026
0.2.22
Apr 22, 2026
0.2.21
Apr 20, 2026
0.2.20
Apr 18, 2026
0.2.19
Apr 01, 2026
0.2.18
Mar 22, 2026
0.2.17
Mar 21, 2026
0.2.16
Feb 28, 2026
0.2.15
Feb 10, 2026
0.2.14
Feb 01, 2026
0.2.13
Jan 30, 2026
0.2.12
Jan 26, 2026
0.2.11
Jan 17, 2026
0.2.10
Jan 15, 2026
0.2.9
Jan 07, 2026
0.2.8
Dec 29, 2025
0.2.7
Dec 19, 2025
0.2.6
Dec 10, 2025
0.2.5
Dec 02, 2025
0.2.4
Nov 13, 2025
0.2.3
Nov 07, 2025
0.2.2
Nov 07, 2025
0.2.1
Nov 07, 2025
0.2.0
Nov 05, 2025
0.1.0
Oct 09, 2025
0.0.0
Oct 11, 2025