@jsonstudio/rcc 0.89.164 → 0.89.333
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 +18 -15
- package/dist/build-info.js +3 -3
- package/dist/build-info.js.map +1 -1
- package/dist/cli.js +32 -0
- package/dist/cli.js.map +1 -1
- package/dist/client/gemini-cli/gemini-cli-protocol-client.js +28 -5
- package/dist/client/gemini-cli/gemini-cli-protocol-client.js.map +1 -1
- package/dist/error-handling/quiet-error-handling-center.d.ts +9 -0
- package/dist/error-handling/quiet-error-handling-center.js +141 -0
- package/dist/error-handling/quiet-error-handling-center.js.map +1 -0
- package/dist/error-handling/route-error-hub.js +8 -2
- package/dist/error-handling/route-error-hub.js.map +1 -1
- package/dist/modules/pipeline/utils/colored-logger.d.ts +2 -0
- package/dist/modules/pipeline/utils/colored-logger.js +20 -3
- package/dist/modules/pipeline/utils/colored-logger.js.map +1 -1
- package/dist/providers/auth/antigravity-userinfo-helper.d.ts +10 -0
- package/dist/providers/auth/antigravity-userinfo-helper.js +140 -0
- package/dist/providers/auth/antigravity-userinfo-helper.js.map +1 -0
- package/dist/providers/auth/oauth-lifecycle.js +140 -8
- package/dist/providers/auth/oauth-lifecycle.js.map +1 -1
- package/dist/providers/auth/token-scanner/index.d.ts +32 -0
- package/dist/providers/auth/token-scanner/index.js +86 -0
- package/dist/providers/auth/token-scanner/index.js.map +1 -0
- package/dist/providers/auth/tokenfile-auth.d.ts +17 -0
- package/dist/providers/auth/tokenfile-auth.js +27 -5
- package/dist/providers/auth/tokenfile-auth.js.map +1 -1
- package/dist/providers/core/api/provider-types.d.ts +10 -0
- package/dist/providers/core/config/oauth-flows.d.ts +2 -0
- package/dist/providers/core/config/oauth-flows.js.map +1 -1
- package/dist/providers/core/config/provider-oauth-configs.js +85 -0
- package/dist/providers/core/config/provider-oauth-configs.js.map +1 -1
- package/dist/providers/core/config/service-profiles.js +15 -1
- package/dist/providers/core/config/service-profiles.js.map +1 -1
- package/dist/providers/core/runtime/base-provider.d.ts +8 -1
- package/dist/providers/core/runtime/base-provider.js +176 -108
- package/dist/providers/core/runtime/base-provider.js.map +1 -1
- package/dist/providers/core/runtime/gemini-cli-http-provider.d.ts +9 -5
- package/dist/providers/core/runtime/gemini-cli-http-provider.js +271 -69
- package/dist/providers/core/runtime/gemini-cli-http-provider.js.map +1 -1
- package/dist/providers/core/runtime/gemini-http-provider.d.ts +1 -2
- package/dist/providers/core/runtime/gemini-http-provider.js +0 -12
- package/dist/providers/core/runtime/gemini-http-provider.js.map +1 -1
- package/dist/providers/core/runtime/http-request-executor.d.ts +42 -0
- package/dist/providers/core/runtime/http-request-executor.js +133 -0
- package/dist/providers/core/runtime/http-request-executor.js.map +1 -0
- package/dist/providers/core/runtime/http-transport-provider.d.ts +32 -12
- package/dist/providers/core/runtime/http-transport-provider.js +464 -426
- package/dist/providers/core/runtime/http-transport-provider.js.map +1 -1
- package/dist/providers/core/runtime/provider-error-classifier.d.ts +25 -0
- package/dist/providers/core/runtime/provider-error-classifier.js +149 -0
- package/dist/providers/core/runtime/provider-error-classifier.js.map +1 -0
- package/dist/providers/core/runtime/provider-error-types.d.ts +23 -0
- package/dist/providers/core/runtime/provider-error-types.js +2 -0
- package/dist/providers/core/runtime/provider-error-types.js.map +1 -0
- package/dist/providers/core/runtime/provider-factory.d.ts +1 -0
- package/dist/providers/core/runtime/provider-factory.js +43 -8
- package/dist/providers/core/runtime/provider-factory.js.map +1 -1
- package/dist/providers/core/runtime/responses-provider.d.ts +3 -3
- package/dist/providers/core/runtime/responses-provider.js +48 -114
- package/dist/providers/core/runtime/responses-provider.js.map +1 -1
- package/dist/providers/core/strategies/oauth-auth-code-flow.js +11 -3
- package/dist/providers/core/strategies/oauth-auth-code-flow.js.map +1 -1
- package/dist/providers/core/utils/http-client.d.ts +5 -0
- package/dist/providers/core/utils/http-client.js +29 -3
- package/dist/providers/core/utils/http-client.js.map +1 -1
- package/dist/providers/core/utils/provider-error-reporter.js +8 -2
- package/dist/providers/core/utils/provider-error-reporter.js.map +1 -1
- package/dist/providers/core/utils/snapshot-writer.js +5 -1
- package/dist/providers/core/utils/snapshot-writer.js.map +1 -1
- package/dist/providers/profile/provider-profile-loader.js +8 -4
- package/dist/providers/profile/provider-profile-loader.js.map +1 -1
- package/dist/runtime/runtime-flags.d.ts +4 -0
- package/dist/runtime/runtime-flags.js +32 -0
- package/dist/runtime/runtime-flags.js.map +1 -0
- package/dist/server/handlers/handler-utils.js +29 -2
- package/dist/server/handlers/handler-utils.js.map +1 -1
- package/dist/server/handlers/messages-handler.js +27 -26
- package/dist/server/handlers/messages-handler.js.map +1 -1
- package/dist/server/handlers/responses-handler.js +35 -1
- package/dist/server/handlers/responses-handler.js.map +1 -1
- package/dist/server/runtime/http-server/index.d.ts +1 -0
- package/dist/server/runtime/http-server/index.js +39 -4
- package/dist/server/runtime/http-server/index.js.map +1 -1
- package/dist/server/runtime/http-server/request-executor.d.ts +4 -0
- package/dist/server/runtime/http-server/request-executor.js +99 -4
- package/dist/server/runtime/http-server/request-executor.js.map +1 -1
- package/dist/server/utils/sse-request-parser.d.ts +1 -0
- package/dist/server/utils/sse-request-parser.js +17 -6
- package/dist/server/utils/sse-request-parser.js.map +1 -1
- package/dist/server/utils/warmup-detector.d.ts +7 -0
- package/dist/server/utils/warmup-detector.js +125 -0
- package/dist/server/utils/warmup-detector.js.map +1 -0
- package/dist/server/utils/warmup-storm-tracker.d.ts +9 -0
- package/dist/server/utils/warmup-storm-tracker.js +61 -0
- package/dist/server/utils/warmup-storm-tracker.js.map +1 -0
- package/dist/utils/debug-utils.js +14 -0
- package/dist/utils/debug-utils.js.map +1 -1
- package/dist/utils/error-handler-registry.js +6 -5
- package/dist/utils/error-handler-registry.js.map +1 -1
- package/dist/utils/error-handling-utils.js +4 -3
- package/dist/utils/error-handling-utils.js.map +1 -1
- package/dist/utils/log-helpers.d.ts +6 -0
- package/dist/utils/log-helpers.js +90 -0
- package/dist/utils/log-helpers.js.map +1 -0
- package/dist/utils/logger.d.ts +8 -0
- package/dist/utils/logger.js +55 -2
- package/dist/utils/logger.js.map +1 -1
- package/dist/utils/snapshot-writer.js +2 -6
- package/dist/utils/snapshot-writer.js.map +1 -1
- package/node_modules/@jsonstudio/llms/dist/conversion/codecs/gemini-openai-codec.js +15 -1
- package/node_modules/@jsonstudio/llms/dist/conversion/compat/actions/auto-thinking.d.ts +6 -0
- package/node_modules/@jsonstudio/llms/dist/conversion/compat/actions/auto-thinking.js +25 -0
- package/node_modules/@jsonstudio/llms/dist/conversion/compat/actions/field-mapping.d.ts +14 -0
- package/node_modules/@jsonstudio/llms/dist/conversion/compat/actions/field-mapping.js +155 -0
- package/node_modules/@jsonstudio/llms/dist/conversion/compat/actions/glm-tool-extraction.d.ts +2 -0
- package/node_modules/@jsonstudio/llms/dist/conversion/compat/actions/glm-tool-extraction.js +264 -0
- package/node_modules/@jsonstudio/llms/dist/conversion/compat/actions/qwen-transform.d.ts +3 -0
- package/node_modules/@jsonstudio/llms/dist/conversion/compat/actions/qwen-transform.js +209 -0
- package/node_modules/@jsonstudio/llms/dist/conversion/compat/actions/request-rules.d.ts +24 -0
- package/node_modules/@jsonstudio/llms/dist/conversion/compat/actions/request-rules.js +63 -0
- package/node_modules/@jsonstudio/llms/dist/conversion/compat/actions/response-blacklist.d.ts +14 -0
- package/node_modules/@jsonstudio/llms/dist/conversion/compat/actions/response-blacklist.js +85 -0
- package/node_modules/@jsonstudio/llms/dist/conversion/compat/actions/response-normalize.d.ts +5 -0
- package/node_modules/@jsonstudio/llms/dist/conversion/compat/actions/response-normalize.js +121 -0
- package/node_modules/@jsonstudio/llms/dist/conversion/compat/actions/response-validate.d.ts +5 -0
- package/node_modules/@jsonstudio/llms/dist/conversion/compat/actions/response-validate.js +76 -0
- package/{dist/providers/compat/utils/snapshot-writer.d.ts → node_modules/@jsonstudio/llms/dist/conversion/compat/actions/snapshot.d.ts} +2 -2
- package/node_modules/@jsonstudio/llms/dist/conversion/compat/actions/snapshot.js +21 -0
- package/node_modules/@jsonstudio/llms/dist/conversion/compat/actions/tool-schema.d.ts +6 -0
- package/{dist/providers/compat/glm/utils/tool-schema-helpers.js → node_modules/@jsonstudio/llms/dist/conversion/compat/actions/tool-schema.js} +6 -1
- package/{dist/providers/compat/filters → node_modules/@jsonstudio/llms/dist/conversion/compat/actions}/universal-shape-filter.d.ts +17 -22
- package/{dist/providers/compat/filters → node_modules/@jsonstudio/llms/dist/conversion/compat/actions}/universal-shape-filter.js +35 -99
- package/node_modules/@jsonstudio/llms/dist/conversion/compat/profiles/chat-glm.json +187 -13
- package/node_modules/@jsonstudio/llms/dist/conversion/compat/profiles/chat-iflow.json +177 -9
- package/node_modules/@jsonstudio/llms/dist/conversion/compat/profiles/chat-lmstudio.json +10 -2
- package/node_modules/@jsonstudio/llms/dist/conversion/compat/profiles/chat-qwen.json +14 -10
- package/node_modules/@jsonstudio/llms/dist/conversion/hub/pipeline/compat/compat-engine.d.ts +7 -2
- package/node_modules/@jsonstudio/llms/dist/conversion/hub/pipeline/compat/compat-engine.js +5 -665
- package/node_modules/@jsonstudio/llms/dist/conversion/hub/pipeline/compat/compat-pipeline-executor.d.ts +9 -0
- package/node_modules/@jsonstudio/llms/dist/conversion/hub/pipeline/compat/compat-pipeline-executor.js +845 -0
- package/node_modules/@jsonstudio/llms/dist/conversion/hub/pipeline/compat/compat-types.d.ts +47 -0
- package/node_modules/@jsonstudio/llms/dist/conversion/hub/pipeline/hub-pipeline.d.ts +2 -0
- package/node_modules/@jsonstudio/llms/dist/conversion/hub/pipeline/hub-pipeline.js +35 -1
- package/node_modules/@jsonstudio/llms/dist/conversion/hub/pipeline/stages/req_outbound/req_outbound_stage3_compat/index.js +2 -2
- package/node_modules/@jsonstudio/llms/dist/conversion/hub/pipeline/target-utils.js +3 -0
- package/node_modules/@jsonstudio/llms/dist/conversion/hub/response/response-runtime.js +19 -2
- package/node_modules/@jsonstudio/llms/dist/conversion/responses/responses-host-policy.d.ts +6 -0
- package/node_modules/@jsonstudio/llms/dist/conversion/responses/responses-host-policy.js +14 -0
- package/node_modules/@jsonstudio/llms/dist/conversion/responses/responses-openai-bridge.js +51 -2
- package/node_modules/@jsonstudio/llms/dist/conversion/shared/anthropic-message-utils.js +6 -0
- package/node_modules/@jsonstudio/llms/dist/conversion/shared/responses-reasoning-registry.d.ts +4 -0
- package/node_modules/@jsonstudio/llms/dist/conversion/shared/responses-reasoning-registry.js +62 -1
- package/node_modules/@jsonstudio/llms/dist/conversion/shared/responses-response-utils.js +23 -1
- package/node_modules/@jsonstudio/llms/dist/conversion/shared/tool-canonicalizer.d.ts +2 -0
- package/node_modules/@jsonstudio/llms/dist/conversion/shared/tool-filter-pipeline.js +11 -0
- package/node_modules/@jsonstudio/llms/dist/router/virtual-router/bootstrap.js +251 -12
- package/node_modules/@jsonstudio/llms/dist/router/virtual-router/classifier.js +11 -4
- package/node_modules/@jsonstudio/llms/dist/router/virtual-router/context-advisor.d.ts +21 -0
- package/node_modules/@jsonstudio/llms/dist/router/virtual-router/context-advisor.js +76 -0
- package/node_modules/@jsonstudio/llms/dist/router/virtual-router/engine.d.ts +11 -0
- package/node_modules/@jsonstudio/llms/dist/router/virtual-router/engine.js +187 -28
- package/node_modules/@jsonstudio/llms/dist/router/virtual-router/features.js +22 -457
- package/node_modules/@jsonstudio/llms/dist/router/virtual-router/health-manager.js +2 -7
- package/node_modules/@jsonstudio/llms/dist/router/virtual-router/message-utils.d.ts +7 -0
- package/node_modules/@jsonstudio/llms/dist/router/virtual-router/message-utils.js +66 -0
- package/node_modules/@jsonstudio/llms/dist/router/virtual-router/provider-registry.js +6 -2
- package/node_modules/@jsonstudio/llms/dist/router/virtual-router/token-estimator.d.ts +2 -0
- package/node_modules/@jsonstudio/llms/dist/router/virtual-router/token-estimator.js +16 -0
- package/node_modules/@jsonstudio/llms/dist/router/virtual-router/token-file-scanner.d.ts +15 -0
- package/node_modules/@jsonstudio/llms/dist/router/virtual-router/token-file-scanner.js +56 -0
- package/node_modules/@jsonstudio/llms/dist/router/virtual-router/tool-signals.d.ts +13 -0
- package/node_modules/@jsonstudio/llms/dist/router/virtual-router/tool-signals.js +403 -0
- package/node_modules/@jsonstudio/llms/dist/router/virtual-router/types.d.ts +21 -1
- package/node_modules/@jsonstudio/llms/dist/router/virtual-router/types.js +1 -0
- package/node_modules/@jsonstudio/llms/package.json +2 -2
- package/package.json +13 -11
- package/scripts/README.md +26 -12
- package/scripts/auth-antigravity-token.mjs +64 -0
- package/scripts/auth-gemini-cli-token.mjs +96 -0
- package/scripts/auth-iflow-manual.mjs +81 -0
- package/scripts/auth-iflow-token-direct.mjs +87 -0
- package/scripts/auth-iflow-token.mjs +77 -0
- package/scripts/copy-compat-assets.mjs +3 -15
- package/scripts/install-verify.mjs +1 -0
- package/scripts/pack-mode.mjs +30 -1
- package/scripts/publish-rcc.mjs +31 -0
- package/scripts/replay-codex-sample.mjs +13 -8
- package/scripts/tests/chat-pipeline-blackbox.mjs +1 -1
- package/scripts/tools/capture-provider-goldens.mjs +8 -7
- package/scripts/verify-client-headers.mjs +224 -0
- package/dist/providers/compat/base-compatibility.d.ts +0 -27
- package/dist/providers/compat/base-compatibility.js +0 -143
- package/dist/providers/compat/base-compatibility.js.map +0 -1
- package/dist/providers/compat/compat-directory-loader.d.ts +0 -4
- package/dist/providers/compat/compat-directory-loader.js +0 -85
- package/dist/providers/compat/compat-directory-loader.js.map +0 -1
- package/dist/providers/compat/compatibility-adapter.d.ts +0 -18
- package/dist/providers/compat/compatibility-adapter.js +0 -104
- package/dist/providers/compat/compatibility-adapter.js.map +0 -1
- package/dist/providers/compat/compatibility-factory.d.ts +0 -57
- package/dist/providers/compat/compatibility-factory.js +0 -155
- package/dist/providers/compat/compatibility-factory.js.map +0 -1
- package/dist/providers/compat/compatibility-interface.d.ts +0 -35
- package/dist/providers/compat/compatibility-interface.js +0 -2
- package/dist/providers/compat/compatibility-interface.js.map +0 -1
- package/dist/providers/compat/compatibility-manager.d.ts +0 -85
- package/dist/providers/compat/compatibility-manager.js +0 -368
- package/dist/providers/compat/compatibility-manager.js.map +0 -1
- package/dist/providers/compat/config/config-compatibility.d.ts +0 -28
- package/dist/providers/compat/config/config-compatibility.js +0 -95
- package/dist/providers/compat/config/config-compatibility.js.map +0 -1
- package/dist/providers/compat/field-mapping.d.ts +0 -102
- package/dist/providers/compat/field-mapping.js +0 -447
- package/dist/providers/compat/field-mapping.js.map +0 -1
- package/dist/providers/compat/filters/blacklist-sanitizer.d.ts +0 -45
- package/dist/providers/compat/filters/blacklist-sanitizer.js +0 -133
- package/dist/providers/compat/filters/blacklist-sanitizer.js.map +0 -1
- package/dist/providers/compat/filters/response-blacklist-sanitizer.d.ts +0 -28
- package/dist/providers/compat/filters/response-blacklist-sanitizer.js +0 -138
- package/dist/providers/compat/filters/response-blacklist-sanitizer.js.map +0 -1
- package/dist/providers/compat/filters/universal-shape-filter.js.map +0 -1
- package/dist/providers/compat/glm/config/blacklist-rules.json +0 -22
- package/dist/providers/compat/glm/config/field-mappings.json +0 -92
- package/dist/providers/compat/glm/config/response-blacklist.json +0 -7
- package/dist/providers/compat/glm/config/shape-filters.json +0 -37
- package/dist/providers/compat/glm/field-mapping/field-mapping-processor.d.ts +0 -28
- package/dist/providers/compat/glm/field-mapping/field-mapping-processor.js +0 -306
- package/dist/providers/compat/glm/field-mapping/field-mapping-processor.js.map +0 -1
- package/dist/providers/compat/glm/functions/glm-processor.d.ts +0 -50
- package/dist/providers/compat/glm/functions/glm-processor.js +0 -134
- package/dist/providers/compat/glm/functions/glm-processor.js.map +0 -1
- package/dist/providers/compat/glm/glm-compatibility.d.ts +0 -34
- package/dist/providers/compat/glm/glm-compatibility.js +0 -117
- package/dist/providers/compat/glm/glm-compatibility.js.map +0 -1
- package/dist/providers/compat/glm/hooks/base-hook.d.ts +0 -21
- package/dist/providers/compat/glm/hooks/base-hook.js +0 -53
- package/dist/providers/compat/glm/hooks/base-hook.js.map +0 -1
- package/dist/providers/compat/glm/hooks/glm-request-validation-hook.d.ts +0 -24
- package/dist/providers/compat/glm/hooks/glm-request-validation-hook.js +0 -268
- package/dist/providers/compat/glm/hooks/glm-request-validation-hook.js.map +0 -1
- package/dist/providers/compat/glm/hooks/glm-response-normalization-hook.d.ts +0 -21
- package/dist/providers/compat/glm/hooks/glm-response-normalization-hook.js +0 -171
- package/dist/providers/compat/glm/hooks/glm-response-normalization-hook.js.map +0 -1
- package/dist/providers/compat/glm/hooks/glm-response-validation-hook.d.ts +0 -25
- package/dist/providers/compat/glm/hooks/glm-response-validation-hook.js +0 -236
- package/dist/providers/compat/glm/hooks/glm-response-validation-hook.js.map +0 -1
- package/dist/providers/compat/glm/hooks/glm-tool-cleaning-hook.d.ts +0 -26
- package/dist/providers/compat/glm/hooks/glm-tool-cleaning-hook.js +0 -186
- package/dist/providers/compat/glm/hooks/glm-tool-cleaning-hook.js.map +0 -1
- package/dist/providers/compat/glm/index.d.ts +0 -24
- package/dist/providers/compat/glm/index.js +0 -29
- package/dist/providers/compat/glm/index.js.map +0 -1
- package/dist/providers/compat/glm/utils/tool-schema-helpers.d.ts +0 -3
- package/dist/providers/compat/glm/utils/tool-schema-helpers.js.map +0 -1
- package/dist/providers/compat/iflow/config/field-mappings.json +0 -92
- package/dist/providers/compat/iflow/config/shape-filters.json +0 -37
- package/dist/providers/compat/iflow/field-mapping/iflow-field-mapping-processor.d.ts +0 -34
- package/dist/providers/compat/iflow/field-mapping/iflow-field-mapping-processor.js +0 -386
- package/dist/providers/compat/iflow/field-mapping/iflow-field-mapping-processor.js.map +0 -1
- package/dist/providers/compat/iflow/functions/iflow-processor.d.ts +0 -53
- package/dist/providers/compat/iflow/functions/iflow-processor.js +0 -215
- package/dist/providers/compat/iflow/functions/iflow-processor.js.map +0 -1
- package/dist/providers/compat/iflow/hooks/base-hook.d.ts +0 -23
- package/dist/providers/compat/iflow/hooks/base-hook.js +0 -59
- package/dist/providers/compat/iflow/hooks/base-hook.js.map +0 -1
- package/dist/providers/compat/iflow/hooks/iflow-request-validation-hook.d.ts +0 -23
- package/dist/providers/compat/iflow/hooks/iflow-request-validation-hook.js +0 -279
- package/dist/providers/compat/iflow/hooks/iflow-request-validation-hook.js.map +0 -1
- package/dist/providers/compat/iflow/hooks/iflow-response-normalization-hook.d.ts +0 -20
- package/dist/providers/compat/iflow/hooks/iflow-response-normalization-hook.js +0 -180
- package/dist/providers/compat/iflow/hooks/iflow-response-normalization-hook.js.map +0 -1
- package/dist/providers/compat/iflow/hooks/iflow-response-validation-hook.d.ts +0 -23
- package/dist/providers/compat/iflow/hooks/iflow-response-validation-hook.js +0 -232
- package/dist/providers/compat/iflow/hooks/iflow-response-validation-hook.js.map +0 -1
- package/dist/providers/compat/iflow/hooks/iflow-tool-cleaning-hook.d.ts +0 -25
- package/dist/providers/compat/iflow/hooks/iflow-tool-cleaning-hook.js +0 -216
- package/dist/providers/compat/iflow/hooks/iflow-tool-cleaning-hook.js.map +0 -1
- package/dist/providers/compat/iflow/iflow-compatibility.d.ts +0 -24
- package/dist/providers/compat/iflow/iflow-compatibility.js +0 -94
- package/dist/providers/compat/iflow/iflow-compatibility.js.map +0 -1
- package/dist/providers/compat/index.d.ts +0 -59
- package/dist/providers/compat/index.js +0 -83
- package/dist/providers/compat/index.js.map +0 -1
- package/dist/providers/compat/lmstudio-compatibility.d.ts +0 -44
- package/dist/providers/compat/lmstudio-compatibility.js +0 -193
- package/dist/providers/compat/lmstudio-compatibility.js.map +0 -1
- package/dist/providers/compat/passthrough-compatibility.d.ts +0 -29
- package/dist/providers/compat/passthrough-compatibility.js +0 -83
- package/dist/providers/compat/passthrough-compatibility.js.map +0 -1
- package/dist/providers/compat/profiles/chat/glm/index.d.ts +0 -6
- package/dist/providers/compat/profiles/chat/glm/index.js +0 -6
- package/dist/providers/compat/profiles/chat/glm/index.js.map +0 -1
- package/dist/providers/compat/profiles/chat/iflow/index.d.ts +0 -6
- package/dist/providers/compat/profiles/chat/iflow/index.js +0 -6
- package/dist/providers/compat/profiles/chat/iflow/index.js.map +0 -1
- package/dist/providers/compat/profiles/chat/lmstudio/index.d.ts +0 -6
- package/dist/providers/compat/profiles/chat/lmstudio/index.js +0 -6
- package/dist/providers/compat/profiles/chat/lmstudio/index.js.map +0 -1
- package/dist/providers/compat/profiles/chat/qwen/index.d.ts +0 -6
- package/dist/providers/compat/profiles/chat/qwen/index.js +0 -6
- package/dist/providers/compat/profiles/chat/qwen/index.js.map +0 -1
- package/dist/providers/compat/profiles/compat/passthrough/index.d.ts +0 -6
- package/dist/providers/compat/profiles/compat/passthrough/index.js +0 -6
- package/dist/providers/compat/profiles/compat/passthrough/index.js.map +0 -1
- package/dist/providers/compat/profiles/responses/c4m/index.d.ts +0 -6
- package/dist/providers/compat/profiles/responses/c4m/index.js +0 -6
- package/dist/providers/compat/profiles/responses/c4m/index.js.map +0 -1
- package/dist/providers/compat/profiles/responses/default/index.d.ts +0 -6
- package/dist/providers/compat/profiles/responses/default/index.js +0 -6
- package/dist/providers/compat/profiles/responses/default/index.js.map +0 -1
- package/dist/providers/compat/profiles/responses/fai/index.d.ts +0 -6
- package/dist/providers/compat/profiles/responses/fai/index.js +0 -6
- package/dist/providers/compat/profiles/responses/fai/index.js.map +0 -1
- package/dist/providers/compat/profiles/responses/fc/index.d.ts +0 -6
- package/dist/providers/compat/profiles/responses/fc/index.js +0 -6
- package/dist/providers/compat/profiles/responses/fc/index.js.map +0 -1
- package/dist/providers/compat/qwen/index.d.ts +0 -4
- package/dist/providers/compat/qwen/index.js +0 -6
- package/dist/providers/compat/qwen/index.js.map +0 -1
- package/dist/providers/compat/qwen-compatibility.d.ts +0 -52
- package/dist/providers/compat/qwen-compatibility.js +0 -330
- package/dist/providers/compat/qwen-compatibility.js.map +0 -1
- package/dist/providers/compat/register-compat-module.d.ts +0 -8
- package/dist/providers/compat/register-compat-module.js +0 -53
- package/dist/providers/compat/register-compat-module.js.map +0 -1
- package/dist/providers/compat/responses/c4m-responses-compatibility.d.ts +0 -27
- package/dist/providers/compat/responses/c4m-responses-compatibility.js +0 -197
- package/dist/providers/compat/responses/c4m-responses-compatibility.js.map +0 -1
- package/dist/providers/compat/standard-compatibility-utils.d.ts +0 -1
- package/dist/providers/compat/standard-compatibility-utils.js +0 -77
- package/dist/providers/compat/standard-compatibility-utils.js.map +0 -1
- package/dist/providers/compat/standard-compatibility.d.ts +0 -31
- package/dist/providers/compat/standard-compatibility.js +0 -118
- package/dist/providers/compat/standard-compatibility.js.map +0 -1
- package/dist/providers/compat/utils/snapshot-writer.js +0 -62
- package/dist/providers/compat/utils/snapshot-writer.js.map +0 -1
- package/scripts/check-glm-compat.mjs +0 -47
|
@@ -1,77 +0,0 @@
|
|
|
1
|
-
const isRecord = (value) => typeof value === 'object' && value !== null;
|
|
2
|
-
const LEGACY_PROFILE_ALIASES = {
|
|
3
|
-
'responses-c4m': 'responses:c4m',
|
|
4
|
-
'responses-c4m-compatibility': 'responses:c4m',
|
|
5
|
-
'responses-fc': 'responses:fc',
|
|
6
|
-
'responses-fai': 'responses:fai'
|
|
7
|
-
};
|
|
8
|
-
export function resolveCompatibilityModuleTypes(config) {
|
|
9
|
-
if (!isRecord(config)) {
|
|
10
|
-
return ['compat:passthrough'];
|
|
11
|
-
}
|
|
12
|
-
const cc = config;
|
|
13
|
-
const profileSources = [];
|
|
14
|
-
if (Array.isArray(cc.profiles)) {
|
|
15
|
-
profileSources.push(cc.profiles);
|
|
16
|
-
}
|
|
17
|
-
const compatibility = isRecord(cc.compatibility) ? cc.compatibility : undefined;
|
|
18
|
-
if (compatibility?.profiles) {
|
|
19
|
-
profileSources.push(compatibility.profiles);
|
|
20
|
-
}
|
|
21
|
-
if (Array.isArray(cc.compatibilityProfiles)) {
|
|
22
|
-
profileSources.push(cc.compatibilityProfiles);
|
|
23
|
-
}
|
|
24
|
-
for (const source of profileSources) {
|
|
25
|
-
const arr = normalizeProfileArray(source);
|
|
26
|
-
if (arr.length > 0) {
|
|
27
|
-
return arr;
|
|
28
|
-
}
|
|
29
|
-
}
|
|
30
|
-
const moduleType = typeof cc.moduleType === 'string' && cc.moduleType.trim()
|
|
31
|
-
? normalizeProfileIdentifier(cc.moduleType.trim())
|
|
32
|
-
: undefined;
|
|
33
|
-
return [moduleType || 'compat:passthrough'];
|
|
34
|
-
}
|
|
35
|
-
function normalizeProfileArray(value) {
|
|
36
|
-
if (!value) {
|
|
37
|
-
return [];
|
|
38
|
-
}
|
|
39
|
-
const values = [];
|
|
40
|
-
if (Array.isArray(value)) {
|
|
41
|
-
for (const entry of value) {
|
|
42
|
-
if (typeof entry === 'string' && entry.trim()) {
|
|
43
|
-
const normalized = normalizeProfileIdentifier(entry);
|
|
44
|
-
if (normalized) {
|
|
45
|
-
values.push(normalized);
|
|
46
|
-
}
|
|
47
|
-
}
|
|
48
|
-
}
|
|
49
|
-
}
|
|
50
|
-
else if (typeof value === 'string' && value.trim()) {
|
|
51
|
-
for (const entry of value.split(/[,\s]+/)) {
|
|
52
|
-
if (!entry.trim()) {
|
|
53
|
-
continue;
|
|
54
|
-
}
|
|
55
|
-
const normalized = normalizeProfileIdentifier(entry);
|
|
56
|
-
if (normalized) {
|
|
57
|
-
values.push(normalized);
|
|
58
|
-
}
|
|
59
|
-
}
|
|
60
|
-
}
|
|
61
|
-
return Array.from(new Set(values));
|
|
62
|
-
}
|
|
63
|
-
function normalizeProfileIdentifier(value) {
|
|
64
|
-
if (!value) {
|
|
65
|
-
return undefined;
|
|
66
|
-
}
|
|
67
|
-
const trimmed = value.trim();
|
|
68
|
-
if (!trimmed) {
|
|
69
|
-
return undefined;
|
|
70
|
-
}
|
|
71
|
-
if (trimmed.includes(':')) {
|
|
72
|
-
return trimmed;
|
|
73
|
-
}
|
|
74
|
-
const alias = LEGACY_PROFILE_ALIASES[trimmed.toLowerCase()];
|
|
75
|
-
return alias || undefined;
|
|
76
|
-
}
|
|
77
|
-
//# sourceMappingURL=standard-compatibility-utils.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"standard-compatibility-utils.js","sourceRoot":"","sources":["../../../src/providers/compat/standard-compatibility-utils.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,31 +0,0 @@
|
|
|
1
|
-
import type { ModuleConfig, PipelineModule } from '../../modules/pipeline/interfaces/pipeline-interfaces.js';
|
|
2
|
-
import type { ModuleDependencies } from '../../modules/pipeline/types/module.types.js';
|
|
3
|
-
import type { SharedPipelineRequest, SharedPipelineResponse } from '../../modules/pipeline/types/shared-dtos.js';
|
|
4
|
-
import './index.js';
|
|
5
|
-
/**
|
|
6
|
-
* Standard V2 Compatibility module
|
|
7
|
-
* - Always present in pipeline
|
|
8
|
-
* - Loads and applies provider-specific compatibility submodule(s) ONLY when explicitly configured
|
|
9
|
-
* - No guessing, no fallback
|
|
10
|
-
*/
|
|
11
|
-
export declare class StandardCompatibility implements PipelineModule {
|
|
12
|
-
readonly id: string;
|
|
13
|
-
readonly type = "compatibility";
|
|
14
|
-
readonly config: ModuleConfig;
|
|
15
|
-
private readonly deps;
|
|
16
|
-
private manager;
|
|
17
|
-
private loadedModuleIds;
|
|
18
|
-
private isReady;
|
|
19
|
-
private injectedConfig;
|
|
20
|
-
constructor(config: ModuleConfig, dependencies: ModuleDependencies);
|
|
21
|
-
initialize(): Promise<void>;
|
|
22
|
-
setConfig(cfg: unknown): void;
|
|
23
|
-
getConfig(): unknown;
|
|
24
|
-
cleanup(): Promise<void>;
|
|
25
|
-
get isInitialized(): boolean;
|
|
26
|
-
private applyAll;
|
|
27
|
-
private applyAllResponse;
|
|
28
|
-
processIncoming(request: SharedPipelineRequest): Promise<SharedPipelineRequest>;
|
|
29
|
-
processOutgoing(response: SharedPipelineResponse): Promise<SharedPipelineResponse>;
|
|
30
|
-
private getActiveConfig;
|
|
31
|
-
}
|
|
@@ -1,118 +0,0 @@
|
|
|
1
|
-
import { CompatibilityManager } from './compatibility-manager.js';
|
|
2
|
-
import { resolveCompatibilityModuleTypes } from './standard-compatibility-utils.js';
|
|
3
|
-
// Ensure built-in compatibility submodules (legacy path) register with the factory
|
|
4
|
-
import './index.js';
|
|
5
|
-
const isRecord = (value) => typeof value === 'object' && value !== null;
|
|
6
|
-
/**
|
|
7
|
-
* Standard V2 Compatibility module
|
|
8
|
-
* - Always present in pipeline
|
|
9
|
-
* - Loads and applies provider-specific compatibility submodule(s) ONLY when explicitly configured
|
|
10
|
-
* - No guessing, no fallback
|
|
11
|
-
*/
|
|
12
|
-
export class StandardCompatibility {
|
|
13
|
-
id;
|
|
14
|
-
type = 'compatibility';
|
|
15
|
-
config;
|
|
16
|
-
deps;
|
|
17
|
-
manager = null;
|
|
18
|
-
loadedModuleIds = [];
|
|
19
|
-
isReady = false;
|
|
20
|
-
injectedConfig = null;
|
|
21
|
-
constructor(config, dependencies) {
|
|
22
|
-
this.id = `compatibility-${Date.now()}`;
|
|
23
|
-
this.config = config;
|
|
24
|
-
this.deps = dependencies;
|
|
25
|
-
}
|
|
26
|
-
async initialize() {
|
|
27
|
-
this.manager = new CompatibilityManager(this.deps);
|
|
28
|
-
await this.manager.initialize();
|
|
29
|
-
try {
|
|
30
|
-
const cc = this.getActiveConfig();
|
|
31
|
-
const moduleCfg = isRecord(cc.moduleConfig) ? cc.moduleConfig : {};
|
|
32
|
-
const providerType = typeof cc.providerType === 'string' && cc.providerType.trim()
|
|
33
|
-
? cc.providerType.trim()
|
|
34
|
-
: 'generic';
|
|
35
|
-
const moduleTypes = resolveCompatibilityModuleTypes(cc);
|
|
36
|
-
if (moduleTypes.length === 0) {
|
|
37
|
-
this.deps.logger?.logModule(this.id, 'compatibility-skipped', { reason: 'no-modules-declared' });
|
|
38
|
-
}
|
|
39
|
-
for (const moduleType of moduleTypes) {
|
|
40
|
-
const createCfg = {
|
|
41
|
-
id: `${moduleType}-${Date.now()}`,
|
|
42
|
-
type: moduleType,
|
|
43
|
-
providerType,
|
|
44
|
-
enabled: true,
|
|
45
|
-
priority: 1,
|
|
46
|
-
config: moduleCfg
|
|
47
|
-
};
|
|
48
|
-
const moduleId = await this.manager.createModule(createCfg);
|
|
49
|
-
this.loadedModuleIds.push(moduleId);
|
|
50
|
-
this.deps.logger?.logModule(this.id, 'module-loaded', { moduleId, moduleType, providerType });
|
|
51
|
-
}
|
|
52
|
-
this.isReady = true;
|
|
53
|
-
}
|
|
54
|
-
catch (error) {
|
|
55
|
-
this.deps.logger?.logError?.(error, { component: 'StandardCompatibility', stage: 'initialize' });
|
|
56
|
-
throw error;
|
|
57
|
-
}
|
|
58
|
-
}
|
|
59
|
-
// 新增:配置注入/读取(V2 调用,V1 不调用不影响)
|
|
60
|
-
setConfig(cfg) {
|
|
61
|
-
this.injectedConfig = isRecord(cfg) ? cfg : null;
|
|
62
|
-
}
|
|
63
|
-
getConfig() {
|
|
64
|
-
return this.getActiveConfig();
|
|
65
|
-
}
|
|
66
|
-
async cleanup() {
|
|
67
|
-
// No specific cleanup required; manager will be GC'ed.
|
|
68
|
-
this.isReady = false;
|
|
69
|
-
}
|
|
70
|
-
get isInitialized() { return this.isReady; }
|
|
71
|
-
async applyAll(request, requestId) {
|
|
72
|
-
if (!this.manager || this.loadedModuleIds.length === 0) {
|
|
73
|
-
return request;
|
|
74
|
-
}
|
|
75
|
-
let cur = request;
|
|
76
|
-
for (const mid of this.loadedModuleIds) {
|
|
77
|
-
cur = await this.manager.processRequest(mid, cur, undefined);
|
|
78
|
-
this.deps.logger?.logModule(this.id, 'compat-applied', { moduleId: mid, requestId });
|
|
79
|
-
}
|
|
80
|
-
return cur;
|
|
81
|
-
}
|
|
82
|
-
async applyAllResponse(response, requestId) {
|
|
83
|
-
if (!this.manager || this.loadedModuleIds.length === 0) {
|
|
84
|
-
return response;
|
|
85
|
-
}
|
|
86
|
-
let cur = response;
|
|
87
|
-
for (const mid of this.loadedModuleIds) {
|
|
88
|
-
cur = await this.manager.processResponse(mid, cur, undefined);
|
|
89
|
-
this.deps.logger?.logModule(this.id, 'compat-applied-response', { moduleId: mid, requestId });
|
|
90
|
-
}
|
|
91
|
-
return cur;
|
|
92
|
-
}
|
|
93
|
-
async processIncoming(request) {
|
|
94
|
-
if (!this.isReady) {
|
|
95
|
-
throw new Error('StandardCompatibility not initialized');
|
|
96
|
-
}
|
|
97
|
-
const reqId = request?.route?.requestId || 'unknown';
|
|
98
|
-
const inPayload = isRecord(request.data) ? request.data : {};
|
|
99
|
-
const outPayload = await this.applyAll(inPayload, reqId);
|
|
100
|
-
return { ...request, data: outPayload };
|
|
101
|
-
}
|
|
102
|
-
async processOutgoing(response) {
|
|
103
|
-
if (!this.isReady) {
|
|
104
|
-
throw new Error('StandardCompatibility not initialized');
|
|
105
|
-
}
|
|
106
|
-
const reqId = typeof response.metadata?.requestId === 'string' ? response.metadata.requestId : 'unknown';
|
|
107
|
-
const inPayload = isRecord(response.data) ? response.data : {};
|
|
108
|
-
const outPayload = await this.applyAllResponse(inPayload, reqId);
|
|
109
|
-
return { ...response, data: outPayload };
|
|
110
|
-
}
|
|
111
|
-
getActiveConfig() {
|
|
112
|
-
if (this.injectedConfig) {
|
|
113
|
-
return this.injectedConfig;
|
|
114
|
-
}
|
|
115
|
-
return isRecord(this.config.config) ? this.config.config : {};
|
|
116
|
-
}
|
|
117
|
-
}
|
|
118
|
-
//# sourceMappingURL=standard-compatibility.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"standard-compatibility.js","sourceRoot":"","sources":["../../../src/providers/compat/standard-compatibility.ts"],"names":[],"mappings":"AAOA,OAAO,EAAE,oBAAoB,EAAE,MAAM,4BAA4B,CAAC;AAClE,OAAO,EAAE,+BAA+B,EAAE,MAAM,mCAAmC,CAAC;AAEpF,mFAAmF;AACnF,OAAO,YAAY,CAAC;AAEpB,MAAM,QAAQ,GAAG,CAAC,KAAc,EAAoC,EAAE,CACpE,OAAO,KAAK,KAAK,QAAQ,IAAI,KAAK,KAAK,IAAI,CAAC;AAE9C;;;;;GAKG;AACH,MAAM,OAAO,qBAAqB;IAChB,EAAE,CAAS;IACX,IAAI,GAAG,eAAe,CAAC;IACvB,MAAM,CAAe;IACpB,IAAI,CAAqB;IAClC,OAAO,GAAgC,IAAI,CAAC;IAC5C,eAAe,GAAa,EAAE,CAAC;IAC/B,OAAO,GAAG,KAAK,CAAC;IAChB,cAAc,GAAmC,IAAI,CAAC;IAE9D,YAAY,MAAoB,EAAE,YAAgC;QAChE,IAAI,CAAC,EAAE,GAAG,iBAAiB,IAAI,CAAC,GAAG,EAAE,EAAE,CAAC;QACxC,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;QACrB,IAAI,CAAC,IAAI,GAAG,YAAY,CAAC;IAC3B,CAAC;IAEM,KAAK,CAAC,UAAU;QACrB,IAAI,CAAC,OAAO,GAAG,IAAI,oBAAoB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACnD,MAAM,IAAI,CAAC,OAAO,CAAC,UAAU,EAAE,CAAC;QAEhC,IAAI,CAAC;YACH,MAAM,EAAE,GAAG,IAAI,CAAC,eAAe,EAAE,CAAC;YAClC,MAAM,SAAS,GACb,QAAQ,CAAC,EAAE,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,YAAY,CAAC,CAAC,CAAC,EAAE,CAAC;YACnD,MAAM,YAAY,GAChB,OAAO,EAAE,CAAC,YAAY,KAAK,QAAQ,IAAI,EAAE,CAAC,YAAY,CAAC,IAAI,EAAE;gBAC3D,CAAC,CAAC,EAAE,CAAC,YAAY,CAAC,IAAI,EAAE;gBACxB,CAAC,CAAC,SAAS,CAAC;YAChB,MAAM,WAAW,GAAG,+BAA+B,CAAC,EAAE,CAAC,CAAC;YACxD,IAAI,WAAW,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;gBAC7B,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,SAAS,CAAC,IAAI,CAAC,EAAE,EAAE,uBAAuB,EAAE,EAAE,MAAM,EAAE,qBAAqB,EAAE,CAAC,CAAC;YACnG,CAAC;YACD,KAAK,MAAM,UAAU,IAAI,WAAW,EAAE,CAAC;gBACrC,MAAM,SAAS,GAA8B;oBAC3C,EAAE,EAAE,GAAG,UAAU,IAAI,IAAI,CAAC,GAAG,EAAE,EAAE;oBACjC,IAAI,EAAE,UAAU;oBAChB,YAAY;oBACZ,OAAO,EAAE,IAAI;oBACb,QAAQ,EAAE,CAAC;oBACX,MAAM,EAAE,SAAS;iBAClB,CAAC;gBACF,MAAM,QAAQ,GAAG,MAAM,IAAI,CAAC,OAAO,CAAC,YAAY,CAAC,SAAS,CAAC,CAAC;gBAC5D,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;gBACpC,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,SAAS,CAAC,IAAI,CAAC,EAAE,EAAE,eAAe,EAAE,EAAE,QAAQ,EAAE,UAAU,EAAE,YAAY,EAAE,CAAC,CAAC;YAChG,CAAC;YACD,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;QACtB,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,QAAQ,EAAE,CAAC,KAAc,EAAE,EAAE,SAAS,EAAE,uBAAuB,EAAE,KAAK,EAAE,YAAY,EAAE,CAAC,CAAC;YAC1G,MAAM,KAAK,CAAC;QACd,CAAC;IACH,CAAC;IAED,8BAA8B;IACvB,SAAS,CAAC,GAAY;QAC3B,IAAI,CAAC,cAAc,GAAG,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC;IACnD,CAAC;IAEM,SAAS;QACd,OAAO,IAAI,CAAC,eAAe,EAAE,CAAC;IAChC,CAAC;IAEM,KAAK,CAAC,OAAO;QAClB,uDAAuD;QACvD,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;IACvB,CAAC;IAED,IAAW,aAAa,KAAc,OAAO,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC;IAEpD,KAAK,CAAC,QAAQ,CAAC,OAAsB,EAAE,SAAiB;QAC9D,IAAI,CAAC,IAAI,CAAC,OAAO,IAAI,IAAI,CAAC,eAAe,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YACvD,OAAO,OAAO,CAAC;QACjB,CAAC;QACD,IAAI,GAAG,GAAG,OAAO,CAAC;QAClB,KAAK,MAAM,GAAG,IAAI,IAAI,CAAC,eAAe,EAAE,CAAC;YACvC,GAAG,GAAG,MAAM,IAAI,CAAC,OAAO,CAAC,cAAc,CAAC,GAAG,EAAE,GAAG,EAAE,SAAS,CAAC,CAAC;YAC7D,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,SAAS,CAAC,IAAI,CAAC,EAAE,EAAE,gBAAgB,EAAE,EAAE,QAAQ,EAAE,GAAG,EAAE,SAAS,EAAE,CAAC,CAAC;QACvF,CAAC;QACD,OAAO,GAAG,CAAC;IACb,CAAC;IAEO,KAAK,CAAC,gBAAgB,CAAC,QAAuB,EAAE,SAAiB;QACvE,IAAI,CAAC,IAAI,CAAC,OAAO,IAAI,IAAI,CAAC,eAAe,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YACvD,OAAO,QAAQ,CAAC;QAClB,CAAC;QACD,IAAI,GAAG,GAAG,QAAQ,CAAC;QACnB,KAAK,MAAM,GAAG,IAAI,IAAI,CAAC,eAAe,EAAE,CAAC;YACvC,GAAG,GAAG,MAAM,IAAI,CAAC,OAAO,CAAC,eAAe,CAAC,GAAG,EAAE,GAAG,EAAE,SAAS,CAAC,CAAC;YAC9D,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,SAAS,CAAC,IAAI,CAAC,EAAE,EAAE,yBAAyB,EAAE,EAAE,QAAQ,EAAE,GAAG,EAAE,SAAS,EAAE,CAAC,CAAC;QAChG,CAAC;QACD,OAAO,GAAG,CAAC;IACb,CAAC;IAEM,KAAK,CAAC,eAAe,CAAC,OAA8B;QACzD,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC;YAClB,MAAM,IAAI,KAAK,CAAC,uCAAuC,CAAC,CAAC;QAC3D,CAAC;QACD,MAAM,KAAK,GAAG,OAAO,EAAE,KAAK,EAAE,SAAS,IAAI,SAAS,CAAC;QACrD,MAAM,SAAS,GAAG,QAAQ,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC;QAC7D,MAAM,UAAU,GAAG,MAAM,IAAI,CAAC,QAAQ,CAAC,SAAS,EAAE,KAAK,CAAC,CAAC;QACzD,OAAO,EAAE,GAAG,OAAO,EAAE,IAAI,EAAE,UAAU,EAAE,CAAC;IAC1C,CAAC;IAEM,KAAK,CAAC,eAAe,CAAC,QAAgC;QAC3D,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC;YAClB,MAAM,IAAI,KAAK,CAAC,uCAAuC,CAAC,CAAC;QAC3D,CAAC;QACD,MAAM,KAAK,GAAG,OAAO,QAAQ,CAAC,QAAQ,EAAE,SAAS,KAAK,QAAQ,CAAC,CAAC,CAAC,QAAQ,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC;QACzG,MAAM,SAAS,GAAG,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC;QAC/D,MAAM,UAAU,GAAG,MAAM,IAAI,CAAC,gBAAgB,CAAC,SAAS,EAAE,KAAK,CAAC,CAAC;QACjE,OAAO,EAAE,GAAG,QAAQ,EAAE,IAAI,EAAE,UAAU,EAAE,CAAC;IAC3C,CAAC;IAEO,eAAe;QACrB,IAAI,IAAI,CAAC,cAAc,EAAE,CAAC;YACxB,OAAO,IAAI,CAAC,cAAc,CAAC;QAC7B,CAAC;QACD,OAAO,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC;IAChE,CAAC;CACF"}
|
|
@@ -1,62 +0,0 @@
|
|
|
1
|
-
import fsp from 'fs/promises';
|
|
2
|
-
import os from 'os';
|
|
3
|
-
import path from 'path';
|
|
4
|
-
import { writeSnapshotViaHooks } from '../../../modules/llmswitch/bridge.js';
|
|
5
|
-
function mapEndpointToFolder(entryEndpoint) {
|
|
6
|
-
const ep = String(entryEndpoint || '').toLowerCase();
|
|
7
|
-
if (ep.includes('/v1/responses')) {
|
|
8
|
-
return 'openai-responses';
|
|
9
|
-
}
|
|
10
|
-
if (ep.includes('/v1/messages') || ep.includes('/anthropic')) {
|
|
11
|
-
return 'anthropic-messages';
|
|
12
|
-
}
|
|
13
|
-
// default to Chat route when unknown
|
|
14
|
-
return 'openai-chat';
|
|
15
|
-
}
|
|
16
|
-
async function ensureDir(dir) {
|
|
17
|
-
try {
|
|
18
|
-
await fsp.mkdir(dir, { recursive: true });
|
|
19
|
-
}
|
|
20
|
-
catch {
|
|
21
|
-
// ignore
|
|
22
|
-
}
|
|
23
|
-
}
|
|
24
|
-
export async function writeCompatSnapshot(options) {
|
|
25
|
-
try {
|
|
26
|
-
// 统一通过 llmswitch-core hooks 快照通道写入(优先),保持与核心路径一致
|
|
27
|
-
try {
|
|
28
|
-
const endpoint = options.entryEndpoint || '/v1/chat/completions';
|
|
29
|
-
await writeSnapshotViaHooks('compatibility', {
|
|
30
|
-
endpoint,
|
|
31
|
-
stage: String(options.phase),
|
|
32
|
-
requestId: options.requestId,
|
|
33
|
-
data: options.data,
|
|
34
|
-
verbosity: 'verbose'
|
|
35
|
-
});
|
|
36
|
-
return;
|
|
37
|
-
}
|
|
38
|
-
catch {
|
|
39
|
-
// 回退到本地写盘(非首选)
|
|
40
|
-
const base = path.join(os.homedir(), '.routecodex', 'codex-samples');
|
|
41
|
-
const folder = mapEndpointToFolder(options.entryEndpoint);
|
|
42
|
-
const dir = path.join(base, folder);
|
|
43
|
-
await ensureDir(dir);
|
|
44
|
-
const file = path.join(dir, `${options.requestId}_${options.phase}.json`);
|
|
45
|
-
const meta = {
|
|
46
|
-
stage: options.phase,
|
|
47
|
-
version: String(process.env.ROUTECODEX_VERSION || 'dev'),
|
|
48
|
-
buildTime: String(process.env.ROUTECODEX_BUILD_TIME || new Date().toISOString())
|
|
49
|
-
};
|
|
50
|
-
const wrapped = {
|
|
51
|
-
meta,
|
|
52
|
-
data: options.data
|
|
53
|
-
};
|
|
54
|
-
const payload = JSON.stringify(wrapped, null, 2);
|
|
55
|
-
await fsp.writeFile(file, payload, 'utf-8');
|
|
56
|
-
}
|
|
57
|
-
}
|
|
58
|
-
catch {
|
|
59
|
-
// snapshot is non-blocking; ignore any fs errors
|
|
60
|
-
}
|
|
61
|
-
}
|
|
62
|
-
//# sourceMappingURL=snapshot-writer.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"snapshot-writer.js","sourceRoot":"","sources":["../../../../src/providers/compat/utils/snapshot-writer.ts"],"names":[],"mappings":"AAAA,OAAO,GAAG,MAAM,aAAa,CAAC;AAC9B,OAAO,EAAE,MAAM,IAAI,CAAC;AACpB,OAAO,IAAI,MAAM,MAAM,CAAC;AACxB,OAAO,EAAE,qBAAqB,EAAE,MAAM,sCAAsC,CAAC;AAI7E,SAAS,mBAAmB,CAAC,aAAsB;IACjD,MAAM,EAAE,GAAG,MAAM,CAAC,aAAa,IAAI,EAAE,CAAC,CAAC,WAAW,EAAE,CAAC;IACrD,IAAI,EAAE,CAAC,QAAQ,CAAC,eAAe,CAAC,EAAE,CAAC;QACjC,OAAO,kBAAkB,CAAC;IAC5B,CAAC;IACD,IAAI,EAAE,CAAC,QAAQ,CAAC,cAAc,CAAC,IAAI,EAAE,CAAC,QAAQ,CAAC,YAAY,CAAC,EAAE,CAAC;QAC7D,OAAO,oBAAoB,CAAC;IAC9B,CAAC;IACD,qCAAqC;IACrC,OAAO,aAAa,CAAC;AACvB,CAAC;AAED,KAAK,UAAU,SAAS,CAAC,GAAW;IAClC,IAAI,CAAC;QACH,MAAM,GAAG,CAAC,KAAK,CAAC,GAAG,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAC;IAC5C,CAAC;IAAC,MAAM,CAAC;QACP,SAAS;IACX,CAAC;AACH,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,mBAAmB,CAAC,OAKzC;IACC,IAAI,CAAC;QACH,iDAAiD;QACjD,IAAI,CAAC;YACH,MAAM,QAAQ,GAAG,OAAO,CAAC,aAAa,IAAI,sBAAsB,CAAC;YACjE,MAAM,qBAAqB,CAAC,eAAe,EAAE;gBAC3C,QAAQ;gBACR,KAAK,EAAE,MAAM,CAAC,OAAO,CAAC,KAAK,CAAC;gBAC5B,SAAS,EAAE,OAAO,CAAC,SAAS;gBAC5B,IAAI,EAAE,OAAO,CAAC,IAAI;gBAClB,SAAS,EAAE,SAAS;aACrB,CAAC,CAAC;YACH,OAAO;QACT,CAAC;QAAC,MAAM,CAAC;YACP,eAAe;YACf,MAAM,IAAI,GAAG,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,OAAO,EAAE,EAAE,aAAa,EAAE,eAAe,CAAC,CAAC;YACrE,MAAM,MAAM,GAAG,mBAAmB,CAAC,OAAO,CAAC,aAAa,CAAC,CAAC;YAC1D,MAAM,GAAG,GAAG,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE,MAAM,CAAC,CAAC;YACpC,MAAM,SAAS,CAAC,GAAG,CAAC,CAAC;YACrB,MAAM,IAAI,GAAG,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,GAAG,OAAO,CAAC,SAAS,IAAI,OAAO,CAAC,KAAK,OAAO,CAAC,CAAC;YAC1E,MAAM,IAAI,GAAG;gBACX,KAAK,EAAE,OAAO,CAAC,KAAK;gBACpB,OAAO,EAAE,MAAM,CAAC,OAAO,CAAC,GAAG,CAAC,kBAAkB,IAAI,KAAK,CAAC;gBACxD,SAAS,EAAE,MAAM,CAAC,OAAO,CAAC,GAAG,CAAC,qBAAqB,IAAI,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE,CAAC;aACjF,CAAC;YACF,MAAM,OAAO,GAAG;gBACd,IAAI;gBACJ,IAAI,EAAE,OAAO,CAAC,IAAI;aACnB,CAAC;YACF,MAAM,OAAO,GAAG,IAAI,CAAC,SAAS,CAAC,OAAO,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC;YACjD,MAAM,GAAG,CAAC,SAAS,CAAC,IAAI,EAAE,OAAO,EAAE,OAAO,CAAC,CAAC;QAC9C,CAAC;IACH,CAAC;IAAC,MAAM,CAAC;QACP,iDAAiD;IACnD,CAAC;AACH,CAAC"}
|
|
@@ -1,47 +0,0 @@
|
|
|
1
|
-
#!/usr/bin/env node
|
|
2
|
-
import fs from 'node:fs/promises';
|
|
3
|
-
import os from 'node:os';
|
|
4
|
-
import path from 'node:path';
|
|
5
|
-
import { pathToFileURL } from 'node:url';
|
|
6
|
-
|
|
7
|
-
async function main() {
|
|
8
|
-
const rawPath = process.argv[2] || path.join(os.homedir(), '.routecodex', 'codex-samples', 'openai-chat', 'req_1762264740299_ifnozpv3l_raw-request.json');
|
|
9
|
-
const outDir = process.argv[3] || path.join(process.cwd(), 'test-results', 'glm-compat');
|
|
10
|
-
await fs.mkdir(outDir, { recursive: true });
|
|
11
|
-
const rawTxt = await fs.readFile(rawPath, 'utf-8');
|
|
12
|
-
const raw = JSON.parse(rawTxt);
|
|
13
|
-
const body = raw.body || raw;
|
|
14
|
-
|
|
15
|
-
// Step1: convert to OpenAI-OpenAI via codec (so we get normalized chat shape)
|
|
16
|
-
const openaiCodecUrl = pathToFileURL(path.join(process.cwd(), 'sharedmodule', 'llmswitch-core', 'dist', 'v2', 'conversion', 'codecs', 'openai-openai-codec.js')).href;
|
|
17
|
-
const { OpenAIOpenAIConversionCodec } = await import(openaiCodecUrl);
|
|
18
|
-
const codec = new OpenAIOpenAIConversionCodec({});
|
|
19
|
-
const profile = { outgoingProtocol: 'openai-chat' };
|
|
20
|
-
const ctx = { requestId: 'check_glm_' + Date.now(), endpoint: '/v1/chat/completions', entryEndpoint: '/v1/chat/completions', metadata: {} };
|
|
21
|
-
const openaiReq = await codec.convertRequest(body, profile, ctx);
|
|
22
|
-
|
|
23
|
-
// Step2: run GLM compatibility incoming path on the normalized request
|
|
24
|
-
const glmCompatUrl = pathToFileURL(path.join(process.cwd(), 'dist', 'modules', 'pipeline', 'modules', 'compatibility', 'glm', 'glm-compatibility.js')).href;
|
|
25
|
-
const { GLMCompatibility } = await import(glmCompatUrl);
|
|
26
|
-
const compat = new GLMCompatibility({ logger: { logModule: ()=>{}, logError: ()=>{} } });
|
|
27
|
-
await compat.initialize();
|
|
28
|
-
const out = await compat.processIncoming(openaiReq, { requestId: ctx.requestId, entryEndpoint: '/v1/chat/completions' });
|
|
29
|
-
|
|
30
|
-
const outFile = path.join(outDir, 'glm_compat_request.json');
|
|
31
|
-
await fs.writeFile(outFile, JSON.stringify(out, null, 2), 'utf-8');
|
|
32
|
-
console.log('GLM compat request written:', outFile);
|
|
33
|
-
|
|
34
|
-
// Quick assertions printed to stdout
|
|
35
|
-
const tools = Array.isArray(out.tools) ? out.tools : [];
|
|
36
|
-
const shell = tools.find(t => t?.function?.name === 'shell');
|
|
37
|
-
const cmdSchema = shell?.function?.parameters?.properties?.command;
|
|
38
|
-
console.log('[schema] shell.command oneOf:', !!(cmdSchema && cmdSchema.oneOf));
|
|
39
|
-
console.log('[schema] shell.command.type:', cmdSchema?.type);
|
|
40
|
-
const msgs = Array.isArray(out.messages) ? out.messages : [];
|
|
41
|
-
const toolCalls = msgs.filter(m => Array.isArray(m?.tool_calls)).flatMap(m => m.tool_calls);
|
|
42
|
-
const argTypeSet = new Set(toolCalls.map(tc => typeof tc?.function?.arguments));
|
|
43
|
-
console.log('[messages] function.arguments types:', Array.from(argTypeSet).join(','));
|
|
44
|
-
}
|
|
45
|
-
|
|
46
|
-
main().catch(err => { console.error(err); process.exit(1); });
|
|
47
|
-
|