Implements weeks 1-4 of the multi-provider architecture: Week 1 - Foundation: - Add domain models (AgentProvider, AgentRequest, AgentEvent, AgentResult) - Define CodeAgent port interface with Execute, Cancel, Capabilities - Create thread-safe provider registry with first-registered default Week 2 - Claude Code Adapter: - Extract kubectl exec logic into CodeAgent implementation - Parse stream-json output format (init, message, tool_use, result) - Support session continuation via --resume flag Week 3 - OpenCode Adapter: - HTTP/SSE client for opencode serve API - Session management (create, send message, abort) - Event streaming with documented buffer rationale Week 4 - Quality & Polish: - Fix race condition in OpenCode Cancel method - Add AgentRequest.Validate() with ErrPromptRequired, ErrInvalidTimeout - Document DefaultAvailabilityTimeout constants - Add HTTP error context for debugging Also includes: - Work queue system with PostgreSQL adapter - Credential store for infrastructure secrets - Project templates with Woodpecker CI integration - Comprehensive test coverage Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
1.2 KiB
1.2 KiB
API Keys
Last Updated: 2025-01 Confidence: High
Summary
API keys authenticate all requests to rdev (except health/docs). Keys have scopes, can be restricted to specific projects and IP ranges, and have expiration dates.
Key Facts:
- Header:
X-API-Key: <key> - Keys are hashed before storage (only prefix visible)
- Admin key via
RDEV_ADMIN_KEYenv var for bootstrap - Scopes:
projects:read,projects:write,keys:read,keys:write,audit:read - Project restrictions: nil = all projects, or list of allowed project IDs
- IP restrictions: CIDR notation for allowed ranges
File Pointers:
- Service:
internal/auth/service.go - Middleware:
internal/auth/middleware.go - Handler:
internal/handlers/keys.go - Repository:
internal/adapter/postgres/apikey.go
Key Lifecycle
- Create via
POST /keys(admin only) - Key returned once (plaintext), stored hashed
- Validate on each request via middleware
- Revoke via
DELETE /keys/{id}
Scopes
| Scope | Allows |
|---|---|
projects:read |
List/get projects |
projects:write |
Execute commands |
keys:read |
List API keys |
keys:write |
Create/delete keys |
audit:read |
Query audit logs |