Add support for filtering search results by tags in the main search endpoint. Changes: - Add tags parameter to SearchQueryDto (comma-separated tag slugs) - Implement tag filtering in SearchService.search() method - Update SQL query to join with knowledge_entry_tags when tags provided - Entries must have ALL specified tags (AND logic) - Add tests for tag filtering (2 controller tests, 2 service tests) - Update endpoint documentation - Fix non-null assertion linting error The search endpoint now supports: - Full-text search with ranking (ts_rank) - Snippet generation with highlighting (ts_headline) - Status filtering - Tag filtering (new) - Pagination Example: GET /api/knowledge/search?q=api&tags=documentation,tutorial All tests pass (25 total), type checking passes, linting passes. Fixes #66 Co-Authored-By: Claude Sonnet 4.5 <noreply@anthropic.com>
274 lines
7.9 KiB
Markdown
274 lines
7.9 KiB
Markdown
# Issue ORCH-103: Docker Compose integration for orchestrator
|
|
|
|
## Objective
|
|
|
|
Add orchestrator service to docker-compose.yml files with proper dependencies, environment variables, volume mounts, health check, and port exposure.
|
|
|
|
## Current State Analysis
|
|
|
|
### Existing Docker Compose Files
|
|
|
|
1. **Root docker-compose.yml** - Main production compose file
|
|
- Already has orchestrator service configured (lines 353-397)
|
|
- Dependencies: valkey, api (NOT coordinator)
|
|
- Port: 3002:3001 (external:internal)
|
|
- Volumes: docker.sock, orchestrator_workspace
|
|
- Health check: configured
|
|
- Network: mosaic-internal
|
|
|
|
2. **docker/docker-compose.yml** - Development compose file
|
|
- Has coordinator service (lines 42-69)
|
|
- No orchestrator service yet
|
|
- Uses mosaic-network
|
|
|
|
### ORCH-103 Acceptance Criteria Review
|
|
|
|
From docs/M6-NEW-ISSUES-TEMPLATES.md:
|
|
|
|
- [x] orchestrator service added to docker-compose.yml (EXISTS in root)
|
|
- [ ] **Depends on: valkey, coordinator** (root has valkey, api instead)
|
|
- [x] Environment variables configured (VALKEY_URL, COORDINATOR_URL, CLAUDE_API_KEY)
|
|
- Missing COORDINATOR_URL in root
|
|
- [x] Volume mounts: /var/run/docker.sock (Docker-in-Docker), /workspace (git operations)
|
|
- [x] Health check configured
|
|
- [x] Port 3001 exposed (externally as 3002)
|
|
|
|
## Issues Identified
|
|
|
|
### 1. Root docker-compose.yml
|
|
|
|
- **Missing dependency**: Should depend on coordinator, not api
|
|
- **Missing env var**: COORDINATOR_URL not set
|
|
- **Wrong dependency**: Currently depends on api, should be coordinator
|
|
|
|
### 2. docker/docker-compose.yml
|
|
|
|
- **Missing service**: No orchestrator service at all
|
|
- Needs to be added following the same pattern as root
|
|
|
|
## Implementation Plan
|
|
|
|
### Task 1: Fix Root docker-compose.yml
|
|
|
|
1. Change dependencies from `api` to `coordinator`
|
|
2. Add COORDINATOR_URL environment variable
|
|
3. Verify all other requirements match
|
|
|
|
### Task 2: Add Orchestrator to docker/docker-compose.yml
|
|
|
|
1. Add orchestrator service configuration
|
|
2. Set dependencies: valkey, coordinator
|
|
3. Configure environment variables
|
|
4. Mount volumes (docker.sock, workspace)
|
|
5. Add health check
|
|
6. Expose port 3001
|
|
|
|
## Notes
|
|
|
|
### Coordinator Service Discovery
|
|
|
|
- Root compose: No coordinator service (coordinator runs separately)
|
|
- docker/ compose: Has coordinator service on port 8000
|
|
- Need to handle both scenarios
|
|
|
|
### Port Mapping
|
|
|
|
- Root: 3002:3001 (avoid conflict with API on 3001)
|
|
- docker/: Can use 3001:3001 (isolated environment)
|
|
|
|
### Network Isolation
|
|
|
|
- Root: Uses mosaic-internal (isolated from public)
|
|
- docker/: Uses mosaic-network (single network)
|
|
|
|
## Testing Plan
|
|
|
|
1. Validate docker-compose.yml syntax
|
|
2. Check for port conflicts
|
|
3. Verify environment variables reference correct services
|
|
4. Ensure dependencies exist in same compose file
|
|
|
|
## Implementation Complete
|
|
|
|
### Changes Made
|
|
|
|
#### 1. Root docker-compose.yml (/home/localadmin/src/mosaic-stack/docker-compose.yml)
|
|
|
|
- Added coordinator service before orchestrator (lines 353-387)
|
|
- Build context: ./apps/coordinator
|
|
- Port: 8000
|
|
- Dependencies: valkey
|
|
- Environment: GITEA integration, VALKEY_URL
|
|
- Health check: Python urllib check on /health endpoint
|
|
- Network: mosaic-internal
|
|
- Updated orchestrator service (lines 389-440)
|
|
- Changed dependency from `api` to `coordinator`
|
|
- Added COORDINATOR_URL environment variable: http://coordinator:8000
|
|
- All other requirements already met
|
|
|
|
#### 2. docker/docker-compose.yml (/home/localadmin/src/mosaic-stack/docker/docker-compose.yml)
|
|
|
|
- Updated coordinator service (lines 42-69)
|
|
- Added VALKEY_URL environment variable
|
|
- Added dependency on valkey service
|
|
- Added orchestrator service (lines 71-112)
|
|
- Build context: .. (parent directory)
|
|
- Dockerfile: ./apps/orchestrator/Dockerfile
|
|
- Port: 3001:3001
|
|
- Dependencies: valkey, coordinator
|
|
- Environment variables:
|
|
- ORCHESTRATOR_PORT: 3001
|
|
- VALKEY_URL: redis://valkey:6379
|
|
- COORDINATOR_URL: http://coordinator:8000
|
|
- CLAUDE_API_KEY: ${CLAUDE_API_KEY}
|
|
- DOCKER_SOCKET: /var/run/docker.sock
|
|
- GIT_USER_NAME, GIT_USER_EMAIL
|
|
- KILLSWITCH_ENABLED, SANDBOX_ENABLED
|
|
- Volume mounts:
|
|
- /var/run/docker.sock:/var/run/docker.sock (Docker-in-Docker)
|
|
- orchestrator_workspace:/workspace (git operations)
|
|
- Health check: wget check on http://localhost:3001/health
|
|
- Network: mosaic-network
|
|
- Added orchestrator_workspace volume (line 78)
|
|
|
|
#### 3. .env.example
|
|
|
|
- Added COORDINATOR_PORT=8000 configuration (lines 148-151)
|
|
|
|
### Validation Results
|
|
|
|
- Root docker-compose.yml: PASSED (syntax valid)
|
|
- docker/docker-compose.yml: PASSED (syntax valid)
|
|
- Both files show expected warnings for unset environment variables (normal)
|
|
|
|
### Acceptance Criteria Status
|
|
|
|
- [x] orchestrator service added to docker-compose.yml (BOTH files)
|
|
- [x] Depends on: valkey, coordinator (BOTH files)
|
|
- [x] Environment variables configured (VALKEY_URL, COORDINATOR_URL, CLAUDE_API_KEY)
|
|
- [x] Volume mounts: /var/run/docker.sock (Docker-in-Docker), /workspace (git operations)
|
|
- [x] Health check configured
|
|
- [x] Port 3001 exposed (3002:3001 in root, 3001:3001 in docker/)
|
|
|
|
### Additional Improvements
|
|
|
|
1. Added coordinator service to root docker-compose.yml (was missing)
|
|
2. Documented coordinator in both compose files
|
|
3. Added COORDINATOR_PORT to .env.example for consistency
|
|
4. Ensured coordinator dependency on valkey in both files
|
|
|
|
### Port Mappings Summary
|
|
|
|
- Root docker-compose.yml (production):
|
|
- API: 3001 (internal)
|
|
- Coordinator: 8000:8000
|
|
- Orchestrator: 3002:3001 (avoids conflict with API)
|
|
- docker/docker-compose.yml (development):
|
|
- Coordinator: 8000:8000
|
|
- Orchestrator: 3001:3001 (isolated environment)
|
|
|
|
### Network Configuration
|
|
|
|
- Root: mosaic-internal (isolated)
|
|
- Docker: mosaic-network (single network for dev)
|
|
|
|
All requirements for ORCH-103 have been successfully implemented.
|
|
|
|
## Final Verification
|
|
|
|
### Syntax Validation
|
|
|
|
Both docker-compose files pass syntax validation:
|
|
|
|
```bash
|
|
docker compose -f /home/localadmin/src/mosaic-stack/docker-compose.yml config --quiet
|
|
docker compose -f /home/localadmin/src/mosaic-stack/docker/docker-compose.yml config --quiet
|
|
```
|
|
|
|
Result: PASSED (warnings for unset env vars are expected)
|
|
|
|
### Port Conflict Check
|
|
|
|
Root docker-compose.yml published ports:
|
|
|
|
- 3000: web
|
|
- 3001: api
|
|
- 3002: orchestrator (internal 3001)
|
|
- 5432: postgres
|
|
- 6379: valkey
|
|
- 8000: coordinator
|
|
- 9000/9443: authentik
|
|
|
|
Docker/docker-compose.yml published ports:
|
|
|
|
- 3001: orchestrator
|
|
- 5432: postgres
|
|
- 6379: valkey
|
|
- 8000: coordinator
|
|
|
|
Result: NO CONFLICTS
|
|
|
|
### Service Dependency Graph
|
|
|
|
```
|
|
Root docker-compose.yml:
|
|
orchestrator → coordinator → valkey
|
|
orchestrator → valkey
|
|
|
|
Docker/docker-compose.yml:
|
|
orchestrator → coordinator → valkey
|
|
orchestrator → valkey
|
|
```
|
|
|
|
### Environment Variables Documented
|
|
|
|
All orchestrator environment variables are documented in .env.example:
|
|
|
|
- COORDINATOR_PORT=8000 (NEW)
|
|
- ORCHESTRATOR_PORT=3001
|
|
- CLAUDE_API_KEY
|
|
- GIT_USER_NAME
|
|
- GIT_USER_EMAIL
|
|
- KILLSWITCH_ENABLED
|
|
- SANDBOX_ENABLED
|
|
|
|
### Files Modified
|
|
|
|
1. /home/localadmin/src/mosaic-stack/docker-compose.yml
|
|
- Added coordinator service (38 lines)
|
|
- Updated orchestrator service (2 lines: dependency + env var)
|
|
|
|
2. /home/localadmin/src/mosaic-stack/docker/docker-compose.yml
|
|
- Updated coordinator service (2 lines: dependency + env var)
|
|
- Added orchestrator service (42 lines)
|
|
- Added volume definition (3 lines)
|
|
|
|
3. /home/localadmin/src/mosaic-stack/.env.example
|
|
- Added COORDINATOR_PORT section (5 lines)
|
|
|
|
### Ready for Testing
|
|
|
|
The configuration is syntactically valid and ready for:
|
|
|
|
1. Building the orchestrator Docker image
|
|
2. Starting services with docker-compose up
|
|
3. Testing orchestrator health endpoint
|
|
4. Testing coordinator integration
|
|
|
|
Next steps (when ready):
|
|
|
|
```bash
|
|
# Build and start services
|
|
docker compose up -d coordinator orchestrator
|
|
|
|
# Check health
|
|
curl http://localhost:8000/health # coordinator
|
|
curl http://localhost:3002/health # orchestrator (root)
|
|
# or
|
|
curl http://localhost:3001/health # orchestrator (docker/)
|
|
|
|
# View logs
|
|
docker compose logs -f orchestrator
|
|
docker compose logs -f coordinator
|
|
```
|