@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.
- package/dist/conversion/args-mapping.js +8 -0
- package/dist/conversion/{shared/bridge-actions.js → bridge-actions.js} +2 -1
- package/dist/conversion/{shared/bridge-id-utils.js → bridge-id-utils.js} +1 -1
- package/dist/conversion/{shared/bridge-instructions.js → bridge-instructions.js} +1 -1
- package/dist/conversion/{shared/bridge-message-utils.d.ts → bridge-message-utils.d.ts} +1 -1
- package/dist/conversion/{shared/bridge-message-utils.js → bridge-message-utils.js} +5 -149
- package/dist/conversion/{shared/bridge-metadata.js → bridge-metadata.js} +1 -1
- package/dist/conversion/{shared/bridge-policies.js → bridge-policies.js} +1 -1
- package/dist/conversion/codecs/gemini-openai-codec.js +27 -8
- package/dist/conversion/codecs/responses-openai-codec.js +1 -1
- package/dist/conversion/{shared/compaction-detect.d.ts → compaction-detect.d.ts} +1 -1
- package/dist/conversion/compaction-detect.js +4 -0
- package/dist/conversion/compat/actions/apply-patch-fixer.js +2 -2
- package/dist/conversion/compat/actions/deepseek-web-response.d.ts +0 -1
- package/dist/conversion/compat/actions/deepseek-web-response.js +15 -405
- package/dist/conversion/compat/actions/harvest-tool-calls-from-text.js +1 -1
- package/dist/conversion/compat/actions/lmstudio-responses-fc-ids.js +1 -1
- package/dist/conversion/compat/actions/qwen-transform.js +74 -2
- package/dist/conversion/compat/actions/snapshot.js +1 -1
- package/dist/conversion/compat/antigravity-session-signature.js +36 -0
- package/dist/conversion/compat/profiles/chat-deepseek-web.json +0 -22
- package/dist/conversion/compat/profiles/chat-glm.json +251 -72
- package/dist/conversion/compat/profiles/chat-iflow.json +174 -39
- package/dist/conversion/compat/profiles/chat-lmstudio.json +43 -14
- package/dist/conversion/hub/operation-table/operation-table-runner.js +2 -2
- package/dist/conversion/hub/operation-table/semantic-mappers/anthropic-mapper.js +1 -1
- package/dist/conversion/hub/operation-table/semantic-mappers/archive/chat-mapper.archive.d.ts +8 -0
- package/dist/conversion/hub/operation-table/semantic-mappers/archive/chat-mapper.archive.js +404 -0
- package/dist/conversion/hub/operation-table/semantic-mappers/chat-mapper.js +5 -381
- package/dist/conversion/hub/operation-table/semantic-mappers/gemini-mapper.js +2 -2
- package/dist/conversion/hub/operation-table/semantic-mappers/responses-mapper.js +2 -8
- package/dist/conversion/hub/pipeline/hub-pipeline.d.ts +1 -0
- package/dist/conversion/hub/pipeline/hub-pipeline.js +50 -3
- package/dist/conversion/hub/pipeline/stages/req_inbound/req_inbound_stage2_semantic_map/index.d.ts +1 -1
- package/dist/conversion/hub/pipeline/stages/req_inbound/req_inbound_stage2_semantic_map/index.js +62 -0
- package/dist/conversion/hub/pipeline/stages/req_process/req_process_stage2_route_select/index.js +3 -1
- package/dist/conversion/hub/pipeline/stages/resp_inbound/resp_inbound_stage1_sse_decode/index.js +1 -1
- package/dist/conversion/hub/pipeline/stages/resp_outbound/resp_outbound_stage1_client_remap/chat-process-semantics-bridge.d.ts +1 -1
- package/dist/conversion/hub/pipeline/stages/resp_process/resp_process_stage1_tool_governance/index.js +42 -29
- package/dist/conversion/hub/pipeline/stages/resp_process/resp_process_stage2_finalize/index.js +12 -0
- package/dist/conversion/hub/policy/protocol-spec.js +1 -1
- package/dist/conversion/hub/process/chat-process-clock-reminders.js +1 -1
- package/dist/conversion/hub/process/chat-process-clock-tools.js +1 -1
- package/dist/conversion/hub/process/chat-process-continue-execution.js +1 -1
- package/dist/conversion/hub/process/chat-process-servertool-orchestration.js +1 -1
- package/dist/conversion/hub/process/chat-process-web-search.js +1 -1
- package/dist/conversion/hub/response/provider-response.js +14 -5
- package/dist/conversion/hub/response/response-mappers.js +23 -1
- package/dist/conversion/hub/response/response-runtime.js +28 -5
- package/dist/conversion/hub/snapshot-recorder.js +3 -92
- package/dist/conversion/hub/tool-governance/engine.d.ts +8 -0
- package/dist/conversion/hub/tool-governance/engine.js +40 -193
- package/dist/conversion/hub/tool-governance/rules.js +73 -69
- package/dist/conversion/hub/tool-surface/tool-surface-engine.js +1 -1
- package/dist/conversion/index.d.ts +1 -2
- package/dist/conversion/index.js +1 -2
- package/dist/conversion/{shared/jsonish.js → jsonish.js} +1 -1
- package/dist/conversion/{shared/mcp-injection.js → mcp-injection.js} +1 -1
- package/dist/conversion/media.js +4 -0
- package/dist/conversion/{shared/metadata-passthrough.d.ts → metadata-passthrough.d.ts} +1 -1
- package/dist/conversion/{shared/metadata-passthrough.js → metadata-passthrough.js} +2 -2
- package/dist/conversion/payload-budget.js +47 -0
- package/dist/conversion/protocol-field-allowlists.d.ts +7 -0
- package/dist/conversion/protocol-field-allowlists.js +9 -0
- package/dist/conversion/{shared/protocol-state.d.ts → protocol-state.d.ts} +2 -2
- package/dist/conversion/{shared/protocol-state.js → protocol-state.js} +2 -2
- package/dist/conversion/{shared/errors.d.ts → provider-protocol-error.d.ts} +0 -3
- package/dist/conversion/provider-protocol-error.js +25 -0
- package/dist/conversion/responses/responses-openai-bridge/response-payload.js +8 -5
- package/dist/conversion/responses/responses-openai-bridge/types.d.ts +1 -1
- package/dist/conversion/responses/responses-openai-bridge.d.ts +1 -1
- package/dist/conversion/responses/responses-openai-bridge.js +43 -10
- package/dist/conversion/{shared/runtime-metadata.d.ts → runtime-metadata.d.ts} +1 -1
- package/dist/conversion/{shared/runtime-metadata.js → runtime-metadata.js} +2 -2
- package/dist/conversion/shared/anthropic-message-utils.js +19 -8
- package/dist/conversion/shared/chat-request-filters.d.ts +3 -4
- package/dist/conversion/shared/chat-request-filters.js +22 -78
- package/dist/conversion/shared/gemini-tool-utils.d.ts +1 -1
- package/dist/conversion/shared/openai-finalizer.js +1 -0
- package/dist/conversion/shared/openai-message-normalize.js +2 -2
- package/dist/conversion/shared/reasoning-normalizer.js +6 -0
- package/dist/conversion/shared/reasoning-utils.js +5 -2
- package/dist/conversion/shared/responses-conversation-store.js +1 -1
- package/dist/conversion/shared/responses-output-builder.js +55 -11
- package/dist/conversion/shared/responses-reasoning-registry.d.ts +14 -2
- package/dist/conversion/shared/responses-reasoning-registry.js +34 -6
- package/dist/conversion/shared/responses-response-utils.js +99 -9
- package/dist/conversion/shared/responses-tool-utils.js +1 -1
- package/dist/conversion/shared/text-markup-normalizer/normalize.d.ts +1 -1
- package/dist/conversion/shared/text-markup-normalizer.d.ts +2 -2
- package/dist/conversion/shared/text-markup-normalizer.js +1 -1
- package/dist/conversion/shared/tool-filter-pipeline.js +1 -1
- package/dist/conversion/shared/tool-governor.js +3 -3
- package/dist/conversion/shared/tool-mapping.d.ts +1 -1
- package/dist/conversion/{shared/snapshot-utils.d.ts → snapshot-utils.d.ts} +11 -0
- package/dist/conversion/{shared/snapshot-utils.js → snapshot-utils.js} +14 -23
- package/dist/conversion/types/text-markup-normalizer.d.ts +13 -0
- package/dist/conversion/types/text-markup-normalizer.js +1 -0
- package/dist/filters/special/request-tools-normalize.js +1 -1
- package/dist/filters/special/response-tool-text-canonicalize.js +2 -2
- package/dist/native/router_hotpath_napi.node +0 -0
- package/dist/quota/quota-manager.js +31 -59
- package/dist/quota/quota-state.js +14 -7
- package/dist/router/virtual-router/bootstrap/profile-builder.d.ts +1 -0
- package/dist/router/virtual-router/bootstrap/profile-builder.js +13 -0
- package/dist/router/virtual-router/bootstrap/provider-normalization.d.ts +2 -0
- package/dist/router/virtual-router/bootstrap/provider-normalization.js +4 -1
- package/dist/router/virtual-router/bootstrap/streaming-helpers.d.ts +7 -0
- package/dist/router/virtual-router/bootstrap/streaming-helpers.js +44 -0
- package/dist/router/virtual-router/bootstrap.js +2 -0
- package/dist/router/virtual-router/engine/routing-state/store.d.ts +1 -2
- package/dist/router/virtual-router/engine/routing-state/store.js +2 -2
- package/dist/router/virtual-router/engine-legacy/config.d.ts +11 -0
- package/dist/router/virtual-router/engine-legacy/config.js +108 -0
- package/dist/router/virtual-router/engine-legacy/direct-model.d.ts +10 -0
- package/dist/router/virtual-router/engine-legacy/direct-model.js +38 -0
- package/dist/router/virtual-router/engine-legacy/health.d.ts +13 -0
- package/dist/router/virtual-router/engine-legacy/health.js +104 -0
- package/dist/router/virtual-router/engine-legacy/helpers.d.ts +16 -0
- package/dist/router/virtual-router/engine-legacy/helpers.js +226 -0
- package/dist/router/virtual-router/engine-legacy/route-finalize.d.ts +9 -0
- package/dist/router/virtual-router/engine-legacy/route-finalize.js +84 -0
- package/dist/router/virtual-router/engine-legacy/route-selection.d.ts +17 -0
- package/dist/router/virtual-router/engine-legacy/route-selection.js +205 -0
- package/dist/router/virtual-router/engine-legacy/route-state-allowlist.d.ts +3 -0
- package/dist/router/virtual-router/engine-legacy/route-state-allowlist.js +36 -0
- package/dist/router/virtual-router/engine-legacy/route-state.d.ts +12 -0
- package/dist/router/virtual-router/engine-legacy/route-state.js +386 -0
- package/dist/router/virtual-router/engine-legacy/route-utils.d.ts +19 -0
- package/dist/router/virtual-router/engine-legacy/route-utils.js +212 -0
- package/dist/router/virtual-router/engine-legacy/routing.d.ts +8 -0
- package/dist/router/virtual-router/engine-legacy/routing.js +8 -0
- package/dist/router/virtual-router/engine-legacy/selection-core.d.ts +28 -0
- package/dist/router/virtual-router/engine-legacy/selection-core.js +112 -0
- package/dist/router/virtual-router/engine-legacy/selection-state.d.ts +16 -0
- package/dist/router/virtual-router/engine-legacy/selection-state.js +187 -0
- package/dist/router/virtual-router/engine-legacy/state-accessors.d.ts +21 -0
- package/dist/router/virtual-router/engine-legacy/state-accessors.js +118 -0
- package/dist/router/virtual-router/engine-legacy.d.ts +123 -0
- package/dist/router/virtual-router/engine-legacy.js +194 -0
- package/dist/router/virtual-router/engine-logging.d.ts +2 -0
- package/dist/router/virtual-router/engine-logging.js +7 -2
- package/dist/router/virtual-router/engine-selection/key-parsing.js +0 -3
- package/dist/router/virtual-router/engine-selection/native-chat-request-filter-semantics.d.ts +1 -0
- package/dist/router/virtual-router/engine-selection/native-chat-request-filter-semantics.js +54 -0
- package/dist/router/virtual-router/engine-selection/native-hub-bridge-policy-semantics.d.ts +10 -0
- package/dist/router/virtual-router/engine-selection/native-hub-bridge-policy-semantics.js +67 -0
- package/dist/router/virtual-router/engine-selection/native-hub-pipeline-governance-semantics.d.ts +30 -0
- package/dist/router/virtual-router/engine-selection/native-hub-pipeline-governance-semantics.js +202 -0
- package/dist/router/virtual-router/engine-selection/native-hub-pipeline-semantic-mappers.d.ts +2 -0
- package/dist/router/virtual-router/engine-selection/native-hub-pipeline-semantic-mappers.js +83 -0
- package/dist/router/virtual-router/engine-selection/native-router-hotpath-loader.js +43 -2
- package/dist/router/virtual-router/engine-selection/native-shared-conversion-semantics.d.ts +75 -0
- package/dist/router/virtual-router/engine-selection/native-shared-conversion-semantics.js +205 -0
- package/dist/router/virtual-router/engine-selection/native-snapshot-hooks.d.ts +3 -0
- package/dist/router/virtual-router/engine-selection/native-snapshot-hooks.js +109 -0
- package/dist/router/virtual-router/engine-selection/native-virtual-router-engine-proxy.d.ts +16 -0
- package/dist/router/virtual-router/engine-selection/native-virtual-router-engine-proxy.js +14 -0
- package/dist/router/virtual-router/engine-selection/native-virtual-router-routing-instructions-semantics.d.ts +2 -0
- package/dist/router/virtual-router/engine-selection/native-virtual-router-routing-instructions-semantics.js +86 -0
- package/dist/router/virtual-router/engine-selection/tier-selection-quota-integration.js +100 -0
- package/dist/router/virtual-router/engine-selection/tier-selection-select.js +99 -0
- package/dist/router/virtual-router/engine.d.ts +22 -105
- package/dist/router/virtual-router/engine.js +274 -1641
- package/dist/router/virtual-router/load-balancer.d.ts +8 -0
- package/dist/router/virtual-router/load-balancer.js +65 -2
- package/dist/router/virtual-router/provider-registry.js +2 -0
- package/dist/router/virtual-router/routing-instructions/clean.d.ts +3 -0
- package/dist/router/virtual-router/routing-instructions/clean.js +34 -0
- package/dist/router/virtual-router/routing-instructions/parse.d.ts +18 -0
- package/dist/router/virtual-router/routing-instructions/parse.js +377 -0
- package/dist/router/virtual-router/routing-instructions/state.d.ts +4 -0
- package/dist/router/virtual-router/routing-instructions/state.js +245 -0
- package/dist/router/virtual-router/routing-instructions/types.d.ts +70 -0
- package/dist/router/virtual-router/routing-instructions/types.js +2 -0
- package/dist/router/virtual-router/routing-instructions.d.ts +5 -89
- package/dist/router/virtual-router/routing-instructions.js +4 -655
- package/dist/router/virtual-router/sticky-session-store.d.ts +4 -0
- package/dist/router/virtual-router/sticky-session-store.js +19 -81
- package/dist/router/virtual-router/tool-signals.js +21 -3
- package/dist/router/virtual-router/types.d.ts +4 -0
- package/dist/servertool/clock/session-scope.js +32 -1
- package/dist/servertool/engine.js +79 -8
- package/dist/servertool/handlers/antigravity-thought-signature-bootstrap.js +1 -1
- package/dist/servertool/handlers/clock-auto.js +1 -1
- package/dist/servertool/handlers/clock.js +1 -1
- package/dist/servertool/handlers/compaction-detect.d.ts +1 -1
- package/dist/servertool/handlers/compaction-detect.js +1 -1
- package/dist/servertool/handlers/gemini-empty-reply-continue.js +1 -1
- package/dist/servertool/handlers/iflow-model-error-retry.js +1 -1
- package/dist/servertool/handlers/recursive-detection-guard.js +1 -1
- package/dist/servertool/handlers/review.js +1 -1
- package/dist/servertool/handlers/stop-message-auto/iflow-followup.js +1 -1
- package/dist/servertool/handlers/stop-message-auto/runtime-utils.js +1 -1
- package/dist/servertool/handlers/stop-message-auto.js +1 -1
- package/dist/servertool/handlers/vision.js +1 -1
- package/dist/servertool/handlers/web-search.js +1 -1
- package/dist/servertool/reenter-backend.js +1 -1
- package/dist/servertool/server-side-tools.js +2 -2
- package/dist/servertool/stop-gateway-context.js +1 -1
- package/dist/servertool/stop-message-compare-context.js +1 -1
- package/dist/sse/json-to-sse/event-generators/responses.d.ts +4 -0
- package/dist/sse/json-to-sse/event-generators/responses.js +95 -1
- package/dist/sse/json-to-sse/sequencers/responses-sequencer.js +6 -4
- package/dist/sse/sse-to-json/builders/response-builder.d.ts +8 -0
- package/dist/sse/sse-to-json/builders/response-builder.js +162 -4
- package/dist/sse/sse-to-json/responses-sse-to-json-converter.js +2 -0
- package/dist/sse/types/responses-types.d.ts +6 -2
- package/dist/tools/apply-patch/structured/coercion.js +5 -0
- package/dist/tools/args-json.js +29 -0
- package/package.json +8 -5
- package/dist/conversion/shared/args-mapping.js +0 -77
- package/dist/conversion/shared/compaction-detect.js +0 -4
- package/dist/conversion/shared/errors.js +0 -31
- package/dist/conversion/shared/media.js +0 -4
- package/dist/conversion/shared/payload-budget.js +0 -165
- package/dist/conversion/shared/protocol-field-allowlists.d.ts +0 -7
- package/dist/conversion/shared/protocol-field-allowlists.js +0 -149
- package/dist/conversion/shared/snapshot-hooks.d.ts +0 -11
- package/dist/conversion/shared/snapshot-hooks.js +0 -503
- package/dist/conversion/shared/text-markup-normalizer/extractors-apply-patch.d.ts +0 -2
- package/dist/conversion/shared/text-markup-normalizer/extractors-apply-patch.js +0 -129
- package/dist/conversion/shared/text-markup-normalizer/extractors-json.d.ts +0 -4
- package/dist/conversion/shared/text-markup-normalizer/extractors-json.js +0 -637
- package/dist/conversion/shared/text-markup-normalizer/extractors-shared.d.ts +0 -21
- package/dist/conversion/shared/text-markup-normalizer/extractors-shared.js +0 -177
- package/dist/conversion/shared/text-markup-normalizer/extractors-transcript.d.ts +0 -5
- package/dist/conversion/shared/text-markup-normalizer/extractors-transcript.js +0 -385
- package/dist/conversion/shared/text-markup-normalizer/extractors-xml.d.ts +0 -10
- package/dist/conversion/shared/text-markup-normalizer/extractors-xml.js +0 -602
- package/dist/conversion/shared/text-markup-normalizer/extractors.d.ts +0 -5
- package/dist/conversion/shared/text-markup-normalizer/extractors.js +0 -4
- package/dist/conversion/shared/tool-canonicalizer.d.ts +0 -2
- package/dist/conversion/shared/tool-canonicalizer.js +0 -38
- /package/dist/conversion/{shared/args-mapping.d.ts → args-mapping.d.ts} +0 -0
- /package/dist/conversion/{shared/bridge-actions.d.ts → bridge-actions.d.ts} +0 -0
- /package/dist/conversion/{shared/bridge-id-utils.d.ts → bridge-id-utils.d.ts} +0 -0
- /package/dist/conversion/{shared/bridge-instructions.d.ts → bridge-instructions.d.ts} +0 -0
- /package/dist/conversion/{shared/bridge-metadata.d.ts → bridge-metadata.d.ts} +0 -0
- /package/dist/conversion/{shared/bridge-policies.d.ts → bridge-policies.d.ts} +0 -0
- /package/dist/conversion/{shared/jsonish.d.ts → jsonish.d.ts} +0 -0
- /package/dist/conversion/{shared/mcp-injection.d.ts → mcp-injection.d.ts} +0 -0
- /package/dist/conversion/{shared/media.d.ts → media.d.ts} +0 -0
- /package/dist/conversion/{shared/payload-budget.d.ts → payload-budget.d.ts} +0 -0
- /package/dist/conversion/{shared → types}/bridge-message-types.d.ts +0 -0
- /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>;
|