sophhub 0.2.4 → 0.4.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +29 -0
- package/agents/ai-cs-admin/.config.json +34 -0
- package/agents/ai-cs-admin/AGENTS.md +293 -0
- package/agents/ai-cs-admin/BOOTSTRAP.md +19 -0
- package/agents/ai-cs-admin/HEARTBEAT.md +19 -0
- package/agents/ai-cs-admin/IDENTITY.md +6 -0
- package/agents/ai-cs-admin/MEMORY.md +22 -0
- package/agents/ai-cs-admin/SOUL.md +25 -0
- package/agents/ai-cs-admin/TOOLS.md +98 -0
- package/agents/ai-cs-admin/USER.md +17 -0
- package/agents/ai-cs-qa/.config.json +32 -0
- package/agents/ai-cs-qa/AGENTS.md +284 -0
- package/agents/ai-cs-qa/BOOTSTRAP.md +22 -0
- package/agents/ai-cs-qa/HEARTBEAT.md +20 -0
- package/agents/ai-cs-qa/IDENTITY.md +6 -0
- package/agents/ai-cs-qa/MEMORY.md +22 -0
- package/agents/ai-cs-qa/SOUL.md +33 -0
- package/agents/ai-cs-qa/TOOLS.md +35 -0
- package/agents/ai-cs-qa/USER.md +16 -0
- package/bin/sophhub.js +2 -0
- package/package.json +3 -2
- package/skills/notes-hub-assistant/skill.json +20 -0
- package/skills/notes-hub-assistant/src/SKILL.md +233 -0
- package/skills/notes-hub-assistant/src/scripts/_resolve_lark_cli.py +48 -0
- package/skills/notes-hub-assistant/src/scripts/openclaw_meeting_minutes.py +473 -0
- package/skills/notes-hub-assistant/src/scripts/openclaw_notes_crud.py +596 -0
- package/skills/notes-hub-assistant/src/scripts/openclaw_wolai_notes_crud.py +364 -0
- package/skills/notes-hub-assistant/src/scripts/run_meeting_minutes.py +79 -0
- package/skills/notes-hub-assistant/src/scripts/run_note_crud.py +37 -0
- package/skills/notes-hub-assistant/src/scripts/run_notionbot.py +36 -0
- package/skills/notes-hub-assistant/src/scripts/run_wolai_note_crud.py +27 -0
- package/src/commands/agent.js +112 -0
- package/src/utils/agents.js +36 -0
- package/src/utils/paths.js +12 -0
|
@@ -0,0 +1,233 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: notes-hub-assistant
|
|
3
|
+
description: 统一处理飞书、Notion、wolai 三类笔记工作流。支持创建、读取、更新、删除、搜索、评论与附件写入;根据用户输入自动路由到对应平台并执行平台专属约束。触发场景包括“写入笔记”“同步到某笔记平台”“查找历史笔记”“按链接读取笔记”“把会议纪要整理到笔记”等。wolai 路线使用官方 OpenAPI。
|
|
4
|
+
version: 1.0.0
|
|
5
|
+
metadata:
|
|
6
|
+
openclaw:
|
|
7
|
+
requires:
|
|
8
|
+
bins: ["python3", "node", "npx", "mcporter"]
|
|
9
|
+
---
|
|
10
|
+
|
|
11
|
+
# Notes Hub Assistant
|
|
12
|
+
|
|
13
|
+
统一入口,整合以下 3 个平台能力:
|
|
14
|
+
|
|
15
|
+
- Feishu Notes(含 Minutes -> Note)
|
|
16
|
+
- Notion(vibe-notionbot)
|
|
17
|
+
- wolai(OpenAPI)
|
|
18
|
+
|
|
19
|
+
> **暂时下线**:印象笔记(Evernote)相关路由与 OpenClaw 工具链已暂时关闭;不要调用 `evernote.*`、不要提示 `openclaw evernote login`、不要将用户意图路由到印象笔记。若用户明确要求印象笔记,说明当前已暂停支持并建议在飞书 / Notion / wolai 中选其一。
|
|
20
|
+
|
|
21
|
+
目标:用户只描述“要做什么”,你负责“选平台 + 执行 + 返回结果”。
|
|
22
|
+
|
|
23
|
+
## 1. 路由优先级
|
|
24
|
+
|
|
25
|
+
按以下顺序判断目标平台:
|
|
26
|
+
|
|
27
|
+
1. **用户明确点名平台**(如“写到 Notion”)-> 直接路由
|
|
28
|
+
2. **输入包含特征链接/标识** -> 自动路由
|
|
29
|
+
- `*.feishu.cn/minutes/` -> Feishu Minutes -> Note
|
|
30
|
+
- `feishu.cn/docx/` 或飞书 doc token -> Feishu Notes
|
|
31
|
+
- `notion.so` 链接或 Notion page/database id -> Notion
|
|
32
|
+
- `wolai.com` 页面链接或存在 `WOLAI_APP_TOKEN` / (`WOLAI_APP_ID` + `WOLAI_APP_SECRET`) 场景 -> wolai
|
|
33
|
+
3. **未指定平台** -> 仅追问一次:`你希望写入飞书、Notion,还是 wolai?`
|
|
34
|
+
|
|
35
|
+
不要在平台已明确时重复追问。
|
|
36
|
+
|
|
37
|
+
## 2. 统一能力模型
|
|
38
|
+
|
|
39
|
+
所有请求先映射到统一动作,再执行平台命令:
|
|
40
|
+
|
|
41
|
+
- `create`:新建笔记/页面
|
|
42
|
+
- `read`:读取笔记内容
|
|
43
|
+
- `update`:追加、覆盖、章节替换
|
|
44
|
+
- `delete/archive`:删除或归档
|
|
45
|
+
- `search`:关键词搜索
|
|
46
|
+
- `comment`:评论
|
|
47
|
+
- `media`:上传图片/文件
|
|
48
|
+
|
|
49
|
+
返回时统一口径:
|
|
50
|
+
|
|
51
|
+
- 成功:说明平台、对象 ID/链接、关键变更内容
|
|
52
|
+
- 失败:简要返回错误原因 + 下一步建议
|
|
53
|
+
|
|
54
|
+
### OpenClaw「在线笔记」面板
|
|
55
|
+
|
|
56
|
+
内置面板将用户意图与正文合并为同一字段:YAML 中 `payload.content` 即「操作与内容」全文;`target.raw` 可能由高级选项单独填写,也可能由前端从正文中抽取第一条可识别的文档链接或 ID。解析时请结合 `action`、`target.raw` 与 `payload.content` 整体理解用户意图。
|
|
57
|
+
|
|
58
|
+
## 2.1 工具安装与执行硬规则(必须遵守)
|
|
59
|
+
|
|
60
|
+
- 严禁输出或建议任何 `npm install`(包括 `npm install -g`)。
|
|
61
|
+
- 涉及 CLI 依赖时,统一使用 `npx -y` 的一次性执行方式。
|
|
62
|
+
- 优先调用本 skill 的 Python wrapper(例如 `run_note_crud.py`、`run_notionbot.py`、`run_wolai_note_crud.py`),由 wrapper 内部处理 `npx -y` 细节。
|
|
63
|
+
- 仅当用户环境缺少 `npx` 时,才提示安装 Node.js;不要提示安装具体 npm 包。
|
|
64
|
+
- 当用户要求“安装某 CLI”时,改为给出 `npx -y -p <package> <bin> ...` 的执行方案,而非本地全局安装。
|
|
65
|
+
|
|
66
|
+
## 3. 平台执行层
|
|
67
|
+
|
|
68
|
+
### A. Feishu Notes(主文档流)
|
|
69
|
+
|
|
70
|
+
优先使用本 skill 内置封装脚本:
|
|
71
|
+
|
|
72
|
+
```bash
|
|
73
|
+
python3 {baseDir}/scripts/run_note_crud.py --op <create|read|update|delete|search> ...
|
|
74
|
+
```
|
|
75
|
+
|
|
76
|
+
```bash
|
|
77
|
+
python3 {baseDir}/scripts/run_note_crud.py --op <media-insert|comment|section-update> ...
|
|
78
|
+
```
|
|
79
|
+
|
|
80
|
+
动作映射:
|
|
81
|
+
|
|
82
|
+
- 新建:`--op create --title --markdown`
|
|
83
|
+
- 读取:`--op read --doc`
|
|
84
|
+
- 追加/覆盖:`--op update --doc --mode <append|overwrite|replace> --markdown`
|
|
85
|
+
- 删除:`--op delete --doc`
|
|
86
|
+
- 搜索:`--op search --query`
|
|
87
|
+
- 图片/附件:`--op media-insert --doc --file --media-type`
|
|
88
|
+
- 评论:`--op comment --doc --comment`
|
|
89
|
+
- 章节编辑:`--op section-update --doc --section-title --section-mode --markdown`
|
|
90
|
+
|
|
91
|
+
强约束:
|
|
92
|
+
|
|
93
|
+
- 用户给的是飞书 Minutes 链接时,不要走普通 read/update 流,改走下方 Minutes 专用流。
|
|
94
|
+
- 不先用网页抓取去读 Minutes 链接;先执行封装脚本。
|
|
95
|
+
- 不要建议 `npm install -g @larksuite/cli` 或其他 npm 安装命令;若需直连 CLI,必须使用 `npx -y -p @larksuite/cli lark-cli ...`。
|
|
96
|
+
- 飞书默认身份为 `bot`(云端优先)。除非用户明确要求并已完成本地 OAuth 登录,否则不要切回 `user`。
|
|
97
|
+
|
|
98
|
+
#### 云端部署授权规范(Feishu)
|
|
99
|
+
|
|
100
|
+
- 运行身份:默认 `bot`,不要依赖 `user` 扫码授权。
|
|
101
|
+
- 凭证策略:使用可持久化的 `LARKSUITE_CLI_CONFIG_DIR`,避免容器重启后 token 丢失。
|
|
102
|
+
- 执行策略:所有 CLI 调用必须可追溯到 `npx -y` 路径,禁止 `npm install`。
|
|
103
|
+
- 故障处理:若报 token 缺失,优先检查配置目录挂载/注入是否成功,而不是提示用户在容器内扫码。
|
|
104
|
+
- 仅在用户明确要求本地交互授权时,才给出:
|
|
105
|
+
`npx -y -p @larksuite/cli lark-cli config init --new`
|
|
106
|
+
|
|
107
|
+
### B. Feishu Minutes -> Note(次能力)
|
|
108
|
+
|
|
109
|
+
仅当输入是飞书妙记链接或 `minute_token` 时触发:
|
|
110
|
+
|
|
111
|
+
```bash
|
|
112
|
+
python3 {baseDir}/scripts/run_meeting_minutes.py "<minutes_url_or_token>"
|
|
113
|
+
```
|
|
114
|
+
|
|
115
|
+
结果处理:
|
|
116
|
+
|
|
117
|
+
- `status=succeeded`:返回 `feishu_doc_url`
|
|
118
|
+
- `status=partial`:说明“已提取但建文档失败”
|
|
119
|
+
- `status=failed`:简要返回 `error_message`
|
|
120
|
+
|
|
121
|
+
### C. Notion(vibe-notionbot)
|
|
122
|
+
|
|
123
|
+
默认命令入口(本 skill 内置 wrapper):
|
|
124
|
+
|
|
125
|
+
```bash
|
|
126
|
+
python3 {baseDir}/scripts/run_notionbot.py ...
|
|
127
|
+
```
|
|
128
|
+
|
|
129
|
+
认证前置:
|
|
130
|
+
|
|
131
|
+
```bash
|
|
132
|
+
python3 {baseDir}/scripts/run_notionbot.py auth status
|
|
133
|
+
```
|
|
134
|
+
|
|
135
|
+
核心动作:
|
|
136
|
+
|
|
137
|
+
- 新建页面:`page create --parent <id> --title "<title>" [--markdown|--markdown-file]`
|
|
138
|
+
- 读取页面:`page get <page_id>`
|
|
139
|
+
- 更新页面属性/内容:`page update <page_id> ...`
|
|
140
|
+
- 归档:`page archive <page_id>`
|
|
141
|
+
- 搜索:`search "<query>"`
|
|
142
|
+
- 评论:`comment create ...`
|
|
143
|
+
- 批量:`batch --file ./operations.json '[]'`
|
|
144
|
+
|
|
145
|
+
Notion 写入硬规则(必须执行):
|
|
146
|
+
|
|
147
|
+
- 任何“新增笔记 / 替换正文 / 追加完整笔记块”都先规范化为固定结构:
|
|
148
|
+
- `元数据`、`摘要`、`事实`、`洞察`、`决策`、`行动`、`问题`、`参考`
|
|
149
|
+
- 缺失项统一用:`未知` / `无` / `待定`
|
|
150
|
+
- 禁止把原始聊天碎片直接写入 Notion
|
|
151
|
+
|
|
152
|
+
### D. wolai(OpenAPI)
|
|
153
|
+
|
|
154
|
+
默认命令入口(本 skill 内置 wrapper):
|
|
155
|
+
|
|
156
|
+
```bash
|
|
157
|
+
python3 {baseDir}/scripts/run_wolai_note_crud.py --op <create|read|read-children|update|delete|search> ...
|
|
158
|
+
```
|
|
159
|
+
|
|
160
|
+
认证前置(满足任一项即可):
|
|
161
|
+
|
|
162
|
+
- 方案 A:配置 `WOLAI_APP_TOKEN`
|
|
163
|
+
- 方案 B:配置 `WOLAI_APP_ID` + `WOLAI_APP_SECRET`(脚本会自动调用 `POST /token` 获取 token)
|
|
164
|
+
|
|
165
|
+
核心动作映射:
|
|
166
|
+
|
|
167
|
+
- 新建块:`--op create --parent-id <id> --content "<text>"`
|
|
168
|
+
- 读取块:`--op read --id <id>`
|
|
169
|
+
- 读取子块:`--op read-children --id <id> [--cursor ... --limit ...]`
|
|
170
|
+
- 更新块:`--op update --id <id> --content "<text>"`(优先 PATCH,失败回退 PUT)
|
|
171
|
+
- 删除块:`--op delete --id <id>`
|
|
172
|
+
- 轻量搜索:`--op search --parent-id <id> --query "<keyword>"`(在子块范围内过滤)
|
|
173
|
+
|
|
174
|
+
执行约束:
|
|
175
|
+
|
|
176
|
+
- 统一使用 `https://openapi.wolai.com/v1` 作为默认 base URL(可被 `WOLAI_OPENAPI_BASE_URL` 覆盖)
|
|
177
|
+
- 用户明确要求 wolai 时,优先 wolai,不降级到其他平台
|
|
178
|
+
- 返回原始错误信息中的 `message/error_code/status_code`,并补充下一步建议
|
|
179
|
+
|
|
180
|
+
<!--
|
|
181
|
+
### E. Evernote(OpenClaw)— 暂时屏蔽
|
|
182
|
+
|
|
183
|
+
恢复时取消注释并同步 frontmatter/路由/第4节/示例/输出模板。
|
|
184
|
+
|
|
185
|
+
优先使用 evernote 工具族:
|
|
186
|
+
|
|
187
|
+
- `evernote.auth_status`
|
|
188
|
+
- `evernote.list_notebooks`
|
|
189
|
+
- `evernote.create_note`
|
|
190
|
+
- `evernote.get_note`
|
|
191
|
+
|
|
192
|
+
流程规则:
|
|
193
|
+
|
|
194
|
+
1. 先 `auth_status`
|
|
195
|
+
2. 未连接时提示 `openclaw evernote login`
|
|
196
|
+
3. 缺少必要参数才追问,且每次只问最少字段
|
|
197
|
+
4. 未指定笔记本时,默认写入后端默认笔记本
|
|
198
|
+
-->
|
|
199
|
+
|
|
200
|
+
## 4. 跨平台默认策略
|
|
201
|
+
|
|
202
|
+
- 除非用户要求“同时写入多个平台”,否则只写一个目标平台。
|
|
203
|
+
- 如果用户要求“同步到多个平台”,执行顺序:Feishu -> Notion -> wolai,并逐项汇报结果。
|
|
204
|
+
- 任一平台失败,不阻塞其他平台继续执行;最后汇总成功/失败列表。
|
|
205
|
+
- 不暴露 token、cookie、敏感 ID;输出中自动脱敏。
|
|
206
|
+
|
|
207
|
+
## 5. 最小追问规则
|
|
208
|
+
|
|
209
|
+
只在以下信息缺失时追问:
|
|
210
|
+
|
|
211
|
+
- 目标平台不明确
|
|
212
|
+
- 目标对象不明确(页面 ID / 文档链接)
|
|
213
|
+
- 写入方式不明确(追加还是覆盖)
|
|
214
|
+
|
|
215
|
+
其余信息优先用上下文推断,不要反复确认。
|
|
216
|
+
|
|
217
|
+
## 6. 示例路由
|
|
218
|
+
|
|
219
|
+
- “把这段会议纪要存到飞书” -> Feishu `create` 或 `update`
|
|
220
|
+
- “读取这个链接并整理成飞书文档:`https://my.feishu.cn/minutes/...`” -> Minutes 专用流
|
|
221
|
+
- “把这段内容按结构化笔记写入 Notion 数据库” -> Notion `page create --database`
|
|
222
|
+
- “帮我搜索 wolai 里关于 OKR 的页面” -> wolai `search`
|
|
223
|
+
|
|
224
|
+
## 7. 输出模板
|
|
225
|
+
|
|
226
|
+
执行结束后使用统一格式回复:
|
|
227
|
+
|
|
228
|
+
- 平台:`<feishu|notion|wolai>`
|
|
229
|
+
- 动作:`<create|read|update|delete|search|comment|media>`
|
|
230
|
+
- 结果:`成功/失败`
|
|
231
|
+
- 对象:`<链接或ID>`
|
|
232
|
+
- 摘要:`一句话说明关键结果`
|
|
233
|
+
- 失败时补充:`建议下一步`
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
#!/usr/bin/env python3
|
|
2
|
+
"""Resolve how to invoke Lark CLI.
|
|
3
|
+
|
|
4
|
+
Cloud environments often have no admin permissions, so we prefer running the
|
|
5
|
+
official CLI via `npx -y -p @larksuite/cli lark-cli ...`.
|
|
6
|
+
|
|
7
|
+
This module returns a *command prefix* (list of argv items), not a path.
|
|
8
|
+
"""
|
|
9
|
+
|
|
10
|
+
from __future__ import annotations
|
|
11
|
+
|
|
12
|
+
import shutil
|
|
13
|
+
from pathlib import Path
|
|
14
|
+
from typing import List, Optional, Sequence
|
|
15
|
+
|
|
16
|
+
|
|
17
|
+
def resolve_lark_cli_prefix(_base_dir: Path) -> list[str]:
|
|
18
|
+
"""Return argv prefix to execute lark-cli.
|
|
19
|
+
|
|
20
|
+
Preferred:
|
|
21
|
+
npx -y -p @larksuite/cli lark-cli
|
|
22
|
+
|
|
23
|
+
Fallback (if npx missing):
|
|
24
|
+
lark-cli (on PATH)
|
|
25
|
+
"""
|
|
26
|
+
npx = shutil.which("npx")
|
|
27
|
+
if npx:
|
|
28
|
+
return [npx, "-y", "-p", "@larksuite/cli", "lark-cli"]
|
|
29
|
+
|
|
30
|
+
lark_cli = shutil.which("lark-cli")
|
|
31
|
+
if lark_cli:
|
|
32
|
+
return [lark_cli]
|
|
33
|
+
|
|
34
|
+
raise FileNotFoundError(
|
|
35
|
+
"missing Lark CLI runner: npx or lark-cli not found on PATH. "
|
|
36
|
+
"expected to run via: npx -y -p @larksuite/cli lark-cli ..."
|
|
37
|
+
)
|
|
38
|
+
|
|
39
|
+
|
|
40
|
+
def as_prefix(cli_bin: str, cli_prefix: Optional[Sequence[str]]) -> List[str]:
|
|
41
|
+
"""Back-compat helper for orchestrators.
|
|
42
|
+
|
|
43
|
+
- If --lark-cli-prefix is provided, use it.
|
|
44
|
+
- Else, use --lark-cli-bin as a single executable path.
|
|
45
|
+
"""
|
|
46
|
+
if cli_prefix:
|
|
47
|
+
return list(cli_prefix)
|
|
48
|
+
return [cli_bin]
|