DiDi Ride SKILL

中国城市出行服务。当用户表达任何交通出行需求时必须使用此技能——包括打车/叫车/网约车、查价格、路线规划(公交/驾车/步行/骑行)、周边搜索、查询订单/司机位置/取消订单。关键词:"打车"、"叫车"、"去[地点]"、"回家"、"上班"、"下班"、"查价格"、"多少钱"、"路线"、"怎么走"、"步行到"、"附近"、"周边"、"司机"、"订单"、"查询订单"。注意:即使用户未明确说"打车",只要涉及从A地到B地、通勤、或交通方式选择,都应触发。不触发场景:开发打车应用、使用其他导航app、订外卖、查公交时刻表、股票/财报查询。

Audits

Pending

Install

openclaw skills install didi-ride-skill-official

滴滴出行服务 (DiDi Ride Skill)

通过 DiDi MCP Server API 提供打车、查询订单、司机位置、预约叫车、路线规划、周边搜索能力。


1. 快速开始(2 分钟)

1.1 获取 MCP KEY

方式一:用「滴滴出行App」扫码(推荐,最快)

滴滴出行APP扫码获取MCP Key,解锁一键打车

⚠️ Agent 注意:用户客户端无法渲染 Markdown 图片,禁止直接输出上方图片语法。需向用户发送二维码时,执行 ### 3.9 MCP KEY 与配置 中的 openclaw message send 命令发图。

打开滴滴出行 App,扫描二维码,即可快速获取 MCP Key。

方式二:访问官网

访问 https://mcp.didichuxing.com/claw 获取您的 MCP Key。

1.2 配置 Key

方式一:对话中输入(推荐)

直接在对话中告诉我您的 MCP Key,我会帮您配置:

你: 我的 MCP Key 是 xxxxxx

方式二:OpenClaw 配置文件

编辑 ~/.openclaw/openclaw.json,添加:

{
  "skills": {
    "entries": {
      "didi-ride-skill": {
        "enabled": true,
        "apiKey": "你的MCP_KEY"  // apiKey 是 OpenClaw 标准字段名,存储的值就是滴滴平台的 MCP KEY
      }
    }
  }
}

1.3 开始使用

配置完成后,直接对话即可:

你: 打车去北京西站
你: 帮我查一下从国贸到三里屯的路线
你: 查询订单

首次使用时,OpenClaw 会提示安装 mcporter 工具。


2. 用户指南

本 Skill 支持以下操作:

  • 打车:直接说"打车去[地点]"、"回家"、"上班"
  • 查价:查一下从 A 到 B 多少钱
  • 查询订单:输入「查询订单」了解当前订单状态(司机位置、行程进度等)
  • 司机位置:司机在哪里、多久到
  • 预约出行:"15分钟后打个车"、"明天9点去机场"
  • 路线规划:驾车/公交/步行/骑行路线
  • 取消订单:取消当前订单

3. Agent 执行指令

以下内容为 AI 执行参考,用户可忽略。

3.1 文件地图

按需读取以下文件,不要猜测未读过的内容:

文件用途何时读取
SKILL.md触发、主流程、硬性门禁、查询订单规则、预约出行规则每次触发必读
references/workflow.md分阶段详细流程与命令范式需要实现细节时读
references/api_references.mdMCP 函数签名与参数定义每次调用工具前必须核对
references/error_handling.mdcreate_order 失败提示、mcporter 常见错误、统一错误码、参数错误排查、apiKey 占位符泄漏⚠️ 遇到任何调用失败(HTTP error / StatusCode=400 / -32xxx 错误码 / Unknown MCP server / Missing KEY parameter / SSE error: Invalid content type)必须读取此文件
references/setup.md安装 mcporter、配置 MCP KEY 的完整步骤用户询问安装/配置问题时读
assets/PREFERENCE.md地址别名/车型/手机号偏好用户提到别名地址(家、公司、妈妈家等)、车型、手机号,或未明确给出起终点时必须读取。别名匹配规则见执行前检查第 7 条

3.2 执行前检查

  1. 检查 mcporter:若 mcporter 不存在(command not found),停止并引导用户阅读 references/setup.md。没有 mcporter 就无法调用任何 MCP 工具,后续任何流程都无法执行。

  2. 检查 Key:执行 openclaw config get skills.entries.didi-ride-skill.apiKey,若输出为空或非 __OPENCLAW_REDACTED__,按 ### 3.9 MCP KEY 与配置 流程引导。Key 缺失时 mcporter 的报错信息具有误导性,不要尝试绕过。

    • ⚠️ 若 Key 已配置(返回 __OPENCLAW_REDACTED__)但 mcporter 仍报 Missing KEY parameter不是 Key 失效禁止向用户索要 Key。排查步骤见 references/error_handling.md 中的「mcporter Missing KEY parameter」章节。
    • ⚠️ __OPENCLAW_REDACTED__ 是"已配置"哨兵值、不是真实 Key:禁止从 openclaw config get(含 --raw)提取 Key 字面量;URL 中 ?key=... 必须固定用 $DIDI_MCP_KEY。误把哨兵拼进 URL 会触发 SSE error: Invalid content type,详见 error_handling.md 同名章节。
  3. mcporter.json 注意事项:本 skill 使用 URL 直连模式,不依赖 config/mcporter.json禁止创建或修改该文件。如果 mcporter 启动时报 JSON 校验错误(invalid_type / Failed to parse JSON),参见 references/error_handling.md 中的「mcporter.json 校验错误」章节。

  4. mcporter 调用格式(固定写法,不要变形):

MCP_URL="https://mcp.didichuxing.com/mcp-servers?key=$DIDI_MCP_KEY"
mcporter call "$MCP_URL" <tool> --args '{"key":"value"}'

必读注意事项

  • MCP_URL 赋值和 "$MCP_URL" 引用都必须用英文双引号,否则 $DIDI_MCP_KEY 不会被 shell 展开。禁止用单引号或中文引号。
  • 禁止添加 --server 标志(如 --server didi-mcp)。--server 会让 mcporter 去查找已注册的命名 server,找不到直接报 Unknown MCP server;即使找到了也会和 URL 参数冲突导致 Missing tool name
  • 参数名必须核对 references/api_references.md,不要凭记忆。常见致命错误:keyword → 应为 keywordsregion → 应为 cityfrom_lng/from_lat/to_lng/to_lat → 应为 from_name/from_lat/from_lng/to_name/to_lat/to_lng(六字段,不是四字段)。
  • mcporter 对参数错误的报错信息为 backend call failed: ... StatusCode=400不会告诉你具体哪个参数错了),遇到此错误第一反应是核对参数名,详见 references/error_handling.md
  • 遇到不确定的参数名时,执行 mcporter list "$MCP_URL" 可以查看所有工具的完整签名。
  1. 参数值必须加引号(字符串格式),包括经纬度和 product_category 等数字语义字段——API 只接受字符串,否则会报"缺少必填参数"。

  2. 先预估再下单taxi_create_order 依赖 taxi_estimate 返回的 traceId,没有 traceId 下单会失败。traceId 有时效性,过期(-32021 错误)需重新预估。

  3. 起终点处理

    坐标来源:坐标必须来自 maps_textsearch,不要凭空猜测。禁止用对话历史记忆补充起终点——用户可能已换了地方。

    缺失补全(按优先级):① 读 assets/PREFERENCE.md,有地址别名且值非空则按场景推断(早晨→起点"家"、下班→起点"公司";别名行存在但地址为空 = 未配置)→ ② 无可用别名则直接询问用户。

    别名匹配:精确优先——"家"只匹配"家",不匹配"妈妈家";需明确含"妈妈"语义才匹配"妈妈家"。读取时必须扫描整张表格(到下一个 ## 为止),不要只看默认的前两行——用户可能已追加"妈妈家""儿子学校""健身房"等自定义别名。

    确认规则:推断的起终点、或 maps_textsearch 返回多个候选时,必须在主流程 step 2 向用户确认;用户明确指定且精确匹配的地点无需确认。

  4. taxi_create_order 参数约束

  • 只接受三个字段:estimate_trace_idproduct_categorycaller_car_phone(可选)
  • taxi_create_ordercaller_car_phone 未由用户提供时,从 assets/PREFERENCE.md 的「默认偏好」表读取;都没有就不传该参数,禁止在对话中反复向用户索要手机号——skill 级别已允许没有手机号直接发单,口头询问一次若用户未答应即视为"用默认/不传"。
  • 不要把 taxi_estimate 的坐标/名称字段(from_lat / from_lng / from_name / to_lat / to_lng / to_name)带入。

3.3 用户确认策略

场景规则
打车(实时/预约)推断的地址或搜索返回多个候选时必须确认起终点(见主流程 step 2),用户明确指定且精确匹配时无需确认,确认后再预估下单
取消订单即使用户说了"取消订单",仍必须先明确询问"确认取消吗?",等用户回复确认后才能调用 taxi_cancel_order。用户的取消意图 ≠ 取消确认。

3.4 主流程(最小可执行)

  1. 地址解析:maps_textsearch(必要时结合 assets/PREFERENCE.md,按执行前检查第 7 条处理)。
  2. 确认起终点:
    • 单一精确匹配(用户描述明确 + maps_textsearch 仅返回 1 个结果)→ 无需确认,直接使用;
    • 多个候选maps_textsearch 返回 ≥2 个同名或近似地点)→ 必须列出至少前 3 个候选供用户选择(如"搜索到以下万达广场:1) 朝阳CBD店 2) 石景山店 3) 通州店,请问您要去哪个?"),不要自行代选或只展示一个
    • 别名推断(从 PREFERENCE.md 推断的起终点)→ 向用户确认 + 告知推断来源(如"按偏好里「家」推断终点是望京 SOHO,对吗?");
    • 用户明确指定且文本精确匹配的地点 → 无需确认。用户纠正则按纠正内容重新解析。
  3. 价格预估:taxi_estimate,记录 traceId
  4. 车型决策(优先级:当前消息 > 偏好 > 询问用户):
    • 用户在当前消息中明确指定车型(如"叫快车""帮我叫专车")→ 在 taxi_estimate 返回列表中精确匹配对应 productCategory(快车=1,专车=8),覆盖一切偏好设置;
    • 用户未指定 → 使用 assets/PREFERENCE.md 中场景车型偏好的精确 productCategory 值;
    • 偏好也未配置 → 向用户询问车型,不要自行推荐;
    • 注意:快车(1)和特惠快车(201)是不同服务等级,不可因价格更优而自动替换;
    • 可用车型以 taxi_estimate API 返回为准。若不包含指定/偏好的 productCategory,向用户说明并让其重新选择,不要默默用近似车型替代。
    • 简化原则(尤其对 reasoning 模型):用户在当前消息中说什么车型就用什么,不要进一步质疑或反复确认;偏好缺失时直接向用户问一次即可,不要在同一轮列出多个权衡选项让用户挑。规则很短,不要过度展开思考分支。
  5. 创建订单:taxi_create_order(使用最新 traceId)。
    • 若此调用返回 Streamable HTTP error: Unexpected content type: text/plain立即停止流程,按 references/error_handling.md 的「taxi_create_order 调用失败」章节向用户输出固定文案。禁止重试、禁止切换 Key、禁止跳过此步继续往下。
  6. 结果输出:给出订单号、起终点、车型、预估价,末尾提示 💡 发送「查询订单」可了解当前订单状态,并告知 ⏱️ 将在 5 分钟后自动为您回查订单状态
  7. ⚠️ 自动回查(必做):根据 ### 3.8 发单后自动回查 中的 cron 指令内容,创建定时任务,参数信息严格遵循章节内要求。此步不可省略。

3.5 偏好设置更新

当用户要求设置/记住/记一下/帮我记/保存地址别名、车型偏好或手机号时,必须通过文件编辑工具(Edit / Write)修改 assets/PREFERENCE.md 对应的 markdown 表格行。严禁仅以文字回复"记住了/已保存"而不调用文件编辑工具——偏好必须落盘到文件,口头承诺无效。

执行步骤

  1. Read 读取 assets/PREFERENCE.md 完整内容(注意表格可能已有用户追加的行);
  2. 定位要更新的表格行(地址别名表 / 场景车型偏好表 / 默认偏好表);
  3. 对地址别名:先调用 maps_textsearch 获取坐标,再更新表格行;
  4. 调用 Edit(替换单行)或 Write(整表重写)写入新值;
  5. 回读验证:再次 Read 确认新值已落盘。若未成功,告知用户并重试。
  • 地址别名("我家在…"、"公司在…"、"儿子的学校是…"、"妈妈家在…"):先调用 maps_textsearch 解析地址获取坐标,然后更新「地址别名」表——已有别名更新对应行,新别名追加新行。别名由用户定义,不限于"家""公司"。
  • 场景车型("上班用快车"、"下班用特惠和快车"):更新「场景车型偏好」表对应行。品类代码参考表底注释,多车型用英文逗号分隔(如 1,201)。
  • 叫车手机号("我的手机号是…"):更新「默认偏好」表中的叫车手机号行。
  • 创建订单时:若 PREFERENCE.md 中配置了叫车手机号,将其作为 caller_car_phone 参数传入 taxi_create_ordercaller_car_phone 为可选参数,若未配置则不传。

3.6 查询订单

触发词:查询订单 / 查询订单 <orderId>

订单号来源(优先级从高到低):

  1. 用户消息中明确给出;
  2. 当前对话上下文中最近一次创建的订单号;
  3. 以上均无时,向用户询问。

调用命令:

MCP_URL="https://mcp.didichuxing.com/mcp-servers?key=$DIDI_MCP_KEY"
mcporter call "$MCP_URL" taxi_query_order --args '{"order_id":"ORDER_ID"}'

3.6.1 状态码与输出规则

code含义必须输出
0匹配中⏳ 正在为您匹配司机,请稍候
1司机已接单必须展示:司机姓名、车型、车牌、电话;距上车点距离和预计到达时间
2司机已到达🔔 司机已到达上车点,请前往上车
4行程进行中🚗 行程已开始
5订单完成✅ 行程结束,展示费用(如有)
6订单已被系统取消❌ 订单已被系统取消
7订单已被取消❌ 订单已取消
3/8-12其他终态显示对应状态描述

3.7 预约出行规则

当用户要求在特定时间叫车(如"15分钟后"、"明天9点"):

  • 使用 cron 一次性任务(--at),到点由 isolated agent 独立执行完整打车流程;
  • ⚠️ --message 必须包含完整起终点(带城市前缀)和车型,isolated session 无历史上下文。起点或终点缺失时先从 assets/PREFERENCE.md 推断并向用户确认,推断不了则必须先询问用户,不要自行推断未知信息
  • 到点后 agent 自行执行:地址解析 → 价格预估(获取最新 traceId)→ 创建订单;
  • 如果无法获取当前会话的 metadata(channel/chat_id),仅跳过 cron 创建步骤,其余流程(地址解析 → 价格预估 → 展示结果)正常执行不受影响。在回复中提醒用户到时手动发消息叫车。metadata 不可用 ≠ 放弃整个打车流程;
  • 如果定时任务创建失败,必须在回复中提示用户,不能默默失败。
# ⚠️ 占位符替换规则:所有 <XXX> 形式都是占位符,必须替换为真实值;
#    禁止保留 <> 字面、禁止当成 shell 变量加 $(不是 $TIME / $CHAT_ID)。
#   <FROM_NAME>    → 带城市前缀的起点全称(如"北京市西二旗地铁站")
#   <TO_NAME>      → 带城市前缀的终点全称(如"北京市佰嘉城小区")
#   <VEHICLE>      → 车型(如"快车")
#   <TIME>         → 见下方时间规则(如 "10m" / "2h" / ISO 时间)
#   <CHANNEL_NAME> → 当前会话 metadata 中的 channel 字段(如 feishu、telegram),命令行参数不带引号;不可用 last
#   <CHAT_ID>      → 当前会话 metadata 中的 chat_id 字段

openclaw cron add \
  --name "didi-ride-skill:$(date +%s)" \
  --at "<TIME>" \
  --session isolated \
  --message "执行定时打车:起点「<FROM_NAME>」,终点「<TO_NAME>」,车型「<VEHICLE>」。请完整执行打车流程:地址解析 → 价格预估(获取最新 traceId)→ 创建订单。订单创建成功后,输出订单信息并提示用户可发送「查询订单」了解订单状态,同时创建 5 分钟后自动回查 cron(模板见 SKILL.md 第 3.8 节「发单后自动回查」)。" \
  --announce \
  --channel <CHANNEL_NAME> \
  --to "<CHAT_ID>"

3.7.1 TIME 填写规则

场景写法示例
相对时间(X 分钟/小时后)duration 格式15m / 2h / 1h30m
绝对时间(具体时刻)本地时区 ISO 格式$(date -d '明天 09:00' '+%Y-%m-%dT%H:%M:%S+08:00')
  • 相对时间(如 15m)无需格式化,直接使用
  • 绝对时间使用带时区的 ISO 8601 格式:YYYY-MM-DDTHH:MM:SS+08:00(北京时间东八区)

系统兼容性说明:

  • Linux (GNU date): date -d '明天 09:00' '+%Y-%m-%dT%H:%M:%S+08:00'
  • macOS (BSD date): TZ=Asia/Shanghai date -j -v+1d -f '%H:%M' '09:00' '+%Y-%m-%dT%H:%M:%S+08:00'

3.8 发单后自动回查

发单成功后(实时单或预约单),根据本章节下文 "openclaw cron add" 命令,创建 cron 任务,务必按照本章节下文bash命令参数设置。

  • 如果无法获取当前会话的 metadata(channel/chat_id),仅跳过 cron 创建步骤,主流程正常完成(已出单则告知用户"5 分钟后可发送'查询订单'了解最新状态")。
  • 如果定时任务创建失败(命令本身报错),必须在回复中提示用户,不能默默失败。
# ⚠️ 占位符替换规则:所有 <XXX> 形式都是占位符,必须替换为真实值,禁止保留 <> 字面或加 $ 当 shell 变量。
#   <ORDER_ID>     → 实际订单号(taxi_create_order 返回)
#   <CHANNEL_NAME> / <CHAT_ID> → 同 §3.7,从会话 metadata 读取或用兜底值

openclaw cron add \
  --name "didi-ride-skill:check:<ORDER_ID>" \
  --at "5m" \
  --session isolated \
  --message "查询滴滴订单状态:订单号 <ORDER_ID>。调用 taxi_query_order 查询并输出当前状态。如果司机已接单,输出司机姓名、车型、车牌、电话及预计到达时间;如果仍在匹配中,提示用户耐心等待。" \
  --announce \
  --channel <CHANNEL_NAME> \
  --to "<CHAT_ID>"

3.9 MCP KEY 与配置

术语说明:滴滴平台称此凭证为「MCP KEY」,OpenClaw 配置字段统一叫 apiKey,注入后的环境变量为 DIDI_MCP_KEY——三者是同一个值。通过 openclaw config set 持久化后,OpenClaw 在每次 agent run 启动时自动注入为环境变量。

3.9.1 检查 Key 状态

# 仅用于判断 DIDI_MCP_KEY 是否已配置;输出不是 Key 值,不可代入 URL
openclaw config get skills.entries.didi-ride-skill.apiKey

结果输出为空 = 未配置;输出 __OPENCLAW_REDACTED__ = 已配置,必须用环境变量 $DIDI_MCP_KEY 拼接 URL。

⚠️ openclaw config get(含 --raw)永远不返回真实 Key——任何把哨兵值拼入 URL/header/参数的请求都会失败,见 error_handling.md「SSE error / apiKey 占位符泄漏」。

3.9.2 持久化用户 Key

⚠️ 当用户回复了 Key(如"我的 Key 是 xxxxxx"),必须执行以下命令持久化 & 在当前 Shell 生效:

#   YOUR_KEY → 实际的 MCP KEY
openclaw config set 'skills.entries.didi-ride-skill.apiKey' 'YOUR_KEY'
export DIDI_MCP_KEY='YOUR_KEY'
  • 持久化后 OpenClaw 在所有后续 agent run(含 cron isolated session)中自动注入 DIDI_MCP_KEY
  • ⚠️⚠️⚠️ 命令输出 "Restart the gateway to apply." ——这是通用提示,必须忽略,禁止执行 restartapiKey 每次 agent run 动态读取,无需重启;强制重启会导致网关崩溃

3.9.3 Key 缺失或鉴权失败

⚠️ Key 未配置 MCP 返回鉴权失败(error.code: -32002)时,依次执行:

  1. 发送二维码图片({CHAT_ID} → metadata 的 chat_id,{CHANNEL_NAME} → metadata 的 channel):
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,解锁一键打车"
  1. 输出文字:

您还没有配置 DIDI_MCP_KEY 或 Key 已失效,请访问 滴滴MCP平台 获取 MCP KEY,然后配置环境变量或在 OpenClaw 配置文件中设置。

3.10 工具清单

领域工具
地图maps_textsearch, maps_regeocode
路线maps_direction_driving, maps_direction_transit, maps_direction_walking, maps_direction_bicycling
周边maps_place_around
打车taxi_estimate(预估), taxi_create_order(下单), taxi_query_order(查单+司机位置), taxi_cancel_order(取消)