10 KiB
Core Concept: Registry System
Purpose: Understanding how component tracking and distribution works
Priority: CRITICAL - Load this before working with registry
What Is the Registry?
The registry is a centralized catalog (registry.json) that tracks all components in OpenAgents Control:
- Agents - AI agent prompts
- Subagents - Delegated specialists
- Commands - Slash commands
- Tools - Custom tools
- Contexts - Context files
Location: registry.json (root directory)
Registry Schema
Top-Level Structure
{
"version": "0.5.0",
"schema_version": "2.0.0",
"components": {
"agents": [...],
"subagents": [...],
"commands": [...],
"tools": [...],
"contexts": [...]
},
"profiles": {
"essential": {...},
"developer": {...},
"business": {...}
}
}
Component Entry
{
"id": "frontend-specialist",
"name": "Frontend Specialist",
"type": "agent",
"path": ".opencode/agent/development/frontend-specialist.md",
"description": "Expert in React, Vue, and modern CSS",
"category": "development",
"tags": ["react", "vue", "css", "frontend"],
"dependencies": ["subagent:tester"],
"version": "0.5.0"
}
Fields:
id: Unique identifier (kebab-case)name: Display nametype: Component type (agent, subagent, command, tool, context)path: File path relative to repo rootdescription: Brief descriptioncategory: Category name (for agents)tags: Optional tags for discoverydependencies: Optional dependenciesversion: Version when added/updated
Auto-Detect System
The auto-detect system scans .opencode/ and automatically updates the registry.
How It Works
1. Scan .opencode/ directory
2. Find all .md files with frontmatter
3. Extract metadata (description, category, type, tags)
4. Validate paths exist
5. Generate component entries
6. Update registry.json
Running Auto-Detect
# Dry run (see what would be added)
./scripts/registry/auto-detect-components.sh --dry-run
# Actually add components
./scripts/registry/auto-detect-components.sh --auto-add
# Force update existing entries
./scripts/registry/auto-detect-components.sh --auto-add --force
What Gets Detected
✅ Agents - .opencode/agent/{category}/*.md
✅ Subagents - .opencode/agent/subagents/**/*.md
✅ Commands - .opencode/command/**/*.md
✅ Tools - .opencode/tool/**/index.ts
✅ Contexts - .opencode/context/**/*.md
Frontmatter Requirements
For auto-detect to work, files must have frontmatter:
---
description: "Brief description"
category: "category-name" # For agents
type: "agent" # Or subagent, command, tool, context
tags: ["tag1", "tag2"] # Optional
---
Validation
Registry Validation
# Validate registry
./scripts/registry/validate-registry.sh
# Verbose output
./scripts/registry/validate-registry.sh -v
What Gets Validated
✅ Schema - Correct JSON structure
✅ Paths - All paths exist
✅ IDs - Unique IDs
✅ Categories - Valid categories
✅ Dependencies - Dependencies exist
✅ Versions - Version consistency
Validation Errors
# Example errors
ERROR: Path does not exist: .opencode/agent/core/missing.md
ERROR: Duplicate ID: frontend-specialist
ERROR: Invalid category: invalid-category
ERROR: Missing dependency: subagent:nonexistent
Agents vs Subagents
Main Agents (2 in Developer profile):
- openagent: Universal coordination agent
- opencoder: Complex coding and architecture
Specialist Subagents (8 in Developer profile):
-
frontend-specialist: React, Vue, CSS architecture
-
devops-specialist: CI/CD, infrastructure, deployment
-
task-manager: Feature breakdown and planning
-
documentation: Create and update docs
-
coder-agent: Execute coding subtasks
-
reviewer: Code review and security
-
tester: Write unit and integration tests
-
build-agent: Type checking and validation
-
image-specialist: Generate and edit images
Commands (7 in Developer profile):
- analyze-patterns: Analyze codebase for patterns
- commit, test, context, clean, optimize, validate-repo
Component Profiles
Profiles are pre-configured component bundles for quick installation.
Available Profiles
Essential Profile
Purpose: Minimal setup for basic usage
Includes:
- Core agents (openagent, opencoder)
- Essential commands (commit, test)
- Core context files
"essential": {
"description": "Minimal setup for basic usage",
"components": [
"agent:openagent",
"agent:opencoder",
"command:commit",
"command:test"
]
}
Developer Profile
Purpose: Full development setup
Includes:
- All core agents
- Development specialists
- All subagents
- Dev commands
- Dev context files
"developer": {
"description": "Full development setup",
"components": [
"agent:*",
"subagent:*",
"command:*",
"context:core/*",
"context:development/*"
]
}
Business Profile
Purpose: Content and product focus
Includes:
- Core agents
- Content specialists
- Product specialists
- Content context files
"business": {
"description": "Content and product focus",
"components": [
"agent:openagent",
"agent:copywriter",
"agent:technical-writer",
"context:core/*",
"context:content/*"
]
}
Install System
The install system uses the registry to distribute components.
Installation Flow
1. User runs install.sh
2. Check for local registry.json (development mode)
3. If not local, fetch from GitHub (production mode)
4. Parse registry.json
5. Show component selection UI
6. Resolve dependencies
7. Download components from GitHub
8. Install to .opencode/
9. Handle collisions (skip/overwrite/backup)
Local Registry (Development)
# Test with local registry
REGISTRY_URL="file://$(pwd)/registry.json" ./install.sh --list
# Install with local registry
REGISTRY_URL="file://$(pwd)/registry.json" ./install.sh developer
Remote Registry (Production)
# Install from GitHub
./install.sh developer
# List available components
./install.sh --list
Dependency Resolution
Dependency Format
"dependencies": [
"subagent:tester",
"context:core/standards/code"
]
Resolution Rules
- Parse dependency string (
type:id) - Find component in registry
- Check if already installed
- Add to install queue
- Recursively resolve dependencies
- Install in dependency order
Example
User installs: frontend-specialist
↓
Depends on: subagent:tester
↓
Depends on: context:core/standards/tests
↓
Install order:
1. context:core/standards/tests
2. subagent:tester
3. frontend-specialist
Collision Handling
When installing components that already exist:
Collision Strategies
- Skip - Keep existing file
- Overwrite - Replace with new file
- Backup - Backup existing, install new
Interactive Mode
File exists: .opencode/agent/core/openagent.md
[S]kip, [O]verwrite, [B]ackup, [A]ll skip, [F]orce all?
Non-Interactive Mode
# Skip all collisions
./install.sh developer --skip-existing
# Overwrite all collisions
./install.sh developer --force
# Backup all collisions
./install.sh developer --backup
Version Management
Version Fields
- Registry version: Overall registry version (e.g., "0.5.0")
- Schema version: Registry schema version (e.g., "2.0.0")
- Component version: When component was added/updated
Version Consistency
# Check version consistency
cat VERSION
cat package.json | jq '.version'
cat registry.json | jq '.version'
# All should match
Updating Versions
# Bump version
echo "0.X.Y" > VERSION
jq '.version = "0.X.Y"' package.json > tmp && mv tmp package.json
jq '.version = "0.X.Y"' registry.json > tmp && mv tmp registry.json
CI/CD Integration
GitHub Workflows
Validate Registry (PR Checks)
# .github/workflows/validate-registry.yml
- name: Validate Registry
run: ./scripts/registry/validate-registry.sh
Auto-Update Registry (Post-Merge)
# .github/workflows/update-registry.yml
- name: Update Registry
run: ./scripts/registry/auto-detect-components.sh --auto-add
Version Bump (On Release)
# .github/workflows/version-bump.yml
- name: Bump Version
run: ./scripts/versioning/bump-version.sh
Best Practices
Adding Components
✅ Add frontmatter - Required for auto-detect
✅ Run auto-detect - Don't manually edit registry
✅ Validate - Always validate after changes
✅ Test locally - Use local registry for testing
Maintaining Registry
✅ Auto-detect first - Let scripts handle updates
✅ Validate often - Catch issues early
✅ Version consistency - Keep versions in sync
✅ CI validation - Automate validation in CI
Dependencies
✅ Explicit dependencies - List all dependencies
✅ Test resolution - Verify dependencies resolve
✅ Avoid cycles - No circular dependencies
Common Issues
Path Not Found
Problem: Registry references non-existent path
Solution: Run auto-detect or fix path manually
Duplicate ID
Problem: Two components with same ID
Solution: Rename one component
Invalid Category
Problem: Agent has invalid category
Solution: Use valid category (core, development, content, data, product, learning)
Missing Dependency
Problem: Dependency doesn't exist in registry
Solution: Add dependency or remove reference
Version Mismatch
Problem: VERSION, package.json, registry.json don't match
Solution: Update all version files to match
Related Files
- Updating registry:
guides/updating-registry.md - Adding agents:
guides/adding-agent.md - Categories:
core-concepts/categories.md
Last Updated: 2025-01-28
Version: 0.5.2