Python SDK for StackMachine.
Project description
StackMachine Python SDK
Python SDK for StackMachine. It mirrors the JavaScript SDK surface with a Pythonic sync client and a native async client.
Installation
uv add stackmachine
Usage
from stackmachine import StackMachine
with StackMachine("sk_stackmachine_...") as stackmachine:
app = stackmachine.apps.retrieve_by_name("my-app")
print(app.url)
from stackmachine import AsyncStackMachine
async with AsyncStackMachine("sk_stackmachine_...") as stackmachine:
app = await stackmachine.apps.retrieve_by_name("my-app")
print(app.url)
Clients
StackMachine exposes sync methods. AsyncStackMachine exposes the same
resource tree with awaitable methods.
from stackmachine import AsyncStackMachine, StackMachine
stackmachine = StackMachine("sk_stackmachine_...")
async_stackmachine = AsyncStackMachine("sk_stackmachine_...")
Both clients accept configuration options during initialization:
stackmachine = StackMachine(
"sk_stackmachine_...",
apiUrl="https://api.stackmachine.com/graphql",
maxNetworkRetries=2,
)
Apps
apps = stackmachine.apps.list(limit=10)
for app in apps:
print(app.id, app.name)
app = stackmachine.apps.retrieve("app_id")
app = stackmachine.apps.retrieve_by_name("my-app")
apps = stackmachine.apps.retrieve_many(["app_1", "app_2"])
stackmachine.apps.delete("app_id")
Async lists can either be awaited for the first page or iterated directly:
apps = async_stackmachine.apps.list(limit=10)
first_page = await apps
async for app in apps:
print(app.name)
Deployments
deployment = stackmachine.deployments.create(
app_name="hello-stackmachine",
owner="stackmachine",
files={
"index.html": "<html><body><h1>Hello StackMachine</h1></body></html>",
},
on_upload_progress=lambda progress: print("Uploading", progress.percent * 100),
)
version = deployment.wait()
deployment = stackmachine.apps.autobuild(
app_name="hello-stackmachine",
owner="stackmachine",
files={
"index.html": "<html><body><h1>Hello StackMachine</h1></body></html>",
},
)
Files
Use this path only for manual package uploads:
from stackmachine import create_zip
zip_bytes = create_zip({"index.html": "<h1>Hello</h1>"})
url = stackmachine.files.upload(zip_bytes)
Domains
domain = stackmachine.apps.domains.create(
app="app_id",
hostname="example.com",
)
is_verified = stackmachine.apps.domains.verify(domain.id)
stackmachine.apps.domains.delete(domain.id)
SSH
server = stackmachine.apps.ssh.retrieve("app_id")
server = stackmachine.apps.ssh.update("app_id", enabled=True)
token = stackmachine.apps.ssh.tokens.create(app="app_id")
users = stackmachine.apps.ssh.users.list(app="app_id")
user = stackmachine.apps.ssh.users.retrieve("ssh_user_id")
password = stackmachine.apps.ssh.users.passwords.rotate("ssh_user_id")
key = stackmachine.apps.ssh.users.authorized_keys.create(
user="ssh_user_id",
public_key="ssh-ed25519 AAAA...",
)
Request Options
Most methods accept request_options for per-request configuration:
from stackmachine import RequestOptions
app = stackmachine.apps.retrieve(
"app_id",
request_options=RequestOptions(
api_key="sk_stackmachine_other",
timeout=30,
idempotency_key="deploy-123",
),
)
Development
cd python
uv sync --dev
uv run ruff check src examples tests
uv run mypy
uv run pytest
uv build --no-sources
Manual Publish
Use this path only for manual package uploads:
cd python
uv sync --dev
uv build --no-sources
uv publish
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
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 stackmachine-0.3.3.tar.gz.
File metadata
- Download URL: stackmachine-0.3.3.tar.gz
- Upload date:
- Size: 27.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: uv/0.11.17 {"installer":{"name":"uv","version":"0.11.17","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
7cad8fd6fc32571dec6405c919d2a0ea26d8f1be08cd1e6e76a9bbe5257d4078
|
|
| MD5 |
b5c7284bc980ebcdf38d240eee769dcc
|
|
| BLAKE2b-256 |
ea9791bb9c9dc57933949a6116f863a761a81e79fe046566e366168a4f88d7b5
|
File details
Details for the file stackmachine-0.3.3-py3-none-any.whl.
File metadata
- Download URL: stackmachine-0.3.3-py3-none-any.whl
- Upload date:
- Size: 35.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: uv/0.11.17 {"installer":{"name":"uv","version":"0.11.17","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
afbcaddb662e09928bbf2728e4c5dff1c9fde95afdb32b9f873611001a8fbd61
|
|
| MD5 |
e764eed74f8ab1375491f365ed8a0657
|
|
| BLAKE2b-256 |
1745a5ab701ba1bdddbed7deaa7a83f5c080f796183beb97599b5561566331cb
|