Agent Skill
2/7/2026

opencode-skills

Create and manage OpenCode skills with proper SKILL.md format, frontmatter, and organization. Use for skill creation, naming conventions, permission configuration, and reference management. Use proactively when user says "create a skill", "SKILL.md", "skill discovery", "skill permissions", or asks about skill structure. Examples: - user: "Create a skill for database migrations" → design SKILL.md with description, instructions, optional references/ - user: "How do I restrict which skills an agent can use?" → explain permission.skill patterns - user: "Where should I put my skill?" → explain project vs global paths

J
justinlevinedotme
6GitHub Stars
1Views
npx skills add justinlevinedotme/jalco-opencode

SKILL.md

Nameopencode-skills
DescriptionCreate and manage OpenCode skills with proper SKILL.md format, frontmatter, and organization. Use for skill creation, naming conventions, permission configuration, and reference management. Use proactively when user says "create a skill", "SKILL.md", "skill discovery", "skill permissions", or asks about skill structure. Examples: - user: "Create a skill for database migrations" → design SKILL.md with description, instructions, optional references/ - user: "How do I restrict which skills an agent can use?" → explain permission.skill patterns - user: "Where should I put my skill?" → explain project vs global paths

name: opencode-skills description: |- Create and manage OpenCode skills with proper SKILL.md format, frontmatter, and organization. Use for skill creation, naming conventions, permission configuration, and reference management.

Use proactively when user says "create a skill", "SKILL.md", "skill discovery", "skill permissions", or asks about skill structure.

Examples:

  • user: "Create a skill for database migrations" → design SKILL.md with description, instructions, optional references/
  • user: "How do I restrict which skills an agent can use?" → explain permission.skill patterns
  • user: "Where should I put my skill?" → explain project vs global paths

<overview>

Create loadable knowledge modules that enhance agent capabilities.

A skill is a markdown file that provides specialized knowledge, workflows, or tool integrations. Skills are loaded on-demand via the skill tool when needed.

</overview> <rules>

Skill Fundamentals

Location

ScopePath
Project.opencode/skill/<name>/SKILL.md
Global~/.config/opencode/skill/<name>/SKILL.md

CRITICAL: The folder name MUST match the name in frontmatter.

Directory Structure

.opencode/skill/my-skill/
├── SKILL.md           # REQUIRED - Main skill definition
├── scripts/           # Optional - Executable scripts
│   └── validate.sh
├── references/        # Optional - Reference documents
│   └── schema.md
└── assets/            # Optional - Images, data files
    └── diagram.png

Naming Rules

RuleValidInvalid
Lowercasemy-skillMy-Skill
Alphanumeric + hyphenapi-clientapi_client
Match folder namefoo/SKILL.md with name: fooMismatch
</rules> <guidelines>

Frontmatter Schema

---
name: my-skill-name          # REQUIRED, MUST match folder name
description: |-              # REQUIRED, 1-1024 characters
  [Capability summary]. Use for [use cases].
  
  Use proactively when [trigger contexts].
  
  Examples:
  - user: "query" → action
  - user: "another query" → action
---

Description Pattern

The description MUST have three parts:

  1. Capability statement: What the skill does (1-2 sentences)
  2. Trigger contexts: "Use proactively when [conditions]"
  3. Examples: user: "query" → action format
description: |-
  Generate comprehensive API documentation from source code. Use for documenting REST endpoints, GraphQL schemas, and SDK methods.
  
  Use proactively when user says "document API", "generate docs", "API reference", or asks about endpoint documentation.
  
  Examples:
  - user: "Document this FastAPI app" → analyze routes, generate OpenAPI-style docs
  - user: "Create SDK documentation" → extract methods, parameters, return types
</guidelines> <examples>

Skill Content Structure

Recommended Sections

---
name: example-skill
description: |-
  [Description as above]
---

# Skill Title

Brief overview of what this skill enables.

## Core Concepts

Fundamental knowledge the agent needs.

## Workflow

Step-by-step process:

1. **Understand**: Gather requirements
2. **Analyze**: Assess current state
3. **Implement**: Make changes
4. **Verify**: Confirm correctness

## Patterns

### Pattern Name

\`\`\`language
// Code example
\`\`\`

## Anti-Patterns

- **Problem**: Description → **Solution**: Fix

## Validation

How to verify the skill's output is correct.

Length Guidelines

GuidelineRecommendation
SKILL.md total lengthSHOULD be under 500 lines
Complex documentationSHOULD use references/ dir
Code examplesSHOULD use scripts/ dir
Progressive disclosureCore in SKILL.md, details in references
</examples> <rules>

Permission Configuration

Control which skills agents can load:

# In agent frontmatter or opencode.json
permission:
  skill:
    "*": "deny"              # Deny all by default
    "security-*": "allow"    # Allow security-prefixed
    "my-skill": "allow"      # Allow specific skill

Pattern Matching

PatternMatches
"*"All skills
"prefix-*"Skills starting with prefix-
"exact-name"Only that exact skill
</rules> <guidelines>

References Directory

For detailed documentation that would bloat SKILL.md:

.opencode/skill/my-skill/
├── SKILL.md
└── references/
    ├── schema.md          # JSON schema documentation
    ├── examples.md        # Extended examples
    └── troubleshooting.md # Common issues

Reference in SKILL.md:

See `references/schema.md` for the complete configuration schema.

Scripts Directory

For executable utilities:

.opencode/skill/my-skill/
├── SKILL.md
└── scripts/
    ├── validate.sh        # Validation script
    └── generate.py        # Generator script

Reference in SKILL.md:

Run validation:
\`\`\`bash
bash .opencode/skill/my-skill/scripts/validate.sh
\`\`\`

Skill Discovery

Skills are discovered at:

  1. Project: .opencode/skill/*/SKILL.md
  2. Global: ~/.config/opencode/skill/*/SKILL.md

Project skills take precedence over global skills with the same name.

</guidelines> <constraints>

Best Practices

MUST

  • Use the description pattern (capability + triggers + examples)
  • Keep SKILL.md focused and under 500 lines
  • Use references/ for detailed documentation
  • Test skill loading with skill my-skill-name
  • Include validation steps

MUST NOT

  • Create overly broad skills (prefer focused, composable skills)
  • Duplicate content that exists in other skills
  • Include secrets or credentials in skill files
  • Forget to match folder name with frontmatter name
</constraints> <examples>

Validation

After creating a skill:

opencode run "test"

Then test loading:

Load the my-skill-name skill and explain what it does.
</examples>
Skills Info
Original Name:opencode-skillsAuthor:justinlevinedotme