III SDK for Python
Project description
iii-sdk
Python SDK for the iii engine.
Install
pip install iii-sdk
Hello World
from iii import register_worker
iii = register_worker("ws://localhost:49134")
def greet(data):
return {"message": f"Hello, {data['name']}!"}
iii.register_function({"id": "greet"}, greet)
iii.register_trigger({
"type": "http",
"function_id": "greet",
"config": {"api_path": "/greet", "http_method": "POST"},
})
iii.connect()
result = iii.trigger({"function_id": "greet", "payload": {"name": "world"}})
print(result) # {"message": "Hello, world!"}
API
| Operation | Signature | Description |
|---|---|---|
| Initialize | register_worker(url, options?) |
Create an SDK instance and auto-connect |
| Register function | iii.register_function({"id": id}, handler) |
Register a function that can be invoked by name |
| Register trigger | iii.register_trigger({"type": ..., "function_id": ..., "config": ...}) |
Bind a trigger (HTTP, cron, queue, etc.) to a function |
| Invoke (await result) | iii.trigger({"function_id": id, "payload": data}) |
Invoke a function and wait for the result |
| Invoke (fire-and-forget) | iii.trigger({"function_id": id, ..., "action": TriggerAction.Void()}) |
Fire-and-forget |
| Shutdown | iii.shutdown() |
Disconnect and stop background thread |
register_worker() creates the SDK instance and auto-connects to the engine.
Registering Functions
def create_order(data):
return {"status_code": 201, "body": {"id": "123", "item": data["body"]["item"]}}
iii.register_function({"id": "orders.create"}, create_order)
Registering Triggers
iii.register_trigger({
"type": "http",
"function_id": "orders.create",
"config": {"api_path": "/orders", "http_method": "POST"},
})
Invoking Functions
result = iii.trigger({"function_id": "orders.create", "payload": {"body": {"item": "widget"}}})
Modules
| Import | What it provides |
|---|---|
iii |
Core SDK (III, types) |
iii.stream |
Stream client for real-time state |
iii.telemetry |
OpenTelemetry integration |
Development
Install in development mode
pip install -e .
Type checking
mypy src
Linting
ruff check src
Resources
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
iii_sdk-0.10.0.tar.gz
(174.6 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
iii_sdk-0.10.0-py3-none-any.whl
(43.4 kB
view details)
File details
Details for the file iii_sdk-0.10.0.tar.gz.
File metadata
- Download URL: iii_sdk-0.10.0.tar.gz
- Upload date:
- Size: 174.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
4c05510ff8c9f912b9943f18c184db57e5c6ee64995d305014aca1d736ca2164
|
|
| MD5 |
0e7ece38073e786fa2021d457cedbedf
|
|
| BLAKE2b-256 |
09b0c8cd2353eb556488114d60e26cfd4148f3f0c2c7bfb57e93657efcae4187
|
File details
Details for the file iii_sdk-0.10.0-py3-none-any.whl.
File metadata
- Download URL: iii_sdk-0.10.0-py3-none-any.whl
- Upload date:
- Size: 43.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
1a1c32219586186cf4ab6ef50e58a53da359ca128c9e67a04e67e6b3d7e617f2
|
|
| MD5 |
56531782ad538352d45e1129ff8bbfa7
|
|
| BLAKE2b-256 |
6955aa7c56f1b1a9c9c196ddb4a299b9550929d224f9002a712ef438d3a2cbe5
|