Open Agent Skill Registry — Manage reusable AI agent skills across IDEs without drift.
You've built useful skills for your AI coding assistant. They work great in Cursor. Now you want them in Windsurf. And Claude. And Copilot.
Each tool expects skills in different locations with different formats:
- Cursor:
.cursor/skills/ - Windsurf:
.windsurf/skills/ - Claude:
.claude/commands/ - Copilot:
.github/.md
So you copy your skills everywhere. Then you improve one. Now the copies are stale. You forget which version is current. Some break silently. This is skill drift.
ASR keeps your skills in one place and generates thin adapters for each IDE.
┌─────────────────────────────────────────────────────────┐
│ Your Skills (canonical source) │
│ ~/skills/git-commit/SKILL.md │
│ ~/skills/code-review/SKILL.md │
└───────────────────────┬─────────────────────────────────┘
│
▼
oasr adapter
│
┌───────────────┼──────────────┐...───────────────┐
▼ ▼ ▼ ▼
.cursor/ .windsurf/ .claude/ <vendor>/
commands/ workflows/ commands/ skills/
No copying. No drift. One source of truth.
List all registered skills with metadata
# Register local skills
oasr add ~/skills/git-commit
oasr add ~/skills/code-review
# Register remote skills from GitHub/GitLab
oasr add https://github.com/user/skills-repo/tree/main/my-skill
oasr add https://gitlab.com/org/project/tree/main/cool-skill
# Generate adapters for a project
oasr adapter --output-dir ~/projects/my-app
# Result:
# ~/projects/my-app/.cursor/commands/git-commit.md
# ~/projects/my-app/.windsurf/workflows/git-commit.md
# ~/projects/my-app/.claude/commands/git-commit.md
Register skills directly from GitHub or GitLab
ASR supports registering skills directly from GitHub and GitLab repositories:
# Add a skill from GitHub
oasr add https://github.com/user/repo/tree/main/skills/my-skill
# Add a skill from GitLab
oasr add https://gitlab.com/org/project/tree/dev/cool-skill
# Sync remote skills (check for updates)
oasr sync
# Use remote skills
oasr use my-skill -d ./outputAuthentication (optional, for private repos and higher rate limits):
export GITHUB_TOKEN=ghp_your_token_here
export GITLAB_TOKEN=glpat_your_token_hereRemote skills are fetched on-demand during adapter and use operations. The registry stores the URL, and sync checks if the remote source has changed.
- Quickstart — Installation and first steps
- Commands — Full command reference
- Validation — Validation rules and error codes
| IDE | Adapter | Output |
|---|---|---|
| Cursor | cursor |
.cursor/commands/*.md |
| Windsurf | windsurf |
.windsurf/workflows/*.md |
| Codex | codex |
.codex/skills/*.md |
| GitHub Copilot | copilot |
.github/prompts/*.prompt.md |
| Claude Code | claude |
.claude/commands/*.md |
See LICENSE.
| Command | Screenshot |
|---|---|
| oasr list | ![]() |
| oasr add (local) | ![]() |
| oasr add (remote) | ![]() |
| oasr sync | ![]() |
| oasr status | ![]() |
| oasr find | ![]() |
| oasr adapter | ![]() |
See docs/.images/ for all screenshots.




