Skip to main content

Multi-Agent Orchestration Framework for Python

Project description

orxhestra logo

Multi-agent orchestration framework for Python — turn any agent setup into a CLI or server.

PyPI Python License


Compose multi-agent AI systems with async event streaming, agent hierarchies, and built-in support for MCP and A2A protocols.

Orx CLI

Turn any orx.yaml agent setup into an interactive terminal agent. Ships with a coding agent out of the box — or compose your own.

pip install orxhestra[cli,openai]
orx
+-- orx - terminal coding agent ------------------------------------+
|  model: gpt-5.4   workspace: ~/my-project   /help for commands    |
+-------------------------------------------------------------------+

orx> add error handling to the API routes

  > read_file(src/api/routes.py)
  > grep(pattern="raise", path=src/api/)
  > write_todos(3 tasks)

  Tasks
  * Add try/except to all route handlers  [in progress]
  - Add custom error response model
  - Write tests for error cases

  > edit_file(src/api/routes.py)
  > shell_exec(pytest tests/test_api.py)
  4 passed

  Done - added structured error handling to all 4 route handlers
  with a custom ErrorResponse model. All tests pass.

Features

  • Any LLM — OpenAI, Anthropic, Google via --model gpt-5.4 / claude-sonnet-4-6 / gemini-2.0-flash
  • Streaming — real-time token rendering with Markdown formatting
  • Tool approval — prompts before destructive operations (write, edit, shell)
  • Task planning — structured todo lists visible in the terminal
  • Sub-agent delegation — spawn isolated agents for complex subtasks
  • AGENTS.md memory — persistent project context across sessions
  • Local context injection — auto-detects language, git state, package manager, project tree
  • Context summarization — auto-compacts long conversations, /compact command
  • Orx YAML — run any orx.yaml agent team: orx my-agents.yaml

Usage

orx                               # interactive REPL (default model)
orx --model claude-sonnet-4-6     # use a specific model
orx -c "fix the failing tests"    # single-shot command
orx my-agents.yaml                # run a custom orx file
orx --auto-approve                # skip approval prompts
orx orx.yaml --serve -p 9000      # start as A2A server

Commands

Command Description
/model <name> Switch model mid-session
/clear Reset conversation
/compact Summarize old messages to free context
/todos Show current task list
/help Show all commands
/exit Exit

Quickstart (SDK)

pip install orxhestra
# or
uv add orxhestra
from orxhestra import LlmAgent, Runner, InMemorySessionService

agent = LlmAgent(
    name="assistant",
    model="gpt-5.4",
    instructions="You are a helpful assistant.",
)

runner = Runner(agent=agent, session_service=InMemorySessionService())
response = await runner.run(user_id="user1", session_id="s1", new_message="Hello!")

for event in response:
    print(event.content)

[!TIP] For persistent database sessions, install the database extra: pip install orxhestra[database]

[!TIP] For full documentation, guides, and API reference, visit docs.orxhestra.com.

Features

  • Agent ensemble - LLM, ReAct, Sequential, Parallel, and Loop agents
  • Event streaming - Async event-driven architecture with real-time streaming
  • Composer - Conduct entire agent orchestras declaratively with YAML
  • Tools - Function tools, filesystem tools, agent-as-tool, shell, and long-running tool support
  • Planners - Choreograph task execution with PlanReAct and TaskPlanner strategies
  • Skills - Reusable, composable agent repertoires
  • MCP - Model Context Protocol integration for tool servers
  • A2A - Agent-to-Agent protocol for cross-service harmonization
  • Memory - Pluggable memory stores for persistent agent context
  • Tracing - Built-in support for Langfuse, LangSmith, and custom callbacks

Agents at a glance

Agent Description
LlmAgent Chat model agent with tools, instructions, and structured output
ReActAgent Reasoning + acting loop with automatic tool use
SequentialAgent Runs sub-agents in order
ParallelAgent Runs sub-agents concurrently
LoopAgent Repeats a sub-agent until exit condition
A2AAgent Connects to remote agents via A2A protocol

Composer

Define entire agent orchestras in a single YAML file — no Python wiring needed. Compose LLM agents, loops, pipelines, tools, and review cycles declaratively. The example below builds a coding agent that plans, implements with filesystem + shell access, and self-reviews in a loop:

defaults:
  model:
    provider: openai
    name: gpt-5.4

tools:
  exit:
    builtin: "exit_loop"
  filesystem:
    builtin: "filesystem"
  shell:
    builtin: "shell"

agents:
  planner:
    type: llm
    description: "Plans the implementation steps for the coder agent."
    instructions: |
      Output a numbered list of concrete steps the coder
      should execute. Each step must be an actionable file
      operation or shell command.

  coder:
    type: llm
    description: "Implements code changes with filesystem and shell access."
    instructions: |
      Follow the plan from the previous step exactly.
      Use filesystem tools to create files and shell to
      run commands. Never ask the user to do anything.
    tools:
      - filesystem
      - shell

  reviewer:
    type: llm
    description: "Reviews changes and approves or requests fixes."
    instructions: |
      Check files exist and look correct. If done, call
      exit_loop. Otherwise describe what needs fixing.
    tools:
      - exit

  dev_loop:
    type: loop
    agents: [coder, reviewer]
    max_iterations: 10

  coordinator:
    type: sequential
    agents: [planner, dev_loop]

main_agent: coordinator

runner:
  app_name: coding-agent
  session_service: memory

Run it as an interactive CLI or expose it as an A2A server:

orx orx.yaml                    # interactive terminal agent
orx orx.yaml --serve -p 9000    # A2A server on port 9000
# test the server
curl -X POST http://localhost:9000/ \
  -H "Content-Type: application/json" \
  -d '{
    "jsonrpc": "2.0", "id": "1",
    "method": "message/send",
    "params": {
      "message": {
        "role": "user",
        "parts": [{"text": "Hello!", "mediaType": "text/plain"}]
      }
    }
  }'

Docker

docker run -e OPENAI_API_KEY=$OPENAI_API_KEY \
  -v ./orx.yaml:/app/orx.yaml \
  nicolaimtlassen/orxhestra

Documentation


Acknowledgments

This project is built on the shoulders of several outstanding open-source projects and research efforts:

Special thanks to the open-source AI community for pushing the boundaries of what's possible with agent frameworks.

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

orxhestra-0.0.31.tar.gz (161.3 kB view details)

Uploaded Source

Built Distribution

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

orxhestra-0.0.31-py3-none-any.whl (177.1 kB view details)

Uploaded Python 3

File details

Details for the file orxhestra-0.0.31.tar.gz.

File metadata

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

File hashes

Hashes for orxhestra-0.0.31.tar.gz
Algorithm Hash digest
SHA256 1c4938bc86b0d7aff246dc4e963aebbc6138b4ea795ea35fa558f618b3910f8d
MD5 513e7c8b81f65c703db4e4bafd6177f2
BLAKE2b-256 a24e9b0fa5ada81519abce00460150709a62ec3f47b1c6c31de215b4740895fb

See more details on using hashes here.

Provenance

The following attestation bundles were made for orxhestra-0.0.31.tar.gz:

Publisher: publish.yml on NicolaiLassen/orxhestra

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

File details

Details for the file orxhestra-0.0.31-py3-none-any.whl.

File metadata

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

File hashes

Hashes for orxhestra-0.0.31-py3-none-any.whl
Algorithm Hash digest
SHA256 17529f74d7fe1d289dc131ce0b92f97dbee031a49a4b9c693ffd100dc46769ab
MD5 543bb5659bde1c2ae7d799c0ced679e7
BLAKE2b-256 3e362ab7ff88cd33bca1de82a639635dea60b3f60b9868852393c391aa24b4ef

See more details on using hashes here.

Provenance

The following attestation bundles were made for orxhestra-0.0.31-py3-none-any.whl:

Publisher: publish.yml on NicolaiLassen/orxhestra

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