Async Python SDK for invoking Opal agents over PAT-authenticated REST and socket.io.
Project description
opal-agent-sdk (Python)
Async Python SDK for invoking Opal agents programmatically over a Personal Access Token (PAT).
Install
pip install opal-agent-sdk # core
pip install "opal-agent-sdk[cli]" # adds the `opal` CLI
Python 3.10+. Async-only.
Quickstart
import asyncio, os
from opal_agent_sdk import OpalClient, PATAuth
async def main() -> None:
async with OpalClient(auth=PATAuth(os.environ["OPAL_PAT"])) as client:
result = await client.agents.specialized.run(
agent_id="your-agent-uuid",
parameters={"query": "Where is order #1234?"},
)
print(result.output_text)
asyncio.run(main())
See examples/ for more (streaming, multi-turn chat, workflow agents, canvas access).
Configuration
| Parameter | Env var | Default | Description |
|---|---|---|---|
base_url |
OPAL_BASE_URL |
https://api.opal.optimizely.com |
API Gateway URL |
instance_id |
OPAL_INSTANCE_ID |
(auto-discovered from PAT) | Opal instance ID |
timeout_s |
— | 30.0 |
Per-request timeout in seconds |
retry_max_attempts |
— | 3 |
Max retry attempts for idempotent 5xx |
verify_ssl |
— | True |
SSL certificate verification. Set to False for localdev only — do not disable in production |
With PAT auth, the SDK extracts instance_id, customer_id, and product_instances from the JWT claims. Env vars are only used with OpalConfig.from_env() for non-PAT flows.
You can also use OpalConfig.from_pat() for explicit PAT-based config construction, or OpalConfig.from_env() to load from environment variables.
PAT Scoping
PATs are scoped to a specific Opal instance at creation time. Optionally, they can also be scoped to specific product connections (CMP, EXP, CMS, etc.).
The SDK reads the instance scope directly from the PAT's JWT claims — no separate
OPAL_INSTANCE_ID configuration is needed:
# Instance auto-discovered from PAT — no config required
async with OpalClient(auth=PATAuth(os.environ["OPAL_PAT"])) as client:
...
# Explicit config (overrides PAT claims)
from opal_agent_sdk import OpalConfig
async with OpalClient(
auth=PATAuth(os.environ["OPAL_PAT"]),
config=OpalConfig.from_pat(os.environ["OPAL_PAT"], base_url="https://opal-localdev.optimizely.com"),
) as client:
...
Create PATs in Settings > Developer > Personal Access Tokens in the Opal UI.
Streaming
async with OpalClient(auth=PATAuth(pat)) as client:
async for event in client.agents.specialized.stream(
agent_id="your-agent-uuid",
parameters={"query": "Summarize this article"},
):
if event.event_type == "response_chunk":
print(event.payload["content"], end="", flush=True)
Multi-turn Chat
async with client.agents.specialized.chat_stream(
agent_id="your-agent-uuid",
) as chat:
async for event in chat.send("Hello"):
... # handle events
async for event in chat.send("Tell me more"):
... # chat.memory_id and chat.etag are managed automatically
Catalog: list / export / import Agents and Skills
Agents
# List + iterate
page = await client.agents.list(type="specialized")
for agent in page:
print(agent.agent_id, agent.name)
async for agent in client.agents.iter(type="all"):
print(agent.agent_id)
# Export — single agent (returns dict, optionally writes file)
doc = await client.agents.export("agent-id", type="specialized")
await client.agents.export("agent-id", type="specialized", output_file=Path("/tmp/a.json"))
# Export — recursive workflow tree (returns AgentExportTree)
tree = await client.agents.export("wf-id", type="workflow", recursive=True)
await client.agents.export(
"wf-id", type="workflow", recursive=True,
output_file=Path("/tmp/agents/"),
)
# Import — single agent, or recursive tree (topological sort + cycle detection)
result = await client.agents.import_(doc, type="specialized")
results = await client.agents.import_tree(Path("/tmp/agents/"))
# Shares
grants = await client.agents.list_shares("agent-id", type="specialized")
Skills
# List
page = await client.skills.list(scope="org")
for skill in page:
print(skill.skill_guid, skill.title)
# Export — JSON envelope, SKILL.md, or whole plugin bundle
doc = await client.skills.export("skill-guid", scope="org")
await client.skills.export(
"skill-guid", scope="org", format="skill_md",
output_file=Path("/tmp/skills/"), # directory; SKILL.md is a directory artifact
)
result = await client.skills.export_as_plugin(
["g1", "g2"], scope="org",
plugin_name="my-plugin", plugin_description="...",
output_dir=Path("/tmp/plugin/"),
)
# Import — JSON, SKILL.md, or whole plugin bundle
r = await client.skills.import_(doc, scope="org")
rs = await client.skills.import_plugin(Path("/tmp/plugin/"))
For the wire shapes and round-trip semantics, see
docs/tech-spec/agent-framework/agent-sdk/skills-agents-export-import.md.
Development
make install # pip install -e ".[dev,cli]"
make test # pytest
make lint # ruff check
make format # ruff format
make typecheck # mypy --strict
make check # all of the above
Demo App
A FastAPI + HTML demo app is included in demo/ — see its README for setup instructions.
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 opal_agent_sdk-0.3.1.tar.gz.
File metadata
- Download URL: opal_agent_sdk-0.3.1.tar.gz
- Upload date:
- Size: 47.3 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.11.23 {"installer":{"name":"uv","version":"0.11.23","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 |
b51588c3b60663ad5e60b367f47b89273d76a20cf6edbfeb076776edc6da0548
|
|
| MD5 |
e8d1b5960bed54b3f1051cbfaedd8545
|
|
| BLAKE2b-256 |
70b18b6afa0d929388dc8658827246a7a39905570affc2479fab1fd184a907bd
|
File details
Details for the file opal_agent_sdk-0.3.1-py3-none-any.whl.
File metadata
- Download URL: opal_agent_sdk-0.3.1-py3-none-any.whl
- Upload date:
- Size: 56.1 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.11.23 {"installer":{"name":"uv","version":"0.11.23","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 |
e9cb84ae617eb297a5523b26c7bf376b1a679c954c09fa847c90eee64e35d89e
|
|
| MD5 |
4897e09f8340cb240d3c86bb453672a1
|
|
| BLAKE2b-256 |
5d69106524309e7c42433f23dbb29c7646801e6a731ad6e8ca0928437355df0a
|