当前位置: 首页 > news >正文

开源免费的WPS AI 软件 察元AI文档助手:# 链路 024:getChatApiConfig 与 RIBBON_MODEL_TO_PROVIDER

链路 024:getChatApiConfig 与 RIBBON_MODEL_TO_PROVIDER

总体链路图

下图在全系列各篇保持一致,仅通过高亮样式标示本篇所覆盖的环节;箭头表示主成功路径,点线为异常或可选路径。阅读任意一篇时都应能回到本图定位,避免在单文件里「钻太深」而失去上下游语境。

plain

structured

multimodal

1 入口: Ribbon/对话框 → assistantId

2 startAssistantTask 占位任务

3 launchInfo 与 resolveDocumentInput

4 resolveModel 与模型清单

5 提示词拼装与 launchGuard

6 分流 plain / structured / multimodal

7a chatCompletion 文本链路 plain

7b chatCompletion 结构化批次

8a applyDocumentAction

8b executionPlan → applyDocumentProcessingPlan

7c generateMultimodalAsset

9 评测持久化与任务完成态

异常路径 normalizeError → 安全弹窗

本篇在总体链路中的位置

对应图中 N8a 与 N8b 之下的「网络出口」层:chatApi 对两类分支共用。 高亮节点:N8a、N8b。若本篇同时引用 chatApi 与任务运行器,通常意味着该逻辑处于「编排层与网络层交界」:修改时要同时考虑任务取消与 UI 快照。

深度说明(工程视角)

从工程维护角度看,本篇讨论的对象应当被视为「可替换实现」:只要对外的任务状态、HTTP 契约与文档写回语义保持不变,内部可以重构函数拆分或调整日志字段。阅读时建议始终抓住三个锚点:一是数据从哪来(PluginStorage、localStorage、COM 选区还是全文);二是数据何时离开本机(进入 fetch 之前是否已完成脱敏与快照);三是失败时用户可见的文本由谁归一(chatApi 与助手错误弹窗两条路径)。

就「链路 024:getChatApiConfig 与 RIBBON_MODEL_TO_PROVIDER」而言,源码位置可概括为:chatApi.js getChatApiConfig。这与摘要中的判断一致:当 ribbonModelId 非 composite 形式时,通过 RIBBON_MODEL_TO_PROVIDER 映射到设置中的 provider key,再读 getModelConfig。兼容早期仅保存「展示用模型 id」的配置。关键词「RIBBON_MODEL_TO_PROVIDER、parseModelCompositeId」提示你在仓库内做全文检索时应优先锁定这些符号,而不是仅依赖界面文案。

与网络请求相关的修改,务必在本地用开发者工具或代理核对:请求体中的 model 字段是否与设置页保存的 modelId 一致;Authorization 是否只取 apiKey 列表的第一段(部分网关对多密钥格式敏感);stream 为 true 时宿主是否稳定消费 SSE。若你引入新的 provider,应对照 getChatApiConfigByProvider 的 URL 拼接分支补充单元测试或手测用例,避免「路径已含 v1 却又重复拼接」类错误。

与文档写回相关的修改,应优先在无界面的纯函数层复现:例如仅调用 applyDocumentAction 或 applyDocumentProcessingPlan 的入参快照,观察 Range 坐标是否在 CRLF 归一化前后发生漂移。WPS 与 Word 在选区、批注锚点上的差异会放大这类问题,因此本篇若在讲坐标或分段,请同时阅读 documentPositionUtils 与 chunk 相关教程篇目。

阅读顺序上,本篇之后建议继续看:与 006 resolveModel 产出的 composite id 主路径并存。若在总体图中定位,对应图中 N8a 与 N8b 之下的「网络出口」层:chatApi 对两类分支共用。 遇到与教程系列术语不一致时,以源码标识符为准:教程侧重导航与概念,本系列侧重调用次序与失败面。

最后说明写作立场:本系列不对任何云厂商或模型服务做优劣评价,也不暗示「必须开通」某类账号;所述配置项仅反映当前仓库为打通 OpenAI 兼容协议而需要的最小字段集合。若组织策略禁止外联,应在网关或 hosts 层拦截,而不是在加载项内写死假地址。

与教程系列文档的对照

下列文档来自docs/chayuan-tutorial-series,侧重「如何阅读仓库」与界面侧概念,与本链路系列互补:不重复推销功能,仅帮助建立目录与模块边界。

  • chayuan-tutorial-series/05-shezhi-moxing-yu-gongyingshang-lianlu.md:与本篇链路相邻的工程说明,可对照变量命名与文件职责。
  • chayuan-tutorial-series/18-moxing-fuhe-id-yu-provider-chouxiang.md:与本篇链路相邻的工程说明,可对照变量命名与文件职责。

摘要

当 ribbonModelId 非 composite 形式时,通过 RIBBON_MODEL_TO_PROVIDER 映射到设置中的 provider key,再读 getModelConfig。兼容早期仅保存「展示用模型 id」的配置。

关键词

RIBBON_MODEL_TO_PROVIDER;parseModelCompositeId

链路位置(源码索引)

chatApi.js getChatApiConfig。

正文

1. 旧版解析

parsed 存在时直接转 getChatApiConfigByProvider。

维护时建议把本节涉及的符号在 IDE 里「查找引用」:确认是否还有对话框专用服务、拼写检查服务或评测脚本以拷贝粘贴方式重复了相似逻辑。若发现重复,优先抽到 chatApi 之上的薄封装,而不是在业务层再次拼接 URL 或 Authorization,以降低安全审查时的遗漏面。

// src/utils/chatApi.js 第127-148行exportfunctiongetChatApiConfig(ribbonModelId){if(!ribbonModelId)returnnullconstparsed=parseModelCompositeId(ribbonModelId)if(parsed){returngetChatApiConfigByProvider(parsed.providerId,parsed.modelId)}constprovider=RIBBON_MODEL_TO_PROVIDER[ribbonModelId]||RIBBON_MODEL_TO_PROVIDER[String(ribbonModelId).toLowerCase()]||ribbonModelIdconstconfig=getModelConfig(provider)if(!config||!config.apiUrl?.trim())returnnullconstapiUrl=config.apiUrl.trim().replace(/\/+$/,'')constchatUrl=/\/v\d+$/.test(apiUrl)||apiUrl.includes('qianfan.baidubce.com')?`${apiUrl}/chat/completions`:apiUrl.endsWith('/v1')?`${apiUrl}/chat/completions`:`${apiUrl}/v1/chat/completions`return{apiKey:(config.apiKey||'').trim(),apiUrl:chatUrl,model:ribbonModelId}

上下游衔接

与 006 resolveModel 产出的 composite id 主路径并存。

http://www.jsqmd.com/news/768816/

相关文章:

  • Java十五:封装和接口
  • 不会修图的人,如何用 GPT-Image-2 辅助出图
  • 3倍推理加速!Ultralytics YOLO模型OpenVINO部署架构深度解析
  • OpenMV颜色识别总调不准?可能是你没搞懂LAB颜色空间和阈值设定
  • OpenWrt端口转发不生效?从防火墙规则到IP转发全面排查
  • 普通用户用GPT-Image-2文生图模型,最实用的5个应用
  • Worm-GPT:AI安全攻防视角下的恶意提示工程与LLM滥用防御
  • 2026用GPT-5.5写文章:新手也能快速出稿
  • 基于子孔径的星载斜视条带SAR成像算法研究及实现DSP【附代码】
  • 为AI智能体接入Kagi搜索:提升信息获取质量与效率
  • 从静态站点到开发者门户:深度解析AsyncAPI官网架构与工程实践
  • 会议背景资料自动汇编(使用千问)
  • ActVer Skills:基于MCP协议为AI助手集成GitHub Actions版本管理能力
  • 视频里的PPT怎么一键提取?这款开源神器让你告别手动截图
  • 告别轮询!用LIN总线的事件触发帧优化你的汽车车窗控制(附Arduino模拟代码)
  • QQ音乐解码终极指南:3分钟学会qmcdump解锁加密音频
  • 3个核心技巧彻底优化《鸣潮》体验:从帧率解锁到抽卡分析的终极指南
  • 2026年4月可靠的退磁器品牌口碑推荐,口碑好的退磁器哪家好 - 品牌推荐师
  • 终极免费指南:如何彻底清理macOS应用残留文件
  • 自托管代码片段管理工具CodeFire部署与实战指南
  • 如何让闲置的PS3控制器在Windows上重获新生:DsHidMini完整使用指南
  • 山西医科大学考研辅导班机构选择:排行榜单与哪家好评测 - michalwang
  • 长期使用Taotoken聚合服务对开发运维复杂度的实际降低
  • DownKyi终极指南:5个技巧轻松搞定B站高清视频下载与批量处理
  • 【MIMO通信】神经网络MIMO无线通信全面性能分析【含Matlab源码 15415期】
  • 利用快马平台快速原型腾讯coding plan前端学习项目:待办清单应用
  • MTKClient终极指南:高效解锁联发科设备的底层调试与救砖技术
  • 从零开始使用 Taotoken 和 OpenClaw 搭建自动化工作流体验
  • 全天候守护,主动预警——视程空间VPP SC6N0-IR,重塑工业安全新范式
  • docker-compose 如何安装、使用及快速入门?