sophhub 0.2.3 → 0.3.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/package.json +1 -1
- package/skills/consensus/skill.json +20 -0
- package/skills/consensus/src/SKILL.md +93 -0
- package/skills/deepwiki/skill.json +20 -0
- package/skills/deepwiki/src/SKILL.md +45 -0
- package/skills/deepwiki/src/_meta.json +6 -0
- package/skills/deepwiki/src/scripts/deepwiki.js +135 -0
- package/skills/feishu-bitable/skill.json +20 -0
- package/skills/feishu-bitable/src/CHECKLIST.md +150 -0
- package/skills/feishu-bitable/src/README.md +178 -0
- package/skills/feishu-bitable/src/SKILL.md +113 -0
- package/skills/feishu-bitable/src/_meta.json +6 -0
- package/skills/feishu-bitable/src/api.js +381 -0
- package/skills/feishu-bitable/src/bin/cli.js +284 -0
- package/skills/feishu-bitable/src/description.md +143 -0
- package/skills/feishu-bitable/src/examples/create-records.json +52 -0
- package/skills/feishu-bitable/src/examples/create-table.json +64 -0
- package/skills/feishu-bitable/src/package-lock.json +324 -0
- package/skills/feishu-bitable/src/package.json +33 -0
- package/skills/feishu-bitable/src/publish-config.json +14 -0
- package/skills/feishu-bitable/src/test-simple.js +61 -0
- package/skills/feishu-bitable/src/utils.js +261 -0
- package/skills/google-maps/skill.json +20 -0
- package/skills/google-maps/src/SKILL.md +237 -0
- package/skills/google-maps/src/_meta.json +6 -0
- package/skills/google-maps/src/lib/map_helper.py +912 -0
- package/skills/large-task-router/skill.json +20 -0
- package/skills/large-task-router/src/SKILL.md +79 -0
- package/skills/large-task-router/src/templates/plan.md +74 -0
- 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/skills/skillhub/skill.json +11 -4
- package/skills/skillhub/src/SKILL.md +11 -1
- package/skills/sophnet-dailynews/skill.json +20 -0
- package/skills/sophnet-dailynews/src/SKILL.md +179 -0
- package/skills/sophnet-dailynews/src/cache.json +151 -0
- package/skills/sophnet-dailynews/src/sources.json +230 -0
- package/skills/sophnet-schedule/skill.json +20 -0
- package/skills/sophnet-schedule/src/ARCHITECTURE.md +321 -0
- package/skills/sophnet-schedule/src/IMPROVEMENTS.md +145 -0
- package/skills/sophnet-schedule/src/SKILL.md +1050 -0
- package/skills/sophnet-schedule/src/_meta.json +6 -0
- package/skills/sophnet-schedule/src/api/__init__.py +0 -0
- package/skills/sophnet-schedule/src/api/models.py +245 -0
- package/skills/sophnet-schedule/src/apps/add_event.py +237 -0
- package/skills/sophnet-schedule/src/apps/check_reminders.py +112 -0
- package/skills/sophnet-schedule/src/apps/check_roc.py +246 -0
- package/skills/sophnet-schedule/src/apps/generate_daily_plan.py +342 -0
- package/skills/sophnet-schedule/src/apps/import_events.py +216 -0
- package/skills/sophnet-schedule/src/apps/monitor_calendar_changes.py +140 -0
- package/skills/sophnet-schedule/src/apps/register_tasks.py +169 -0
- package/skills/sophnet-schedule/src/apps/sync_roc_to_gcal.py +174 -0
- package/skills/sophnet-schedule/src/compat.py +66 -0
- package/skills/sophnet-schedule/src/config/__init__.py +0 -0
- package/skills/sophnet-schedule/src/config/reminder_rules.yaml +96 -0
- package/skills/sophnet-schedule/src/config/roc_events.yaml +44 -0
- package/skills/sophnet-schedule/src/config/settings.py +133 -0
- package/skills/sophnet-schedule/src/config/task_registry.yaml +92 -0
- package/skills/sophnet-schedule/src/docs/FRONTEND_INTEGRATION_GUIDE.md +437 -0
- package/skills/sophnet-schedule/src/gcal/__init__.py +0 -0
- package/skills/sophnet-schedule/src/gcal/client.py +374 -0
- package/skills/sophnet-schedule/src/gcal/models.py +91 -0
- package/skills/sophnet-schedule/src/requirements.txt +6 -0
- package/skills/sophnet-schedule/src/scripts/setup_gcal_token.py +85 -0
- package/skills/sophnet-schedule/src/server.py +669 -0
- package/skills/sophnet-schedule/src/services/__init__.py +0 -0
- package/skills/sophnet-schedule/src/services/calendar_backend.py +139 -0
- package/skills/sophnet-schedule/src/services/conflict_detector.py +96 -0
- package/skills/sophnet-schedule/src/services/datetime_utils.py +117 -0
- package/skills/sophnet-schedule/src/services/event_classifier.py +100 -0
- package/skills/sophnet-schedule/src/services/event_diff.py +160 -0
- package/skills/sophnet-schedule/src/services/google_integration.py +500 -0
- package/skills/sophnet-schedule/src/services/job_store.py +100 -0
- package/skills/sophnet-schedule/src/services/local_event_store.py +266 -0
- package/skills/sophnet-schedule/src/services/reminder_planner.py +116 -0
- package/skills/sophnet-schedule/src/services/runtime_utils.py +31 -0
- package/skills/sophnet-schedule/src/services/table_parser.py +286 -0
- package/skills/sophnet-schedule/src/services/task_builder.py +167 -0
- package/skills/sophnet-schedule/src/services/time_window.py +72 -0
- package/skills/sophnet-stock/skill.json +20 -0
- package/skills/sophnet-stock/src/App-Plan.md +442 -0
- package/skills/sophnet-stock/src/README.md +214 -0
- package/skills/sophnet-stock/src/SKILL.md +236 -0
- package/skills/sophnet-stock/src/TODO.md +394 -0
- package/skills/sophnet-stock/src/_meta.json +6 -0
- package/skills/sophnet-stock/src/docs/ARCHITECTURE.md +408 -0
- package/skills/sophnet-stock/src/docs/CONCEPT.md +233 -0
- package/skills/sophnet-stock/src/docs/HOT_SCANNER.md +288 -0
- package/skills/sophnet-stock/src/docs/README.md +95 -0
- package/skills/sophnet-stock/src/docs/USAGE.md +465 -0
- package/skills/sophnet-stock/src/scripts/analyze_stock.py +2565 -0
- package/skills/sophnet-stock/src/scripts/dividends.py +365 -0
- package/skills/sophnet-stock/src/scripts/hot_scanner.py +582 -0
- package/skills/sophnet-stock/src/scripts/portfolio.py +548 -0
- package/skills/sophnet-stock/src/scripts/rumor_scanner.py +342 -0
- package/skills/sophnet-stock/src/scripts/test_stock_analysis.py +409 -0
- package/skills/sophnet-stock/src/scripts/watchlist.py +336 -0
- package/skills/xiaohongshu/skill.json +20 -0
- package/skills/xiaohongshu/src/SKILL.md +91 -0
- package/skills/xiaohongshu/src/_meta.json +6 -0
- package/skills/xiaohongshu/src/assets/card.html +216 -0
- package/skills/xiaohongshu/src/assets/cover.html +82 -0
- package/skills/xiaohongshu/src/assets/example.md +84 -0
- package/skills/xiaohongshu/src/assets/styles.css +318 -0
- package/skills/xiaohongshu/src/scripts/render_xhs_v2.py +737 -0
- package/skills/xiaohongshu/src/scripts/sign_server.py +158 -0
- package/skills/xiaohongshu/src/scripts/stealth.min.js +7 -0
- package/skills/xiaohongshu/src/scripts/xhs_tool.py +186 -0
- package/skills/xiaohongshu/src/workflow.py +185 -0
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "large-task-router",
|
|
3
|
+
"version": "1.0.0",
|
|
4
|
+
"types": [
|
|
5
|
+
"builtin"
|
|
6
|
+
],
|
|
7
|
+
"displayName": "",
|
|
8
|
+
"description": "",
|
|
9
|
+
"changelog": [
|
|
10
|
+
{
|
|
11
|
+
"version": "1.0.0",
|
|
12
|
+
"date": "2026-04-16",
|
|
13
|
+
"changes": [
|
|
14
|
+
"初次提交"
|
|
15
|
+
]
|
|
16
|
+
}
|
|
17
|
+
],
|
|
18
|
+
"createdAt": "2026-04-16",
|
|
19
|
+
"updatedAt": "2026-04-16"
|
|
20
|
+
}
|
|
@@ -0,0 +1,79 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: large-task-router
|
|
3
|
+
description: "大任务拆分规划。触发:单文件≥20MB、合计≥50MB、≥2 文件同类处理、用户提到并行/分批/拆分/subagent。命中时先 read SKILL.md 后按 Subagent Plan 执行。"
|
|
4
|
+
---
|
|
5
|
+
|
|
6
|
+
# Large Task Router
|
|
7
|
+
|
|
8
|
+
## 目标
|
|
9
|
+
|
|
10
|
+
把"大任务先拆分后执行"变成**强制**固定流程,避免直接串行处理导致慢、易中断、难恢复。本技能一旦被加载进上下文,触发条件匹配即自动生效,不再需要用户重申。
|
|
11
|
+
|
|
12
|
+
## 何时启用(命中任一即必须启用)
|
|
13
|
+
|
|
14
|
+
- 输入文件总大小 > 50MB
|
|
15
|
+
- 任意单文件 > 20MB(即使只有一个文件)
|
|
16
|
+
- 预计步骤 > 8
|
|
17
|
+
- 预计耗时 > 10 分钟
|
|
18
|
+
- 用户明确或隐含提到:并行 / 分批 / 拆分 / subagent / 多 agent / 同时处理 / 一起跑 / 并发
|
|
19
|
+
|
|
20
|
+
> **关键**:以上条件是**客观触发器**,不是建议。不要用"任务简单"、"一个子任务就够"、"我直接跑更快"等理由跳过。触发条件成立即必须输出 Subagent Plan,即使 subagent 数量 = 1。
|
|
21
|
+
|
|
22
|
+
## 固定流程(必须按顺序)
|
|
23
|
+
|
|
24
|
+
1. **规模评估**
|
|
25
|
+
- 估算:文件大小、文件数量、步骤数、预估时长
|
|
26
|
+
- 输出一行结论:`任务规模=小|中|大`
|
|
27
|
+
- 若任一触发条件命中,`任务规模` 至少为 `中`,进入步骤 2
|
|
28
|
+
2. **拆分计划**
|
|
29
|
+
- 先完整输出 "Subagent Plan" 模板(参考 `templates/plan.md`),再开始执行
|
|
30
|
+
- 子任务命名统一为 `subagent-1..n`
|
|
31
|
+
- **即使 n = 1,也要填写完整模板**,显式说明"无法进一步拆分的理由"
|
|
32
|
+
3. **并行执行**
|
|
33
|
+
- 按计划并发执行
|
|
34
|
+
- 子任务失败可重试 1 次(同参数)
|
|
35
|
+
4. **聚合汇总**
|
|
36
|
+
- 合并成功结果
|
|
37
|
+
- 标注失败项、重试结果、遗留风险
|
|
38
|
+
5. **最终报告**
|
|
39
|
+
- 给出结论 + 可执行下一步
|
|
40
|
+
|
|
41
|
+
## 并发策略
|
|
42
|
+
|
|
43
|
+
- 默认并发数:`N = min(4, 子任务数)`
|
|
44
|
+
- 若环境允许且任务明显可并行:可提高到 `N = 6~8`
|
|
45
|
+
- 避免过度并发:当任务共享同一资源(同一大文件写入、同一数据库表)时改为分阶段并行
|
|
46
|
+
|
|
47
|
+
## 拆分模板(按优先级选择)
|
|
48
|
+
|
|
49
|
+
1. **按文件切块**:大文件按块/页/段/行数范围拆分(单文件 > 20MB 时首选此模式)
|
|
50
|
+
2. **按阶段拆分**:采集 → 清洗 → 分析 → 汇总
|
|
51
|
+
3. **按目标拆分**:A 子任务做提取,B 子任务做校验,C 子任务做格式化
|
|
52
|
+
|
|
53
|
+
每个子任务必须包含:
|
|
54
|
+
|
|
55
|
+
- `objective`:目标
|
|
56
|
+
- `input`:输入范围
|
|
57
|
+
- `output`:期望产出
|
|
58
|
+
- `timeout`:超时限制
|
|
59
|
+
- `success_criteria`:成功判定
|
|
60
|
+
|
|
61
|
+
## 输出格式
|
|
62
|
+
|
|
63
|
+
先使用 `templates/plan.md` 输出计划,再执行任务。
|
|
64
|
+
|
|
65
|
+
最终报告必须包含:
|
|
66
|
+
|
|
67
|
+
- `Summary`:总体结果
|
|
68
|
+
- `Completed`:完成项
|
|
69
|
+
- `Failed/Retried`:失败与重试
|
|
70
|
+
- `Risks`:风险与边界
|
|
71
|
+
- `Next Actions`:建议下一步
|
|
72
|
+
|
|
73
|
+
## 护栏(硬性规则,不得绕过)
|
|
74
|
+
|
|
75
|
+
- **禁止直接开跑**:触发条件命中的任务不得跳过 Subagent Plan 阶段,直接调用工具/读写文件。
|
|
76
|
+
- **禁止自主降级**:不得以"任务简单 / 不需要拆分 / 我评估不用" 为由拒绝本流程。规模评估仅决定拆分粒度(subagent 数量),不决定是否输出计划。
|
|
77
|
+
- **禁止静默失败**:子任务失败必须显式列入最终报告的 `Failed/Retried`,并说明重试结果。
|
|
78
|
+
- **单文件大**:当触发器是"单文件 > 20MB"时,仍需输出 Subagent Plan;若该文件确实无法按块/行/段拆分,在计划中说明理由后可仅用 1 个 subagent 执行,但流程不变。
|
|
79
|
+
- **关键词即触发**:用户提到"并行/分批/拆分"等关键词时,即使规模小,也要输出简化版 Subagent Plan(可 1~2 个 subagent)以确认并行意图,避免误解为串行。
|
|
@@ -0,0 +1,74 @@
|
|
|
1
|
+
# Subagent Plan
|
|
2
|
+
|
|
3
|
+
## 0) Task Size Assessment
|
|
4
|
+
|
|
5
|
+
- Input size:
|
|
6
|
+
- File count:
|
|
7
|
+
- Estimated steps:
|
|
8
|
+
- Estimated runtime:
|
|
9
|
+
- Decision: `small | medium | large`
|
|
10
|
+
- Split required: `yes | no` (if `no`, explain)
|
|
11
|
+
|
|
12
|
+
## 1) Execution Strategy
|
|
13
|
+
|
|
14
|
+
- Split mode: `by-file | by-stage | by-objective`
|
|
15
|
+
- Planned subagents:
|
|
16
|
+
- Planned concurrency (`N`):
|
|
17
|
+
- Retry policy: `failed subtask retry once`
|
|
18
|
+
|
|
19
|
+
## 2) Subtasks
|
|
20
|
+
|
|
21
|
+
### subagent-1
|
|
22
|
+
|
|
23
|
+
- objective:
|
|
24
|
+
- input:
|
|
25
|
+
- output:
|
|
26
|
+
- timeout:
|
|
27
|
+
- success_criteria:
|
|
28
|
+
|
|
29
|
+
### subagent-2
|
|
30
|
+
|
|
31
|
+
- objective:
|
|
32
|
+
- input:
|
|
33
|
+
- output:
|
|
34
|
+
- timeout:
|
|
35
|
+
- success_criteria:
|
|
36
|
+
|
|
37
|
+
<!-- Add subagent-3..n when needed -->
|
|
38
|
+
|
|
39
|
+
## 3) Merge Rules
|
|
40
|
+
|
|
41
|
+
- Dedup strategy:
|
|
42
|
+
- Conflict resolution:
|
|
43
|
+
- Output ordering:
|
|
44
|
+
|
|
45
|
+
---
|
|
46
|
+
|
|
47
|
+
# Final Report
|
|
48
|
+
|
|
49
|
+
## Summary
|
|
50
|
+
|
|
51
|
+
- Overall result:
|
|
52
|
+
- Time spent:
|
|
53
|
+
- Coverage:
|
|
54
|
+
|
|
55
|
+
## Completed
|
|
56
|
+
|
|
57
|
+
- item 1
|
|
58
|
+
- item 2
|
|
59
|
+
|
|
60
|
+
## Failed/Retried
|
|
61
|
+
|
|
62
|
+
- failed item:
|
|
63
|
+
- reason:
|
|
64
|
+
- retry result:
|
|
65
|
+
|
|
66
|
+
## Risks
|
|
67
|
+
|
|
68
|
+
- risk 1
|
|
69
|
+
- risk 2
|
|
70
|
+
|
|
71
|
+
## Next Actions
|
|
72
|
+
|
|
73
|
+
- next step 1
|
|
74
|
+
- next step 2
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "notes-hub-assistant",
|
|
3
|
+
"version": "1.0.0",
|
|
4
|
+
"types": [
|
|
5
|
+
"builtin"
|
|
6
|
+
],
|
|
7
|
+
"displayName": "多平台笔记中枢助手",
|
|
8
|
+
"description": "统一处理飞书、Notion、wolai 三类笔记工作流,支持创建、读取、更新、删除、搜索、评论与附件写入,并根据用户输入自动路由到对应平台。",
|
|
9
|
+
"changelog": [
|
|
10
|
+
{
|
|
11
|
+
"version": "1.0.0",
|
|
12
|
+
"date": "2026-04-16",
|
|
13
|
+
"changes": [
|
|
14
|
+
"初次提交"
|
|
15
|
+
]
|
|
16
|
+
}
|
|
17
|
+
],
|
|
18
|
+
"createdAt": "2026-04-16",
|
|
19
|
+
"updatedAt": "2026-04-16"
|
|
20
|
+
}
|
|
@@ -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]
|