> 一键发布技能到 ClawHub 技能市场。
检查登录→确认技能目录→检测发布历史→推荐Slug→确认参数→执行发布→验证结果。
发布技能、ClawHub、publish、技能市场、上传、版本管理
clawhub whoami,未登录则clawhub loginclawhub inspect 判断是否已发布clawhub publish --slug --name --version --changelog --tags clawhub inspect判断是否已存在当用户说:
立即调用本技能。
clawhub whoami
结果:
clawhub login,等待用户浏览器登录检查技能文件夹是否存在:
/home/fslong/.copaw/workspaces/default/active_skills/<技能名>/SKILL.md
必须存在:
SKILL.md - 技能描述文件在确定参数前,必须检查该技能是否已在 ClawHub 存在:
clawhub inspect <候选slug>
(若 slug 不确定,可先用 clawhub list 模糊查找)
结果判断:
--tags 和 --name 完全一致!tags,作为本次发布的 --tags 参数。仅更新 --version 和 --changelog。Skill not found 或无输出。⚠️ 核心警告:
version(递增)和 changelog(本次改动)。⚠️ 关键区分:新技能 vs 更新技能
根据 Step 2.2 的检测结果,走不同流程:
3A.1 读取 SKILL.md 获取预设参数
先读取技能目录下的 SKILL.md,检查是否已定义:
name - 技能名称(如有则直接使用)metadata.slug 或 frontmatter 中的 slug(如有则直接使用,跳过推荐步骤)3A.2 Slug 推荐(仅当 SKILL.md 未定义 slug 时)
向用户展示 3 个不同维度的 Slug 推荐方案,等待用户选择。
推荐维度示例:
mochi, bantiinkpot, ojimportproblemporter, dailyreport⚠️ 推荐铁律:
- 或 _。3A.3 确定其他参数
| 参数 | 来源 | 示例 |
|---|---|---|
| ------ | ------ | ------ |
--slug | SKILL.md 或用户确认 | ojimport |
--name | SKILL.md 或技能目录名 | 搬题姬 |
--version | 首次发布默认 1.0.0 | 1.0.0 |
--changelog | 询问用户或自动生成 | 首次发布 |
--tags | SKILL.md 或询问用户 | oj,algorithm |
⚠️ 铁律:更新时必须保持 slug、name、tags 与历史一致!
3B.1 从 SKILL.md 读取 slug
# 读取 SKILL.md frontmatter 中的 slug
3B.2 从 clawhub inspect 输出提取历史信息
Latest: 1.7.0 → 新版本应为 1.7.1 或更高Tags: algorithm=1.7.0, oj=1.7.0 → tags 为 algorithm,ojojimport 搬题姬 → name 为 搬题姬3B.3 自动递增版本号
Latest: x.y.z 提取版本号x.y.z → x.y.(z+1)3B.4 确定参数
| 参数 | 来源 | 示例 |
|---|---|---|
| ------ | ------ | ------ |
--slug | SKILL.md(必须与历史一致) | ojimport |
--name | clawhub inspect(必须与历史一致) | 搬题姬 |
--version | 历史版本递增 | 1.7.0 → 1.7.1 |
--changelog | 询问用户本次改动 | 修复 WebSocket 问题 |
--tags | clawhub inspect(必须与历史一致) | oj,algorithm,problem |
⚠️ Slug 命名铁律(最高优先级):
-、下划线 _ 或任何符号!--version 必须是语义化版本(x.y.z)clawhub publish <技能路径> \
--slug <英文slug> \
--name <显示名> \
--version <版本号> \
--changelog "<更新说明>" \
--tags "<英文标签>"
示例:
clawhub publish /home/fslong/.copaw/workspaces/default/active_skills/墨池 \
--slug inkpot \
--name "InkPot" \
--version "2.0.0" \
--changelog "Switch from JSON to simple KV text format" \
--tags "knowledge,learning,chinese"
成功输出:
✔ OK. Published inkpot@2.0.0 (k97f1c87nkv5tzq1rzkd26b3a983shgy)
失败情况:
Field name 中文 has invalid character → tags 或 name 包含中文,改用英文Not logged in → 执行 clawhub loginSkill not found → 路径错误,检查技能目录| 版本类型 | 何时使用 | 示例 |
|---|---|---|
| ---------- | ---------- | ------ |
| Major (x.0.0) | 大改动、不兼容更新 | 2.0.0 - 从 JSON 改为 KV 格式 |
| Minor (0.y.0) | 新功能、向后兼容 | 1.1.0 - 新增搜索功能 |
| Patch (0.0.z) | 小修复、bug 修复 | 1.0.1 - 修复解析错误 |
错误:
Field name 中文 has invalid character '中'
解决:tags 只能用英文,如 chinese 而不是 中文。
铁律(无符号纯净模式):
-、下划线 _!示例:
inkpot, poxiao, lessonprep (紧密相连)po-xiao (连字符), oi-style (连字符), 墨池 (中文)流程:
1.0.0 → 1.1.0)clawhub publish| 命令 | 用途 |
|---|---|
| ------ | ------ |
clawhub whoami | 检查登录状态 |
clawhub login | 登录(浏览器认证) |
clawhub logout | 登出 |
clawhub publish | 发布技能 |
clawhub search | 搜索技能 |
clawhub install | 安装技能 |
clawhub list | 列出已安装技能 |
clawhub inspect | 查看技能详情 |
发布前检查:
clawhub whoami)- _)作者: fslong
创建日期: 2026-03-29
来源: 墨池技能发布实践
共 1 个版本