Official Python SDK for the PromptRails API
Project description
PromptRails Python SDK
Official Python SDK for PromptRails — the AI agent orchestration platform.
Installation
pip install promptrails
Quick Start
Synchronous
from promptrails import PromptRails
client = PromptRails(api_key="pr_key_...")
# Execute an agent
result = client.agents.execute("agent-id", input={"query": "Summarise this week's sales"})
print(result.output)
client.close()
Async
import asyncio
from promptrails import AsyncPromptRails
async def main():
async with AsyncPromptRails(api_key="pr_key_...") as client:
result = await client.agents.execute("agent-id", input={"query": "hello"})
print(result.output)
asyncio.run(main())
Context Manager
with PromptRails(api_key="pr_key_...") as client:
agents = client.agents.list()
for agent in agents.data:
print(agent.name)
Error Handling
from promptrails import NotFoundError, ValidationError, RateLimitError, QuotaExceededError
try:
result = client.agents.execute("agent-id", input={})
except QuotaExceededError:
print("Execution limit reached — upgrade your plan")
except RateLimitError:
print("Too many requests, back off and retry")
except NotFoundError as e:
print(f"Agent not found: {e.message}")
Available Resources
| Resource | Methods |
|---|---|
client.agents |
list, get, create, update, delete, execute, list_versions, create_version, list_guardrails, create_guardrail, list_memories, create_memory, search_memories, delete_all_memories |
client.prompts |
list, get, create, update, delete, list_versions, create_version |
client.executions |
list, get |
client.credentials |
list, get, create, update, delete, set_default, check_connection |
client.data_sources |
list, get, create, update, delete, list_versions, create_version, test_connection, query |
client.chat |
list_sessions, get_session, create_session, delete_session, list_messages, send_message |
client.traces |
list, get_by_trace_id |
client.costs |
get_summary, get_agent_summary |
client.scores |
list, get, create, update, delete, list_configs, get_config, create_config, update_config, delete_config, aggregates |
client.mcp_tools |
list, get, create, update, delete |
client.approvals |
list, get, decide |
client.webhook_triggers |
list, get, create, update, delete |
client.a2a |
get_agent_card, send_message, get_task, list_tasks, cancel_task |
client.media_models |
list |
client.media |
generate |
client.assets |
list, get, delete, get_signed_url |
Media Studio
Generate images, speech, and video using various providers:
# List available media models
models = client.media_models.list(media_type="image")
for model in models:
print(f"{model.provider}/{model.model_id}: {model.display_name}")
# Generate an image
result = client.media.generate(
provider="fal",
media_type="image",
model="fal-ai/flux/schnell",
prompt="A futuristic cityscape at sunset",
config={"width": 1024, "height": 768},
)
print(result.url)
# List assets
assets = client.assets.list(type="image")
for asset in assets.data:
print(f"{asset.file_name} ({asset.mime_type})")
# Get a signed download URL
signed = client.assets.get_signed_url(asset_id="asset-id")
print(signed.url)
# Delete an asset
client.assets.delete(asset_id="asset-id")
Configuration
| Option | Default | Description |
|---|---|---|
api_key |
required | API key |
base_url |
https://api.promptrails.ai |
API base URL |
timeout |
30.0 |
Request timeout (seconds) |
max_retries |
3 |
Max retries on network/5xx errors |
Contributing
# Install development dependencies
pip install -e ".[dev]"
# Run linter
ruff check .
# Run formatter
ruff format .
# Run tests
pytest tests/ -v
License
MIT
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
promptrails-0.3.0.tar.gz
(28.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
File details
Details for the file promptrails-0.3.0.tar.gz.
File metadata
- Download URL: promptrails-0.3.0.tar.gz
- Upload date:
- Size: 28.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.9.25
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
c77db370e696bdbf00b2bfb0af55eb67067ad8069ed256a753206a3257f1f92b
|
|
| MD5 |
2d6525fec33d4f8a5d09330c0f549384
|
|
| BLAKE2b-256 |
e15f131a0c65f53d063d6cded855e70df4bc7db34762214a43a1ad71d0f01bd4
|
File details
Details for the file promptrails-0.3.0-py3-none-any.whl.
File metadata
- Download URL: promptrails-0.3.0-py3-none-any.whl
- Upload date:
- Size: 38.6 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.9.25
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
a07c4635432a3ac26c77a7335c632b77788bc3a5ea21307e1aee9d5e925afb94
|
|
| MD5 |
9ec0e84eb9674ff42d7246a5d508c049
|
|
| BLAKE2b-256 |
2c5829ce49992f4ab501d3c98f39712cf303827c5fc64dd31115ad0f40bcd395
|