| name | wind-alice |
| description | 调用万得 Alice Agent(A2A 协议,SSE 流式)执行指定 Skill 并获取分析结果的 CLI 工具。当用户要求"用 Alice 跑某个 Skill"、"出一份某公司的调研问题清单"、"做一页纸投资备忘"、"核验一段金融信息"等需要点名 Alice 子 Skill 的场景使用。 |
wind-alice
一个 CLI:把用户问题 + 指定的 Alice Skill(中文或英文名均可) 送到万得 Alice Agent 接口,按 SSE 流式拉取并打印 agentResult.value。
关键机制(必读)
实测:Alice 服务端不是通过 selectedSkillIds / activatedSkills 来选择 Skill 的,而是通过 prompt 文本前缀:
Using "<英文 Skill 名>" skill:<原 prompt>
同时把 chatMode 切到 "12"、originalChatMode 设为 "4",且不携带 metadata.agentCard。本 CLI 已在 buildBody 里封装这套行为;外部只需要传 --skill "<Skill 名>"。
因此:
--skill 同时支持中文名和英文名,不是 id。例如下列写法等价:
--skill "上市公司调研问题清单" (中文 nameZh)
--skill "Stock DD List" (英文 nameEn)
--skill "stock-dd-list" (英文模糊:忽略大小写/空格/-_)
- 命中后 CLI 统一回填英文名拼入文本前缀(服务端按英文识别 Skill)。
- 未在
KNOWN_SKILLS 中登记的名称会以 [warn] 提示,但仍按字面值拼接前缀提交(portal 上新建/改名的 Skill 也能立刻使用)。
何时使用本技能
满足任一条件就用:
- 用户明确说:"用 Alice 跑 / 调 / 执行 …"、"用 Wind 的 XX 技能跑 …"。
- 用户点名 Alice 的某个专业子 Skill(如「上市公司调研问题清单」「公司一页纸」「事实核验」「按主题选股」等)。
- 用户的问题与某个 Skill 的能力高度匹配,且希望走专业链路而不是 auto 路由。
不要用本技能的场景:用户只是普通金融问答、不在意走哪个子 Skill — 让 Alice 自己 auto 路由即可(不传 --skill)。
调用方式(Agent 工作流)
- 拿到用户问题 → 决定 Skill:
- 用户点名 Skill → 直接传该 Skill 的中文名或英文名到
--skill(脚本会自动归一化并回填英文名);
- 用户没点名但问题明显属于某 Skill(如「核查事实」「公司调研问题清单」「财报点评」)→ 可建议并征询后再指定;
- 否则不传
--skill,走 auto。
- 发起调用前用一句话告知用户:Alice 专业 Skill 耗时常为 数分钟到十几分钟(复杂研报、一页纸、可比分析等更久),属正常现象,请耐心等待,不要中途取消命令或重复发起相同请求。
- 先定位本 skill 目录:下面命令里的
scripts/wind-alice.mjs 是相对当前 SKILL.md 所在的 wind-alice 目录。若当前工作目录不是该目录,先 cd 到该目录再执行。
- 执行(任一种写法都可以):
node scripts/wind-alice.mjs --prompt "<USER_QUESTION>" --skill "<中文 Skill 名>"
node scripts/wind-alice.mjs --prompt "<USER_QUESTION>" --skill "<英文 Skill 名>"
- 等流式输出结束后,基于
agentResult.value 汇总回复给用户。等待期间若终端长时间无新输出,仍应继续等至进程退出,勿误判为卡死。
也可以先列已知 Skill 给用户挑:
node scripts/wind-alice.mjs list-skills
一次性配置
- Node.js 18+(自带
fetch)。
- 配置 WIND_API_KEY:
- 可选:
WIND_ALICE_API_URL 覆盖默认接口地址。
安全要求
- 绝不要输出真实
WIND_API_KEY、Bearer token、config.json 内容或 %USERPROFILE%\.wind-aifinmarket\config 内容。
- 若需要说明下载方式,只展示
Authorization: Bearer <WIND_API_KEY> 这种占位格式;不要拼出含真实 Key 的 curl、PowerShell 或 HTTP 示例。
- Alice 返回的报告 URL 可以在当前用户会话中用于交付和下载;写入 README、示例、工单、提交信息等长期材料时使用占位 URL。
文件下载处理
许多 Skill(公司一页纸 / 调研问题清单 / 季报点评 / 市场规模测算 / 可比公司分析 等)的 agentResult.value 末尾会附一个可下载文件链接。
CLI 在每次调用结束时会自动扫描 value 中的可下载文件链接,直接用 WIND_API_KEY 作 Bearer Token 下载到当前工作目录,并把下载结果(已保存路径或失败原因)打到 stderr:
=== 检测到 1 个可下载文件,正在下载到当前目录:<cwd> ===
- <文件名>
已保存:<cwd>\<文件名>
重要事实:
- 文件接口与 Agent 接口 共用同一份
WIND_API_KEY(即万得 AIFin Market 提供的 apiKey),CLI 内部自带 Authorization: Bearer <WIND_API_KEY> 走 HTTP GET 下载。
- 下载目标目录是用户当前命令执行所在目录(
process.cwd());同名文件冲突会自动追加 (1)、 (2) 等后缀,不会覆盖已有文件。
- CLI 不会把 Key 打印到日志;下载结果只出现在 stderr,不会污染 stdout 的
agentResult.value 主体。
- 下载失败(401 / 403 / 网络异常等)只会打印失败原因 + 原始 URL,不影响主流程退出码。
调用结束后无需再向用户解释"如何下载",直接告诉用户文件已保存到哪里即可;只有当 CLI 报"下载失败"时才需要把 URL 与失败原因转告用户排查。
硬性要求
- PowerShell 下读取本文档必须显式使用 UTF-8:例如
Get-Content -Encoding UTF8 skills\wind-alice\SKILL.md;若看到中文乱码,先按 UTF-8 重新读取,不能基于乱码内容执行。
--skill 接受中文或英文 Skill 名(与 KNOWN_SKILLS / portal 一致)。脚本会按 nameEn → nameZh → normalize(nameEn) → normalize(nameZh) 顺序匹配;命中后统一以 nameEn 拼入文本前缀提交,服务端必须看到英文名才识别。中文别名/缩写/口语表述不会自动翻译,请勿擅自意译;不确定时先 list-skills。
- Prompt 必须非空:空白或缺失时直接退出码 2,不发请求。
- 不得把 Key 打印到日志:脚本仅在
Authorization 头里使用,不会输出到 stdout/stderr。
- 流式必须等到结束:CLI 已在父子进程间
await 子进程退出;切勿改成"发完即返"。
- 耗时预期与耐心提示:调用前须提醒用户 Alice Skill 可能较慢;执行中不得因等待过久而中断 CLI、改走其它工具或并行重复调用同一任务。
- 不要凭空构造
selectedSkillIds / agentCard 之类的旧字段去指定 Skill — 已实测不生效,必须走文本前缀。
更新提示处理
每次调用 wind-alice.mjs 后,留意 stderr 是否包含 [wind-skills] 前缀的提示。
- 检测到新版(
检测到新版可用):同一会话首次看到时必须转告用户一次(同会话再次调用不重复);把清单和 升级命令: 那一行完整带给用户。命令是否带 -g 由脚本按 lock 来源自动决定(global 装的带 -g,project 装的不带;Gitee 源会改成 npx skills add ... 重装),直接照搬即可,不要自行加减 -g。
- 检查失败(
检查更新失败)或无法确认(无法确认是否最新):只是更新检查提醒,不影响当前 Alice 调用;同一会话首次看到时简要告知用户一次即可,不可重复提示,也不能当作主调用失败。遇到版本相关错误,可建议用户升级 skill(命令以实际 stderr 输出的 升级命令: 为准)。