@jsonstudio/rcc 0.89.1205 → 0.89.1457

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 (391) hide show
  1. package/README.md +53 -1412
  2. package/configsamples/config.json +426 -0
  3. package/configsamples/config.reference.json +58 -0
  4. package/configsamples/provider/crs/config.v1.json +46 -0
  5. package/configsamples/provider/glm/config.v1.json +81 -0
  6. package/configsamples/provider/glm-anthropic/config.v1.json +45 -0
  7. package/configsamples/provider/iflow/config.v1.json +74 -0
  8. package/configsamples/provider/kimi/config.v1.json +41 -0
  9. package/configsamples/provider/lmstudio/config.v1.json +101 -0
  10. package/configsamples/provider/mimo/config.v1.json +35 -0
  11. package/configsamples/provider/modelscope/config.v1.json +96 -0
  12. package/configsamples/provider/qwen/config.v1.json +38 -0
  13. package/configsamples/provider/tab/config.v1.json +50 -0
  14. package/configsamples/provider/tabglm/config.v1.json +49 -0
  15. package/dist/build-info.js +2 -2
  16. package/dist/cli/commands/code.js +12 -6
  17. package/dist/cli/commands/code.js.map +1 -1
  18. package/dist/cli/commands/config.d.ts +2 -1
  19. package/dist/cli/commands/config.js +77 -103
  20. package/dist/cli/commands/config.js.map +1 -1
  21. package/dist/cli/commands/examples.js +6 -6
  22. package/dist/cli/commands/examples.js.map +1 -1
  23. package/dist/cli/commands/init.d.ts +28 -0
  24. package/dist/cli/commands/init.js +94 -0
  25. package/dist/cli/commands/init.js.map +1 -0
  26. package/dist/cli/commands/port.js +10 -2
  27. package/dist/cli/commands/port.js.map +1 -1
  28. package/dist/cli/commands/restart.js +5 -2
  29. package/dist/cli/commands/restart.js.map +1 -1
  30. package/dist/cli/commands/start.js +25 -22
  31. package/dist/cli/commands/start.js.map +1 -1
  32. package/dist/cli/commands/status.js +1 -0
  33. package/dist/cli/commands/status.js.map +1 -1
  34. package/dist/cli/commands/stop.js +1 -0
  35. package/dist/cli/commands/stop.js.map +1 -1
  36. package/dist/cli/config/bundled-docs.d.ts +20 -0
  37. package/dist/cli/config/bundled-docs.js +91 -0
  38. package/dist/cli/config/bundled-docs.js.map +1 -0
  39. package/dist/cli/config/init-config.d.ts +37 -0
  40. package/dist/cli/config/init-config.js +212 -0
  41. package/dist/cli/config/init-config.js.map +1 -0
  42. package/dist/cli/config/init-provider-catalog.d.ts +8 -0
  43. package/dist/cli/config/init-provider-catalog.js +187 -0
  44. package/dist/cli/config/init-provider-catalog.js.map +1 -0
  45. package/dist/cli/register/init-command.d.ts +3 -0
  46. package/dist/cli/register/init-command.js +5 -0
  47. package/dist/cli/register/init-command.js.map +1 -0
  48. package/dist/cli.js +28 -3
  49. package/dist/cli.js.map +1 -1
  50. package/dist/client/gemini/gemini-protocol-client.js +2 -1
  51. package/dist/client/gemini/gemini-protocol-client.js.map +1 -1
  52. package/dist/client/gemini-cli/gemini-cli-protocol-client.js +40 -16
  53. package/dist/client/gemini-cli/gemini-cli-protocol-client.js.map +1 -1
  54. package/dist/client/openai/chat-protocol-client.js +2 -1
  55. package/dist/client/openai/chat-protocol-client.js.map +1 -1
  56. package/dist/client/responses/responses-protocol-client.js +2 -1
  57. package/dist/client/responses/responses-protocol-client.js.map +1 -1
  58. package/dist/config/risk-control-config.d.ts +94 -0
  59. package/dist/config/risk-control-config.js +196 -0
  60. package/dist/config/risk-control-config.js.map +1 -0
  61. package/dist/constants/index.d.ts +6 -0
  62. package/dist/constants/index.js +13 -0
  63. package/dist/constants/index.js.map +1 -1
  64. package/dist/docs/daemon-admin-ui.html +2113 -190
  65. package/dist/error-handling/quiet-error-handling-center.js +46 -8
  66. package/dist/error-handling/quiet-error-handling-center.js.map +1 -1
  67. package/dist/index.js +0 -1
  68. package/dist/index.js.map +1 -1
  69. package/dist/manager/modules/health/index.d.ts +1 -1
  70. package/dist/manager/modules/quota/antigravity-quota-manager.d.ts +70 -0
  71. package/dist/manager/modules/quota/antigravity-quota-manager.js +442 -0
  72. package/dist/manager/modules/quota/antigravity-quota-manager.js.map +1 -0
  73. package/dist/manager/modules/quota/index.d.ts +3 -127
  74. package/dist/manager/modules/quota/index.js +2 -1093
  75. package/dist/manager/modules/quota/index.js.map +1 -1
  76. package/dist/manager/modules/quota/provider-key-normalization.d.ts +3 -0
  77. package/dist/manager/modules/quota/provider-key-normalization.js +155 -0
  78. package/dist/manager/modules/quota/provider-key-normalization.js.map +1 -0
  79. package/dist/manager/modules/quota/provider-quota-daemon.cooldown.d.ts +9 -0
  80. package/dist/manager/modules/quota/provider-quota-daemon.cooldown.js +115 -0
  81. package/dist/manager/modules/quota/provider-quota-daemon.cooldown.js.map +1 -0
  82. package/dist/manager/modules/quota/provider-quota-daemon.d.ts +77 -0
  83. package/dist/manager/modules/quota/provider-quota-daemon.events.d.ts +12 -0
  84. package/dist/manager/modules/quota/provider-quota-daemon.events.js +239 -0
  85. package/dist/manager/modules/quota/provider-quota-daemon.events.js.map +1 -0
  86. package/dist/manager/modules/quota/provider-quota-daemon.js +404 -0
  87. package/dist/manager/modules/quota/provider-quota-daemon.js.map +1 -0
  88. package/dist/manager/modules/quota/provider-quota-daemon.model-backoff.d.ts +11 -0
  89. package/dist/manager/modules/quota/provider-quota-daemon.model-backoff.js +192 -0
  90. package/dist/manager/modules/quota/provider-quota-daemon.model-backoff.js.map +1 -0
  91. package/dist/manager/modules/quota/provider-quota-daemon.snapshot.d.ts +8 -0
  92. package/dist/manager/modules/quota/provider-quota-daemon.snapshot.js +96 -0
  93. package/dist/manager/modules/quota/provider-quota-daemon.snapshot.js.map +1 -0
  94. package/dist/manager/modules/quota/provider-quota-daemon.view.d.ts +19 -0
  95. package/dist/manager/modules/quota/provider-quota-daemon.view.js +37 -0
  96. package/dist/manager/modules/quota/provider-quota-daemon.view.js.map +1 -0
  97. package/dist/manager/modules/routing/index.d.ts +1 -0
  98. package/dist/manager/modules/routing/index.js +11 -25
  99. package/dist/manager/modules/routing/index.js.map +1 -1
  100. package/dist/manager/quota/provider-quota-center.d.ts +2 -0
  101. package/dist/manager/quota/provider-quota-center.js +80 -82
  102. package/dist/manager/quota/provider-quota-center.js.map +1 -1
  103. package/dist/modules/llmswitch/bridge.d.ts +16 -18
  104. package/dist/modules/llmswitch/bridge.js +293 -94
  105. package/dist/modules/llmswitch/bridge.js.map +1 -1
  106. package/dist/modules/llmswitch/core-loader.d.ts +4 -2
  107. package/dist/modules/llmswitch/core-loader.js +32 -20
  108. package/dist/modules/llmswitch/core-loader.js.map +1 -1
  109. package/dist/modules/pipeline/utils/colored-logger.js +3 -2
  110. package/dist/modules/pipeline/utils/colored-logger.js.map +1 -1
  111. package/dist/modules/pipeline/utils/debug-logger.js +1 -1
  112. package/dist/modules/pipeline/utils/debug-logger.js.map +1 -1
  113. package/dist/providers/auth/antigravity-userinfo-helper.d.ts +2 -1
  114. package/dist/providers/auth/antigravity-userinfo-helper.js +25 -4
  115. package/dist/providers/auth/antigravity-userinfo-helper.js.map +1 -1
  116. package/dist/providers/auth/iflow-cookie-auth.js +0 -2
  117. package/dist/providers/auth/iflow-cookie-auth.js.map +1 -1
  118. package/dist/providers/auth/oauth-lifecycle.js +2 -23
  119. package/dist/providers/auth/oauth-lifecycle.js.map +1 -1
  120. package/dist/providers/auth/tokenfile-auth.d.ts +2 -0
  121. package/dist/providers/auth/tokenfile-auth.js +33 -1
  122. package/dist/providers/auth/tokenfile-auth.js.map +1 -1
  123. package/dist/providers/core/config/camoufox-launcher.d.ts +5 -0
  124. package/dist/providers/core/config/camoufox-launcher.js +40 -4
  125. package/dist/providers/core/config/camoufox-launcher.js.map +1 -1
  126. package/dist/providers/core/config/service-profiles.js +7 -18
  127. package/dist/providers/core/config/service-profiles.js.map +1 -1
  128. package/dist/providers/core/runtime/antigravity-quota-client.js +6 -3
  129. package/dist/providers/core/runtime/antigravity-quota-client.js.map +1 -1
  130. package/dist/providers/core/runtime/base-provider.d.ts +2 -7
  131. package/dist/providers/core/runtime/base-provider.js +84 -165
  132. package/dist/providers/core/runtime/base-provider.js.map +1 -1
  133. package/dist/providers/core/runtime/gemini-cli-http-provider.d.ts +7 -0
  134. package/dist/providers/core/runtime/gemini-cli-http-provider.js +368 -97
  135. package/dist/providers/core/runtime/gemini-cli-http-provider.js.map +1 -1
  136. package/dist/providers/core/runtime/http-request-executor.d.ts +3 -0
  137. package/dist/providers/core/runtime/http-request-executor.js +110 -38
  138. package/dist/providers/core/runtime/http-request-executor.js.map +1 -1
  139. package/dist/providers/core/runtime/http-transport-provider.d.ts +17 -0
  140. package/dist/providers/core/runtime/http-transport-provider.js +165 -16
  141. package/dist/providers/core/runtime/http-transport-provider.js.map +1 -1
  142. package/dist/providers/core/runtime/provider-error-classifier.js +10 -0
  143. package/dist/providers/core/runtime/provider-error-classifier.js.map +1 -1
  144. package/dist/providers/core/runtime/provider-factory.js +7 -5
  145. package/dist/providers/core/runtime/provider-factory.js.map +1 -1
  146. package/dist/providers/core/runtime/provider-runtime-metadata.d.ts +6 -0
  147. package/dist/providers/core/runtime/provider-runtime-metadata.js.map +1 -1
  148. package/dist/providers/core/runtime/rate-limit-manager.d.ts +1 -12
  149. package/dist/providers/core/runtime/rate-limit-manager.js +4 -77
  150. package/dist/providers/core/runtime/rate-limit-manager.js.map +1 -1
  151. package/dist/providers/core/runtime/responses-provider.d.ts +1 -7
  152. package/dist/providers/core/runtime/responses-provider.js +12 -93
  153. package/dist/providers/core/runtime/responses-provider.js.map +1 -1
  154. package/dist/providers/core/strategies/oauth-auth-code-flow.js +12 -8
  155. package/dist/providers/core/strategies/oauth-auth-code-flow.js.map +1 -1
  156. package/dist/providers/core/utils/http-client.js +36 -46
  157. package/dist/providers/core/utils/http-client.js.map +1 -1
  158. package/dist/providers/core/utils/provider-error-logger.d.ts +1 -1
  159. package/dist/providers/core/utils/provider-error-reporter.d.ts +3 -1
  160. package/dist/providers/core/utils/provider-error-reporter.js +3 -0
  161. package/dist/providers/core/utils/provider-error-reporter.js.map +1 -1
  162. package/dist/providers/core/utils/snapshot-writer.js +1 -4
  163. package/dist/providers/core/utils/snapshot-writer.js.map +1 -1
  164. package/dist/providers/mock/mock-provider-runtime.js +57 -27
  165. package/dist/providers/mock/mock-provider-runtime.js.map +1 -1
  166. package/dist/scripts/camoufox/launch-auth.mjs +193 -58
  167. package/dist/server/handlers/handler-utils.js +8 -3
  168. package/dist/server/handlers/handler-utils.js.map +1 -1
  169. package/dist/server/handlers/responses-handler.js +1 -1
  170. package/dist/server/handlers/responses-handler.js.map +1 -1
  171. package/dist/server/runtime/http-server/daemon-admin/auth-handler.d.ts +2 -0
  172. package/dist/server/runtime/http-server/daemon-admin/auth-handler.js +103 -0
  173. package/dist/server/runtime/http-server/daemon-admin/auth-handler.js.map +1 -0
  174. package/dist/server/runtime/http-server/daemon-admin/auth-session.d.ts +5 -0
  175. package/dist/server/runtime/http-server/daemon-admin/auth-session.js +77 -0
  176. package/dist/server/runtime/http-server/daemon-admin/auth-session.js.map +1 -0
  177. package/dist/server/runtime/http-server/daemon-admin/auth-store.d.ts +18 -0
  178. package/dist/server/runtime/http-server/daemon-admin/auth-store.js +89 -0
  179. package/dist/server/runtime/http-server/daemon-admin/auth-store.js.map +1 -0
  180. package/dist/server/runtime/http-server/daemon-admin/credentials-handler.js +1 -2
  181. package/dist/server/runtime/http-server/daemon-admin/credentials-handler.js.map +1 -1
  182. package/dist/server/runtime/http-server/daemon-admin/providers-handler.js +226 -24
  183. package/dist/server/runtime/http-server/daemon-admin/providers-handler.js.map +1 -1
  184. package/dist/server/runtime/http-server/daemon-admin/quota-handler.js +47 -8
  185. package/dist/server/runtime/http-server/daemon-admin/quota-handler.js.map +1 -1
  186. package/dist/server/runtime/http-server/daemon-admin/restart-handler.js +1 -1
  187. package/dist/server/runtime/http-server/daemon-admin/restart-handler.js.map +1 -1
  188. package/dist/server/runtime/http-server/daemon-admin/stats-handler.js +1 -1
  189. package/dist/server/runtime/http-server/daemon-admin/stats-handler.js.map +1 -1
  190. package/dist/server/runtime/http-server/daemon-admin/status-handler.js +68 -4
  191. package/dist/server/runtime/http-server/daemon-admin/status-handler.js.map +1 -1
  192. package/dist/server/runtime/http-server/daemon-admin-routes.d.ts +3 -4
  193. package/dist/server/runtime/http-server/daemon-admin-routes.js +9 -14
  194. package/dist/server/runtime/http-server/daemon-admin-routes.js.map +1 -1
  195. package/dist/server/runtime/http-server/executor-metadata.js +1 -1
  196. package/dist/server/runtime/http-server/executor-metadata.js.map +1 -1
  197. package/dist/server/runtime/http-server/executor-response.js +0 -16
  198. package/dist/server/runtime/http-server/executor-response.js.map +1 -1
  199. package/dist/server/runtime/http-server/hub-shadow-compare.js +110 -34
  200. package/dist/server/runtime/http-server/hub-shadow-compare.js.map +1 -1
  201. package/dist/server/runtime/http-server/index.d.ts +5 -3
  202. package/dist/server/runtime/http-server/index.js +281 -136
  203. package/dist/server/runtime/http-server/index.js.map +1 -1
  204. package/dist/server/runtime/http-server/middleware.js +19 -1
  205. package/dist/server/runtime/http-server/middleware.js.map +1 -1
  206. package/dist/server/runtime/http-server/request-executor.js +59 -24
  207. package/dist/server/runtime/http-server/request-executor.js.map +1 -1
  208. package/dist/server/runtime/http-server/routes.js +12 -3
  209. package/dist/server/runtime/http-server/routes.js.map +1 -1
  210. package/dist/server/runtime/http-server/session-dir.d.ts +2 -0
  211. package/dist/server/runtime/http-server/session-dir.js +59 -0
  212. package/dist/server/runtime/http-server/session-dir.js.map +1 -0
  213. package/dist/server/runtime/http-server/types.d.ts +0 -4
  214. package/dist/server/utils/utf8-chunk-buffer.js +6 -3
  215. package/dist/server/utils/utf8-chunk-buffer.js.map +1 -1
  216. package/dist/server/utils/warmup-storm-tracker.js +1 -1
  217. package/dist/server/utils/warmup-storm-tracker.js.map +1 -1
  218. package/dist/server-factory.d.ts +6 -28
  219. package/dist/server-factory.js +8 -93
  220. package/dist/server-factory.js.map +1 -1
  221. package/dist/token-daemon/index.js +2 -2
  222. package/dist/token-daemon/index.js.map +1 -1
  223. package/dist/token-daemon/provider-registry.js +0 -1
  224. package/dist/token-daemon/provider-registry.js.map +1 -1
  225. package/dist/token-daemon/server-utils.js +8 -9
  226. package/dist/token-daemon/server-utils.js.map +1 -1
  227. package/dist/token-daemon/token-utils.js +1 -1
  228. package/dist/token-daemon/token-utils.js.map +1 -1
  229. package/dist/tools/semantic-replay.js +2 -2
  230. package/dist/tools/semantic-replay.js.map +1 -1
  231. package/dist/tools/stats-request-events.d.ts +1 -1
  232. package/dist/tools/stats-usage.js +6 -3
  233. package/dist/tools/stats-usage.js.map +1 -1
  234. package/dist/utils/llms-engine-shadow.d.ts +19 -0
  235. package/dist/utils/llms-engine-shadow.js +209 -0
  236. package/dist/utils/llms-engine-shadow.js.map +1 -0
  237. package/dist/utils/runtime-versions.js +2 -1
  238. package/dist/utils/runtime-versions.js.map +1 -1
  239. package/dist/utils/strip-internal-keys.d.ts +12 -0
  240. package/dist/utils/strip-internal-keys.js +28 -0
  241. package/dist/utils/strip-internal-keys.js.map +1 -0
  242. package/docs/ARCHITECTURE.md +402 -0
  243. package/docs/CHAT_PROCESS_PROTOCOL_AND_PIPELINE.md +221 -0
  244. package/docs/CODEX_AND_CLAUDE_CODE.md +69 -0
  245. package/docs/CONFIG_ARCHITECTURE.md +517 -0
  246. package/docs/ERROR_HANDLING_AUDIT.md +0 -0
  247. package/docs/GCLI2API_PARITY_GAPS.md +98 -0
  248. package/docs/INSTALLATION_AND_QUICKSTART.md +74 -0
  249. package/docs/INSTRUCTION_MARKUP.md +89 -0
  250. package/docs/MODULE_ENHANCEMENT_SYSTEM.md +666 -0
  251. package/docs/PORTS.md +36 -0
  252. package/docs/PROVIDERS_BUILTIN.md +111 -0
  253. package/docs/PROVIDER_TYPES.md +55 -0
  254. package/docs/SERVERTOOL_CLOCK_DESIGN.md +233 -0
  255. package/docs/USAGE_HANDLING_ANALYSIS.md +335 -0
  256. package/docs/USER_CONFIG_PARSER_CHANGES.md +175 -0
  257. package/docs/V3_INBOUND_OUTBOUND_DESIGN.md +86 -0
  258. package/docs/VIRTUAL_ROUTER_PRIORITY_AND_HEALTH.md +125 -0
  259. package/docs/anthropic-request-golden-samples.md +50 -0
  260. package/docs/antigravity-gemini-format-cleanup.md +102 -0
  261. package/docs/antigravity-routing-contract.md +31 -0
  262. package/docs/ccr-alignment-enhancetool.md +105 -0
  263. package/docs/chat-glm-500-analysis.md +79 -0
  264. package/docs/chat-request-golden-samples.md +42 -0
  265. package/docs/chat-semantic-expansion-plan.md +84 -0
  266. package/docs/cli-command-inventory.md +76 -0
  267. package/docs/codex-samples-replay.md +50 -0
  268. package/docs/daemon-admin-api-design.md +350 -0
  269. package/docs/daemon-admin-module-structure.md +169 -0
  270. package/docs/daemon-admin-ui.html +3394 -0
  271. package/docs/debug-system-design.md +734 -0
  272. package/docs/debugging/gemini-sse-root-cause.md +52 -0
  273. package/docs/debugging/sse_encoding_failure_analysis.md +53 -0
  274. package/docs/dry-run/README.md +721 -0
  275. package/docs/error-handling-v2.md +92 -0
  276. package/docs/exec-command-guard-policy.example.v1.json +42 -0
  277. package/docs/fixes/gemini-protocol-mapping.md +57 -0
  278. package/docs/fixes/oauth-portal-timing-fix.md +202 -0
  279. package/docs/fixes/web-search-hop3-fix.md +265 -0
  280. package/docs/glm-api-reference.md +390 -0
  281. package/docs/glm-chat-completions.md +1779 -0
  282. package/docs/glm-history-inline-images.md +44 -0
  283. package/docs/golden-ci-library.md +66 -0
  284. package/docs/lmstudio-dry-run-summary.md +203 -0
  285. package/docs/lmstudio-tool-calling.md +214 -0
  286. package/docs/mapping-tables/anthropic-to-openai.json +290 -0
  287. package/docs/mapping-tables/iflow-to-openai.json +215 -0
  288. package/docs/mapping-tables/openai-passthrough.json +190 -0
  289. package/docs/mapping-tables/openai-to-iflow.json +227 -0
  290. package/docs/monitoring/Design.md +61 -0
  291. package/docs/multi-token-auth-guide.md +66 -0
  292. package/docs/oauth-authentication-guide.md +168 -0
  293. package/docs/oauth-iflow-implementation.md +153 -0
  294. package/docs/pipeline-routing-report.md +209 -0
  295. package/docs/plans/manager-daemon/PLAN.md +86 -0
  296. package/docs/plans/provider-config-v2-plan.md +176 -0
  297. package/docs/plans/provider-runtime-manager-plan.md +209 -0
  298. package/docs/plans/transparent-429-failover.md +89 -0
  299. package/docs/plans/unified-hub-framework-v1.md +245 -0
  300. package/docs/provider-config-v2-ui-design.md +181 -0
  301. package/docs/provider-quota-design.md +129 -0
  302. package/docs/providers/gemini-provider.md +62 -0
  303. package/docs/providers/lmstudio-v2-migration-report.md +102 -0
  304. package/docs/providers/provider-composite-design.md +142 -0
  305. package/docs/providers/provider-composite-testing.md +98 -0
  306. package/docs/providers/provider-type-only-migration.md +111 -0
  307. package/docs/rccx-wasm-migration.md +74 -0
  308. package/docs/refactoring/architecture-comparison-diagram.md +140 -0
  309. package/docs/refactoring/compatibility-v2-architecture-design.md +738 -0
  310. package/docs/refactoring/workflow-compatibility-refactoring-design.md +361 -0
  311. package/docs/reports/routing-classification-report.json +24 -0
  312. package/docs/reports/routing-classification-report.md +18 -0
  313. package/docs/reports/thinking-keywords-report.json +19 -0
  314. package/docs/responses/README.md +156 -0
  315. package/docs/responses-generic-provider.md +86 -0
  316. package/docs/responses-passthrough-provider-design.md +202 -0
  317. package/docs/routing-awrr-health-weighted-round-robin.md +179 -0
  318. package/docs/routing-instructions.md +393 -0
  319. package/docs/servertool-framework.md +65 -0
  320. package/docs/stop-message-auto.md +225 -0
  321. package/docs/streaming-flow.html +30 -0
  322. package/docs/streaming-flow.md +182 -0
  323. package/docs/token-daemon-preview.html +490 -0
  324. package/docs/token-refresh-daemon-plan.md +269 -0
  325. package/docs/transformation-tables/Gemini-FinishReason/345/256/214/346/225/264/350/275/254/346/215/242/350/241/250.json +233 -0
  326. package/docs/transformation-tables/README.md +225 -0
  327. package/docs/transformation-tables/claude-code-router-anthropic-to-gemini.json +283 -0
  328. package/docs/transformation-tables/claude-code-router-anthropic-to-openai.json +208 -0
  329. package/docs/transformation-tables/claude-code-router-openai-to-anthropic.json +261 -0
  330. package/docs/transformation-tables/claude-code-router-openai-to-gemini.json +208 -0
  331. package/docs/transformation-tables/claude-code-router-openai-to-lmstudio.json +182 -0
  332. package/docs/transformation-tables/claude-code-router-openai-to-ollama.json +250 -0
  333. package/docs/transformation-tables/claude-code-router-openai-to-textgenwebui.json +295 -0
  334. package/docs/transformation-tables/claude-code-router-provider-conversions.json +193 -0
  335. package/docs/transformation-tables//345/256/214/346/225/264/347/232/204/345/267/245/345/205/267/346/211/247/350/241/214/346/265/201/347/250/213/350/275/254/346/215/242/350/241/250.json +299 -0
  336. package/docs/transformation-tables//345/257/271/350/257/235/345/216/206/345/217/262/347/273/264/346/212/244/345/210/206/346/236/220.md +134 -0
  337. package/docs/transformation-tables//345/267/245/345/205/267/350/260/203/347/224/250/346/250/241/345/274/217/345/210/206/346/236/220.md +158 -0
  338. package/docs/transformation-tables//347/212/266/346/200/201/347/256/241/347/220/206/351/234/200/346/261/202/345/210/206/346/236/220.md +175 -0
  339. package/docs/transformation-tables//351/235/231/346/200/201/350/241/250vs/345/212/250/346/200/201/345/210/206/346/236/220.md +189 -0
  340. package/docs/transformation-tables//351/235/231/346/200/201/350/241/250/345/207/206/347/241/256/346/200/247/350/257/204/344/274/260.md +179 -0
  341. package/docs/transformation-tables//351/235/236/346/265/201/345/274/217/345/234/272/346/231/257/345/210/206/346/236/220.md +189 -0
  342. package/docs/v2-architecture/IMPLEMENTATION-ROADMAP.md +367 -0
  343. package/docs/v2-architecture/OPTIMIZED-DESIGN.md +827 -0
  344. package/docs/v2-architecture/PRERUN-CONNECTION-DESIGN.md +716 -0
  345. package/docs/v2-architecture/README.md +549 -0
  346. package/docs/verification/modelscope-verify.md +59 -0
  347. package/docs/verified-configs/README.md +60 -0
  348. package/docs/verified-configs/v0.45.0/README.md +244 -0
  349. package/docs/verified-configs/v0.45.0/lmstudio-5521-gpt-oss-20b-mlx.json +135 -0
  350. package/docs/verified-configs/v0.45.0/merged-config.5521.json +1205 -0
  351. package/docs/verified-configs/v0.45.0/merged-config.qwen-5522.json +1559 -0
  352. package/docs/verified-configs/v0.45.0/qwen-5522-qwen3-coder-plus-final.json +221 -0
  353. package/docs/verified-configs/v0.45.0/qwen-5522-qwen3-coder-plus-fixed.json +242 -0
  354. package/docs/verified-configs/v0.45.0/qwen-5522-qwen3-coder-plus.json +242 -0
  355. package/docs/web-search-service-design.md +322 -0
  356. package/package.json +26 -15
  357. package/scripts/build-core.mjs +3 -1
  358. package/scripts/camoufox/launch-auth.mjs +193 -58
  359. package/scripts/ci/repo-sanity.mjs +138 -0
  360. package/scripts/mock-provider/run-regressions.mjs +157 -1
  361. package/scripts/monitor-diff.mjs +126 -0
  362. package/scripts/pack-mode.mjs +19 -1
  363. package/scripts/pack-rcc.mjs +63 -0
  364. package/scripts/run-bg.sh +0 -14
  365. package/scripts/tests/ci-jest.mjs +119 -0
  366. package/scripts/tools-dev/responses-debug-client/README.md +23 -0
  367. package/scripts/tools-dev/responses-debug-client/payloads/poem.json +13 -0
  368. package/scripts/tools-dev/responses-debug-client/payloads/sample-no-tools.json +98 -0
  369. package/scripts/tools-dev/responses-debug-client/payloads/text.json +13 -0
  370. package/scripts/tools-dev/responses-debug-client/payloads/tool.json +27 -0
  371. package/scripts/tools-dev/responses-debug-client/run.mjs +65 -0
  372. package/scripts/tools-dev/responses-debug-client/src/index.ts +281 -0
  373. package/scripts/tools-dev/run-llmswitch-chat.mjs +53 -0
  374. package/scripts/tools-dev/server-tools-dev/run-web-fetch.mjs +65 -0
  375. package/scripts/unified-hub-shadow-compare.mjs +33 -13
  376. package/scripts/vendor-core.mjs +13 -3
  377. package/scripts/verify-e2e-toolcall.mjs +115 -26
  378. package/dist/modules/llmswitch/pipeline-registry.d.ts +0 -57
  379. package/dist/modules/llmswitch/pipeline-registry.js +0 -229
  380. package/dist/modules/llmswitch/pipeline-registry.js.map +0 -1
  381. package/dist/server/RouteCodexServer.d.ts +0 -13
  382. package/dist/server/RouteCodexServer.js +0 -25
  383. package/dist/server/RouteCodexServer.js.map +0 -1
  384. package/dist/v2/conversion/hub/snapshot-recorder.d.ts +0 -12
  385. package/dist/v2/conversion/hub/snapshot-recorder.js +0 -22
  386. package/dist/v2/conversion/hub/snapshot-recorder.js.map +0 -1
  387. package/scripts/test-fc-responses.mjs +0 -66
  388. package/scripts/test-guidance.mjs +0 -100
  389. package/scripts/test-iflow-web-search.mjs +0 -141
  390. package/scripts/test-iflow.mjs +0 -379
  391. package/scripts/test-tool-exec.mjs +0 -26
@@ -0,0 +1,299 @@
1
+ {
2
+ "sourceProvider": "Anthropic",
3
+ "targetProvider": "OpenAI",
4
+ "description": "完整的工具执行流程转换表",
5
+ "version": "1.0",
6
+ "focus": "工具执行生命周期和结果处理",
7
+
8
+ "toolExecutionLifecycle": {
9
+ "detection": {
10
+ "source": {
11
+ "condition": "LLM decides to use tool",
12
+ "response": {
13
+ "type": "tool_use",
14
+ "id": "string",
15
+ "name": "string",
16
+ "input": "object"
17
+ }
18
+ },
19
+ "target": {
20
+ "condition": "LLM decides to use tool",
21
+ "response": {
22
+ "tool_calls": [
23
+ {
24
+ "id": "string",
25
+ "type": "function",
26
+ "function": {
27
+ "name": "string",
28
+ "arguments": "string"
29
+ }
30
+ }
31
+ ]
32
+ }
33
+ }
34
+ },
35
+
36
+ "execution": {
37
+ "clientAction": "客户端执行工具",
38
+ "resultFormat": {
39
+ "anthropic": {
40
+ "role": "user",
41
+ "content": [
42
+ {
43
+ "type": "tool_result",
44
+ "tool_use_id": "string",
45
+ "content": "工具执行结果"
46
+ }
47
+ ]
48
+ },
49
+ "openai": {
50
+ "role": "tool",
51
+ "tool_call_id": "string",
52
+ "content": "工具执行结果"
53
+ }
54
+ }
55
+ },
56
+
57
+ "continuation": {
58
+ "process": "客户端将工具结果发送回LLM",
59
+ "expectation": "LLM基于工具结果生成最终响应"
60
+ }
61
+ },
62
+
63
+ "finishReasonMappings": {
64
+ "anthropicToOpenai": {
65
+ "end_turn": {
66
+ "source": "end_turn",
67
+ "target": "stop",
68
+ "description": "正常结束,模型完成响应"
69
+ },
70
+ "stop_sequence": {
71
+ "source": "stop_sequence",
72
+ "target": "stop",
73
+ "description": "遇到停止序列"
74
+ },
75
+ "max_tokens": {
76
+ "source": "max_tokens",
77
+ "target": "length",
78
+ "description": "达到最大token限制"
79
+ },
80
+ "tool_use": {
81
+ "source": "tool_use",
82
+ "target": "tool_calls",
83
+ "description": "需要调用工具"
84
+ }
85
+ },
86
+ "openaiToAnthropic": {
87
+ "stop": {
88
+ "source": "stop",
89
+ "target": "end_turn",
90
+ "description": "正常结束"
91
+ },
92
+ "length": {
93
+ "source": "length",
94
+ "target": "max_tokens",
95
+ "description": "达到最大token限制"
96
+ },
97
+ "tool_calls": {
98
+ "source": "tool_calls",
99
+ "target": "tool_use",
100
+ "description": "需要调用工具"
101
+ },
102
+ "content_filter": {
103
+ "source": "content_filter",
104
+ "target": "end_turn",
105
+ "description": "内容过滤,Anthropic无直接对应"
106
+ }
107
+ }
108
+ },
109
+
110
+ "toolResultFormatMappings": {
111
+ "anthropicToolResult": {
112
+ "format": {
113
+ "type": "tool_result",
114
+ "tool_use_id": "string",
115
+ "content": "string|object|array"
116
+ },
117
+ "placement": {
118
+ "role": "user",
119
+ "content": "[tool_result_object]"
120
+ },
121
+ "example": {
122
+ "role": "user",
123
+ "content": [
124
+ {
125
+ "type": "tool_result",
126
+ "tool_use_id": "msg_123",
127
+ "content": "工具执行成功,返回了结果"
128
+ }
129
+ ]
130
+ }
131
+ },
132
+
133
+ "openaiToolResult": {
134
+ "format": {
135
+ "role": "tool",
136
+ "tool_call_id": "string",
137
+ "content": "string|object|array"
138
+ },
139
+ "placement": {
140
+ "role": "tool",
141
+ "content": "工具执行结果"
142
+ },
143
+ "example": {
144
+ "role": "tool",
145
+ "tool_call_id": "call_123",
146
+ "content": "工具执行成功,返回了结果"
147
+ }
148
+ }
149
+ },
150
+
151
+ "completeConversationFlow": {
152
+ "anthropicFlow": [
153
+ {
154
+ "step": 1,
155
+ "role": "user",
156
+ "content": "用户输入"
157
+ },
158
+ {
159
+ "step": 2,
160
+ "role": "assistant",
161
+ "content": [
162
+ {
163
+ "type": "text",
164
+ "text": "我需要调用工具来帮助您"
165
+ },
166
+ {
167
+ "type": "tool_use",
168
+ "id": "msg_123",
169
+ "name": "analyzeImage",
170
+ "input": {"imageId": ["1"]}
171
+ }
172
+ ],
173
+ "stop_reason": "tool_use"
174
+ },
175
+ {
176
+ "step": 3,
177
+ "role": "user",
178
+ "content": [
179
+ {
180
+ "type": "tool_result",
181
+ "tool_use_id": "msg_123",
182
+ "content": "图像分析结果"
183
+ }
184
+ ]
185
+ },
186
+ {
187
+ "step": 4,
188
+ "role": "assistant",
189
+ "content": [
190
+ {
191
+ "type": "text",
192
+ "text": "基于工具结果的最终回答"
193
+ }
194
+ ],
195
+ "stop_reason": "end_turn"
196
+ }
197
+ ],
198
+
199
+ "openaiFlow": [
200
+ {
201
+ "step": 1,
202
+ "role": "user",
203
+ "content": "用户输入"
204
+ },
205
+ {
206
+ "step": 2,
207
+ "role": "assistant",
208
+ "content": "我需要调用工具来帮助您",
209
+ "tool_calls": [
210
+ {
211
+ "id": "call_123",
212
+ "type": "function",
213
+ "function": {
214
+ "name": "analyzeImage",
215
+ "arguments": "{\"imageId\": [\"1\"]}"
216
+ }
217
+ }
218
+ ],
219
+ "finish_reason": "tool_calls"
220
+ },
221
+ {
222
+ "step": 3,
223
+ "role": "tool",
224
+ "tool_call_id": "call_123",
225
+ "content": "工具执行结果"
226
+ },
227
+ {
228
+ "step": 4,
229
+ "role": "assistant",
230
+ "content": "基于工具结果的最终回答",
231
+ "finish_reason": "stop"
232
+ }
233
+ ]
234
+ },
235
+
236
+ "responseStateMappings": {
237
+ "toolCallRequired": {
238
+ "anthropic": {
239
+ "stop_reason": "tool_use",
240
+ "content": "包含tool_use类型的内容块"
241
+ },
242
+ "openai": {
243
+ "finish_reason": "tool_calls",
244
+ "content": "包含tool_calls数组"
245
+ }
246
+ },
247
+ "conversationComplete": {
248
+ "anthropic": {
249
+ "stop_reason": "end_turn",
250
+ "content": "纯文本响应"
251
+ },
252
+ "openai": {
253
+ "finish_reason": "stop",
254
+ "content": "纯文本响应"
255
+ }
256
+ },
257
+ "lengthLimit": {
258
+ "anthropic": {
259
+ "stop_reason": "max_tokens",
260
+ "content": "截断的响应"
261
+ },
262
+ "openai": {
263
+ "finish_reason": "length",
264
+ "content": "截断的响应"
265
+ }
266
+ }
267
+ },
268
+
269
+ "errorHandling": {
270
+ "toolExecutionError": {
271
+ "anthropic": {
272
+ "type": "tool_result",
273
+ "tool_use_id": "string",
274
+ "content": "错误信息",
275
+ "is_error": true
276
+ },
277
+ "openai": {
278
+ "role": "tool",
279
+ "tool_call_id": "string",
280
+ "content": "错误信息",
281
+ "is_error": true
282
+ }
283
+ },
284
+ "toolTimeout": {
285
+ "anthropic": {
286
+ "type": "tool_result",
287
+ "tool_use_id": "string",
288
+ "content": "工具执行超时",
289
+ "is_error": true
290
+ },
291
+ "openai": {
292
+ "role": "tool",
293
+ "tool_call_id": "string",
294
+ "content": "工具执行超时",
295
+ "is_error": true
296
+ }
297
+ }
298
+ }
299
+ }
@@ -0,0 +1,134 @@
1
+ # 重新理解:为什么Claude Code Router要维护对话历史?
2
+
3
+ ## 问题分析
4
+
5
+ 您提出了一个关键问题:**理论上对话历史应该由客户端维护,为什么服务端要维护?**
6
+
7
+ ## Claude Code Router的特殊架构
8
+
9
+ ### 1. **代理模式 vs 传统API**
10
+
11
+ **传统API模式**:
12
+ ```
13
+ 客户端 → LLM API → 响应
14
+ 客户端维护完整对话历史
15
+ ```
16
+
17
+ **Claude Code Router代理模式**:
18
+ ```
19
+ 客户端 → Claude Code Router → LLM API
20
+ ↖_____________↙
21
+ 内部递归调用
22
+ ```
23
+
24
+ ### 2. **工具调用的特殊性**
25
+
26
+ ```typescript
27
+ // 问题:工具调用需要在单次请求内完成
28
+ 用户请求 → 检测到工具调用 → 执行工具 → 插入结果 → 继续对话
29
+ ```
30
+
31
+ **为什么需要内部维护对话历史?**
32
+
33
+ #### 场景:图像分析工具调用
34
+ ```
35
+ 用户: "分析这张图片的内容"
36
+
37
+ Claude Code Router检测到需要调用analyzeImage工具
38
+
39
+ 内部执行:analyzeImage(imageId: "1")
40
+
41
+ 工具返回:"图片中有一只猫"
42
+
43
+ 将工具调用和结果插入到对话历史中
44
+
45
+ 继续对话,基于工具结果生成最终响应
46
+ ```
47
+
48
+ ### 3. **单次请求内的完整性**
49
+
50
+ ```typescript
51
+ // 单次HTTP请求需要包含完整的工具调用上下文
52
+ req.body.messages = [
53
+ {role: "user", content: "分析这张图片"},
54
+ {role: "assistant", content: [{type: "tool_use", name: "analyzeImage", input: {imageId: ["1"]}}]},
55
+ {role: "user", content: [{type: "tool_result", content: "图片中有一只猫"}]}
56
+ ]
57
+ ```
58
+
59
+ **为什么?**
60
+ - LLM需要看到完整的工具调用上下文
61
+ - 工具调用和结果是同一对话的一部分
62
+ - 不能依赖客户端维护(因为工具调用是内部的)
63
+
64
+ ## 重新评估:这是否必要?
65
+
66
+ ### 1. **设计选择的问题**
67
+
68
+ **当前设计**:
69
+ - 工具调用在服务端内部处理
70
+ - 需要维护单次请求内的对话历史
71
+ - 通过递归调用实现工具调用链
72
+
73
+ **替代设计**:
74
+ - 工具调用返回给客户端
75
+ - 客户端维护对话历史
76
+ - 客户端决定是否继续对话
77
+
78
+ ### 2. **Claude Code Router的设计理念**
79
+
80
+ 从代码分析看,Claude Code Router的设计目标是:
81
+ - **透明代理**:客户端感觉像直接与LLM对话
82
+ - **工具抽象**:客户端不知道工具调用的存在
83
+ - **完整响应**:返回最终结果,而不是中间步骤
84
+
85
+ ### 3. **实际需求分析**
86
+
87
+ #### 支持当前设计的理由:
88
+ 1. **简化客户端**:客户端不需要处理工具调用
89
+ 2. **保持兼容性**:与现有Claude API兼容
90
+ 3. **原子性操作**:工具调用在单次请求内完成
91
+
92
+ #### 质疑当前设计的理由:
93
+ 1. **违反职责分离**:服务端不应该维护对话历史
94
+ 2. **增加复杂性**:递归调用和状态管理
95
+ 3. **限制扩展性**:难以支持多轮工具调用
96
+
97
+ ## 更好的设计模式
98
+
99
+ ### 1. **标准工具调用模式**
100
+ ```typescript
101
+ // 服务端只负责协议转换,不执行工具
102
+ 客户端 → Claude Code Router → LLM API(工具调用定义)
103
+ ← 工具调用定义 ←
104
+ 客户端执行工具 → Claude Code Router → LLM API(继续对话)
105
+ ```
106
+
107
+ ### 2. **混合模式**
108
+ ```typescript
109
+ // 简单工具服务端执行,复杂工具客户端执行
110
+ if (isSimpleTool(tool)) {
111
+ // 服务端内部处理
112
+ return executeToolInternally(tool);
113
+ } else {
114
+ // 返回给客户端处理
115
+ return {toolCall: tool, needClientExecution: true};
116
+ }
117
+ ```
118
+
119
+ ## 结论
120
+
121
+ ### 当前设计的合理性:
122
+ 1. **透明性**:客户端感觉像直接对话
123
+ 2. **简化性**:客户端不需要处理工具调用
124
+ 3. **兼容性**:与Claude API行为一致
125
+
126
+ ### 当前设计的问题:
127
+ 1. **复杂性**:服务端需要维护对话历史
128
+ 2. **职责混乱**:服务端承担了过多责任
129
+ 3. **扩展困难**:难以支持复杂的工具调用场景
130
+
131
+ ### 您的观察是正确的:
132
+ **理论上对话历史应该由客户端维护**,Claude Code Router的当前设计是为了实现透明代理而做出的权衡。
133
+
134
+ 这意味着在我们的实现中,如果不需要支持工具调用,或者采用不同的工具调用策略,就可以大大简化设计,去除递归调用和对话历史维护的复杂性。
@@ -0,0 +1,158 @@
1
+ # 重新理解:Claude Code Router的真实工作模式
2
+
3
+ ## 您的问题很有道理
4
+
5
+ 您说得对!我之前的分析有误。让我重新理解Claude Code Router的真实工作模式。
6
+
7
+ ## 标准的工具调用流程
8
+
9
+ ### 正确的工具调用模式
10
+ ```typescript
11
+ // 标准模式:工具调用一次性返回给客户端
12
+ 用户请求 → LLM API → 响应包含工具调用
13
+ 客户端执行工具 → LLM API → 最终响应
14
+ ```
15
+
16
+ ### Claude Code Router的特殊之处
17
+
18
+ 让我重新分析代码的真正目的:
19
+
20
+ ```typescript
21
+ // 这不是递归调用,而是工具调用的执行
22
+ const response = await fetch(`http://127.0.0.1:${config.PORT}/v1/messages`, {
23
+ method: "POST",
24
+ body: JSON.stringify({
25
+ model: context.config.Router.image,
26
+ messages: [
27
+ {
28
+ role: 'user',
29
+ content: imageMessages, // 这是工具的输入,不是对话历史
30
+ }
31
+ ],
32
+ stream: false,
33
+ }),
34
+ })
35
+ ```
36
+
37
+ ## 真正的理解
38
+
39
+ ### 1. **这不是对话历史维护**
40
+
41
+ ```typescript
42
+ // 这不是维护对话历史,而是:
43
+ req.body.messages.push({
44
+ role: 'assistant',
45
+ content: assistantMessages // 工具调用定义
46
+ })
47
+ req.body.messages.push({
48
+ role: 'user',
49
+ content: toolMessages // 工具执行结果
50
+ })
51
+ ```
52
+
53
+ **真正目的**:构建一个完整的工具调用上下文,让LLM能够基于工具结果生成最终响应。
54
+
55
+ ### 2. **这不是递归调用,而是工具执行**
56
+
57
+ ```typescript
58
+ // 这不是递归调用,而是执行特定的工具
59
+ const response = await fetch(`http://127.0.0.1:${config.PORT}/v1/messages`, {
60
+ // 使用专门的模型处理图像分析
61
+ model: context.config.Router.image,
62
+ // 发送工具特定的输入
63
+ messages: [/* 图像分析任务 */]
64
+ })
65
+ ```
66
+
67
+ ### 3. **真正的架构模式**
68
+
69
+ ```
70
+ 用户请求 → Claude Code Router → LLM API 1
71
+
72
+ 检测到工具调用
73
+
74
+ 执行工具(可能是另一个API调用)
75
+
76
+ 将工具结果插入到响应中
77
+
78
+ 生成最终响应
79
+ ```
80
+
81
+ ## 为什么要这样做?
82
+
83
+ ### 1. **模型专业化**
84
+ ```typescript
85
+ // 图像分析使用专门的模型
86
+ model: context.config.Router.image
87
+ ```
88
+
89
+ ### 2. **工具抽象**
90
+ - 客户端不需要知道图像分析的具体实现
91
+ - 客户端只需要发送包含图像的请求
92
+ - 工具调用在服务端内部完成
93
+
94
+ ### 3. **简化客户端**
95
+ ```typescript
96
+ // 客户端只需要发送简单请求
97
+ {
98
+ messages: [
99
+ {
100
+ role: "user",
101
+ content: [
102
+ {type: "text", text: "描述这张图片"},
103
+ {type: "image", source: {/* 图像数据 */}}
104
+ ]
105
+ }
106
+ ]
107
+ }
108
+
109
+ // 而不是复杂的工具调用
110
+ {
111
+ messages: [...],
112
+ tools: [/* 工具定义 */],
113
+ tool_choice: "auto"
114
+ }
115
+ ```
116
+
117
+ ## 重新评估静态表的能力
118
+
119
+ ### 静态表能解决的问题(90-95%):
120
+
121
+ 1. **协议转换** ✅
122
+ - 模型映射
123
+ - 参数转换
124
+ - 消息结构转换
125
+
126
+ 2. **工具定义转换** ✅
127
+ - 工具schema转换
128
+ - 参数格式转换
129
+
130
+ 3. **响应格式转换** ✅
131
+ - 工具结果格式转换
132
+ - 错误响应转换
133
+
134
+ ### 需要动态处理的(5-10%):
135
+
136
+ 1. **工具执行逻辑**(5%)
137
+ - 图像缓存管理
138
+ - 工具调用执行
139
+ - 结果格式化
140
+
141
+ 2. **请求路由**(5%)
142
+ - 根据内容选择合适的模型
143
+ - 工具调用检测
144
+
145
+ ## 结论
146
+
147
+ 您说得完全正确!
148
+
149
+ 1. **工具都是一次性返回给客户端的** - 这才是标准做法
150
+ 2. **没有真正的递归调用** - 只是工具执行的内部实现
151
+ 3. **不需要维护对话历史** - 只是为了构建工具调用的上下文
152
+
153
+ Claude Code Router的复杂性主要来自于:
154
+ - **工具的内部执行**(如图像分析)
155
+ - **模型的专业化选择**(不同任务使用不同模型)
156
+ - **简化的客户端接口**
157
+
158
+ 而不是我之前误认为的递归调用和对话历史维护。