Python client for depot.dev API
Project description
depot-client
Python client library for Depot. Provides both synchronous and asynchronous APIs through an intuitive Pythonic interface.
Installation
pip install depot-client
Usage
Basic Example
from depot_client import Client
with Client(token=DEPOT_API_TOKEN) as client:
# Create a project
project = client.create_project(
name="my-project",
region_id="us-east-1"
)
# Create a build
with client.create_endpoint(project_id=project.project_id) as endpoint:
# Write certificates to files
with open("client.crt", "w") as f:
f.write(endpoint.cert)
with open("client.key", "w") as f:
f.write(endpoint.key)
with open("ca.crt", "w") as f:
f.write(endpoint.ca_cert)
# Use with buildctl:
# buildctl --addr endpoint.endpoint \
# --tlsservername endpoint.server_name \
# --tlscacert ca.crt \
# --tlscert client.crt \
# --tlskey client.key \
# build --frontend dockerfile.v0
Async Support
The library provides async versions of all operations:
from depot_client import AsyncClient
import aiofiles
async with AsyncClient(token=DEPOT_API_TOKEN) as client:
async with await client.create_endpoint(project_id=PROJECT_ID) as endpoint:
# Write certificates to files
async with aiofiles.open("client.crt", "w") as f:
await f.write(endpoint.cert)
async with aiofiles.open("client.key", "w") as f:
await f.write(endpoint.key)
async with aiofiles.open("ca.crt", "w") as f:
await f.write(endpoint.ca_cert)
# Use with buildctl:
# buildctl --addr endpoint.endpoint \
# --tlsservername endpoint.server_name \
# --tlscacert ca.crt \
# --tlscert client.crt \
# --tlskey client.key \
# build --frontend dockerfile.v0
Project Operations
# List projects
projects = client.list_projects()
# Create and manage tokens
token = client.create_token(
project_id=project.project_id,
description="CI/CD token"
)
# Configure trust policies
policy = client.add_trust_policy(
project_id=project.project_id,
github={
"repository_owner": "org",
"repository": "repo"
}
)
Build Operations
# Create and track builds
build = client.create_build(project_id=PROJECT_ID)
# Get a shareable URL for the build
share_url = client.share_build(build.build_id)
# List project builds
builds = client.list_builds(project_id=PROJECT_ID)
Features
- Pythonic interface to Depot's API
- Context manager support for proper resource cleanup
- Full async/await support using
AsyncClient - Type hints throughout for better IDE integration
- Automatic handling of BuildKit endpoint lifecycle
- Comprehensive error handling
API Reference
Client Methods
Project Operations
list_projects() -> List[ProjectInfo]: List all available projectscreate_project(name: str, region_id: str) -> ProjectInfo: Create a new projectget_project(project_id: str) -> ProjectInfo: Get project detailsdelete_project(project_id: str) -> None: Delete a projectreset_project(project_id: str) -> None: Reset project state
Token Management
list_tokens(project_id: str) -> List[TokenInfo]: List project tokenscreate_token(project_id: str, description: str) -> TokenCreationInfo: Create new tokenupdate_token(token_id: str, description: str) -> None: Update token descriptiondelete_token(token_id: str) -> None: Delete token
Trust Policies
list_trust_policies(project_id: str) -> List[TrustPolicy]: List trust policiesadd_trust_policy(project_id: str, github: Optional[dict] = None, circleci: Optional[dict] = None, buildkite: Optional[dict] = None) -> TrustPolicy: Add trust policyremove_trust_policy(project_id: str, trust_policy_id: str) -> None: Remove trust policy
Build Operations
create_build(project_id: str) -> Build: Create new buildfinish_build(build_id: str, error: Optional[str] = None) -> None: Complete buildshare_build(build_id: str) -> str: Create a shareable URL for the buildstop_sharing_build(build_id: str) -> None: Revoke the shareable URL for the buildget_build(build_id: str) -> BuildInfo: Get build infolist_builds(project_id: str) -> List[BuildInfo]: List project builds
BuildKit Integration
create_endpoint(project_id: str, platform: Optional[str] = None) -> Endpoint: Create a BuildKit endpoint
Environment Variables
DEPOT_API_TOKEN: Your Depot API token for authentication
Development
# Install development dependencies
pip install -e ".[test]"
# Run tests
pytest
# Build package
make build
# Generate API bindings
make protos
make api
License
Apache License 2.0
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
depot_client-0.0.21.tar.gz
(28.4 kB
view details)
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 depot_client-0.0.21.tar.gz.
File metadata
- Download URL: depot_client-0.0.21.tar.gz
- Upload date:
- Size: 28.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.11.9
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
922165775455541053f6510cb6f04b8eea4cdf1ea287618075287034adbfe15b
|
|
| MD5 |
15bb5b2bb3fe1b7e14ec7d18e40470ec
|
|
| BLAKE2b-256 |
02844f474a6f78457778d6b49575a28cdb7d8d88c8d6c2626a6cc5ca6f74c59e
|
File details
Details for the file depot_client-0.0.21-py3-none-any.whl.
File metadata
- Download URL: depot_client-0.0.21-py3-none-any.whl
- Upload date:
- Size: 32.9 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.11.9
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
2b02c9cc36da86015460a25948a99086796724abb18b96302de427a9bcb6e075
|
|
| MD5 |
549bc003c0c600a5649a7d62b28f73a3
|
|
| BLAKE2b-256 |
8ae86e580a9384b901c683fcc05d595c739dc62c58e4858da1e695dab9a4967b
|