Install
openclaw skills install clawmate-workClawMate 文件管理 + 预览 + 反馈闭环 + 项目管理。支持文件搜索预览、feedback 处理、项目初始化与前期梳理(Phase I-V)。
openclaw skills install clawmate-work⚠️ {base_url} 需要由你根据 ClawMate 服务端的实际访问地址指定,由服务端 config.json 的 public_base_url 配置决定。 内部 API 调用(cron job / agent 处理)使用
http://localhost:5533绕过 nginx basic auth(此地址不受 {base_url} 影响)。调用方式:内部 API 调用 (
localhost:5533) 必须使用exec curl,禁止使用web_fetch。web_fetch的安全策略会阻止localhost/私有 IP 地址(SSRF 防护),而exec curl在宿主机本地执行不受此限制。
| 命令 | 功能 | 状态 |
|---|---|---|
clawmate link <filename> | 搜索文件生成可点击预览链接 | ✅ |
clawmate project [root] <projectname> | 项目初始化与前期梳理(Phase I-V),默认 root 为 defaultRootId | ✅ |
clawmate feed [status] [project] [filename] [date] | 查询 feedback 列表 | ✅ |
clawmate do [feedback_id] | 处理待处理 feedback | ✅ |
基于 work agent SOP,各阶段推荐调用的 skill:
| 阶段 | 任务 | 推荐 Skill | 说明 |
|---|---|---|---|
| Phase III | 深度调研 | academic-deep-research | 行业分析、竞品研究 |
| Phase III | 快速查证 | web_search / tavily_search | 事实数据、最新动态 |
| Phase III | 技术评估 | cto-advisor | 技术可行性、方案对比 |
| Phase IV | MRD 编写 | business-writing | 商业文档写作 |
| Phase V | PRD 编写 | prd-writer | 产品需求文档 |
| Phase V | 图表绘制 | mermaid-diagrams | 流程图/架构图 |
| 研发 | 代码开发 | github / gh-issues | 代码管理、Issue 跟踪 |
| 研发 | 测试验证 | healthcheck | 服务健康检查 |
| 全部 | 任务管理 | clawlist | 树形 TODO + 进度跟踪 |
| 全部 | 知识沉淀 | memory / wiki-maintainer | 经验归档、知识库更新 |
调用原则:每个阶段优先使用对应 skill,不重复造轮子。skill 调用后需将结论写回 PROJECT_NOTE.md。
OpenClaw 编写文件并保存后,使用 /clawmate link {filename} 搜索文件并生成 Markdown 可点击预览链接。
步骤:
web_fetch 会阻止 localhost):
curl -s "http://localhost:5533/api/clawmate/search?q={关键词}&root={root}" 2>/dev/null
模糊匹配时简化搜索词(如去空格、取核心词)重试{base_url}/clawmate/preview.html?root={root}&file={encoded_path}[filename](url)正确输出:
[CLAWLIST.md](https://example.com/clawmate/preview.html?root=webprojects&file=clawmate%2FCLAWLIST.md)
错误输出(禁止):
https://example.com/clawmate/preview.html?root=webprojects&file=clawmate/CLAWLIST.md ← 裸 URL
~/webprojects/clawmate/CLAWLIST.md ← 裸路径
多结果处理:模糊匹配到多个文件时,列出所有匹配项,每项生成独立预览链接。
基于 skill project 五阶段框架,在 ClawMate 管理的目录中创建项目并进行前期梳理。
Phase I 确认三种类型之一,决定后续全流程和目录结构:
| 类型 | 目录 | 流程 | 产出 |
|---|---|---|---|
| 观点收集 | research/ collect/ | I→II→III→研究报告 | 结构化研究报告 |
| 产品方案 | + prd/ | I→II→III→IV(MRD)→V(PRD) | MRD + PRD |
| 研发需求 | + prd/ dev/ test/ | I→II→III→IV(MRD)→V(PRD) | MRD + PRD + 可运行系统 |
clawmate project [root] <projectname>
root: 可选,指定 ClawMate root_id(默认使用 config.json 的 defaultRootId)projectname: 项目名称默认路径:{root_dir}/{项目名}/(root_dir 由 root_id 解析)
源码目录:统一使用 dev/
flowchart LR
A[Phase I<br>项目初始化] --> B[Phase II<br>需求澄清]
B --> C[Phase III<br>信息收集]
C --> D{项目类型?}
D -->|观点收集| E[研究报告<br>编写与评审]
D -->|产品方案| F[Phase IV<br>MRD 编写]
D -->|研发需求| F
E --> G{通过?}
G -->|否| C
G -->|是| H[✅ 完成]
F --> I{通过?}
I -->|否| C
I -->|是| J[Phase V<br>PRD 编写]
J --> K{通过?}
K -->|否| J
K -->|是| H
步骤 0:询问项目类型(必须先执行)
## 🏗️ 请确认项目类型
这个项目属于哪一种?
1. **观点收集** — 纯文档/研究输出,无需 MRD/PRD
2. **产品方案** — 需要 MRD + PRD 的产品规划
3. **研发需求** — 需要开发 + 测试的完整工程
步骤 1:创建目录结构
确认类型后立即创建:
# 观点收集
mkdir -p {项目根路径}/{research,collect}
# 产品方案
mkdir -p {项目根路径}/{research,collect,prd}
# 研发需求
mkdir -p {项目根路径}/{research,collect,prd,dev,test}
# 或 mkdir -p {项目根路径}/{research,collect,prd,dev,test}
步骤 2:创建核心文档 + 归档机制
关键原则:所有文档必须有明确的「更新触发器」和「归档边界」,避免过期信息堆积。
活跃文档(始终加载):
dev/ 下创建,管理开发任务明细research/ 下,管理研究计划与进度(替代独立的 RESEARCH_PLAN.md)test/ 下,管理测试任务明细归档文档(按需加载,详见「懒加载机制」):
硬性规则:所有归档必须放在
archive/根目录下,严禁在子目录中创建 archive/(如prd/archive/、research/done/等)。
归档触发条件:
| 场景 | 归档源 | 归档目标 | 示例 |
|---|---|---|---|
| 研究主题已实施 | research/{主题}/ | archive/research/2026-06-{主题}/ | 技术选型完成后归档 |
| PRD 迭代 | prd/PRD.md | archive/prd-versions/PRD-v1.2-YYYY-MM-DD.md | PRD v1.3 评审通过后 |
| 决策过期 | PROJECT_NOTE.md 旧条目 | archive/decisions/YYYY-MM-DD-{主题}.md | 技术方案变更 |
| 迭代结束 | CLAWLIST.md 已完成项 | archive/iterations/sprint-{N}-YYYY-MM-DD.md | Sprint 复盘完成 |
| 需求取消 | prd/sub_prd/{场景}.md | archive/prd-versions/cancelled/{场景}-v{版本}.md | 明确取消开发 |
归档命名规范:archive/{类别}/YYYY-MM-{主题}/ 或 archive/{类别}/YYYY-MM-DD-{简述}.md,确保可检索。
CLAWLIST.md 模板(项目级 — 总览):
# CLAWLIST — {项目名}(项目级 — 总览)
> 本项目级 CLAWLIST 管理所有非研发、测试的项目进展,并汇总各分组的简要状态。
> 明细任务分别在 dev/、test/、research/ 的 CLAWLIST 中管理。
## Phase I 项目初始化
- [x] 确认项目类型
- [x] 创建目录结构
- [x] 初始化 Git
## Phase II 需求澄清
- [ ] 目的确认
- [ ] 服务对象(三类)
- [ ] 输出物清单
- [ ] 评价标准
- [ ] 工作范围
## Phase III 信息收集
- [ ] 识别信息需求
- [ ] 生成研究计划 → [research/CLAWLIST.md](research/CLAWLIST.md)
- [ ] 执行研究
- [ ] 用户确认
## Phase IV MRD 编写(产品方案/研发需求)
- [ ] 市场概述
- [ ] 目标市场
- [ ] 竞品分析
- [ ] 用户需求
- [ ] 商业价值
- [ ] 市场策略
- [ ] 风险与假设
- [ ] 用户评审通过
## Phase V PRD 编写(产品方案/研发需求)
- [ ] 总 PRD
- [ ] 子场景 PRD: {场景1}
- [ ] 用户评审通过
## 研发进展汇总(明细见 dev/CLAWLIST.md)
- [ ] 架构设计 → [dev/CLAWLIST.md](dev/CLAWLIST.md)
- [ ] 核心功能开发
- [ ] 接口联调
- [ ] 单元测试覆盖
## 测试进展汇总(明细见 test/CLAWLIST.md)
- [ ] 集成测试 → [test/CLAWLIST.md](test/CLAWLIST.md)
- [ ] 回归验证
- [ ] 性能测试
## 研究进展汇总(明细见 research/CLAWLIST.md)
- [ ] 技术选型 → [research/CLAWLIST.md](research/CLAWLIST.md)
- [ ] 竞品分析
- [ ] 用户调研
CLAWLIST.md 模板(研发级 — 明细):
# CLAWLIST — {项目名}(研发级 — 明细)
> 本文件只放研发任务明细。项目总览和跨组协调在项目根目录的 CLAWLIST.md 中管理。
## 架构
- [ ] 技术选型确认
- [ ] 核心架构设计
- [ ] 接口契约定义
## 开发
- [ ] 功能模块 A
- [ ] 功能模块 B
- [ ] 单元测试覆盖
## 联调
- [ ] 接口联调
- [ ] 端到端验证
CLAWLIST.md 模板(研究级 — 明细):
# CLAWLIST — {项目名}(研究级 — 明细)
> 本文件替代独立的 RESEARCH_PLAN.md,管理所有研究主题和进度。
> 项目总览在项目根目录的 CLAWLIST.md 中管理。
## 进行中
- [ ] 技术选型:数据库方案对比
- [x] MySQL 调研
- [x] PostgreSQL 调研
- [ ] 性能基准测试
- [ ] 竞品分析:xxx 产品
- [ ] 功能矩阵
- [ ] 用户体验报告
## 已完成(归档后从本列表移除)
- [x] 市场调研报告 → 已归档到 archive/research/2026-06-市场调研/
CLAWLIST.md 模板(测试级 — 明细):
# CLAWLIST — {项目名}(测试级 — 明细)
> 本文件只放测试任务明细。项目总览在项目根目录的 CLAWLIST.md 中管理。
## 测试计划
- [ ] 集成测试方案设计
- [ ] 测试用例编写
## 执行中
- [ ] API 接口测试
- [ ] 前端兼容性测试
## 报告
- [ ] 测试报告 v1.0
PROJECT_NOTE.md 是产品决策的唯一来源。所有后续决策必须能在其中找到依据。
触发器 → 同步动作矩阵:
| 触发事件 | CLAWLIST | PROJECT_NOTE.md | PRD/MRD | 归档 |
|---|---|---|---|---|
| 需求变更 | ✅ 更新 TODO | ✅ 记录决策 | ⚠️ 评估是否需更新 | — |
| 技术选型变更 | ✅ 标记完成 | ✅ 记录决策 + 理由 | — | ✅ 旧方案归档 |
| PRD 评审通过 | ✅ 标记完成 | — | ✅ 定稿 | ✅ 旧版本归档 |
| 功能开发完成 | ✅ 标记完成 | — | ✅ 更新验收状态 | — |
| Bug 修复 | ✅ 添加/关闭 | — | — | — |
| 迭代结束 | ✅ 关闭迭代 | ✅ 记录复盘 | — | ✅ 迭代记录归档 |
硬性规则:任何文档超过 2 周未更新 → 进入「过期审查」,标记在 CLAWLIST 中,确认是否归档或更新。
首次加载(必须):
1. PROJECT_NOTE.md ← 最新决策(≤ 50 行摘要 + 关键决策表)
2. CLAWLIST.md(项目级) ← 当前阶段未完成任务
按需加载(延迟):
3. CLAWLIST.md(研发级) ← 仅当进入开发阶段
4. prd/PRD.md ← 仅当需要查看详细需求
5. research/ ← 仅当需要背景信息
6. archive/ ← 仅当需要历史决策
加载优先级:
实现方式:
PROJECT_NOTE.md 模板(更新版,顶部增加「当前焦点」):
# {项目名} 产品笔记
## 当前焦点(≤ 20 行,每次会话首先阅读)
- **当前阶段**: {Phase X}
- **本周目标**: {一句话}
- **阻塞项**: {如有}
- **关键决策**: {最近 3 条}
## 项目方向(只写一次,变更时更新)
...
```markdown
# {项目名} 产品笔记
## 项目简介
{项目描述}
## 项目方向(只写一次,变更时更新)
- **要解决的核心问题**: {一句话}
- **目标用户/受众**: {谁用这个项目}
- **预期成果**: {最终产出什么}
- **项目类型**: 观点收集 / 产品方案 / 研发需求
## 关键决策(所有决策必须记录)
| 日期 | 决策 | 理由 | 影响 |
|------|------|------|------|
| YYYY-MM-DD | {决策内容} | {为什么} | {影响范围} |
## 开发规范(研发需求项目)
- 代码风格:{规范}
- 测试要求:{覆盖率}
- 文档要求:{必须更新哪些文档}
## 核心架构
{架构图 + 说明}
## 常见问题与修复
| 问题 | 原因 | 修复 | 日期 |
|------|------|------|------|
| {问题} | {原因} | {修复} | {日期} |
## 关键代码模式
{可复用的代码模式 / 设计模式}
步骤 3:初始化 Git
cd {项目根路径}
git init
git config user.email "openclaw@openclaw.ai"
git config user.name "OpenClaw"
.gitignore 模板:
node_modules/ .npm/ .pnpm-store/
__pycache__/ *.py[cod] .venv/ venv/ .env*
*.log logs/
.DS_Store Thumbs.db
.vscode/ .idea/
dist/ build/
首次提交:git add -A && git commit -m "Initial commit: {项目名}"
五项必问:
产出:PROJECT_NOTE.md「需求澄清记录」章节(更新)
research/CLAWLIST.mdacademic-deep-research / web_search / cto-advisorMRD 内容框架:
| # | 章节 | 内容 |
|---|---|---|
| 1 | 市场概述 | 市场规模、增长趋势、关键驱动因素 |
| 2 | 目标市场 | 细分市场定义、目标用户画像 |
| 3 | 竞品分析 | 主要竞品、差异化定位、竞争格局图 |
| 4 | 用户需求 | 痛点分析、需求优先级、使用场景 |
| 5 | 商业价值 | 商业模式、收入预期、投资回报 |
| 6 | 市场策略 | 进入策略、定价、推广路径 |
| 7 | 风险与假设 | 关键假设、主要风险、缓解措施 |
评审检查单:
执行步骤:
prd/PRD.mdprd/sub_prd/{场景名}.mdPRD 评审检查单:
观点收集:
{项目名}/
├── CLAWLIST.md
├── PROJECT_NOTE.md ← 含「需求澄清记录」+「信息架构规则」
├── research/
│ └── CLAWLIST.md ← 研究计划与进度
└── collect/
产品方案:
{项目名}/
├── CLAWLIST.md
├── PROJECT_NOTE.md ← 含「需求澄清记录」+「信息架构规则」
├── research/
│ └── CLAWLIST.md ← 研究计划与进度
├── collect/
└── prd/
├── MRD.md
├── PRD.md
└── sub_prd/
研发需求:
{项目名}/
├── CLAWLIST.md ← 项目级总览:Phase I-V + 研发/测试/研究进展汇总
├── PROJECT_NOTE.md ← 产品决策唯一来源 + 信息架构规则(顶部「当前焦点」)
├── research/ ← 研究目录
│ ├── CLAWLIST.md ← 研究计划与进度(替代 RESEARCH_PLAN.md)
│ └── {主题}/
├── collect/ ← 收集素材
├── prd/
│ ├── MRD.md ← 当前版本
│ ├── PRD.md ← 当前版本
│ └── sub_prd/ ← 当前子场景
├── dev/ ← 源码
│ ├── main.py
│ ├── requirements.txt
│ └── ...
├── test/ ← 测试(与源码严格分离)
│ ├── CLAWLIST.md ← 测试级:测试任务明细
│ ├── reports/ ← 测试报告
│ ├── results/ ← 测试结果、日志、截图
│ └── scripts/ ← 测试脚本
├── archive/ ← 统一归档目录(根目录,严禁子目录建 archive/)
│ ├── research/
│ │ └── 2026-06-技术选型/
│ ├── decisions/
│ │ └── 2026-06-10-数据库选型.md
│ ├── iterations/
│ │ └── sprint-1.md
│ └── prd-versions/
│ └── PRD-v1.2-2026-05-20.md
└── .gitignore
测试工作结果必须存放在 test/ 目录,严禁与源码混放。
| 内容 | 正确位置 | 错误位置 |
|---|---|---|
| 测试报告 | test/reports/ | dev/reports/ ❌ |
| 测试结果/日志 | test/results/ | dev/logs/ ❌ |
| 测试脚本 | test/scripts/ | dev/scripts/ ❌ |
| 测试截图 | test/results/screenshots/ | dev/ ❌ |
| 测试计划/CLAWLIST | test/CLAWLIST.md | dev/CLAWLIST.md ❌ |
理由:
目录结构:
{项目名}/
├── CLAWLIST.md ← 项目级总览
├── PROJECT_NOTE.md ← 产品决策唯一来源 + 信息架构规则
├── research/ ← 研究目录
│ ├── CLAWLIST.md ← 研究计划与进度(替代 RESEARCH_PLAN.md)
│ └── {主题}/
├── collect/
├── prd/
│ ├── MRD.md
│ ├── PRD.md
│ └── sub_prd/
├── dev/ ← 源码
│ ├── main.py
│ └── ...
├── test/ ← 测试(与源码严格分离)
│ ├── CLAWLIST.md ← 测试级:测试任务明细
│ ├── reports/ ← 测试报告
│ ├── results/ ← 测试结果、日志
│ └── scripts/ ← 测试脚本
├── archive/ ← 统一归档目录(根目录)
│ ├── research/
│ ├── decisions/
│ ├── iterations/
│ └── prd-versions/
└── .gitignore
| 时机 | 类型 | 格式 |
|---|---|---|
| 新功能 | feat: | feat: 添加xxx功能 |
| Bug 修复 | fix: | fix: 修复xxx问题 |
| 文档 | docs: | docs: 更新xxx文档 |
| 重构 | refactor: | refactor: 重构xxx |
| 测试 | test: | test: 添加xxx测试 |
| 杂项 | chore: | chore: 更新依赖 |
所有文档图表使用 Mermaid 语法,禁止截图替代。
查询 feedback 列表,支持过滤。
参数:
status: pending / in_progress / done / failed(默认全部)project: 项目名称过滤(可选)filename: 文件名模糊匹配(可选)date: today 或 YYYY-MM-DD(默认 today)步骤:
curl -s "http://localhost:5533/api/clawmate/feedback/list?root={root}&project={project}&status={status}&file={filename}&since={date}" 2>/dev/null
| ID | 状态 | 文件 | 用户备注 | 更新时间 |
| FD-CM-042 | ⏳ pending | clawmate/README.md | 补充 Docker 截图 | 2026-06-06 20:00 |
状态符号:⏳ pending / 🔄 in_progress / ✅ done / ❌ failed
处理待处理 feedback(全部或指定 ID)。
clawmate do
clawmate do FD-CM-042
处理步骤:
使用 /api/clawmate/feedback/cron-tick 接口执行所有未处理的 feedback 操作(使用 exec curl 调用):
curl -s "http://localhost:5533/api/clawmate/feedback/cron-tick" 2>/dev/null
该接口内部依次处理:查询 → 标记 in_progress → 执行变更 → 标记 done/failed。
硬约束:
item.content 是选区原文(已解析),item.note 是用户备注每次生成本地文件后,必须推送摘要 + 可点击预览链接给用户。
模板:
✅ <做了什么>
[文件名]({base_url}/clawmate/preview.html?root=<root>&file=<encoded_path>)
<简短摘要,2-3 句话>
链接生成规则:
[文件名]({base_url}/clawmate/preview.html?root=<root>&file=<encoded_path>)正确示例:
✅ 测试报告已生成
[测试报告-v1.3.md](https://example.com/clawmate/preview.html?root=webprojects&file=clawmate%2Ftest%2Ftest-report-v1.3.md)
- 通过率:49/52 (94%)
- 3 个问题均为预期行为
经验规律:项目推进 3 个月后,未归档的文档量通常膨胀 3-5 倍,导致模型加载大量过期信息,干扰当前决策。
归档目标:
| 场景 | 归档源 | 归档目标 | 触发条件 |
|---|---|---|---|
| 研究完成 | research/{主题}/ | archive/research/YYYY-MM-{主题}/ | 方案已实施或已否决 |
| PRD 迭代 | prd/PRD.md | archive/prd-versions/PRD-v{X.Y}-YYYY-MM-DD.md | 新版本评审通过 |
| 决策变更 | PROJECT_NOTE.md 旧条目 | archive/decisions/YYYY-MM-DD-{主题}.md | 决策被新决策覆盖 |
| 迭代结束 | CLAWLIST.md 已完成项 | archive/iterations/sprint-{N}-YYYY-MM-DD.md | Sprint 复盘完成 |
| 需求取消 | prd/sub_prd/{场景}.md | archive/prd-versions/cancelled/{场景}-v{版本}.md | 明确取消开发 |
归档检查点:
research/、prd/sub_prd/、CLAWLIST 已完成项第一层:会话初始化(必须加载,≤ 30 行)
1. PROJECT_NOTE.md「当前焦点」摘要
2. CLAWLIST.md 当前阶段未完成项
第二层:任务执行时(按需加载)
3. 具体 PRD 子场景(仅涉及当前任务)
4. 相关研究文档(仅涉及当前决策)
5. CLAWLIST.md 研发级任务(仅开发阶段)
第三层:历史回溯(显式请求时加载)
6. archive/ 目录(用户问「为什么当初选 A 不选 B」时)
7. 旧版本 PRD(用户问「这个需求什么时候改的」时)
加载控制原则:
PRD-core.md + sub_prd/archive/
├── research/
│ └── 2026-06-15-数据库选型/ ← 日期-主题
│ ├── report.md
│ └── comparison.xlsx
├── decisions/
│ └── 2026-06-10-从MySQL迁移到PostgreSQL.md ← 日期-决策简述
├── iterations/
│ └── 2026-Q2-sprint-3.md ← 季度-sprint编号
└── prd-versions/
└── PRD-v1.2-2026-05-20.md ← 文件名-版本-日期
⚠️ 严禁在
prd/、research/、dev/等子目录中创建archive/或done/子目录。所有归档统一在根目录archive/下。
每次开发迭代结束后执行:
## 文档同步检查
- [ ] CLAWLIST.md:已完成项已勾选,新增项已添加
- [ ] PROJECT_NOTE.md:如有决策变更,已记录
- [ ] PRD.md:如有功能变更,已同步更新
- [ ] research/:已实施方案已归档到 archive/research/
- [ ] prd/sub_prd/:已取消/已合并场景已归档
- [ ] 过期文档(> 2 周未更新):已审查并标记状态
硬性规则:未通过文档同步检查,不得进入下一阶段。