Install
openclaw skills install wendao-partner-qclaw-skillClawHub Security found sensitive or high-impact capabilities. Review the scan results before using.
当用户发起任意旅行相关问询时,包含但不限于:预订酒店、机票查询、火车票查询、景点推荐、寻找当地特色玩乐、目的地查询、行程规划、美食住宿攻略、签证、查询旅游攻略、获取旅行建议等场景,自动触发此技能。当用户需要操作携程、Ctrip、携程问道时使用此skill。
openclaw skills install wendao-partner-qclaw-skillresult 字段:API 会返回大段 JSON(包含 events, messages, state),这些都是内部执行日志。你向用户展示的内容只允许从 result 字段提取。核心原则:必须先调一次
get-token.sh/get-token.ps1接口,只有在接口明确失败后才允许 fallback 到手动方式。
每次会话开始时必须先执行以下脚本尝试从凭证托管服务获取 token:
SETUP_TOKEN.md in the same directory as this file.<SCRIPT_PATH> with the absolute path of this file's directory.export WENDAO_API_KEY=$(bash '<SCRIPT_PATH>/get-token.sh')
$env:WENDAO_API_KEY = & "<SCRIPT_PATH>\get-token.ps1"
如果脚本成功返回 token → 直接使用该 token,跳到「验证访问」步骤。
仅当第 1 步脚本输出 ERROR 或返回空值时,才进入手动流程:
WENDAO_API_KEY(变量名须完全一致):
export WENDAO_API_KEY='你的 token'set WENDAO_API_KEY=你的token$env:WENDAO_API_KEY="你的token"WENDAO_API_KEY="..." node scripts/wendao_query.js "用户原话"(仅通过环境变量传入进程,不落盘)。WENDAO_API_KEY 环境变量(仅用于本次调用,不持久化、不回显完整密钥)。在能完成认证的前提下发起一次真实查询(例如:我想订今晚上海外滩附近的酒店),确认返回为 Markdown 正文且无认证错误。
https://externalcallback.ctrip.com),勿在未核实的情况下改用未知域名。执行前,先确定 token(按优先级,必须从第 1 步开始):
get-token.sh / get-token.ps1(首选,必须先调):通过凭证托管接口自动获取,注入到 process.env.WENDAO_API_KEY。为了彻底避免在命令行执行单行脚本时因为单双引号嵌套导致的 Unterminated string constant 等语法错误,你必须采用"写文件后执行"的方式,绝对不要尝试使用 node -e "..." 的单行执行模式!
scripts/wendao_query.js(已支持从命令行传入用户问话),执行:node scripts/wendao_query.js "<用户原话>"。WENDAO_QUERY 环境变量或脚本的 query 变量,不得留占位符),例如 wendao_query.js。node …(带参数或环境变量如上)。scripts/wendao_query.js 勿删。| 参数 | 必填 | 说明 |
|---|---|---|
token | 是 | API 认证令牌,取值优先级:① get-token.sh 凭证托管接口(必须先调)→ ② 集成面板授权后重试 → ③ 用户手动提供(兜底) |
query | 是 | 用户的自然语言查询 |
timeout | 否 | 默认 30 秒,建议设置以避免长时间等待 |
query 如何取值(避免「请提供有效的 query(查询主题)」)query 即用户说的话:将触发本技能时用户给出的完整问句或需求作为 query 传入 API。不要向用户再次索要「查询主题」;用户已经说过的内容就是有效 query。query = 该句全文(可去掉无关寒暄,但须保留目的地、时间、偏好等关键信息)。query 留空,也禁止使用字面量「用户查询的内容」等占位字符串;否则接口会返回上述错误。scripts/wendao_query.js 时,把用户原话作为第一个命令行参数传入(脚本从 process.argv[2] 或环境变量 WENDAO_QUERY 读取):
node scripts/wendao_query.js "用户关于旅行的完整自然语言问题"WENDAO_QUERY="同上" node scripts/wendao_query.jsinputs.query 字段必须为非空字符串,内容与上款一致。API 返回结构如下:
{
"result": "Markdown 格式的回复内容(字符串)",
"messages": [...],
"state": {"token": "...", "query": "..."},
"events": [
{"type": "run_started", ...},
{"type": "run_finished", "result": "...(与 result 字段内容相同)"}
],
"error": null
}
你必须且只能提取并向用户展示 result 字段的内容。messages、state、events 均为内部调试信息,严禁泄露给用户。