Skip to main content

Serve and run your Waldiez flows in isolated environments and stream logs/input/output via Redis

Project description

Waldiez Runner

Run your Waldiez flows in isolated environments and stream AG2 logs/input/output via Redis.

Overview

Waldiez Runner enables executing flows in isolated Python virtual environments or containers, with full I/O streaming via Redis and task management via FastAPI + Taskiq.

Backed by:

  • FastAPI for the HTTP API
  • Taskiq for async task queuing and scheduling
  • Redis for messaging and log/input/output streaming
  • PostgreSQL for task and client persistence
  • Waldiez + ag2 + FastStream for defining, executing, and streaming interactive flows in isolation

overview

Getting Started

Follow these steps to get Waldiez Runner up and running in your development environment.


🐳 Quickstart (Docker/Podman Compose)

To launch the full development stack (API + Redis + Postgres + Nginx):

!!!Note This could take some minutes on the first run, as it installs all dependencies.

docker compose -f compose.dev.yaml up --build

This setup includes:

  • API server (waldiez-runner)
  • Redis + PostgreSQL
  • Taskiq worker + scheduler
  • Nginx reverse proxy
  • A simple static example in examples/html

Once started, you can access:

Example Preview

!!!Note Alternatively, you can open this project in VS Code with Dev Containers enabled — it uses most of the services (not nginx) via .devcontainer/compose.yaml.


🔑 Authenticating with the API or Example UI

When the server starts, it automatically generates a clients.json file in the project root.
This file contains two API clients:

  • One for the clients-api audience (managing clients)
  • One for the tasks-api audience (creating and interacting with tasks)

You'll need the tasks-api credentials to:

  • Use the Swagger UI (try out endpoints under /api/v1/tasks)
  • Submit tasks via curl or HTTP clients
  • Use the example UI at http://localhost

!!!INFO On the example page, you’ll be asked to paste the base URL, client ID, and secret.
Use the values from clients.json (specifically the tasks-api entry).

🔐 See Clients & Authentication for more details.

🔐 Admin Access

For administrative operations, you'll need an admin-api audience client:

  • View all tasks across all users: GET /api/v1/admin/tasks
  • Monitor task activity across all clients
  • Access administrative endpoints for oversight and management

!!!WARNING Admin endpoints require special authentication with the admin-api audience.
Regular tasks-api clients cannot access admin functionality.

The server automatically generates an admin client alongside the standard clients.
Check clients.json for the admin-api entry when it exists.

🧪 Local Mode (Advanced)

You can also run the server without any external dependencies (Redis/Postgres):

  • SQLite for storage
  • FakeRedis for message streams
make dev-no-reload

!!!Warning Do expect limitations in this mode, [Fake]Redis messages might not work as expected.

Or manually (what make dev-no-reload does):

# drop all tables and remove the .env file if it exists
python scripts/drop.py
# switch to local mode if not already
python scripts/toggle.py --mode local
# make sure the .env file is created and the database is initialized
python scripts/pre_start.py --dev
# make sure the first two Clients are created
python scripts/initial_data.py --dev
# start the server, the broker and the scheduler
python -m waldiez_runner --trusted-origins http://localhost:3000,http://localhost:8000 --trusted-hosts localhost --debug --no-force-ssl --no-redis --no-postgres --dev --all

You can now either use the Swagger UI at http://localhost:8000/docs or you can also serve the example on another port terminal:

cd examples/plain
python -m http.server 3000

Calling python -m http.server will start a simple HTTP server on port 3000, serving the files in the current directory. You can now access the example UI at http://localhost:3000.


📤 Submitting and Managing Tasks

Once the server is running, you can create and interact with tasks:

  • Submit a task by uploading a .waldiez file via:

  • Monitor task progress via:

    • the Swagger GET /api/v1/tasks/{task_id}
    • or the WebSocket endpoint /ws/{task_id} (see WebSocket)
    • Admin users: GET /api/v1/admin/tasks to view all tasks across all users
  • Send input if the task requests it:

    • Use the input box in the example UI
    • Or call POST /api/v1/tasks/{task_id}/input
  • Cancel or delete tasks using:

    • POST /api/v1/tasks/{task_id}/cancel
    • DELETE /api/v1/tasks/{task_id}

You can explore all available routes via the interactive API docs at /docs.

Contributors ✨

Thanks goes to these wonderful people (emoji key):

Panagiotis Kasnesis
Panagiotis Kasnesis

📆 🔬
Lazaros Toumanidis
Lazaros Toumanidis

💻
Stella Ioannidou
Stella Ioannidou

📣 🎨
Amalia Contiero
Amalia Contiero

💻 🐛
Christos Chatzigeorgiou
Christos Chatzigeorgiou

💻
Add your contributions

This project follows the all-contributors specification. Contributions of any kind welcome!

License

This project is licensed under the Apache License, Version 2.0 (Apache-2.0).

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

waldiez_runner-0.6.3.tar.gz (118.3 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

waldiez_runner-0.6.3-py3-none-any.whl (179.1 kB view details)

Uploaded Python 3

File details

Details for the file waldiez_runner-0.6.3.tar.gz.

File metadata

  • Download URL: waldiez_runner-0.6.3.tar.gz
  • Upload date:
  • Size: 118.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for waldiez_runner-0.6.3.tar.gz
Algorithm Hash digest
SHA256 c5a1072227802d38f8e48931957f4f233f34aaef833057d3b00880a927cf7078
MD5 ff1039da8c4749025149f498049e6022
BLAKE2b-256 091aa32f6d3dd2b025f1f36416a7e14fe36dbb40337c80e050150a450cf1678d

See more details on using hashes here.

Provenance

The following attestation bundles were made for waldiez_runner-0.6.3.tar.gz:

Publisher: publish.yaml on waldiez/runner

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file waldiez_runner-0.6.3-py3-none-any.whl.

File metadata

  • Download URL: waldiez_runner-0.6.3-py3-none-any.whl
  • Upload date:
  • Size: 179.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for waldiez_runner-0.6.3-py3-none-any.whl
Algorithm Hash digest
SHA256 3d2fc896a7736fe619ddd0d75fcda736ebd6ad12f334e4d0c85e984061dba86f
MD5 e639c18e09cce5b100e532aec023d8ea
BLAKE2b-256 1e6dca19120b27544175f2376200a36fe41937b6101769e525724be40dcafd94

See more details on using hashes here.

Provenance

The following attestation bundles were made for waldiez_runner-0.6.3-py3-none-any.whl:

Publisher: publish.yaml on waldiez/runner

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page