Airalogy protocol execute sandbox
Project description
airalogy-engine (Python)
Airalogy protocol execution sandbox for Python. Run protocol packages (parse, assign, validate) inside a secure BoxLite sandbox.
Installation
pip install airalogy-engine
Sandbox Image
The engine runs protocol code in a BoxLite sandbox. You can use either a remote Docker image or a local OCI rootfs directory.
Remote Image
from airalogy_engine import AiralogyEngine
engine = AiralogyEngine(image="numbcoder/airalogy-engine:0.1")
result = await engine.parse_protocol(protocol_path)
Local OCI Rootfs (Recommended)
Build and export the image locally for faster, offline execution:
docker build -t airalogy-engine:latest .
docker save airalogy-engine:latest -o airalogy-engine-image.tar
mkdir airalogy-engine-image
tar -xf airalogy-engine-image.tar -C airalogy-engine-image
Then use rootfs_path:
from airalogy_engine import AiralogyEngine
engine = AiralogyEngine(rootfs_path="./airalogy-engine-image")
result = await engine.parse_protocol(protocol_path)
If neither
imagenorrootfs_pathis provided, the engine falls back to the default remote imagenumbcoder/airalogy-engine:0.1.
Usage
import asyncio
from airalogy_engine import AiralogyEngine
async def main():
protocol_path = "/path/to/your/protocol"
rootfs_path = "/path/to/airalogy-engine-image" # or use image="..." instead
engine = AiralogyEngine(
rootfs_path=rootfs_path,
boxlite_home="/tmp/airalogy-engine-worker-1",
)
# 1. Parse the protocol
result = await engine.parse_protocol(protocol_path, env_vars={"API_KEY": "xxx"})
print(result["data"]["meta_data"])
print(result["data"]["json_schema"])
# 2. Assign a variable
result = await engine.assign_variable(
protocol_path,
var_name="duration",
dependent_data={"seconds": 3600},
env_vars={"API_KEY": "xxx"},
)
print(result["data"])
# 3. Validate variables
result = await engine.validate_variables(
protocol_path,
variables={"seconds": 60, "duration": "PT1M"},
)
print(result["data"])
await engine.close()
asyncio.run(main())
You can also use the engine as an async context manager:
async with AiralogyEngine(rootfs_path=rootfs_path, boxlite_home="/tmp/worker-1") as engine:
result = await engine.parse_protocol(protocol_path)
API
| API | Description |
|---|---|
AiralogyEngine(boxlite_home=None, image=None, rootfs_path=None, timeout=300, memory_mib=512, cpus=1) |
Create an engine bound to one BoxLite runtime home and sandbox configuration |
engine.parse_protocol(protocol_path, env_vars=None, timeout=None, debug=False, log_file="protocol_debug.log") |
Parse a protocol and return schema, metadata, fields |
engine.assign_variable(protocol_path, var_name, dependent_data, env_vars=None, timeout=None, debug=False, log_file="protocol_debug.log") |
Assign a variable using assigner functions |
engine.validate_variables(protocol_path, variables, env_vars=None, timeout=None, debug=False, log_file="protocol_debug.log") |
Validate variable values against the protocol model |
await engine.close() |
Release this engine's BoxLite runtime reference |
All engine methods are async and return a dict with success, message, and data keys.
Engine parameters:
boxlite_home: BoxLite runtime home directory. Use a distinct value for each OS process when running multiple workers.image: Remote Docker image name (e.g.,"numbcoder/airalogy-engine:0.1").rootfs_path: Path to a local OCI rootfs directory (overridesimage).timeout: Execution timeout in seconds (default: 300). The sandboxed process will be killed once it times out.memory_mib: Memory limit in MiB (default: 512).cpus: CPU limit (default: 1).
Concurrency
Use one AiralogyEngine instance per worker process and run concurrent operations through that object:
engine = AiralogyEngine(rootfs_path=rootfs_path, boxlite_home="/tmp/worker-1")
results = await asyncio.gather(
engine.parse_protocol(protocol_a),
engine.parse_protocol(protocol_b),
)
BoxLite locks each runtime home per OS process. Two independent processes must not share the same boxlite_home or default ~/.boxlite; give each process a distinct directory, for example /tmp/airalogy-worker-1 and /tmp/airalogy-worker-2.
Testing
cd python
uv sync
# Default: local OCI rootfs mode
uv run pytest tests/ -v
# Custom rootfs path
uv run pytest tests/ -v --sandbox-mode=rootfs --rootfs-path=../airalogy-engine-0.1
# Remote image mode
uv run pytest tests/ -v --sandbox-mode=image --sandbox-image=numbcoder/airalogy-engine:0.1
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
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 airalogy_engine-0.0.1.tar.gz.
File metadata
- Download URL: airalogy_engine-0.0.1.tar.gz
- Upload date:
- Size: 9.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.11.7 {"installer":{"name":"uv","version":"0.11.7","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
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
f2caf492a675898f8c0eeff24b86aaa7356aeb179834291ec6ea2913fd5ecf91
|
|
| MD5 |
c7234cf440ae4eca49ee8f92a50be731
|
|
| BLAKE2b-256 |
f240c748e343e9678e81f17851967e48878f376de2d584ef7e9be4fd142db18e
|
File details
Details for the file airalogy_engine-0.0.1-py3-none-any.whl.
File metadata
- Download URL: airalogy_engine-0.0.1-py3-none-any.whl
- Upload date:
- Size: 11.3 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.11.7 {"installer":{"name":"uv","version":"0.11.7","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
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
c05ec04a800baa32a55f32096694f829d4038ef08e626503fe9aef73b8a1e716
|
|
| MD5 |
51e538f1e8f7e056b9c259c939b22d49
|
|
| BLAKE2b-256 |
65af09fb6809b41c2eb3ea26afd43f7e4bd5f4b53ad8ffdefc45224b29ab0395
|