Complete toolkit for configuring and extending OpenCode: agent creation, custom slash commands, configuration management, plugin development, and SDK usage.
98
98%
Does it follow best practices?
Impact
Pending
No eval scenarios have been run
Advisory
Suggest reviewing before use
Create and refine OpenCode agents through a guided Q&A process.
Create .opencode/agents/<name>.md:
---
description: Code review specialist. Use when user says "review", "check my code", "find bugs".
---
You are an expert code reviewer. Analyze code for bugs, security issues, and performance problems.
Provide specific, actionable feedback with line references.For subagents (Task tool only), add mode: subagent. For permission restrictions, add a permission: block:
---
mode: subagent
permission:
bash:
"*": "ask"
"npm test": "allow"
---Run bun run opencode and type /agents to confirm the new agent appears in the list.
An agent is a markdown file with YAML frontmatter. Three decisions drive every design:
| Decision | Why it matters |
|---|---|
Scope (description) | Controls when the agent triggers — too vague = never fires, too broad = fires on everything |
Mode (mode:) | all = visible everywhere; subagent = Task-tool only; primary = main list only |
Permissions (permission:) | Standard tools need no config; skills ALWAYS need explicit allowlists |
When to use: You need a distinct scope, persona, or permission set that differs from the default.
When NOT to use: Do not create an agent just to run a single command — use a slash command instead. Do not create a subagent when you just need a custom system prompt — use AGENTS.md.
Ask questions first. Follow phases in references/agent-patterns.md:
NEVER use bash: { "*": "allow" }. WHY: Allows destructive commands like rm -rf. Use "*": "ask" plus an explicit allowlist.
# BAD
permission:
bash:
"*": "allow"
# GOOD
permission:
bash:
"*": "ask"
"npm test": "allow"
"git status": "allow"NEVER write system prompts in third person. WHY: The model reads its own system prompt — third person is confusing and degrades instruction-following.
# BAD — "The assistant analyzes code..."
# GOOD — "You analyze code for bugs, security issues, and performance problems."NEVER add permission: block for standard tools. WHY: It creates noise and can accidentally restrict access to built-in capabilities. Only use permission: when you need to restrict or explicitly allow skills.
| Anti-Pattern | Fix |
|---|---|
Vague description | Add concrete trigger examples |
Missing mode: subagent on subagents | Set it explicitly |
skill: { "my-skill": "allow" } without "*": "deny" | Deny "*" first |
references/agent-patterns.md — Creation phases, patterns, prompt engineering, enhancement/troubleshootingreferences/opencode-config.md — Full frontmatter schema, tools, permissions reference