@jsonstudio/rcc 0.89.1968 → 0.89.2195

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 (555) hide show
  1. package/README.md +22 -0
  2. package/config/file-line-limit-policy.json +21 -0
  3. package/configsamples/config.json +1 -1
  4. package/configsamples/config.v1.quickstart.sanitized.json +6 -6
  5. package/configsamples/provider/iflow/config.v1.json +1 -1
  6. package/dist/app/config-readers.d.ts +18 -0
  7. package/dist/app/config-readers.js +95 -0
  8. package/dist/app/config-readers.js.map +1 -0
  9. package/dist/app/index.d.ts +9 -0
  10. package/dist/app/index.js +8 -0
  11. package/dist/app/index.js.map +1 -0
  12. package/dist/app/shutdown.d.ts +32 -0
  13. package/dist/app/shutdown.js +41 -0
  14. package/dist/app/shutdown.js.map +1 -0
  15. package/dist/bootstrap/index.d.ts +7 -0
  16. package/dist/bootstrap/index.js +7 -0
  17. package/dist/bootstrap/index.js.map +1 -0
  18. package/dist/bootstrap/log-filter.d.ts +15 -0
  19. package/dist/bootstrap/log-filter.js +81 -0
  20. package/dist/bootstrap/log-filter.js.map +1 -0
  21. package/dist/build-info.js +2 -2
  22. package/dist/cli/commands/claude.js +6 -5
  23. package/dist/cli/commands/claude.js.map +1 -1
  24. package/dist/cli/commands/init/basic.d.ts +1 -7
  25. package/dist/cli/commands/init/basic.js +0 -79
  26. package/dist/cli/commands/init/basic.js.map +1 -1
  27. package/dist/cli/commands/init/prompt-utils.d.ts +7 -0
  28. package/dist/cli/commands/init/prompt-utils.js +80 -0
  29. package/dist/cli/commands/init/prompt-utils.js.map +1 -0
  30. package/dist/cli/commands/init/workflows.js +2 -1
  31. package/dist/cli/commands/init/workflows.js.map +1 -1
  32. package/dist/cli/commands/init.js +74 -2
  33. package/dist/cli/commands/init.js.map +1 -1
  34. package/dist/cli/commands/launcher/index.d.ts +7 -0
  35. package/dist/cli/commands/launcher/index.js +7 -0
  36. package/dist/cli/commands/launcher/index.js.map +1 -0
  37. package/dist/cli/commands/launcher/types.d.ts +112 -0
  38. package/dist/cli/commands/launcher/types.js +7 -0
  39. package/dist/cli/commands/launcher/types.js.map +1 -0
  40. package/dist/cli/commands/launcher/utils.d.ts +114 -0
  41. package/dist/cli/commands/launcher/utils.js +378 -0
  42. package/dist/cli/commands/launcher/utils.js.map +1 -0
  43. package/dist/cli/commands/launcher-kernel.d.ts +2 -74
  44. package/dist/cli/commands/launcher-kernel.js +141 -143
  45. package/dist/cli/commands/launcher-kernel.js.map +1 -1
  46. package/dist/cli/commands/start-types.d.ts +67 -0
  47. package/dist/cli/commands/start-types.js +3 -0
  48. package/dist/cli/commands/start-types.js.map +1 -0
  49. package/dist/cli/commands/start-utils.d.ts +19 -0
  50. package/dist/cli/commands/start-utils.js +78 -0
  51. package/dist/cli/commands/start-utils.js.map +1 -0
  52. package/dist/cli/commands/start.d.ts +2 -67
  53. package/dist/cli/commands/start.js +131 -47
  54. package/dist/cli/commands/start.js.map +1 -1
  55. package/dist/cli/commands/stop.js +13 -0
  56. package/dist/cli/commands/stop.js.map +1 -1
  57. package/dist/cli/commands/tmux-inject.js +1 -1
  58. package/dist/cli/commands/tmux-inject.js.map +1 -1
  59. package/dist/cli/config/init-config.js +60 -2
  60. package/dist/cli/config/init-config.js.map +1 -1
  61. package/dist/cli/config/init-provider-catalog.js +3 -1
  62. package/dist/cli/config/init-provider-catalog.js.map +1 -1
  63. package/dist/cli/config/precommand-default-script.d.ts +17 -0
  64. package/dist/cli/config/precommand-default-script.js +47 -0
  65. package/dist/cli/config/precommand-default-script.js.map +1 -0
  66. package/dist/cli.js +2 -0
  67. package/dist/cli.js.map +1 -1
  68. package/dist/client/gemini-cli/gemini-cli-protocol-client.js +55 -5
  69. package/dist/client/gemini-cli/gemini-cli-protocol-client.js.map +1 -1
  70. package/dist/commands/oauth.js +28 -4
  71. package/dist/commands/oauth.js.map +1 -1
  72. package/dist/commands/quota-daemon.js +12 -0
  73. package/dist/commands/quota-daemon.js.map +1 -1
  74. package/dist/configsamples/config.v1.quickstart.sanitized.json +6 -6
  75. package/dist/constants/index.d.ts +34 -0
  76. package/dist/constants/index.js +57 -0
  77. package/dist/constants/index.js.map +1 -1
  78. package/dist/docs/daemon-admin-ui.html +268 -11
  79. package/dist/error-handling/quiet-error-handling-center.js +19 -1
  80. package/dist/error-handling/quiet-error-handling-center.js.map +1 -1
  81. package/dist/index.js +233 -30
  82. package/dist/index.js.map +1 -1
  83. package/dist/manager/index.js +4 -4
  84. package/dist/manager/index.js.map +1 -1
  85. package/dist/manager/modules/quota/antigravity-quota-core.d.ts +26 -0
  86. package/dist/manager/modules/quota/antigravity-quota-core.js +23 -0
  87. package/dist/manager/modules/quota/antigravity-quota-core.js.map +1 -0
  88. package/dist/manager/modules/quota/antigravity-quota-helpers.d.ts +16 -0
  89. package/dist/manager/modules/quota/antigravity-quota-helpers.js +167 -0
  90. package/dist/manager/modules/quota/antigravity-quota-helpers.js.map +1 -0
  91. package/dist/manager/modules/quota/antigravity-quota-manager.d.ts +10 -39
  92. package/dist/manager/modules/quota/antigravity-quota-manager.js +167 -464
  93. package/dist/manager/modules/quota/antigravity-quota-manager.js.map +1 -1
  94. package/dist/manager/modules/quota/antigravity-quota-persistence.d.ts +20 -0
  95. package/dist/manager/modules/quota/antigravity-quota-persistence.js +139 -0
  96. package/dist/manager/modules/quota/antigravity-quota-persistence.js.map +1 -0
  97. package/dist/manager/modules/quota/antigravity-quota-runtime.d.ts +55 -0
  98. package/dist/manager/modules/quota/antigravity-quota-runtime.js +174 -0
  99. package/dist/manager/modules/quota/antigravity-quota-runtime.js.map +1 -0
  100. package/dist/manager/modules/quota/antigravity-quota-sync.d.ts +46 -0
  101. package/dist/manager/modules/quota/antigravity-quota-sync.js +162 -0
  102. package/dist/manager/modules/quota/antigravity-quota-sync.js.map +1 -0
  103. package/dist/manager/modules/quota/index.d.ts +1 -0
  104. package/dist/manager/modules/quota/provider-quota-daemon.error-helpers.d.ts +13 -0
  105. package/dist/manager/modules/quota/provider-quota-daemon.error-helpers.js +149 -0
  106. package/dist/manager/modules/quota/provider-quota-daemon.error-helpers.js.map +1 -0
  107. package/dist/manager/modules/quota/provider-quota-daemon.events.js +1 -148
  108. package/dist/manager/modules/quota/provider-quota-daemon.events.js.map +1 -1
  109. package/dist/manager/modules/quota/provider-quota-daemon.js.map +1 -1
  110. package/dist/manager/modules/quota/quota-adapter.d.ts +111 -0
  111. package/dist/manager/modules/quota/quota-adapter.js +325 -0
  112. package/dist/manager/modules/quota/quota-adapter.js.map +1 -0
  113. package/dist/manager/quota/provider-quota-center.d.ts +10 -0
  114. package/dist/manager/quota/provider-quota-center.js +15 -2
  115. package/dist/manager/quota/provider-quota-center.js.map +1 -1
  116. package/dist/modules/llmswitch/bridge/antigravity-signature.d.ts +28 -0
  117. package/dist/modules/llmswitch/bridge/antigravity-signature.js +180 -0
  118. package/dist/modules/llmswitch/bridge/antigravity-signature.js.map +1 -0
  119. package/dist/modules/llmswitch/bridge/index.d.ts +13 -0
  120. package/dist/modules/llmswitch/bridge/index.js +14 -0
  121. package/dist/modules/llmswitch/bridge/index.js.map +1 -0
  122. package/dist/modules/llmswitch/bridge/module-loader.d.ts +16 -0
  123. package/dist/modules/llmswitch/bridge/module-loader.js +59 -0
  124. package/dist/modules/llmswitch/bridge/module-loader.js.map +1 -0
  125. package/dist/modules/llmswitch/bridge/quota-manager.d.ts +8 -0
  126. package/dist/modules/llmswitch/bridge/quota-manager.js +37 -0
  127. package/dist/modules/llmswitch/bridge/quota-manager.js.map +1 -0
  128. package/dist/modules/llmswitch/bridge/response-converter.d.ts +11 -0
  129. package/dist/modules/llmswitch/bridge/response-converter.js +68 -0
  130. package/dist/modules/llmswitch/bridge/response-converter.js.map +1 -0
  131. package/dist/modules/llmswitch/bridge/routing-integrations.d.ts +12 -0
  132. package/dist/modules/llmswitch/bridge/routing-integrations.js +56 -0
  133. package/dist/modules/llmswitch/bridge/routing-integrations.js.map +1 -0
  134. package/dist/modules/llmswitch/bridge/runtime-integrations.d.ts +34 -0
  135. package/dist/modules/llmswitch/bridge/runtime-integrations.js +87 -0
  136. package/dist/modules/llmswitch/bridge/runtime-integrations.js.map +1 -0
  137. package/dist/modules/llmswitch/bridge/snapshot-recorder.d.ts +13 -0
  138. package/dist/modules/llmswitch/bridge/snapshot-recorder.js +484 -0
  139. package/dist/modules/llmswitch/bridge/snapshot-recorder.js.map +1 -0
  140. package/dist/modules/llmswitch/bridge/state-integrations.d.ts +59 -0
  141. package/dist/modules/llmswitch/bridge/state-integrations.js +264 -0
  142. package/dist/modules/llmswitch/bridge/state-integrations.js.map +1 -0
  143. package/dist/modules/llmswitch/bridge.d.ts +14 -131
  144. package/dist/modules/llmswitch/bridge.js +14 -834
  145. package/dist/modules/llmswitch/bridge.js.map +1 -1
  146. package/dist/modules/pipeline/types/provider-config-types.d.ts +240 -0
  147. package/dist/modules/pipeline/types/provider-config-types.js +2 -0
  148. package/dist/modules/pipeline/types/provider-config-types.js.map +1 -0
  149. package/dist/modules/pipeline/types/provider-types.d.ts +2 -239
  150. package/dist/modules/pipeline/types/provider-types.js +1 -1
  151. package/dist/modules/pipeline/types/provider-types.js.map +1 -1
  152. package/dist/modules/pipeline/utils/debug-logger.js +3 -5
  153. package/dist/modules/pipeline/utils/debug-logger.js.map +1 -1
  154. package/dist/providers/auth/apikey-auth.d.ts +57 -1
  155. package/dist/providers/auth/apikey-auth.js +131 -1
  156. package/dist/providers/auth/apikey-auth.js.map +1 -1
  157. package/dist/providers/auth/oauth-lifecycle/error-detection.d.ts +8 -0
  158. package/dist/providers/auth/oauth-lifecycle/error-detection.js +71 -0
  159. package/dist/providers/auth/oauth-lifecycle/error-detection.js.map +1 -0
  160. package/dist/providers/auth/oauth-lifecycle/index.d.ts +10 -0
  161. package/dist/providers/auth/oauth-lifecycle/index.js +11 -0
  162. package/dist/providers/auth/oauth-lifecycle/index.js.map +1 -0
  163. package/dist/providers/auth/oauth-lifecycle/path-resolver.d.ts +18 -0
  164. package/dist/providers/auth/oauth-lifecycle/path-resolver.js +121 -0
  165. package/dist/providers/auth/oauth-lifecycle/path-resolver.js.map +1 -0
  166. package/dist/providers/auth/oauth-lifecycle/throttle.d.ts +22 -0
  167. package/dist/providers/auth/oauth-lifecycle/throttle.js +37 -0
  168. package/dist/providers/auth/oauth-lifecycle/throttle.js.map +1 -0
  169. package/dist/providers/auth/oauth-lifecycle/token-helpers.d.ts +36 -0
  170. package/dist/providers/auth/oauth-lifecycle/token-helpers.js +127 -0
  171. package/dist/providers/auth/oauth-lifecycle/token-helpers.js.map +1 -0
  172. package/dist/providers/auth/oauth-lifecycle/token-io.d.ts +14 -0
  173. package/dist/providers/auth/oauth-lifecycle/token-io.js +151 -0
  174. package/dist/providers/auth/oauth-lifecycle/token-io.js.map +1 -0
  175. package/dist/providers/auth/oauth-lifecycle.js +70 -446
  176. package/dist/providers/auth/oauth-lifecycle.js.map +1 -1
  177. package/dist/providers/auth/oauth-repair-cooldown.js +8 -3
  178. package/dist/providers/auth/oauth-repair-cooldown.js.map +1 -1
  179. package/dist/providers/auth/oauth-repair-env.js +5 -3
  180. package/dist/providers/auth/oauth-repair-env.js.map +1 -1
  181. package/dist/providers/auth/oauth-token-utils.d.ts +61 -0
  182. package/dist/providers/auth/oauth-token-utils.js +187 -0
  183. package/dist/providers/auth/oauth-token-utils.js.map +1 -0
  184. package/dist/providers/auth/oauth-utils/camoufox-helper.d.ts +21 -0
  185. package/dist/providers/auth/oauth-utils/camoufox-helper.js +82 -0
  186. package/dist/providers/auth/oauth-utils/camoufox-helper.js.map +1 -0
  187. package/dist/providers/auth/oauth-utils/error-extraction.d.ts +17 -0
  188. package/dist/providers/auth/oauth-utils/error-extraction.js +80 -0
  189. package/dist/providers/auth/oauth-utils/error-extraction.js.map +1 -0
  190. package/dist/providers/auth/oauth-utils/index.d.ts +7 -0
  191. package/dist/providers/auth/oauth-utils/index.js +8 -0
  192. package/dist/providers/auth/oauth-utils/index.js.map +1 -0
  193. package/dist/providers/auth/token-refresh/index.d.ts +6 -0
  194. package/dist/providers/auth/token-refresh/index.js +7 -0
  195. package/dist/providers/auth/token-refresh/index.js.map +1 -0
  196. package/dist/providers/auth/token-refresh/token-state.d.ts +17 -0
  197. package/dist/providers/auth/token-refresh/token-state.js +30 -0
  198. package/dist/providers/auth/token-refresh/token-state.js.map +1 -0
  199. package/dist/providers/auth/token-storage/index.d.ts +7 -0
  200. package/dist/providers/auth/token-storage/index.js +8 -0
  201. package/dist/providers/auth/token-storage/index.js.map +1 -0
  202. package/dist/providers/auth/token-storage/token-file-resolver.d.ts +12 -0
  203. package/dist/providers/auth/token-storage/token-file-resolver.js +117 -0
  204. package/dist/providers/auth/token-storage/token-file-resolver.js.map +1 -0
  205. package/dist/providers/auth/token-storage/token-persistence.d.ts +22 -0
  206. package/dist/providers/auth/token-storage/token-persistence.js +86 -0
  207. package/dist/providers/auth/token-storage/token-persistence.js.map +1 -0
  208. package/dist/providers/auth/tokenfile-auth.js +12 -9
  209. package/dist/providers/auth/tokenfile-auth.js.map +1 -1
  210. package/dist/providers/core/api/provider-config.d.ts +8 -0
  211. package/dist/providers/core/config/camoufox-launcher.d.ts +1 -0
  212. package/dist/providers/core/config/camoufox-launcher.js +40 -9
  213. package/dist/providers/core/config/camoufox-launcher.js.map +1 -1
  214. package/dist/providers/core/config/oauth-flows.js +7 -2
  215. package/dist/providers/core/config/oauth-flows.js.map +1 -1
  216. package/dist/providers/core/config/provider-debug-hooks.d.ts +0 -12
  217. package/dist/providers/core/config/provider-debug-hooks.js +16 -56
  218. package/dist/providers/core/config/provider-debug-hooks.js.map +1 -1
  219. package/dist/providers/core/config/provider-debug-output-utils.d.ts +38 -0
  220. package/dist/providers/core/config/provider-debug-output-utils.js +46 -0
  221. package/dist/providers/core/config/provider-debug-output-utils.js.map +1 -0
  222. package/dist/providers/core/config/provider-oauth-configs.js +13 -9
  223. package/dist/providers/core/config/provider-oauth-configs.js.map +1 -1
  224. package/dist/providers/core/runtime/antigravity-request-type.d.ts +2 -0
  225. package/dist/providers/core/runtime/antigravity-request-type.js +126 -0
  226. package/dist/providers/core/runtime/antigravity-request-type.js.map +1 -0
  227. package/dist/providers/core/runtime/base-provider-runtime-helpers.d.ts +27 -0
  228. package/dist/providers/core/runtime/base-provider-runtime-helpers.js +105 -0
  229. package/dist/providers/core/runtime/base-provider-runtime-helpers.js.map +1 -0
  230. package/dist/providers/core/runtime/base-provider-series-cooldown.d.ts +19 -0
  231. package/dist/providers/core/runtime/base-provider-series-cooldown.js +363 -0
  232. package/dist/providers/core/runtime/base-provider-series-cooldown.js.map +1 -0
  233. package/dist/providers/core/runtime/base-provider.d.ts +4 -35
  234. package/dist/providers/core/runtime/base-provider.js +20 -501
  235. package/dist/providers/core/runtime/base-provider.js.map +1 -1
  236. package/dist/providers/core/runtime/deepseek-http-provider-helpers.d.ts +32 -0
  237. package/dist/providers/core/runtime/deepseek-http-provider-helpers.js +301 -0
  238. package/dist/providers/core/runtime/deepseek-http-provider-helpers.js.map +1 -0
  239. package/dist/providers/core/runtime/deepseek-http-provider.d.ts +0 -3
  240. package/dist/providers/core/runtime/deepseek-http-provider.js +5 -127
  241. package/dist/providers/core/runtime/deepseek-http-provider.js.map +1 -1
  242. package/dist/providers/core/runtime/deepseek-session-pow-helpers.d.ts +21 -0
  243. package/dist/providers/core/runtime/deepseek-session-pow-helpers.js +99 -0
  244. package/dist/providers/core/runtime/deepseek-session-pow-helpers.js.map +1 -0
  245. package/dist/providers/core/runtime/deepseek-session-pow.js +13 -108
  246. package/dist/providers/core/runtime/deepseek-session-pow.js.map +1 -1
  247. package/dist/providers/core/runtime/gemini-cli-http-provider.d.ts +0 -15
  248. package/dist/providers/core/runtime/gemini-cli-http-provider.js +13 -303
  249. package/dist/providers/core/runtime/gemini-cli-http-provider.js.map +1 -1
  250. package/dist/providers/core/runtime/gemini-cli-response-postprocessor.d.ts +9 -0
  251. package/dist/providers/core/runtime/gemini-cli-response-postprocessor.js +85 -0
  252. package/dist/providers/core/runtime/gemini-cli-response-postprocessor.js.map +1 -0
  253. package/dist/providers/core/runtime/gemini-http-provider.js +2 -2
  254. package/dist/providers/core/runtime/gemini-http-provider.js.map +1 -1
  255. package/dist/providers/core/runtime/gemini-sse-normalizer.d.ts +25 -0
  256. package/dist/providers/core/runtime/gemini-sse-normalizer.js +159 -0
  257. package/dist/providers/core/runtime/gemini-sse-normalizer.js.map +1 -0
  258. package/dist/providers/core/runtime/http-request-executor.js +1 -48
  259. package/dist/providers/core/runtime/http-request-executor.js.map +1 -1
  260. package/dist/providers/core/runtime/http-transport-provider.d.ts +2 -48
  261. package/dist/providers/core/runtime/http-transport-provider.js +158 -1273
  262. package/dist/providers/core/runtime/http-transport-provider.js.map +1 -1
  263. package/dist/providers/core/runtime/provider-bootstrap-utils.d.ts +20 -0
  264. package/dist/providers/core/runtime/provider-bootstrap-utils.js +78 -0
  265. package/dist/providers/core/runtime/provider-bootstrap-utils.js.map +1 -0
  266. package/dist/providers/core/runtime/provider-factory-helpers.d.ts +19 -0
  267. package/dist/providers/core/runtime/provider-factory-helpers.js +203 -0
  268. package/dist/providers/core/runtime/provider-factory-helpers.js.map +1 -0
  269. package/dist/providers/core/runtime/provider-factory.d.ts +9 -7
  270. package/dist/providers/core/runtime/provider-factory.js +57 -214
  271. package/dist/providers/core/runtime/provider-factory.js.map +1 -1
  272. package/dist/providers/core/runtime/provider-family-profile-utils.d.ts +23 -0
  273. package/dist/providers/core/runtime/provider-family-profile-utils.js +57 -0
  274. package/dist/providers/core/runtime/provider-family-profile-utils.js.map +1 -0
  275. package/dist/providers/core/runtime/provider-http-executor-utils.d.ts +32 -0
  276. package/dist/providers/core/runtime/provider-http-executor-utils.js +92 -0
  277. package/dist/providers/core/runtime/provider-http-executor-utils.js.map +1 -0
  278. package/dist/providers/core/runtime/provider-iflow-business-error-utils.d.ts +15 -0
  279. package/dist/providers/core/runtime/provider-iflow-business-error-utils.js +49 -0
  280. package/dist/providers/core/runtime/provider-iflow-business-error-utils.js.map +1 -0
  281. package/dist/providers/core/runtime/provider-request-executor-deps-factory.d.ts +29 -0
  282. package/dist/providers/core/runtime/provider-request-executor-deps-factory.js +41 -0
  283. package/dist/providers/core/runtime/provider-request-executor-deps-factory.js.map +1 -0
  284. package/dist/providers/core/runtime/provider-request-header-orchestrator.d.ts +30 -0
  285. package/dist/providers/core/runtime/provider-request-header-orchestrator.js +91 -0
  286. package/dist/providers/core/runtime/provider-request-header-orchestrator.js.map +1 -0
  287. package/dist/providers/core/runtime/provider-request-preprocessor.d.ts +5 -0
  288. package/dist/providers/core/runtime/provider-request-preprocessor.js +39 -0
  289. package/dist/providers/core/runtime/provider-request-preprocessor.js.map +1 -0
  290. package/dist/providers/core/runtime/provider-request-shaping-utils.d.ts +37 -0
  291. package/dist/providers/core/runtime/provider-request-shaping-utils.js +65 -0
  292. package/dist/providers/core/runtime/provider-request-shaping-utils.js.map +1 -0
  293. package/dist/providers/core/runtime/provider-response-postprocessor.d.ts +7 -0
  294. package/dist/providers/core/runtime/provider-response-postprocessor.js +28 -0
  295. package/dist/providers/core/runtime/provider-response-postprocessor.js.map +1 -0
  296. package/dist/providers/core/runtime/provider-runtime-utils.d.ts +16 -0
  297. package/dist/providers/core/runtime/provider-runtime-utils.js +51 -0
  298. package/dist/providers/core/runtime/provider-runtime-utils.js.map +1 -0
  299. package/dist/providers/core/runtime/responses-provider-helpers.d.ts +37 -0
  300. package/dist/providers/core/runtime/responses-provider-helpers.js +212 -0
  301. package/dist/providers/core/runtime/responses-provider-helpers.js.map +1 -0
  302. package/dist/providers/core/runtime/responses-provider.d.ts +0 -10
  303. package/dist/providers/core/runtime/responses-provider.js +14 -224
  304. package/dist/providers/core/runtime/responses-provider.js.map +1 -1
  305. package/dist/providers/core/runtime/runtime-endpoint-resolver.d.ts +21 -0
  306. package/dist/providers/core/runtime/runtime-endpoint-resolver.js +64 -0
  307. package/dist/providers/core/runtime/runtime-endpoint-resolver.js.map +1 -0
  308. package/dist/providers/core/runtime/service-profile-resolver.d.ts +29 -0
  309. package/dist/providers/core/runtime/service-profile-resolver.js +88 -0
  310. package/dist/providers/core/runtime/service-profile-resolver.js.map +1 -0
  311. package/dist/providers/core/runtime/transport/auth-mode-utils.d.ts +13 -0
  312. package/dist/providers/core/runtime/transport/auth-mode-utils.js +43 -0
  313. package/dist/providers/core/runtime/transport/auth-mode-utils.js.map +1 -0
  314. package/dist/providers/core/runtime/transport/auth-provider-factory.d.ts +37 -0
  315. package/dist/providers/core/runtime/transport/auth-provider-factory.js +131 -0
  316. package/dist/providers/core/runtime/transport/auth-provider-factory.js.map +1 -0
  317. package/dist/providers/core/runtime/transport/header-utils.d.ts +15 -0
  318. package/dist/providers/core/runtime/transport/header-utils.js +85 -0
  319. package/dist/providers/core/runtime/transport/header-utils.js.map +1 -0
  320. package/dist/providers/core/runtime/transport/iflow-signer.d.ts +12 -0
  321. package/dist/providers/core/runtime/transport/iflow-signer.js +63 -0
  322. package/dist/providers/core/runtime/transport/iflow-signer.js.map +1 -0
  323. package/dist/providers/core/runtime/transport/index.d.ts +15 -0
  324. package/dist/providers/core/runtime/transport/index.js +16 -0
  325. package/dist/providers/core/runtime/transport/index.js.map +1 -0
  326. package/dist/providers/core/runtime/transport/oauth-header-preflight.d.ts +12 -0
  327. package/dist/providers/core/runtime/transport/oauth-header-preflight.js +56 -0
  328. package/dist/providers/core/runtime/transport/oauth-header-preflight.js.map +1 -0
  329. package/dist/providers/core/runtime/transport/oauth-recovery-handler.d.ts +34 -0
  330. package/dist/providers/core/runtime/transport/oauth-recovery-handler.js +126 -0
  331. package/dist/providers/core/runtime/transport/oauth-recovery-handler.js.map +1 -0
  332. package/dist/providers/core/runtime/transport/provider-payload-utils.d.ts +21 -0
  333. package/dist/providers/core/runtime/transport/provider-payload-utils.js +88 -0
  334. package/dist/providers/core/runtime/transport/provider-payload-utils.js.map +1 -0
  335. package/dist/providers/core/runtime/transport/request-header-builder.d.ts +24 -0
  336. package/dist/providers/core/runtime/transport/request-header-builder.js +90 -0
  337. package/dist/providers/core/runtime/transport/request-header-builder.js.map +1 -0
  338. package/dist/providers/core/runtime/transport/runtime-detector.d.ts +22 -0
  339. package/dist/providers/core/runtime/transport/runtime-detector.js +63 -0
  340. package/dist/providers/core/runtime/transport/runtime-detector.js.map +1 -0
  341. package/dist/providers/core/runtime/transport/session-header-utils.d.ts +8 -0
  342. package/dist/providers/core/runtime/transport/session-header-utils.js +72 -0
  343. package/dist/providers/core/runtime/transport/session-header-utils.js.map +1 -0
  344. package/dist/providers/core/runtime/vision-debug-utils.d.ts +2 -0
  345. package/dist/providers/core/runtime/vision-debug-utils.js +31 -0
  346. package/dist/providers/core/runtime/vision-debug-utils.js.map +1 -1
  347. package/dist/providers/core/strategies/oauth-auth-code-flow.d.ts +13 -0
  348. package/dist/providers/core/strategies/oauth-auth-code-flow.js +272 -55
  349. package/dist/providers/core/strategies/oauth-auth-code-flow.js.map +1 -1
  350. package/dist/providers/core/utils/snapshot-writer-buffer.d.ts +13 -0
  351. package/dist/providers/core/utils/snapshot-writer-buffer.js +39 -0
  352. package/dist/providers/core/utils/snapshot-writer-buffer.js.map +1 -0
  353. package/dist/providers/core/utils/snapshot-writer.js +75 -54
  354. package/dist/providers/core/utils/snapshot-writer.js.map +1 -1
  355. package/dist/providers/profile/families/antigravity-profile.js +2 -10
  356. package/dist/providers/profile/families/antigravity-profile.js.map +1 -1
  357. package/dist/providers/profile/families/deepseek-profile.d.ts +2 -0
  358. package/dist/providers/profile/families/deepseek-profile.js +110 -0
  359. package/dist/providers/profile/families/deepseek-profile.js.map +1 -0
  360. package/dist/providers/profile/families/iflow-profile.js +89 -10
  361. package/dist/providers/profile/families/iflow-profile.js.map +1 -1
  362. package/dist/providers/profile/provider-profile-loader.d.ts +5 -0
  363. package/dist/providers/profile/provider-profile-loader.js +35 -0
  364. package/dist/providers/profile/provider-profile-loader.js.map +1 -1
  365. package/dist/providers/profile/provider-profile.d.ts +16 -1
  366. package/dist/runtime/runtime-flags.js +1 -1
  367. package/dist/runtime/runtime-flags.js.map +1 -1
  368. package/dist/runtime/wasm-runtime/index.d.ts +56 -0
  369. package/dist/runtime/wasm-runtime/index.js +69 -0
  370. package/dist/runtime/wasm-runtime/index.js.map +1 -0
  371. package/dist/scripts/camoufox/launch-auth.mjs +158 -10
  372. package/dist/server/handlers/handler-response-utils.d.ts +13 -0
  373. package/dist/server/handlers/handler-response-utils.js +427 -0
  374. package/dist/server/handlers/handler-response-utils.js.map +1 -0
  375. package/dist/server/handlers/handler-utils.d.ts +2 -11
  376. package/dist/server/handlers/handler-utils.js +21 -421
  377. package/dist/server/handlers/handler-utils.js.map +1 -1
  378. package/dist/server/runtime/http-server/clock-client-reaper.d.ts +23 -0
  379. package/dist/server/runtime/http-server/clock-client-reaper.js +159 -0
  380. package/dist/server/runtime/http-server/clock-client-reaper.js.map +1 -0
  381. package/dist/server/runtime/http-server/clock-client-registry-utils.d.ts +87 -0
  382. package/dist/server/runtime/http-server/clock-client-registry-utils.js +276 -0
  383. package/dist/server/runtime/http-server/clock-client-registry-utils.js.map +1 -0
  384. package/dist/server/runtime/http-server/clock-client-registry.d.ts +5 -50
  385. package/dist/server/runtime/http-server/clock-client-registry.js +74 -320
  386. package/dist/server/runtime/http-server/clock-client-registry.js.map +1 -1
  387. package/dist/server/runtime/http-server/clock-client-route-utils.d.ts +12 -0
  388. package/dist/server/runtime/http-server/clock-client-route-utils.js +210 -0
  389. package/dist/server/runtime/http-server/clock-client-route-utils.js.map +1 -0
  390. package/dist/server/runtime/http-server/clock-client-routes.js +27 -201
  391. package/dist/server/runtime/http-server/clock-client-routes.js.map +1 -1
  392. package/dist/server/runtime/http-server/clock-daemon-log-throttle.d.ts +12 -0
  393. package/dist/server/runtime/http-server/clock-daemon-log-throttle.js +56 -0
  394. package/dist/server/runtime/http-server/clock-daemon-log-throttle.js.map +1 -0
  395. package/dist/server/runtime/http-server/daemon-admin/control-handler.js +143 -14
  396. package/dist/server/runtime/http-server/daemon-admin/control-handler.js.map +1 -1
  397. package/dist/server/runtime/http-server/daemon-admin/credentials-handler-utils.d.ts +19 -0
  398. package/dist/server/runtime/http-server/daemon-admin/credentials-handler-utils.js +107 -0
  399. package/dist/server/runtime/http-server/daemon-admin/credentials-handler-utils.js.map +1 -0
  400. package/dist/server/runtime/http-server/daemon-admin/credentials-handler.js +2 -104
  401. package/dist/server/runtime/http-server/daemon-admin/credentials-handler.js.map +1 -1
  402. package/dist/server/runtime/http-server/daemon-admin/providers-handler-routing-utils.d.ts +28 -0
  403. package/dist/server/runtime/http-server/daemon-admin/providers-handler-routing-utils.js +298 -0
  404. package/dist/server/runtime/http-server/daemon-admin/providers-handler-routing-utils.js.map +1 -0
  405. package/dist/server/runtime/http-server/daemon-admin/providers-handler-utils.d.ts +22 -0
  406. package/dist/server/runtime/http-server/daemon-admin/providers-handler-utils.js +211 -0
  407. package/dist/server/runtime/http-server/daemon-admin/providers-handler-utils.js.map +1 -0
  408. package/dist/server/runtime/http-server/daemon-admin/providers-handler.js +25 -454
  409. package/dist/server/runtime/http-server/daemon-admin/providers-handler.js.map +1 -1
  410. package/dist/server/runtime/http-server/daemon-admin/quota-handler.js +81 -32
  411. package/dist/server/runtime/http-server/daemon-admin/quota-handler.js.map +1 -1
  412. package/dist/server/runtime/http-server/daemon-admin/routecodex-x7e-gate.d.ts +22 -0
  413. package/dist/server/runtime/http-server/daemon-admin/routecodex-x7e-gate.js +70 -0
  414. package/dist/server/runtime/http-server/daemon-admin/routecodex-x7e-gate.js.map +1 -0
  415. package/dist/server/runtime/http-server/executor/antigravity-detector.d.ts +34 -0
  416. package/dist/server/runtime/http-server/executor/antigravity-detector.js +118 -0
  417. package/dist/server/runtime/http-server/executor/antigravity-detector.js.map +1 -0
  418. package/dist/server/runtime/http-server/executor/env-config.d.ts +13 -0
  419. package/dist/server/runtime/http-server/executor/env-config.js +20 -0
  420. package/dist/server/runtime/http-server/executor/env-config.js.map +1 -0
  421. package/dist/server/runtime/http-server/executor/index.d.ts +11 -0
  422. package/dist/server/runtime/http-server/executor/index.js +18 -0
  423. package/dist/server/runtime/http-server/executor/index.js.map +1 -0
  424. package/dist/server/runtime/http-server/executor/provider-request-context.d.ts +20 -0
  425. package/dist/server/runtime/http-server/executor/provider-request-context.js +38 -0
  426. package/dist/server/runtime/http-server/executor/provider-request-context.js.map +1 -0
  427. package/dist/server/runtime/http-server/executor/provider-response-converter.d.ts +23 -0
  428. package/dist/server/runtime/http-server/executor/provider-response-converter.js +337 -0
  429. package/dist/server/runtime/http-server/executor/provider-response-converter.js.map +1 -0
  430. package/dist/server/runtime/http-server/executor/provider-response-utils.d.ts +8 -0
  431. package/dist/server/runtime/http-server/executor/provider-response-utils.js +93 -0
  432. package/dist/server/runtime/http-server/executor/provider-response-utils.js.map +1 -0
  433. package/dist/server/runtime/http-server/executor/provider-runtime-resolver.d.ts +23 -0
  434. package/dist/server/runtime/http-server/executor/provider-runtime-resolver.js +85 -0
  435. package/dist/server/runtime/http-server/executor/provider-runtime-resolver.js.map +1 -0
  436. package/dist/server/runtime/http-server/executor/request-executor-core-utils.d.ts +7 -0
  437. package/dist/server/runtime/http-server/executor/request-executor-core-utils.js +39 -0
  438. package/dist/server/runtime/http-server/executor/request-executor-core-utils.js.map +1 -0
  439. package/dist/server/runtime/http-server/executor/request-retry-helpers.d.ts +16 -0
  440. package/dist/server/runtime/http-server/executor/request-retry-helpers.js +218 -0
  441. package/dist/server/runtime/http-server/executor/request-retry-helpers.js.map +1 -0
  442. package/dist/server/runtime/http-server/executor/retry-engine.d.ts +21 -0
  443. package/dist/server/runtime/http-server/executor/retry-engine.js +73 -0
  444. package/dist/server/runtime/http-server/executor/retry-engine.js.map +1 -0
  445. package/dist/server/runtime/http-server/executor/sse-error-handler.d.ts +14 -0
  446. package/dist/server/runtime/http-server/executor/sse-error-handler.js +127 -0
  447. package/dist/server/runtime/http-server/executor/sse-error-handler.js.map +1 -0
  448. package/dist/server/runtime/http-server/executor/usage-aggregator.d.ts +39 -0
  449. package/dist/server/runtime/http-server/executor/usage-aggregator.js +177 -0
  450. package/dist/server/runtime/http-server/executor/usage-aggregator.js.map +1 -0
  451. package/dist/server/runtime/http-server/executor/usage-logger.d.ts +7 -0
  452. package/dist/server/runtime/http-server/executor/usage-logger.js +13 -0
  453. package/dist/server/runtime/http-server/executor/usage-logger.js.map +1 -0
  454. package/dist/server/runtime/http-server/executor/utils.d.ts +21 -0
  455. package/dist/server/runtime/http-server/executor/utils.js +62 -0
  456. package/dist/server/runtime/http-server/executor/utils.js.map +1 -0
  457. package/dist/server/runtime/http-server/executor-metadata.js +83 -2
  458. package/dist/server/runtime/http-server/executor-metadata.js.map +1 -1
  459. package/dist/server/runtime/http-server/executor-response.js +17 -9
  460. package/dist/server/runtime/http-server/executor-response.js.map +1 -1
  461. package/dist/server/runtime/http-server/http-server-bootstrap.d.ts +31 -0
  462. package/dist/server/runtime/http-server/http-server-bootstrap.js +367 -0
  463. package/dist/server/runtime/http-server/http-server-bootstrap.js.map +1 -0
  464. package/dist/server/runtime/http-server/http-server-clock-daemon.d.ts +5 -0
  465. package/dist/server/runtime/http-server/http-server-clock-daemon.js +242 -0
  466. package/dist/server/runtime/http-server/http-server-clock-daemon.js.map +1 -0
  467. package/dist/server/runtime/http-server/http-server-legacy-pipeline.d.ts +2 -0
  468. package/dist/server/runtime/http-server/http-server-legacy-pipeline.js +65 -0
  469. package/dist/server/runtime/http-server/http-server-legacy-pipeline.js.map +1 -0
  470. package/dist/server/runtime/http-server/http-server-lifecycle.d.ts +27 -0
  471. package/dist/server/runtime/http-server/http-server-lifecycle.js +285 -0
  472. package/dist/server/runtime/http-server/http-server-lifecycle.js.map +1 -0
  473. package/dist/server/runtime/http-server/http-server-runtime-providers.d.ts +10 -0
  474. package/dist/server/runtime/http-server/http-server-runtime-providers.js +415 -0
  475. package/dist/server/runtime/http-server/http-server-runtime-providers.js.map +1 -0
  476. package/dist/server/runtime/http-server/http-server-runtime-setup.d.ts +2 -0
  477. package/dist/server/runtime/http-server/http-server-runtime-setup.js +93 -0
  478. package/dist/server/runtime/http-server/http-server-runtime-setup.js.map +1 -0
  479. package/dist/server/runtime/http-server/index.d.ts +2 -46
  480. package/dist/server/runtime/http-server/index.js +96 -2615
  481. package/dist/server/runtime/http-server/index.js.map +1 -1
  482. package/dist/server/runtime/http-server/request-executor.d.ts +8 -21
  483. package/dist/server/runtime/http-server/request-executor.js +94 -956
  484. package/dist/server/runtime/http-server/request-executor.js.map +1 -1
  485. package/dist/server/runtime/http-server/routes.js +2 -2
  486. package/dist/server/runtime/http-server/routes.js.map +1 -1
  487. package/dist/server/runtime/http-server/servertool-admin-state.d.ts +42 -0
  488. package/dist/server/runtime/http-server/servertool-admin-state.js +210 -0
  489. package/dist/server/runtime/http-server/servertool-admin-state.js.map +1 -0
  490. package/dist/server/runtime/http-server/stats-manager-internals.d.ts +96 -0
  491. package/dist/server/runtime/http-server/stats-manager-internals.js +311 -0
  492. package/dist/server/runtime/http-server/stats-manager-internals.js.map +1 -0
  493. package/dist/server/runtime/http-server/stats-manager-table.d.ts +6 -0
  494. package/dist/server/runtime/http-server/stats-manager-table.js +135 -0
  495. package/dist/server/runtime/http-server/stats-manager-table.js.map +1 -0
  496. package/dist/server/runtime/http-server/stats-manager.d.ts +0 -23
  497. package/dist/server/runtime/http-server/stats-manager.js +95 -483
  498. package/dist/server/runtime/http-server/stats-manager.js.map +1 -1
  499. package/dist/server/utils/client-connection-state.js +61 -0
  500. package/dist/server/utils/client-connection-state.js.map +1 -1
  501. package/dist/server/utils/request-id-manager.d.ts +6 -0
  502. package/dist/server/utils/request-id-manager.js +105 -15
  503. package/dist/server/utils/request-id-manager.js.map +1 -1
  504. package/dist/server/utils/stage-logger.js +14 -4
  505. package/dist/server/utils/stage-logger.js.map +1 -1
  506. package/dist/server-lifecycle/index.d.ts +6 -0
  507. package/dist/server-lifecycle/index.js +7 -0
  508. package/dist/server-lifecycle/index.js.map +1 -0
  509. package/dist/server-lifecycle/port-utils.d.ts +18 -0
  510. package/dist/server-lifecycle/port-utils.js +204 -0
  511. package/dist/server-lifecycle/port-utils.js.map +1 -0
  512. package/dist/sharedmodule/process-snapshot.d.ts +26 -0
  513. package/dist/sharedmodule/process-snapshot.js +141 -0
  514. package/dist/sharedmodule/process-snapshot.js.map +1 -0
  515. package/dist/token-daemon/index.js +10 -3
  516. package/dist/token-daemon/index.js.map +1 -1
  517. package/dist/token-daemon/token-daemon.js +9 -11
  518. package/dist/token-daemon/token-daemon.js.map +1 -1
  519. package/dist/token-daemon/token-utils.d.ts +1 -1
  520. package/dist/token-daemon/token-utils.js +19 -3
  521. package/dist/token-daemon/token-utils.js.map +1 -1
  522. package/dist/tools/semantic-replay-snapshot-loader.d.ts +4 -0
  523. package/dist/tools/semantic-replay-snapshot-loader.js +396 -0
  524. package/dist/tools/semantic-replay-snapshot-loader.js.map +1 -0
  525. package/dist/tools/semantic-replay.js +2 -393
  526. package/dist/tools/semantic-replay.js.map +1 -1
  527. package/dist/utils/daemon-stop-intent.d.ts +17 -0
  528. package/dist/utils/daemon-stop-intent.js +104 -0
  529. package/dist/utils/daemon-stop-intent.js.map +1 -0
  530. package/dist/utils/key-429-tracker.js +6 -5
  531. package/dist/utils/key-429-tracker.js.map +1 -1
  532. package/dist/utils/pipeline-health-manager.js +7 -6
  533. package/dist/utils/pipeline-health-manager.js.map +1 -1
  534. package/dist/utils/process-lifecycle-logger.js +45 -1
  535. package/dist/utils/process-lifecycle-logger.js.map +1 -1
  536. package/dist/utils/runtime-exit-forensics.d.ts +2 -2
  537. package/dist/utils/runtime-exit-forensics.js +10 -5
  538. package/dist/utils/runtime-exit-forensics.js.map +1 -1
  539. package/dist/utils/snapshot-writer.js +3 -3
  540. package/dist/utils/snapshot-writer.js.map +1 -1
  541. package/docs/QUOTA_MANAGER_V3.md +3 -0
  542. package/docs/VIRTUAL_ROUTER_PRIORITY_AND_HEALTH.md +114 -0
  543. package/docs/daemon-admin-ui.html +268 -11
  544. package/docs/file-line-limit-gate.md +30 -0
  545. package/docs/refactoring/host-164.3-responsibility-migration.md +62 -0
  546. package/docs/release-iflow-400-gate.md +58 -0
  547. package/docs/replay-evidence-iflow-400.txt +33 -0
  548. package/docs/stop-message-auto.md +4 -3
  549. package/package.json +4 -3
  550. package/scripts/auth-iflow-manual.mjs +13 -23
  551. package/scripts/camoufox/launch-auth.mjs +158 -10
  552. package/scripts/ci/check-file-line-limit.mjs +149 -0
  553. package/scripts/copy-compat-assets.mjs +26 -0
  554. package/scripts/tests/ci-jest.mjs +4 -0
  555. package/scripts/verify-codex-error-samples.mjs +27 -6
@@ -3,7 +3,10 @@ import fsSync from 'node:fs';
3
3
  import path from 'node:path';
4
4
  import os from 'node:os';
5
5
  import { buildInfo } from '../../../build-info.js';
6
+ import { buildHistoricalProviderRow, buildSessionProviderRow, composeBucketKey, computeProviderTotals, extractToolCalls, formatProviderLabel, logHistoricalFromMemory, logProviderSummaryTable, logToolSummary, mergeSnapshotIntoHistorical, snapshotTools } from './stats-manager-internals.js';
6
7
  const DEFAULT_STATS_LOG_PATH = path.join(os.homedir(), '.routecodex', 'logs', 'provider-stats.jsonl');
8
+ const DEFAULT_HISTORY_MAX_TAIL_BYTES = 8 * 1024 * 1024;
9
+ const DEFAULT_HISTORY_MAX_LINES = 20000;
7
10
  function resolveBoolFromEnv(value, fallback) {
8
11
  if (!value) {
9
12
  return fallback;
@@ -23,6 +26,47 @@ function isStatsEnabledByDefault() {
23
26
  function isStatsVerboseEnabled(enabled) {
24
27
  return resolveBoolFromEnv(process.env.ROUTECODEX_STATS_VERBOSE ?? process.env.RCC_STATS_VERBOSE, enabled && buildInfo.mode !== 'release');
25
28
  }
29
+ function resolvePositiveIntEnv(primary, secondary, fallback) {
30
+ const values = [primary, secondary];
31
+ for (const value of values) {
32
+ const parsed = Number(String(value || '').trim());
33
+ if (Number.isFinite(parsed) && parsed >= 1) {
34
+ return Math.floor(parsed);
35
+ }
36
+ }
37
+ return fallback;
38
+ }
39
+ function readTailLines(filePath, maxTailBytes, maxLines) {
40
+ let text = '';
41
+ const stat = fsSync.statSync(filePath);
42
+ if (!Number.isFinite(stat.size) || stat.size <= 0) {
43
+ return [];
44
+ }
45
+ if (stat.size <= maxTailBytes) {
46
+ text = fsSync.readFileSync(filePath, 'utf-8');
47
+ }
48
+ else {
49
+ const start = Math.max(0, stat.size - maxTailBytes);
50
+ const fd = fsSync.openSync(filePath, 'r');
51
+ try {
52
+ const length = stat.size - start;
53
+ const buffer = Buffer.alloc(length);
54
+ const read = fsSync.readSync(fd, buffer, 0, length, start);
55
+ text = buffer.toString('utf8', 0, read);
56
+ const firstNl = text.indexOf('\n');
57
+ if (firstNl >= 0) {
58
+ text = text.slice(firstNl + 1);
59
+ }
60
+ }
61
+ finally {
62
+ fsSync.closeSync(fd);
63
+ }
64
+ }
65
+ return text
66
+ .split(/\r?\n/)
67
+ .filter(Boolean)
68
+ .slice(-maxLines);
69
+ }
26
70
  export class StatsManager {
27
71
  inflight = new Map();
28
72
  buckets = new Map();
@@ -52,9 +96,7 @@ export class StatsManager {
52
96
  if (!this.enabled || !requestId) {
53
97
  return;
54
98
  }
55
- this.inflight.set(requestId, {
56
- startTime: Date.now()
57
- });
99
+ this.inflight.set(requestId, { startTime: Date.now() });
58
100
  }
59
101
  bindProvider(requestId, meta) {
60
102
  if (!this.enabled || !requestId) {
@@ -73,10 +115,7 @@ export class StatsManager {
73
115
  }
74
116
  return;
75
117
  }
76
- this.inflight.set(requestId, {
77
- startTime: Date.now(),
78
- ...meta
79
- });
118
+ this.inflight.set(requestId, { startTime: Date.now(), ...meta });
80
119
  }
81
120
  recordCompletion(requestId, options) {
82
121
  if (!this.enabled || !requestId) {
@@ -87,7 +126,7 @@ export class StatsManager {
87
126
  if (!sample?.providerKey) {
88
127
  return;
89
128
  }
90
- const key = this.composeBucketKey(sample.providerKey, sample.model);
129
+ const key = composeBucketKey(sample.providerKey, sample.model);
91
130
  let bucket = this.buckets.get(key);
92
131
  if (!bucket) {
93
132
  const now = Date.now();
@@ -128,14 +167,14 @@ export class StatsManager {
128
167
  if (!providerKey) {
129
168
  return;
130
169
  }
131
- const toolCalls = this.extractToolCalls(payload);
170
+ const toolCalls = extractToolCalls(payload);
132
171
  if (!toolCalls.length) {
133
172
  return;
134
173
  }
135
174
  const now = Date.now();
136
175
  this.totalToolCalls += toolCalls.length;
137
176
  this.totalToolResponses += 1;
138
- const providerBucketKey = this.composeBucketKey(providerKey, meta.model);
177
+ const providerBucketKey = composeBucketKey(providerKey, meta.model);
139
178
  const providerTotals = this.toolProviderTotals.get(providerBucketKey) ?? {
140
179
  providerKey,
141
180
  model: meta.model,
@@ -190,26 +229,17 @@ export class StatsManager {
190
229
  }
191
230
  snapshot(uptimeMs) {
192
231
  if (!this.enabled) {
193
- return {
194
- generatedAt: Date.now(),
195
- uptimeMs,
196
- totals: []
197
- };
198
- }
199
- const totals = Array.from(this.buckets.values()).map(bucket => ({
200
- ...bucket,
201
- averageLatencyMs: bucket.requestCount ? bucket.totalLatencyMs / bucket.requestCount : 0,
202
- averagePromptTokens: bucket.requestCount ? bucket.totalPromptTokens / bucket.requestCount : 0,
203
- averageCompletionTokens: bucket.requestCount ? bucket.totalCompletionTokens / bucket.requestCount : 0,
204
- averageOutputTokens: bucket.requestCount ? bucket.totalOutputTokens / bucket.requestCount : 0
205
- }));
206
- const tools = this.snapshotTools();
207
- return {
208
- generatedAt: Date.now(),
209
- uptimeMs,
210
- totals,
211
- ...(tools ? { tools } : {})
212
- };
232
+ return { generatedAt: Date.now(), uptimeMs, totals: [] };
233
+ }
234
+ const totals = computeProviderTotals(this.buckets);
235
+ const tools = snapshotTools({
236
+ totalToolCalls: this.totalToolCalls,
237
+ totalToolResponses: this.totalToolResponses,
238
+ toolBuckets: this.toolBuckets,
239
+ toolBucketsByProvider: this.toolBucketsByProvider,
240
+ toolProviderTotals: this.toolProviderTotals
241
+ });
242
+ return { generatedAt: Date.now(), uptimeMs, totals, ...(tools ? { tools } : {}) };
213
243
  }
214
244
  logSummary(uptimeMs) {
215
245
  const snapshot = this.snapshot(uptimeMs);
@@ -217,7 +247,16 @@ export class StatsManager {
217
247
  return snapshot;
218
248
  }
219
249
  this.ensureHistoricalLoaded();
220
- this.mergeSnapshotIntoHistorical(snapshot);
250
+ const merged = mergeSnapshotIntoHistorical({
251
+ snapshot,
252
+ historicalBuckets: this.historicalBuckets,
253
+ historicalToolAggregate: this.historicalToolAggregate,
254
+ historicalToolByProvider: this.historicalToolByProvider,
255
+ historicalSnapshotCount: this.historicalSnapshotCount,
256
+ historicalSampleCount: this.historicalSampleCount
257
+ });
258
+ this.historicalSnapshotCount = merged.historicalSnapshotCount;
259
+ this.historicalSampleCount = merged.historicalSampleCount;
221
260
  if (!this.verboseLogging) {
222
261
  return snapshot;
223
262
  }
@@ -226,8 +265,8 @@ export class StatsManager {
226
265
  return snapshot;
227
266
  }
228
267
  console.log('\n[Stats][session] Provider summary (uptime=%d ms · samples=%d)', Math.round(snapshot.uptimeMs), snapshot.totals.reduce((sum, bucket) => sum + bucket.requestCount, 0));
229
- this.logProviderSummaryTable(snapshot.totals.map((bucket) => this.buildSessionProviderRow(bucket)), false);
230
- this.logToolSummary(snapshot.tools);
268
+ logProviderSummaryTable(snapshot.totals.map((bucket) => buildSessionProviderRow(bucket)), false);
269
+ logToolSummary(snapshot.tools, formatProviderLabel);
231
270
  return snapshot;
232
271
  }
233
272
  async persistSnapshot(snapshot, options) {
@@ -248,9 +287,6 @@ export class StatsManager {
248
287
  console.warn('[Stats] Failed to persist provider stats snapshot', error);
249
288
  }
250
289
  }
251
- /**
252
- * 打印历史 provider-stats 聚合(内存中实时维护,异常退出前也能看到历史)。
253
- */
254
290
  async logHistoricalSummary(options) {
255
291
  if (!this.enabled || !this.verboseLogging) {
256
292
  return;
@@ -261,25 +297,20 @@ export class StatsManager {
261
297
  else {
262
298
  this.ensureHistoricalLoaded();
263
299
  }
264
- this.logHistoricalFromMemory();
300
+ logHistoricalFromMemory({
301
+ historicalBuckets: this.historicalBuckets,
302
+ historicalSnapshotCount: this.historicalSnapshotCount,
303
+ historicalSampleCount: this.historicalSampleCount,
304
+ historicalToolAggregate: this.historicalToolAggregate,
305
+ historicalToolByProvider: this.historicalToolByProvider
306
+ });
265
307
  }
266
308
  snapshotHistorical() {
267
309
  if (!this.enabled) {
268
- return {
269
- generatedAt: Date.now(),
270
- snapshotCount: 0,
271
- sampleCount: 0,
272
- totals: []
273
- };
310
+ return { generatedAt: Date.now(), snapshotCount: 0, sampleCount: 0, totals: [] };
274
311
  }
275
312
  this.ensureHistoricalLoaded();
276
- const totals = Array.from(this.historicalBuckets.values()).map(bucket => ({
277
- ...bucket,
278
- averageLatencyMs: bucket.requestCount ? bucket.totalLatencyMs / bucket.requestCount : 0,
279
- averagePromptTokens: bucket.requestCount ? bucket.totalPromptTokens / bucket.requestCount : 0,
280
- averageCompletionTokens: bucket.requestCount ? bucket.totalCompletionTokens / bucket.requestCount : 0,
281
- averageOutputTokens: bucket.requestCount ? bucket.totalOutputTokens / bucket.requestCount : 0
282
- }));
313
+ const totals = computeProviderTotals(this.historicalBuckets);
283
314
  return {
284
315
  generatedAt: Date.now(),
285
316
  snapshotCount: this.historicalSnapshotCount,
@@ -287,416 +318,6 @@ export class StatsManager {
287
318
  totals
288
319
  };
289
320
  }
290
- composeBucketKey(providerKey, model) {
291
- return `${providerKey}|${model ?? '-'}`;
292
- }
293
- snapshotTools() {
294
- if (this.totalToolCalls <= 0 && this.totalToolResponses <= 0) {
295
- return undefined;
296
- }
297
- const byToolName = {};
298
- for (const [name, bucket] of this.toolBuckets.entries()) {
299
- byToolName[name] = { ...bucket };
300
- }
301
- const byProviderKey = {};
302
- for (const [providerKey, providerTools] of this.toolBucketsByProvider.entries()) {
303
- const totals = this.toolProviderTotals.get(providerKey);
304
- const byTool = {};
305
- for (const [name, bucket] of providerTools.entries()) {
306
- byTool[name] = { ...bucket };
307
- }
308
- byProviderKey[providerKey] = {
309
- providerKey: totals?.providerKey ?? providerKey,
310
- model: totals?.model,
311
- totalCalls: totals?.totalCalls ?? 0,
312
- totalResponses: totals?.totalResponses ?? 0,
313
- byToolName: byTool
314
- };
315
- }
316
- return {
317
- totalCalls: this.totalToolCalls,
318
- totalResponses: this.totalToolResponses,
319
- byToolName,
320
- byProviderKey
321
- };
322
- }
323
- logToolSummary(snapshot) {
324
- if (!snapshot || snapshot.totalCalls <= 0) {
325
- return;
326
- }
327
- console.log('\n[Stats] Tools:');
328
- console.log(' total tool calls : %d (responses with tools=%d)', snapshot.totalCalls, snapshot.totalResponses);
329
- const sorted = Object.values(snapshot.byToolName)
330
- .sort((a, b) => b.callCount - a.callCount)
331
- .slice(0, 10);
332
- if (sorted.length) {
333
- console.log(' top tools:');
334
- for (const bucket of sorted) {
335
- console.log(' %s → calls=%d responses=%d', bucket.toolName, bucket.callCount, bucket.responseCount);
336
- }
337
- }
338
- const providerEntries = Object.values(snapshot.byProviderKey ?? {});
339
- if (providerEntries.length) {
340
- console.log(' by provider:');
341
- const sortedProviders = providerEntries
342
- .slice()
343
- .sort((a, b) => b.totalCalls - a.totalCalls)
344
- .slice(0, 10);
345
- for (const provider of sortedProviders) {
346
- const label = this.formatProviderLabel(provider.providerKey, provider.model);
347
- console.log(' %s → calls=%d responses=%d', label, provider.totalCalls, provider.totalResponses);
348
- }
349
- }
350
- }
351
- logHistoricalToolSummary(toolAggregate, toolByProvider) {
352
- if (toolAggregate.size === 0) {
353
- return;
354
- }
355
- const totalCalls = Array.from(toolAggregate.values()).reduce((sum, bucket) => sum + bucket.callCount, 0);
356
- const totalResponses = Array.from(toolAggregate.values()).reduce((sum, bucket) => sum + bucket.responseCount, 0);
357
- console.log('\n[Stats] Historical tools summary (total calls=%d, responses with tools=%d)', totalCalls, totalResponses);
358
- const sorted = Array.from(toolAggregate.values())
359
- .sort((a, b) => b.callCount - a.callCount)
360
- .slice(0, 10);
361
- if (sorted.length) {
362
- console.log(' top tools:');
363
- for (const bucket of sorted) {
364
- console.log(' %s → calls=%d responses=%d', bucket.toolName, bucket.callCount, bucket.responseCount);
365
- }
366
- }
367
- if (toolByProvider.size) {
368
- console.log(' by provider:');
369
- const entries = Array.from(toolByProvider.entries()).sort((a, b) => a[0].localeCompare(b[0]));
370
- for (const [, bucket] of entries) {
371
- const label = this.formatProviderLabel(bucket.providerKey, bucket.model);
372
- console.log(' %s → calls=%d responses=%d', label, bucket.totalCalls, bucket.totalResponses);
373
- }
374
- }
375
- }
376
- mergeToolAggregate(toolAggregate, toolByProvider, tools) {
377
- for (const bucket of Object.values(tools.byToolName ?? {})) {
378
- if (!bucket || !bucket.toolName) {
379
- continue;
380
- }
381
- const existing = toolAggregate.get(bucket.toolName);
382
- if (!existing) {
383
- toolAggregate.set(bucket.toolName, { ...bucket });
384
- }
385
- else {
386
- existing.callCount += bucket.callCount;
387
- existing.responseCount += bucket.responseCount;
388
- if (bucket.firstSeenAt < existing.firstSeenAt) {
389
- existing.firstSeenAt = bucket.firstSeenAt;
390
- }
391
- if (bucket.lastSeenAt > existing.lastSeenAt) {
392
- existing.lastSeenAt = bucket.lastSeenAt;
393
- }
394
- }
395
- }
396
- for (const providerRecord of Object.values(tools.byProviderKey ?? {})) {
397
- if (!providerRecord || !providerRecord.providerKey) {
398
- continue;
399
- }
400
- const providerKey = providerRecord.providerKey;
401
- const bucketKey = this.composeBucketKey(providerKey, providerRecord.model);
402
- const entry = toolByProvider.get(bucketKey) ?? {
403
- providerKey,
404
- model: providerRecord.model,
405
- totalCalls: 0,
406
- totalResponses: 0,
407
- byToolName: new Map()
408
- };
409
- entry.totalCalls += providerRecord.totalCalls ?? 0;
410
- entry.totalResponses += providerRecord.totalResponses ?? 0;
411
- for (const toolBucket of Object.values(providerRecord.byToolName ?? {})) {
412
- if (!toolBucket || !toolBucket.toolName) {
413
- continue;
414
- }
415
- const existing = entry.byToolName.get(toolBucket.toolName);
416
- if (!existing) {
417
- entry.byToolName.set(toolBucket.toolName, { ...toolBucket });
418
- }
419
- else {
420
- existing.callCount += toolBucket.callCount;
421
- existing.responseCount += toolBucket.responseCount;
422
- if (toolBucket.firstSeenAt < existing.firstSeenAt) {
423
- existing.firstSeenAt = toolBucket.firstSeenAt;
424
- }
425
- if (toolBucket.lastSeenAt > existing.lastSeenAt) {
426
- existing.lastSeenAt = toolBucket.lastSeenAt;
427
- }
428
- }
429
- }
430
- toolByProvider.set(bucketKey, entry);
431
- }
432
- }
433
- extractToolCalls(payload) {
434
- if (!payload || typeof payload !== 'object') {
435
- return [];
436
- }
437
- const record = payload;
438
- const calls = [];
439
- const seenIds = new Set();
440
- const addCall = (nameRaw, idRaw) => {
441
- const name = typeof nameRaw === 'string' && nameRaw.trim() ? nameRaw.trim() : '';
442
- if (!name) {
443
- return;
444
- }
445
- const id = typeof idRaw === 'string' && idRaw.trim() ? idRaw.trim() : undefined;
446
- if (id && seenIds.has(id)) {
447
- return;
448
- }
449
- if (id) {
450
- seenIds.add(id);
451
- }
452
- calls.push({ name, ...(id ? { id } : {}) });
453
- };
454
- const toolCalls = (record.tool_calls ??
455
- // eslint-disable-next-line @typescript-eslint/no-explicit-any
456
- record.required_action?.submit_tool_outputs?.tool_calls);
457
- if (Array.isArray(toolCalls)) {
458
- for (const toolCall of toolCalls) {
459
- if (!toolCall || typeof toolCall !== 'object') {
460
- continue;
461
- }
462
- const toolRec = toolCall;
463
- const fn = toolRec.function;
464
- addCall(fn?.name ?? toolRec.name, toolRec.id ?? toolRec.call_id ?? toolRec.tool_call_id);
465
- }
466
- }
467
- const output = record.output;
468
- if (Array.isArray(output)) {
469
- for (const entry of output) {
470
- if (!entry || typeof entry !== 'object') {
471
- continue;
472
- }
473
- const node = entry;
474
- const type = typeof node.type === 'string' ? node.type.trim().toLowerCase() : '';
475
- if (type === 'function_call' || type === 'tool_call' || type === 'function') {
476
- addCall(node.name ?? node.tool_name ??
477
- // eslint-disable-next-line @typescript-eslint/no-explicit-any
478
- node.function?.name, node.call_id ?? node.id);
479
- }
480
- if (Array.isArray(node.content)) {
481
- for (const contentItem of node.content) {
482
- if (!contentItem || typeof contentItem !== 'object') {
483
- continue;
484
- }
485
- const contentNode = contentItem;
486
- const contentType = typeof contentNode.type === 'string' ? contentNode.type.trim().toLowerCase() : '';
487
- if (contentType === 'tool_call' || contentType === 'function_call') {
488
- addCall(contentNode.name ?? contentNode.tool_name ??
489
- // eslint-disable-next-line @typescript-eslint/no-explicit-any
490
- contentNode.function?.name, contentNode.call_id ?? contentNode.id);
491
- }
492
- }
493
- }
494
- }
495
- }
496
- const choices = record.choices;
497
- if (Array.isArray(choices)) {
498
- for (const choice of choices) {
499
- if (!choice || typeof choice !== 'object') {
500
- continue;
501
- }
502
- const message = choice.message;
503
- if (!message || typeof message !== 'object') {
504
- continue;
505
- }
506
- const toolCallsNode = message.tool_calls;
507
- if (Array.isArray(toolCallsNode)) {
508
- for (const toolCall of toolCallsNode) {
509
- if (!toolCall || typeof toolCall !== 'object') {
510
- continue;
511
- }
512
- const toolRec = toolCall;
513
- const fn = toolRec.function;
514
- addCall(fn?.name ?? toolRec.name, toolRec.id ?? toolRec.tool_call_id);
515
- }
516
- }
517
- }
518
- }
519
- return calls;
520
- }
521
- mergeSnapshotIntoHistorical(snapshot) {
522
- if (!snapshot) {
523
- return;
524
- }
525
- this.historicalSnapshotCount += 1;
526
- const totals = Array.isArray(snapshot.totals) ? snapshot.totals : [];
527
- let snapshotSamples = 0;
528
- for (const bucket of totals) {
529
- const key = this.composeBucketKey(bucket.providerKey, bucket.model);
530
- const existing = this.historicalBuckets.get(key);
531
- const promptTokens = bucket.totalPromptTokens ?? 0;
532
- const completionTokens = bucket.totalCompletionTokens ?? 0;
533
- const outputTokens = bucket.totalOutputTokens ?? 0;
534
- const latency = bucket.totalLatencyMs ?? 0;
535
- const firstAt = typeof bucket.firstRequestAt === 'number' ? bucket.firstRequestAt : Date.now();
536
- const lastAt = typeof bucket.lastRequestAt === 'number' ? bucket.lastRequestAt : Date.now();
537
- if (!existing) {
538
- this.historicalBuckets.set(key, {
539
- providerKey: bucket.providerKey,
540
- providerType: bucket.providerType,
541
- model: bucket.model,
542
- requestCount: bucket.requestCount ?? 0,
543
- errorCount: bucket.errorCount ?? 0,
544
- totalLatencyMs: latency,
545
- totalPromptTokens: promptTokens,
546
- totalCompletionTokens: completionTokens,
547
- totalOutputTokens: outputTokens,
548
- firstRequestAt: firstAt,
549
- lastRequestAt: lastAt
550
- });
551
- }
552
- else {
553
- existing.requestCount += bucket.requestCount ?? 0;
554
- existing.errorCount += bucket.errorCount ?? 0;
555
- existing.totalLatencyMs += latency;
556
- existing.totalPromptTokens += promptTokens;
557
- existing.totalCompletionTokens += completionTokens;
558
- existing.totalOutputTokens += outputTokens;
559
- if (firstAt < existing.firstRequestAt) {
560
- existing.firstRequestAt = firstAt;
561
- }
562
- if (lastAt > existing.lastRequestAt) {
563
- existing.lastRequestAt = lastAt;
564
- }
565
- }
566
- snapshotSamples += bucket.requestCount ?? 0;
567
- }
568
- this.historicalSampleCount += snapshotSamples;
569
- if (snapshot.tools && typeof snapshot.tools === 'object') {
570
- this.mergeToolAggregate(this.historicalToolAggregate, this.historicalToolByProvider, snapshot.tools);
571
- }
572
- }
573
- logHistoricalFromMemory() {
574
- if (!this.historicalBuckets.size) {
575
- console.log('[Stats] No historical provider activity recorded');
576
- return;
577
- }
578
- console.log('\n[Stats][historical] Provider summary (snapshots=%d · samples=%d)', this.historicalSnapshotCount, this.historicalSampleCount);
579
- const sorted = Array.from(this.historicalBuckets.values()).sort((a, b) => a.providerKey.localeCompare(b.providerKey));
580
- this.logProviderSummaryTable(sorted.map((bucket) => this.buildHistoricalProviderRow(bucket)), true);
581
- this.logHistoricalToolSummary(this.historicalToolAggregate, this.historicalToolByProvider);
582
- }
583
- buildSessionProviderRow(bucket) {
584
- const okCount = bucket.requestCount - bucket.errorCount;
585
- return {
586
- providerKey: this.normalizeCellValue(bucket.providerKey),
587
- model: this.normalizeCellValue(bucket.model),
588
- requests: String(bucket.requestCount),
589
- ok: String(okCount),
590
- err: String(bucket.errorCount),
591
- avgLatencyMs: bucket.averageLatencyMs.toFixed(1),
592
- avgTokens: this.formatAverageTokenTriple(bucket.averagePromptTokens, bucket.averageCompletionTokens, bucket.averageOutputTokens),
593
- totalTokens: this.formatTotalTokenTriple(bucket.totalPromptTokens, bucket.totalCompletionTokens, bucket.totalOutputTokens)
594
- };
595
- }
596
- buildHistoricalProviderRow(bucket) {
597
- const okCount = bucket.requestCount - bucket.errorCount;
598
- const avgLatency = bucket.requestCount ? bucket.totalLatencyMs / bucket.requestCount : 0;
599
- const avgPrompt = bucket.requestCount ? bucket.totalPromptTokens / bucket.requestCount : 0;
600
- const avgCompletion = bucket.requestCount ? bucket.totalCompletionTokens / bucket.requestCount : 0;
601
- const avgTotal = bucket.requestCount ? bucket.totalOutputTokens / bucket.requestCount : 0;
602
- return {
603
- providerKey: this.normalizeCellValue(bucket.providerKey),
604
- model: this.normalizeCellValue(bucket.model),
605
- requests: String(bucket.requestCount),
606
- ok: String(okCount),
607
- err: String(bucket.errorCount),
608
- avgLatencyMs: avgLatency.toFixed(1),
609
- avgTokens: this.formatAverageTokenTriple(avgPrompt, avgCompletion, avgTotal),
610
- totalTokens: this.formatTotalTokenTriple(bucket.totalPromptTokens, bucket.totalCompletionTokens, bucket.totalOutputTokens),
611
- window: this.formatWindowRange(bucket.firstRequestAt, bucket.lastRequestAt)
612
- };
613
- }
614
- logProviderSummaryTable(rows, includeWindow) {
615
- if (!rows.length) {
616
- return;
617
- }
618
- const columns = [
619
- { key: 'providerKey', title: 'providerKey', align: 'left', maxWidth: 44 },
620
- { key: 'model', title: 'model', align: 'left', maxWidth: 28 },
621
- { key: 'requests', title: 'req', align: 'right' },
622
- { key: 'ok', title: 'ok', align: 'right' },
623
- { key: 'err', title: 'err', align: 'right' },
624
- { key: 'avgLatencyMs', title: 'avgMs', align: 'right' },
625
- { key: 'avgTokens', title: 'avgTok(i/o/t)', align: 'right', maxWidth: 22 },
626
- { key: 'totalTokens', title: 'totTok(i/o/t)', align: 'right', maxWidth: 22 }
627
- ];
628
- if (includeWindow) {
629
- columns.push({ key: 'window', title: 'window', align: 'left', maxWidth: 41 });
630
- }
631
- const widths = columns.map((column) => {
632
- const maxCellLength = rows.reduce((maxLength, row) => {
633
- const value = this.normalizeCellValue(row[column.key]);
634
- const clipped = this.clipCellValue(value, column.maxWidth);
635
- return Math.max(maxLength, clipped.length);
636
- }, column.title.length);
637
- if (typeof column.maxWidth === 'number' && column.maxWidth > 0) {
638
- return Math.min(Math.max(column.title.length, maxCellLength), column.maxWidth);
639
- }
640
- return Math.max(column.title.length, maxCellLength);
641
- });
642
- console.log(this.renderTableRow(columns, widths, undefined, true));
643
- console.log(this.renderTableSeparator(widths));
644
- for (const row of rows) {
645
- console.log(this.renderTableRow(columns, widths, row, false));
646
- }
647
- }
648
- renderTableRow(columns, widths, row, isHeader) {
649
- const cells = columns.map((column, index) => {
650
- const value = isHeader
651
- ? column.title
652
- : this.normalizeCellValue(row?.[column.key]);
653
- const clipped = this.clipCellValue(value, widths[index]);
654
- return column.align === 'right'
655
- ? clipped.padStart(widths[index], ' ')
656
- : clipped.padEnd(widths[index], ' ');
657
- });
658
- return ` | ${cells.join(' | ')} |`;
659
- }
660
- renderTableSeparator(widths) {
661
- return ` |-` + widths.map((width) => '-'.repeat(width)).join('-|-') + '-|';
662
- }
663
- clipCellValue(value, maxWidth) {
664
- if (!Number.isFinite(maxWidth) || typeof maxWidth !== 'number' || maxWidth <= 0) {
665
- return value;
666
- }
667
- if (value.length <= maxWidth) {
668
- return value;
669
- }
670
- if (maxWidth <= 1) {
671
- return '…';
672
- }
673
- if (maxWidth <= 3) {
674
- return value.slice(0, maxWidth);
675
- }
676
- return `${value.slice(0, maxWidth - 1)}…`;
677
- }
678
- normalizeCellValue(value) {
679
- if (value === undefined || value === null) {
680
- return '-';
681
- }
682
- const normalized = String(value).trim();
683
- return normalized.length ? normalized : '-';
684
- }
685
- formatAverageTokenTriple(prompt, completion, total) {
686
- if (prompt === 0 && completion === 0 && total === 0) {
687
- return '-';
688
- }
689
- return `${prompt.toFixed(1)}/${completion.toFixed(1)}/${total.toFixed(1)}`;
690
- }
691
- formatTotalTokenTriple(prompt, completion, total) {
692
- if (prompt === 0 && completion === 0 && total === 0) {
693
- return '-';
694
- }
695
- return `${prompt}/${completion}/${total}`;
696
- }
697
- formatWindowRange(firstAt, lastAt) {
698
- return `${this.formatIso(firstAt)}→${this.formatIso(lastAt)}`;
699
- }
700
321
  ensureHistoricalLoaded() {
701
322
  if (!this.enabled || this.historicalLoaded) {
702
323
  return;
@@ -712,12 +333,22 @@ export class StatsManager {
712
333
  this.historicalSampleCount = 0;
713
334
  }
714
335
  try {
715
- const raw = fsSync.readFileSync(logPath, 'utf-8');
716
- const lines = raw.split(/\r?\n/).filter(Boolean);
336
+ const maxTailBytes = resolvePositiveIntEnv(process.env.ROUTECODEX_STATS_HISTORY_MAX_TAIL_BYTES, process.env.RCC_STATS_HISTORY_MAX_TAIL_BYTES, DEFAULT_HISTORY_MAX_TAIL_BYTES);
337
+ const maxLines = resolvePositiveIntEnv(process.env.ROUTECODEX_STATS_HISTORY_MAX_LINES, process.env.RCC_STATS_HISTORY_MAX_LINES, DEFAULT_HISTORY_MAX_LINES);
338
+ const lines = readTailLines(logPath, maxTailBytes, maxLines);
717
339
  for (const line of lines) {
718
340
  try {
719
341
  const record = JSON.parse(line);
720
- this.mergeSnapshotIntoHistorical(record);
342
+ const merged = mergeSnapshotIntoHistorical({
343
+ snapshot: record,
344
+ historicalBuckets: this.historicalBuckets,
345
+ historicalToolAggregate: this.historicalToolAggregate,
346
+ historicalToolByProvider: this.historicalToolByProvider,
347
+ historicalSnapshotCount: this.historicalSnapshotCount,
348
+ historicalSampleCount: this.historicalSampleCount
349
+ });
350
+ this.historicalSnapshotCount = merged.historicalSnapshotCount;
351
+ this.historicalSampleCount = merged.historicalSampleCount;
721
352
  }
722
353
  catch {
723
354
  continue;
@@ -725,7 +356,7 @@ export class StatsManager {
725
356
  }
726
357
  }
727
358
  catch {
728
- // File missing or unreadable treat as empty history.
359
+ // File missing or unreadable -> treat as empty history.
729
360
  }
730
361
  this.historicalLoaded = true;
731
362
  }
@@ -741,25 +372,6 @@ export class StatsManager {
741
372
  }
742
373
  return this.statsLogPath;
743
374
  }
744
- formatProviderLabel(providerKey, model) {
745
- const key = typeof providerKey === 'string' && providerKey.trim() ? providerKey.trim() : '-';
746
- const modelId = typeof model === 'string' && model.trim() ? model.trim() : undefined;
747
- if (modelId) {
748
- return `${key} / ${modelId}`;
749
- }
750
- return key;
751
- }
752
- formatIso(value) {
753
- if (typeof value !== 'number' || !Number.isFinite(value) || value <= 0) {
754
- return '-';
755
- }
756
- try {
757
- return new Date(value).toISOString();
758
- }
759
- catch {
760
- return '-';
761
- }
762
- }
763
375
  resolveLogPath(explicit) {
764
376
  if (explicit && explicit.trim()) {
765
377
  return explicit.trim();