# CLAUDE.md This file provides guidance to Claude Code (claude.ai/code) when working with code in this repository. ## Alpha Development Guidelines **Local-only deployment** - each user runs their own instance. ### Core Principles - **No backwards compatibility** - remove deprecated code immediately - **Detailed errors over graceful failures** - we want to identify and fix issues fast - **Break things to improve them** - alpha is for rapid iteration ### Error Handling **Core Principle**: In alpha, we need to intelligently decide when to fail hard and fast to quickly address issues, and when to allow processes to complete in critical services despite failures. Read below carefully and make intelligent decisions on a case-by-case basis. #### When to Fail Fast and Loud (Let it Crash!) These errors should stop execution and bubble up immediately: - **Service startup failures** - If credentials, database, or any service can't initialize, the system should crash with a clear error - **Missing configuration** - Missing environment variables or invalid settings should stop the system - **Database connection failures** - Don't hide connection issues, expose them - **Authentication/authorization failures** - Security errors must be visible and halt the operation - **Data corruption or validation errors** - Never silently accept bad data, Pydantic should raise - **Critical dependencies unavailable** - If a required service is down, fail immediately - **Invalid data that would corrupt state** - Never store zero embeddings, null foreign keys, or malformed JSON #### When to Complete but Log Detailed Errors These operations should continue but track and report failures clearly: - **Batch processing** - When crawling websites or processing documents, complete what you can and report detailed failures for each item - **Background tasks** - Embedding generation, async jobs should finish the queue but log failures - **WebSocket events** - Don't crash on a single event failure, log it and continue serving other clients - **Optional features** - If projects/tasks are disabled, log and skip rather than crash - **External API calls** - Retry with exponential backoff, then fail with a clear message about what service failed and why #### Critical Nuance: Never Accept Corrupted Data When a process should continue despite failures, it must **skip the failed item entirely** rather than storing corrupted data: **❌ WRONG - Silent Corruption:** ```python try: embedding = create_embedding(text) except Exception as e: embedding = [0.0] * 1536 # NEVER DO THIS - corrupts database store_document(doc, embedding) ``` **✅ CORRECT - Skip Failed Items:** ```python try: embedding = create_embedding(text) store_document(doc, embedding) # Only store on success except Exception as e: failed_items.append({'doc': doc, 'error': str(e)}) logger.error(f"Skipping document {doc.id}: {e}") # Continue with next document, don't store anything ``` **✅ CORRECT - Batch Processing with Failure Tracking:** ```python def process_batch(items): results = {'succeeded': [], 'failed': []} for item in items: try: result = process_item(item) results['succeeded'].append(result) except Exception as e: results['failed'].append({ 'item': item, 'error': str(e), 'traceback': traceback.format_exc() }) logger.error(f"Failed to process {item.id}: {e}") # Always return both successes and failures return results ``` #### Error Message Guidelines - Include context about what was being attempted when the error occurred - Preserve full stack traces with `exc_info=True` in Python logging - Use specific exception types, not generic Exception catching - Include relevant IDs, URLs, or data that helps debug the issue - Never return None/null to indicate failure - raise an exception with details - For batch operations, always report both success count and detailed failure list ### Code Quality - Remove dead code immediately rather than maintaining it - no backward compatibility or legacy functions - Prioritize functionality over production-ready patterns - Focus on user experience and feature completeness - When updating code, don't reference what is changing (avoid keywords like LEGACY, CHANGED, REMOVED), instead focus on comments that document just the functionality of the code ## Architecture Overview Archon V2 Alpha is a microservices-based knowledge management system with MCP (Model Context Protocol) integration: - **Frontend (port 3737)**: React + TypeScript + Vite + TailwindCSS - **Main Server (port 8181)**: FastAPI + Socket.IO for real-time updates - **MCP Server (port 8051)**: Lightweight HTTP-based MCP protocol server - **Agents Service (port 8052)**: PydanticAI agents for AI/ML operations - **Database**: Supabase (PostgreSQL + pgvector for embeddings) ## Development Commands ### Frontend (archon-ui-main/) ```bash npm run dev # Start development server on port 3737 npm run build # Build for production npm run lint # Run ESLint npm run test # Run Vitest tests npm run test:coverage # Run tests with coverage report ``` ### Backend (python/) ```bash # Using uv package manager uv sync # Install/update dependencies uv run pytest # Run tests uv run python -m src.server.main # Run server locally # With Docker docker-compose up --build -d # Start all services docker-compose logs -f # View logs docker-compose restart # Restart services ``` ### Testing ```bash # Frontend tests (from archon-ui-main/) npm run test:coverage:stream # Run with streaming output npm run test:ui # Run with Vitest UI # Backend tests (from python/) uv run pytest tests/test_api_essentials.py -v uv run pytest tests/test_service_integration.py -v ``` ## Key API Endpoints ### Knowledge Base - `POST /api/knowledge/crawl` - Crawl a website - `POST /api/knowledge/upload` - Upload documents (PDF, DOCX, MD) - `GET /api/knowledge/items` - List knowledge items - `POST /api/knowledge/search` - RAG search ### MCP Integration - `GET /api/mcp/health` - MCP server status - `POST /api/mcp/tools/{tool_name}` - Execute MCP tool - `GET /api/mcp/tools` - List available tools ### Projects & Tasks (when enabled) - `GET /api/projects` - List projects - `POST /api/projects` - Create project - `GET /api/projects/{id}/tasks` - Get project tasks - `POST /api/projects/{id}/tasks` - Create task ## Socket.IO Events Real-time updates via Socket.IO on port 8181: - `crawl_progress` - Website crawling progress - `project_creation_progress` - Project setup progress - `task_update` - Task status changes - `knowledge_update` - Knowledge base changes ## Environment Variables Required in `.env`: ```bash SUPABASE_URL=https://your-project.supabase.co SUPABASE_SERVICE_KEY=your-service-key-here ``` Optional: ```bash OPENAI_API_KEY=your-openai-key # Can be set via UI LOGFIRE_TOKEN=your-logfire-token # For observability LOG_LEVEL=INFO # DEBUG, INFO, WARNING, ERROR ``` ## File Organization ### Frontend Structure - `src/components/` - Reusable UI components - `src/pages/` - Main application pages - `src/services/` - API communication and business logic - `src/hooks/` - Custom React hooks - `src/contexts/` - React context providers ### Backend Structure - `src/server/` - Main FastAPI application - `src/server/api_routes/` - API route handlers - `src/server/services/` - Business logic services - `src/mcp/` - MCP server implementation - `src/agents/` - PydanticAI agent implementations ## Database Schema Key tables in Supabase: - `sources` - Crawled websites and uploaded documents - `documents` - Processed document chunks with embeddings - `projects` - Project management (optional feature) - `tasks` - Task tracking linked to projects - `code_examples` - Extracted code snippets ## Common Development Tasks ### Add a new API endpoint 1. Create route handler in `python/src/server/api_routes/` 2. Add service logic in `python/src/server/services/` 3. Include router in `python/src/server/main.py` 4. Update frontend service in `archon-ui-main/src/services/` ### Add a new UI component 1. Create component in `archon-ui-main/src/components/` 2. Add to page in `archon-ui-main/src/pages/` 3. Include any new API calls in services 4. Add tests in `archon-ui-main/test/` ### Debug MCP connection issues 1. Check MCP health: `curl http://localhost:8051/health` 2. View MCP logs: `docker-compose logs archon-mcp` 3. Test tool execution via UI MCP page 4. Verify Supabase connection and credentials ## Code Quality Standards We enforce code quality through automated linting and type checking: - **Python 3.12** with 120 character line length - **Ruff** for linting - checks for errors, warnings, unused imports, and code style - **Mypy** for type checking - ensures type safety across the codebase - **Auto-formatting** on save in IDEs to maintain consistent style - Run `uv run ruff check` and `uv run mypy src/` locally before committing ## MCP Tools Available When connected to Cursor/Windsurf: - `archon:perform_rag_query` - Search knowledge base - `archon:search_code_examples` - Find code snippets - `archon:manage_project` - Project operations - `archon:manage_task` - Task management - `archon:get_available_sources` - List knowledge sources ## Important Notes - Projects feature is optional - toggle in Settings UI - All services communicate via HTTP, not gRPC - Socket.IO handles all real-time updates - Frontend uses Vite proxy for API calls in development - Python backend uses `uv` for dependency management - Docker Compose handles service orchestration