@jsonstudio/llms 0.6.2979 → 0.6.3238

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 (246) hide show
  1. package/dist/conversion/args-mapping.js +8 -0
  2. package/dist/conversion/{shared/bridge-actions.js → bridge-actions.js} +2 -1
  3. package/dist/conversion/{shared/bridge-id-utils.js → bridge-id-utils.js} +1 -1
  4. package/dist/conversion/{shared/bridge-instructions.js → bridge-instructions.js} +1 -1
  5. package/dist/conversion/{shared/bridge-message-utils.d.ts → bridge-message-utils.d.ts} +1 -1
  6. package/dist/conversion/{shared/bridge-message-utils.js → bridge-message-utils.js} +5 -149
  7. package/dist/conversion/{shared/bridge-metadata.js → bridge-metadata.js} +1 -1
  8. package/dist/conversion/{shared/bridge-policies.js → bridge-policies.js} +1 -1
  9. package/dist/conversion/codecs/gemini-openai-codec.js +27 -8
  10. package/dist/conversion/codecs/responses-openai-codec.js +1 -1
  11. package/dist/conversion/{shared/compaction-detect.d.ts → compaction-detect.d.ts} +1 -1
  12. package/dist/conversion/compaction-detect.js +4 -0
  13. package/dist/conversion/compat/actions/apply-patch-fixer.js +2 -2
  14. package/dist/conversion/compat/actions/deepseek-web-response.d.ts +0 -1
  15. package/dist/conversion/compat/actions/deepseek-web-response.js +15 -405
  16. package/dist/conversion/compat/actions/harvest-tool-calls-from-text.js +1 -1
  17. package/dist/conversion/compat/actions/lmstudio-responses-fc-ids.js +1 -1
  18. package/dist/conversion/compat/actions/qwen-transform.js +74 -2
  19. package/dist/conversion/compat/actions/snapshot.js +1 -1
  20. package/dist/conversion/compat/antigravity-session-signature.js +36 -0
  21. package/dist/conversion/compat/profiles/chat-deepseek-web.json +0 -22
  22. package/dist/conversion/compat/profiles/chat-glm.json +251 -72
  23. package/dist/conversion/compat/profiles/chat-iflow.json +174 -39
  24. package/dist/conversion/compat/profiles/chat-lmstudio.json +43 -14
  25. package/dist/conversion/hub/operation-table/operation-table-runner.js +2 -2
  26. package/dist/conversion/hub/operation-table/semantic-mappers/anthropic-mapper.js +1 -1
  27. package/dist/conversion/hub/operation-table/semantic-mappers/archive/chat-mapper.archive.d.ts +8 -0
  28. package/dist/conversion/hub/operation-table/semantic-mappers/archive/chat-mapper.archive.js +404 -0
  29. package/dist/conversion/hub/operation-table/semantic-mappers/chat-mapper.js +5 -381
  30. package/dist/conversion/hub/operation-table/semantic-mappers/gemini-mapper.js +2 -2
  31. package/dist/conversion/hub/operation-table/semantic-mappers/responses-mapper.js +2 -8
  32. package/dist/conversion/hub/pipeline/hub-pipeline.d.ts +1 -0
  33. package/dist/conversion/hub/pipeline/hub-pipeline.js +50 -3
  34. package/dist/conversion/hub/pipeline/stages/req_inbound/req_inbound_stage2_semantic_map/index.d.ts +1 -1
  35. package/dist/conversion/hub/pipeline/stages/req_inbound/req_inbound_stage2_semantic_map/index.js +62 -0
  36. package/dist/conversion/hub/pipeline/stages/req_process/req_process_stage2_route_select/index.js +3 -1
  37. package/dist/conversion/hub/pipeline/stages/resp_inbound/resp_inbound_stage1_sse_decode/index.js +1 -1
  38. package/dist/conversion/hub/pipeline/stages/resp_outbound/resp_outbound_stage1_client_remap/chat-process-semantics-bridge.d.ts +1 -1
  39. package/dist/conversion/hub/pipeline/stages/resp_process/resp_process_stage1_tool_governance/index.js +42 -29
  40. package/dist/conversion/hub/pipeline/stages/resp_process/resp_process_stage2_finalize/index.js +12 -0
  41. package/dist/conversion/hub/policy/protocol-spec.js +1 -1
  42. package/dist/conversion/hub/process/chat-process-clock-reminders.js +1 -1
  43. package/dist/conversion/hub/process/chat-process-clock-tools.js +1 -1
  44. package/dist/conversion/hub/process/chat-process-continue-execution.js +1 -1
  45. package/dist/conversion/hub/process/chat-process-servertool-orchestration.js +1 -1
  46. package/dist/conversion/hub/process/chat-process-web-search.js +1 -1
  47. package/dist/conversion/hub/response/provider-response.js +14 -5
  48. package/dist/conversion/hub/response/response-mappers.js +23 -1
  49. package/dist/conversion/hub/response/response-runtime.js +28 -5
  50. package/dist/conversion/hub/snapshot-recorder.js +3 -92
  51. package/dist/conversion/hub/tool-governance/engine.d.ts +8 -0
  52. package/dist/conversion/hub/tool-governance/engine.js +40 -193
  53. package/dist/conversion/hub/tool-governance/rules.js +73 -69
  54. package/dist/conversion/hub/tool-surface/tool-surface-engine.js +1 -1
  55. package/dist/conversion/index.d.ts +1 -2
  56. package/dist/conversion/index.js +1 -2
  57. package/dist/conversion/{shared/jsonish.js → jsonish.js} +1 -1
  58. package/dist/conversion/{shared/mcp-injection.js → mcp-injection.js} +1 -1
  59. package/dist/conversion/media.js +4 -0
  60. package/dist/conversion/{shared/metadata-passthrough.d.ts → metadata-passthrough.d.ts} +1 -1
  61. package/dist/conversion/{shared/metadata-passthrough.js → metadata-passthrough.js} +2 -2
  62. package/dist/conversion/payload-budget.js +47 -0
  63. package/dist/conversion/protocol-field-allowlists.d.ts +7 -0
  64. package/dist/conversion/protocol-field-allowlists.js +9 -0
  65. package/dist/conversion/{shared/protocol-state.d.ts → protocol-state.d.ts} +2 -2
  66. package/dist/conversion/{shared/protocol-state.js → protocol-state.js} +2 -2
  67. package/dist/conversion/{shared/errors.d.ts → provider-protocol-error.d.ts} +0 -3
  68. package/dist/conversion/provider-protocol-error.js +25 -0
  69. package/dist/conversion/responses/responses-openai-bridge/response-payload.js +8 -5
  70. package/dist/conversion/responses/responses-openai-bridge/types.d.ts +1 -1
  71. package/dist/conversion/responses/responses-openai-bridge.d.ts +1 -1
  72. package/dist/conversion/responses/responses-openai-bridge.js +43 -10
  73. package/dist/conversion/{shared/runtime-metadata.d.ts → runtime-metadata.d.ts} +1 -1
  74. package/dist/conversion/{shared/runtime-metadata.js → runtime-metadata.js} +2 -2
  75. package/dist/conversion/shared/anthropic-message-utils.js +19 -8
  76. package/dist/conversion/shared/chat-request-filters.d.ts +3 -4
  77. package/dist/conversion/shared/chat-request-filters.js +22 -78
  78. package/dist/conversion/shared/gemini-tool-utils.d.ts +1 -1
  79. package/dist/conversion/shared/openai-finalizer.js +1 -0
  80. package/dist/conversion/shared/openai-message-normalize.js +2 -2
  81. package/dist/conversion/shared/reasoning-normalizer.js +6 -0
  82. package/dist/conversion/shared/reasoning-utils.js +5 -2
  83. package/dist/conversion/shared/responses-conversation-store.js +1 -1
  84. package/dist/conversion/shared/responses-output-builder.js +55 -11
  85. package/dist/conversion/shared/responses-reasoning-registry.d.ts +14 -2
  86. package/dist/conversion/shared/responses-reasoning-registry.js +34 -6
  87. package/dist/conversion/shared/responses-response-utils.js +99 -9
  88. package/dist/conversion/shared/responses-tool-utils.js +1 -1
  89. package/dist/conversion/shared/text-markup-normalizer/normalize.d.ts +1 -1
  90. package/dist/conversion/shared/text-markup-normalizer.d.ts +2 -2
  91. package/dist/conversion/shared/text-markup-normalizer.js +1 -1
  92. package/dist/conversion/shared/tool-filter-pipeline.js +1 -1
  93. package/dist/conversion/shared/tool-governor.js +3 -3
  94. package/dist/conversion/shared/tool-mapping.d.ts +1 -1
  95. package/dist/conversion/{shared/snapshot-utils.d.ts → snapshot-utils.d.ts} +11 -0
  96. package/dist/conversion/{shared/snapshot-utils.js → snapshot-utils.js} +14 -23
  97. package/dist/conversion/types/text-markup-normalizer.d.ts +13 -0
  98. package/dist/conversion/types/text-markup-normalizer.js +1 -0
  99. package/dist/filters/special/request-tools-normalize.js +1 -1
  100. package/dist/filters/special/response-tool-text-canonicalize.js +2 -2
  101. package/dist/native/router_hotpath_napi.node +0 -0
  102. package/dist/quota/quota-manager.js +31 -59
  103. package/dist/quota/quota-state.js +14 -7
  104. package/dist/router/virtual-router/bootstrap/profile-builder.d.ts +1 -0
  105. package/dist/router/virtual-router/bootstrap/profile-builder.js +13 -0
  106. package/dist/router/virtual-router/bootstrap/provider-normalization.d.ts +2 -0
  107. package/dist/router/virtual-router/bootstrap/provider-normalization.js +4 -1
  108. package/dist/router/virtual-router/bootstrap/streaming-helpers.d.ts +7 -0
  109. package/dist/router/virtual-router/bootstrap/streaming-helpers.js +44 -0
  110. package/dist/router/virtual-router/bootstrap.js +2 -0
  111. package/dist/router/virtual-router/engine/routing-state/store.d.ts +1 -2
  112. package/dist/router/virtual-router/engine/routing-state/store.js +2 -2
  113. package/dist/router/virtual-router/engine-legacy/config.d.ts +11 -0
  114. package/dist/router/virtual-router/engine-legacy/config.js +108 -0
  115. package/dist/router/virtual-router/engine-legacy/direct-model.d.ts +10 -0
  116. package/dist/router/virtual-router/engine-legacy/direct-model.js +38 -0
  117. package/dist/router/virtual-router/engine-legacy/health.d.ts +13 -0
  118. package/dist/router/virtual-router/engine-legacy/health.js +104 -0
  119. package/dist/router/virtual-router/engine-legacy/helpers.d.ts +16 -0
  120. package/dist/router/virtual-router/engine-legacy/helpers.js +226 -0
  121. package/dist/router/virtual-router/engine-legacy/route-finalize.d.ts +9 -0
  122. package/dist/router/virtual-router/engine-legacy/route-finalize.js +84 -0
  123. package/dist/router/virtual-router/engine-legacy/route-selection.d.ts +17 -0
  124. package/dist/router/virtual-router/engine-legacy/route-selection.js +205 -0
  125. package/dist/router/virtual-router/engine-legacy/route-state-allowlist.d.ts +3 -0
  126. package/dist/router/virtual-router/engine-legacy/route-state-allowlist.js +36 -0
  127. package/dist/router/virtual-router/engine-legacy/route-state.d.ts +12 -0
  128. package/dist/router/virtual-router/engine-legacy/route-state.js +386 -0
  129. package/dist/router/virtual-router/engine-legacy/route-utils.d.ts +19 -0
  130. package/dist/router/virtual-router/engine-legacy/route-utils.js +212 -0
  131. package/dist/router/virtual-router/engine-legacy/routing.d.ts +8 -0
  132. package/dist/router/virtual-router/engine-legacy/routing.js +8 -0
  133. package/dist/router/virtual-router/engine-legacy/selection-core.d.ts +28 -0
  134. package/dist/router/virtual-router/engine-legacy/selection-core.js +112 -0
  135. package/dist/router/virtual-router/engine-legacy/selection-state.d.ts +16 -0
  136. package/dist/router/virtual-router/engine-legacy/selection-state.js +187 -0
  137. package/dist/router/virtual-router/engine-legacy/state-accessors.d.ts +21 -0
  138. package/dist/router/virtual-router/engine-legacy/state-accessors.js +118 -0
  139. package/dist/router/virtual-router/engine-legacy.d.ts +123 -0
  140. package/dist/router/virtual-router/engine-legacy.js +194 -0
  141. package/dist/router/virtual-router/engine-logging.d.ts +2 -0
  142. package/dist/router/virtual-router/engine-logging.js +7 -2
  143. package/dist/router/virtual-router/engine-selection/key-parsing.js +0 -3
  144. package/dist/router/virtual-router/engine-selection/native-chat-request-filter-semantics.d.ts +1 -0
  145. package/dist/router/virtual-router/engine-selection/native-chat-request-filter-semantics.js +54 -0
  146. package/dist/router/virtual-router/engine-selection/native-hub-bridge-policy-semantics.d.ts +10 -0
  147. package/dist/router/virtual-router/engine-selection/native-hub-bridge-policy-semantics.js +67 -0
  148. package/dist/router/virtual-router/engine-selection/native-hub-pipeline-governance-semantics.d.ts +30 -0
  149. package/dist/router/virtual-router/engine-selection/native-hub-pipeline-governance-semantics.js +202 -0
  150. package/dist/router/virtual-router/engine-selection/native-hub-pipeline-semantic-mappers.d.ts +2 -0
  151. package/dist/router/virtual-router/engine-selection/native-hub-pipeline-semantic-mappers.js +83 -0
  152. package/dist/router/virtual-router/engine-selection/native-router-hotpath-loader.js +43 -2
  153. package/dist/router/virtual-router/engine-selection/native-shared-conversion-semantics.d.ts +75 -0
  154. package/dist/router/virtual-router/engine-selection/native-shared-conversion-semantics.js +205 -0
  155. package/dist/router/virtual-router/engine-selection/native-snapshot-hooks.d.ts +3 -0
  156. package/dist/router/virtual-router/engine-selection/native-snapshot-hooks.js +109 -0
  157. package/dist/router/virtual-router/engine-selection/native-virtual-router-engine-proxy.d.ts +16 -0
  158. package/dist/router/virtual-router/engine-selection/native-virtual-router-engine-proxy.js +14 -0
  159. package/dist/router/virtual-router/engine-selection/native-virtual-router-routing-instructions-semantics.d.ts +2 -0
  160. package/dist/router/virtual-router/engine-selection/native-virtual-router-routing-instructions-semantics.js +86 -0
  161. package/dist/router/virtual-router/engine-selection/tier-selection-quota-integration.js +100 -0
  162. package/dist/router/virtual-router/engine-selection/tier-selection-select.js +99 -0
  163. package/dist/router/virtual-router/engine.d.ts +22 -105
  164. package/dist/router/virtual-router/engine.js +274 -1641
  165. package/dist/router/virtual-router/load-balancer.d.ts +8 -0
  166. package/dist/router/virtual-router/load-balancer.js +65 -2
  167. package/dist/router/virtual-router/provider-registry.js +2 -0
  168. package/dist/router/virtual-router/routing-instructions/clean.d.ts +3 -0
  169. package/dist/router/virtual-router/routing-instructions/clean.js +34 -0
  170. package/dist/router/virtual-router/routing-instructions/parse.d.ts +18 -0
  171. package/dist/router/virtual-router/routing-instructions/parse.js +377 -0
  172. package/dist/router/virtual-router/routing-instructions/state.d.ts +4 -0
  173. package/dist/router/virtual-router/routing-instructions/state.js +245 -0
  174. package/dist/router/virtual-router/routing-instructions/types.d.ts +70 -0
  175. package/dist/router/virtual-router/routing-instructions/types.js +2 -0
  176. package/dist/router/virtual-router/routing-instructions.d.ts +5 -89
  177. package/dist/router/virtual-router/routing-instructions.js +4 -655
  178. package/dist/router/virtual-router/sticky-session-store.d.ts +4 -0
  179. package/dist/router/virtual-router/sticky-session-store.js +19 -81
  180. package/dist/router/virtual-router/tool-signals.js +21 -3
  181. package/dist/router/virtual-router/types.d.ts +4 -0
  182. package/dist/servertool/clock/session-scope.js +32 -1
  183. package/dist/servertool/engine.js +79 -8
  184. package/dist/servertool/handlers/antigravity-thought-signature-bootstrap.js +1 -1
  185. package/dist/servertool/handlers/clock-auto.js +1 -1
  186. package/dist/servertool/handlers/clock.js +1 -1
  187. package/dist/servertool/handlers/compaction-detect.d.ts +1 -1
  188. package/dist/servertool/handlers/compaction-detect.js +1 -1
  189. package/dist/servertool/handlers/gemini-empty-reply-continue.js +1 -1
  190. package/dist/servertool/handlers/iflow-model-error-retry.js +1 -1
  191. package/dist/servertool/handlers/recursive-detection-guard.js +1 -1
  192. package/dist/servertool/handlers/review.js +1 -1
  193. package/dist/servertool/handlers/stop-message-auto/iflow-followup.js +1 -1
  194. package/dist/servertool/handlers/stop-message-auto/runtime-utils.js +1 -1
  195. package/dist/servertool/handlers/stop-message-auto.js +1 -1
  196. package/dist/servertool/handlers/vision.js +1 -1
  197. package/dist/servertool/handlers/web-search.js +1 -1
  198. package/dist/servertool/reenter-backend.js +1 -1
  199. package/dist/servertool/server-side-tools.js +2 -2
  200. package/dist/servertool/stop-gateway-context.js +1 -1
  201. package/dist/servertool/stop-message-compare-context.js +1 -1
  202. package/dist/sse/json-to-sse/event-generators/responses.d.ts +4 -0
  203. package/dist/sse/json-to-sse/event-generators/responses.js +95 -1
  204. package/dist/sse/json-to-sse/sequencers/responses-sequencer.js +6 -4
  205. package/dist/sse/sse-to-json/builders/response-builder.d.ts +8 -0
  206. package/dist/sse/sse-to-json/builders/response-builder.js +162 -4
  207. package/dist/sse/sse-to-json/responses-sse-to-json-converter.js +2 -0
  208. package/dist/sse/types/responses-types.d.ts +6 -2
  209. package/dist/tools/apply-patch/structured/coercion.js +5 -0
  210. package/dist/tools/args-json.js +29 -0
  211. package/package.json +8 -5
  212. package/dist/conversion/shared/args-mapping.js +0 -77
  213. package/dist/conversion/shared/compaction-detect.js +0 -4
  214. package/dist/conversion/shared/errors.js +0 -31
  215. package/dist/conversion/shared/media.js +0 -4
  216. package/dist/conversion/shared/payload-budget.js +0 -165
  217. package/dist/conversion/shared/protocol-field-allowlists.d.ts +0 -7
  218. package/dist/conversion/shared/protocol-field-allowlists.js +0 -149
  219. package/dist/conversion/shared/snapshot-hooks.d.ts +0 -11
  220. package/dist/conversion/shared/snapshot-hooks.js +0 -503
  221. package/dist/conversion/shared/text-markup-normalizer/extractors-apply-patch.d.ts +0 -2
  222. package/dist/conversion/shared/text-markup-normalizer/extractors-apply-patch.js +0 -129
  223. package/dist/conversion/shared/text-markup-normalizer/extractors-json.d.ts +0 -4
  224. package/dist/conversion/shared/text-markup-normalizer/extractors-json.js +0 -637
  225. package/dist/conversion/shared/text-markup-normalizer/extractors-shared.d.ts +0 -21
  226. package/dist/conversion/shared/text-markup-normalizer/extractors-shared.js +0 -177
  227. package/dist/conversion/shared/text-markup-normalizer/extractors-transcript.d.ts +0 -5
  228. package/dist/conversion/shared/text-markup-normalizer/extractors-transcript.js +0 -385
  229. package/dist/conversion/shared/text-markup-normalizer/extractors-xml.d.ts +0 -10
  230. package/dist/conversion/shared/text-markup-normalizer/extractors-xml.js +0 -602
  231. package/dist/conversion/shared/text-markup-normalizer/extractors.d.ts +0 -5
  232. package/dist/conversion/shared/text-markup-normalizer/extractors.js +0 -4
  233. package/dist/conversion/shared/tool-canonicalizer.d.ts +0 -2
  234. package/dist/conversion/shared/tool-canonicalizer.js +0 -38
  235. /package/dist/conversion/{shared/args-mapping.d.ts → args-mapping.d.ts} +0 -0
  236. /package/dist/conversion/{shared/bridge-actions.d.ts → bridge-actions.d.ts} +0 -0
  237. /package/dist/conversion/{shared/bridge-id-utils.d.ts → bridge-id-utils.d.ts} +0 -0
  238. /package/dist/conversion/{shared/bridge-instructions.d.ts → bridge-instructions.d.ts} +0 -0
  239. /package/dist/conversion/{shared/bridge-metadata.d.ts → bridge-metadata.d.ts} +0 -0
  240. /package/dist/conversion/{shared/bridge-policies.d.ts → bridge-policies.d.ts} +0 -0
  241. /package/dist/conversion/{shared/jsonish.d.ts → jsonish.d.ts} +0 -0
  242. /package/dist/conversion/{shared/mcp-injection.d.ts → mcp-injection.d.ts} +0 -0
  243. /package/dist/conversion/{shared/media.d.ts → media.d.ts} +0 -0
  244. /package/dist/conversion/{shared/payload-budget.d.ts → payload-budget.d.ts} +0 -0
  245. /package/dist/conversion/{shared → types}/bridge-message-types.d.ts +0 -0
  246. /package/dist/conversion/{shared → types}/bridge-message-types.js +0 -0
@@ -1,165 +0,0 @@
1
- // Resolve payload budget (bytes) for a given model from host app config, with safety headroom.
2
- // Search order:
3
- // 1) env ROUTECODEX_CONTEXT_BUDGET_BYTES (direct override)
4
- // 2) config/merged-config*.json (most recent) -> virtualrouter.providers.*.models[model].maxContext
5
- // 3) config/config.json -> virtualrouter.providers.*.models[model].maxContext
6
- // 4) default 200_000 bytes
7
- // Safety headroom: 10% (env RCC_CONTEXT_BUDGET_SAFETY to override; default 0.1)
8
- import { UnifiedConfig } from '../../config-unified/unified-config.js';
9
- import { enforceChatBudgetWithNative } from '../../router/virtual-router/engine-selection/native-shared-conversion-semantics.js';
10
- function isObject(v) { return !!v && typeof v === 'object' && !Array.isArray(v); }
11
- function listMergedConfigsSync(configDir) {
12
- try {
13
- const fs = require('fs');
14
- const path = require('path');
15
- const ents = fs.readdirSync(configDir);
16
- const files = ents.filter((n) => /merged-config.*\.json$/i.test(n)).map((n) => path.join(configDir, n));
17
- files.sort((a, b) => {
18
- try {
19
- const sa = fs.statSync(a);
20
- const sb = fs.statSync(b);
21
- return (sb.mtimeMs || 0) - (sa.mtimeMs || 0);
22
- }
23
- catch {
24
- return 0;
25
- }
26
- });
27
- return files;
28
- }
29
- catch {
30
- return [];
31
- }
32
- }
33
- function readJsonSync(file) {
34
- try {
35
- const fs = require('fs');
36
- const buf = fs.readFileSync(file, 'utf-8');
37
- return JSON.parse(buf);
38
- }
39
- catch {
40
- return null;
41
- }
42
- }
43
- function findMaxContextInConfig(cfg, modelId) {
44
- try {
45
- const vr = cfg.virtualrouter;
46
- if (!vr || typeof vr !== 'object')
47
- return null;
48
- const providers = vr.providers;
49
- if (!providers || typeof providers !== 'object')
50
- return null;
51
- for (const provKey of Object.keys(providers)) {
52
- const prov = providers[provKey];
53
- if (!prov || typeof prov !== 'object')
54
- continue;
55
- const models = prov.models;
56
- if (!models || typeof models !== 'object')
57
- continue;
58
- if (Object.prototype.hasOwnProperty.call(models, modelId)) {
59
- const item = models[modelId];
60
- const v = (item && typeof item === 'object') ? item.maxContext : undefined;
61
- const n = Number(v);
62
- if (Number.isFinite(n) && n > 0)
63
- return n;
64
- }
65
- }
66
- }
67
- catch { /* ignore */ }
68
- return null;
69
- }
70
- export function resolveBudgetForModelSync(modelId) {
71
- try {
72
- const viaFacade = UnifiedConfig.getContextBudgetForModel(modelId);
73
- if (viaFacade && typeof viaFacade.allowedBytes === 'number')
74
- return viaFacade;
75
- }
76
- catch { /* ignore facade errors and fallback */ }
77
- const envDirect = Number(process?.env?.ROUTECODEX_CONTEXT_BUDGET_BYTES || process?.env?.RCC_CONTEXT_BUDGET_BYTES || '');
78
- const envSafety = (() => { const v = Number(process?.env?.RCC_CONTEXT_BUDGET_SAFETY ?? 'NaN'); return (Number.isFinite(v) && v >= 0 && v < 1) ? v : NaN; })();
79
- if (Number.isFinite(envDirect) && envDirect > 0) {
80
- const safety = Number.isFinite(envSafety) ? envSafety : 0.1;
81
- const allowed = Math.floor(envDirect * (1 - safety));
82
- return { maxBytes: envDirect, safetyRatio: safety, allowedBytes: allowed, source: 'env' };
83
- }
84
- const path = require('path');
85
- const cwd = (typeof process !== 'undefined' && process && typeof process.cwd === 'function') ? process.cwd() : '';
86
- const configDir = cwd ? path.join(cwd, 'config') : 'config';
87
- // Modules default context budget (fallback)
88
- let modulesDefault = null;
89
- let modulesSafety = null;
90
- try {
91
- const file = path.join(configDir, 'modules.json');
92
- const cfg = readJsonSync(file);
93
- if (cfg && isObject(cfg.modules) && isObject(cfg.modules.virtualrouter) && isObject(cfg.modules.virtualrouter.config)) {
94
- const vr = cfg.modules.virtualrouter.config;
95
- if (isObject(vr.contextBudget)) {
96
- const ctx = vr.contextBudget;
97
- const d = Number(ctx.defaultMaxContextBytes);
98
- if (Number.isFinite(d) && d > 0)
99
- modulesDefault = d;
100
- const s = Number(ctx.safetyRatio);
101
- if (Number.isFinite(s) && s >= 0 && s < 1)
102
- modulesSafety = s;
103
- }
104
- }
105
- }
106
- catch { /* ignore */ }
107
- try {
108
- const mergedFiles = listMergedConfigsSync(configDir);
109
- for (const file of mergedFiles) {
110
- const cfg = readJsonSync(file);
111
- if (cfg) {
112
- const v = findMaxContextInConfig(cfg, modelId);
113
- if (v && v > 0) {
114
- const safety = Number.isFinite(envSafety) ? envSafety : (modulesSafety ?? 0.1);
115
- const allowed = Math.floor(v * (1 - safety));
116
- return { maxBytes: v, safetyRatio: safety, allowedBytes: allowed, source: `merged:${path.basename(file)}` };
117
- }
118
- }
119
- }
120
- }
121
- catch { /* ignore */ }
122
- try {
123
- const file = path.join(configDir, 'config.json');
124
- const cfg = readJsonSync(file);
125
- if (cfg) {
126
- const v = findMaxContextInConfig(cfg, modelId);
127
- if (v && v > 0) {
128
- const safety = Number.isFinite(envSafety) ? envSafety : (modulesSafety ?? 0.1);
129
- const allowed = Math.floor(v * (1 - safety));
130
- return { maxBytes: v, safetyRatio: safety, allowedBytes: allowed, source: 'config.json' };
131
- }
132
- }
133
- }
134
- catch { /* ignore */ }
135
- // Fallback to modules default, then hard default
136
- const def = modulesDefault && modulesDefault > 0 ? modulesDefault : 200_000;
137
- const safety = Number.isFinite(envSafety) ? envSafety : (modulesSafety ?? 0.1);
138
- return { maxBytes: def, safetyRatio: safety, allowedBytes: Math.floor(def * (1 - safety)), source: (modulesDefault ? 'modules.json' : 'default') };
139
- }
140
- export const resolveBudgetForModel = async (modelId) => resolveBudgetForModelSync(modelId);
141
- // Apply payload budget enforcement to an OpenAI Chat-shaped request object in-place.
142
- // Strategy (deterministic, minimal):
143
- // 1) Truncate the first system message to RCC_SYSTEM_TEXT_LIMIT (default 8192 chars).
144
- // 2) Remove assistant messages that have no tool_calls and empty/whitespace content.
145
- // 3) Iteratively clamp tool role message content down to fit allowedBytes.
146
- // 4) If仍超限,轻度收紧 assistant 文本(不移除,仅截断)。
147
- export function enforceChatBudget(chat, modelId) {
148
- try {
149
- if (!chat || typeof chat !== 'object')
150
- return chat;
151
- const messages = Array.isArray(chat.messages) ? chat.messages : [];
152
- if (!messages.length)
153
- return chat;
154
- const budget = resolveBudgetForModelSync(modelId || 'unknown');
155
- const allowed = Math.max(1024, Number(budget.allowedBytes || 200000));
156
- const sysLimit = (() => {
157
- const raw = process?.env?.RCC_SYSTEM_TEXT_LIMIT;
158
- const n = Number(raw);
159
- return Number.isFinite(n) && n >= 0 ? n : 8192;
160
- })();
161
- return enforceChatBudgetWithNative(chat, allowed, sysLimit);
162
- }
163
- catch { /* ignore budget errors */ }
164
- return chat;
165
- }
@@ -1,7 +0,0 @@
1
- export declare const OPENAI_CHAT_ALLOWED_FIELDS: readonly ["messages", "tools", "tool_outputs", "model", "temperature", "top_p", "top_k", "max_tokens", "frequency_penalty", "presence_penalty", "logit_bias", "response_format", "parallel_tool_calls", "tool_choice", "seed", "user", "metadata", "stop", "stop_sequences", "stream"];
2
- export declare const ANTHROPIC_ALLOWED_FIELDS: readonly ["model", "messages", "tools", "system", "stop_sequences", "temperature", "top_p", "top_k", "max_tokens", "max_output_tokens", "metadata", "stream", "tool_choice"];
3
- export declare const OPENAI_RESPONSES_ALLOWED_FIELDS: readonly ["id", "object", "created_at", "model", "status", "input", "instructions", "output", "output_text", "required_action", "response_id", "previous_response_id", "tool_outputs", "tools", "metadata", "include", "store", "user", "response_format", "temperature", "top_p", "top_k", "max_tokens", "max_output_tokens", "logit_bias", "seed", "parallel_tool_calls", "tool_choice", "prompt_cache_key", "reasoning", "stream", "instructions_is_raw"];
4
- export declare const GEMINI_ALLOWED_FIELDS: readonly ["model", "contents", "systemInstruction", "system_instruction", "generationConfig", "generation_config", "safetySettings", "safety_settings", "metadata", "toolConfig", "tool_config", "tools", "tool_choice", "parallelToolCalls", "parallel_tool_calls", "responseMimeType", "response_mime_type", "stopSequences", "stop_sequences", "cachedContent", "prompt", "response", "candidates", "usageMetadata", "responseMetadata", "promptFeedback", "modelVersion", "client", "user", "stream"];
5
- export declare const OPENAI_RESPONSES_PARAMETERS_WRAPPER_ALLOW_KEYS: readonly ["temperature", "top_p", "max_output_tokens", "seed", "logit_bias", "user", "parallel_tool_calls", "tool_choice", "response_format", "prompt_cache_key", "reasoning", "stream", "stop", "stop_sequences", "modalities", "top_k"];
6
- export declare const OPENAI_CHAT_PARAMETERS_WRAPPER_ALLOW_KEYS: readonly ["temperature", "top_p", "top_k", "max_tokens", "frequency_penalty", "presence_penalty", "logit_bias", "seed", "user", "parallel_tool_calls", "tool_choice", "response_format", "stream", "stop", "stop_sequences"];
7
- export declare const ANTHROPIC_PARAMETERS_WRAPPER_ALLOW_KEYS: readonly ["stop_sequences", "temperature", "top_p", "top_k", "max_tokens", "max_output_tokens", "metadata", "stream", "tool_choice"];
@@ -1,149 +0,0 @@
1
- export const OPENAI_CHAT_ALLOWED_FIELDS = [
2
- 'messages',
3
- 'tools',
4
- 'tool_outputs',
5
- 'model',
6
- 'temperature',
7
- 'top_p',
8
- 'top_k',
9
- 'max_tokens',
10
- 'frequency_penalty',
11
- 'presence_penalty',
12
- 'logit_bias',
13
- 'response_format',
14
- 'parallel_tool_calls',
15
- 'tool_choice',
16
- 'seed',
17
- 'user',
18
- 'metadata',
19
- 'stop',
20
- 'stop_sequences',
21
- 'stream'
22
- ];
23
- export const ANTHROPIC_ALLOWED_FIELDS = [
24
- 'model',
25
- 'messages',
26
- 'tools',
27
- 'system',
28
- 'stop_sequences',
29
- 'temperature',
30
- 'top_p',
31
- 'top_k',
32
- 'max_tokens',
33
- 'max_output_tokens',
34
- 'metadata',
35
- 'stream',
36
- 'tool_choice'
37
- ];
38
- export const OPENAI_RESPONSES_ALLOWED_FIELDS = [
39
- 'id',
40
- 'object',
41
- 'created_at',
42
- 'model',
43
- 'status',
44
- 'input',
45
- 'instructions',
46
- 'output',
47
- 'output_text',
48
- 'required_action',
49
- 'response_id',
50
- 'previous_response_id',
51
- 'tool_outputs',
52
- 'tools',
53
- 'metadata',
54
- 'include',
55
- 'store',
56
- 'user',
57
- 'response_format',
58
- 'temperature',
59
- 'top_p',
60
- 'top_k',
61
- 'max_tokens',
62
- 'max_output_tokens',
63
- 'logit_bias',
64
- 'seed',
65
- 'parallel_tool_calls',
66
- 'tool_choice',
67
- 'prompt_cache_key',
68
- 'reasoning',
69
- 'stream',
70
- 'instructions_is_raw'
71
- ];
72
- export const GEMINI_ALLOWED_FIELDS = [
73
- 'model',
74
- 'contents',
75
- 'systemInstruction',
76
- 'system_instruction',
77
- 'generationConfig',
78
- 'generation_config',
79
- 'safetySettings',
80
- 'safety_settings',
81
- 'metadata',
82
- 'toolConfig',
83
- 'tool_config',
84
- 'tools',
85
- 'tool_choice',
86
- 'parallelToolCalls',
87
- 'parallel_tool_calls',
88
- 'responseMimeType',
89
- 'response_mime_type',
90
- 'stopSequences',
91
- 'stop_sequences',
92
- 'cachedContent',
93
- 'prompt',
94
- 'response',
95
- 'candidates',
96
- 'usageMetadata',
97
- 'responseMetadata',
98
- 'promptFeedback',
99
- 'modelVersion',
100
- 'client',
101
- 'user',
102
- 'stream'
103
- ];
104
- export const OPENAI_RESPONSES_PARAMETERS_WRAPPER_ALLOW_KEYS = [
105
- 'temperature',
106
- 'top_p',
107
- 'max_output_tokens',
108
- 'seed',
109
- 'logit_bias',
110
- 'user',
111
- 'parallel_tool_calls',
112
- 'tool_choice',
113
- 'response_format',
114
- 'prompt_cache_key',
115
- 'reasoning',
116
- 'stream',
117
- 'stop',
118
- 'stop_sequences',
119
- 'modalities',
120
- 'top_k'
121
- ];
122
- export const OPENAI_CHAT_PARAMETERS_WRAPPER_ALLOW_KEYS = [
123
- 'temperature',
124
- 'top_p',
125
- 'top_k',
126
- 'max_tokens',
127
- 'frequency_penalty',
128
- 'presence_penalty',
129
- 'logit_bias',
130
- 'seed',
131
- 'user',
132
- 'parallel_tool_calls',
133
- 'tool_choice',
134
- 'response_format',
135
- 'stream',
136
- 'stop',
137
- 'stop_sequences'
138
- ];
139
- export const ANTHROPIC_PARAMETERS_WRAPPER_ALLOW_KEYS = [
140
- 'stop_sequences',
141
- 'temperature',
142
- 'top_p',
143
- 'top_k',
144
- 'max_tokens',
145
- 'max_output_tokens',
146
- 'metadata',
147
- 'stream',
148
- 'tool_choice'
149
- ];
@@ -1,11 +0,0 @@
1
- export interface SnapshotHookOptions {
2
- endpoint: string;
3
- stage: string;
4
- requestId: string;
5
- data: unknown;
6
- verbosity?: 'minimal' | 'verbose';
7
- channel?: string;
8
- providerKey?: string;
9
- groupRequestId?: string;
10
- }
11
- export declare function writeSnapshotViaHooks(options: SnapshotHookOptions): Promise<void>;