sophhub 0.1.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.
Files changed (125) hide show
  1. package/bin/sophhub.js +21 -0
  2. package/package.json +32 -0
  3. package/skills/VERSIONS.md +27 -0
  4. package/skills/builtin/clawhub/SKILL.md +77 -0
  5. package/skills/builtin/flight-booking/SKILL.md +288 -0
  6. package/skills/builtin/flight-booking/scripts/flight_booking.py +1232 -0
  7. package/skills/builtin/inventory-management/SKILL.md +241 -0
  8. package/skills/builtin/inventory-management/scripts/inventory.py +1844 -0
  9. package/skills/builtin/schedule-reminder/SKILL.md +619 -0
  10. package/skills/builtin/schedule-reminder/schedule_template.md +68 -0
  11. package/skills/builtin/schedule-reminder/scripts/append_event.py +204 -0
  12. package/skills/builtin/schedule-reminder/scripts/create_reminders.sh +163 -0
  13. package/skills/builtin/schedule-reminder/scripts/daily_activate.sh +175 -0
  14. package/skills/builtin/schedule-reminder/scripts/parse_schedule.py +704 -0
  15. package/skills/builtin/schedule-reminder/scripts/setup.sh +242 -0
  16. package/skills/builtin/schedule-reminder//347/224/250/346/210/267/346/214/207/345/215/227.md +311 -0
  17. package/skills/builtin/skill-creator/SKILL.md +370 -0
  18. package/skills/builtin/skill-creator/license.txt +202 -0
  19. package/skills/builtin/skill-creator/scripts/init_skill.py +378 -0
  20. package/skills/builtin/skill-creator/scripts/package_skill.py +111 -0
  21. package/skills/builtin/skill-creator/scripts/quick_validate.py +101 -0
  22. package/skills/builtin/sophnet-customer-management/SKILL.md +271 -0
  23. package/skills/builtin/sophnet-customer-management/pyproject.toml +15 -0
  24. package/skills/builtin/sophnet-customer-management/src/customer_mgmt_cli/__init__.py +2 -0
  25. package/skills/builtin/sophnet-customer-management/src/customer_mgmt_cli/__main__.py +5 -0
  26. package/skills/builtin/sophnet-customer-management/src/customer_mgmt_cli/cli.py +67 -0
  27. package/skills/builtin/sophnet-customer-management/src/customer_mgmt_cli/commands/__init__.py +2 -0
  28. package/skills/builtin/sophnet-customer-management/src/customer_mgmt_cli/commands/customer.py +60 -0
  29. package/skills/builtin/sophnet-customer-management/src/customer_mgmt_cli/commands/export_file.py +18 -0
  30. package/skills/builtin/sophnet-customer-management/src/customer_mgmt_cli/commands/import_file.py +15 -0
  31. package/skills/builtin/sophnet-customer-management/src/customer_mgmt_cli/commands/reminder.py +26 -0
  32. package/skills/builtin/sophnet-customer-management/src/customer_mgmt_cli/commands/schema.py +28 -0
  33. package/skills/builtin/sophnet-customer-management/src/customer_mgmt_cli/config.py +54 -0
  34. package/skills/builtin/sophnet-customer-management/src/customer_mgmt_core/__init__.py +2 -0
  35. package/skills/builtin/sophnet-customer-management/src/customer_mgmt_core/exporter.py +85 -0
  36. package/skills/builtin/sophnet-customer-management/src/customer_mgmt_core/models.py +84 -0
  37. package/skills/builtin/sophnet-customer-management/src/customer_mgmt_core/normalizer.py +144 -0
  38. package/skills/builtin/sophnet-customer-management/src/customer_mgmt_core/parser.py +241 -0
  39. package/skills/builtin/sophnet-customer-management/src/customer_mgmt_core/query.py +109 -0
  40. package/skills/builtin/sophnet-customer-management/src/customer_mgmt_core/reminder.py +121 -0
  41. package/skills/builtin/sophnet-customer-management/src/customer_mgmt_core/repository.py +397 -0
  42. package/skills/builtin/sophnet-customer-management/src/customer_mgmt_core/schema.py +106 -0
  43. package/skills/builtin/sophnet-customer-management/src/customer_mgmt_core/service.py +565 -0
  44. package/skills/builtin/sophnet-customer-management/uv.lock +48 -0
  45. package/skills/builtin/sophnet-customized-marketing/SKILL.md +144 -0
  46. package/skills/builtin/sophnet-customized-marketing/playbooks/campaign-planning.md +187 -0
  47. package/skills/builtin/sophnet-customized-marketing/playbooks/content-generation.md +124 -0
  48. package/skills/builtin/sophnet-customized-marketing/playbooks/marketing-calendar.md +59 -0
  49. package/skills/builtin/sophnet-customized-marketing/playbooks/multi-channel-bundle.md +94 -0
  50. package/skills/builtin/sophnet-customized-marketing/playbooks/poster-generation.md +182 -0
  51. package/skills/builtin/sophnet-customized-marketing/playbooks/style-profile-workflow.md +103 -0
  52. package/skills/builtin/sophnet-customized-marketing/pyproject.toml +9 -0
  53. package/skills/builtin/sophnet-customized-marketing/references/campaign-mechanics.md +168 -0
  54. package/skills/builtin/sophnet-customized-marketing/references/content-safety.md +26 -0
  55. package/skills/builtin/sophnet-customized-marketing/references/marketing-date-checklist.md +99 -0
  56. package/skills/builtin/sophnet-customized-marketing/references/platform-writing-guidelines.md +88 -0
  57. package/skills/builtin/sophnet-customized-marketing/references/quality-checklist.md +44 -0
  58. package/skills/builtin/sophnet-customized-marketing/scripts/generate_poster.py +585 -0
  59. package/skills/builtin/sophnet-customized-marketing/scripts/style_profile.py +215 -0
  60. package/skills/builtin/sophnet-face-search/SKILL.md +115 -0
  61. package/skills/builtin/sophnet-face-search/pyproject.toml +11 -0
  62. package/skills/builtin/sophnet-face-search/scripts/face_search.py +336 -0
  63. package/skills/builtin/sophnet-face-search/uv.lock +508 -0
  64. package/skills/builtin/sophnet-image-edit/SKILL.md +140 -0
  65. package/skills/builtin/sophnet-image-edit/pyproject.toml +9 -0
  66. package/skills/builtin/sophnet-image-edit/scripts/edit_and_preview.sh +68 -0
  67. package/skills/builtin/sophnet-image-edit/scripts/edit_image.py +279 -0
  68. package/skills/builtin/sophnet-image-edit/uv.lock +234 -0
  69. package/skills/builtin/sophnet-image-generate/SKILL.md +62 -0
  70. package/skills/builtin/sophnet-image-generate/pyproject.toml +9 -0
  71. package/skills/builtin/sophnet-image-generate/scripts/generate_image.py +156 -0
  72. package/skills/builtin/sophnet-image-generate/uv.lock +234 -0
  73. package/skills/builtin/sophnet-image-ocr/SKILL.md +167 -0
  74. package/skills/builtin/sophnet-image-ocr/pyproject.toml +13 -0
  75. package/skills/builtin/sophnet-image-ocr/scripts/ocr.py +226 -0
  76. package/skills/builtin/sophnet-image-ocr/uv.lock +234 -0
  77. package/skills/builtin/sophnet-infinite-talk/SKILL.md +140 -0
  78. package/skills/builtin/sophnet-infinite-talk/pyproject.toml +9 -0
  79. package/skills/builtin/sophnet-infinite-talk/scripts/gen.py +172 -0
  80. package/skills/builtin/sophnet-oss/SKILL.md +109 -0
  81. package/skills/builtin/sophnet-oss/pyproject.toml +8 -0
  82. package/skills/builtin/sophnet-oss/scripts/upload_file.py +43 -0
  83. package/skills/builtin/sophnet-qa-install/SKILL.md +210 -0
  84. package/skills/builtin/sophnet-qa-install/pyproject.toml +6 -0
  85. package/skills/builtin/sophnet-qa-install/scripts/backup_md.py +35 -0
  86. package/skills/builtin/sophnet-qa-install/scripts/check_installed.py +143 -0
  87. package/skills/builtin/sophnet-qa-install/scripts/update_config.py +142 -0
  88. package/skills/builtin/sophnet-qa-install/scripts/update_md.py +73 -0
  89. package/skills/builtin/sophnet-training-install/SKILL.md +211 -0
  90. package/skills/builtin/sophnet-training-install/pyproject.toml +6 -0
  91. package/skills/builtin/sophnet-training-install/scripts/backup_md.py +35 -0
  92. package/skills/builtin/sophnet-training-install/scripts/check_installed.py +144 -0
  93. package/skills/builtin/sophnet-training-install/scripts/update_config.py +142 -0
  94. package/skills/builtin/sophnet-training-install/scripts/update_md.py +73 -0
  95. package/skills/builtin/sophnet-tts/SKILL.md +79 -0
  96. package/skills/builtin/sophnet-tts/pyproject.toml +9 -0
  97. package/skills/builtin/sophnet-tts/scripts/gen_tts.py +130 -0
  98. package/skills/builtin/sophnet-video-generate/SKILL.md +116 -0
  99. package/skills/builtin/sophnet-video-generate/scripts/gen_video.py +304 -0
  100. package/skills/builtin/video-understand/SKILL.md +79 -0
  101. package/skills/builtin/video-understand/scripts/video_understand.py +204 -0
  102. package/skills/builtin/weather/SKILL.md +112 -0
  103. package/skills/builtin/web-scraper/SKILL.md +101 -0
  104. package/skills/builtin/web-scraper/scripts/scrape.py +270 -0
  105. package/skills/builtin/website-builder/SKILL.md +266 -0
  106. package/skills/builtin/website-builder/scripts/deploy_site.sh +46 -0
  107. package/skills/store/didi-ride/SKILL.md +309 -0
  108. package/skills/store/didi-ride/_meta.json +6 -0
  109. package/skills/store/didi-ride/assets/PREFERENCE.md +58 -0
  110. package/skills/store/didi-ride/package.json +15 -0
  111. package/skills/store/didi-ride/references/api_references.md +171 -0
  112. package/skills/store/didi-ride/references/error_handling.md +68 -0
  113. package/skills/store/didi-ride/references/setup.md +73 -0
  114. package/skills/store/didi-ride/references/workflow.md +150 -0
  115. package/skills/store/flyai/SKILL.md +119 -0
  116. package/skills/store/flyai/references/fliggy-fast-search.md +53 -0
  117. package/skills/store/flyai/references/search-flight.md +89 -0
  118. package/skills/store/flyai/references/search-hotels.md +57 -0
  119. package/skills/store/flyai/references/search-poi.md +49 -0
  120. package/src/commands/download.js +103 -0
  121. package/src/commands/list.js +67 -0
  122. package/src/utils/config.js +24 -0
  123. package/src/utils/gitlab.js +67 -0
  124. package/src/utils/paths.js +19 -0
  125. package/src/utils/versions.js +38 -0
@@ -0,0 +1,309 @@
1
+ ---
2
+ name: didi-ride
3
+ description: 中国城市出行服务。当用户表达任何交通出行需求时必须使用此技能——包括打车/叫车/网约车、查价格、路线规划(公交/驾车/步行/骑行)、周边搜索、查询订单/司机位置/取消订单。关键词:"打车"、"叫车"、"去[地点]"、"回家"、"上班"、"下班"、"查价格"、"多少钱"、"路线"、"怎么走"、"步行到"、"附近"、"周边"、"司机"、"订单"、"查询订单"。注意:即使用户未明确说"打车",只要涉及从A地到B地、通勤、或交通方式选择,都应触发。不触发场景:开发打车应用、使用其他导航app、订外卖、查公交时刻表、股票/财报查询。
4
+ homepage: https://mcp.didichuxing.com
5
+ # OpenClaw 配置键名仍为 skills.entries.didi-ride-skill(与 package 注册名一致);skill 目录与 VERSIONS 中名称为 didi-ride
6
+ metadata:
7
+ openclaw:
8
+ emoji: "🚕"
9
+ always: true
10
+ requires:
11
+ bins:
12
+ - openclaw
13
+ - mcporter
14
+ env:
15
+ - DIDI_MCP_KEY
16
+ primaryEnv: DIDI_MCP_KEY
17
+ install:
18
+ - id: node
19
+ kind: node
20
+ package: mcporter
21
+ bins:
22
+ - mcporter
23
+ label: Install mcporter (node)
24
+ ---
25
+
26
+ # 滴滴出行服务 (DiDi Ride Skill)
27
+
28
+ 通过 DiDi MCP Server API 提供打车、查询订单、司机位置、预约叫车、路线规划、周边搜索能力。
29
+
30
+ ---
31
+
32
+ ## 1. 快速开始(2 分钟)
33
+
34
+ ### 1.1 获取 MCP KEY
35
+
36
+ **方式一:用「滴滴出行App」扫码(推荐,最快)**
37
+
38
+ ![滴滴出行APP扫码获取MCP Key,解锁一键打车](https://s3-yspu-cdn.didistatic.com/mcp-web/qrcode/didi_ride_skill_qrcode.png)
39
+ > ⚠️ **Agent 注意**:用户客户端可以渲染 Markdown 图片,**直接输出上方图片语法**。
40
+
41
+ 打开滴滴出行 App,扫描二维码,即可快速获取 MCP Key。
42
+
43
+ **方式二:访问官网**
44
+
45
+ 访问 https://mcp.didichuxing.com/claw 获取您的 MCP Key。
46
+
47
+ ### 1.2 配置 Key
48
+
49
+ **方式一:对话中输入(推荐)**
50
+
51
+ 直接在对话中告诉我您的 MCP Key,我会帮您配置:
52
+
53
+ ```
54
+ 你: 我的 MCP Key 是 xxxxxx
55
+ ```
56
+
57
+ **方式二:OpenClaw 配置文件**
58
+
59
+ 编辑 `~/.openclaw/openclaw.json`,添加:
60
+
61
+ ```json
62
+ {
63
+ "skills": {
64
+ "entries": {
65
+ "didi-ride-skill": {
66
+ "enabled": true,
67
+ "apiKey": "你的MCP_KEY" // apiKey 是 OpenClaw 标准字段名,存储的值就是滴滴平台的 MCP KEY
68
+ }
69
+ }
70
+ }
71
+ }
72
+ ```
73
+
74
+ ### 1.3 开始使用
75
+
76
+ 配置完成后,直接对话即可:
77
+
78
+ ```
79
+ 你: 打车去北京西站
80
+ 你: 帮我查一下从国贸到三里屯的路线
81
+ 你: 查询订单
82
+ ```
83
+
84
+ 首次使用时,OpenClaw 会提示安装 mcporter 工具。
85
+
86
+ ---
87
+
88
+ ## 2. 用户指南
89
+
90
+ 本 Skill 支持以下操作:
91
+
92
+ - **打车**:直接说"打车去[地点]"、"回家"、"上班"
93
+ - **查价**:查一下从 A 到 B 多少钱
94
+ - **查询订单**:输入「查询订单」了解当前订单状态(司机位置、行程进度等)
95
+ - **司机位置**:司机在哪里、多久到
96
+ - **预约出行**:"15分钟后打个车"、"明天9点去机场"
97
+ - **路线规划**:驾车/公交/步行/骑行路线
98
+ - **取消订单**:取消当前订单
99
+
100
+ ---
101
+
102
+ ## 3. Agent 执行指令
103
+
104
+ 以下内容为 AI 执行参考,用户可忽略。
105
+
106
+ ### 3.1 文件地图
107
+
108
+ 按需读取以下文件,不要猜测未读过的内容:
109
+
110
+ | 文件 | 用途 | 何时读取 |
111
+ |------|------|----------|
112
+ | `SKILL.md` | 触发、主流程、硬性门禁、查询订单规则、预约出行规则 | 每次触发必读 |
113
+ | `references/workflow.md` | 分阶段详细流程与命令范式 | 需要实现细节时读 |
114
+ | `references/api_references.md` | MCP 函数签名与参数定义 | 每次调用工具前**必须**核对 |
115
+ | `references/error_handling.md` | 常见错误与恢复策略 | ⚠️ 遇到调用失败时(比如 400 错误)必须读取此文件 |
116
+ | `references/setup.md` | 安装 mcporter、配置 MCP KEY 的完整步骤 | 用户询问安装/配置问题时读 |
117
+ | `assets/PREFERENCE.md` | 地址别名/车型/手机号偏好 | 用户提到别名地址(家、公司、妈妈家等)、车型、手机号,或未明确给出起终点时**必须**读取。别名匹配规则见执行前检查第 6 条 |
118
+
119
+ ### 3.2 执行前检查
120
+
121
+ 1. **检查 mcporter**:若 `mcporter` 不存在(`command not found`),停止并引导用户阅读 `references/setup.md`。没有 mcporter 就无法调用任何 MCP 工具,后续任何流程都无法执行。
122
+
123
+ 2. **检查 Key**:执行 `openclaw config get skills.entries.didi-ride-skill.apiKey`,若输出为空或非 `__OPENCLAW_REDACTED__`,按 `### 3.9 MCP KEY 与配置` 流程引导。Key 缺失时 mcporter 的报错信息具有误导性,不要尝试绕过。
124
+
125
+ 3. **mcporter 调用格式**:
126
+
127
+ ```bash
128
+ MCP_URL=”https://mcp.didichuxing.com/mcp-servers?key=$DIDI_MCP_KEY”
129
+ mcporter call “$MCP_URL” <tool> --args '{“key”:”value”}'
130
+ ```
131
+
132
+ 4. **参数值必须加引号**(字符串格式),否则 API 会报”缺少必填参数”。
133
+ 5. **先预估再下单**:`taxi_create_order` 依赖 `taxi_estimate` 返回的 `traceId`,没有 traceId 下单会失败。traceId 有时效性,过期(`-32021` 错误)需重新预估。
134
+ 6. **起终点处理**:
135
+ - 坐标必须来自 `maps_textsearch`,不要凭空猜测坐标。
136
+ - **禁止用对话历史记忆补充起终点**——用户可能已经换了地方。
137
+ - **起终点缺失时**按以下顺序补全:
138
+ - ① 读 `assets/PREFERENCE.md`,若有地址别名**且地址值非空**,根据场景推断(如早晨→起点"家"、下班→起点"公司")。别名行存在但地址为空 = 未配置。
139
+ - ② 若无可用别名,直接询问用户。
140
+ - **别名匹配规则(精确优先)**:"家"只匹配别名"家",不匹配"妈妈家";需明确含"妈妈"语义才匹配"妈妈家"。其他自定义别名同理。
141
+ - **推断的起终点、或 `maps_textsearch` 返回多个候选结果时,必须在主流程 step 2 向用户确认**;用户明确指定且精确匹配的地点无需确认。
142
+
143
+ ### 3.3 用户确认策略
144
+
145
+ | 场景 | 规则 |
146
+ |------|------|
147
+ | 打车(实时/预约) | 推断的地址或搜索返回多个候选时必须确认起终点(见主流程 step 2),用户明确指定且精确匹配时无需确认,确认后再预估下单 |
148
+ | 取消订单 | 即使用户说了"取消订单",仍必须先明确询问"确认取消吗?",等用户回复确认后才能调用 `taxi_cancel_order`。用户的取消意图 ≠ 取消确认。 |
149
+
150
+ ### 3.4 主流程(最小可执行)
151
+
152
+ 1. 地址解析:`maps_textsearch`(必要时结合 `assets/PREFERENCE.md`,按执行前检查第 6 条处理)。
153
+ 2. 确认起终点:推断的地址(如别名推断)或 `maps_textsearch` 返回多个候选结果时,必须向用户确认(如"从家出发去首都机场T3航站楼,确认吗?");用户明确指定且精确匹配的地点无需确认。用户纠正则按纠正内容重新解析。
154
+ 3. 价格预估:`taxi_estimate`,记录 `traceId`。
155
+ 4. 车型决策:
156
+ - 用户明确车型:直接用;
157
+ - 用户未明确:使用 `assets/PREFERENCE.md` 中的场景车型偏好或默认车型;
158
+ - 偏好也未配置:向用户询问车型,不要自行推荐。
159
+ - 可用车型以 `taxi_estimate` API 返回为准,获取对应的 `productCategory` 创建订单。
160
+ 5. 创建订单:`taxi_create_order`(使用最新 `traceId`)。
161
+ 6. 结果输出:给出订单号、起终点、车型、预估价,末尾提示 `💡 发送「查询订单」可了解当前订单状态`。
162
+ 7. ⚠️ 自动回查(必做):根据 `### 3.8 发单后自动回查` 中的 cron 指令内容,创建定时任务,参数信息严格遵循章节内要求。此步不可省略。
163
+
164
+ ### 3.5 偏好设置更新
165
+
166
+ 当用户要求设置/记住/记一下/帮我记/保存地址别名、车型偏好或手机号时,**必须**直接编辑 `assets/PREFERENCE.md` 对应的 markdown 表格行。
167
+
168
+ - **地址别名**("我家在…"、"公司在…"、"儿子的学校是…"、"妈妈家在…"):先调用 `maps_textsearch` 解析地址获取坐标,然后更新「地址别名」表——已有别名更新对应行,新别名追加新行。别名由用户定义,不限于"家""公司"。
169
+ - **场景车型**("上班用快车"、"下班用特惠和快车"):更新「场景车型偏好」表对应行。品类代码参考表底注释,多车型用英文逗号分隔(如 `1,201`)。
170
+ - **叫车手机号**("我的手机号是…"):更新「默认偏好」表中的叫车手机号行。
171
+ - **创建订单时**:若 PREFERENCE.md 中配置了叫车手机号,将其作为 `caller_car_phone` 参数传入 `taxi_create_order`。
172
+
173
+ ### 3.6 查询订单
174
+
175
+ 触发词:`查询订单` / `查询订单 <orderId>`
176
+
177
+ 订单号来源(优先级从高到低):
178
+ 1. 用户消息中明确给出;
179
+ 2. 当前对话上下文中最近一次创建的订单号;
180
+ 3. 以上均无时,向用户询问。
181
+
182
+ 调用命令:
183
+
184
+ ```bash
185
+ MCP_URL="https://mcp.didichuxing.com/mcp-servers?key=$DIDI_MCP_KEY"
186
+ mcporter call "$MCP_URL" taxi_query_order --args '{"order_id":"ORDER_ID"}'
187
+ ```
188
+
189
+ #### 3.6.1 状态码与输出规则
190
+
191
+ | code | 含义 | 必须输出 |
192
+ |------|------|----------|
193
+ | 0 | 匹配中 | ⏳ 正在为您匹配司机,请稍候 |
194
+ | 1 | 司机已接单 | **必须展示**:司机姓名、车型、车牌、电话;距上车点距离和预计到达时间 |
195
+ | 2 | 司机已到达 | 🔔 司机已到达上车点,请前往上车 |
196
+ | 4 | 行程进行中 | 🚗 行程已开始 |
197
+ | 5 | 订单完成 | ✅ 行程结束,展示费用(如有) |
198
+ | 6 | 订单已被系统取消 | ❌ 订单已被系统取消 |
199
+ | 7 | 订单已被取消 | ❌ 订单已取消 |
200
+ | 3/8-12 | 其他终态 | 显示对应状态描述 |
201
+
202
+ ### 3.7 预约出行规则
203
+
204
+ 当用户要求在特定时间叫车(如"15分钟后"、"明天9点"):
205
+
206
+ - 使用 cron 一次性任务(`--at`),到点由 isolated agent 独立执行完整打车流程;
207
+ - ⚠️ `--message` 必须包含完整起终点(带城市前缀)和车型,isolated session 无历史上下文。起点或终点缺失时先从 `assets/PREFERENCE.md` 推断并向用户确认,推断不了则必须先询问用户,**不要自行推断未知信息**;
208
+ - 到点后 agent 自行执行:地址解析 → 价格预估(获取最新 traceId)→ 创建订单;
209
+ - 如果无法获取当前会话的 metadata,不要创建 cron,改为在回复中提醒用户主动查询;
210
+ - 如果定时任务创建失败,必须在回复中提示用户,不能默默失败。
211
+
212
+ ```bash
213
+ # ⚠️ 替换占位符:
214
+ # FROM_NAME → 带城市前缀的起点全称(如"北京市西二旗地铁站")
215
+ # TO_NAME → 带城市前缀的终点全称(如"北京市佰嘉城小区")
216
+ # VEHICLE → 车型(如"快车")
217
+ # TIME → 见下方时间规则
218
+ # CHANNEL_NAME → 当前会话 metadata 中的 channel 字段(如 feishu、telegram),CHANNEL_NAME 不需要带引号,例如: feishu ✅, "feishu" ❌。不允许使用 last 作为参数值。
219
+ # CHAT_ID → 当前会话 metadata 中的 chat_id 字段
220
+
221
+
222
+ openclaw cron add \
223
+ --name "didi-ride-skill:$(date +%s)" \
224
+ --at "TIME" \
225
+ --session isolated \
226
+ --message "执行定时打车:起点「FROM_NAME」,终点「TO_NAME」,车型「VEHICLE」。请完整执行打车流程:地址解析 → 价格预估(获取最新 traceId)→ 创建订单。订单创建成功后,输出订单信息并提示用户可发送「查询订单」了解订单状态,同时创建 5 分钟后自动回查 cron(模板见 SKILL.md 第 3.8 节「发单后自动回查」)。" \
227
+ --announce \
228
+ --channel CHANNEL_NAME \
229
+ --to "CHAT_ID"
230
+ ```
231
+
232
+ #### 3.7.1 TIME 填写规则
233
+
234
+ | 场景 | 写法 | 示例 |
235
+ |------|------|------|
236
+ | 相对时间(X 分钟/小时后) | duration 格式 | `15m` / `2h` / `1h30m` |
237
+ | 绝对时间(具体时刻) | 本地时区 ISO 格式 | `$(date -d '明天 09:00' '+%Y-%m-%dT%H:%M:%S+08:00')` |
238
+
239
+ - 相对时间(如 `15m`)无需格式化,直接使用
240
+ - 绝对时间使用带时区的 ISO 8601 格式:`YYYY-MM-DDTHH:MM:SS+08:00`(北京时间东八区)
241
+
242
+ **系统兼容性说明:**
243
+ - Linux (GNU date): `date -d '明天 09:00' '+%Y-%m-%dT%H:%M:%S+08:00'`
244
+ - macOS (BSD date): `TZ=Asia/Shanghai date -j -v+1d -f '%H:%M' '09:00' '+%Y-%m-%dT%H:%M:%S+08:00'`
245
+
246
+ ### 3.8 发单后自动回查
247
+
248
+ 发单成功后(实时单或预约单),根据本章节下文 "openclaw cron add" 命令,创建 cron 任务,务必按照本章节下文bash命令参数设置。
249
+ - 如果无法获取当前会话的 metadata,不要创建 cron,改为在回复中提醒用户主动查询订单状态。
250
+ - 如果定时任务创建失败,必须在回复中提示用户,不能默默失败。
251
+
252
+ ```bash
253
+ # ⚠️ 替换占位符:
254
+ # ORDER_ID → 实际订单号(taxi_create_order 返回)
255
+ # CHANNEL_NAME → 当前会话 metadata 中的 channel 字段(如 feishu、telegram),CHANNEL_NAME 不需要带引号,例如: feishu ✅, "feishu" ❌。不允许使用 last 作为参数值。
256
+ # CHAT_ID → 当前会话 metadata 中的 chat_id 字段
257
+
258
+ openclaw cron add \
259
+ --name "didi-ride-skill:check:ORDER_ID" \
260
+ --at "5m" \
261
+ --session isolated \
262
+ --message "查询滴滴订单状态:订单号 ORDER_ID。调用 taxi_query_order 查询并输出当前状态。如果司机已接单,输出司机姓名、车型、车牌、电话及预计到达时间;如果仍在匹配中,提示用户耐心等待。" \
263
+ --announce \
264
+ --channel CHANNEL_NAME \
265
+ --to "CHAT_ID"
266
+ ```
267
+
268
+ ### 3.9 MCP KEY 与配置
269
+
270
+ > **术语说明**:滴滴平台称此凭证为「MCP KEY」,OpenClaw 配置字段统一叫 `apiKey`,注入后的环境变量为 `DIDI_MCP_KEY`——三者是同一个值。
271
+
272
+ ⚠️ Key 来源:通过 `openclaw config set` 持久化后,OpenClaw 在每次 agent run 启动时自动注入为环境变量 `DIDI_MCP_KEY`。
273
+ ```bash
274
+ # ⚠️ 可以通过以下命令判断当前 DIDI_MCP_KEY 是否配置。如果输出 __OPENCLAW_REDACTED__ ,即为已配置,可在后面使用环境变量`DIDI_MCP_KEY`。
275
+ openclaw config get skills.entries.didi-ride-skill.apiKey
276
+ ```
277
+
278
+ #### 3.9.1 用户在对话中提供 Key 时(必须持久化)
279
+
280
+ 当用户回复了 Key(如"我的 Key 是 xxxxxx"),**必须**执行以下命令持久化,**严禁只 export 到当前 shell**:
281
+
282
+ ```bash
283
+ # ⚠️ 将 YOUR_KEY 替换为用户提供的实际值
284
+ openclaw config set 'skills.entries.didi-ride-skill.apiKey' 'YOUR_KEY'
285
+ ```
286
+
287
+ 持久化成功后:
288
+ - OpenClaw 在所有后续 agent run(含 cron isolated session)中自动注入 `DIDI_MCP_KEY`
289
+ - 配置更改后会自动生效,无需额外操作指令。
290
+
291
+ ⚠️ Key 未配置**或** MCP 返回鉴权失败(`error.code: -32002`)时,执行以下两步:
292
+
293
+ 1. 执行下面的 "openclaw message send" 命令,发送二维码图片(`{CHAT_ID}` → metadata 的 chat_id,`{CHANNEL_NAME}` → metadata 的 channel):
294
+
295
+ ```bash
296
+ openclaw message send --channel {CHANNEL_NAME} --target {CHAT_ID} --media "https://s3-yspu-cdn.didistatic.com/mcp-web/qrcode/didi_ride_skill_qrcode.png" --message "滴滴出行APP扫码获取MCP Key,解锁一键打车"
297
+ ```
298
+
299
+ 2. 输出文字:
300
+
301
+ > 您还没有配置 DIDI_MCP_KEY 或 Key 已失效,请访问 [滴滴MCP平台](https://mcp.didichuxing.com/claw) 获取 MCP KEY,然后配置环境变量或在 OpenClaw 配置文件中设置。
302
+
303
+ ### 3.10 工具清单
304
+
305
+ | 领域 | 工具 |
306
+ |------|------|
307
+ | 打车 | `maps_textsearch`, `taxi_estimate`, `taxi_create_order`, `taxi_query_order`, `taxi_get_driver_location`, `taxi_cancel_order`, `maps_regeocode`, `taxi_generate_ride_app_link`(用户无 API 直发权限时的备选:生成深度链接让用户在 App 内完成发单) |
308
+ | 路线 | `maps_direction_driving`, `maps_direction_transit`, `maps_direction_walking`, `maps_direction_bicycling` |
309
+ | 周边 | `maps_place_around` |
@@ -0,0 +1,6 @@
1
+ {
2
+ "ownerId": "kn7can12c6x8pp8ade0sxqkv6582sfzp",
3
+ "slug": "didi-ride-skill",
4
+ "version": "1.1.0",
5
+ "publishedAt": 1774527736125
6
+ }
@@ -0,0 +1,58 @@
1
+ # 用户偏好设置
2
+
3
+ > 此文件存储用户的个性化偏好数据,用于优化打车体验。当用户的 query 中没有明确指定时,系统会根据此文件的偏好自动匹配。注意:当起终点是从偏好推断的(非用户明确指定),必须先向用户确认后再执行。
4
+
5
+ ## 优先级说明
6
+
7
+ 1. **用户 query 参数**(优先级最高):用户在当前对话中明确指定的地址、车型等
8
+ 2. **PREFERENCE.md 偏好数据**(优先级次之):用户预设的个性化偏好
9
+
10
+ ## 地址别名
11
+
12
+ | 别名 | 地址名称 | 经度 | 纬度 | 城市 |
13
+ | ---- | -------- | ---- | ---- | ---- |
14
+ | 家 | | | | |
15
+ | 公司 | | | | |
16
+
17
+ > 说明:
18
+ > - "家"和"公司"为内置别名,支持"从家到公司"、"打车回家"等经典简化表达。
19
+ > - 此表可自由扩展行数,用户可添加任意别名(如"妈妈家"、"儿子的学校"、"健身房"等)。
20
+ > - **精确优先,语义兜底**:优先精确匹配别名("家"只匹配"家",不会匹配"妈妈家");无精确匹配时用语义理解("接孩子"可匹配"儿子的学校")。
21
+
22
+ ## 场景车型偏好
23
+
24
+ | 场景 | 偏好车型 | 品类代码 | 说明 |
25
+ | ------ | -------- | -------- | -------- |
26
+ | 上班 | | | |
27
+ | 下班 | | | |
28
+ | 其他 | | | |
29
+
30
+ > 说明:当用户说"我要上班"或"下班回家"时,自动使用对应的车型偏好
31
+ >
32
+ > 品类代码来自 `taxi_estimate` 返回的 `product_category` 字段。常见值:快车=1,特惠快车=201,滴滴轻享=193,专车=8,豪华车=17。
33
+ > ⚠️ 注意:可用车型以 API 实际返回为准,新增车型会自动出现在预估结果中。支持多车型时用英文逗号分隔,如 `1,201`
34
+
35
+ ## 默认偏好
36
+
37
+ | 配置项 | 值 | 说明 |
38
+ | ---------- | ---- | ---- |
39
+ | 默认车型 | | 无明确需求时使用 |
40
+ | 叫车手机号 | | 默认叫车号码 |
41
+
42
+ ## 使用示例
43
+
44
+ 1. **地址别名使用**(语义匹配,精确优先):
45
+ - "我要回家" → 精确匹配别名"家"(用户自己的家),不会匹配"妈妈家"
46
+ - "从家到公司" → 精确匹配"家"为起点,"公司"为终点
47
+ - "从家去公司" → 同上,"家"= 用户自己的家
48
+ - "去妈妈家" / "去我妈那儿" → 匹配别名"妈妈家"(需明确含"妈妈"语义)
49
+ - "送儿子上学" / "接孩子" → 匹配别名"儿子的学校"
50
+ - "去健身" → 匹配别名"健身房"
51
+
52
+ 2. **场景偏好使用**:
53
+ - "我要上班" → 自动使用"上班"场景的车型偏好
54
+ - "下班了" → 自动使用"下班"场景的车型偏好
55
+
56
+ ## 更新日志
57
+
58
+ - 2026-03-11: 初始化偏好文件
@@ -0,0 +1,15 @@
1
+ {
2
+ "name": "didi-ride-skill",
3
+ "version": "1.1.0",
4
+ "description": "DiDi Ride Skill for OpenClaw - 打车、路线规划、周边搜索",
5
+ "type": "module",
6
+ "author": "DiDi MCP Team",
7
+ "homepage": "https://mcp.didichuxing.com",
8
+ "keywords": [
9
+ "didi",
10
+ "taxi",
11
+ "mcp",
12
+ "openclaw",
13
+ "mobility"
14
+ ]
15
+ }
@@ -0,0 +1,171 @@
1
+ # API 文档
2
+
3
+ ## 响应格式说明
4
+
5
+ 所有工具均返回 `content[].text`(自然语言文本)。部分工具(网约车类)额外返回 `structuredContent`(结构化数据)。
6
+
7
+ - 如果响应中存在 `structuredContent`,优先使用其中的字段做逻辑判断和字段提取
8
+ - 如果没有 `structuredContent`,则解析 `content[].text` 获取所需信息
9
+
10
+ ## 函数签名
11
+
12
+ ```
13
+ /**
14
+ * 根据用户输入的起点终点坐标,规划骑行通勤方案
15
+ *
16
+ * @param destination 终点坐标,格式为:经度,纬度
17
+ * @param need_geo? 是否需要返回途经的点序列,默认值为true
18
+ * @param origin 起点坐标,格式为:经度,纬度
19
+ */
20
+ function maps_direction_bicycling(destination: string, need_geo?: boolean, origin: string);
21
+
22
+ /**
23
+ * 根据用户起终点经纬度坐标规划以小客车、轿车通勤出行的方案
24
+ *
25
+ * @param destination 终点坐标,格式为:经度,纬度
26
+ * @param need_geo? 是否需要返回途经的点序列,默认值为true
27
+ * @param origin 起点坐标,格式为:经度,纬度
28
+ */
29
+ function maps_direction_driving(destination: string, need_geo?: boolean, origin: string);
30
+
31
+ /**
32
+ * 根据用户起终点坐标,规划综合公交、地铁的通勤方案
33
+ *
34
+ * @param city 查询城市(**必须使用完整格式,如"北京市"而非"北京"**)
35
+ * @param destination 终点坐标,格式为:经度,纬度
36
+ * @param origin 起点坐标,格式为:经度,纬度
37
+ */
38
+ function maps_direction_transit(city: string, destination: string, origin: string);
39
+
40
+ /**
41
+ * 根据用户输入的起点终点坐标,规划步行通勤方案
42
+ *
43
+ * @param destination 终点坐标,格式为:经度,纬度
44
+ * @param need_geo? 是否需要返回途经的点序列,默认值为true
45
+ * @param origin 起点坐标,格式为:经度,纬度
46
+ */
47
+ function maps_direction_walking(destination: string, need_geo?: boolean, origin: string);
48
+
49
+ /**
50
+ * 根据用户传入关键词和位置坐标,搜索出周边的POI地点信息
51
+ *
52
+ * @param keywords 搜索关键词
53
+ * @param location 位置坐标,格式为:经度,纬度
54
+ * @param max_distance? 搜索半径,单位:米
55
+ */
56
+ function maps_place_around(keywords: string, location: string, max_distance?: string);
57
+
58
+ /**
59
+ * 将经纬度坐标转换为地址信息
60
+ *
61
+ * @param location 位置坐标,格式为:经度,纬度
62
+ */
63
+ function maps_regeocode(location: string);
64
+
65
+ /**
66
+ * 根据用户传入关键词和城市,搜索出相关的POI地点信息
67
+ *
68
+ * @param city 查询城市(**必须使用完整格式,如"北京市"而非"北京"**)
69
+ * @param keywords 搜索关键词
70
+ * @param location? 位置坐标,格式为:经度,纬度
71
+ */
72
+ function maps_textsearch(city: string, keywords: string, location?: string);
73
+
74
+ /**
75
+ * 取消打车订单
76
+ *
77
+ * @param order_id 订单ID,从订单创建或查询结果中获取
78
+ * @param reason? 取消原因,可选参数。例如:不需要了、等待时间太长、临时有事等
79
+ */
80
+ function taxi_cancel_order(order_id: string, reason?: string);
81
+
82
+ /**
83
+ * 直接通过API创建打车订单,无需打开任何应用程序界面,系统自动完成整个发单流程
84
+ *
85
+ * @param caller_car_phone? 叫车人手机号,如果有就要传递,没有就不传
86
+ * @param estimate_trace_id 预估流程ID,从预估结果中获取
87
+ * @param product_category 车型品类标识,从预估结果中获取,传入多个车型时,用英文逗号分割,不要带空格
88
+ * @returns structuredContent.orderId 订单ID,后续查询/取消订单使用
89
+ * @returns structuredContent.status 订单初始状态(created)
90
+ */
91
+ function taxi_create_order(caller_car_phone?: string, estimate_trace_id: string, product_category: string);
92
+
93
+ /**
94
+ * 查看当前可用的网约车车型,请先获取对应地点的经纬度信息,如果有maps_textsearch的tool,优先使用maps_textsearch进行经纬度的获取。
95
+ *
96
+ * @param from_lat 出发纬度,必须从地图相关的工具获取,不能假设
97
+ * @param from_lng 出发经度,必须从地图相关的工具获取,不能假设
98
+ * @param from_name 出发地名称
99
+ * @param to_lat 目的纬度,必须从地图相关的工具获取,不能假设
100
+ * @param to_lng 目的经度,必须从地图相关的工具获取,不能假设
101
+ * @param to_name 目的地名称
102
+ * @returns structuredContent.traceId 预估流程ID,创建订单时必须传入
103
+ * @returns structuredContent.items[] 可用车型列表
104
+ * @returns structuredContent.items[].productName 车型名称
105
+ * @returns structuredContent.items[].productCategory 车型品类代码,创建订单时传入
106
+ * @returns structuredContent.items[].priceText 预估价格(元)
107
+ */
108
+ function taxi_estimate(from_lat: string, from_lng: string, from_name: string, to_lat: string, to_lng: string, to_name: string);
109
+
110
+ /**
111
+ * 根据起点、终点和车型生成打开移动应用或小程序的深度链接,用户点击后将跳转到相应的打车应用完成发单操作
112
+ *
113
+ * @param from_lat 出发纬度,必须从地图相关的工具获取,不能假设
114
+ * @param from_lng 出发经度,必须从地图相关的工具获取,不能假设
115
+ * @param product_category? 车型品类标识列表,从预估结果中获取,支持多个车型,仅当用户明确指定某个或某些品类时才传递此参数,格式为英文逗号,分割
116
+ * @param to_lat 目的地纬度,必须从地图相关的工具获取,不能假设
117
+ * @param to_lng 目的经度,必须从地图相关的工具获取,不能假设
118
+ */
119
+ function taxi_generate_ride_app_link(from_lat: string, from_lng: string, product_category?: string, to_lat: string, to_lng: string);
120
+
121
+ /**
122
+ * 获取打车订单对应司机的实时位置经纬度
123
+ *
124
+ * @param order_id 打车订单ID
125
+ */
126
+ function taxi_get_driver_location(order_id: string);
127
+
128
+ /**
129
+ * 查询打车订单的状态和信息,如司机联系方式、车牌号、预估到达时间
130
+ *
131
+ * ⚠️ 重要:此函数单次调用仅返回当前状态。
132
+ * 单次调用返回当前状态,详见 SKILL.md `### 3.6 查询订单`。
133
+ *
134
+ * @param order_id? 订单ID,从创建订单结果中获取,如果有就要传递,如果没有,会查询当前账号下未完成的订单
135
+ * @returns structuredContent.statusCode 订单状态码(见下表)
136
+ * @returns structuredContent.statusText 状态文本描述
137
+ * @returns structuredContent.driver 司机信息(name/phone/carModel/carPlate),接单后可用
138
+ * @returns structuredContent.map.distanceKm 距离(公里),行程中可用
139
+ * @returns structuredContent.map.eta 预计剩余时间(分钟),行程中可用
140
+ * @returns structuredContent.map.phase 当前阶段:to_pickup(前往上车点)| to_dropoff(前往终点)
141
+ *
142
+ * 订单状态码:
143
+ * 0 匹配中(非终态)
144
+ * 1 司机已接单(非终态)
145
+ * 2 司机已到达(非终态,里程碑通知)
146
+ * 3 未知状态(终态)
147
+ * 4 行程开始(非终态,里程碑通知)
148
+ * 5 订单完成(终态)✅
149
+ * 6 订单已被系统取消(终态)✅
150
+ * 7 订单已被取消(终态)✅
151
+ * 8 未知状态(终态)✅
152
+ * 9 未知状态(终态)✅
153
+ * 10 未知状态(终态)✅
154
+ * 11 客服关闭订单(终态)✅
155
+ * 12 未能完成服务(终态)✅
156
+ */
157
+ function taxi_query_order(order_id?: string);
158
+ ```
159
+
160
+ Examples:
161
+
162
+ ```bash
163
+ # 设置 MCP_URL 变量
164
+ MCP_URL="https://mcp.didichuxing.com/mcp-servers?key=$DIDI_MCP_KEY"
165
+
166
+ # 地址解析(city 建议使用完整行政区名称)
167
+ mcporter call "$MCP_URL" maps_textsearch --args '{"keywords":"望京SOHO","city":"北京市"}'
168
+
169
+ # 价格预估(注意:所有参数值必须加引号,使用字符串格式)
170
+ mcporter call "$MCP_URL" taxi_estimate --args '{"from_lat":"39.9","from_lng":"116.4","from_name":"望京SOHO","to_lat":"39.9","to_lng":"116.4","to_name":"国贸"}'
171
+ ```
@@ -0,0 +1,68 @@
1
+ # 错误处理指南
2
+
3
+ 本文档说明 didi-ride-skill skill 使用过程中可能遇到的错误及解决方案。
4
+
5
+ > `<skill-dir>` 代表 didi-ride-skill 技能的安装根目录(即 SKILL.md 所在目录),可通过 `openclaw skills info didi-ride-skill` 获取。
6
+
7
+ ## 目录
8
+
9
+ - [错误处理指南](#错误处理指南)
10
+ - [目录](#目录)
11
+ - [统一错误码表](#统一错误码表)
12
+ - [API 返回 400 错误](#400-错误排查)
13
+ - [常见问题 (FAQ)](#常见问题-faq)
14
+ - [获取帮助](#获取帮助)
15
+
16
+ ***
17
+
18
+ ## 统一错误码表
19
+
20
+ 所有 MCP 工具返回的统一错误码对照:
21
+
22
+ | 错误码 | 说明 | 解决方案 |
23
+ |--------|------|----------|
24
+ | `-32001` | 命中限流 | 请等待一段时间后重试(配额限制按时间窗口重置) |
25
+ | `-32002` | 鉴权失败(`auth failed`) | Key 存在但无效或已过期,执行 `### 3.9 MCP KEY 与配置` 的引导流程(含发送二维码) |
26
+ | `-32010` | 参数验证失败 | 检查参数格式,确保所有值为字符串 |
27
+ | `-32011` | 订单不存在 | 确认订单ID正确 |
28
+ | `-32021` | 预估结果过期 | 重新调用价格预估获取新的 traceId |
29
+ | `-32030` | 不支持订单类型 | 该类型订单不支持此操作 |
30
+ | `-32031` | 订单未支付 | 订单未进入支付状态 |
31
+ | `-32040` | 订单已经取消过了 | 订单已被取消,无需重复操作 |
32
+ | `-32041` | 订单无法被取消 | 司机已接单或订单已完成,无法通过 API 取消 |
33
+ | `-32050` | 内部错误 | 稍后重试,如持续失败请联系客服 |
34
+ | `-32060` | 支付失败 | 检查支付账户状态或更换支付方式 |
35
+
36
+ ***
37
+
38
+ ## 400 错误排查
39
+
40
+ > 💡 **故障排查**:如果配置后 API 返回 400 错误,请检查:
41
+ > 1. 参数名是否正确(如 `keywords` 而非 `keyword`)
42
+ > 2. 城市名称是否使用完整格式(如 `"北京市"` 而非 `"北京"`)
43
+ > 3. 所有参数值是否为字符串格式(加引号)
44
+
45
+ ***
46
+
47
+ ## 常见问题 (FAQ)
48
+
49
+ **Q: 为什么说"我要上班"没反应?**
50
+ A: 需要先配置 `assets/PREFERENCE.md` 中的家和公司地址,以及上班场景的车型偏好。
51
+
52
+ **Q: 预估价格和实际价格不一致?**
53
+ A: 预估价格为参考值,实际费用以行程完成后为准。
54
+
55
+ **Q: 如何查看历史订单?**
56
+ A: 当前 API 仅支持查询 MCP 渠道未完成订单,历史订单请在滴滴 App 中查看。
57
+
58
+ **Q: 支持哪些城市?**
59
+ A: 支持滴滴服务覆盖的所有中国大陆城市。
60
+
61
+ ***
62
+
63
+ ## 获取帮助
64
+
65
+ 如果以上方案无法解决问题,请:
66
+
67
+ 1. 检查 [workflow.md](./workflow.md) 确认操作流程
68
+ 2. 访问 <https://mcp.didichuxing.com> 获取最新文档