Quick Start
Using Recipe Operations
Copy
from praisonai import recipe
# Submit recipe as async job
job = recipe.submit_job(
"my-recipe",
input={"query": "What is AI?"},
config={"max_tokens": 1000},
session_id="session_123",
timeout_sec=3600,
webhook_url="https://example.com/webhook",
idempotency_key="unique-key-123",
api_url="http://127.0.0.1:8005",
)
print(f"Job ID: {job.job_id}")
print(f"Status: {job.status}")
# Wait for completion
result = job.wait(poll_interval=5, timeout=300)
print(f"Result: {result}")
Using HTTP API Directly
Copy
import httpx
API_URL = "http://127.0.0.1:8005"
# Submit job
response = httpx.post(f"{API_URL}/api/v1/runs", json={"prompt": "Analyze data"})
job = response.json()
job_id = job["job_id"]
# Check status
status = httpx.get(f"{API_URL}/api/v1/runs/{job_id}").json()
# Get result
result = httpx.get(f"{API_URL}/api/v1/runs/{job_id}/result").json()
Start Server
Copy
python -m uvicorn praisonai.jobs.server:create_app --port 8005 --factory
Submit Job
Copy
import httpx
response = httpx.post(
"http://127.0.0.1:8005/api/v1/runs",
json={"prompt": "Your task here"}
)
job_id = response.json()["job_id"]
Idempotency
Copy
response = httpx.post(
"http://127.0.0.1:8005/api/v1/runs",
json={"prompt": "Task"},
headers={"Idempotency-Key": "unique-key-123"}
)
Polling
Copy
import time
def wait_for_completion(job_id):
while True:
status = httpx.get(f"http://127.0.0.1:8005/api/v1/runs/{job_id}").json()
if status["status"] in ("succeeded", "failed", "cancelled"):
return status
time.sleep(status.get("retry_after", 2))
SSE Streaming
Copy
with httpx.stream("GET", f"http://127.0.0.1:8005/api/v1/runs/{job_id}/stream") as r:
for line in r.iter_lines():
if line.startswith("data:"):
print(line[5:])
Webhook Callback
Copy
response = httpx.post(
"http://127.0.0.1:8005/api/v1/runs",
json={
"prompt": "Task",
"webhook_url": "https://example.com/callback"
}
)
Session Grouping
Copy
for task in tasks:
httpx.post(
"http://127.0.0.1:8005/api/v1/runs",
json={"prompt": task, "session_id": "project-alpha"}
)
Cancel Job
Copy
httpx.post(f"http://127.0.0.1:8005/api/v1/runs/{job_id}/cancel")
List Jobs
Copy
jobs = httpx.get("http://127.0.0.1:8005/api/v1/runs").json()
Complete Example
Copy
import httpx
import time
API_URL = "http://127.0.0.1:8005"
def submit_and_wait(prompt):
# Submit
response = httpx.post(f"{API_URL}/api/v1/runs", json={"prompt": prompt})
job_id = response.json()["job_id"]
# Wait
while True:
status = httpx.get(f"{API_URL}/api/v1/runs/{job_id}").json()
if status["status"] == "succeeded":
return httpx.get(f"{API_URL}/api/v1/runs/{job_id}/result").json()
elif status["status"] in ("failed", "cancelled"):
raise Exception(f"Job {status['status']}")
time.sleep(2)
result = submit_and_wait("What is 2+2?")
print(result["result"])
CLI Usage
Copy
# Start the jobs server
python -m uvicorn praisonai.jobs.server:create_app --port 8005 --factory
# Submit a job
praisonai run submit "Analyze this data"
# Submit a recipe as job
praisonai run submit "Analyze AI trends" --recipe news-analyzer
# With recipe config
praisonai run submit "Analyze" --recipe analyzer --recipe-config '{"format": "json"}'
# Wait for completion
praisonai run submit "Quick task" --wait
# Stream progress
praisonai run submit "Long task" --stream
# Check status
praisonai run status <job_id>
# Get result
praisonai run result <job_id>
# List jobs
praisonai run list
# Cancel job
praisonai run cancel <job_id>

