Purpose: Standard structure for subagent files
Priority: CRITICAL - Load this before creating subagent files
---
name: AgentName
description: Brief description
mode: subagent
temperature: 0.1
tools: {...}
permissions: {...}
---
# AgentName
> **Mission**: One-sentence mission
<rule id="rule_name">Rule description</rule>
<context>
<system>Role in pipeline</system>
<domain>Expertise area</domain>
<task>What agent does</task>
<constraints>Limitations</constraints>
</context>
<tier level="1" desc="Critical">
- @rule_id: Description
</tier>
## Workflow
### Step 1: Preparation
### Step 2: Execution
### Step 3: Output
## Output Format
```yaml
status: "success" | "failure"
---
## Section Details
### 1. Frontmatter
- ONLY valid OpenCode fields (see agent-frontmatter.md)
- No duplicate keys, orphaned items, or invalid fields
### 2. Header + Mission
```markdown
# TestEngineer
> **Mission**: Author tests following TDD — grounded in project standards.
<rule id="context_first">ALWAYS call ContextScout BEFORE writing tests.</rule>
<rule id="positive_and_negative">EVERY behavior needs positive AND negative tests.</rule>
<context>
<system>Code quality gate</system>
<domain>Code review, security, quality</domain>
<task>Review code against standards</task>
<constraints>Read-only, no modifications</constraints>
</context>
<tier level="1" desc="Critical">
- @context_first: Load context first
</tier>
<tier level="2" desc="Core">
- Load standards
- Analyze code
</tier>
<conflict_resolution>Tier 1 overrides Tier 2/3</conflict_resolution>
tools: {read: true, grep: true, glob: true, bash: false, edit: false, write: false}
permissions:
bash: {"*": "deny"}
edit: {"**/*": "deny"}
task: {contextscout: "allow", "*": "deny"}
tools: {read: true, edit: true, write: true, bash: true}
permissions:
bash: {"npm test *": "allow", "git *": "allow", "sudo *": "deny", "*": "deny"}
edit: {"**/*.env*": "deny", "**/*.key": "deny"}
task: {contextscout: "allow", "*": "deny"}
tools: {read: true, bash: true}
permissions:
bash: {"npx ts-node*task-cli*": "allow", "mkdir -p .tmp/tasks*": "allow", "*": "deny"}
.opencode/agent/subagents/
├── code/ # tester, reviewer, coder-agent, build-agent
├── core/ # task-manager, contextscout, documentation
├── system-builder/ # agent-generator, command-creator
└── utils/ # image-specialist
Context-First Pattern:
<rule id="context_first">
ALWAYS call ContextScout BEFORE starting work. Load relevant standards first.
</rule>
Read-Only Pattern:
<rule id="read_only">
Read-only agent. NEVER use write, edit, or bash. Provide suggestions only.
</rule>
Security Pattern:
permissions:
edit:
"**/*.env*": "deny"
"**/*.key": "deny"
"**/*.secret": "deny"
See existing subagents:
.opencode/agent/subagents/code/tester.md - Write-enabled with tests.opencode/agent/subagents/code/reviewer.md - Read-only reviewer.opencode/agent/subagents/core/task-manager.md - Restricted bashstandards/agent-frontmatter.mdcore-concepts/agent-metadata.mdguides/adding-agent.mdLast Updated: 2026-01-31 | Version: 1.0.0