@jsonstudio/rcc 0.89.1205 → 0.89.1348

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 (332) hide show
  1. package/README.md +17 -0
  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 +74 -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 +91 -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 +36 -0
  40. package/dist/cli/config/init-config.js +180 -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-cli/gemini-cli-protocol-client.js +1 -1
  51. package/dist/client/gemini-cli/gemini-cli-protocol-client.js.map +1 -1
  52. package/dist/config/risk-control-config.d.ts +94 -0
  53. package/dist/config/risk-control-config.js +196 -0
  54. package/dist/config/risk-control-config.js.map +1 -0
  55. package/dist/constants/index.d.ts +6 -0
  56. package/dist/constants/index.js +13 -0
  57. package/dist/constants/index.js.map +1 -1
  58. package/dist/docs/daemon-admin-ui.html +2113 -190
  59. package/dist/index.js +0 -1
  60. package/dist/index.js.map +1 -1
  61. package/dist/manager/modules/health/index.d.ts +1 -1
  62. package/dist/manager/modules/quota/antigravity-quota-manager.d.ts +70 -0
  63. package/dist/manager/modules/quota/antigravity-quota-manager.js +442 -0
  64. package/dist/manager/modules/quota/antigravity-quota-manager.js.map +1 -0
  65. package/dist/manager/modules/quota/index.d.ts +3 -127
  66. package/dist/manager/modules/quota/index.js +2 -1093
  67. package/dist/manager/modules/quota/index.js.map +1 -1
  68. package/dist/manager/modules/quota/provider-key-normalization.d.ts +3 -0
  69. package/dist/manager/modules/quota/provider-key-normalization.js +155 -0
  70. package/dist/manager/modules/quota/provider-key-normalization.js.map +1 -0
  71. package/dist/manager/modules/quota/provider-quota-daemon.cooldown.d.ts +9 -0
  72. package/dist/manager/modules/quota/provider-quota-daemon.cooldown.js +115 -0
  73. package/dist/manager/modules/quota/provider-quota-daemon.cooldown.js.map +1 -0
  74. package/dist/manager/modules/quota/provider-quota-daemon.d.ts +77 -0
  75. package/dist/manager/modules/quota/provider-quota-daemon.events.d.ts +12 -0
  76. package/dist/manager/modules/quota/provider-quota-daemon.events.js +237 -0
  77. package/dist/manager/modules/quota/provider-quota-daemon.events.js.map +1 -0
  78. package/dist/manager/modules/quota/provider-quota-daemon.js +404 -0
  79. package/dist/manager/modules/quota/provider-quota-daemon.js.map +1 -0
  80. package/dist/manager/modules/quota/provider-quota-daemon.model-backoff.d.ts +11 -0
  81. package/dist/manager/modules/quota/provider-quota-daemon.model-backoff.js +189 -0
  82. package/dist/manager/modules/quota/provider-quota-daemon.model-backoff.js.map +1 -0
  83. package/dist/manager/modules/quota/provider-quota-daemon.snapshot.d.ts +8 -0
  84. package/dist/manager/modules/quota/provider-quota-daemon.snapshot.js +96 -0
  85. package/dist/manager/modules/quota/provider-quota-daemon.snapshot.js.map +1 -0
  86. package/dist/manager/modules/quota/provider-quota-daemon.view.d.ts +19 -0
  87. package/dist/manager/modules/quota/provider-quota-daemon.view.js +37 -0
  88. package/dist/manager/modules/quota/provider-quota-daemon.view.js.map +1 -0
  89. package/dist/manager/modules/routing/index.d.ts +1 -0
  90. package/dist/manager/modules/routing/index.js +11 -25
  91. package/dist/manager/modules/routing/index.js.map +1 -1
  92. package/dist/manager/quota/provider-quota-center.d.ts +2 -0
  93. package/dist/manager/quota/provider-quota-center.js +80 -82
  94. package/dist/manager/quota/provider-quota-center.js.map +1 -1
  95. package/dist/modules/llmswitch/bridge.d.ts +16 -18
  96. package/dist/modules/llmswitch/bridge.js +293 -94
  97. package/dist/modules/llmswitch/bridge.js.map +1 -1
  98. package/dist/modules/llmswitch/core-loader.d.ts +4 -2
  99. package/dist/modules/llmswitch/core-loader.js +32 -20
  100. package/dist/modules/llmswitch/core-loader.js.map +1 -1
  101. package/dist/modules/pipeline/utils/colored-logger.js +3 -2
  102. package/dist/modules/pipeline/utils/colored-logger.js.map +1 -1
  103. package/dist/modules/pipeline/utils/debug-logger.js +1 -1
  104. package/dist/modules/pipeline/utils/debug-logger.js.map +1 -1
  105. package/dist/providers/auth/iflow-cookie-auth.js +0 -2
  106. package/dist/providers/auth/iflow-cookie-auth.js.map +1 -1
  107. package/dist/providers/auth/oauth-lifecycle.js +2 -23
  108. package/dist/providers/auth/oauth-lifecycle.js.map +1 -1
  109. package/dist/providers/core/config/camoufox-launcher.js +35 -4
  110. package/dist/providers/core/config/camoufox-launcher.js.map +1 -1
  111. package/dist/providers/core/runtime/antigravity-quota-client.js +6 -3
  112. package/dist/providers/core/runtime/antigravity-quota-client.js.map +1 -1
  113. package/dist/providers/core/runtime/base-provider.d.ts +2 -2
  114. package/dist/providers/core/runtime/base-provider.js +74 -69
  115. package/dist/providers/core/runtime/base-provider.js.map +1 -1
  116. package/dist/providers/core/runtime/gemini-cli-http-provider.js +6 -4
  117. package/dist/providers/core/runtime/gemini-cli-http-provider.js.map +1 -1
  118. package/dist/providers/core/runtime/http-request-executor.js +2 -2
  119. package/dist/providers/core/runtime/http-request-executor.js.map +1 -1
  120. package/dist/providers/core/runtime/http-transport-provider.d.ts +14 -0
  121. package/dist/providers/core/runtime/http-transport-provider.js +111 -5
  122. package/dist/providers/core/runtime/http-transport-provider.js.map +1 -1
  123. package/dist/providers/core/runtime/provider-error-classifier.js +10 -0
  124. package/dist/providers/core/runtime/provider-error-classifier.js.map +1 -1
  125. package/dist/providers/core/runtime/provider-factory.js +7 -5
  126. package/dist/providers/core/runtime/provider-factory.js.map +1 -1
  127. package/dist/providers/core/runtime/provider-runtime-metadata.d.ts +6 -0
  128. package/dist/providers/core/runtime/provider-runtime-metadata.js.map +1 -1
  129. package/dist/providers/core/runtime/responses-provider.d.ts +1 -7
  130. package/dist/providers/core/runtime/responses-provider.js +12 -93
  131. package/dist/providers/core/runtime/responses-provider.js.map +1 -1
  132. package/dist/providers/core/strategies/oauth-auth-code-flow.js +12 -8
  133. package/dist/providers/core/strategies/oauth-auth-code-flow.js.map +1 -1
  134. package/dist/providers/core/utils/http-client.js +16 -3
  135. package/dist/providers/core/utils/http-client.js.map +1 -1
  136. package/dist/providers/core/utils/provider-error-logger.d.ts +1 -1
  137. package/dist/providers/core/utils/provider-error-reporter.d.ts +3 -1
  138. package/dist/providers/core/utils/provider-error-reporter.js +3 -0
  139. package/dist/providers/core/utils/provider-error-reporter.js.map +1 -1
  140. package/dist/providers/core/utils/snapshot-writer.js +1 -4
  141. package/dist/providers/core/utils/snapshot-writer.js.map +1 -1
  142. package/dist/providers/mock/mock-provider-runtime.js +57 -27
  143. package/dist/providers/mock/mock-provider-runtime.js.map +1 -1
  144. package/dist/scripts/camoufox/launch-auth.mjs +193 -58
  145. package/dist/server/handlers/handler-utils.js +3 -2
  146. package/dist/server/handlers/handler-utils.js.map +1 -1
  147. package/dist/server/runtime/http-server/daemon-admin/auth-handler.d.ts +2 -0
  148. package/dist/server/runtime/http-server/daemon-admin/auth-handler.js +103 -0
  149. package/dist/server/runtime/http-server/daemon-admin/auth-handler.js.map +1 -0
  150. package/dist/server/runtime/http-server/daemon-admin/auth-session.d.ts +5 -0
  151. package/dist/server/runtime/http-server/daemon-admin/auth-session.js +77 -0
  152. package/dist/server/runtime/http-server/daemon-admin/auth-session.js.map +1 -0
  153. package/dist/server/runtime/http-server/daemon-admin/auth-store.d.ts +18 -0
  154. package/dist/server/runtime/http-server/daemon-admin/auth-store.js +89 -0
  155. package/dist/server/runtime/http-server/daemon-admin/auth-store.js.map +1 -0
  156. package/dist/server/runtime/http-server/daemon-admin/credentials-handler.js +1 -2
  157. package/dist/server/runtime/http-server/daemon-admin/credentials-handler.js.map +1 -1
  158. package/dist/server/runtime/http-server/daemon-admin/providers-handler.js +226 -24
  159. package/dist/server/runtime/http-server/daemon-admin/providers-handler.js.map +1 -1
  160. package/dist/server/runtime/http-server/daemon-admin/quota-handler.js +47 -8
  161. package/dist/server/runtime/http-server/daemon-admin/quota-handler.js.map +1 -1
  162. package/dist/server/runtime/http-server/daemon-admin/restart-handler.js +1 -1
  163. package/dist/server/runtime/http-server/daemon-admin/restart-handler.js.map +1 -1
  164. package/dist/server/runtime/http-server/daemon-admin/stats-handler.js +1 -1
  165. package/dist/server/runtime/http-server/daemon-admin/stats-handler.js.map +1 -1
  166. package/dist/server/runtime/http-server/daemon-admin/status-handler.js +68 -4
  167. package/dist/server/runtime/http-server/daemon-admin/status-handler.js.map +1 -1
  168. package/dist/server/runtime/http-server/daemon-admin-routes.d.ts +3 -4
  169. package/dist/server/runtime/http-server/daemon-admin-routes.js +9 -14
  170. package/dist/server/runtime/http-server/daemon-admin-routes.js.map +1 -1
  171. package/dist/server/runtime/http-server/executor-metadata.js +1 -1
  172. package/dist/server/runtime/http-server/executor-metadata.js.map +1 -1
  173. package/dist/server/runtime/http-server/executor-response.js +0 -16
  174. package/dist/server/runtime/http-server/executor-response.js.map +1 -1
  175. package/dist/server/runtime/http-server/hub-shadow-compare.js +110 -34
  176. package/dist/server/runtime/http-server/hub-shadow-compare.js.map +1 -1
  177. package/dist/server/runtime/http-server/index.d.ts +5 -3
  178. package/dist/server/runtime/http-server/index.js +215 -109
  179. package/dist/server/runtime/http-server/index.js.map +1 -1
  180. package/dist/server/runtime/http-server/middleware.js +19 -1
  181. package/dist/server/runtime/http-server/middleware.js.map +1 -1
  182. package/dist/server/runtime/http-server/request-executor.js +10 -19
  183. package/dist/server/runtime/http-server/request-executor.js.map +1 -1
  184. package/dist/server/runtime/http-server/routes.js +8 -2
  185. package/dist/server/runtime/http-server/routes.js.map +1 -1
  186. package/dist/server/runtime/http-server/session-dir.d.ts +2 -0
  187. package/dist/server/runtime/http-server/session-dir.js +59 -0
  188. package/dist/server/runtime/http-server/session-dir.js.map +1 -0
  189. package/dist/server/runtime/http-server/types.d.ts +0 -4
  190. package/dist/server/utils/utf8-chunk-buffer.js +6 -3
  191. package/dist/server/utils/utf8-chunk-buffer.js.map +1 -1
  192. package/dist/server/utils/warmup-storm-tracker.js +1 -1
  193. package/dist/server/utils/warmup-storm-tracker.js.map +1 -1
  194. package/dist/server-factory.d.ts +6 -28
  195. package/dist/server-factory.js +8 -93
  196. package/dist/server-factory.js.map +1 -1
  197. package/dist/token-daemon/index.js +2 -2
  198. package/dist/token-daemon/index.js.map +1 -1
  199. package/dist/token-daemon/provider-registry.js +0 -1
  200. package/dist/token-daemon/provider-registry.js.map +1 -1
  201. package/dist/token-daemon/server-utils.js +8 -9
  202. package/dist/token-daemon/server-utils.js.map +1 -1
  203. package/dist/token-daemon/token-utils.js +1 -1
  204. package/dist/token-daemon/token-utils.js.map +1 -1
  205. package/dist/tools/semantic-replay.js +2 -2
  206. package/dist/tools/semantic-replay.js.map +1 -1
  207. package/dist/tools/stats-request-events.d.ts +1 -1
  208. package/dist/tools/stats-usage.js +6 -3
  209. package/dist/tools/stats-usage.js.map +1 -1
  210. package/dist/utils/llms-engine-shadow.d.ts +19 -0
  211. package/dist/utils/llms-engine-shadow.js +209 -0
  212. package/dist/utils/llms-engine-shadow.js.map +1 -0
  213. package/dist/utils/runtime-versions.js +2 -1
  214. package/dist/utils/runtime-versions.js.map +1 -1
  215. package/docs/ARCHITECTURE.md +402 -0
  216. package/docs/CODEX_AND_CLAUDE_CODE.md +69 -0
  217. package/docs/CONFIG_ARCHITECTURE.md +517 -0
  218. package/docs/ERROR_HANDLING_AUDIT.md +0 -0
  219. package/docs/GCLI2API_PARITY_GAPS.md +98 -0
  220. package/docs/INSTALLATION_AND_QUICKSTART.md +74 -0
  221. package/docs/INSTRUCTION_MARKUP.md +89 -0
  222. package/docs/MODULE_ENHANCEMENT_SYSTEM.md +666 -0
  223. package/docs/PORTS.md +36 -0
  224. package/docs/PROVIDERS_BUILTIN.md +111 -0
  225. package/docs/PROVIDER_TYPES.md +55 -0
  226. package/docs/SERVERTOOL_CLOCK_DESIGN.md +233 -0
  227. package/docs/USAGE_HANDLING_ANALYSIS.md +335 -0
  228. package/docs/USER_CONFIG_PARSER_CHANGES.md +175 -0
  229. package/docs/V3_INBOUND_OUTBOUND_DESIGN.md +86 -0
  230. package/docs/VIRTUAL_ROUTER_PRIORITY_AND_HEALTH.md +125 -0
  231. package/docs/anthropic-request-golden-samples.md +50 -0
  232. package/docs/ccr-alignment-enhancetool.md +105 -0
  233. package/docs/chat-glm-500-analysis.md +79 -0
  234. package/docs/chat-request-golden-samples.md +42 -0
  235. package/docs/chat-semantic-expansion-plan.md +82 -0
  236. package/docs/cli-command-inventory.md +76 -0
  237. package/docs/codex-samples-replay.md +50 -0
  238. package/docs/daemon-admin-api-design.md +350 -0
  239. package/docs/daemon-admin-module-structure.md +169 -0
  240. package/docs/daemon-admin-ui.html +3394 -0
  241. package/docs/debug-system-design.md +734 -0
  242. package/docs/debugging/gemini-sse-root-cause.md +52 -0
  243. package/docs/debugging/sse_encoding_failure_analysis.md +53 -0
  244. package/docs/dry-run/README.md +721 -0
  245. package/docs/error-handling-v2.md +92 -0
  246. package/docs/exec-command-guard-policy.example.v1.json +42 -0
  247. package/docs/fixes/gemini-protocol-mapping.md +57 -0
  248. package/docs/fixes/oauth-portal-timing-fix.md +202 -0
  249. package/docs/fixes/web-search-hop3-fix.md +265 -0
  250. package/docs/glm-api-reference.md +390 -0
  251. package/docs/glm-chat-completions.md +1779 -0
  252. package/docs/glm-history-inline-images.md +44 -0
  253. package/docs/golden-ci-library.md +66 -0
  254. package/docs/lmstudio-dry-run-summary.md +203 -0
  255. package/docs/lmstudio-tool-calling.md +214 -0
  256. package/docs/mapping-tables/anthropic-to-openai.json +290 -0
  257. package/docs/mapping-tables/iflow-to-openai.json +215 -0
  258. package/docs/mapping-tables/openai-passthrough.json +190 -0
  259. package/docs/mapping-tables/openai-to-iflow.json +227 -0
  260. package/docs/monitoring/Design.md +61 -0
  261. package/docs/multi-token-auth-guide.md +66 -0
  262. package/docs/oauth-authentication-guide.md +168 -0
  263. package/docs/oauth-iflow-implementation.md +153 -0
  264. package/docs/pipeline-routing-report.md +209 -0
  265. package/docs/plans/manager-daemon/PLAN.md +86 -0
  266. package/docs/plans/provider-config-v2-plan.md +176 -0
  267. package/docs/plans/provider-runtime-manager-plan.md +209 -0
  268. package/docs/plans/transparent-429-failover.md +89 -0
  269. package/docs/plans/unified-hub-framework-v1.md +245 -0
  270. package/docs/provider-config-v2-ui-design.md +181 -0
  271. package/docs/provider-quota-design.md +129 -0
  272. package/docs/providers/gemini-provider.md +62 -0
  273. package/docs/providers/lmstudio-v2-migration-report.md +102 -0
  274. package/docs/providers/provider-composite-design.md +142 -0
  275. package/docs/providers/provider-composite-testing.md +98 -0
  276. package/docs/providers/provider-type-only-migration.md +111 -0
  277. package/docs/rccx-wasm-migration.md +74 -0
  278. package/docs/refactoring/architecture-comparison-diagram.md +140 -0
  279. package/docs/refactoring/compatibility-v2-architecture-design.md +738 -0
  280. package/docs/refactoring/workflow-compatibility-refactoring-design.md +361 -0
  281. package/docs/reports/routing-classification-report.json +24 -0
  282. package/docs/reports/routing-classification-report.md +18 -0
  283. package/docs/reports/thinking-keywords-report.json +19 -0
  284. package/docs/responses/README.md +156 -0
  285. package/docs/responses-generic-provider.md +86 -0
  286. package/docs/responses-passthrough-provider-design.md +202 -0
  287. package/docs/routing-awrr-health-weighted-round-robin.md +179 -0
  288. package/docs/routing-instructions.md +393 -0
  289. package/docs/stop-message-auto.md +225 -0
  290. package/docs/streaming-flow.html +30 -0
  291. package/docs/streaming-flow.md +182 -0
  292. package/docs/token-daemon-preview.html +490 -0
  293. package/docs/token-refresh-daemon-plan.md +269 -0
  294. package/docs/transformation-tables/Gemini-FinishReason/345/256/214/346/225/264/350/275/254/346/215/242/350/241/250.json +233 -0
  295. package/docs/transformation-tables/README.md +225 -0
  296. package/docs/transformation-tables/claude-code-router-anthropic-to-gemini.json +283 -0
  297. package/docs/transformation-tables/claude-code-router-anthropic-to-openai.json +208 -0
  298. package/docs/transformation-tables/claude-code-router-openai-to-anthropic.json +261 -0
  299. package/docs/transformation-tables/claude-code-router-openai-to-gemini.json +208 -0
  300. package/docs/transformation-tables/claude-code-router-openai-to-lmstudio.json +182 -0
  301. package/docs/transformation-tables/claude-code-router-openai-to-ollama.json +250 -0
  302. package/docs/transformation-tables/claude-code-router-openai-to-textgenwebui.json +295 -0
  303. package/docs/transformation-tables/claude-code-router-provider-conversions.json +193 -0
  304. 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
  305. 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
  306. 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
  307. 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
  308. 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
  309. 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
  310. 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
  311. package/docs/v2-architecture/IMPLEMENTATION-ROADMAP.md +367 -0
  312. package/docs/v2-architecture/OPTIMIZED-DESIGN.md +827 -0
  313. package/docs/v2-architecture/PRERUN-CONNECTION-DESIGN.md +716 -0
  314. package/docs/v2-architecture/README.md +551 -0
  315. package/docs/verification/modelscope-verify.md +59 -0
  316. package/docs/web-search-service-design.md +322 -0
  317. package/package.json +12 -7
  318. package/scripts/camoufox/launch-auth.mjs +193 -58
  319. package/scripts/monitor-diff.mjs +126 -0
  320. package/scripts/pack-mode.mjs +19 -1
  321. package/scripts/pack-rcc.mjs +63 -0
  322. package/scripts/unified-hub-shadow-compare.mjs +33 -13
  323. package/scripts/verify-e2e-toolcall.mjs +115 -26
  324. package/dist/modules/llmswitch/pipeline-registry.d.ts +0 -57
  325. package/dist/modules/llmswitch/pipeline-registry.js +0 -229
  326. package/dist/modules/llmswitch/pipeline-registry.js.map +0 -1
  327. package/dist/server/RouteCodexServer.d.ts +0 -13
  328. package/dist/server/RouteCodexServer.js +0 -25
  329. package/dist/server/RouteCodexServer.js.map +0 -1
  330. package/dist/v2/conversion/hub/snapshot-recorder.d.ts +0 -12
  331. package/dist/v2/conversion/hub/snapshot-recorder.js +0 -22
  332. package/dist/v2/conversion/hub/snapshot-recorder.js.map +0 -1
@@ -0,0 +1,295 @@
1
+ {
2
+ "sourceProvider": "OpenAI",
3
+ "targetProvider": "Text Generation WebUI",
4
+ "description": "Transformation table for converting OpenAI API format to Text Generation WebUI compatible format",
5
+ "version": "1.0",
6
+ "endpointMappings": {
7
+ "chatCompletions": {
8
+ "sourceEndpoint": "/v1/chat/completions",
9
+ "targetEndpoint": "/v1/chat/completions",
10
+ "method": "POST"
11
+ },
12
+ "completions": {
13
+ "sourceEndpoint": "/v1/completions",
14
+ "targetEndpoint": "/v1/completions",
15
+ "method": "POST"
16
+ },
17
+ "models": {
18
+ "sourceEndpoint": "/v1/models",
19
+ "targetEndpoint": "/v1/models",
20
+ "method": "GET"
21
+ },
22
+ "embeddings": {
23
+ "sourceEndpoint": "/v1/embeddings",
24
+ "targetEndpoint": "/v1/embeddings",
25
+ "method": "POST"
26
+ }
27
+ },
28
+ "requestMappings": {
29
+ "model": {
30
+ "sourcePath": "model",
31
+ "targetPath": "model",
32
+ "transform": "directMapping",
33
+ "description": "Text Generation WebUI uses the same model parameter format"
34
+ },
35
+ "messages": {
36
+ "sourcePath": "messages",
37
+ "targetPath": "messages",
38
+ "transform": "directMapping",
39
+ "description": "Text Generation WebUI uses the same message structure"
40
+ },
41
+ "maxTokens": {
42
+ "sourcePath": "max_tokens",
43
+ "targetPath": "max_tokens",
44
+ "transform": "directMapping"
45
+ },
46
+ "temperature": {
47
+ "sourcePath": "temperature",
48
+ "targetPath": "temperature",
49
+ "transform": "directMapping"
50
+ },
51
+ "topP": {
52
+ "sourcePath": "top_p",
53
+ "targetPath": "top_p",
54
+ "transform": "directMapping"
55
+ },
56
+ "frequencyPenalty": {
57
+ "sourcePath": "frequency_penalty",
58
+ "targetPath": "frequency_penalty",
59
+ "transform": "directMapping"
60
+ },
61
+ "presencePenalty": {
62
+ "sourcePath": "presence_penalty",
63
+ "targetPath": "presence_penalty",
64
+ "transform": "directMapping"
65
+ },
66
+ "stop": {
67
+ "sourcePath": "stop",
68
+ "targetPath": "stop",
69
+ "transform": "directMapping"
70
+ },
71
+ "stream": {
72
+ "sourcePath": "stream",
73
+ "targetPath": "stream",
74
+ "transform": "directMapping"
75
+ },
76
+ "tools": {
77
+ "sourcePath": "tools",
78
+ "targetPath": "tools",
79
+ "transform": "directMapping",
80
+ "description": "Text Generation WebUI supports OpenAI-compatible tool calling"
81
+ },
82
+ "toolChoice": {
83
+ "sourcePath": "tool_choice",
84
+ "targetPath": "tool_choice",
85
+ "transform": "directMapping"
86
+ }
87
+ },
88
+ "responseMappings": {
89
+ "id": {
90
+ "sourcePath": "id",
91
+ "targetPath": "id",
92
+ "transform": "directMapping"
93
+ },
94
+ "object": {
95
+ "sourcePath": "object",
96
+ "targetPath": "object",
97
+ "transform": "directMapping"
98
+ },
99
+ "created": {
100
+ "sourcePath": "created",
101
+ "targetPath": "created",
102
+ "transform": "directMapping"
103
+ },
104
+ "model": {
105
+ "sourcePath": "model",
106
+ "targetPath": "model",
107
+ "transform": "directMapping"
108
+ },
109
+ "choices": {
110
+ "sourcePath": "choices",
111
+ "targetPath": "choices",
112
+ "transform": "directMapping"
113
+ },
114
+ "usage": {
115
+ "sourcePath": "usage",
116
+ "targetPath": "usage",
117
+ "transform": "directMapping"
118
+ }
119
+ },
120
+ "completionMappings": {
121
+ "prompt": {
122
+ "sourcePath": "prompt",
123
+ "targetPath": "prompt",
124
+ "transform": "directMapping"
125
+ },
126
+ "suffix": {
127
+ "sourcePath": "suffix",
128
+ "targetPath": "suffix",
129
+ "transform": "directMapping"
130
+ },
131
+ "bestOf": {
132
+ "sourcePath": "best_of",
133
+ "targetPath": "best_of",
134
+ "transform": "directMapping"
135
+ },
136
+ "echo": {
137
+ "sourcePath": "echo",
138
+ "targetPath": "echo",
139
+ "transform": "directMapping"
140
+ },
141
+ "logProbs": {
142
+ "sourcePath": "logprobs",
143
+ "targetPath": "logprobs",
144
+ "transform": "directMapping"
145
+ },
146
+ "logitBias": {
147
+ "sourcePath": "logit_bias",
148
+ "targetPath": "logit_bias",
149
+ "transform": "directMapping"
150
+ }
151
+ },
152
+ "embeddingMappings": {
153
+ "input": {
154
+ "sourcePath": "input",
155
+ "targetPath": "input",
156
+ "transform": "directMapping"
157
+ },
158
+ "model": {
159
+ "sourcePath": "model",
160
+ "targetPath": "model",
161
+ "transform": "directMapping"
162
+ },
163
+ "encodingFormat": {
164
+ "sourcePath": "encoding_format",
165
+ "targetPath": "encoding_format",
166
+ "transform": "directMapping"
167
+ },
168
+ "dimensions": {
169
+ "sourcePath": "dimensions",
170
+ "targetPath": "dimensions",
171
+ "transform": "directMapping"
172
+ }
173
+ },
174
+ "generationParameters": {
175
+ "doSample": {
176
+ "sourcePath": "do_sample",
177
+ "targetPath": "do_sample",
178
+ "transform": "directMapping"
179
+ },
180
+ "earlyStopping": {
181
+ "sourcePath": "early_stopping",
182
+ "targetPath": "early_stopping",
183
+ "transform": "directMapping"
184
+ },
185
+ "numBeams": {
186
+ "sourcePath": "num_beams",
187
+ "targetPath": "num_beams",
188
+ "transform": "directMapping"
189
+ },
190
+ "noRepeatNgramSize": {
191
+ "sourcePath": "no_repeat_ngram_size",
192
+ "targetPath": "no_repeat_ngram_size",
193
+ "transform": "directMapping"
194
+ },
195
+ "minLength": {
196
+ "sourcePath": "min_length",
197
+ "targetPath": "min_length",
198
+ "transform": "directMapping"
199
+ },
200
+ "repetitionPenalty": {
201
+ "sourcePath": "repetition_penalty",
202
+ "targetPath": "repetition_penalty",
203
+ "transform": "directMapping"
204
+ },
205
+ "lengthPenalty": {
206
+ "sourcePath": "length_penalty",
207
+ "targetPath": "length_penalty",
208
+ "transform": "directMapping"
209
+ },
210
+ "badWordsIds": {
211
+ "sourcePath": "bad_words_ids",
212
+ "targetPath": "bad_words_ids",
213
+ "transform": "directMapping"
214
+ },
215
+ "bosTokenId": {
216
+ "sourcePath": "bos_token_id",
217
+ "targetPath": "bos_token_id",
218
+ "transform": "directMapping"
219
+ },
220
+ "eosTokenId": {
221
+ "sourcePath": "eos_token_id",
222
+ "targetPath": "eos_token_id",
223
+ "transform": "directMapping"
224
+ },
225
+ "padTokenId": {
226
+ "sourcePath": "pad_token_id",
227
+ "targetPath": "pad_token_id",
228
+ "transform": "directMapping"
229
+ },
230
+ "decoderStartTokenId": {
231
+ "sourcePath": "decoder_start_token_id",
232
+ "targetPath": "decoder_start_token_id",
233
+ "transform": "directMapping"
234
+ }
235
+ },
236
+ "streamMappings": {
237
+ "chunkFormat": {
238
+ "sourceFormat": "data: {JSON}",
239
+ "targetFormat": "data: {JSON}",
240
+ "transform": "directMapping"
241
+ },
242
+ "eventTypes": {
243
+ "message_start": "message_start",
244
+ "message_delta": "message_delta",
245
+ "message_stop": "message_stop"
246
+ }
247
+ },
248
+ "authentication": {
249
+ "apiKey": {
250
+ "sourceHeader": "Authorization: Bearer {token}",
251
+ "targetHeader": "Authorization: Bearer {token}",
252
+ "transform": "directMapping"
253
+ }
254
+ },
255
+ "headers": {
256
+ "contentType": {
257
+ "sourceHeader": "Content-Type: application/json",
258
+ "targetHeader": "Content-Type: application/json",
259
+ "transform": "directMapping"
260
+ }
261
+ },
262
+ "errorMappings": {
263
+ "errorResponse": {
264
+ "sourceFormat": {
265
+ "error": {
266
+ "message": "string",
267
+ "type": "string",
268
+ "code": "string"
269
+ }
270
+ },
271
+ "targetFormat": {
272
+ "error": {
273
+ "message": "string",
274
+ "type": "string",
275
+ "code": "string"
276
+ }
277
+ },
278
+ "transform": "directMapping"
279
+ }
280
+ },
281
+ "specialFeatures": {
282
+ "multipleModels": {
283
+ "description": "Text Generation WebUI supports multiple model backends",
284
+ "handling": "Model selection handled through UI, API uses OpenAI format"
285
+ },
286
+ "extensions": {
287
+ "description": "Text Generation WebUI supports various extensions",
288
+ "handling": "Extensions provide additional features not in standard API"
289
+ },
290
+ "webInterface": {
291
+ "description": "Text Generation WebUI provides comprehensive web interface",
292
+ "handling": "Not relevant for API conversion"
293
+ }
294
+ }
295
+ }
@@ -0,0 +1,193 @@
1
+ {
2
+ "description": "Provider conversion reference table extracted from claude-code-router",
3
+ "version": "1.0",
4
+ "architecture": "agent-based",
5
+ "notes": "Shows how OpenAI-compatible requests are transformed to various provider formats",
6
+ "baseFormat": "OpenAI",
7
+ "providers": {
8
+ "openai": {
9
+ "name": "OpenAI",
10
+ "compatibility": "native",
11
+ "endpointMapping": {
12
+ "chat": "https://api.openai.com/v1/chat/completions",
13
+ "embeddings": "https://api.openai.com/v1/embeddings",
14
+ "models": "https://api.openai.com/v1/models"
15
+ },
16
+ "modelMapping": {
17
+ "direct": true,
18
+ "notes": "No model mapping needed - native OpenAI format"
19
+ },
20
+ "parameterMapping": {
21
+ "temperature": "temperature",
22
+ "max_tokens": "max_tokens",
23
+ "top_p": "top_p",
24
+ "frequency_penalty": "frequency_penalty",
25
+ "presence_penalty": "presence_penalty",
26
+ "stop": "stop",
27
+ "stream": "stream",
28
+ "tools": "tools",
29
+ "tool_choice": "tool_choice"
30
+ }
31
+ },
32
+ "anthropic": {
33
+ "name": "Anthropic Claude",
34
+ "compatibility": "transformed",
35
+ "endpointMapping": {
36
+ "chat": "https://api.anthropic.com/v1/messages",
37
+ "messages": "https://api.anthropic.com/v1/messages"
38
+ },
39
+ "modelMapping": {
40
+ "gpt-4o": "claude-3-5-sonnet-20241022",
41
+ "gpt-4o-mini": "claude-3-5-haiku-20241022",
42
+ "gpt-4-turbo": "claude-3-opus-20240229",
43
+ "gpt-4": "claude-3-sonnet-20240229",
44
+ "gpt-3.5-turbo": "claude-3-haiku-20240307"
45
+ },
46
+ "parameterMapping": {
47
+ "max_tokens": "max_tokens",
48
+ "temperature": "temperature",
49
+ "top_p": "top_p",
50
+ "stop": "stop_sequences",
51
+ "stream": "stream",
52
+ "tools": "tools",
53
+ "tool_choice": "tool_choice"
54
+ },
55
+ "differences": {
56
+ "messageStructure": "Uses content blocks instead of simple message array",
57
+ "toolFormat": "Uses tool_use/tool_result blocks instead of function calls",
58
+ "streaming": "Different event structure for streaming responses",
59
+ "usage": "Different usage reporting format"
60
+ }
61
+ },
62
+ "gemini": {
63
+ "name": "Google Gemini",
64
+ "compatibility": "transformed",
65
+ "endpointMapping": {
66
+ "chat": "https://generativelanguage.googleapis.com/v1beta/models/{model}:generateContent",
67
+ "stream": "https://generativelanguage.googleapis.com/v1beta/models/{model}:streamGenerateContent"
68
+ },
69
+ "modelMapping": {
70
+ "gpt-4o": "gemini-1.5-pro",
71
+ "gpt-4o-mini": "gemini-1.5-flash",
72
+ "gpt-4-turbo": "gemini-1.0-pro",
73
+ "gpt-4": "gemini-1.0-pro",
74
+ "gpt-3.5-turbo": "gemini-1.0-pro-latest"
75
+ },
76
+ "parameterMapping": {
77
+ "temperature": "generationConfig.temperature",
78
+ "max_tokens": "generationConfig.maxOutputTokens",
79
+ "top_p": "generationConfig.topP",
80
+ "top_k": "generationConfig.topK",
81
+ "stop": "generationConfig.stopSequences",
82
+ "stream": "stream",
83
+ "tools": "tools",
84
+ "tool_choice": "toolConfig"
85
+ },
86
+ "differences": {
87
+ "messageStructure": "Uses contents with parts array",
88
+ "roles": "Different role names (user/model/function)",
89
+ "toolFormat": "Uses functionCall/functionResponse parts",
90
+ "safety": "Built-in safety filtering with configurable thresholds",
91
+ "usage": "Usage metadata structure different"
92
+ }
93
+ },
94
+ "deepseek": {
95
+ "name": "DeepSeek",
96
+ "compatibility": "openai-compatible",
97
+ "endpointMapping": {
98
+ "chat": "https://api.deepseek.com/v1/chat/completions",
99
+ "models": "https://api.deepseek.com/v1/models"
100
+ },
101
+ "modelMapping": {
102
+ "gpt-4o": "deepseek-chat",
103
+ "gpt-4o-mini": "deepseek-chat",
104
+ "gpt-4-turbo": "deepseek-chat",
105
+ "gpt-4": "deepseek-chat",
106
+ "gpt-3.5-turbo": "deepseek-coder"
107
+ },
108
+ "parameterMapping": {
109
+ "temperature": "temperature",
110
+ "max_tokens": "max_tokens",
111
+ "top_p": "top_p",
112
+ "frequency_penalty": "frequency_penalty",
113
+ "presence_penalty": "presence_penalty",
114
+ "stop": "stop",
115
+ "stream": "stream",
116
+ "tools": "tools",
117
+ "tool_choice": "tool_choice"
118
+ },
119
+ "differences": {
120
+ "modelAvailability": "Limited model selection",
121
+ "features": "Some advanced features may not be supported",
122
+ "pricing": "Different pricing structure"
123
+ }
124
+ },
125
+ "openrouter": {
126
+ "name": "OpenRouter",
127
+ "compatibility": "openai-compatible",
128
+ "endpointMapping": {
129
+ "chat": "https://openrouter.ai/api/v1/chat/completions",
130
+ "models": "https://openrouter.ai/api/v1/models"
131
+ },
132
+ "modelMapping": {
133
+ "gpt-4o": "openai/gpt-4o",
134
+ "gpt-4o-mini": "openai/gpt-4o-mini",
135
+ "gpt-4-turbo": "openai/gpt-4-turbo",
136
+ "gpt-4": "openai/gpt-4",
137
+ "gpt-3.5-turbo": "openai/gpt-3.5-turbo"
138
+ },
139
+ "parameterMapping": {
140
+ "temperature": "temperature",
141
+ "max_tokens": "max_tokens",
142
+ "top_p": "top_p",
143
+ "frequency_penalty": "frequency_penalty",
144
+ "presence_penalty": "presence_penalty",
145
+ "stop": "stop",
146
+ "stream": "stream",
147
+ "tools": "tools",
148
+ "tool_choice": "tool_choice"
149
+ },
150
+ "differences": {
151
+ "routing": "Routes to multiple providers based on availability",
152
+ "models": "Access to multiple provider models through single API",
153
+ "pricing": "Unified pricing across providers",
154
+ "features": "Provider-specific feature support varies"
155
+ }
156
+ }
157
+ },
158
+ "commonTransformations": {
159
+ "authentication": {
160
+ "openai": "Bearer token in Authorization header",
161
+ "anthropic": "x-api-key header + anthropic-version",
162
+ "gemini": "API key as query parameter",
163
+ "deepseek": "Bearer token in Authorization header",
164
+ "openrouter": "Bearer token in Authorization header"
165
+ },
166
+ "errorHandling": {
167
+ "format": "Standardized error response format",
168
+ "codes": "HTTP status codes with provider-specific details",
169
+ "retry": "Exponential backoff for rate limits"
170
+ },
171
+ "streaming": {
172
+ "format": "Server-Sent Events (SSE)",
173
+ "chunking": "Different chunk structures per provider",
174
+ "encoding": "UTF-8 text encoding"
175
+ }
176
+ },
177
+ "usagePatterns": {
178
+ "tokenCounting": {
179
+ "openai": "Detailed token breakdown",
180
+ "anthropic": "Input/output token counts",
181
+ "gemini": "Prompt/candidate/total token counts",
182
+ "deepseek": "Similar to OpenAI format",
183
+ "openrouter": "Varies by underlying provider"
184
+ },
185
+ "rateLimiting": {
186
+ "openai": "Requests per minute + tokens per minute",
187
+ "anthropic": "Requests per minute + tokens per minute",
188
+ "gemini": "Requests per minute + tokens per minute",
189
+ "deepseek": "Requests per minute + tokens per minute",
190
+ "openrouter": "Varies by underlying provider"
191
+ }
192
+ }
193
+ }