帮助管理来自 GitHub 仓库的技能安装、检查更新、更新和卸载。
技能安装到 skills/{skill-name}/,并通过 skills/skill-manager/REGISTRY.yaml 记录来源与 commit SHA。
所有 GitHub 操作都依赖已认证的 gh CLI。
执行前运行:
gh auth status
如果失败,提示:请先运行 gh auth login。 并停止。
从来源中提取这 4 个字段:
| 字段 | 说明 | 示例 |
|---|---|---|
| ------ | ------ | ------ |
owner | 仓库所有者 | openai |
repo | 仓库名称 | skills |
branch | 分支名,默认 main | main |
path | 仓库内技能目录路径 | skills/example-skill |
技能名称取 path 的最后一段目录名。
检查更新时,用表格输出结果:
| 技能名称 | 本地 commit SHA | 远程 commit SHA | 状态 |
|---------------|-----------------|-----------------|------|
| example-skill | abc1234 | def5678 | 需要更新 |
| web-search | 9f8e7d6 | 9f8e7d6 | 已是最新 |
安装、更新或卸载完成后,明确告诉用户受影响的技能名称和结果。
安装指定来源的技能,并写入 REGISTRY.yaml。
步骤:
owner、repo、branch、pathskills/{skill-name}/REGISTRY.yaml 中追加条目,记录 owner、repo、branch、path、commit 和 updated使用:
gh api "repos/{owner}/{repo}/tarball/{branch}" > archive.tar.gz
# 解压后将 {path} 复制到 skills/{skill-name}/
如果目标目录已存在,停止安装,不覆盖现有目录。
扫描 REGISTRY.yaml,检查已注册技能的远程 commit SHA 是否发生变化。
使用:
gh api "repos/{owner}/{repo}/contents/{path}?ref={branch}" --jq '.sha'
默认检查全部已注册技能;如果用户指定技能名,只检查对应条目。
检查失败时,跳过该技能,并保持本地文件和注册表不变。
更新已注册技能中有变化的条目。
步骤:
skills/{skill-name}/commit 和 updated未指定技能名时,更新全部过期技能;指定技能名时,只更新对应条目。
如果技能未注册,先告诉用户该技能不在 REGISTRY.yaml 中,不执行更新。
更新前如果发现本地有未保存的修改,先提示冲突风险。
任何下载或更新失败时,不覆盖本地文件,不修改对应注册表条目。
删除技能目录,并从 REGISTRY.yaml 中移除对应条目。
步骤:
skills/{skill-name}/REGISTRY.yaml 中移除对应条目如果技能目录不存在但注册表条目存在,只移除注册表条目。
位置:skills/skill-manager/REGISTRY.yaml
skills:
- owner: openai
repo: skills
branch: main
path: skills/example-skill
commit: abc123def456
updated: 2026-01-01
规则:
commit 和 updatedbranch=main 处理未显式指定分支的来源共 1 个版本