sophhub 0.2.2 → 0.2.4

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.
Files changed (109) hide show
  1. package/package.json +1 -1
  2. package/skills/consensus/skill.json +20 -0
  3. package/skills/consensus/src/SKILL.md +93 -0
  4. package/skills/deepwiki/skill.json +20 -0
  5. package/skills/deepwiki/src/SKILL.md +45 -0
  6. package/skills/deepwiki/src/_meta.json +6 -0
  7. package/skills/deepwiki/src/scripts/deepwiki.js +135 -0
  8. package/skills/feishu-bitable/skill.json +20 -0
  9. package/skills/feishu-bitable/src/CHECKLIST.md +150 -0
  10. package/skills/feishu-bitable/src/README.md +178 -0
  11. package/skills/feishu-bitable/src/SKILL.md +113 -0
  12. package/skills/feishu-bitable/src/_meta.json +6 -0
  13. package/skills/feishu-bitable/src/api.js +381 -0
  14. package/skills/feishu-bitable/src/bin/cli.js +284 -0
  15. package/skills/feishu-bitable/src/description.md +143 -0
  16. package/skills/feishu-bitable/src/examples/create-records.json +52 -0
  17. package/skills/feishu-bitable/src/examples/create-table.json +64 -0
  18. package/skills/feishu-bitable/src/package-lock.json +324 -0
  19. package/skills/feishu-bitable/src/package.json +33 -0
  20. package/skills/feishu-bitable/src/publish-config.json +14 -0
  21. package/skills/feishu-bitable/src/test-simple.js +61 -0
  22. package/skills/feishu-bitable/src/utils.js +261 -0
  23. package/skills/flight-booking/skill.json +9 -2
  24. package/skills/flight-booking/src/scripts/flight_booking.py +2 -1
  25. package/skills/google-maps/skill.json +20 -0
  26. package/skills/google-maps/src/SKILL.md +237 -0
  27. package/skills/google-maps/src/_meta.json +6 -0
  28. package/skills/google-maps/src/lib/map_helper.py +912 -0
  29. package/skills/large-task-router/skill.json +20 -0
  30. package/skills/large-task-router/src/SKILL.md +79 -0
  31. package/skills/large-task-router/src/templates/plan.md +74 -0
  32. package/skills/skillhub/skill.json +11 -4
  33. package/skills/skillhub/src/SKILL.md +11 -1
  34. package/skills/sophnet-dailynews/skill.json +20 -0
  35. package/skills/sophnet-dailynews/src/SKILL.md +179 -0
  36. package/skills/sophnet-dailynews/src/cache.json +151 -0
  37. package/skills/sophnet-dailynews/src/sources.json +230 -0
  38. package/skills/sophnet-schedule/skill.json +20 -0
  39. package/skills/sophnet-schedule/src/ARCHITECTURE.md +321 -0
  40. package/skills/sophnet-schedule/src/IMPROVEMENTS.md +145 -0
  41. package/skills/sophnet-schedule/src/SKILL.md +1050 -0
  42. package/skills/sophnet-schedule/src/_meta.json +6 -0
  43. package/skills/sophnet-schedule/src/api/__init__.py +0 -0
  44. package/skills/sophnet-schedule/src/api/models.py +245 -0
  45. package/skills/sophnet-schedule/src/apps/add_event.py +237 -0
  46. package/skills/sophnet-schedule/src/apps/check_reminders.py +112 -0
  47. package/skills/sophnet-schedule/src/apps/check_roc.py +246 -0
  48. package/skills/sophnet-schedule/src/apps/generate_daily_plan.py +342 -0
  49. package/skills/sophnet-schedule/src/apps/import_events.py +216 -0
  50. package/skills/sophnet-schedule/src/apps/monitor_calendar_changes.py +140 -0
  51. package/skills/sophnet-schedule/src/apps/register_tasks.py +169 -0
  52. package/skills/sophnet-schedule/src/apps/sync_roc_to_gcal.py +174 -0
  53. package/skills/sophnet-schedule/src/compat.py +66 -0
  54. package/skills/sophnet-schedule/src/config/__init__.py +0 -0
  55. package/skills/sophnet-schedule/src/config/reminder_rules.yaml +96 -0
  56. package/skills/sophnet-schedule/src/config/roc_events.yaml +44 -0
  57. package/skills/sophnet-schedule/src/config/settings.py +133 -0
  58. package/skills/sophnet-schedule/src/config/task_registry.yaml +92 -0
  59. package/skills/sophnet-schedule/src/docs/FRONTEND_INTEGRATION_GUIDE.md +437 -0
  60. package/skills/sophnet-schedule/src/gcal/__init__.py +0 -0
  61. package/skills/sophnet-schedule/src/gcal/client.py +374 -0
  62. package/skills/sophnet-schedule/src/gcal/models.py +91 -0
  63. package/skills/sophnet-schedule/src/requirements.txt +6 -0
  64. package/skills/sophnet-schedule/src/scripts/setup_gcal_token.py +85 -0
  65. package/skills/sophnet-schedule/src/server.py +669 -0
  66. package/skills/sophnet-schedule/src/services/__init__.py +0 -0
  67. package/skills/sophnet-schedule/src/services/calendar_backend.py +139 -0
  68. package/skills/sophnet-schedule/src/services/conflict_detector.py +96 -0
  69. package/skills/sophnet-schedule/src/services/datetime_utils.py +117 -0
  70. package/skills/sophnet-schedule/src/services/event_classifier.py +100 -0
  71. package/skills/sophnet-schedule/src/services/event_diff.py +160 -0
  72. package/skills/sophnet-schedule/src/services/google_integration.py +500 -0
  73. package/skills/sophnet-schedule/src/services/job_store.py +100 -0
  74. package/skills/sophnet-schedule/src/services/local_event_store.py +266 -0
  75. package/skills/sophnet-schedule/src/services/reminder_planner.py +116 -0
  76. package/skills/sophnet-schedule/src/services/runtime_utils.py +31 -0
  77. package/skills/sophnet-schedule/src/services/table_parser.py +286 -0
  78. package/skills/sophnet-schedule/src/services/task_builder.py +167 -0
  79. package/skills/sophnet-schedule/src/services/time_window.py +72 -0
  80. package/skills/sophnet-stock/skill.json +20 -0
  81. package/skills/sophnet-stock/src/App-Plan.md +442 -0
  82. package/skills/sophnet-stock/src/README.md +214 -0
  83. package/skills/sophnet-stock/src/SKILL.md +236 -0
  84. package/skills/sophnet-stock/src/TODO.md +394 -0
  85. package/skills/sophnet-stock/src/_meta.json +6 -0
  86. package/skills/sophnet-stock/src/docs/ARCHITECTURE.md +408 -0
  87. package/skills/sophnet-stock/src/docs/CONCEPT.md +233 -0
  88. package/skills/sophnet-stock/src/docs/HOT_SCANNER.md +288 -0
  89. package/skills/sophnet-stock/src/docs/README.md +95 -0
  90. package/skills/sophnet-stock/src/docs/USAGE.md +465 -0
  91. package/skills/sophnet-stock/src/scripts/analyze_stock.py +2565 -0
  92. package/skills/sophnet-stock/src/scripts/dividends.py +365 -0
  93. package/skills/sophnet-stock/src/scripts/hot_scanner.py +582 -0
  94. package/skills/sophnet-stock/src/scripts/portfolio.py +548 -0
  95. package/skills/sophnet-stock/src/scripts/rumor_scanner.py +342 -0
  96. package/skills/sophnet-stock/src/scripts/test_stock_analysis.py +409 -0
  97. package/skills/sophnet-stock/src/scripts/watchlist.py +336 -0
  98. package/skills/xiaohongshu/skill.json +20 -0
  99. package/skills/xiaohongshu/src/SKILL.md +91 -0
  100. package/skills/xiaohongshu/src/_meta.json +6 -0
  101. package/skills/xiaohongshu/src/assets/card.html +216 -0
  102. package/skills/xiaohongshu/src/assets/cover.html +82 -0
  103. package/skills/xiaohongshu/src/assets/example.md +84 -0
  104. package/skills/xiaohongshu/src/assets/styles.css +318 -0
  105. package/skills/xiaohongshu/src/scripts/render_xhs_v2.py +737 -0
  106. package/skills/xiaohongshu/src/scripts/sign_server.py +158 -0
  107. package/skills/xiaohongshu/src/scripts/stealth.min.js +7 -0
  108. package/skills/xiaohongshu/src/scripts/xhs_tool.py +186 -0
  109. package/skills/xiaohongshu/src/workflow.py +185 -0
@@ -0,0 +1,437 @@
1
+ # 前端接入说明
2
+
3
+ 更新日期:2026-04-01
4
+
5
+ 本文面向前端开发,说明当前 `sophnet-schedule` 在“本地托底模式 + Google 接入流程”下的接口、状态流和推荐调用顺序。
6
+
7
+ ## 一、整体模式
8
+
9
+ 系统现在有两种运行模式:
10
+
11
+ - `local`
12
+ - 默认模式
13
+ - 用户没有 Google token,或尚未完成首次同步时使用
14
+ - 事件读写来自本地 `data/local_events.json`
15
+ - 提醒仍通过 OpenClaw `jobs.json` 执行
16
+
17
+ - `google`
18
+ - 用户已完成 Google 授权,且首次同步成功后启用
19
+ - 事件读写来自 Google Calendar
20
+
21
+ 前端不需要自己判断应该走哪套事件 API。
22
+
23
+ 现有日历接口路径保持不变:
24
+
25
+ - `GET /events`
26
+ - `POST /events`
27
+ - `DELETE /events/{event_id}`
28
+ - `GET /events/conflicts`
29
+ - `GET /daily-plan`
30
+ - `GET /reminders`
31
+
32
+ 前端只需要读取响应中的:
33
+
34
+ - `provider`
35
+ - `active_mode`
36
+ - `sync_state`
37
+
38
+ 来决定页面展示文案。
39
+
40
+ ## 二、认证
41
+
42
+ 所有接口都需要请求头:
43
+
44
+ ```http
45
+ X-API-Key: <your-api-key>
46
+ ```
47
+
48
+ 开发环境如果服务端 `API_KEY=dev`,仍建议前端带上 `X-API-Key: dev`。
49
+
50
+ ## 三、核心状态流
51
+
52
+ ### 1. 默认本地模式
53
+
54
+ 初始状态:
55
+
56
+ - `active_mode = local`
57
+ - `google_state = not_connected`
58
+
59
+ 这时前端可以直接:
60
+
61
+ - 创建本地事件
62
+ - 查询某天事件
63
+ - 查看冲突
64
+ - 查看日报
65
+ - 查看提醒预览
66
+
67
+ ### 2. 启动 Google 接入
68
+
69
+ 前端流程:
70
+
71
+ 1. 调 `GET /integrations/google/status`
72
+ 2. 调 `GET /integrations/google/guide`
73
+ 3. 用户填写自己的 `client_id` / `client_secret`
74
+ 4. 调 `POST /integrations/google/start`
75
+ 5. 打开返回的 `authorize_url`
76
+ 6. 用户授权完成后,Google 回调到后端
77
+ 7. 前端重新查询 `GET /integrations/google/status`
78
+
79
+ 授权成功但还没同步时:
80
+
81
+ - `active_mode = local`
82
+ - `google_state = connected_pending_sync`
83
+
84
+ ### 3. 首次同步
85
+
86
+ 前端在 `connected_pending_sync` 时调用:
87
+
88
+ - `POST /integrations/google/sync`
89
+
90
+ 同步成功后:
91
+
92
+ - `active_mode = google`
93
+ - `google_state = ready`
94
+
95
+ 同步失败时:
96
+
97
+ - `active_mode` 仍然保持 `local`
98
+ - `google_state = connected_pending_sync`
99
+ - 错误信息在 `last_error` 和 `last_sync_summary.last_error`
100
+
101
+ ## 四、状态接口
102
+
103
+ ### `GET /integrations/google/status`
104
+
105
+ 用途:
106
+
107
+ - 判断当前模式
108
+ - 判断 Google 是否已接入
109
+ - 判断是否需要首次同步
110
+ - 给前端页面顶部或设置页展示连接状态
111
+
112
+ 返回示例:
113
+
114
+ ```json
115
+ {
116
+ "active_mode": "local",
117
+ "google_state": "not_connected",
118
+ "has_token": false,
119
+ "masked_client_id": "",
120
+ "needs_initial_sync": false,
121
+ "current_step": "credentials",
122
+ "last_error": "",
123
+ "last_sync_time": "",
124
+ "last_sync_summary": {
125
+ "status": "idle",
126
+ "total": 0,
127
+ "succeeded": 0,
128
+ "failed": 0,
129
+ "skipped": 0,
130
+ "started_at": "",
131
+ "finished_at": "",
132
+ "last_error": ""
133
+ }
134
+ }
135
+ ```
136
+
137
+ 字段说明:
138
+
139
+ - `active_mode`
140
+ - 当前事件主来源
141
+ - `local | google`
142
+ - `google_state`
143
+ - Google 接入状态
144
+ - `not_connected | authorizing | connected_pending_sync | syncing | ready | error`
145
+ - `has_token`
146
+ - 服务端是否已经有有效 token 文件
147
+ - `needs_initial_sync`
148
+ - 是否还需要执行首次同步
149
+ - `current_step`
150
+ - 前端向导当前步骤
151
+ - `credentials | authorize | sync | done`
152
+
153
+ ### `GET /integrations/google/guide`
154
+
155
+ 用途:
156
+
157
+ - 获取前端向导步骤文案
158
+ - 获取回调地址
159
+
160
+ 返回示例:
161
+
162
+ ```json
163
+ {
164
+ "current_step": "credentials",
165
+ "active_mode": "local",
166
+ "google_state": "not_connected",
167
+ "callback_url": "http://127.0.0.1:8765/integrations/google/callback",
168
+ "required_fields": ["client_id", "client_secret"],
169
+ "steps": [
170
+ {
171
+ "key": "credentials",
172
+ "title": "填写 Google OAuth 凭据",
173
+ "description": "用户提供自己的 Google Client ID 和 Client Secret。"
174
+ }
175
+ ]
176
+ }
177
+ ```
178
+
179
+ ## 五、授权启动与回调
180
+
181
+ ### `POST /integrations/google/start`
182
+
183
+ 用途:
184
+
185
+ - 启动授权会话
186
+ - 获取 Google 授权链接
187
+
188
+ 请求体:
189
+
190
+ ```json
191
+ {
192
+ "client_id": "xxx.apps.googleusercontent.com",
193
+ "client_secret": "xxx"
194
+ }
195
+ ```
196
+
197
+ 返回示例:
198
+
199
+ ```json
200
+ {
201
+ "ok": true,
202
+ "authorize_url": "https://accounts.google.com/o/oauth2/v2/auth?...",
203
+ "expires_at": "2026-04-01T08:15:00+00:00",
204
+ "google_state": "authorizing"
205
+ }
206
+ ```
207
+
208
+ 前端处理建议:
209
+
210
+ - 在新窗口或弹窗中打开 `authorize_url`
211
+ - 不要在前端保存 `client_secret`
212
+ - 授权完成后关闭弹窗,再轮询或刷新状态接口
213
+
214
+ ### `GET /integrations/google/callback`
215
+
216
+ 用途:
217
+
218
+ - Google OAuth 回调地址
219
+ - 前端不直接调用
220
+
221
+ 行为:
222
+
223
+ - 成功时返回简单 HTML 成功页
224
+ - 失败时返回简单 HTML 失败页
225
+
226
+ 前端只需在授权完成后重新请求:
227
+
228
+ - `GET /integrations/google/status`
229
+
230
+ ## 六、同步接口
231
+
232
+ ### `POST /integrations/google/sync`
233
+
234
+ 用途:
235
+
236
+ - 将本地事件补推到 Google
237
+ - 成功后把系统切换到 `google` 模式
238
+
239
+ 返回示例:
240
+
241
+ ```json
242
+ {
243
+ "ok": true,
244
+ "active_mode": "google",
245
+ "google_state": "ready",
246
+ "summary": {
247
+ "status": "finished",
248
+ "total": 3,
249
+ "succeeded": 3,
250
+ "failed": 0,
251
+ "skipped": 0,
252
+ "started_at": "2026-04-01T08:00:00+00:00",
253
+ "finished_at": "2026-04-01T08:00:02+00:00",
254
+ "last_error": ""
255
+ }
256
+ }
257
+ ```
258
+
259
+ 前端处理建议:
260
+
261
+ - 成功后立刻刷新 `GET /integrations/google/status`
262
+ - 如果 `summary.failed > 0`,保持在设置页提示用户重试
263
+
264
+ ### `GET /integrations/google/sync-status`
265
+
266
+ 用途:
267
+
268
+ - 查看最近一次同步结果
269
+
270
+ 适合:
271
+
272
+ - 设置页
273
+ - 授权完成后的结果展示
274
+
275
+ ## 七、事件接口
276
+
277
+ ### `GET /events`
278
+
279
+ 支持两种查询方式:
280
+
281
+ - `GET /events?date=YYYY-MM-DD`
282
+ - `GET /events?start=<ISO>&end=<ISO>`
283
+
284
+ 返回新增字段:
285
+
286
+ - `provider`
287
+ - `active_mode`
288
+ - 每条事件上的 `sync_state`
289
+
290
+ 返回示例:
291
+
292
+ ```json
293
+ {
294
+ "date": "2026-04-01",
295
+ "provider": "local",
296
+ "active_mode": "local",
297
+ "events": [
298
+ {
299
+ "id": "local_abc123",
300
+ "summary": "本地会议",
301
+ "start": "2026-04-01T09:00:00+08:00",
302
+ "end": "2026-04-01T10:00:00+08:00",
303
+ "status": "confirmed",
304
+ "duration_minutes": 60,
305
+ "provider": "local",
306
+ "sync_state": "local_only"
307
+ }
308
+ ],
309
+ "conflicts": []
310
+ }
311
+ ```
312
+
313
+ 前端展示建议:
314
+
315
+ - `provider=local` 时可显示“本地模式”
316
+ - `sync_state=local_only` 时可显示“未同步到 Google”
317
+ - `sync_state=failed` 时可显示“同步失败”
318
+
319
+ ### `POST /events`
320
+
321
+ 请求体保持原样:
322
+
323
+ ```json
324
+ {
325
+ "summary": "产品评审",
326
+ "date": "2026-04-01",
327
+ "start": "10:00",
328
+ "end": "11:30",
329
+ "location": "线上",
330
+ "description": "Q2 规划",
331
+ "remind": 15
332
+ }
333
+ ```
334
+
335
+ 返回新增字段:
336
+
337
+ - `provider`
338
+ - `sync_state`
339
+
340
+ 说明:
341
+
342
+ - `local` 模式下,事件写入本地 JSON
343
+ - `google` 模式下,事件写入 Google Calendar
344
+ - `remind > 0` 时,仍会注册 OpenClaw 一次性提醒任务
345
+
346
+ ### `DELETE /events/{event_id}`
347
+
348
+ 说明:
349
+
350
+ - 本地模式下,本地事件会被标记取消
351
+ - Google 模式下,会删除 Google 事件
352
+
353
+ ### `GET /events/conflicts`
354
+
355
+ 说明:
356
+
357
+ - 继续复用 `/events` 的冲突检测结果
358
+ - 本地模式和 Google 模式都可用
359
+
360
+ ## 八、日报与提醒
361
+
362
+ ### `GET /daily-plan`
363
+
364
+ 作用:
365
+
366
+ - 获取某一天的事件、冲突和已生成 Markdown
367
+
368
+ 新增字段:
369
+
370
+ - `provider`
371
+
372
+ 说明:
373
+
374
+ - Markdown 仍然只是人类可读日报,不是事件数据库
375
+ - 前端如要做日历视图,应该使用 `/events`,不要解析 Markdown
376
+
377
+ ### `GET /reminders?window=30`
378
+
379
+ 作用:
380
+
381
+ - 预览未来 N 分钟内将触发的提醒
382
+
383
+ 新增字段:
384
+
385
+ - `provider`
386
+ - `active_mode`
387
+
388
+ 说明:
389
+
390
+ - 本地模式下从本地事件计算
391
+ - Google 模式下从 Google 日历计算
392
+
393
+ ## 九、前端推荐接入顺序
394
+
395
+ ### 场景 A:用户完全没有 Google
396
+
397
+ 1. 页面启动先调 `GET /integrations/google/status`
398
+ 2. 发现 `active_mode=local`
399
+ 3. 日历页直接用 `/events`
400
+ 4. 创建事件直接用 `POST /events`
401
+ 5. 日报页用 `/daily-plan`
402
+ 6. 提醒预览用 `/reminders`
403
+
404
+ ### 场景 B:用户要接入 Google
405
+
406
+ 1. 调 `GET /integrations/google/guide`
407
+ 2. 展示凭据输入表单
408
+ 3. 调 `POST /integrations/google/start`
409
+ 4. 打开 `authorize_url`
410
+ 5. 授权完成后刷新 `GET /integrations/google/status`
411
+ 6. 若 `google_state=connected_pending_sync`,显示“开始同步”按钮
412
+ 7. 用户点击后调 `POST /integrations/google/sync`
413
+ 8. 成功后重新拉 `GET /integrations/google/status`
414
+ 9. 当 `active_mode=google` 后,前端其余日历调用不需要换接口
415
+
416
+ ## 十、错误处理建议
417
+
418
+ - 401
419
+ - `X-API-Key` 缺失或错误
420
+ - 400
421
+ - 日期、时间或请求参数格式不合法
422
+ - 502
423
+ - Google 授权或 Google API 上游失败
424
+ - 500
425
+ - 服务端内部错误
426
+
427
+ 前端建议:
428
+
429
+ - 对 `/integrations/google/*` 的错误单独显示,不要影响本地模式日程页面
430
+ - 即使 Google 接入失败,只要 `active_mode=local`,日历功能仍应保持可用
431
+
432
+ ## 十一、已知边界
433
+
434
+ - 当前是单用户模型,不支持多账号切换
435
+ - 首次同步只做“本地 -> Google”单向补推
436
+ - 不做双向合并,也不处理 Google 现有事件去重
437
+ - Markdown 报表不是结构化托底源,只做展示用途
File without changes