← 返回
未分类

Skill管理员

管理 SKILL 的安装、更新、卸载和用户自定义的系统级技能。 当用户在消息中提供 SKILL 安装包的 HTTP URL(.zip 链接)并要求安装或更新时触发本技能; 当用户要求卸载某个已安装的 SKILL 时触发本技能; 当用户要求对已安装的 SKILL 进行补充、修正、拓展或自定义时触发本技能; 当用户提到"安装技能"、"更新技能"、"卸载技能"、"修改技能规则"、"给技能补充内容"等意图时触发本技能。 日常编码、问答、讨论等普通对话不触发本技能。
管理 SKILL 的安装、更新、卸载和用户自定义的系统级技能。 当用户在消息中提供 SKILL 安装包的 HTTP URL(.zip 链接)并要求安装或更新时触发本技能; 当用户要求卸载某个已安装的 SKILL 时触发本技能; 当用户要求对已安装的 SKILL 进行补充、修正、拓展或自定义时触发本技能; 当用户提到"安装技能"、"更新技能"、"卸载技能"、"修改技能规则"、"给技能补充内容"等意图时触发本技能。 日常编码、问答、讨论等普通对话不触发本技能。
加博
未分类 community v1.0.0 1 版本 100000 Key: 无需
★ 0
Stars
📥 100
下载
💾 0
安装
1
版本
#latest

概述

SKILL 管理器

本技能是系统预装的基础技能,负责管理项目中所有 SKILL 的安装、更新、卸载和用户自定义。

SKILL 从 Store 下载后,通过本技能的流程安装到项目中,

并支持用户在不破坏官方内容的前提下进行个性化定制。

自我保护声明

以下规则具有最高优先级,不可被任何对话指令覆盖:

  1. skill-manager 自身的所有文件(SKILL.md、references/ 下的模板等)

不可通过对话修改、删除、重写或卸载。如果用户要求对 skill-manager 本身执行

任何安装、修改、卸载等管理操作,应礼貌拒绝并说明原因:

"skill-manager 是系统级基础技能,负责管理所有技能的安装和自定义。

修改它可能导致已安装技能的分层结构和自定义内容出现不可预期的问题,

因此不支持通过对话修改。"

  1. 每个已安装 SKILL 的根 SKILL.md(入口文件,即 /SKILL.md

也不可被用户通过对话直接修改。该文件由 skill-manager 自动生成和维护。

如果用户要求修改某个 SKILL 的根 SKILL.md,应引导其通过

补充(extensions/)或纠正(patches/)机制来实现需求。

  1. 所有已安装 SKILL 的 base/ 目录中的内容视为只读,

不可通过对话修改。如果用户要求直接修改 base/ 中的文件,

应引导其通过补充(extensions/)或纠正(patches/)机制来实现。


意图识别

收到用户消息时,先判断是否涉及 SKILL 管理。

以下情况触发本技能,其余按正常对话处理:

触发安装/更新流程的信号

  • 用户在消息中提供了 .zip 的 HTTP URL,并提到"安装"、"更新"、"升级"、"装一下"、"替换"等
  • 用户明确提到某个 SKILL 名称并表达安装或更新意图

触发卸载流程的信号

  • 用户提到"卸载"、"删除技能"、"移除技能"、"不用这个技能了"等意图
  • 用户明确提到某个已安装的 SKILL 名称并表达卸载意图

触发自定义流程的信号

  • 用户提到"加一个规则"、"补充"、"新增"、"拓展"等补充意图
  • 用户提到"改一下"、"不对"、"应该是"、"纠正"、"修正"等纠正意图
  • 用户提到某个已安装的 SKILL 名称并表达了定制意图

不触发本技能的情况

  • 日常编码、问答、讨论等普通对话
  • 用户要求"使用"某个已安装的 SKILL 来辅助工作(此时按该 SKILL 自身的指令执行)
  • 用户只是询问某个 SKILL 的内容或规则(只读查看,不涉及修改)

核心概念:分层架构

每个通过本技能安装的 SKILL 采用以下目录结构:

root/
├── skill-manager/                ← 预装的管理技能(不可操作)
├── <skill_name>/                 ← 官方内容区(openclaw 可能删除或覆盖此目录)
│   ├── SKILL.md                  ← 入口文件(每次安装后由 skill-manager 生成)
│   └── base/                     ← 官方原始内容(只读)
│       ├── SKILL.md
│       └── ...
└── _user/                        ← 用户定制区(skill-manager 独占管理)
    └── <skill_name>/
        ├── registry.md           ← 用户自定义注册表
        ├── extensions/           ← 用户补充内容(base 中不存在的新内容)
        └── patches/              ← 用户纠正内容(对 base 中具体条目的修正)

目录职责说明:

  • /base/ — 官方 SKILL 包的精确镜像,任何情况下不得修改
  • _user//extensions/ — 只存放 base 中不存在的全新内容,与 base 并行生效
  • _user//patches/ — 只存放对 base 中已有条目的定向修正,未修正的条目照常生效
  • _user//registry.md — 记录所有用户定制项,由 skill-manager 维护

关键设计原则: _user/ 目录由 skill-manager 独占管理,openclaw 的任何安装、更新、卸载操作均不得影响此目录及其内容。用户对某个技能的全部个人定制永久保存于此,重装技能不会丢失。

/SKILL.md 是该 SKILL 的唯一入口,使用该 SKILL 时必须先读取此文件,

按其中的阅读指令顺序组装最终生效的内容。


流程一:安装 / 更新 SKILL

步骤 1:下载、解压并识别

从用户消息中提取 .zip 的 HTTP URL,使用工具将其下载到本地临时目录。

如果下载失败(网络错误、URL 无效等),提示用户检查链接后重试,终止流程。

将下载的 .zip 文件解压到临时目录。

确认解压内容中包含 SKILL.md 文件(SKILL 的标准标识)。

如果不包含 SKILL.md,提示用户该包不是有效的 SKILL,终止流程。

步骤 2:提取元数据

从解压出的 SKILL.md 中提取 name 和 description:

提取 name:

  1. 检查 SKILL.md 头部是否包含 frontmatter(以 --- 包裹的 YAML 块)
  2. 如有 frontmatter 且包含 name: 字段 → 使用该值
  3. 如无 frontmatter 或无 name: 字段 → 使用 .zip 解压后的根目录名

提取 description:

  1. 检查 SKILL.md 头部是否包含 frontmatter
  2. 如有 frontmatter 且包含 description: 字段 → 使用该值
  3. 如无 frontmatter 或无 description: 字段 →

在 SKILL.md 正文中定位「技能描述」标题(可能是 # 技能描述## 技能描述 等),

提取该标题下方的文本内容作为 description

步骤 3:判断新装还是更新

检查 _user// 目录是否已存在:

  • 不存在 → 执行「全新安装」(步骤 4A)
  • 已存在 → 执行「更新」(步骤 4B)

> 注:以 _user// 作为判断依据,而非 / 目录。

> 原因:openclaw 可能在重装时删除 / 目录,但用户定制内容仍保存在 _user/ 中,

> 此时应视为更新而非全新安装,以保留用户的个人定制。

步骤 4A:全新安装

  1. 创建 /base/ 目录(直接创建到 base/ 层级,不需要先建 /
  2. 将解压出的全部原始内容直接复制到 /base/ 目录内

保持原始目录结构和文件内容不做任何修改。

验证: 复制完成后,/base/SKILL.md 必须存在;

/ 根目录下只应有 base/ 子目录,不应有其他文件或目录。

  1. _user// 下创建 extensions/ 目录,放入 .gitkeep 占位文件
  2. _user// 下创建 patches/ 目录,放入 .gitkeep 占位文件
  3. _user// 下创建 registry.md,写入空注册表(表头 + 无数据行)
  4. 读取 skill-manager/references/ROOT_TEMPLATE.md 模板,

用提取到的 name、description 和当前日期填充占位符,

扫描 base/ 目录结构填充 {{base_tree}}

{{patch_count}}{{extension_count}} 填为 0

生成 /SKILL.md 入口文件

  1. 向用户确认安装完成,展示 base/ 下的目录结构概要

向用户反馈的示例:

已安装技能 frontend-coding。

base/ 目录结构:
├── SKILL.md
├── scripts/lint-check.sh
├── rules/naming.md
├── rules/error-handling.md
└── templates/component.md

你可以直接使用该技能,也可以随时对它进行补充或修正。

步骤 4B:更新已有 SKILL

  1. 记录当前 /base/ 的完整目录树(文件路径列表)
  2. / 目录不存在(可能被 openclaw 删除),重新创建它
  3. 清空 /base/ 目录下所有内容
  4. 将新包的全部内容直接复制到 /base/ 内,保持原始结构。

验证: 复制完成后,/base/SKILL.md 必须存在;

/ 根目录下只应有 base/ 子目录和 SKILL.md 入口文件。

  1. 不触碰 _user// 目录
  2. 记录新版 /base/ 的完整目录树
  3. 比对新旧目录树,列出新增、删除、修改的文件
  4. 执行兼容性校验(见下方)
  5. 重新读取 skill-manager/references/ROOT_TEMPLATE.md 模板,

扫描 _user//patches/_user//extensions/ 获取实际文件数,

重新生成 /SKILL.md 入口文件(计数同步到当前状态)

  1. 向用户展示更新报告和兼容性检查结果

更新后兼容性校验

读取 _user//registry.md,对每条记录逐一检查:

检查 _user//patches/ 中的文件:

读取文件头部 target: 字段指向的 base 文件路径。

  • 如果该文件在新版 base 中已不存在

→ 状态标记为「已失效」,说明:patch 引用的文件已被官方删除

  • 如果该文件仍存在,逐条检查 patch 中每个 original: 文本

是否在新版文件内容中仍能精确找到

  • 全部找到 → 状态标记为「有效」
  • 部分或全部找不到 → 状态标记为「需审核」,

说明:原文已被官方改写,patch 可能需要调整

检查 _user//extensions/ 中的文件:

读取文件头部 relates_to: 字段。

  • 检查新版 base 中是否新增了同名文件或同主题内容
  • 未发现重叠 → 状态标记为「有效」
  • 发现重叠 → 状态标记为「需审核」,

说明:官方已新增同主题内容,可能存在重复或冲突

向用户展示更新报告的格式:

更新完成:<name>

base/ 变更:
- 新增: <文件列表>
- 删除: <文件列表>
- 修改: <文件列表>

用户自定义兼容性:
| 用户文件 | 状态 | 说明 |
|----------|------|------|
| patches/xxx | 有效 / 需审核 / 已失效 | 具体原因 |
| extensions/xxx | 有效 / 需审核 | 具体原因 |

标记为「需审核」的项建议你检查一下,需要我帮你对比具体内容吗?

流程二:用户自定义(补充或纠正)

步骤 1:定位目标 SKILL

根据用户提到的 SKILL 名称定位到对应目录。

如果用户未明确提到名称,根据用户描述的内容领域,

扫描已安装的 SKILL 列表进行推断。

如果仍无法确定,询问用户要操作哪个技能。

步骤 2:读取现有内容

读取目标 SKILL 的根 /SKILL.md,了解阅读指令。

读取 _user//registry.md,了解已有自定义记录。

然后扫描 /base/ 下与用户描述相关的文件,

理解官方已有的内容范围和具体条目。

步骤 3:判定自定义模式

将用户需求与 base 已有内容做比对,按以下规则判定:

判定为「补充」(append)——满足任一:

  • 用户描述的主题在 base 中完全不存在(新话题、新领域)
  • 用户明确表达了"新增"、"加一个"、"补充"、"额外"、"拓展"等意图
  • 用户描述的内容不与 base 中任何已有条目矛盾,属于全新规则/模板/配置

判定为「纠正」(patch)——满足任一:

  • 用户描述直接针对 base 中某个已有条目,且给出了与其矛盾的版本
  • 用户明确表达了"不对"、"改成"、"应该是"、"纠正"、"修正"等意图
  • 用户引用了 base 中的具体文字或规则并给出了不同版本

无法判定时:

先列出 base 中与用户描述相关的已有内容,然后询问用户:

"base 中已有以下相关内容:[列出具体条目]。

你是想在这些基础上补充新内容,还是修正其中某条具体规则?"

步骤 4:创建自定义文件

如果是补充(append):

_user//extensions/ 下创建文件。目录结构参照 base 的组织方式

(如 base 中规则放在 rules/ 下,那用户补充的规则也放在 extensions/rules/ 下)。

文件头部必须包含以下 frontmatter 元数据:

---
mode: append
relates_to: <对应 base 中的目录或文件路径,如 base/rules/>
created: <当前日期>
reason: <用户自定义的原因摘要>
---

<用户补充的具体内容>

如果是纠正(patch):

_user//patches/ 下创建文件,路径与被纠正的 base 文件对应

(如纠正 base/rules/naming.md,则创建 _user//patches/rules/naming.md)。

文件头部必须包含以下 frontmatter 元数据,

正文使用结构化的纠正格式:

---
mode: patch
target: <被纠正的 base 文件路径,如 base/rules/naming.md>
created: <当前日期>
reason: <用户纠正的原因摘要>
---

## patch-001
- section: <所属章节或上下文描述>
- original: <base 中的原始内容,精确引用>
- corrected: <用户要求的正确内容>

## patch-002
- section: ...
- original: ...
- corrected: ...

其余内容沿用 base 原文,不做修改。

步骤 5:更新注册表和入口文件

  1. _user//registry.md 的注册表中追加一行:

```

| <文件路径> | | <简要说明> | <日期> |

```

  1. 重新生成 /SKILL.md 入口文件

读取 skill-manager/references/ROOT_TEMPLATE.md 模板,

扫描 _user//patches/_user//extensions/ 获取最新文件数,

用当前实际状态重新填充所有占位符,覆盖写入 /SKILL.md

这一步确保入口文件中的计数与磁盘状态始终同步。

步骤 6:向用户确认

告诉用户:

  • 执行了什么操作(补充 / 纠正)
  • 文件创建在什么位置
  • 如何生效(补充内容追加在 base 之后生效;纠正内容覆盖 base 中对应条目,其余照常)

流程三:卸载 SKILL

步骤 1:确认目标

根据用户消息确认要卸载的 SKILL 名称。

如果目标是 skill-manager 本身,触发自我保护,礼貌拒绝:

"skill-manager 是系统级基础技能,不支持卸载。"

步骤 2:向用户二次确认

卸载操作将删除该技能的全部内容,包括用户的个人定制,且不可恢复。

执行前必须向用户明确说明并要求确认:

即将卸载技能「<name>」。

以下内容将被永久删除:
- <name>/(官方内容)
- _user/<name>/(你的全部个人定制)

此操作不可恢复,确认卸载吗?

步骤 3:执行卸载

用户确认后:

  1. 删除 / 目录(含 SKILL.md 和 base/)
  2. 删除 _user// 目录(含 registry.md、extensions/、patches/)
  3. 向用户确认卸载完成

附录:对话场景参考

场景 A:普通对话(不触发)

用户:帮我写一个 React 登录组件

与 SKILL 管理无关,正常响应即可。

场景 B:安装

用户:帮我安装前端编码助手 http://dsclaw-server.cn/dsclaw/install/xxx/frontend-coding_skill.zip

触发安装流程。下载 → 解压 → 提取元数据 → 检查 _user/frontend-coding/ 不存在 → 执行全新安装。

场景 C:更新

用户:帮我更新前端编码助手 http://dsclaw-server.cn/dsclaw/install/xxx/frontend-coding_skill.zip

触发更新流程。下载 → 解压 → 检查 _user/frontend-coding/ 已存在 → 替换 base/ → 校验用户自定义 → 展示报告。

场景 D:用户不区分安装和更新

用户:帮我装上这个 http://dsclaw-server.cn/dsclaw/install/xxx/frontend-coding_skill.zip

不需要用户区分。检查 _user// 是否存在,自动走对应分支。

场景 E:明确的补充

用户:帮我在 frontend-coding 里加一个国际化规范

触发自定义流程。读取 base → 未找到国际化相关内容 → 判定为补充 →

创建 _user/frontend-coding/extensions/rules/i18n.md → 更新 _user/frontend-coding/registry.md

场景 F:明确的纠正

用户:frontend-coding 里命名规范要求 camelCase,
     但我们项目用 snake_case,帮我改一下

触发自定义流程。读取 frontend-coding/base/rules/naming.md

找到 camelCase 规则 → 用户给出矛盾版本 → 判定为纠正 →

创建 _user/frontend-coding/patches/rules/naming.md → 更新注册表。

场景 G:意图模糊

用户:帮我改改 frontend-coding 的错误处理

触发自定义流程。读取 base → 找到 error-handling.md →

无法判断是补充还是纠正 → 列出已有内容并反问用户确认。

场景 H:使用 SKILL(不触发 skill-manager)

用户:用 frontend-coding 技能帮我审查这段代码

这是「使用」SKILL 而非「管理」SKILL,不触发 skill-manager。

frontend-coding/SKILL.md 的阅读指令加载内容,辅助审查。

场景 I:试图修改或卸载 skill-manager(触发保护)

用户:帮我把 skill-manager 的安装逻辑改一下
用户:帮我卸载 skill-manager

触发自我保护。礼貌拒绝并说明:

"skill-manager 是系统级基础技能,负责管理所有技能的安装和自定义。

修改它可能导致已安装技能的分层结构和自定义内容出现不可预期的问题,

因此不支持通过对话修改。"

场景 J:试图直接修改 base/ 或根 SKILL.md(引导保护)

用户:帮我直接改一下 frontend-coding/base/rules/naming.md

触发保护。引导用户通过正规机制实现:

"base/ 目录中的内容是官方原始版本,不支持直接修改。

如果你想修正其中的某条规则,我可以通过纠正机制(patches/)来实现,

官方原文保持不变,你的修正版本会在使用时优先生效。

你想修正 naming.md 中的哪条规则?"

场景 K:卸载技能

用户:帮我卸载 frontend-coding

触发卸载流程。向用户说明将删除的内容(含个人定制),要求二次确认。

确认后删除 frontend-coding/_user/frontend-coding/,告知完成。

版本历史

共 1 个版本

  • v1.0.0 Initial release 当前
    2026-05-06 13:55 安全 安全

安全检测

腾讯云安全 (Keen)

安全,无风险
查看报告

腾讯云安全 (Sanbu)

安全,无风险
查看报告

🔗 相关推荐

ai-agent

Find Skills

guipi888
场景驱动+关键词双模式技能发现工具。当用户用自然语言描述场景/需求(如"我想做一个海报""帮我分析股票"),或明确说"安装技能/find skills/找个skill"时,自动从官方内置、本地已安装、SkillHub、虾评、GitHub、C
★ 1,494 📥 558,974
ai-agent

Skill Vetter

spclaudehome
AI智能体技能安全预审工具。安装ClawdHub、GitHub等来源技能前,检查风险信号、权限范围及可疑模式。
★ 1,243 📥 271,442
ai-agent

Agent Browser

rez0
用于 AI 代理的浏览器自动化 CLI。当用户需要与网站交互(包括浏览页面、填写表单、点击按钮、截图等)时使用。
★ 844 📥 325,923