* feat: Add universal clipboard utility with enhanced copy functionality - Add comprehensive clipboard utility (src/utils/clipboard.ts) with: - Modern Clipboard API with automatic fallback to document.execCommand - Cross-browser compatibility and security context handling - Detailed error reporting and debugging capabilities - Support for secure (HTTPS) and insecure (HTTP/localhost) contexts - Update components to use new clipboard utility: - BugReportModal: Enhanced copy functionality with error handling - CodeViewerModal: Improved copy-to-clipboard for code snippets - IDEGlobalRules: Robust clipboard operations for rule copying - McpConfigSection: Enhanced config and command copying - DocumentCard: Reliable ID copying functionality - KnowledgeInspector: Improved content copying - ButtonPlayground: Enhanced CSS style copying - Benefits: - Consistent copy behavior across all browser environments - Better error handling and user feedback - Improved accessibility and security context support - Enhanced debugging capabilities Fixes #662 * fix: Improve clipboard utility robustness and add missing host configuration Clipboard utility improvements: - Prevent textarea element leak in clipboard fallback with proper cleanup - Add SSR compatibility with typeof guards for navigator/document - Use finally block to ensure cleanup in all error cases Host configuration fixes: - Update MCP API to use ARCHON_HOST environment variable instead of hardcoded localhost - Add ARCHON_HOST to docker-compose environment variables - Ensures MCP configuration shows correct hostname in different deployment environments Addresses CodeRabbit feedback and restores missing host functionality * fix: Use relative URLs for Vite proxy in development - Update getApiUrl() to return empty string when VITE_API_URL is unset - Ensures all API requests use relative paths (/api/...) in development - Prevents bypassing Vite proxy with absolute URLs (host:port) - Maintains existing functionality for explicit VITE_API_URL configuration - Fix TypeScript error by using bracket notation for environment access Addresses CodeRabbit feedback about dev setup relying on Vite proxy * fix: Resolve TypeScript error in API configuration Use proper type assertion to access VITE_API_URL environment variable * Address PR review comments: Move clipboard utility to features architecture - Move clipboard.ts from src/utils/ to src/features/shared/utils/ - Remove copyTextToClipboard backward compatibility function (dead code) - Update all import statements to use new file location - Maintain full clipboard functionality with modern API and fallbacks Addresses: - Review comment r2348420743: Move to new architecture location - Review comment r2348422625: Remove unused backward compatibility function 🤖 Generated with [Claude Code](https://claude.ai/code) Co-Authored-By: Claude <noreply@anthropic.com> * Fix SSR safety issue in clipboard utility - Add typeof navigator !== 'undefined' guard before accessing navigator.clipboard - Add typeof document !== 'undefined' guard before using document.execCommand fallback - Ensure proper error handling when running in server-side environment - Maintain existing functionality while preventing ReferenceError during SSR/prerender Addresses CodeRabbit feedback: Navigator access needs SSR-safe guards 🤖 Generated with [Claude Code](https://claude.ai/code) Co-Authored-By: Claude <noreply@anthropic.com> --------- Co-authored-by: Claude <noreply@anthropic.com>
181 lines
5.6 KiB
YAML
181 lines
5.6 KiB
YAML
# Docker Compose profiles:
|
|
# - Default (no profile): Starts archon-server, archon-mcp, and archon-frontend
|
|
# - Agents are opt-in: archon-agents starts only with the "agents" profile
|
|
# Usage:
|
|
# docker compose up # Starts server, mcp, frontend (agents disabled)
|
|
# docker compose --profile agents up -d # Also starts archon-agents
|
|
|
|
services:
|
|
# Server Service (FastAPI + Socket.IO + Crawling)
|
|
archon-server:
|
|
build:
|
|
context: ./python
|
|
dockerfile: Dockerfile.server
|
|
args:
|
|
BUILDKIT_INLINE_CACHE: 1
|
|
ARCHON_SERVER_PORT: ${ARCHON_SERVER_PORT:-8181}
|
|
container_name: archon-server
|
|
ports:
|
|
- "${ARCHON_SERVER_PORT:-8181}:${ARCHON_SERVER_PORT:-8181}"
|
|
environment:
|
|
- SUPABASE_URL=${SUPABASE_URL}
|
|
- SUPABASE_SERVICE_KEY=${SUPABASE_SERVICE_KEY}
|
|
- OPENAI_API_KEY=${OPENAI_API_KEY:-}
|
|
- LOGFIRE_TOKEN=${LOGFIRE_TOKEN:-}
|
|
- SERVICE_DISCOVERY_MODE=docker_compose
|
|
- LOG_LEVEL=${LOG_LEVEL:-INFO}
|
|
- ARCHON_SERVER_PORT=${ARCHON_SERVER_PORT:-8181}
|
|
- ARCHON_MCP_PORT=${ARCHON_MCP_PORT:-8051}
|
|
- ARCHON_AGENTS_PORT=${ARCHON_AGENTS_PORT:-8052}
|
|
- AGENTS_ENABLED=${AGENTS_ENABLED:-false}
|
|
- ARCHON_HOST=${HOST:-localhost}
|
|
networks:
|
|
- app-network
|
|
volumes:
|
|
- /var/run/docker.sock:/var/run/docker.sock # Docker socket for MCP container control
|
|
- ./python/src:/app/src # Mount source code for hot reload
|
|
- ./python/tests:/app/tests # Mount tests for UI test execution
|
|
extra_hosts:
|
|
- "host.docker.internal:host-gateway"
|
|
command:
|
|
[
|
|
"python",
|
|
"-m",
|
|
"uvicorn",
|
|
"src.server.main:app",
|
|
"--host",
|
|
"0.0.0.0",
|
|
"--port",
|
|
"${ARCHON_SERVER_PORT:-8181}",
|
|
"--reload",
|
|
]
|
|
healthcheck:
|
|
test:
|
|
[
|
|
"CMD",
|
|
"sh",
|
|
"-c",
|
|
'python -c "import urllib.request; urllib.request.urlopen(''http://localhost:${ARCHON_SERVER_PORT:-8181}/health'')"',
|
|
]
|
|
interval: 30s
|
|
timeout: 10s
|
|
retries: 3
|
|
start_period: 40s
|
|
|
|
# Lightweight MCP Server Service (HTTP-based)
|
|
archon-mcp:
|
|
build:
|
|
context: ./python
|
|
dockerfile: Dockerfile.mcp
|
|
args:
|
|
BUILDKIT_INLINE_CACHE: 1
|
|
ARCHON_MCP_PORT: ${ARCHON_MCP_PORT:-8051}
|
|
container_name: archon-mcp
|
|
ports:
|
|
- "${ARCHON_MCP_PORT:-8051}:${ARCHON_MCP_PORT:-8051}"
|
|
environment:
|
|
- SUPABASE_URL=${SUPABASE_URL}
|
|
- SUPABASE_SERVICE_KEY=${SUPABASE_SERVICE_KEY}
|
|
- LOGFIRE_TOKEN=${LOGFIRE_TOKEN:-}
|
|
- SERVICE_DISCOVERY_MODE=docker_compose
|
|
- TRANSPORT=sse
|
|
- LOG_LEVEL=${LOG_LEVEL:-INFO}
|
|
# MCP needs to know where to find other services
|
|
- API_SERVICE_URL=http://archon-server:${ARCHON_SERVER_PORT:-8181}
|
|
- AGENTS_ENABLED=${AGENTS_ENABLED:-false}
|
|
- AGENTS_SERVICE_URL=${AGENTS_SERVICE_URL:-http://archon-agents:${ARCHON_AGENTS_PORT:-8052}}
|
|
- ARCHON_MCP_PORT=${ARCHON_MCP_PORT:-8051}
|
|
- ARCHON_SERVER_PORT=${ARCHON_SERVER_PORT:-8181}
|
|
- ARCHON_AGENTS_PORT=${ARCHON_AGENTS_PORT:-8052}
|
|
networks:
|
|
- app-network
|
|
depends_on:
|
|
archon-server:
|
|
condition: service_healthy
|
|
|
|
extra_hosts:
|
|
- "host.docker.internal:host-gateway"
|
|
healthcheck:
|
|
test:
|
|
[
|
|
"CMD",
|
|
"sh",
|
|
"-c",
|
|
'python -c "import socket; s=socket.socket(); s.connect((''localhost'', ${ARCHON_MCP_PORT:-8051})); s.close()"',
|
|
]
|
|
interval: 30s
|
|
timeout: 10s
|
|
retries: 3
|
|
start_period: 60s # Give dependencies time to start
|
|
|
|
# AI Agents Service (ML/Reranking)
|
|
archon-agents:
|
|
profiles:
|
|
- agents # Only starts when explicitly using --profile agents
|
|
build:
|
|
context: ./python
|
|
dockerfile: Dockerfile.agents
|
|
args:
|
|
BUILDKIT_INLINE_CACHE: 1
|
|
ARCHON_AGENTS_PORT: ${ARCHON_AGENTS_PORT:-8052}
|
|
container_name: archon-agents
|
|
ports:
|
|
- "${ARCHON_AGENTS_PORT:-8052}:${ARCHON_AGENTS_PORT:-8052}"
|
|
environment:
|
|
- SUPABASE_URL=${SUPABASE_URL}
|
|
- SUPABASE_SERVICE_KEY=${SUPABASE_SERVICE_KEY}
|
|
- OPENAI_API_KEY=${OPENAI_API_KEY:-}
|
|
- LOGFIRE_TOKEN=${LOGFIRE_TOKEN:-}
|
|
- SERVICE_DISCOVERY_MODE=docker_compose
|
|
- LOG_LEVEL=${LOG_LEVEL:-INFO}
|
|
- ARCHON_AGENTS_PORT=${ARCHON_AGENTS_PORT:-8052}
|
|
- ARCHON_SERVER_PORT=${ARCHON_SERVER_PORT:-8181}
|
|
networks:
|
|
- app-network
|
|
healthcheck:
|
|
test:
|
|
[
|
|
"CMD",
|
|
"sh",
|
|
"-c",
|
|
'python -c "import urllib.request; urllib.request.urlopen(''http://localhost:${ARCHON_AGENTS_PORT:-8052}/health'')"',
|
|
]
|
|
interval: 30s
|
|
timeout: 10s
|
|
retries: 3
|
|
start_period: 40s
|
|
|
|
# Frontend
|
|
archon-frontend:
|
|
build: ./archon-ui-main
|
|
container_name: archon-ui
|
|
ports:
|
|
- "${ARCHON_UI_PORT:-3737}:3737"
|
|
environment:
|
|
# Don't set VITE_API_URL so frontend uses relative URLs through proxy
|
|
# - VITE_API_URL=http://${HOST:-localhost}:${ARCHON_SERVER_PORT:-8181}
|
|
- VITE_ARCHON_SERVER_PORT=${ARCHON_SERVER_PORT:-8181}
|
|
- ARCHON_SERVER_PORT=${ARCHON_SERVER_PORT:-8181}
|
|
- HOST=${HOST:-localhost}
|
|
- PROD=${PROD:-false}
|
|
- VITE_ALLOWED_HOSTS=${VITE_ALLOWED_HOSTS:-}
|
|
- VITE_SHOW_DEVTOOLS=${VITE_SHOW_DEVTOOLS:-false}
|
|
- DOCKER_ENV=true
|
|
networks:
|
|
- app-network
|
|
healthcheck:
|
|
test: ["CMD", "curl", "-f", "http://localhost:3737"]
|
|
interval: 30s
|
|
timeout: 10s
|
|
retries: 3
|
|
volumes:
|
|
- ./archon-ui-main/src:/app/src
|
|
- ./archon-ui-main/public:/app/public
|
|
depends_on:
|
|
archon-server:
|
|
condition: service_healthy
|
|
|
|
networks:
|
|
app-network:
|
|
driver: bridge
|