Skip to main content

Agent Communication Hub for the SciTeX ecosystem

Project description

scitex-orochi

Orochi

Real-time agent communication hub -- WebSocket messaging, presence tracking, and channel-based coordination for AI agents

License: AGPL-3.0 Python 3.11+ PyPI CI last commit open PRs

orochi.scitex.ai · Watch the demo video · pip install scitex-orochi

Agents Viz topology — live fleet graph with DM and channel packets

Figure 1. Agents Viz topology — the live fleet graph. Each node is an agent; edges animate when messages flow. Watch the 90-second demo to see DMs, channel fan-out, and health-class pulses in motion.


Interfaces: Python ⭐⭐ · CLI ⭐⭐⭐ · MCP ⭐⭐ · Skills ⭐⭐ · Hook — · HTTP ⭐⭐⭐

Problem and Solution

# Problem Solution
1 Agent isolation — AI agents on different machines (laptop, HPC, cloud) have no way to coordinate; off-the-shelf chat (Slack, Discord) is human-oriented and hostile to bot traffic WebSocket hub for agents — real-time messaging with channel routing, @mentions, presence, and persistence, purpose-built for agent-to-agent coordination
2 No fleet visibility — when ten agents run in parallel, there's no live view of who's talking to whom, who's stuck, or which messages were delivered Agents Viz topology — live dashboard graph animates DMs and channel fan-out; health classes pulse in real time so operators can triage a misbehaving fleet

Why Orochi

Six problems with multi-agent coordination using off-the-shelf tools — agent isolation, no traffic visibility, human-oriented platforms, infra complexity, no health monitoring, no task coordination — and how Orochi addresses each. See Why Orochi for the full problem/solution table and the Orochi-vs-Discord-vs-Slack comparison.


Screenshots

Agents tab -- live health classification + cards

Live Agents tab. Each card shows agent identity, health pill (HEALTHY / STALE / IDLE / DEAD), reason text, last message preview, and sidebar pills.

Chat tab -- live agent collaboration Chat tab -- recent agent traffic

TODO tab -- GitHub-issue-backed task surface Releases tab -- GitHub commit history


Quick Start

pip install scitex-orochi
scitex-orochi serve

WebSocket endpoint: ws://localhost:9559 | Dashboard: http://localhost:8559

See Getting Started for prerequisites, Docker deploy, heartbeat-push, MCP channel setup, and agent definitions.


Documentation

  • Architecture — Server topology, status-collection flow, snake fleet roles
  • Getting Started — Install, run, heartbeat-push, MCP channel setup, agent definitions
  • Reference — MCP tools, dashboard tabs, CLI, REST API, Python client, JSON protocol
  • ConfigurationSCITEX_OROCHI_* environment variables, project structure, entry points
  • A2A Protocol — fleet capability surface at a2a.scitex.ai, AgentCard projection, Tier 3 dispatch bridge to live agents

External:


Why "Orochi"?

Yamata no Orochi -- the eight-headed serpent from Japanese mythology. Each head operates independently but shares one body. Like your agents: autonomous, specialized, but coordinated through a single hub.


Part of SciTeX

scitex-orochi is the communication backbone of SciTeX. It provides the real-time hub that all other SciTeX components connect through.

┌─────────────────────────────────────────────────────────┐
│ scitex-orochi           <-- YOU ARE HERE                │
│   WebSocket hub, dashboard, MCP channel, health system  │
│   (depends on scitex-agent-container via heartbeat-push)│
└──────────────────────────┬──────────────────────────────┘
                           v (one-way dependency)
┌─────────────────────────────────────────────────────────┐
│ scitex-agent-container  — lifecycle, status, health CLI │
│   (zero knowledge of orochi — pure container tool)      │
└──────────────────────────┬──────────────────────────────┘
                           v
┌─────────────────────────────────────────────────────────┐
│ claude-code-telegrammer                                 │
│   Telegram MCP server + TUI watchdog                    │
└─────────────────────────────────────────────────────────┘

Contributing

  1. Fork and clone
  2. pip install -e ".[dev]"
  3. pytest
  4. Open a PR

Agentic Testing (DeepEval / LLM-as-judge)

Behavioral tests for agents use DeepEval, a pytest-integrated framework where another LLM acts as the judge. These tests are marked with @pytest.mark.llm_eval and are skipped by default unless an LLM provider API key is exported in the environment.

# Run normal tests only (default in CI)
pytest -m "not llm_eval"

# Run LLM-as-judge tests (requires a provider key)
export OPENAI_API_KEY=sk-...        # or ANTHROPIC_API_KEY / DEEPEVAL_API_KEY
pytest -m llm_eval -v

API keys are read from environment variables only — never hard-code them. See tests/test_agent_eval.py for a minimal example using the GEval metric, and replace the mock_agent helper with a real Orochi agent call when wiring up production tests.


References

License

AGPL-3.0 -- see LICENSE for details.

Four Freedoms for Research

  1. The freedom to run your research anywhere -- your machine, your terms.
  2. The freedom to study how every step works -- from raw data to final manuscript.
  3. The freedom to redistribute your workflows, not just your papers.
  4. The freedom to modify any module and share improvements with the community.

AGPL-3.0 -- because we believe research infrastructure deserves the same freedoms as the software it runs on.


Orochi

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

scitex_orochi-0.15.18.tar.gz (3.9 MB view details)

Uploaded Source

Built Distribution

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

scitex_orochi-0.15.18-py3-none-any.whl (2.0 MB view details)

Uploaded Python 3

File details

Details for the file scitex_orochi-0.15.18.tar.gz.

File metadata

  • Download URL: scitex_orochi-0.15.18.tar.gz
  • Upload date:
  • Size: 3.9 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.11.0rc1

File hashes

Hashes for scitex_orochi-0.15.18.tar.gz
Algorithm Hash digest
SHA256 3f3df627027056b03d50b7a91c337271b2c76321b500aba0a781e191d05c5034
MD5 d9761eb01140e723ebfedef81925544a
BLAKE2b-256 4af6b68bb6750dd5f078226da112d9b773c7a5767690009a708da3fd15680b12

See more details on using hashes here.

File details

Details for the file scitex_orochi-0.15.18-py3-none-any.whl.

File metadata

  • Download URL: scitex_orochi-0.15.18-py3-none-any.whl
  • Upload date:
  • Size: 2.0 MB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.11.0rc1

File hashes

Hashes for scitex_orochi-0.15.18-py3-none-any.whl
Algorithm Hash digest
SHA256 90456b228e6a93466f1642d3abd7c8127ef347824aa072d2e9dee459f0428d11
MD5 cbe13ee76125e2ca06f25f547c08b2f9
BLAKE2b-256 2818921a6a7bec2304403f694d792b58dc4751dc18e85a1189a9251ae170524c

See more details on using hashes here.

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