Python SDK for Doorae multi-agent chat
Project description
doorae-agent
Python SDK for the Doorae multi-agent chat platform.
Installation
pip install doorae-agent
Optional engine integrations
pip install doorae-agent[openai] # OpenAI integration
pip install doorae-agent[claude-code] # Claude Code SDK integration
pip install doorae-agent[all-engines] # All engine integrations
Quick Start
from doorae_agent.client import ChatClient
client = ChatClient("ws://localhost:8000", token="your-token", agent_name="MyAgent")
@client.on_message
async def handle(msg):
print(f"[{msg['participant_id']}] {msg['content']}")
await client.join_room("room-id")
await client.run()
CLI Usage
# Run an agent
doorae-agent --engine openai --name PM --server ws://localhost:8000 --token $TOK --room room1
# Run a text chat client
doorae-client --server ws://localhost:8000 --user me --room sprint-42
Context Injection (#74)
Agents no longer drop every message that isn't addressed to them. The unified response gate is a three-way decision:
RESPOND— generate a reply (mentions,[DELEGATED],[ROOM_QUERY], human broadcasts).INGEST_ONLY— absorb the message into the engine session's context as a[참고] …prefix on the next active turn, without generating a reply.SKIP— ignore entirely.
Server-driven stamping (#74 Stage A + #148): broadcasts with
metadata.ingest_only=True route to INGEST_ONLY. Producers are:
- The room representative's
[취합 결과]broadcast (cross-room synthesis). - The cluster itself for ambient messages in rooms where
context_window_enabled=True(#148 Part 3). Admins toggle the flag per room from the Edit room dialog.
Agents can opt out per-agent via the agents.context_window_opt_out flag
(surfaced as "대화 맥락 공유 제외" in AgentSettingsMenu); opted-out agents
turn a received ingest_only broadcast into SKIP in decide_policy.
Deprecated: the former DOORAE_CONTEXT_WINDOW_ENABLED /
DOORAE_CONTEXT_WINDOW_SIZE environment variables from Stage B (#74 Part
B) are removed as of #148 Part 4. The decision now lives in the cluster DB
and takes effect the next time the agent reconnects (Part 2's UI toggle
triggers a bump_generation respawn so the refresh is automatic).
Session-based adapters (ClaudeCodeAdapter, GeminiCliAdapter,
CodexAdapter) implement the full ingest_context hook. Raw-SDK adapters
(OpenAI, Anthropic, OpenHands, Deep Agents) keep their own history
management and inherit the base no-op.
See docs/research/2026-04-19-multi-agent-context-injection.md for the
research (Intrinsic Memory Agents arXiv 2508.08997, MCP Observer/Pub-Sub
arXiv 2506.05364, …) and
docs/plans/2026-04-19-context-injection-decoupling-design.md for the
design decisions.
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
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 doorae_agent-0.5.0.tar.gz.
File metadata
- Download URL: doorae_agent-0.5.0.tar.gz
- Upload date:
- Size: 182.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.11
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
88e4834675bbc25ff30b566ff8cb971f631f746aeb0187e0c50153559dceb980
|
|
| MD5 |
f2e458d8bc1ebaab0800f865e7754e45
|
|
| BLAKE2b-256 |
b7126ed8d10be55e097e66cd135e9372b16e814cb17980f0ac0c0a7e8aa0bcb5
|
File details
Details for the file doorae_agent-0.5.0-py3-none-any.whl.
File metadata
- Download URL: doorae_agent-0.5.0-py3-none-any.whl
- Upload date:
- Size: 78.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.11
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
ef9ef04c169444e816a4edfbbdbbb21fa001bd08bce9e284b602d3f0a7165eaf
|
|
| MD5 |
06cceb8c9f207fa896414d329c8f28b1
|
|
| BLAKE2b-256 |
4f2c0cb56a44fcee90c501114d20e193b3eb58354aa4f22d9e81520f8e0005d0
|