@jsonstudio/rcc 0.90.876 → 0.90.1270
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/README.md +5 -6
- package/configsamples/provider-default/ali-coding-plan/config.v2.json +6 -1
- package/configsamples/provider-default/antigravity/config.v2.json +6 -1
- package/configsamples/provider-default/ark-coding-plan/config.v2.json +7 -2
- package/configsamples/provider-default/crs/config.v2.json +6 -1
- package/configsamples/provider-default/deepseek-web/config.v2.json +6 -1
- package/configsamples/provider-default/gemini/config.v2.json +6 -1
- package/configsamples/provider-default/gemini-cli/config.v2.json +6 -1
- package/configsamples/provider-default/gemini-native/config.v2.json +6 -1
- package/configsamples/provider-default/glm/config.v2.json +7 -2
- package/configsamples/provider-default/glm-anthropic/config.v2.json +6 -1
- package/configsamples/provider-default/kimi/config.v2.json +7 -2
- package/configsamples/provider-default/lmstudio/config.v2.json +6 -1
- package/configsamples/provider-default/lmstudio-proxy/config.v2.json +6 -1
- package/configsamples/provider-default/manifest.json +0 -1
- package/configsamples/provider-default/meituan/config.v2.json +6 -1
- package/configsamples/provider-default/mimo/config.v2.json +7 -2
- package/configsamples/provider-default/modelscope/config.v2.json +7 -2
- package/configsamples/provider-default/my-openai/config.v2.json +6 -1
- package/configsamples/provider-default/nvidia/config.v2.json +7 -2
- package/configsamples/provider-default/opencode-zen-free/config.v2.json +6 -1
- package/configsamples/provider-default/openrouter/config.v2.json +6 -1
- package/configsamples/provider-default/qwen/config.v2.json +11 -1
- package/configsamples/provider-default/tab/config.v2.json +6 -1
- package/configsamples/provider-default/tabglm/config.v2.json +7 -2
- package/dist/build-info.js +2 -2
- package/dist/build-info.js.map +1 -1
- package/dist/cli/commands/camoufox.js +44 -3
- package/dist/cli/commands/camoufox.js.map +1 -1
- package/dist/cli/commands/config.js +2 -2
- package/dist/cli/commands/config.js.map +1 -1
- package/dist/cli/commands/heartbeat.js +82 -27
- package/dist/cli/commands/heartbeat.js.map +1 -1
- package/dist/cli/commands/init.js +1 -2
- package/dist/cli/commands/init.js.map +1 -1
- package/dist/cli/commands/launcher/utils.js +37 -24
- package/dist/cli/commands/launcher/utils.js.map +1 -1
- package/dist/cli/commands/launcher-kernel.js +6 -3
- package/dist/cli/commands/launcher-kernel.js.map +1 -1
- package/dist/cli/commands/restart.js +102 -31
- package/dist/cli/commands/restart.js.map +1 -1
- package/dist/cli/commands/start-types.d.ts +1 -0
- package/dist/cli/commands/start-utils.d.ts +1 -0
- package/dist/cli/commands/start-utils.js +3 -0
- package/dist/cli/commands/start-utils.js.map +1 -1
- package/dist/cli/commands/start.js +217 -51
- package/dist/cli/commands/start.js.map +1 -1
- package/dist/cli/commands/status.js +48 -9
- package/dist/cli/commands/status.js.map +1 -1
- package/dist/cli/config/bootstrap-provider-templates.js +1 -1
- package/dist/cli/config/bootstrap-provider-templates.js.map +1 -1
- package/dist/cli/config/init-provider-catalog.js +3 -50
- package/dist/cli/config/init-provider-catalog.js.map +1 -1
- package/dist/cli/config/init-v2-builder.js +0 -1
- package/dist/cli/config/init-v2-builder.js.map +1 -1
- package/dist/cli/guardian/client.js +40 -18
- package/dist/cli/guardian/client.js.map +1 -1
- package/dist/cli/server/port-utils.d.ts +5 -0
- package/dist/cli/server/port-utils.js +45 -31
- package/dist/cli/server/port-utils.js.map +1 -1
- package/dist/commands/camoufox-fp.js +1 -1
- package/dist/commands/camoufox-fp.js.map +1 -1
- package/dist/commands/oauth.js +48 -64
- package/dist/commands/oauth.js.map +1 -1
- package/dist/commands/provider-update-maintenance.js +4 -4
- package/dist/commands/provider-update-maintenance.js.map +1 -1
- package/dist/commands/token-daemon.js +38 -10
- package/dist/commands/token-daemon.js.map +1 -1
- package/dist/commands/validate.js +31 -3
- package/dist/commands/validate.js.map +1 -1
- package/dist/config/provider-v2-loader.d.ts +5 -2
- package/dist/config/provider-v2-loader.js +80 -26
- package/dist/config/provider-v2-loader.js.map +1 -1
- package/dist/config/routecodex-config-loader.d.ts +1 -0
- package/dist/config/routecodex-config-loader.js +18 -207
- package/dist/config/routecodex-config-loader.js.map +1 -1
- package/dist/config/virtual-router-builder.d.ts +3 -2
- package/dist/config/virtual-router-builder.js +4 -214
- package/dist/config/virtual-router-builder.js.map +1 -1
- package/dist/constants/index.d.ts +2 -3
- package/dist/constants/index.js +2 -4
- package/dist/constants/index.js.map +1 -1
- package/dist/error-handling/route-error-hub.js +1 -0
- package/dist/error-handling/route-error-hub.js.map +1 -1
- package/dist/index.js +98 -21
- package/dist/index.js.map +1 -1
- package/dist/manager/modules/quota/antigravity-quota-manager.d.ts +1 -1
- package/dist/manager/modules/quota/antigravity-quota-manager.js +21 -12
- package/dist/manager/modules/quota/antigravity-quota-manager.js.map +1 -1
- package/dist/manager/modules/quota/antigravity-quota-runtime.d.ts +1 -1
- package/dist/manager/modules/quota/antigravity-quota-runtime.js +32 -45
- package/dist/manager/modules/quota/antigravity-quota-runtime.js.map +1 -1
- package/dist/manager/modules/quota/provider-key-normalization.js +10 -1
- package/dist/manager/modules/quota/provider-key-normalization.js.map +1 -1
- package/dist/manager/modules/quota/provider-quota-daemon.d.ts +2 -1
- package/dist/manager/modules/quota/provider-quota-daemon.error-helpers.d.ts +1 -1
- package/dist/manager/modules/quota/provider-quota-daemon.error-helpers.js +22 -12
- package/dist/manager/modules/quota/provider-quota-daemon.error-helpers.js.map +1 -1
- package/dist/manager/modules/quota/provider-quota-daemon.events.js +69 -33
- package/dist/manager/modules/quota/provider-quota-daemon.events.js.map +1 -1
- package/dist/manager/modules/quota/provider-quota-daemon.js +47 -35
- package/dist/manager/modules/quota/provider-quota-daemon.js.map +1 -1
- package/dist/manager/storage/file-store.js +3 -0
- package/dist/manager/storage/file-store.js.map +1 -1
- package/dist/modules/llmswitch/bridge/antigravity-signature.js +58 -20
- package/dist/modules/llmswitch/bridge/antigravity-signature.js.map +1 -1
- package/dist/modules/llmswitch/bridge/index.d.ts +1 -1
- package/dist/modules/llmswitch/bridge/index.js +1 -1
- package/dist/modules/llmswitch/bridge/index.js.map +1 -1
- package/dist/modules/llmswitch/bridge/runtime-integrations.d.ts +22 -16
- package/dist/modules/llmswitch/bridge/runtime-integrations.js +89 -30
- package/dist/modules/llmswitch/bridge/runtime-integrations.js.map +1 -1
- package/dist/modules/llmswitch/bridge/snapshot-recorder-runtime.js +10 -9
- package/dist/modules/llmswitch/bridge/snapshot-recorder-runtime.js.map +1 -1
- package/dist/modules/llmswitch/bridge/snapshot-recorder.js +3 -0
- package/dist/modules/llmswitch/bridge/snapshot-recorder.js.map +1 -1
- package/dist/modules/llmswitch/bridge/state-integrations.d.ts +1 -0
- package/dist/modules/llmswitch/bridge/state-integrations.js +263 -51
- package/dist/modules/llmswitch/bridge/state-integrations.js.map +1 -1
- package/dist/modules/llmswitch/bridge.d.ts +2 -2
- package/dist/modules/llmswitch/bridge.js +2 -2
- package/dist/modules/llmswitch/bridge.js.map +1 -1
- package/dist/provider-sdk/provider-add-template.d.ts +1 -1
- package/dist/provider-sdk/provider-add-template.js.map +1 -1
- package/dist/provider-sdk/provider-runtime-inference.js +48 -13
- package/dist/provider-sdk/provider-runtime-inference.js.map +1 -1
- package/dist/providers/auth/deepseek-account-token-acquirer.d.ts +24 -0
- package/dist/providers/auth/deepseek-account-token-acquirer.js +42 -13
- package/dist/providers/auth/deepseek-account-token-acquirer.js.map +1 -1
- package/dist/providers/auth/oauth-auth.js +12 -5
- package/dist/providers/auth/oauth-auth.js.map +1 -1
- package/dist/providers/auth/oauth-lifecycle/path-resolver.d.ts +0 -1
- package/dist/providers/auth/oauth-lifecycle/path-resolver.js +10 -9
- package/dist/providers/auth/oauth-lifecycle/path-resolver.js.map +1 -1
- package/dist/providers/auth/oauth-lifecycle/token-helpers.js +0 -1
- package/dist/providers/auth/oauth-lifecycle/token-helpers.js.map +1 -1
- package/dist/providers/auth/oauth-lifecycle/token-io.js +18 -8
- package/dist/providers/auth/oauth-lifecycle/token-io.js.map +1 -1
- package/dist/providers/auth/oauth-lifecycle.d.ts +5 -0
- package/dist/providers/auth/oauth-lifecycle.js +370 -353
- package/dist/providers/auth/oauth-lifecycle.js.map +1 -1
- package/dist/providers/auth/oauth-repair-env.js +0 -26
- package/dist/providers/auth/oauth-repair-env.js.map +1 -1
- package/dist/providers/auth/qwen-userinfo-helper.d.ts +11 -0
- package/dist/providers/auth/qwen-userinfo-helper.js +85 -13
- package/dist/providers/auth/qwen-userinfo-helper.js.map +1 -1
- package/dist/providers/auth/token-refresh/token-state.js +1 -4
- package/dist/providers/auth/token-refresh/token-state.js.map +1 -1
- package/dist/providers/auth/token-scanner/index.d.ts +1 -1
- package/dist/providers/auth/token-scanner/index.js +2 -2
- package/dist/providers/auth/token-storage/token-file-resolver.js +0 -3
- package/dist/providers/auth/token-storage/token-file-resolver.js.map +1 -1
- package/dist/providers/auth/token-storage/token-persistence.js +10 -3
- package/dist/providers/auth/token-storage/token-persistence.js.map +1 -1
- package/dist/providers/auth/tokenfile-auth.d.ts +0 -1
- package/dist/providers/auth/tokenfile-auth.js +23 -30
- package/dist/providers/auth/tokenfile-auth.js.map +1 -1
- package/dist/providers/core/api/provider-config.d.ts +1 -1
- package/dist/providers/core/api/provider-types.d.ts +2 -1
- package/dist/providers/core/config/camoufox-actions.js +23 -15
- package/dist/providers/core/config/camoufox-actions.js.map +1 -1
- package/dist/providers/core/config/camoufox-launcher.js +235 -121
- package/dist/providers/core/config/camoufox-launcher.js.map +1 -1
- package/dist/providers/core/config/oauth-flows.js +23 -1
- package/dist/providers/core/config/oauth-flows.js.map +1 -1
- package/dist/providers/core/config/provider-oauth-configs.js +2 -93
- package/dist/providers/core/config/provider-oauth-configs.js.map +1 -1
- package/dist/providers/core/config/service-profiles.d.ts +0 -1
- package/dist/providers/core/config/service-profiles.js +23 -66
- package/dist/providers/core/config/service-profiles.js.map +1 -1
- package/dist/providers/core/runtime/base-provider-runtime-helpers.js +4 -1
- package/dist/providers/core/runtime/base-provider-runtime-helpers.js.map +1 -1
- package/dist/providers/core/runtime/base-provider.js +21 -11
- package/dist/providers/core/runtime/base-provider.js.map +1 -1
- package/dist/providers/core/runtime/deepseek-http-provider-helpers.d.ts +1 -0
- package/dist/providers/core/runtime/deepseek-http-provider-helpers.js +28 -0
- package/dist/providers/core/runtime/deepseek-http-provider-helpers.js.map +1 -1
- package/dist/providers/core/runtime/deepseek-http-provider.d.ts +0 -2
- package/dist/providers/core/runtime/deepseek-http-provider.js +3 -33
- package/dist/providers/core/runtime/deepseek-http-provider.js.map +1 -1
- package/dist/providers/core/runtime/http-request-executor.d.ts +1 -0
- package/dist/providers/core/runtime/http-request-executor.js +131 -47
- package/dist/providers/core/runtime/http-request-executor.js.map +1 -1
- package/dist/providers/core/runtime/http-transport-provider.d.ts +5 -5
- package/dist/providers/core/runtime/http-transport-provider.js +97 -38
- package/dist/providers/core/runtime/http-transport-provider.js.map +1 -1
- package/dist/providers/core/runtime/openai-responses-sdk-transport.js +2 -1
- package/dist/providers/core/runtime/openai-responses-sdk-transport.js.map +1 -1
- package/dist/providers/core/runtime/provider-error-classifier.js +19 -126
- package/dist/providers/core/runtime/provider-error-classifier.js.map +1 -1
- package/dist/providers/core/runtime/provider-factory-helpers.d.ts +1 -0
- package/dist/providers/core/runtime/provider-factory-helpers.js +8 -12
- package/dist/providers/core/runtime/provider-factory-helpers.js.map +1 -1
- package/dist/providers/core/runtime/provider-factory.js +2 -9
- package/dist/providers/core/runtime/provider-factory.js.map +1 -1
- package/dist/providers/core/runtime/provider-failure-policy.d.ts +135 -0
- package/dist/providers/core/runtime/provider-failure-policy.js +685 -0
- package/dist/providers/core/runtime/provider-failure-policy.js.map +1 -0
- package/dist/providers/core/runtime/provider-family-profile-utils.d.ts +0 -10
- package/dist/providers/core/runtime/provider-family-profile-utils.js +0 -28
- package/dist/providers/core/runtime/provider-family-profile-utils.js.map +1 -1
- package/dist/providers/core/runtime/provider-http-executor-utils.js +40 -1
- package/dist/providers/core/runtime/provider-http-executor-utils.js.map +1 -1
- package/dist/providers/core/runtime/provider-request-header-orchestrator.d.ts +0 -2
- package/dist/providers/core/runtime/provider-request-header-orchestrator.js +35 -8
- package/dist/providers/core/runtime/provider-request-header-orchestrator.js.map +1 -1
- package/dist/providers/core/runtime/provider-response-postprocessor.js +3 -23
- package/dist/providers/core/runtime/provider-response-postprocessor.js.map +1 -1
- package/dist/providers/core/runtime/provider-runtime-utils.js +4 -1
- package/dist/providers/core/runtime/provider-runtime-utils.js.map +1 -1
- package/dist/providers/core/runtime/provider-startup-tasks.js +18 -2
- package/dist/providers/core/runtime/provider-startup-tasks.js.map +1 -1
- package/dist/providers/core/runtime/responses-provider-helpers.d.ts +1 -0
- package/dist/providers/core/runtime/responses-provider-helpers.js +11 -12
- package/dist/providers/core/runtime/responses-provider-helpers.js.map +1 -1
- package/dist/providers/core/runtime/responses-provider.js +15 -10
- package/dist/providers/core/runtime/responses-provider.js.map +1 -1
- package/dist/providers/core/runtime/transport/auth-provider-factory.d.ts +0 -1
- package/dist/providers/core/runtime/transport/auth-provider-factory.js +1 -15
- package/dist/providers/core/runtime/transport/auth-provider-factory.js.map +1 -1
- package/dist/providers/core/runtime/transport/index.d.ts +0 -1
- package/dist/providers/core/runtime/transport/index.js +0 -1
- package/dist/providers/core/runtime/transport/index.js.map +1 -1
- package/dist/providers/core/runtime/transport/oauth-recovery-handler.d.ts +2 -0
- package/dist/providers/core/runtime/transport/oauth-recovery-handler.js +76 -5
- package/dist/providers/core/runtime/transport/oauth-recovery-handler.js.map +1 -1
- package/dist/providers/core/runtime/transport/request-header-builder.d.ts +0 -1
- package/dist/providers/core/runtime/transport/request-header-builder.js +1 -7
- package/dist/providers/core/runtime/transport/request-header-builder.js.map +1 -1
- package/dist/providers/core/runtime/transport/runtime-detector.d.ts +0 -2
- package/dist/providers/core/runtime/transport/runtime-detector.js +0 -20
- package/dist/providers/core/runtime/transport/runtime-detector.js.map +1 -1
- package/dist/providers/core/runtime/transport/session-header-utils.d.ts +6 -0
- package/dist/providers/core/runtime/transport/session-header-utils.js +61 -2
- package/dist/providers/core/runtime/transport/session-header-utils.js.map +1 -1
- package/dist/providers/core/runtime/vercel-ai-sdk/anthropic-sdk-request-exec.js +2 -1
- package/dist/providers/core/runtime/vercel-ai-sdk/anthropic-sdk-request-exec.js.map +1 -1
- package/dist/providers/core/runtime/vercel-ai-sdk/openai-sdk-transport.js +2 -1
- package/dist/providers/core/runtime/vercel-ai-sdk/openai-sdk-transport.js.map +1 -1
- package/dist/providers/core/strategies/oauth-auth-code-flow.d.ts +1 -4
- package/dist/providers/core/strategies/oauth-auth-code-flow.js +26 -84
- package/dist/providers/core/strategies/oauth-auth-code-flow.js.map +1 -1
- package/dist/providers/core/strategies/oauth-device-flow.d.ts +2 -0
- package/dist/providers/core/strategies/oauth-device-flow.js +43 -8
- package/dist/providers/core/strategies/oauth-device-flow.js.map +1 -1
- package/dist/providers/core/utils/http-client.d.ts +7 -5
- package/dist/providers/core/utils/http-client.js +108 -33
- package/dist/providers/core/utils/http-client.js.map +1 -1
- package/dist/providers/core/utils/provider-error-reporter.d.ts +2 -2
- package/dist/providers/core/utils/provider-error-reporter.js +9 -85
- package/dist/providers/core/utils/provider-error-reporter.js.map +1 -1
- package/dist/providers/core/utils/provider-type-utils.js +1 -3
- package/dist/providers/core/utils/provider-type-utils.js.map +1 -1
- package/dist/providers/core/utils/qwen-client-fingerprint.d.ts +15 -0
- package/dist/providers/core/utils/qwen-client-fingerprint.js +47 -0
- package/dist/providers/core/utils/qwen-client-fingerprint.js.map +1 -0
- package/dist/providers/core/utils/snapshot-writer.d.ts +3 -0
- package/dist/providers/core/utils/snapshot-writer.js +385 -26
- package/dist/providers/core/utils/snapshot-writer.js.map +1 -1
- package/dist/providers/profile/families/qwen-profile.js +285 -22
- package/dist/providers/profile/families/qwen-profile.js.map +1 -1
- package/dist/providers/profile/profile-registry.js +0 -2
- package/dist/providers/profile/profile-registry.js.map +1 -1
- package/dist/providers/profile/provider-directory.js +0 -1
- package/dist/providers/profile/provider-directory.js.map +1 -1
- package/dist/providers/profile/provider-profile-loader.js +1 -1
- package/dist/providers/profile/provider-profile-loader.js.map +1 -1
- package/dist/server/handlers/chat-handler.js +6 -5
- package/dist/server/handlers/chat-handler.js.map +1 -1
- package/dist/server/handlers/config-admin-handler.js +44 -69
- package/dist/server/handlers/config-admin-handler.js.map +1 -1
- package/dist/server/handlers/handler-response-utils.js +190 -27
- package/dist/server/handlers/handler-response-utils.js.map +1 -1
- package/dist/server/handlers/handler-utils.d.ts +3 -0
- package/dist/server/handlers/handler-utils.js +72 -0
- package/dist/server/handlers/handler-utils.js.map +1 -1
- package/dist/server/handlers/images-handler.js +7 -7
- package/dist/server/handlers/images-handler.js.map +1 -1
- package/dist/server/handlers/messages-handler.js +6 -5
- package/dist/server/handlers/messages-handler.js.map +1 -1
- package/dist/server/handlers/responses-handler.js +32 -14
- package/dist/server/handlers/responses-handler.js.map +1 -1
- package/dist/server/handlers/sse-dispatcher.js +55 -13
- package/dist/server/handlers/sse-dispatcher.js.map +1 -1
- package/dist/server/handlers/types.d.ts +12 -0
- package/dist/server/runtime/http-server/daemon-admin/auth-handler.js +5 -2
- package/dist/server/runtime/http-server/daemon-admin/auth-handler.js.map +1 -1
- package/dist/server/runtime/http-server/daemon-admin/control-handler.js +62 -18
- package/dist/server/runtime/http-server/daemon-admin/control-handler.js.map +1 -1
- package/dist/server/runtime/http-server/daemon-admin/credentials-handler-utils.js +1 -1
- package/dist/server/runtime/http-server/daemon-admin/credentials-handler-utils.js.map +1 -1
- package/dist/server/runtime/http-server/daemon-admin/credentials-handler.js +9 -9
- package/dist/server/runtime/http-server/daemon-admin/credentials-handler.js.map +1 -1
- package/dist/server/runtime/http-server/daemon-admin/providers-handler-routing-utils.js +36 -10
- package/dist/server/runtime/http-server/daemon-admin/providers-handler-routing-utils.js.map +1 -1
- package/dist/server/runtime/http-server/daemon-admin/providers-handler.js +11 -11
- package/dist/server/runtime/http-server/daemon-admin/providers-handler.js.map +1 -1
- package/dist/server/runtime/http-server/daemon-admin/quota-handler.js +49 -8
- package/dist/server/runtime/http-server/daemon-admin/quota-handler.js.map +1 -1
- package/dist/server/runtime/http-server/daemon-admin-routes.d.ts +1 -0
- package/dist/server/runtime/http-server/daemon-admin-routes.js +46 -0
- package/dist/server/runtime/http-server/daemon-admin-routes.js.map +1 -1
- package/dist/server/runtime/http-server/executor/client-injection-flow.js +2 -0
- package/dist/server/runtime/http-server/executor/client-injection-flow.js.map +1 -1
- package/dist/server/runtime/http-server/executor/log-rollup.d.ts +38 -0
- package/dist/server/runtime/http-server/executor/log-rollup.js +775 -0
- package/dist/server/runtime/http-server/executor/log-rollup.js.map +1 -0
- package/dist/server/runtime/http-server/executor/provider-response-converter.js +654 -281
- package/dist/server/runtime/http-server/executor/provider-response-converter.js.map +1 -1
- package/dist/server/runtime/http-server/executor/provider-response-utils.js +34 -3
- package/dist/server/runtime/http-server/executor/provider-response-utils.js.map +1 -1
- package/dist/server/runtime/http-server/executor/provider-runtime-resolver.js +14 -68
- package/dist/server/runtime/http-server/executor/provider-runtime-resolver.js.map +1 -1
- package/dist/server/runtime/http-server/executor/request-executor-core-utils.js +26 -2
- package/dist/server/runtime/http-server/executor/request-executor-core-utils.js.map +1 -1
- package/dist/server/runtime/http-server/executor/request-retry-helpers.js +20 -2
- package/dist/server/runtime/http-server/executor/request-retry-helpers.js.map +1 -1
- package/dist/server/runtime/http-server/executor/servertool-adapter-context.d.ts +10 -0
- package/dist/server/runtime/http-server/executor/servertool-adapter-context.js +120 -0
- package/dist/server/runtime/http-server/executor/servertool-adapter-context.js.map +1 -0
- package/dist/server/runtime/http-server/executor/servertool-followup-dispatch.d.ts +35 -0
- package/dist/server/runtime/http-server/executor/servertool-followup-dispatch.js +101 -0
- package/dist/server/runtime/http-server/executor/servertool-followup-dispatch.js.map +1 -0
- package/dist/server/runtime/http-server/executor/servertool-followup-error.d.ts +46 -0
- package/dist/server/runtime/http-server/executor/servertool-followup-error.js +127 -0
- package/dist/server/runtime/http-server/executor/servertool-followup-error.js.map +1 -0
- package/dist/server/runtime/http-server/executor/servertool-followup-metadata.d.ts +7 -0
- package/dist/server/runtime/http-server/executor/servertool-followup-metadata.js +186 -0
- package/dist/server/runtime/http-server/executor/servertool-followup-metadata.js.map +1 -0
- package/dist/server/runtime/http-server/executor/servertool-request-normalizer.d.ts +2 -0
- package/dist/server/runtime/http-server/executor/servertool-request-normalizer.js +56 -0
- package/dist/server/runtime/http-server/executor/servertool-request-normalizer.js.map +1 -0
- package/dist/server/runtime/http-server/executor/servertool-response-normalizer.d.ts +8 -0
- package/dist/server/runtime/http-server/executor/servertool-response-normalizer.js +31 -0
- package/dist/server/runtime/http-server/executor/servertool-response-normalizer.js.map +1 -0
- package/dist/server/runtime/http-server/executor/servertool-runtime-log.d.ts +8 -0
- package/dist/server/runtime/http-server/executor/servertool-runtime-log.js +33 -0
- package/dist/server/runtime/http-server/executor/servertool-runtime-log.js.map +1 -0
- package/dist/server/runtime/http-server/executor/sse-error-handler.js +37 -0
- package/dist/server/runtime/http-server/executor/sse-error-handler.js.map +1 -1
- package/dist/server/runtime/http-server/executor/usage-aggregator.js +32 -2
- package/dist/server/runtime/http-server/executor/usage-aggregator.js.map +1 -1
- package/dist/server/runtime/http-server/executor/usage-logger.d.ts +12 -0
- package/dist/server/runtime/http-server/executor/usage-logger.js +56 -1
- package/dist/server/runtime/http-server/executor/usage-logger.js.map +1 -1
- package/dist/server/runtime/http-server/executor-metadata.d.ts +15 -0
- package/dist/server/runtime/http-server/executor-metadata.js +60 -18
- package/dist/server/runtime/http-server/executor-metadata.js.map +1 -1
- package/dist/server/runtime/http-server/executor-provider.d.ts +2 -0
- package/dist/server/runtime/http-server/executor-provider.js +88 -205
- package/dist/server/runtime/http-server/executor-provider.js.map +1 -1
- package/dist/server/runtime/http-server/executor-response.js +30 -149
- package/dist/server/runtime/http-server/executor-response.js.map +1 -1
- package/dist/server/runtime/http-server/http-server-bootstrap.js +53 -17
- package/dist/server/runtime/http-server/http-server-bootstrap.js.map +1 -1
- package/dist/server/runtime/http-server/http-server-legacy-pipeline.js +28 -1
- package/dist/server/runtime/http-server/http-server-legacy-pipeline.js.map +1 -1
- package/dist/server/runtime/http-server/http-server-lifecycle.js +17 -4
- package/dist/server/runtime/http-server/http-server-lifecycle.js.map +1 -1
- package/dist/server/runtime/http-server/http-server-runtime-providers.js +42 -13
- package/dist/server/runtime/http-server/http-server-runtime-providers.js.map +1 -1
- package/dist/server/runtime/http-server/http-server-runtime-setup.js +40 -2
- package/dist/server/runtime/http-server/http-server-runtime-setup.js.map +1 -1
- package/dist/server/runtime/http-server/hub-shadow-compare.js +8 -4
- package/dist/server/runtime/http-server/hub-shadow-compare.js.map +1 -1
- package/dist/server/runtime/http-server/managed-process-probe.js +30 -4
- package/dist/server/runtime/http-server/managed-process-probe.js.map +1 -1
- package/dist/server/runtime/http-server/middleware.js +32 -4
- package/dist/server/runtime/http-server/middleware.js.map +1 -1
- package/dist/server/runtime/http-server/provider-traffic-governor.d.ts +45 -1
- package/dist/server/runtime/http-server/provider-traffic-governor.js +697 -111
- package/dist/server/runtime/http-server/provider-traffic-governor.js.map +1 -1
- package/dist/server/runtime/http-server/provider-utils.js +2 -6
- package/dist/server/runtime/http-server/provider-utils.js.map +1 -1
- package/dist/server/runtime/http-server/request-activity-tracker.d.ts +4 -0
- package/dist/server/runtime/http-server/request-activity-tracker.js +54 -11
- package/dist/server/runtime/http-server/request-activity-tracker.js.map +1 -1
- package/dist/server/runtime/http-server/request-executor.d.ts +247 -0
- package/dist/server/runtime/http-server/request-executor.js +2444 -334
- package/dist/server/runtime/http-server/request-executor.js.map +1 -1
- package/dist/server/runtime/http-server/routes.js +59 -16
- package/dist/server/runtime/http-server/routes.js.map +1 -1
- package/dist/server/runtime/http-server/runtime-manager.js +0 -15
- package/dist/server/runtime/http-server/runtime-manager.js.map +1 -1
- package/dist/server/runtime/http-server/session-client-registry-utils.js +46 -10
- package/dist/server/runtime/http-server/session-client-registry-utils.js.map +1 -1
- package/dist/server/runtime/http-server/session-client-registry.js +22 -4
- package/dist/server/runtime/http-server/session-client-registry.js.map +1 -1
- package/dist/server/runtime/http-server/session-client-routes.js +40 -18
- package/dist/server/runtime/http-server/session-client-routes.js.map +1 -1
- package/dist/server/runtime/http-server/session-dir.js +35 -2
- package/dist/server/runtime/http-server/session-dir.js.map +1 -1
- package/dist/server/runtime/http-server/session-scope-resolution.js +38 -9
- package/dist/server/runtime/http-server/session-scope-resolution.js.map +1 -1
- package/dist/server/runtime/http-server/session-storage-cleanup.js +64 -27
- package/dist/server/runtime/http-server/session-storage-cleanup.js.map +1 -1
- package/dist/server/runtime/http-server/stats-manager.d.ts +5 -0
- package/dist/server/runtime/http-server/stats-manager.js +138 -6
- package/dist/server/runtime/http-server/stats-manager.js.map +1 -1
- package/dist/server/runtime/http-server/tmux-injection-history.js +30 -4
- package/dist/server/runtime/http-server/tmux-injection-history.js.map +1 -1
- package/dist/server/runtime/http-server/tmux-session-probe.d.ts +3 -1
- package/dist/server/runtime/http-server/tmux-session-probe.js +198 -9
- package/dist/server/runtime/http-server/tmux-session-probe.js.map +1 -1
- package/dist/server/utils/client-connection-state.d.ts +1 -0
- package/dist/server/utils/client-connection-state.js +45 -5
- package/dist/server/utils/client-connection-state.js.map +1 -1
- package/dist/server/utils/finish-reason.js +61 -2
- package/dist/server/utils/finish-reason.js.map +1 -1
- package/dist/server/utils/http-error-mapper.d.ts +4 -0
- package/dist/server/utils/http-error-mapper.js +31 -6
- package/dist/server/utils/http-error-mapper.js.map +1 -1
- package/dist/server/utils/stage-logger.js +42 -13
- package/dist/server/utils/stage-logger.js.map +1 -1
- package/dist/server-lifecycle/port-utils.js +6 -2
- package/dist/server-lifecycle/port-utils.js.map +1 -1
- package/dist/token-daemon/index.js +44 -15
- package/dist/token-daemon/index.js.map +1 -1
- package/dist/token-daemon/leader-lock.js +65 -7
- package/dist/token-daemon/leader-lock.js.map +1 -1
- package/dist/token-daemon/provider-registry.js +1 -1
- package/dist/token-daemon/provider-registry.js.map +1 -1
- package/dist/token-daemon/server-utils.d.ts +11 -0
- package/dist/token-daemon/server-utils.js +71 -18
- package/dist/token-daemon/server-utils.js.map +1 -1
- package/dist/token-daemon/token-daemon.d.ts +0 -1
- package/dist/token-daemon/token-daemon.js +81 -63
- package/dist/token-daemon/token-daemon.js.map +1 -1
- package/dist/token-daemon/token-types.d.ts +1 -1
- package/dist/token-daemon/token-types.js +0 -1
- package/dist/token-daemon/token-types.js.map +1 -1
- package/dist/token-daemon/token-utils.js +4 -2
- package/dist/token-daemon/token-utils.js.map +1 -1
- package/dist/tools/provider-update/fetch-models.js +1 -5
- package/dist/tools/provider-update/fetch-models.js.map +1 -1
- package/dist/utils/error-handler-registry.js +50 -13
- package/dist/utils/error-handler-registry.js.map +1 -1
- package/dist/utils/errorsamples.d.ts +3 -1
- package/dist/utils/errorsamples.js +198 -14
- package/dist/utils/errorsamples.js.map +1 -1
- package/dist/utils/http-health-probe.d.ts +42 -0
- package/dist/utils/http-health-probe.js +231 -0
- package/dist/utils/http-health-probe.js.map +1 -0
- package/dist/utils/managed-server-pids.js +2 -2
- package/dist/utils/managed-server-pids.js.map +1 -1
- package/dist/utils/module-config-reader.js +11 -1
- package/dist/utils/module-config-reader.js.map +1 -1
- package/dist/utils/runtime-package-root.d.ts +2 -0
- package/dist/utils/runtime-package-root.js +47 -0
- package/dist/utils/runtime-package-root.js.map +1 -0
- package/dist/utils/snapshot-local-disk-gate.d.ts +3 -0
- package/dist/utils/snapshot-local-disk-gate.js +50 -0
- package/dist/utils/snapshot-local-disk-gate.js.map +1 -0
- package/dist/utils/snapshot-payload-guard.d.ts +1 -0
- package/dist/utils/snapshot-payload-guard.js +234 -0
- package/dist/utils/snapshot-payload-guard.js.map +1 -0
- package/dist/utils/snapshot-request-retention.d.ts +3 -0
- package/dist/utils/snapshot-request-retention.js +128 -0
- package/dist/utils/snapshot-request-retention.js.map +1 -0
- package/dist/utils/snapshot-stage-policy.d.ts +3 -0
- package/dist/utils/snapshot-stage-policy.js +111 -0
- package/dist/utils/snapshot-stage-policy.js.map +1 -0
- package/dist/utils/snapshot-writer.js +124 -127
- package/dist/utils/snapshot-writer.js.map +1 -1
- package/docs/CHAT_PROCESS_PROTOCOL_AND_PIPELINE.md +4 -0
- package/docs/CONFIG_ARCHITECTURE.md +2 -2
- package/docs/INSTALLATION_AND_QUICKSTART.md +5 -5
- package/docs/OAUTH.md +2 -5
- package/docs/PORTS.md +1 -1
- package/docs/PROVIDERS_BUILTIN.md +1 -5
- package/docs/PROVIDER_TYPES.md +1 -1
- package/docs/agent-routing/10-runtime-ssot-routing.md +4 -0
- package/docs/agent-routing/20-build-test-release-routing.md +2 -2
- package/docs/agent-routing/30-servertool-lifecycle-routing.md +2 -0
- package/docs/agent-routing/40-task-memory-routing.md +22 -2
- package/docs/audit/286.1-provider-failure-policy-audit.md +341 -0
- package/docs/audits/2026-04-26-fallback-silent-failure-audit.md +119 -0
- package/docs/audits/2026-04-27-provider-failure-policy-ssot-audit.md +153 -0
- package/docs/chat-process-continuation-state-contract.md +196 -0
- package/docs/chat-semantic-expansion-plan.md +2 -0
- package/docs/daemon-admin-api-design.md +9 -9
- package/docs/design/provider-failure-policy-ssot.md +215 -0
- package/docs/design/reasoning-stop-lifecycle.md +90 -0
- package/docs/design/servertool-unified-skeleton.md +202 -0
- package/docs/design/websearch-servertool-orchestration.md +190 -0
- package/docs/error-handling-v2.md +120 -11
- package/docs/protocol-compatibility-matrix.md +147 -0
- package/docs/providers/provider-composite-design.md +4 -5
- package/docs/providers/provider-composite-testing.md +1 -1
- package/docs/providers/provider-type-only-migration.md +2 -15
- package/docs/refactoring/compatibility-v2-architecture-design.md +1 -3
- package/docs/refactoring/host-164.3-responsibility-migration.md +0 -1
- package/docs/routing-instructions.md +42 -1
- package/docs/stop-message-auto.md +0 -1
- package/docs/token-refresh-daemon-plan.md +14 -14
- package/docs/v2-architecture/IMPLEMENTATION-ROADMAP.md +1 -1
- package/docs/v2-architecture/PROVIDER-V2-CHANGESET-RELEASE-CHECKLIST.md +1 -9
- package/docs/v2-architecture/PROVIDER-V2-LAYERING-ADR-DRAFT.md +3 -4
- package/docs/v2-architecture/PROVIDER-V2-MIGRATION-MATRIX-DRAFT.md +4 -15
- package/docs/v2-architecture/PROVIDER-V2-PHASED-MIGRATION-ROLLBACK-DRAFT.md +4 -5
- package/docs/v2-architecture/PROVIDER-V2-PROFILE-API-REGISTRY-DRAFT.md +4 -4
- package/docs/v2-architecture/PROVIDER-V2-REFACTOR-OVERVIEW-DRAFT.md +1 -2
- package/docs/v2-architecture/PROVIDER-V2-VERIFICATION-MATRIX-DRAFT.md +2 -2
- package/node_modules/@jsonstudio/llms/dist/config-unified/unified-config.js +36 -10
- package/node_modules/@jsonstudio/llms/dist/conversion/compat/actions/deepseek-web-request.js +7 -0
- package/node_modules/@jsonstudio/llms/dist/conversion/compat/actions/deepseek-web-response.js +2 -2
- package/node_modules/@jsonstudio/llms/dist/conversion/compat/antigravity-session-signature.js +33 -17
- package/node_modules/@jsonstudio/llms/dist/conversion/compat/profile-registry/header-policies.d.ts +20 -0
- package/node_modules/@jsonstudio/llms/dist/conversion/compat/profile-registry/header-policies.js +79 -0
- package/node_modules/@jsonstudio/llms/dist/conversion/compat/profile-registry/policy-overrides.d.ts +16 -0
- package/node_modules/@jsonstudio/llms/dist/conversion/compat/profile-registry/policy-overrides.js +27 -0
- package/node_modules/@jsonstudio/llms/dist/conversion/compat/profile-registry/provider-resolver.d.ts +26 -0
- package/node_modules/@jsonstudio/llms/dist/conversion/compat/profile-registry/provider-resolver.js +59 -0
- package/node_modules/@jsonstudio/llms/dist/conversion/compat/profile-registry/registry.d.ts +35 -0
- package/node_modules/@jsonstudio/llms/dist/conversion/compat/profile-registry/registry.js +154 -0
- package/node_modules/@jsonstudio/llms/dist/conversion/compat/profile-registry/types.d.ts +75 -0
- package/node_modules/@jsonstudio/llms/dist/conversion/compat/profile-registry/types.js +8 -0
- package/node_modules/@jsonstudio/llms/dist/conversion/compat/profiles/anthropic-claude-code.json +13 -7
- package/node_modules/@jsonstudio/llms/dist/conversion/compat/profiles/chat-claude-code.json +13 -8
- package/node_modules/@jsonstudio/llms/dist/conversion/compat/profiles/chat-deepseek-web.json +37 -8
- package/node_modules/@jsonstudio/llms/dist/conversion/compat/profiles/chat-qwen.json +48 -11
- package/node_modules/@jsonstudio/llms/dist/conversion/compat/profiles/compat-passthrough.json +6 -0
- package/node_modules/@jsonstudio/llms/dist/conversion/compat/provider-resolution-config.json +24 -0
- package/node_modules/@jsonstudio/llms/dist/conversion/hub/operation-table/semantic-mappers/anthropic-mapper-config.js +0 -1
- package/node_modules/@jsonstudio/llms/dist/conversion/hub/operation-table/semantic-mappers/anthropic-mapper-from-chat.js +54 -7
- package/node_modules/@jsonstudio/llms/dist/conversion/hub/operation-table/semantic-mappers/anthropic-mapper-to-chat.js +15 -2
- package/node_modules/@jsonstudio/llms/dist/conversion/hub/operation-table/semantic-mappers/anthropic-semantics-audit.d.ts +11 -0
- package/node_modules/@jsonstudio/llms/dist/conversion/hub/operation-table/semantic-mappers/anthropic-semantics-audit.js +16 -30
- package/node_modules/@jsonstudio/llms/dist/conversion/hub/operation-table/semantic-mappers/gemini-mapper-config.js +0 -1
- package/node_modules/@jsonstudio/llms/dist/conversion/hub/operation-table/semantic-mappers/gemini-mapper-from-chat.js +15 -1
- package/node_modules/@jsonstudio/llms/dist/conversion/hub/operation-table/semantic-mappers/gemini-mapping-audit.d.ts +10 -0
- package/node_modules/@jsonstudio/llms/dist/conversion/hub/operation-table/semantic-mappers/gemini-mapping-audit.js +9 -30
- package/node_modules/@jsonstudio/llms/dist/conversion/hub/operation-table/semantic-mappers/protocol-mapping-audit.d.ts +43 -0
- package/node_modules/@jsonstudio/llms/dist/conversion/hub/operation-table/semantic-mappers/protocol-mapping-audit.js +148 -0
- package/node_modules/@jsonstudio/llms/dist/conversion/hub/operation-table/semantic-mappers/responses-mapper-from-chat.js +16 -6
- package/node_modules/@jsonstudio/llms/dist/conversion/hub/operation-table/semantic-mappers/responses-mapper-helpers.d.ts +2 -1
- package/node_modules/@jsonstudio/llms/dist/conversion/hub/operation-table/semantic-mappers/responses-mapper-helpers.js +65 -3
- package/node_modules/@jsonstudio/llms/dist/conversion/hub/operation-table/semantic-mappers/responses-mapper-to-chat.js +1 -1
- package/node_modules/@jsonstudio/llms/dist/conversion/hub/operation-table/semantic-mappers/responses-mapper.d.ts +1 -1
- package/node_modules/@jsonstudio/llms/dist/conversion/hub/operation-table/semantic-mappers/responses-mapper.js +1 -1
- package/node_modules/@jsonstudio/llms/dist/conversion/hub/pipeline/compat/compat-types.d.ts +14 -154
- package/node_modules/@jsonstudio/llms/dist/conversion/hub/pipeline/hub-pipeline-chat-process-request-utils.d.ts +6 -1
- package/node_modules/@jsonstudio/llms/dist/conversion/hub/pipeline/hub-pipeline-chat-process-request-utils.js +83 -3
- package/node_modules/@jsonstudio/llms/dist/conversion/hub/pipeline/hub-pipeline-execute-chat-process-entry.js +6 -5
- package/node_modules/@jsonstudio/llms/dist/conversion/hub/pipeline/hub-pipeline-execute-request-stage-inbound.d.ts +0 -1
- package/node_modules/@jsonstudio/llms/dist/conversion/hub/pipeline/hub-pipeline-execute-request-stage-inbound.js +9 -5
- package/node_modules/@jsonstudio/llms/dist/conversion/hub/pipeline/hub-pipeline-execute-request-stage-provider-payload.js +132 -1
- package/node_modules/@jsonstudio/llms/dist/conversion/hub/pipeline/hub-pipeline-execute-request-stage.js +0 -1
- package/node_modules/@jsonstudio/llms/dist/conversion/hub/pipeline/hub-pipeline-heavy-input-fastpath.d.ts +4 -22
- package/node_modules/@jsonstudio/llms/dist/conversion/hub/pipeline/hub-pipeline-heavy-input-fastpath.js +109 -139
- package/node_modules/@jsonstudio/llms/dist/conversion/hub/pipeline/hub-pipeline-max-tokens-policy.js +40 -1
- package/node_modules/@jsonstudio/llms/dist/conversion/hub/pipeline/hub-pipeline-route-and-outbound.d.ts +0 -1
- package/node_modules/@jsonstudio/llms/dist/conversion/hub/pipeline/hub-pipeline-route-and-outbound.js +19 -2
- package/node_modules/@jsonstudio/llms/dist/conversion/hub/pipeline/hub-pipeline.d.ts +0 -2
- package/node_modules/@jsonstudio/llms/dist/conversion/hub/pipeline/hub-pipeline.js +45 -43
- package/node_modules/@jsonstudio/llms/dist/conversion/hub/pipeline/route-aware-responses-continuation.d.ts +10 -0
- package/node_modules/@jsonstudio/llms/dist/conversion/hub/pipeline/route-aware-responses-continuation.js +143 -0
- package/node_modules/@jsonstudio/llms/dist/conversion/hub/pipeline/stages/req_inbound/req_inbound_stage2_semantic_map/index.js +37 -0
- package/node_modules/@jsonstudio/llms/dist/conversion/hub/pipeline/stages/req_inbound/req_inbound_stage2_semantic_map/semantic-lift.js +14 -2
- package/node_modules/@jsonstudio/llms/dist/conversion/hub/pipeline/stages/req_inbound/req_inbound_stage3_context_capture/responses-context-snapshot.d.ts +3 -0
- package/node_modules/@jsonstudio/llms/dist/conversion/hub/pipeline/stages/req_inbound/req_inbound_stage3_context_capture/responses-context-snapshot.js +22 -11
- package/node_modules/@jsonstudio/llms/dist/conversion/hub/pipeline/stages/resp_outbound/resp_outbound_stage1_client_remap/chat-process-semantics-bridge.js +59 -2
- package/node_modules/@jsonstudio/llms/dist/conversion/hub/pipeline/stages/resp_outbound/resp_outbound_stage1_client_remap/client-remap-protocol-switch.d.ts +1 -0
- package/node_modules/@jsonstudio/llms/dist/conversion/hub/pipeline/stages/resp_outbound/resp_outbound_stage1_client_remap/client-remap-protocol-switch.js +3 -1
- package/node_modules/@jsonstudio/llms/dist/conversion/hub/pipeline/stages/resp_outbound/resp_outbound_stage1_client_remap/index.d.ts +1 -0
- package/node_modules/@jsonstudio/llms/dist/conversion/hub/pipeline/stages/resp_outbound/resp_outbound_stage1_client_remap/index.js +2 -1
- package/node_modules/@jsonstudio/llms/dist/conversion/hub/pipeline/stages/resp_process/resp_process_stage1_tool_governance/index.d.ts +2 -0
- package/node_modules/@jsonstudio/llms/dist/conversion/hub/pipeline/stages/resp_process/resp_process_stage1_tool_governance/index.js +53 -1
- package/node_modules/@jsonstudio/llms/dist/conversion/hub/pipeline/stages/resp_process/resp_process_stage2_finalize/index.js +4 -1
- package/node_modules/@jsonstudio/llms/dist/conversion/hub/pipeline/stages/resp_process/resp_process_stage3_servertool_orchestration/index.d.ts +1 -0
- package/node_modules/@jsonstudio/llms/dist/conversion/hub/pipeline/stages/resp_process/resp_process_stage3_servertool_orchestration/index.js +16 -0
- package/node_modules/@jsonstudio/llms/dist/conversion/hub/policy/policy-engine.js +14 -4
- package/node_modules/@jsonstudio/llms/dist/conversion/hub/process/chat-process-anthropic-alias.d.ts +1 -0
- package/node_modules/@jsonstudio/llms/dist/conversion/hub/process/chat-process-anthropic-alias.js +29 -1
- package/node_modules/@jsonstudio/llms/dist/conversion/hub/process/chat-process-pending-tool-sync.js +38 -2
- package/node_modules/@jsonstudio/llms/dist/conversion/hub/process/chat-process-request-sanitizer.js +164 -1
- package/node_modules/@jsonstudio/llms/dist/conversion/hub/response/provider-response.js +27 -2
- package/node_modules/@jsonstudio/llms/dist/conversion/hub/response/response-mappers.d.ts +9 -3
- package/node_modules/@jsonstudio/llms/dist/conversion/hub/response/response-mappers.js +8 -7
- package/node_modules/@jsonstudio/llms/dist/conversion/hub/response/response-runtime-anthropic.js +20 -5
- package/node_modules/@jsonstudio/llms/dist/conversion/hub/snapshot-recorder.js +1 -247
- package/node_modules/@jsonstudio/llms/dist/conversion/hub/types/chat-envelope.d.ts +84 -4
- package/node_modules/@jsonstudio/llms/dist/conversion/pipeline/codecs/v2/responses-openai-pipeline.js +26 -1
- package/node_modules/@jsonstudio/llms/dist/conversion/responses/responses-openai-bridge/response-payload.js +10 -9
- package/node_modules/@jsonstudio/llms/dist/conversion/responses/responses-openai-bridge/utils.js +20 -5
- package/node_modules/@jsonstudio/llms/dist/conversion/responses/responses-openai-bridge.js +88 -4
- package/node_modules/@jsonstudio/llms/dist/conversion/shared/anthropic-message-utils-core.js +5 -1
- package/node_modules/@jsonstudio/llms/dist/conversion/shared/anthropic-message-utils-openai-request.js +55 -14
- package/node_modules/@jsonstudio/llms/dist/conversion/shared/anthropic-message-utils-tool-schema.js +1 -2
- package/node_modules/@jsonstudio/llms/dist/conversion/shared/anthropic-message-utils.js +38 -15
- package/node_modules/@jsonstudio/llms/dist/conversion/shared/openai-message-normalize.js +45 -6
- package/node_modules/@jsonstudio/llms/dist/conversion/shared/responses-conversation-store.d.ts +15 -0
- package/node_modules/@jsonstudio/llms/dist/conversion/shared/responses-conversation-store.js +157 -13
- package/node_modules/@jsonstudio/llms/dist/conversion/shared/responses-reasoning-registry.d.ts +8 -2
- package/node_modules/@jsonstudio/llms/dist/conversion/shared/responses-reasoning-registry.js +103 -9
- package/node_modules/@jsonstudio/llms/dist/conversion/shared/responses-response-utils.js +10 -10
- package/node_modules/@jsonstudio/llms/dist/conversion/shared/tool-filter-pipeline.js +59 -9
- package/node_modules/@jsonstudio/llms/dist/conversion/shared/tool-governor-guards.d.ts +1 -1
- package/node_modules/@jsonstudio/llms/dist/conversion/shared/tool-governor-guards.js +54 -43
- package/node_modules/@jsonstudio/llms/dist/conversion/shared/tool-governor.js +62 -8
- package/node_modules/@jsonstudio/llms/dist/conversion/snapshot-utils.js +121 -8
- package/node_modules/@jsonstudio/llms/dist/filters/engine.js +64 -6
- package/node_modules/@jsonstudio/llms/dist/filters/special/request-tool-list-filter.js +32 -11
- package/node_modules/@jsonstudio/llms/dist/filters/special/request-toolcalls-stringify.js +26 -1
- package/node_modules/@jsonstudio/llms/dist/filters/special/request-tools-normalize.js +46 -7
- package/node_modules/@jsonstudio/llms/dist/filters/special/response-tool-arguments-blacklist.js +10 -1
- package/node_modules/@jsonstudio/llms/dist/filters/special/response-tool-arguments-schema-converge.js +10 -1
- package/node_modules/@jsonstudio/llms/dist/filters/special/response-tool-arguments-stringify.js +30 -5
- package/node_modules/@jsonstudio/llms/dist/filters/special/response-tool-arguments-whitelist.js +10 -1
- package/node_modules/@jsonstudio/llms/dist/filters/special/tool-filter-hooks.js +16 -14
- package/node_modules/@jsonstudio/llms/dist/filters/utils/snapshot-writer.js +47 -5
- package/node_modules/@jsonstudio/llms/dist/guidance/index.js +16 -2
- package/node_modules/@jsonstudio/llms/dist/http/sse-response.js +42 -6
- package/node_modules/@jsonstudio/llms/dist/native/router_hotpath_napi.node +0 -0
- package/node_modules/@jsonstudio/llms/dist/router/virtual-router/bootstrap/auth-utils.js +33 -31
- package/node_modules/@jsonstudio/llms/dist/router/virtual-router/bootstrap/provider-normalization.d.ts +6 -0
- package/node_modules/@jsonstudio/llms/dist/router/virtual-router/bootstrap/provider-normalization.js +78 -98
- package/node_modules/@jsonstudio/llms/dist/router/virtual-router/bootstrap/responses-helpers.js +22 -2
- package/node_modules/@jsonstudio/llms/dist/router/virtual-router/bootstrap/routing-config.js +56 -3
- package/node_modules/@jsonstudio/llms/dist/router/virtual-router/bootstrap/streaming-helpers.js +19 -1
- package/node_modules/@jsonstudio/llms/dist/router/virtual-router/bootstrap.js +62 -293
- package/node_modules/@jsonstudio/llms/dist/router/virtual-router/classifier.js +11 -82
- package/node_modules/@jsonstudio/llms/dist/router/virtual-router/engine/antigravity/alias-lease.js +42 -15
- package/node_modules/@jsonstudio/llms/dist/router/virtual-router/engine/cooldown-manager.js +55 -3
- package/node_modules/@jsonstudio/llms/dist/router/virtual-router/engine/health/index.js +66 -15
- package/node_modules/@jsonstudio/llms/dist/router/virtual-router/engine/routing-pools/index.js +44 -8
- package/node_modules/@jsonstudio/llms/dist/router/virtual-router/engine/routing-state/keys.d.ts +7 -0
- package/node_modules/@jsonstudio/llms/dist/router/virtual-router/engine/routing-state/keys.js +65 -21
- package/node_modules/@jsonstudio/llms/dist/router/virtual-router/engine/routing-state/store.js +19 -2
- package/node_modules/@jsonstudio/llms/dist/router/virtual-router/engine/sticky-session-manager.d.ts +9 -0
- package/node_modules/@jsonstudio/llms/dist/router/virtual-router/engine/sticky-session-manager.js +139 -4
- package/node_modules/@jsonstudio/llms/dist/router/virtual-router/engine-logging.js +2 -1
- package/node_modules/@jsonstudio/llms/dist/router/virtual-router/engine-selection/native-chat-process-clock-reminder-semantics.js +68 -59
- package/node_modules/@jsonstudio/llms/dist/router/virtual-router/engine-selection/native-chat-process-governance-semantics.js +156 -157
- package/node_modules/@jsonstudio/llms/dist/router/virtual-router/engine-selection/native-chat-process-node-result-semantics.d.ts +1 -0
- package/node_modules/@jsonstudio/llms/dist/router/virtual-router/engine-selection/native-chat-process-node-result-semantics.js +31 -0
- package/node_modules/@jsonstudio/llms/dist/router/virtual-router/engine-selection/native-chat-process-servertool-orchestration-semantics.js +94 -95
- package/node_modules/@jsonstudio/llms/dist/router/virtual-router/engine-selection/native-compat-action-semantics.d.ts +0 -1
- package/node_modules/@jsonstudio/llms/dist/router/virtual-router/engine-selection/native-compat-action-semantics.js +0 -7
- package/node_modules/@jsonstudio/llms/dist/router/virtual-router/engine-selection/native-hub-bridge-action-semantics-parsers.d.ts +1 -1
- package/node_modules/@jsonstudio/llms/dist/router/virtual-router/engine-selection/native-hub-bridge-action-semantics-parsers.js +203 -305
- package/node_modules/@jsonstudio/llms/dist/router/virtual-router/engine-selection/native-hub-bridge-action-semantics-tools-post.js +35 -0
- package/node_modules/@jsonstudio/llms/dist/router/virtual-router/engine-selection/native-hub-bridge-action-semantics-tools-request.js +2 -1
- package/node_modules/@jsonstudio/llms/dist/router/virtual-router/engine-selection/native-hub-bridge-action-semantics-types.d.ts +2 -0
- package/node_modules/@jsonstudio/llms/dist/router/virtual-router/engine-selection/native-hub-bridge-policy-semantics.js +173 -154
- package/node_modules/@jsonstudio/llms/dist/router/virtual-router/engine-selection/native-hub-pipeline-edge-stage-semantics.d.ts +1 -0
- package/node_modules/@jsonstudio/llms/dist/router/virtual-router/engine-selection/native-hub-pipeline-edge-stage-semantics.js +106 -57
- package/node_modules/@jsonstudio/llms/dist/router/virtual-router/engine-selection/native-hub-pipeline-inbound-outbound-semantics.js +122 -114
- package/node_modules/@jsonstudio/llms/dist/router/virtual-router/engine-selection/native-hub-pipeline-orchestration-semantics-builders.d.ts +1 -0
- package/node_modules/@jsonstudio/llms/dist/router/virtual-router/engine-selection/native-hub-pipeline-orchestration-semantics-metadata-policy.js +100 -86
- package/node_modules/@jsonstudio/llms/dist/router/virtual-router/engine-selection/native-hub-pipeline-orchestration-semantics-passthrough.js +52 -33
- package/node_modules/@jsonstudio/llms/dist/router/virtual-router/engine-selection/native-hub-pipeline-orchestration-semantics-protocol.js +79 -62
- package/node_modules/@jsonstudio/llms/dist/router/virtual-router/engine-selection/native-hub-pipeline-orchestration-semantics.d.ts +1 -0
- package/node_modules/@jsonstudio/llms/dist/router/virtual-router/engine-selection/native-hub-pipeline-req-inbound-semantics-parsers.js +50 -33
- package/node_modules/@jsonstudio/llms/dist/router/virtual-router/engine-selection/native-hub-pipeline-req-inbound-semantics-types.d.ts +2 -0
- package/node_modules/@jsonstudio/llms/dist/router/virtual-router/engine-selection/native-hub-pipeline-req-outbound-semantics-parsers.d.ts +1 -1
- package/node_modules/@jsonstudio/llms/dist/router/virtual-router/engine-selection/native-hub-pipeline-req-outbound-semantics-parsers.js +161 -177
- package/node_modules/@jsonstudio/llms/dist/router/virtual-router/engine-selection/native-hub-pipeline-resp-semantics-outbound-tools.d.ts +1 -0
- package/node_modules/@jsonstudio/llms/dist/router/virtual-router/engine-selection/native-hub-pipeline-resp-semantics-outbound-tools.js +1 -0
- package/node_modules/@jsonstudio/llms/dist/router/virtual-router/engine-selection/native-hub-pipeline-resp-semantics-parsers.d.ts +1 -1
- package/node_modules/@jsonstudio/llms/dist/router/virtual-router/engine-selection/native-hub-pipeline-resp-semantics-parsers.js +231 -286
- package/node_modules/@jsonstudio/llms/dist/router/virtual-router/engine-selection/native-router-hotpath-analysis.js +143 -164
- package/node_modules/@jsonstudio/llms/dist/router/virtual-router/engine-selection/native-router-hotpath-required-exports.d.ts +1 -1
- package/node_modules/@jsonstudio/llms/dist/router/virtual-router/engine-selection/native-router-hotpath-required-exports.js +8 -1
- package/node_modules/@jsonstudio/llms/dist/router/virtual-router/engine-selection/native-shared-conversion-semantics-reasoning.js +57 -28
- package/node_modules/@jsonstudio/llms/dist/router/virtual-router/engine-selection/native-shared-conversion-semantics-responses.d.ts +8 -0
- package/node_modules/@jsonstudio/llms/dist/router/virtual-router/engine-selection/native-shared-conversion-semantics-responses.js +76 -0
- package/node_modules/@jsonstudio/llms/dist/router/virtual-router/engine-selection/native-shared-conversion-semantics.d.ts +1 -1
- package/node_modules/@jsonstudio/llms/dist/router/virtual-router/engine-selection/native-shared-conversion-semantics.js +1 -1
- package/node_modules/@jsonstudio/llms/dist/router/virtual-router/engine-selection/native-virtual-router-bootstrap-providers.d.ts +24 -0
- package/node_modules/@jsonstudio/llms/dist/router/virtual-router/engine-selection/native-virtual-router-bootstrap-providers.js +78 -0
- package/node_modules/@jsonstudio/llms/dist/router/virtual-router/engine-selection/native-virtual-router-bootstrap-routing.d.ts +17 -0
- package/node_modules/@jsonstudio/llms/dist/router/virtual-router/engine-selection/native-virtual-router-bootstrap-routing.js +72 -0
- package/node_modules/@jsonstudio/llms/dist/router/virtual-router/engine-selection/route-utils.js +9 -0
- package/node_modules/@jsonstudio/llms/dist/router/virtual-router/engine-selection/tier-selection-select.js +11 -5
- package/node_modules/@jsonstudio/llms/dist/router/virtual-router/engine.js +4 -39
- package/node_modules/@jsonstudio/llms/dist/router/virtual-router/features.js +199 -31
- package/node_modules/@jsonstudio/llms/dist/router/virtual-router/health-manager.js +7 -2
- package/node_modules/@jsonstudio/llms/dist/router/virtual-router/load-balancer.d.ts +3 -0
- package/node_modules/@jsonstudio/llms/dist/router/virtual-router/load-balancer.js +47 -3
- package/node_modules/@jsonstudio/llms/dist/router/virtual-router/native-error.d.ts +11 -0
- package/node_modules/@jsonstudio/llms/dist/router/virtual-router/native-error.js +71 -0
- package/node_modules/@jsonstudio/llms/dist/router/virtual-router/provider-registry.js +81 -2
- package/node_modules/@jsonstudio/llms/dist/router/virtual-router/provider-runtime-ingress.d.ts +24 -0
- package/node_modules/@jsonstudio/llms/dist/router/virtual-router/provider-runtime-ingress.js +139 -0
- package/node_modules/@jsonstudio/llms/dist/router/virtual-router/routing-instructions/parse.js +21 -1
- package/node_modules/@jsonstudio/llms/dist/router/virtual-router/routing-instructions/state.js +46 -0
- package/node_modules/@jsonstudio/llms/dist/router/virtual-router/routing-instructions/types.d.ts +7 -0
- package/node_modules/@jsonstudio/llms/dist/router/virtual-router/routing-stop-message-state-codec.js +30 -1
- package/node_modules/@jsonstudio/llms/dist/router/virtual-router/sticky-session-store.js +44 -15
- package/node_modules/@jsonstudio/llms/dist/router/virtual-router/stop-message-state-sync.d.ts +1 -1
- package/node_modules/@jsonstudio/llms/dist/router/virtual-router/stop-message-state-sync.js +10 -2
- package/node_modules/@jsonstudio/llms/dist/router/virtual-router/success-center.js +39 -2
- package/node_modules/@jsonstudio/llms/dist/router/virtual-router/tool-signals.d.ts +1 -0
- package/node_modules/@jsonstudio/llms/dist/router/virtual-router/tool-signals.js +25 -24
- package/node_modules/@jsonstudio/llms/dist/router/virtual-router/types.d.ts +3 -0
- package/node_modules/@jsonstudio/llms/dist/servertool/engine.js +255 -71
- package/node_modules/@jsonstudio/llms/dist/servertool/handlers/clock.js +20 -2
- package/node_modules/@jsonstudio/llms/dist/servertool/handlers/followup-request-builder.js +120 -85
- package/node_modules/@jsonstudio/llms/dist/servertool/handlers/memory-appender.d.ts +6 -0
- package/node_modules/@jsonstudio/llms/dist/servertool/handlers/memory-appender.js +42 -0
- package/node_modules/@jsonstudio/llms/dist/servertool/handlers/reasoning-only-continue.js +1 -1
- package/node_modules/@jsonstudio/llms/dist/servertool/handlers/reasoning-stop-guard.js +630 -0
- package/node_modules/@jsonstudio/llms/dist/servertool/handlers/reasoning-stop-state.d.ts +24 -0
- package/node_modules/@jsonstudio/llms/dist/servertool/handlers/reasoning-stop-state.js +606 -0
- package/node_modules/@jsonstudio/llms/dist/servertool/handlers/reasoning-stop.js +292 -0
- package/node_modules/@jsonstudio/llms/dist/servertool/handlers/stop-message-auto/{iflow-followup.d.ts → ai-followup.d.ts} +3 -3
- package/node_modules/@jsonstudio/llms/dist/servertool/handlers/stop-message-auto/{iflow-followup.js → ai-followup.js} +76 -81
- package/node_modules/@jsonstudio/llms/dist/servertool/handlers/stop-message-auto/config.d.ts +1 -2
- package/node_modules/@jsonstudio/llms/dist/servertool/handlers/stop-message-auto/config.js +2 -6
- package/node_modules/@jsonstudio/llms/dist/servertool/handlers/stop-message-auto/runtime-utils.d.ts +1 -0
- package/node_modules/@jsonstudio/llms/dist/servertool/handlers/stop-message-auto/runtime-utils.js +51 -11
- package/node_modules/@jsonstudio/llms/dist/servertool/handlers/stop-message-auto.js +5 -4
- package/node_modules/@jsonstudio/llms/dist/servertool/handlers/web-search-auto-trigger.d.ts +9 -0
- package/node_modules/@jsonstudio/llms/dist/servertool/handlers/web-search-auto-trigger.js +91 -0
- package/node_modules/@jsonstudio/llms/dist/servertool/handlers/web-search.js +1 -131
- package/node_modules/@jsonstudio/llms/dist/servertool/heartbeat/session-store.js +49 -18
- package/node_modules/@jsonstudio/llms/dist/servertool/registry.js +3 -0
- package/node_modules/@jsonstudio/llms/dist/servertool/server-side-tools.d.ts +2 -2
- package/node_modules/@jsonstudio/llms/dist/servertool/server-side-tools.js +14 -10
- package/node_modules/@jsonstudio/llms/dist/servertool/strip-servertool-calls.js +2 -3
- package/node_modules/@jsonstudio/llms/dist/servertool/types.d.ts +11 -1
- package/node_modules/@jsonstudio/llms/dist/sse/json-to-sse/chat-json-to-sse-converter.js +26 -1
- package/node_modules/@jsonstudio/llms/dist/sse/json-to-sse/event-generators/chat.d.ts +2 -2
- package/node_modules/@jsonstudio/llms/dist/sse/json-to-sse/event-generators/chat.js +38 -3
- package/node_modules/@jsonstudio/llms/dist/sse/json-to-sse/sequencers/chat-sequencer.js +6 -3
- package/node_modules/@jsonstudio/llms/dist/sse/shared/chat-serializer.js +27 -3
- package/node_modules/@jsonstudio/llms/dist/sse/shared/constants.d.ts +6 -6
- package/node_modules/@jsonstudio/llms/dist/sse/shared/constants.js +3 -3
- package/node_modules/@jsonstudio/llms/dist/sse/sse-to-json/anthropic-sse-to-json-converter.d.ts +1 -0
- package/node_modules/@jsonstudio/llms/dist/sse/sse-to-json/anthropic-sse-to-json-converter.js +36 -1
- package/node_modules/@jsonstudio/llms/dist/sse/sse-to-json/builders/anthropic-response-builder.js +6 -20
- package/node_modules/@jsonstudio/llms/dist/sse/sse-to-json/builders/response-builder.d.ts +3 -0
- package/node_modules/@jsonstudio/llms/dist/sse/sse-to-json/builders/response-builder.js +125 -42
- package/node_modules/@jsonstudio/llms/dist/sse/sse-to-json/chat-sse-to-json-converter.js +59 -10
- package/node_modules/@jsonstudio/llms/dist/sse/sse-to-json/parsers/sse-parser.js +2 -0
- package/node_modules/@jsonstudio/llms/dist/sse/sse-to-json/responses-sse-to-json-converter.d.ts +1 -0
- package/node_modules/@jsonstudio/llms/dist/sse/sse-to-json/responses-sse-to-json-converter.js +71 -2
- package/node_modules/@jsonstudio/llms/dist/sse/types/chat-types.d.ts +1 -0
- package/node_modules/@jsonstudio/llms/dist/sse/types/chat-types.js +1 -1
- package/node_modules/@jsonstudio/llms/dist/sse/types/conversion-context.js +2 -2
- package/node_modules/@jsonstudio/llms/dist/sse/types/index.d.ts +1 -1
- package/node_modules/@jsonstudio/llms/dist/sse/types/responses-types.d.ts +1 -1
- package/node_modules/@jsonstudio/llms/dist/sse/types/responses-types.js +1 -1
- package/node_modules/@jsonstudio/llms/dist/telemetry/stats-center.js +34 -12
- package/node_modules/@jsonstudio/llms/dist/tools/apply-patch/patch-text/fuzzy-match.d.ts +14 -0
- package/node_modules/@jsonstudio/llms/dist/tools/apply-patch/patch-text/fuzzy-match.js +174 -0
- package/node_modules/@jsonstudio/llms/dist/tools/apply-patch/patch-text/normalize.js +148 -0
- package/node_modules/@jsonstudio/llms/dist/tools/apply-patch/structured.js +31 -2
- package/node_modules/@jsonstudio/llms/dist/tools/apply-patch/validator.js +121 -4
- package/node_modules/@jsonstudio/llms/dist/tools/exec-command/normalize.d.ts +4 -1
- package/node_modules/@jsonstudio/llms/dist/tools/exec-command/normalize.js +31 -16
- package/node_modules/@jsonstudio/llms/dist/tools/exec-command/validator.d.ts +1 -0
- package/node_modules/@jsonstudio/llms/dist/tools/exec-command/validator.js +3 -1
- package/node_modules/@jsonstudio/llms/dist/tools/tool-registry.d.ts +1 -0
- package/node_modules/@jsonstudio/llms/dist/tools/tool-registry.js +5 -27
- package/node_modules/@jsonstudio/llms/package.json +1 -1
- package/package.json +6 -7
- package/scripts/ci/repo-sanity.mjs +1 -0
- package/scripts/ci/silent-failure-audit.mjs +112 -70
- package/scripts/cleanup-stale-server-pids.mjs +0 -6
- package/scripts/ensure-cli-command-shim.mjs +49 -15
- package/scripts/ensure-cli-executable.mjs +1 -1
- package/scripts/install-global.sh +7 -6
- package/scripts/install-release-snapshot.mjs +232 -0
- package/scripts/install-release.sh +30 -24
- package/scripts/link-global-llms-local.mjs +1 -2
- package/scripts/pack-mode.mjs +0 -4
- package/scripts/pack-rcc.mjs +17 -58
- package/scripts/run-bg.sh +0 -6
- package/scripts/run-fg-gtimeout.sh +0 -6
- package/scripts/tests/antigravity-codex-sample-pipeline-compare.mjs +1 -1
- package/scripts/tests/blackbox-rcc-vs-routecodex-antigravity.mjs +60 -39
- package/scripts/verify-install-e2e.mjs +64 -26
- package/configsamples/provider-default/qwenchat/config.v2.json +0 -53
- package/dist/providers/auth/iflow-cookie-auth.d.ts +0 -27
- package/dist/providers/auth/iflow-cookie-auth.js +0 -207
- package/dist/providers/auth/iflow-cookie-auth.js.map +0 -1
- package/dist/providers/auth/iflow-userinfo-helper.d.ts +0 -32
- package/dist/providers/auth/iflow-userinfo-helper.js +0 -81
- package/dist/providers/auth/iflow-userinfo-helper.js.map +0 -1
- package/dist/providers/core/runtime/iflow-http-provider.d.ts +0 -13
- package/dist/providers/core/runtime/iflow-http-provider.js +0 -22
- package/dist/providers/core/runtime/iflow-http-provider.js.map +0 -1
- package/dist/providers/core/runtime/provider-iflow-business-error-utils.d.ts +0 -15
- package/dist/providers/core/runtime/provider-iflow-business-error-utils.js +0 -49
- package/dist/providers/core/runtime/provider-iflow-business-error-utils.js.map +0 -1
- package/dist/providers/core/runtime/qwenchat-http-provider-helpers.d.ts +0 -89
- package/dist/providers/core/runtime/qwenchat-http-provider-helpers.js +0 -1698
- package/dist/providers/core/runtime/qwenchat-http-provider-helpers.js.map +0 -1
- package/dist/providers/core/runtime/qwenchat-http-provider.d.ts +0 -9
- package/dist/providers/core/runtime/qwenchat-http-provider.js +0 -78
- package/dist/providers/core/runtime/qwenchat-http-provider.js.map +0 -1
- package/dist/providers/core/runtime/standard-tool-text-request-transform.d.ts +0 -13
- package/dist/providers/core/runtime/standard-tool-text-request-transform.js +0 -138
- package/dist/providers/core/runtime/standard-tool-text-request-transform.js.map +0 -1
- package/dist/providers/core/runtime/transport/iflow-signer.d.ts +0 -12
- package/dist/providers/core/runtime/transport/iflow-signer.js +0 -63
- package/dist/providers/core/runtime/transport/iflow-signer.js.map +0 -1
- package/dist/providers/profile/families/iflow-profile.d.ts +0 -2
- package/dist/providers/profile/families/iflow-profile.js +0 -384
- package/dist/providers/profile/families/iflow-profile.js.map +0 -1
- package/docs/mapping-tables/iflow-to-openai.json +0 -215
- package/docs/mapping-tables/openai-to-iflow.json +0 -227
- package/docs/multi-token-auth-guide.md +0 -66
- package/docs/oauth-authentication-guide.md +0 -172
- package/docs/oauth-iflow-implementation.md +0 -157
- package/docs/release-iflow-400-gate.md +0 -58
- package/node_modules/@jsonstudio/llms/dist/conversion/compat/actions/iflow-kimi-cli-defaults.d.ts +0 -10
- package/node_modules/@jsonstudio/llms/dist/conversion/compat/actions/iflow-kimi-cli-defaults.js +0 -31
- package/node_modules/@jsonstudio/llms/dist/conversion/compat/actions/iflow-kimi-history-media-placeholder.d.ts +0 -7
- package/node_modules/@jsonstudio/llms/dist/conversion/compat/actions/iflow-kimi-history-media-placeholder.js +0 -25
- package/node_modules/@jsonstudio/llms/dist/conversion/compat/actions/iflow-kimi-thinking-reasoning-fill.d.ts +0 -12
- package/node_modules/@jsonstudio/llms/dist/conversion/compat/actions/iflow-kimi-thinking-reasoning-fill.js +0 -46
- package/node_modules/@jsonstudio/llms/dist/conversion/compat/actions/iflow-native-compat.d.ts +0 -6
- package/node_modules/@jsonstudio/llms/dist/conversion/compat/actions/iflow-native-compat.js +0 -36
- package/node_modules/@jsonstudio/llms/dist/conversion/compat/actions/iflow-response-body-unwrap.d.ts +0 -9
- package/node_modules/@jsonstudio/llms/dist/conversion/compat/actions/iflow-response-body-unwrap.js +0 -25
- package/node_modules/@jsonstudio/llms/dist/conversion/compat/actions/iflow-tool-text-fallback.d.ts +0 -5
- package/node_modules/@jsonstudio/llms/dist/conversion/compat/actions/iflow-tool-text-fallback.js +0 -29
- package/node_modules/@jsonstudio/llms/dist/conversion/compat/actions/iflow-web-search.d.ts +0 -18
- package/node_modules/@jsonstudio/llms/dist/conversion/compat/actions/iflow-web-search.js +0 -49
- package/node_modules/@jsonstudio/llms/dist/conversion/compat/actions/qwenchat-web-request.d.ts +0 -3
- package/node_modules/@jsonstudio/llms/dist/conversion/compat/actions/qwenchat-web-request.js +0 -62
- package/node_modules/@jsonstudio/llms/dist/conversion/compat/profiles/chat-iflow.json +0 -353
- package/node_modules/@jsonstudio/llms/dist/conversion/compat/profiles/chat-qwenchat-web.json +0 -47
- package/node_modules/@jsonstudio/llms/dist/router/virtual-router/engine-health.d.ts +0 -1
- package/node_modules/@jsonstudio/llms/dist/router/virtual-router/engine-health.js +0 -1
- package/node_modules/@jsonstudio/llms/dist/servertool/handlers/iflow-model-error-retry.js +0 -92
- package/node_modules/@jsonstudio/llms/dist/servertool/handlers/review.js +0 -202
- package/scripts/publish-rcc.mjs +0 -81
- /package/node_modules/@jsonstudio/llms/dist/servertool/handlers/{iflow-model-error-retry.d.ts → reasoning-stop-guard.d.ts} +0 -0
- /package/node_modules/@jsonstudio/llms/dist/servertool/handlers/{review.d.ts → reasoning-stop.d.ts} +0 -0
|
@@ -1,40 +1,17 @@
|
|
|
1
1
|
import { asRecord } from '../provider-utils.js';
|
|
2
2
|
import { convertProviderResponse as bridgeConvertProviderResponse, createSnapshotRecorder as bridgeCreateSnapshotRecorder } from '../../../../modules/llmswitch/bridge.js';
|
|
3
|
-
import {
|
|
4
|
-
import { resolveStopMessageClientInjectReadiness, runClientInjectionFlowBeforeReenter } from './client-injection-flow.js';
|
|
5
|
-
import { extractClientModelId, normalizeProviderResponse } from './provider-response-utils.js';
|
|
3
|
+
import { normalizeProviderResponse } from './provider-response-utils.js';
|
|
6
4
|
import { isVerboseErrorLoggingEnabled } from './env-config.js';
|
|
5
|
+
import { logExecutorRuntimeNonBlockingWarning } from './servertool-runtime-log.js';
|
|
7
6
|
import { extractSseWrapperError } from './sse-error-handler.js';
|
|
8
7
|
import { isRateLimitLikeError } from './request-retry-helpers.js';
|
|
9
8
|
import { extractUsageFromResult } from './usage-aggregator.js';
|
|
10
|
-
import { deriveFinishReason
|
|
9
|
+
import { deriveFinishReason } from '../../../utils/finish-reason.js';
|
|
11
10
|
import { logPipelineStage } from '../../../utils/stage-logger.js';
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
'xconversationid',
|
|
17
|
-
'anthropicsessionid',
|
|
18
|
-
'anthropicconversationid',
|
|
19
|
-
'xroutecodexsessionid',
|
|
20
|
-
'xroutecodexconversationid',
|
|
21
|
-
'xroutecodexclientdaemonid',
|
|
22
|
-
'xroutecodexclientdid',
|
|
23
|
-
'xrccclientdaemonid',
|
|
24
|
-
'xroutecodexsessiondaemonid',
|
|
25
|
-
'xroutecodexdaemonid',
|
|
26
|
-
'xrccsessiondaemonid',
|
|
27
|
-
'xroutecodexclienttmuxsessionid',
|
|
28
|
-
'xrccclienttmuxsessionid',
|
|
29
|
-
'xroutecodextmuxsessionid',
|
|
30
|
-
'xrcctmuxsessionid',
|
|
31
|
-
'xtmuxsessionid',
|
|
32
|
-
'xroutecodexclientworkdir',
|
|
33
|
-
'xrccclientworkdir',
|
|
34
|
-
'xroutecodexworkdir',
|
|
35
|
-
'xrccworkdir',
|
|
36
|
-
'xworkdir'
|
|
37
|
-
]);
|
|
11
|
+
import { buildServerToolSseWrapperBody } from './servertool-response-normalizer.js';
|
|
12
|
+
import { buildServerToolAdapterContext } from './servertool-adapter-context.js';
|
|
13
|
+
import { executeServerToolClientInjectDispatch, executeServerToolReenterPipeline } from './servertool-followup-dispatch.js';
|
|
14
|
+
import { compactFollowupLogReason, extractServerToolFollowupErrorLogDetails, finalizeServerToolBridgeConvertError } from './servertool-followup-error.js';
|
|
38
15
|
const CONTEXT_LENGTH_MESSAGE_HINTS = [
|
|
39
16
|
'context_length_exceeded',
|
|
40
17
|
'context_window_exceeded',
|
|
@@ -71,6 +48,555 @@ const RETRYABLE_NETWORK_CODE_HINTS = [
|
|
|
71
48
|
'timeout'
|
|
72
49
|
];
|
|
73
50
|
const truthy = new Set(['1', 'true', 'yes', 'on']);
|
|
51
|
+
const FATAL_CONVERSION_ERROR_CODES = new Set([
|
|
52
|
+
'CLIENT_TOOL_ARGS_INVALID',
|
|
53
|
+
]);
|
|
54
|
+
const STOPLESS_DIRECTIVE_PATTERN = /<\*\*stopless:[^*]+\*\*>/i;
|
|
55
|
+
function isImagePathLike(value) {
|
|
56
|
+
return /\.(png|jpg|jpeg|gif|webp|bmp|svg|tiff?|ico|heic|jxl)$/i.test(value);
|
|
57
|
+
}
|
|
58
|
+
function parseToolArgsRecord(argsString) {
|
|
59
|
+
const trimmed = String(argsString || '').trim();
|
|
60
|
+
if (!trimmed || !(trimmed.startsWith('{') || trimmed.startsWith('['))) {
|
|
61
|
+
return null;
|
|
62
|
+
}
|
|
63
|
+
try {
|
|
64
|
+
const parsed = JSON.parse(trimmed);
|
|
65
|
+
return asFlatRecord(parsed) ?? null;
|
|
66
|
+
}
|
|
67
|
+
catch {
|
|
68
|
+
return null;
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
function buildMissingFields(fields) {
|
|
72
|
+
const normalized = fields
|
|
73
|
+
.map((field) => (typeof field === 'string' ? field.trim() : ''))
|
|
74
|
+
.filter((field) => Boolean(field));
|
|
75
|
+
return normalized.length ? normalized : undefined;
|
|
76
|
+
}
|
|
77
|
+
function buildToolValidationFailure(args) {
|
|
78
|
+
return {
|
|
79
|
+
ok: false,
|
|
80
|
+
reason: args.reason,
|
|
81
|
+
message: args.message,
|
|
82
|
+
...(args.missingFields?.length ? { missingFields: args.missingFields } : {})
|
|
83
|
+
};
|
|
84
|
+
}
|
|
85
|
+
function readReasoningStopBoolean(value) {
|
|
86
|
+
if (value === true) {
|
|
87
|
+
return true;
|
|
88
|
+
}
|
|
89
|
+
if (value === false) {
|
|
90
|
+
return false;
|
|
91
|
+
}
|
|
92
|
+
if (typeof value !== 'string') {
|
|
93
|
+
return undefined;
|
|
94
|
+
}
|
|
95
|
+
const normalized = value.trim().toLowerCase();
|
|
96
|
+
if (normalized === 'true') {
|
|
97
|
+
return true;
|
|
98
|
+
}
|
|
99
|
+
if (normalized === 'false') {
|
|
100
|
+
return false;
|
|
101
|
+
}
|
|
102
|
+
return undefined;
|
|
103
|
+
}
|
|
104
|
+
function validateCanonicalClientToolCall(name, argsString, declaredToolNames) {
|
|
105
|
+
const parsed = parseToolArgsRecord(argsString);
|
|
106
|
+
const normalizedName = name.trim().toLowerCase();
|
|
107
|
+
switch (normalizedName) {
|
|
108
|
+
case 'exec_command': {
|
|
109
|
+
const cmd = typeof parsed?.cmd === 'string' ? parsed.cmd.trim() : '';
|
|
110
|
+
if (!cmd) {
|
|
111
|
+
return buildToolValidationFailure({
|
|
112
|
+
reason: 'missing_cmd',
|
|
113
|
+
message: 'exec_command requires input.cmd as a non-empty string.',
|
|
114
|
+
missingFields: ['cmd']
|
|
115
|
+
});
|
|
116
|
+
}
|
|
117
|
+
return { ok: true, normalizedArgs: JSON.stringify({ ...parsed, cmd }) };
|
|
118
|
+
}
|
|
119
|
+
case 'view_image': {
|
|
120
|
+
const pathValue = typeof parsed?.path === 'string' ? parsed.path.trim() : '';
|
|
121
|
+
if (!pathValue || !isImagePathLike(pathValue)) {
|
|
122
|
+
return buildToolValidationFailure({
|
|
123
|
+
reason: 'invalid_image_path',
|
|
124
|
+
message: 'view_image requires input.path pointing to an image file.'
|
|
125
|
+
});
|
|
126
|
+
}
|
|
127
|
+
return { ok: true, normalizedArgs: JSON.stringify({ path: pathValue }) };
|
|
128
|
+
}
|
|
129
|
+
case 'apply_patch': {
|
|
130
|
+
const patch = typeof parsed?.patch === 'string' && parsed.patch.trim()
|
|
131
|
+
? parsed.patch
|
|
132
|
+
: typeof parsed?.input === 'string' && parsed.input.trim()
|
|
133
|
+
? parsed.input
|
|
134
|
+
: '';
|
|
135
|
+
if (!patch) {
|
|
136
|
+
return buildToolValidationFailure({
|
|
137
|
+
reason: 'missing_patch',
|
|
138
|
+
message: 'apply_patch requires patch content in input.patch or input.input.',
|
|
139
|
+
missingFields: ['patch']
|
|
140
|
+
});
|
|
141
|
+
}
|
|
142
|
+
return { ok: true, normalizedArgs: JSON.stringify({ patch, input: patch }) };
|
|
143
|
+
}
|
|
144
|
+
case 'update_plan': {
|
|
145
|
+
if (!Array.isArray(parsed?.plan)) {
|
|
146
|
+
return buildToolValidationFailure({
|
|
147
|
+
reason: 'missing_plan',
|
|
148
|
+
message: 'update_plan requires input.plan as an array.',
|
|
149
|
+
missingFields: ['plan']
|
|
150
|
+
});
|
|
151
|
+
}
|
|
152
|
+
return { ok: true, normalizedArgs: JSON.stringify({ explanation: parsed?.explanation, plan: parsed.plan }) };
|
|
153
|
+
}
|
|
154
|
+
case 'shell_command':
|
|
155
|
+
case 'bash': {
|
|
156
|
+
const command = typeof parsed?.command === 'string' ? parsed.command.trim() : '';
|
|
157
|
+
if (!command) {
|
|
158
|
+
return buildToolValidationFailure({
|
|
159
|
+
reason: 'missing_command',
|
|
160
|
+
message: `${normalizedName} requires input.command as a non-empty string.`,
|
|
161
|
+
missingFields: ['command']
|
|
162
|
+
});
|
|
163
|
+
}
|
|
164
|
+
return { ok: true, normalizedArgs: JSON.stringify(parsed) };
|
|
165
|
+
}
|
|
166
|
+
case 'shell': {
|
|
167
|
+
const command = parsed?.command;
|
|
168
|
+
if (!(Array.isArray(command) && command.every((entry) => typeof entry === 'string' && entry.trim().length > 0))) {
|
|
169
|
+
return buildToolValidationFailure({
|
|
170
|
+
reason: 'invalid_command',
|
|
171
|
+
message: 'shell requires input.command as a non-empty string array.'
|
|
172
|
+
});
|
|
173
|
+
}
|
|
174
|
+
return { ok: true, normalizedArgs: JSON.stringify(parsed) };
|
|
175
|
+
}
|
|
176
|
+
case 'read_mcp_resource': {
|
|
177
|
+
const server = typeof parsed?.server === 'string' ? parsed.server.trim() : '';
|
|
178
|
+
const uri = typeof parsed?.uri === 'string' ? parsed.uri.trim() : '';
|
|
179
|
+
if (!server || !uri) {
|
|
180
|
+
return buildToolValidationFailure({
|
|
181
|
+
reason: 'missing_server_or_uri',
|
|
182
|
+
message: 'read_mcp_resource requires both input.server and input.uri.',
|
|
183
|
+
missingFields: buildMissingFields([
|
|
184
|
+
!server ? 'server' : undefined,
|
|
185
|
+
!uri ? 'uri' : undefined
|
|
186
|
+
])
|
|
187
|
+
});
|
|
188
|
+
}
|
|
189
|
+
return { ok: true, normalizedArgs: JSON.stringify({ server, uri }) };
|
|
190
|
+
}
|
|
191
|
+
case 'reasoning.stop': {
|
|
192
|
+
if (!parsed) {
|
|
193
|
+
return buildToolValidationFailure({
|
|
194
|
+
reason: 'invalid_reasoning_stop_arguments',
|
|
195
|
+
message: 'reasoning.stop requires a JSON object arguments payload.'
|
|
196
|
+
});
|
|
197
|
+
}
|
|
198
|
+
const taskGoal = typeof parsed.task_goal === 'string'
|
|
199
|
+
? parsed.task_goal.trim()
|
|
200
|
+
: typeof parsed.taskGoal === 'string'
|
|
201
|
+
? parsed.taskGoal.trim()
|
|
202
|
+
: typeof parsed.goal === 'string'
|
|
203
|
+
? parsed.goal.trim()
|
|
204
|
+
: '';
|
|
205
|
+
if (!taskGoal) {
|
|
206
|
+
return buildToolValidationFailure({
|
|
207
|
+
reason: 'invalid_reasoning_stop_arguments',
|
|
208
|
+
message: 'reasoning.stop requires task_goal.',
|
|
209
|
+
missingFields: ['task_goal']
|
|
210
|
+
});
|
|
211
|
+
}
|
|
212
|
+
const completed = readReasoningStopBoolean(parsed.is_completed ?? parsed.isCompleted ?? parsed.completed);
|
|
213
|
+
if (typeof completed !== 'boolean') {
|
|
214
|
+
return buildToolValidationFailure({
|
|
215
|
+
reason: 'invalid_reasoning_stop_arguments',
|
|
216
|
+
message: 'reasoning.stop requires is_completed(boolean).',
|
|
217
|
+
missingFields: ['is_completed']
|
|
218
|
+
});
|
|
219
|
+
}
|
|
220
|
+
return { ok: true, normalizedArgs: JSON.stringify(parsed) };
|
|
221
|
+
}
|
|
222
|
+
case 'list_mcp_resources':
|
|
223
|
+
case 'list_mcp_resource_templates':
|
|
224
|
+
return { ok: true, normalizedArgs: JSON.stringify(parsed ?? {}) };
|
|
225
|
+
default:
|
|
226
|
+
if (declaredToolNames?.has(normalizedName)) {
|
|
227
|
+
if (!parsed) {
|
|
228
|
+
return buildToolValidationFailure({
|
|
229
|
+
reason: 'invalid_declared_tool_arguments',
|
|
230
|
+
message: `Tool "${name.trim()}" requires JSON object arguments.`
|
|
231
|
+
});
|
|
232
|
+
}
|
|
233
|
+
return { ok: true, normalizedArgs: JSON.stringify(parsed) };
|
|
234
|
+
}
|
|
235
|
+
const declaredList = declaredToolNames && declaredToolNames.size > 0
|
|
236
|
+
? Array.from(declaredToolNames).sort().join(', ')
|
|
237
|
+
: '';
|
|
238
|
+
return buildToolValidationFailure({
|
|
239
|
+
reason: 'unknown_tool',
|
|
240
|
+
message: declaredList
|
|
241
|
+
? `Tool "${name.trim()}" is not declared for this request. Declared tools: ${declaredList}.`
|
|
242
|
+
: `Tool "${name.trim()}" is not declared for this request.`
|
|
243
|
+
});
|
|
244
|
+
}
|
|
245
|
+
}
|
|
246
|
+
function readSessionLikeToken(value) {
|
|
247
|
+
if (typeof value !== 'string') {
|
|
248
|
+
return undefined;
|
|
249
|
+
}
|
|
250
|
+
const trimmed = value.trim();
|
|
251
|
+
return trimmed || undefined;
|
|
252
|
+
}
|
|
253
|
+
function asFlatRecord(value) {
|
|
254
|
+
return value && typeof value === 'object' && !Array.isArray(value)
|
|
255
|
+
? value
|
|
256
|
+
: undefined;
|
|
257
|
+
}
|
|
258
|
+
function tryParseJsonLikeString(raw) {
|
|
259
|
+
const trimmed = raw.trim();
|
|
260
|
+
if (!trimmed) {
|
|
261
|
+
return undefined;
|
|
262
|
+
}
|
|
263
|
+
if (!(trimmed.startsWith('{') || trimmed.startsWith('['))
|
|
264
|
+
&& !trimmed.includes('{"')
|
|
265
|
+
&& !trimmed.includes("{'")) {
|
|
266
|
+
return undefined;
|
|
267
|
+
}
|
|
268
|
+
try {
|
|
269
|
+
return JSON.parse(trimmed);
|
|
270
|
+
}
|
|
271
|
+
catch {
|
|
272
|
+
const balanced = extractFirstBalancedJsonObject(trimmed);
|
|
273
|
+
if (!balanced) {
|
|
274
|
+
return undefined;
|
|
275
|
+
}
|
|
276
|
+
try {
|
|
277
|
+
return JSON.parse(balanced);
|
|
278
|
+
}
|
|
279
|
+
catch {
|
|
280
|
+
return undefined;
|
|
281
|
+
}
|
|
282
|
+
}
|
|
283
|
+
}
|
|
284
|
+
function extractContentTextForStoplessScan(content) {
|
|
285
|
+
if (typeof content === 'string') {
|
|
286
|
+
return content;
|
|
287
|
+
}
|
|
288
|
+
if (!Array.isArray(content)) {
|
|
289
|
+
return '';
|
|
290
|
+
}
|
|
291
|
+
const parts = [];
|
|
292
|
+
for (const item of content) {
|
|
293
|
+
if (typeof item === 'string') {
|
|
294
|
+
parts.push(item);
|
|
295
|
+
continue;
|
|
296
|
+
}
|
|
297
|
+
if (!item || typeof item !== 'object' || Array.isArray(item)) {
|
|
298
|
+
continue;
|
|
299
|
+
}
|
|
300
|
+
const text = typeof item.text === 'string'
|
|
301
|
+
? String(item.text)
|
|
302
|
+
: '';
|
|
303
|
+
if (text) {
|
|
304
|
+
parts.push(text);
|
|
305
|
+
}
|
|
306
|
+
}
|
|
307
|
+
return parts.join('\n');
|
|
308
|
+
}
|
|
309
|
+
function extractLatestUserTextForStoplessScan(source) {
|
|
310
|
+
const record = asFlatRecord(source);
|
|
311
|
+
if (!record) {
|
|
312
|
+
return '';
|
|
313
|
+
}
|
|
314
|
+
const rows = Array.isArray(record.messages)
|
|
315
|
+
? record.messages
|
|
316
|
+
: Array.isArray(record.input)
|
|
317
|
+
? record.input
|
|
318
|
+
: [];
|
|
319
|
+
for (let i = rows.length - 1; i >= 0; i -= 1) {
|
|
320
|
+
const row = asFlatRecord(rows[i]);
|
|
321
|
+
if (!row) {
|
|
322
|
+
continue;
|
|
323
|
+
}
|
|
324
|
+
const role = typeof row.role === 'string' ? row.role.trim().toLowerCase() : '';
|
|
325
|
+
if (role !== 'user') {
|
|
326
|
+
continue;
|
|
327
|
+
}
|
|
328
|
+
const text = extractContentTextForStoplessScan(row.content).trim();
|
|
329
|
+
if (text) {
|
|
330
|
+
return text;
|
|
331
|
+
}
|
|
332
|
+
}
|
|
333
|
+
return '';
|
|
334
|
+
}
|
|
335
|
+
function hasStoplessDirectiveInRequestPayload(source) {
|
|
336
|
+
return STOPLESS_DIRECTIVE_PATTERN.test(extractLatestUserTextForStoplessScan(source));
|
|
337
|
+
}
|
|
338
|
+
function collectDeclaredToolNames(baseContext) {
|
|
339
|
+
const capturedRequest = asFlatRecord(baseContext.capturedChatRequest);
|
|
340
|
+
const tools = Array.isArray(capturedRequest?.tools) ? capturedRequest.tools : [];
|
|
341
|
+
const names = new Set();
|
|
342
|
+
for (const tool of tools) {
|
|
343
|
+
if (!tool || typeof tool !== 'object' || Array.isArray(tool)) {
|
|
344
|
+
continue;
|
|
345
|
+
}
|
|
346
|
+
const row = tool;
|
|
347
|
+
const fn = row.function && typeof row.function === 'object' && !Array.isArray(row.function)
|
|
348
|
+
? row.function
|
|
349
|
+
: row;
|
|
350
|
+
const name = typeof fn.name === 'string' ? fn.name.trim().toLowerCase() : '';
|
|
351
|
+
if (name) {
|
|
352
|
+
names.add(name);
|
|
353
|
+
}
|
|
354
|
+
}
|
|
355
|
+
return names;
|
|
356
|
+
}
|
|
357
|
+
function findNestedRawString(payload, depth = 3) {
|
|
358
|
+
if (depth < 0 || payload === null || payload === undefined) {
|
|
359
|
+
return '';
|
|
360
|
+
}
|
|
361
|
+
if (typeof payload === 'string') {
|
|
362
|
+
return payload;
|
|
363
|
+
}
|
|
364
|
+
if (typeof payload !== 'object' || Array.isArray(payload)) {
|
|
365
|
+
return '';
|
|
366
|
+
}
|
|
367
|
+
const record = payload;
|
|
368
|
+
const directRaw = typeof record.raw === 'string' ? record.raw : '';
|
|
369
|
+
if (directRaw) {
|
|
370
|
+
return directRaw;
|
|
371
|
+
}
|
|
372
|
+
for (const key of ['body', 'data', 'payload', 'response', 'error']) {
|
|
373
|
+
const nested = findNestedRawString(record[key], depth - 1);
|
|
374
|
+
if (nested) {
|
|
375
|
+
return nested;
|
|
376
|
+
}
|
|
377
|
+
}
|
|
378
|
+
return '';
|
|
379
|
+
}
|
|
380
|
+
function findNestedErrorMarker(payload, depth = 3) {
|
|
381
|
+
if (depth < 0 || payload === null || payload === undefined) {
|
|
382
|
+
return '';
|
|
383
|
+
}
|
|
384
|
+
if (typeof payload === 'string') {
|
|
385
|
+
return payload;
|
|
386
|
+
}
|
|
387
|
+
if (typeof payload !== 'object' || Array.isArray(payload)) {
|
|
388
|
+
return '';
|
|
389
|
+
}
|
|
390
|
+
const record = payload;
|
|
391
|
+
const directError = typeof record.error === 'string' ? record.error.trim() : '';
|
|
392
|
+
if (directError) {
|
|
393
|
+
return directError;
|
|
394
|
+
}
|
|
395
|
+
for (const key of ['body', 'data', 'payload', 'response']) {
|
|
396
|
+
const nested = findNestedErrorMarker(record[key], depth - 1);
|
|
397
|
+
if (nested) {
|
|
398
|
+
return nested;
|
|
399
|
+
}
|
|
400
|
+
}
|
|
401
|
+
return '';
|
|
402
|
+
}
|
|
403
|
+
function extractFirstBalancedJsonObject(raw) {
|
|
404
|
+
const start = raw.indexOf('{');
|
|
405
|
+
if (start < 0) {
|
|
406
|
+
return undefined;
|
|
407
|
+
}
|
|
408
|
+
let depth = 0;
|
|
409
|
+
let inString = false;
|
|
410
|
+
let escaping = false;
|
|
411
|
+
for (let i = start; i < raw.length; i += 1) {
|
|
412
|
+
const ch = raw[i];
|
|
413
|
+
if (inString) {
|
|
414
|
+
if (escaping) {
|
|
415
|
+
escaping = false;
|
|
416
|
+
continue;
|
|
417
|
+
}
|
|
418
|
+
if (ch === '\\') {
|
|
419
|
+
escaping = true;
|
|
420
|
+
continue;
|
|
421
|
+
}
|
|
422
|
+
if (ch === '"') {
|
|
423
|
+
inString = false;
|
|
424
|
+
}
|
|
425
|
+
continue;
|
|
426
|
+
}
|
|
427
|
+
if (ch === '"') {
|
|
428
|
+
inString = true;
|
|
429
|
+
continue;
|
|
430
|
+
}
|
|
431
|
+
if (ch === '{') {
|
|
432
|
+
depth += 1;
|
|
433
|
+
continue;
|
|
434
|
+
}
|
|
435
|
+
if (ch === '}') {
|
|
436
|
+
depth -= 1;
|
|
437
|
+
if (depth === 0) {
|
|
438
|
+
return raw.slice(start, i + 1);
|
|
439
|
+
}
|
|
440
|
+
}
|
|
441
|
+
}
|
|
442
|
+
return undefined;
|
|
443
|
+
}
|
|
444
|
+
function normalizeRecoveredToolCalls(value, declaredToolNames) {
|
|
445
|
+
const rows = Array.isArray(value) ? value : [];
|
|
446
|
+
const normalized = [];
|
|
447
|
+
for (const row of rows) {
|
|
448
|
+
const item = asFlatRecord(row);
|
|
449
|
+
const functionRecord = asFlatRecord(item?.function);
|
|
450
|
+
const nameRaw = (typeof item?.name === 'string' ? item.name : '') ||
|
|
451
|
+
(typeof functionRecord?.name === 'string' ? functionRecord.name : '');
|
|
452
|
+
const name = nameRaw.trim();
|
|
453
|
+
if (!name) {
|
|
454
|
+
continue;
|
|
455
|
+
}
|
|
456
|
+
if (declaredToolNames.size > 0 && !declaredToolNames.has(name.toLowerCase())) {
|
|
457
|
+
continue;
|
|
458
|
+
}
|
|
459
|
+
const inputRecord = asFlatRecord(item?.input)
|
|
460
|
+
?? asFlatRecord(item?.arguments)
|
|
461
|
+
?? asFlatRecord(functionRecord?.arguments)
|
|
462
|
+
?? {};
|
|
463
|
+
const validation = validateCanonicalClientToolCall(name, JSON.stringify(inputRecord ?? {}), declaredToolNames);
|
|
464
|
+
if (!validation.ok) {
|
|
465
|
+
return {
|
|
466
|
+
toolCalls: normalized,
|
|
467
|
+
invalidCall: {
|
|
468
|
+
name,
|
|
469
|
+
reason: validation.reason || 'invalid_tool_arguments',
|
|
470
|
+
message: validation.message,
|
|
471
|
+
...(validation.missingFields?.length ? { missingFields: validation.missingFields } : {})
|
|
472
|
+
}
|
|
473
|
+
};
|
|
474
|
+
}
|
|
475
|
+
let normalizedInput = inputRecord;
|
|
476
|
+
if (typeof validation.normalizedArgs === 'string') {
|
|
477
|
+
try {
|
|
478
|
+
const parsed = JSON.parse(validation.normalizedArgs);
|
|
479
|
+
if (asFlatRecord(parsed)) {
|
|
480
|
+
normalizedInput = parsed;
|
|
481
|
+
}
|
|
482
|
+
}
|
|
483
|
+
catch {
|
|
484
|
+
// keep validated original
|
|
485
|
+
}
|
|
486
|
+
}
|
|
487
|
+
normalized.push({ name, input: normalizedInput });
|
|
488
|
+
}
|
|
489
|
+
return { toolCalls: normalized };
|
|
490
|
+
}
|
|
491
|
+
function stringifyToolCallArgumentsForValidation(value) {
|
|
492
|
+
if (typeof value === 'string') {
|
|
493
|
+
return value;
|
|
494
|
+
}
|
|
495
|
+
try {
|
|
496
|
+
return JSON.stringify(value ?? {});
|
|
497
|
+
}
|
|
498
|
+
catch {
|
|
499
|
+
return '{}';
|
|
500
|
+
}
|
|
501
|
+
}
|
|
502
|
+
function collectConvertedProviderToolCalls(payload) {
|
|
503
|
+
const result = [];
|
|
504
|
+
const record = asFlatRecord(payload);
|
|
505
|
+
if (!record) {
|
|
506
|
+
return result;
|
|
507
|
+
}
|
|
508
|
+
const choices = Array.isArray(record.choices) ? record.choices : [];
|
|
509
|
+
for (let i = 0; i < choices.length; i += 1) {
|
|
510
|
+
const choice = asFlatRecord(choices[i]);
|
|
511
|
+
const message = asFlatRecord(choice?.message);
|
|
512
|
+
const toolCalls = Array.isArray(message?.tool_calls) ? message.tool_calls : [];
|
|
513
|
+
for (let j = 0; j < toolCalls.length; j += 1) {
|
|
514
|
+
const toolCall = asFlatRecord(toolCalls[j]);
|
|
515
|
+
const fn = asFlatRecord(toolCall?.function);
|
|
516
|
+
const name = (typeof fn?.name === 'string' ? fn.name : '')
|
|
517
|
+
|| (typeof toolCall?.name === 'string' ? toolCall.name : '');
|
|
518
|
+
if (!name.trim()) {
|
|
519
|
+
continue;
|
|
520
|
+
}
|
|
521
|
+
result.push({
|
|
522
|
+
name: name.trim(),
|
|
523
|
+
argumentsText: stringifyToolCallArgumentsForValidation(fn?.arguments ?? toolCall?.arguments ?? toolCall?.input),
|
|
524
|
+
path: `choices[${i}].message.tool_calls[${j}]`
|
|
525
|
+
});
|
|
526
|
+
}
|
|
527
|
+
}
|
|
528
|
+
const requiredAction = asFlatRecord(record.required_action);
|
|
529
|
+
const submitToolOutputs = asFlatRecord(requiredAction?.submit_tool_outputs);
|
|
530
|
+
const submitToolCalls = Array.isArray(submitToolOutputs?.tool_calls) ? submitToolOutputs.tool_calls : [];
|
|
531
|
+
for (let i = 0; i < submitToolCalls.length; i += 1) {
|
|
532
|
+
const toolCall = asFlatRecord(submitToolCalls[i]);
|
|
533
|
+
const fn = asFlatRecord(toolCall?.function);
|
|
534
|
+
const name = (typeof fn?.name === 'string' ? fn.name : '')
|
|
535
|
+
|| (typeof toolCall?.name === 'string' ? toolCall.name : '');
|
|
536
|
+
if (!name.trim()) {
|
|
537
|
+
continue;
|
|
538
|
+
}
|
|
539
|
+
result.push({
|
|
540
|
+
name: name.trim(),
|
|
541
|
+
argumentsText: stringifyToolCallArgumentsForValidation(fn?.arguments ?? toolCall?.arguments ?? toolCall?.input),
|
|
542
|
+
path: `required_action.submit_tool_outputs.tool_calls[${i}]`
|
|
543
|
+
});
|
|
544
|
+
}
|
|
545
|
+
return result;
|
|
546
|
+
}
|
|
547
|
+
function validateConvertedProviderToolCallsOrThrow(payload, declaredToolNames) {
|
|
548
|
+
const toolCalls = collectConvertedProviderToolCalls(payload);
|
|
549
|
+
for (const toolCall of toolCalls) {
|
|
550
|
+
const validation = validateCanonicalClientToolCall(toolCall.name, toolCall.argumentsText, declaredToolNames);
|
|
551
|
+
if (validation.ok) {
|
|
552
|
+
continue;
|
|
553
|
+
}
|
|
554
|
+
const err = new Error(validation.message
|
|
555
|
+
? `Converted provider tool call has invalid client arguments at ${toolCall.path}: ${toolCall.name}. ${validation.message}`
|
|
556
|
+
: `Converted provider tool call has invalid client arguments at ${toolCall.path}: ${toolCall.name} (${validation.reason || 'invalid_tool_arguments'})`);
|
|
557
|
+
err.code = 'CLIENT_TOOL_ARGS_INVALID';
|
|
558
|
+
err.status = 502;
|
|
559
|
+
err.statusCode = 502;
|
|
560
|
+
err.retryable = false;
|
|
561
|
+
err.upstreamCode = 'CLIENT_TOOL_ARGS_INVALID';
|
|
562
|
+
err.toolName = toolCall.name;
|
|
563
|
+
err.validationReason = validation.reason || 'invalid_tool_arguments';
|
|
564
|
+
err.validationMessage = validation.message;
|
|
565
|
+
if (validation.missingFields?.length) {
|
|
566
|
+
err.missingFields = validation.missingFields;
|
|
567
|
+
}
|
|
568
|
+
err.details = {
|
|
569
|
+
...(err.details ?? {}),
|
|
570
|
+
toolName: toolCall.name,
|
|
571
|
+
validationReason: validation.reason || 'invalid_tool_arguments',
|
|
572
|
+
...(validation.message ? { validationMessage: validation.message } : {}),
|
|
573
|
+
...(validation.missingFields?.length ? { missingFields: validation.missingFields } : {})
|
|
574
|
+
};
|
|
575
|
+
throw err;
|
|
576
|
+
}
|
|
577
|
+
}
|
|
578
|
+
function isGenericBridgeResponseContractError(args) {
|
|
579
|
+
const code = typeof args.error.code === 'string' ? args.error.code.trim() : '';
|
|
580
|
+
const name = typeof args.error.name === 'string' ? args.error.name.trim() : '';
|
|
581
|
+
const normalizedMessage = args.message.trim().toLowerCase();
|
|
582
|
+
if (name !== 'ProviderProtocolError') {
|
|
583
|
+
return false;
|
|
584
|
+
}
|
|
585
|
+
if (code !== 'MALFORMED_RESPONSE') {
|
|
586
|
+
return false;
|
|
587
|
+
}
|
|
588
|
+
return (normalizedMessage.includes('[hub_response] non-canonical response payload')
|
|
589
|
+
|| normalizedMessage.includes('[hub_response] failed to canonicalize response payload'));
|
|
590
|
+
}
|
|
591
|
+
function logProviderResponseConverterNonBlockingError(stage, error, details) {
|
|
592
|
+
logExecutorRuntimeNonBlockingWarning({
|
|
593
|
+
namespace: 'provider-response-converter',
|
|
594
|
+
stage,
|
|
595
|
+
error,
|
|
596
|
+
details,
|
|
597
|
+
throttleKey: stage
|
|
598
|
+
});
|
|
599
|
+
}
|
|
74
600
|
function shouldEnableHubStageRecorder() {
|
|
75
601
|
const raw = String(process.env.ROUTECODEX_ENABLE_HUB_STAGE_RECORDER
|
|
76
602
|
?? process.env.RCC_ENABLE_HUB_STAGE_RECORDER
|
|
@@ -146,63 +672,6 @@ function remapBridgeSseErrorToHttp(error, message) {
|
|
|
146
672
|
error.code = 'HTTP_502';
|
|
147
673
|
}
|
|
148
674
|
}
|
|
149
|
-
function canonicalizeHeaderName(headerName) {
|
|
150
|
-
return headerName.toLowerCase().replace(/[^a-z0-9]/g, '');
|
|
151
|
-
}
|
|
152
|
-
function extractFollowupSessionHeaders(headers) {
|
|
153
|
-
if (!headers || typeof headers !== 'object' || Array.isArray(headers)) {
|
|
154
|
-
return undefined;
|
|
155
|
-
}
|
|
156
|
-
const source = headers;
|
|
157
|
-
const preserved = {};
|
|
158
|
-
for (const [headerName, headerValue] of Object.entries(source)) {
|
|
159
|
-
if (!FOLLOWUP_SESSION_HEADER_KEYS.has(canonicalizeHeaderName(headerName))) {
|
|
160
|
-
continue;
|
|
161
|
-
}
|
|
162
|
-
if (typeof headerValue !== 'string') {
|
|
163
|
-
continue;
|
|
164
|
-
}
|
|
165
|
-
const normalizedValue = headerValue.trim();
|
|
166
|
-
if (!normalizedValue) {
|
|
167
|
-
continue;
|
|
168
|
-
}
|
|
169
|
-
preserved[headerName] = normalizedValue;
|
|
170
|
-
}
|
|
171
|
-
return Object.keys(preserved).length ? preserved : undefined;
|
|
172
|
-
}
|
|
173
|
-
function extractPreservedSessionToken(headers, field) {
|
|
174
|
-
if (!headers) {
|
|
175
|
-
return undefined;
|
|
176
|
-
}
|
|
177
|
-
for (const [headerName, headerValue] of Object.entries(headers)) {
|
|
178
|
-
const normalizedName = canonicalizeHeaderName(headerName);
|
|
179
|
-
if (field === 'session' && normalizedName.endsWith('sessionid')) {
|
|
180
|
-
return headerValue;
|
|
181
|
-
}
|
|
182
|
-
if (field === 'conversation' && normalizedName.endsWith('conversationid')) {
|
|
183
|
-
return headerValue;
|
|
184
|
-
}
|
|
185
|
-
}
|
|
186
|
-
return undefined;
|
|
187
|
-
}
|
|
188
|
-
function extractPreservedDaemonOrInjectToken(headers, field) {
|
|
189
|
-
if (!headers) {
|
|
190
|
-
return undefined;
|
|
191
|
-
}
|
|
192
|
-
for (const [headerName, headerValue] of Object.entries(headers)) {
|
|
193
|
-
const normalizedName = canonicalizeHeaderName(headerName);
|
|
194
|
-
if (field === 'daemon' && (normalizedName.endsWith('sessiondaemonid') || normalizedName.endsWith('daemonid'))) {
|
|
195
|
-
return headerValue;
|
|
196
|
-
}
|
|
197
|
-
if (field === 'tmux' && normalizedName.endsWith('tmuxsessionid')) {
|
|
198
|
-
return headerValue;
|
|
199
|
-
}
|
|
200
|
-
if (field === 'workdir' && normalizedName.endsWith('workdir')) {
|
|
201
|
-
return headerValue;
|
|
202
|
-
}
|
|
203
|
-
}
|
|
204
|
-
return undefined;
|
|
205
|
-
}
|
|
206
675
|
function syncHubStageTopBackToPipelineMetadata(options) {
|
|
207
676
|
const pipelineMetadata = asRecord(options.pipelineMetadata);
|
|
208
677
|
if (!pipelineMetadata) {
|
|
@@ -226,6 +695,7 @@ export async function convertProviderResponseIfNeeded(options, deps) {
|
|
|
226
695
|
const codeSuffix = wrapperError.errorCode ? ` [${wrapperError.errorCode}]` : '';
|
|
227
696
|
const error = new Error(`Upstream SSE error event${codeSuffix}: ${wrapperError.message}`);
|
|
228
697
|
error.code = 'SSE_DECODE_ERROR';
|
|
698
|
+
error.requestExecutorProviderErrorStage = 'provider.sse_decode';
|
|
229
699
|
if (wrapperError.errorCode) {
|
|
230
700
|
error.upstreamCode = wrapperError.errorCode;
|
|
231
701
|
}
|
|
@@ -294,76 +764,23 @@ export async function convertProviderResponseIfNeeded(options, deps) {
|
|
|
294
764
|
}
|
|
295
765
|
};
|
|
296
766
|
};
|
|
767
|
+
let adapterContext;
|
|
297
768
|
try {
|
|
298
769
|
const metadataBag = asRecord(options.pipelineMetadata);
|
|
299
|
-
const
|
|
300
|
-
|
|
301
|
-
|
|
302
|
-
:
|
|
303
|
-
|
|
304
|
-
|
|
305
|
-
|
|
306
|
-
|
|
307
|
-
|
|
308
|
-
|
|
309
|
-
|
|
310
|
-
|
|
311
|
-
|
|
312
|
-
...(metadataBag ?? {})
|
|
313
|
-
};
|
|
314
|
-
if (baseContext.capturedChatRequest === undefined &&
|
|
315
|
-
options.originalRequest &&
|
|
316
|
-
typeof options.originalRequest === 'object' &&
|
|
317
|
-
!Array.isArray(options.originalRequest)) {
|
|
318
|
-
baseContext.capturedChatRequest = options.originalRequest;
|
|
319
|
-
}
|
|
320
|
-
if (typeof metadataBag?.routeName === 'string') {
|
|
321
|
-
baseContext.routeId = metadataBag.routeName;
|
|
322
|
-
}
|
|
323
|
-
baseContext.requestId = options.requestId;
|
|
324
|
-
baseContext.entryEndpoint = options.entryEndpoint || entry;
|
|
325
|
-
baseContext.providerProtocol = options.providerProtocol;
|
|
326
|
-
baseContext.originalModelId = originalModelId;
|
|
327
|
-
if (assignedModelId && assignedModelId.trim()) {
|
|
328
|
-
baseContext.modelId = assignedModelId.trim();
|
|
329
|
-
}
|
|
330
|
-
applyClientConnectionStateToContext(metadataBag, baseContext);
|
|
331
|
-
const adapterContext = baseContext;
|
|
332
|
-
const stopMessageInjectReadiness = resolveStopMessageClientInjectReadiness(baseContext);
|
|
333
|
-
{
|
|
334
|
-
const rt = asRecord(adapterContext.__rt) ?? {};
|
|
335
|
-
adapterContext.__rt = {
|
|
336
|
-
...rt,
|
|
337
|
-
stopMessageClientInjectReady: stopMessageInjectReadiness.ready,
|
|
338
|
-
stopMessageClientInjectReason: stopMessageInjectReadiness.reason,
|
|
339
|
-
...(stopMessageInjectReadiness.sessionScope
|
|
340
|
-
? { stopMessageClientInjectSessionScope: stopMessageInjectReadiness.sessionScope }
|
|
341
|
-
: {}),
|
|
342
|
-
...(stopMessageInjectReadiness.tmuxSessionId
|
|
343
|
-
? { stopMessageClientInjectTmuxSessionId: stopMessageInjectReadiness.tmuxSessionId }
|
|
344
|
-
: {})
|
|
345
|
-
};
|
|
346
|
-
}
|
|
347
|
-
const hasTargetMetadata = metadataBag &&
|
|
348
|
-
typeof metadataBag === 'object' &&
|
|
349
|
-
metadataBag.target &&
|
|
350
|
-
typeof metadataBag.target === 'object';
|
|
351
|
-
const targetCompatProfile = hasTargetMetadata &&
|
|
352
|
-
typeof metadataBag.target.compatibilityProfile === 'string'
|
|
353
|
-
? metadataBag.target.compatibilityProfile
|
|
354
|
-
: undefined;
|
|
355
|
-
const metadataCompatProfile = typeof metadataBag?.compatibilityProfile === 'string'
|
|
356
|
-
? String(metadataBag.compatibilityProfile)
|
|
357
|
-
: undefined;
|
|
358
|
-
const compatProfile = hasTargetMetadata ? targetCompatProfile : metadataCompatProfile;
|
|
359
|
-
if (compatProfile && compatProfile.trim()) {
|
|
360
|
-
adapterContext.compatibilityProfile = compatProfile.trim();
|
|
361
|
-
}
|
|
770
|
+
const baseContext = buildServerToolAdapterContext({
|
|
771
|
+
metadata: metadataBag,
|
|
772
|
+
originalRequest: options.originalRequest,
|
|
773
|
+
requestSemantics: options.requestSemantics,
|
|
774
|
+
requestId: options.requestId,
|
|
775
|
+
entryEndpoint: options.entryEndpoint || entry,
|
|
776
|
+
providerProtocol: options.providerProtocol,
|
|
777
|
+
serverToolsEnabled: options.serverToolsEnabled !== false,
|
|
778
|
+
onReasoningStopSeedError: (error) => {
|
|
779
|
+
logProviderResponseConverterNonBlockingError('seedReasoningStopStateFromCapturedRequest', error);
|
|
780
|
+
}
|
|
781
|
+
});
|
|
782
|
+
adapterContext = baseContext;
|
|
362
783
|
const serverToolsEnabled = options.serverToolsEnabled !== false;
|
|
363
|
-
adapterContext.serverToolsEnabled = serverToolsEnabled;
|
|
364
|
-
if (!serverToolsEnabled) {
|
|
365
|
-
adapterContext.serverToolsDisabled = true;
|
|
366
|
-
}
|
|
367
784
|
let stageRecorder;
|
|
368
785
|
if (shouldEnableHubStageRecorder()) {
|
|
369
786
|
logPipelineStage('convert.snapshot_recorder.start', options.requestId, {
|
|
@@ -440,69 +857,31 @@ export async function convertProviderResponseIfNeeded(options, deps) {
|
|
|
440
857
|
};
|
|
441
858
|
const reenterPipeline = async (reenterOpts) => {
|
|
442
859
|
const reenterStartMs = Date.now();
|
|
860
|
+
const nestedEntry = reenterOpts.entryEndpoint || options.entryEndpoint || entry;
|
|
443
861
|
logPipelineStage('convert.reenter.start', reenterOpts.requestId, {
|
|
444
|
-
entryEndpoint:
|
|
862
|
+
entryEndpoint: nestedEntry
|
|
445
863
|
});
|
|
446
|
-
const
|
|
447
|
-
|
|
448
|
-
|
|
449
|
-
const out = {
|
|
450
|
-
...(metadataBag ?? {}),
|
|
451
|
-
...extra,
|
|
452
|
-
entryEndpoint: resolvedEntry,
|
|
453
|
-
direction: 'request',
|
|
454
|
-
stage: 'inbound'
|
|
455
|
-
};
|
|
456
|
-
try {
|
|
457
|
-
const baseRt = asRecord(metadataBag?.__rt) ?? {};
|
|
458
|
-
const extraRt = asRecord(extra?.__rt) ?? {};
|
|
459
|
-
if (Object.keys(baseRt).length || Object.keys(extraRt).length) {
|
|
460
|
-
out.__rt = { ...baseRt, ...extraRt };
|
|
461
|
-
}
|
|
462
|
-
}
|
|
463
|
-
catch {
|
|
464
|
-
// best-effort
|
|
465
|
-
}
|
|
466
|
-
if (asRecord(out.__rt)?.serverToolFollowup === true) {
|
|
467
|
-
const preservedClientHeaders = extractFollowupSessionHeaders(out.clientHeaders);
|
|
468
|
-
if (preservedClientHeaders) {
|
|
469
|
-
out.clientHeaders = preservedClientHeaders;
|
|
470
|
-
const sessionId = extractPreservedSessionToken(preservedClientHeaders, 'session');
|
|
471
|
-
const conversationId = extractPreservedSessionToken(preservedClientHeaders, 'conversation');
|
|
472
|
-
if (sessionId) {
|
|
473
|
-
out.sessionId = sessionId;
|
|
474
|
-
}
|
|
475
|
-
if (conversationId) {
|
|
476
|
-
out.conversationId = conversationId;
|
|
477
|
-
}
|
|
478
|
-
}
|
|
479
|
-
else {
|
|
480
|
-
delete out.clientHeaders;
|
|
481
|
-
}
|
|
482
|
-
delete out.clientRequestId;
|
|
483
|
-
}
|
|
484
|
-
return out;
|
|
485
|
-
};
|
|
486
|
-
const nestedMetadata = buildNestedMetadata(nestedExtra, nestedEntry);
|
|
487
|
-
const nestedInput = {
|
|
488
|
-
entryEndpoint: nestedEntry,
|
|
489
|
-
method: 'POST',
|
|
864
|
+
const nestedResult = await executeServerToolReenterPipeline({
|
|
865
|
+
entryEndpoint: reenterOpts.entryEndpoint,
|
|
866
|
+
fallbackEntryEndpoint: options.entryEndpoint || entry,
|
|
490
867
|
requestId: reenterOpts.requestId,
|
|
491
|
-
headers: {},
|
|
492
|
-
query: {},
|
|
493
868
|
body: reenterOpts.body,
|
|
494
|
-
metadata:
|
|
495
|
-
|
|
496
|
-
|
|
869
|
+
metadata: reenterOpts.metadata,
|
|
870
|
+
baseMetadata: metadataBag,
|
|
871
|
+
executeNested: deps.executeNested,
|
|
872
|
+
runClientInjectBeforeNested: false,
|
|
873
|
+
onMergeRuntimeMetaError: (error, details) => {
|
|
874
|
+
logProviderResponseConverterNonBlockingError('reenter.buildNestedMetadata.mergeRuntimeMeta', error, {
|
|
875
|
+
requestId: details.requestId,
|
|
876
|
+
entryEndpoint: details.entryEndpoint
|
|
877
|
+
});
|
|
878
|
+
}
|
|
879
|
+
});
|
|
497
880
|
logPipelineStage('convert.reenter.completed', reenterOpts.requestId, {
|
|
498
881
|
entryEndpoint: nestedEntry,
|
|
499
|
-
status: nestedResult.status,
|
|
500
882
|
elapsedMs: Date.now() - reenterStartMs
|
|
501
883
|
});
|
|
502
|
-
|
|
503
|
-
? nestedResult.body
|
|
504
|
-
: undefined;
|
|
505
|
-
return { body: nestedBody };
|
|
884
|
+
return nestedResult;
|
|
506
885
|
};
|
|
507
886
|
const clientInjectDispatch = async (injectOpts) => {
|
|
508
887
|
const clientInjectAttemptStartedAt = Date.now();
|
|
@@ -511,47 +890,22 @@ export async function convertProviderResponseIfNeeded(options, deps) {
|
|
|
511
890
|
entryEndpoint: injectOpts.entryEndpoint || options.entryEndpoint || entry
|
|
512
891
|
});
|
|
513
892
|
const nestedEntry = injectOpts.entryEndpoint || options.entryEndpoint || entry;
|
|
514
|
-
const
|
|
515
|
-
|
|
516
|
-
|
|
517
|
-
|
|
518
|
-
|
|
519
|
-
|
|
520
|
-
|
|
521
|
-
|
|
522
|
-
|
|
523
|
-
|
|
524
|
-
|
|
525
|
-
|
|
526
|
-
if (Object.keys(baseRt).length || Object.keys(extraRt).length) {
|
|
527
|
-
out.__rt = { ...baseRt, ...extraRt };
|
|
528
|
-
}
|
|
529
|
-
}
|
|
530
|
-
catch {
|
|
531
|
-
// best-effort
|
|
893
|
+
const injectResult = await executeServerToolClientInjectDispatch({
|
|
894
|
+
entryEndpoint: injectOpts.entryEndpoint,
|
|
895
|
+
fallbackEntryEndpoint: options.entryEndpoint || entry,
|
|
896
|
+
requestId: injectOpts.requestId,
|
|
897
|
+
body: injectOpts.body,
|
|
898
|
+
metadata: injectOpts.metadata,
|
|
899
|
+
baseMetadata: metadataBag,
|
|
900
|
+
onMergeRuntimeMetaError: (error, details) => {
|
|
901
|
+
logProviderResponseConverterNonBlockingError('clientInjectDispatch.mergeRuntimeMeta', error, {
|
|
902
|
+
requestId: details.requestId,
|
|
903
|
+
entryEndpoint: details.entryEndpoint
|
|
904
|
+
});
|
|
532
905
|
}
|
|
533
|
-
if (asRecord(out.__rt)?.serverToolFollowup === true) {
|
|
534
|
-
const preservedClientHeaders = extractFollowupSessionHeaders(out.clientHeaders);
|
|
535
|
-
if (preservedClientHeaders) {
|
|
536
|
-
out.clientHeaders = preservedClientHeaders;
|
|
537
|
-
}
|
|
538
|
-
else {
|
|
539
|
-
delete out.clientHeaders;
|
|
540
|
-
}
|
|
541
|
-
delete out.clientRequestId;
|
|
542
|
-
}
|
|
543
|
-
return out;
|
|
544
|
-
})();
|
|
545
|
-
const requestBody = injectOpts.body && typeof injectOpts.body === 'object' && !Array.isArray(injectOpts.body)
|
|
546
|
-
? injectOpts.body
|
|
547
|
-
: {};
|
|
548
|
-
const injectResult = await runClientInjectionFlowBeforeReenter({
|
|
549
|
-
nestedMetadata,
|
|
550
|
-
requestBody,
|
|
551
|
-
requestId: injectOpts.requestId
|
|
552
906
|
});
|
|
553
907
|
clientInjectWaitMs += Math.max(0, Date.now() - clientInjectAttemptStartedAt);
|
|
554
|
-
if (injectResult.
|
|
908
|
+
if (injectResult.ok) {
|
|
555
909
|
logPipelineStage('convert.client_inject.completed', injectOpts.requestId, {
|
|
556
910
|
entryEndpoint: nestedEntry,
|
|
557
911
|
handled: true,
|
|
@@ -562,10 +916,10 @@ export async function convertProviderResponseIfNeeded(options, deps) {
|
|
|
562
916
|
logPipelineStage('convert.client_inject.completed', injectOpts.requestId, {
|
|
563
917
|
entryEndpoint: nestedEntry,
|
|
564
918
|
handled: false,
|
|
565
|
-
reason: 'client_inject_not_handled',
|
|
919
|
+
reason: injectResult.reason || 'client_inject_not_handled',
|
|
566
920
|
elapsedMs: Date.now() - clientInjectStartMs
|
|
567
921
|
});
|
|
568
|
-
return { ok: false, reason: 'client_inject_not_handled' };
|
|
922
|
+
return { ok: false, reason: injectResult.reason || 'client_inject_not_handled' };
|
|
569
923
|
};
|
|
570
924
|
logPipelineStage('convert.bridge.start', options.requestId, {
|
|
571
925
|
entryEndpoint: options.entryEndpoint || entry,
|
|
@@ -596,6 +950,7 @@ export async function convertProviderResponseIfNeeded(options, deps) {
|
|
|
596
950
|
hasBody: converted.body !== undefined && converted.body !== null,
|
|
597
951
|
elapsedMs: Date.now() - bridgeStartMs
|
|
598
952
|
});
|
|
953
|
+
validateConvertedProviderToolCallsOrThrow(converted.body ?? body, collectDeclaredToolNames(baseContext));
|
|
599
954
|
if (converted.__sse_responses) {
|
|
600
955
|
const usage = converted.body
|
|
601
956
|
? extractUsageFromResult({ body: converted.body })
|
|
@@ -605,16 +960,13 @@ export async function convertProviderResponseIfNeeded(options, deps) {
|
|
|
605
960
|
hasUsage: Boolean(usage),
|
|
606
961
|
finishReason
|
|
607
962
|
});
|
|
608
|
-
const body = { __sse_responses: converted.__sse_responses };
|
|
609
|
-
if (usage) {
|
|
610
|
-
body.usage = usage;
|
|
611
|
-
}
|
|
612
|
-
if (finishReason) {
|
|
613
|
-
body[STREAM_LOG_FINISH_REASON_KEY] = finishReason;
|
|
614
|
-
}
|
|
615
963
|
return attachTimingBreakdown({
|
|
616
964
|
...options.response,
|
|
617
|
-
body
|
|
965
|
+
body: buildServerToolSseWrapperBody({
|
|
966
|
+
sseResponses: converted.__sse_responses,
|
|
967
|
+
convertedBody: converted.body,
|
|
968
|
+
usage
|
|
969
|
+
})
|
|
618
970
|
});
|
|
619
971
|
}
|
|
620
972
|
return attachTimingBreakdown({
|
|
@@ -635,40 +987,61 @@ export async function convertProviderResponseIfNeeded(options, deps) {
|
|
|
635
987
|
: undefined;
|
|
636
988
|
const detailReason = typeof detailRecord?.reason === 'string'
|
|
637
989
|
? String(detailRecord.reason)
|
|
638
|
-
:
|
|
990
|
+
: typeof detailRecord?.error === 'string'
|
|
991
|
+
? String(detailRecord.error)
|
|
992
|
+
: undefined;
|
|
639
993
|
const normalizedUpstreamCode = (upstreamCode || detailUpstreamCode || '').trim().toLowerCase();
|
|
994
|
+
const fatalConversionCode = (typeof errCode === 'string' && FATAL_CONVERSION_ERROR_CODES.has(errCode) ? errCode : undefined)
|
|
995
|
+
?? (typeof upstreamCode === 'string' && FATAL_CONVERSION_ERROR_CODES.has(upstreamCode) ? upstreamCode : undefined)
|
|
996
|
+
?? (typeof detailUpstreamCode === 'string' && FATAL_CONVERSION_ERROR_CODES.has(detailUpstreamCode) ? detailUpstreamCode : undefined);
|
|
997
|
+
if (fatalConversionCode) {
|
|
998
|
+
logPipelineStage('convert.bridge.error', options.requestId, {
|
|
999
|
+
code: errCode,
|
|
1000
|
+
upstreamCode: upstreamCode || detailUpstreamCode,
|
|
1001
|
+
reason: detailReason,
|
|
1002
|
+
message
|
|
1003
|
+
});
|
|
1004
|
+
throw error;
|
|
1005
|
+
}
|
|
640
1006
|
const isSseDecodeError = errCode === 'SSE_DECODE_ERROR' ||
|
|
641
1007
|
errCode === 'HTTP_502' ||
|
|
642
1008
|
errCode === 'HTTP_429' ||
|
|
643
1009
|
(errName === 'ProviderProtocolError' && message.toLowerCase().includes('sse'));
|
|
644
|
-
const isServerToolFollowupError = errCode === 'SERVERTOOL_FOLLOWUP_FAILED' ||
|
|
645
|
-
errCode === 'SERVERTOOL_EMPTY_FOLLOWUP' ||
|
|
646
|
-
(typeof errCode === 'string' && errCode.startsWith('SERVERTOOL_'));
|
|
647
1010
|
const normalizedMessage = message.toLowerCase();
|
|
648
1011
|
const isContextLengthExceeded = isContextLengthExceededError(normalizedMessage, upstreamCode || detailUpstreamCode, detailReason);
|
|
649
|
-
if (
|
|
1012
|
+
if (isGenericBridgeResponseContractError({ error: errRecord, message })) {
|
|
1013
|
+
errRecord.requestExecutorProviderErrorStage = 'host.response_contract';
|
|
1014
|
+
}
|
|
1015
|
+
const convertErrorPlan = finalizeServerToolBridgeConvertError({
|
|
1016
|
+
error,
|
|
1017
|
+
requestId: options.requestId,
|
|
1018
|
+
defaultFollowupStatus: 502,
|
|
1019
|
+
message,
|
|
1020
|
+
isSseDecodeError,
|
|
1021
|
+
isContextLengthExceeded,
|
|
1022
|
+
code: errCode,
|
|
1023
|
+
upstreamCode,
|
|
1024
|
+
detailUpstreamCode,
|
|
1025
|
+
detailReason
|
|
1026
|
+
});
|
|
1027
|
+
const isServerToolFollowupFailure = convertErrorPlan.handled
|
|
1028
|
+
&& errRecord.requestExecutorProviderErrorStage === 'provider.followup';
|
|
1029
|
+
const followupLogDetails = isServerToolFollowupFailure
|
|
1030
|
+
? extractServerToolFollowupErrorLogDetails(error)
|
|
1031
|
+
: undefined;
|
|
1032
|
+
if (convertErrorPlan.handled) {
|
|
650
1033
|
if (isSseDecodeError || isContextLengthExceeded) {
|
|
651
1034
|
remapBridgeSseErrorToHttp(errRecord, message);
|
|
652
1035
|
}
|
|
653
|
-
const normalizedCode = typeof errRecord.code === 'string' ? errRecord.code : errCode;
|
|
654
|
-
if (isServerToolFollowupError) {
|
|
655
|
-
console.error('[RequestExecutor] ServerTool followup failed', {
|
|
656
|
-
requestId: options.requestId,
|
|
657
|
-
code: normalizedCode,
|
|
658
|
-
upstreamCode: upstreamCode || detailUpstreamCode,
|
|
659
|
-
reason: detailReason,
|
|
660
|
-
message
|
|
661
|
-
});
|
|
662
|
-
if (normalizedUpstreamCode === 'client_inject_failed') {
|
|
663
|
-
// Followup rejection should not break the main assistant response.
|
|
664
|
-
return options.response;
|
|
665
|
-
}
|
|
666
|
-
}
|
|
667
1036
|
logPipelineStage('convert.bridge.error', options.requestId, {
|
|
668
|
-
|
|
669
|
-
|
|
670
|
-
|
|
671
|
-
|
|
1037
|
+
...(isServerToolFollowupFailure
|
|
1038
|
+
? (convertErrorPlan.stageDetails ?? {})
|
|
1039
|
+
: (convertErrorPlan.stageDetails ?? {
|
|
1040
|
+
code: followupLogDetails?.code || (typeof errRecord.code === 'string' ? errRecord.code : errCode),
|
|
1041
|
+
upstreamCode: followupLogDetails?.upstreamCode || upstreamCode || detailUpstreamCode,
|
|
1042
|
+
reason: followupLogDetails?.reason || compactFollowupLogReason(detailReason),
|
|
1043
|
+
message
|
|
1044
|
+
}))
|
|
672
1045
|
});
|
|
673
1046
|
if (isVerboseErrorLoggingEnabled()) {
|
|
674
1047
|
console.error('[RequestExecutor] Fatal conversion error, bubbling as HTTP error', error);
|
|
@@ -684,7 +1057,7 @@ export async function convertProviderResponseIfNeeded(options, deps) {
|
|
|
684
1057
|
if (isVerboseErrorLoggingEnabled()) {
|
|
685
1058
|
console.error('[RequestExecutor] Failed to convert provider response via llmswitch-core', error);
|
|
686
1059
|
}
|
|
687
|
-
|
|
1060
|
+
throw error;
|
|
688
1061
|
}
|
|
689
1062
|
}
|
|
690
1063
|
//# sourceMappingURL=provider-response-converter.js.map
|