Agent routing: - Remove !agent command and manual agent selection flow - Registry auto-assigns agent from user_agents mapping (fallback: agents[0]) - provision_workspace_chat and !new both write agent_id to room_meta - Reconciliation backfills agent_id from registry on cold start - Fix duplicate agent_id block in auth.py Deployment stability: - Add bot-state named volume to persist lambda_matrix.db and matrix_store - Fix docker-compose.prod.yml duplicate environment: key (was silently losing all Matrix credentials) - Fix MATRIX_AGENT_REGISTRY_PATH to use absolute container path /app/config/... - Add bot-state volume declaration to docker-compose.fullstack.yml Docs and config: - Rewrite README.md for platform handoff (deploy table, working commands only) - Rewrite docs/matrix-prototype.md (remove stale commands and mock descriptions) - Remove !save/!load/!context/!agent from help text and welcome message - Add !clear, !list, !remove, !yes/!no to help text - Clean up .env.example (remove Telegram token, internal vars, real URLs) - Update config/matrix-agents.example.yaml with user_agents section and comments - Add explanatory comment to Dockerfile for --ignore-requires-python - Remove silent uv sync fallbacks in Dockerfile
51 lines
1.4 KiB
YAML
51 lines
1.4 KiB
YAML
services:
|
|
matrix-bot:
|
|
extends:
|
|
file: docker-compose.prod.yml
|
|
service: matrix-bot
|
|
environment:
|
|
AGENT_BASE_URL: http://platform-agent:8000
|
|
depends_on:
|
|
platform-agent:
|
|
condition: service_healthy
|
|
|
|
platform-agent:
|
|
build:
|
|
context: ./external/platform-agent
|
|
target: development
|
|
additional_contexts:
|
|
agent_api: ./external/platform-agent_api
|
|
environment:
|
|
PYTHONUNBUFFERED: "1"
|
|
AGENT_ID: ${AGENT_ID:-matrix-dev}
|
|
PROVIDER_MODEL: ${PROVIDER_MODEL:-openai/gpt-4o-mini}
|
|
PROVIDER_URL: ${PROVIDER_URL:-}
|
|
PROVIDER_API_KEY: ${PROVIDER_API_KEY:-}
|
|
COMPOSIO_API_KEY: ${COMPOSIO_API_KEY:-}
|
|
volumes:
|
|
- ./external/platform-agent/src:/app/src
|
|
- ./external/platform-agent_api:/agent_api
|
|
- agents:/workspace
|
|
command: >
|
|
sh -lc "
|
|
mkdir -p /workspace &&
|
|
chown -R agent:agent /workspace &&
|
|
exec /app/.venv/bin/uvicorn src.main:app --host 0.0.0.0 --port 8000 --no-access-log
|
|
"
|
|
ports:
|
|
- "8000:8000"
|
|
healthcheck:
|
|
test:
|
|
- CMD-SHELL
|
|
- python -c "import urllib.request; urllib.request.urlopen('http://127.0.0.1:8000/openapi.json', timeout=2).read()"
|
|
interval: 60s
|
|
timeout: 5s
|
|
retries: 5
|
|
start_period: 15s
|
|
restart: unless-stopped
|
|
|
|
volumes:
|
|
agents:
|
|
name: ${SURFACES_SHARED_VOLUME:-surfaces-agents}
|
|
bot-state:
|
|
name: ${SURFACES_BOT_STATE_VOLUME:-surfaces-bot-state}
|