@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
|
@@ -0,0 +1,224 @@
|
|
|
1
|
+
#!/usr/bin/env node
|
|
2
|
+
import path from 'node:path';
|
|
3
|
+
import { fileURLToPath, pathToFileURL } from 'node:url';
|
|
4
|
+
|
|
5
|
+
const ROOT = path.join(path.dirname(fileURLToPath(import.meta.url)), '..');
|
|
6
|
+
|
|
7
|
+
async function loadModule(relPath) {
|
|
8
|
+
const modulePath = pathToFileURL(path.join(ROOT, relPath)).href;
|
|
9
|
+
return import(modulePath);
|
|
10
|
+
}
|
|
11
|
+
|
|
12
|
+
class RecordingHttpClient {
|
|
13
|
+
constructor() {
|
|
14
|
+
this.lastHeaders = undefined;
|
|
15
|
+
}
|
|
16
|
+
|
|
17
|
+
async post(endpoint, _data, headers) {
|
|
18
|
+
this.lastHeaders = headers ? { ...headers } : {};
|
|
19
|
+
return {
|
|
20
|
+
data: { ok: true },
|
|
21
|
+
status: 200,
|
|
22
|
+
statusText: 'OK',
|
|
23
|
+
headers: {},
|
|
24
|
+
url: endpoint
|
|
25
|
+
};
|
|
26
|
+
}
|
|
27
|
+
|
|
28
|
+
async postStream() {
|
|
29
|
+
throw new Error('RecordingHttpClient.postStream not implemented');
|
|
30
|
+
}
|
|
31
|
+
|
|
32
|
+
async get(endpoint, headers) {
|
|
33
|
+
return {
|
|
34
|
+
data: {},
|
|
35
|
+
status: 200,
|
|
36
|
+
statusText: 'OK',
|
|
37
|
+
headers: headers ?? {},
|
|
38
|
+
url: endpoint
|
|
39
|
+
};
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
async function main() {
|
|
44
|
+
const deps = {
|
|
45
|
+
errorHandlingCenter: {
|
|
46
|
+
handleError: async () => {},
|
|
47
|
+
createContext: () => ({}),
|
|
48
|
+
getStatistics: () => ({})
|
|
49
|
+
},
|
|
50
|
+
debugCenter: {
|
|
51
|
+
logDebug: () => {},
|
|
52
|
+
logError: () => {},
|
|
53
|
+
logModule: () => {},
|
|
54
|
+
processDebugEvent: () => {},
|
|
55
|
+
getLogs: () => []
|
|
56
|
+
},
|
|
57
|
+
logger: {
|
|
58
|
+
logModule: () => {},
|
|
59
|
+
logError: () => {},
|
|
60
|
+
logDebug: () => {},
|
|
61
|
+
logPipeline: () => {},
|
|
62
|
+
logRequest: () => {},
|
|
63
|
+
logResponse: () => {},
|
|
64
|
+
logTransformation: () => {},
|
|
65
|
+
logProviderRequest: () => {},
|
|
66
|
+
getRequestLogs: () => ({ general: [], transformations: [], provider: [] }),
|
|
67
|
+
getPipelineLogs: () => ({ general: [], transformations: [], provider: [] }),
|
|
68
|
+
getRecentLogs: () => [],
|
|
69
|
+
getTransformationLogs: () => [],
|
|
70
|
+
getProviderLogs: () => [],
|
|
71
|
+
getStatistics: () => ({
|
|
72
|
+
totalLogs: 0,
|
|
73
|
+
logsByLevel: {},
|
|
74
|
+
logsByCategory: {},
|
|
75
|
+
logsByPipeline: {},
|
|
76
|
+
transformationCount: 0,
|
|
77
|
+
providerRequestCount: 0
|
|
78
|
+
}),
|
|
79
|
+
clearLogs: () => {},
|
|
80
|
+
exportLogs: () => [],
|
|
81
|
+
log: () => {}
|
|
82
|
+
}
|
|
83
|
+
};
|
|
84
|
+
|
|
85
|
+
const { HttpTransportProvider } = await loadModule('dist/providers/core/runtime/http-transport-provider.js');
|
|
86
|
+
const { attachProviderRuntimeMetadata } = await loadModule('dist/providers/core/runtime/provider-runtime-metadata.js');
|
|
87
|
+
|
|
88
|
+
class TestProvider extends HttpTransportProvider {
|
|
89
|
+
createHttpClient() {
|
|
90
|
+
this.client = new RecordingHttpClient();
|
|
91
|
+
this.httpClient = this.client;
|
|
92
|
+
}
|
|
93
|
+
|
|
94
|
+
wantsUpstreamSse() {
|
|
95
|
+
return false;
|
|
96
|
+
}
|
|
97
|
+
}
|
|
98
|
+
|
|
99
|
+
const providerConfig = {
|
|
100
|
+
id: 'verify-http-provider',
|
|
101
|
+
type: 'responses-http-provider',
|
|
102
|
+
config: {
|
|
103
|
+
providerType: 'responses',
|
|
104
|
+
providerId: 'crs.key1',
|
|
105
|
+
auth: { type: 'apikey', apiKey: 'test-key-1234567890' },
|
|
106
|
+
overrides: {
|
|
107
|
+
baseUrl: 'https://example.invalid',
|
|
108
|
+
endpoint: '/responses',
|
|
109
|
+
defaultModel: 'gpt-5.1-codex'
|
|
110
|
+
}
|
|
111
|
+
}
|
|
112
|
+
};
|
|
113
|
+
|
|
114
|
+
const provider = new TestProvider(providerConfig, deps);
|
|
115
|
+
await provider.initialize();
|
|
116
|
+
|
|
117
|
+
const inboundHeaders = {
|
|
118
|
+
accept: 'text/event-stream',
|
|
119
|
+
conversation_id: 'verify-conv',
|
|
120
|
+
session_id: 'verify-sess'
|
|
121
|
+
};
|
|
122
|
+
|
|
123
|
+
const providerRequest = {
|
|
124
|
+
metadata: {
|
|
125
|
+
clientHeaders: inboundHeaders,
|
|
126
|
+
stream: true
|
|
127
|
+
},
|
|
128
|
+
data: {
|
|
129
|
+
model: 'gpt-5.1-codex',
|
|
130
|
+
input: []
|
|
131
|
+
}
|
|
132
|
+
};
|
|
133
|
+
|
|
134
|
+
attachProviderRuntimeMetadata(providerRequest, {
|
|
135
|
+
requestId: 'verify-req',
|
|
136
|
+
providerId: 'crs.key1',
|
|
137
|
+
providerKey: 'crs.key1.gpt-5.1-codex',
|
|
138
|
+
providerType: 'responses',
|
|
139
|
+
providerProtocol: 'openai-responses',
|
|
140
|
+
routeName: 'verify',
|
|
141
|
+
metadata: {
|
|
142
|
+
entryEndpoint: '/v1/responses',
|
|
143
|
+
clientHeaders: inboundHeaders
|
|
144
|
+
},
|
|
145
|
+
target: {
|
|
146
|
+
providerKey: 'crs.key1.gpt-5.1-codex',
|
|
147
|
+
providerType: 'responses',
|
|
148
|
+
compatibilityProfile: undefined,
|
|
149
|
+
runtimeKey: 'crs.key1',
|
|
150
|
+
modelId: 'gpt-5.1-codex'
|
|
151
|
+
}
|
|
152
|
+
});
|
|
153
|
+
|
|
154
|
+
const response = await provider.processIncoming(providerRequest);
|
|
155
|
+
if (!response) {
|
|
156
|
+
throw new Error('provider did not return a response during verification');
|
|
157
|
+
}
|
|
158
|
+
|
|
159
|
+
const headers = provider.client.lastHeaders || {};
|
|
160
|
+
if (headers['conversation_id'] !== 'verify-conv' || headers['session_id'] !== 'verify-sess') {
|
|
161
|
+
throw new Error(
|
|
162
|
+
`client headers not forwarded. observed=${JSON.stringify(headers)} expected conversation_id/session_id`
|
|
163
|
+
);
|
|
164
|
+
}
|
|
165
|
+
|
|
166
|
+
console.log('[verify-client-headers] ✅ inbound conversation/session headers forwarded');
|
|
167
|
+
|
|
168
|
+
const originalUaMode = process.env.ROUTECODEX_UA_MODE;
|
|
169
|
+
process.env.ROUTECODEX_UA_MODE = 'codex';
|
|
170
|
+
const codexRequest = {
|
|
171
|
+
metadata: {
|
|
172
|
+
clientHeaders: {},
|
|
173
|
+
stream: true
|
|
174
|
+
},
|
|
175
|
+
data: {
|
|
176
|
+
model: 'gpt-5.1-codex',
|
|
177
|
+
input: []
|
|
178
|
+
}
|
|
179
|
+
};
|
|
180
|
+
|
|
181
|
+
attachProviderRuntimeMetadata(codexRequest, {
|
|
182
|
+
requestId: 'verify-codex',
|
|
183
|
+
providerId: 'crs.key1',
|
|
184
|
+
providerKey: 'crs.key1.gpt-5.1-codex',
|
|
185
|
+
providerType: 'responses',
|
|
186
|
+
providerProtocol: 'openai-responses',
|
|
187
|
+
routeName: 'verify',
|
|
188
|
+
metadata: {
|
|
189
|
+
entryEndpoint: '/v1/chat/completions',
|
|
190
|
+
clientHeaders: {}
|
|
191
|
+
},
|
|
192
|
+
target: {
|
|
193
|
+
providerKey: 'crs.key1.gpt-5.1-codex',
|
|
194
|
+
providerType: 'responses',
|
|
195
|
+
compatibilityProfile: undefined,
|
|
196
|
+
runtimeKey: 'crs.key1',
|
|
197
|
+
modelId: 'gpt-5.1-codex'
|
|
198
|
+
}
|
|
199
|
+
});
|
|
200
|
+
|
|
201
|
+
await provider.processIncoming(codexRequest);
|
|
202
|
+
const codexHeaders = provider.client.lastHeaders || {};
|
|
203
|
+
const codexSession = codexHeaders['session_id'];
|
|
204
|
+
const codexConv = codexHeaders['conversation_id'];
|
|
205
|
+
if (!codexSession?.startsWith('codex_cli_session_') || !codexConv?.startsWith('codex_cli_conversation_')) {
|
|
206
|
+
throw new Error(
|
|
207
|
+
`codex headers not injected. observed=${JSON.stringify(
|
|
208
|
+
{ session_id: codexSession, conversation_id: codexConv }
|
|
209
|
+
)}`
|
|
210
|
+
);
|
|
211
|
+
}
|
|
212
|
+
|
|
213
|
+
console.log('[verify-client-headers] ✅ codex session/conversation headers generated');
|
|
214
|
+
if (originalUaMode === undefined) {
|
|
215
|
+
delete process.env.ROUTECODEX_UA_MODE;
|
|
216
|
+
} else {
|
|
217
|
+
process.env.ROUTECODEX_UA_MODE = originalUaMode;
|
|
218
|
+
}
|
|
219
|
+
}
|
|
220
|
+
|
|
221
|
+
main().catch((error) => {
|
|
222
|
+
console.error('[verify-client-headers] ❌ failed:', error?.message || error);
|
|
223
|
+
process.exit(1);
|
|
224
|
+
});
|
|
@@ -1,27 +0,0 @@
|
|
|
1
|
-
import type { UnknownObject } from '../../modules/pipeline/types/common-types.js';
|
|
2
|
-
import type { ModuleDependencies } from '../../modules/pipeline/types/module.types.js';
|
|
3
|
-
import type { CompatibilityContext } from './compatibility-interface.js';
|
|
4
|
-
import { UniversalShapeFilter } from './filters/universal-shape-filter.js';
|
|
5
|
-
import { ResponseBlacklistSanitizer } from './filters/response-blacklist-sanitizer.js';
|
|
6
|
-
export interface BaseCompatibilityOptions {
|
|
7
|
-
providerType: string;
|
|
8
|
-
shapeFilterConfigPath: string;
|
|
9
|
-
mapper?: {
|
|
10
|
-
mapIncoming?: (request: UnknownObject) => Promise<UnknownObject> | UnknownObject;
|
|
11
|
-
mapOutgoing?: (response: UnknownObject) => Promise<UnknownObject> | UnknownObject;
|
|
12
|
-
};
|
|
13
|
-
validator?: {
|
|
14
|
-
request?: (request: UnknownObject) => Promise<UnknownObject> | UnknownObject;
|
|
15
|
-
response?: (response: UnknownObject) => Promise<UnknownObject> | UnknownObject;
|
|
16
|
-
};
|
|
17
|
-
}
|
|
18
|
-
export declare class BaseCompatibility {
|
|
19
|
-
protected readonly deps: ModuleDependencies;
|
|
20
|
-
protected readonly opts: BaseCompatibilityOptions;
|
|
21
|
-
protected filter: UniversalShapeFilter;
|
|
22
|
-
protected respBlacklist: ResponseBlacklistSanitizer;
|
|
23
|
-
constructor(dependencies: ModuleDependencies, options: BaseCompatibilityOptions);
|
|
24
|
-
initialize(): Promise<void>;
|
|
25
|
-
processIncoming(input: UnknownObject, ctx: CompatibilityContext): Promise<UnknownObject>;
|
|
26
|
-
processOutgoing(input: UnknownObject, ctx: CompatibilityContext): Promise<UnknownObject>;
|
|
27
|
-
}
|
|
@@ -1,143 +0,0 @@
|
|
|
1
|
-
import { UniversalShapeFilter } from './filters/universal-shape-filter.js';
|
|
2
|
-
import { ResponseBlacklistSanitizer } from './filters/response-blacklist-sanitizer.js';
|
|
3
|
-
import * as path from 'path';
|
|
4
|
-
function isRecord(value) {
|
|
5
|
-
return typeof value === 'object' && value !== null && !Array.isArray(value);
|
|
6
|
-
}
|
|
7
|
-
function isResponseEnvelope(value) {
|
|
8
|
-
return ('data' in value) && ('status' in value || 'headers' in value);
|
|
9
|
-
}
|
|
10
|
-
function unwrapResponseEnvelope(value) {
|
|
11
|
-
if (isResponseEnvelope(value) && isRecord(value.data)) {
|
|
12
|
-
return value.data;
|
|
13
|
-
}
|
|
14
|
-
return value;
|
|
15
|
-
}
|
|
16
|
-
export class BaseCompatibility {
|
|
17
|
-
deps;
|
|
18
|
-
opts;
|
|
19
|
-
filter;
|
|
20
|
-
respBlacklist;
|
|
21
|
-
constructor(dependencies, options) {
|
|
22
|
-
this.deps = dependencies;
|
|
23
|
-
this.opts = options;
|
|
24
|
-
this.filter = new UniversalShapeFilter({ configPath: options.shapeFilterConfigPath });
|
|
25
|
-
const respCfgPath = (() => {
|
|
26
|
-
try {
|
|
27
|
-
const dir = path.dirname(options.shapeFilterConfigPath || '');
|
|
28
|
-
return path.join(dir, 'response-blacklist.json');
|
|
29
|
-
}
|
|
30
|
-
catch {
|
|
31
|
-
return '';
|
|
32
|
-
}
|
|
33
|
-
})();
|
|
34
|
-
this.respBlacklist = new ResponseBlacklistSanitizer({ configPath: respCfgPath });
|
|
35
|
-
}
|
|
36
|
-
async initialize() {
|
|
37
|
-
await this.filter.initialize();
|
|
38
|
-
await this.respBlacklist.initialize();
|
|
39
|
-
}
|
|
40
|
-
async processIncoming(input, ctx) {
|
|
41
|
-
let req = input;
|
|
42
|
-
// compat-pre snapshot (non-blocking)
|
|
43
|
-
try {
|
|
44
|
-
const { writeCompatSnapshot } = await import('./utils/snapshot-writer.js');
|
|
45
|
-
await writeCompatSnapshot({
|
|
46
|
-
phase: 'compat-pre',
|
|
47
|
-
requestId: ctx.requestId,
|
|
48
|
-
data: req,
|
|
49
|
-
entryEndpoint: ctx.entryEndpoint
|
|
50
|
-
});
|
|
51
|
-
}
|
|
52
|
-
catch { /* ignore */ }
|
|
53
|
-
// Standard sequence: filter → mapping → filter
|
|
54
|
-
try {
|
|
55
|
-
req = await this.filter.applyRequestFilter(req);
|
|
56
|
-
}
|
|
57
|
-
catch { /* ignore */ }
|
|
58
|
-
if (this.opts.validator?.request) {
|
|
59
|
-
try {
|
|
60
|
-
req = await this.opts.validator.request(req);
|
|
61
|
-
}
|
|
62
|
-
catch { /* ignore */ }
|
|
63
|
-
}
|
|
64
|
-
if (this.opts.mapper?.mapIncoming) {
|
|
65
|
-
try {
|
|
66
|
-
req = await this.opts.mapper.mapIncoming(req);
|
|
67
|
-
}
|
|
68
|
-
catch { /* ignore */ }
|
|
69
|
-
}
|
|
70
|
-
try {
|
|
71
|
-
req = await this.filter.applyRequestFilter(req);
|
|
72
|
-
}
|
|
73
|
-
catch { /* ignore */ }
|
|
74
|
-
// compat-post snapshot (non-blocking)
|
|
75
|
-
try {
|
|
76
|
-
const { writeCompatSnapshot } = await import('./utils/snapshot-writer.js');
|
|
77
|
-
await writeCompatSnapshot({
|
|
78
|
-
phase: 'compat-post',
|
|
79
|
-
requestId: ctx.requestId,
|
|
80
|
-
data: req,
|
|
81
|
-
entryEndpoint: ctx.entryEndpoint
|
|
82
|
-
});
|
|
83
|
-
}
|
|
84
|
-
catch { /* ignore */ }
|
|
85
|
-
return req;
|
|
86
|
-
}
|
|
87
|
-
async processOutgoing(input, ctx) {
|
|
88
|
-
let res = unwrapResponseEnvelope(input);
|
|
89
|
-
// compat-pre snapshot for response (non-blocking)
|
|
90
|
-
try {
|
|
91
|
-
const { writeCompatSnapshot } = await import('./utils/snapshot-writer.js');
|
|
92
|
-
await writeCompatSnapshot({
|
|
93
|
-
phase: 'compat-pre',
|
|
94
|
-
requestId: ctx.requestId,
|
|
95
|
-
data: res,
|
|
96
|
-
entryEndpoint: ctx.entryEndpoint
|
|
97
|
-
});
|
|
98
|
-
}
|
|
99
|
-
catch { /* ignore */ }
|
|
100
|
-
// Standard sequence: validate(entry) → filter → mapping → filter
|
|
101
|
-
// Minimal blacklist only on non-stream path (exclude /v1/responses)
|
|
102
|
-
try {
|
|
103
|
-
const entry = String(ctx.entryEndpoint ?? '').toLowerCase();
|
|
104
|
-
if (entry !== '/v1/responses') {
|
|
105
|
-
res = await this.respBlacklist.apply(res);
|
|
106
|
-
}
|
|
107
|
-
}
|
|
108
|
-
catch { /* ignore blacklist errors */ }
|
|
109
|
-
if (this.opts.validator?.response) {
|
|
110
|
-
try {
|
|
111
|
-
res = await this.opts.validator.response(res);
|
|
112
|
-
}
|
|
113
|
-
catch { /* ignore */ }
|
|
114
|
-
}
|
|
115
|
-
try {
|
|
116
|
-
res = await this.filter.applyResponseFilter(res, ctx);
|
|
117
|
-
}
|
|
118
|
-
catch { /* ignore */ }
|
|
119
|
-
if (this.opts.mapper?.mapOutgoing) {
|
|
120
|
-
try {
|
|
121
|
-
res = await this.opts.mapper.mapOutgoing(res);
|
|
122
|
-
}
|
|
123
|
-
catch { /* ignore */ }
|
|
124
|
-
}
|
|
125
|
-
try {
|
|
126
|
-
res = await this.filter.applyResponseFilter(res, ctx);
|
|
127
|
-
}
|
|
128
|
-
catch { /* ignore */ }
|
|
129
|
-
// compat-post snapshot for response (non-blocking)
|
|
130
|
-
try {
|
|
131
|
-
const { writeCompatSnapshot } = await import('./utils/snapshot-writer.js');
|
|
132
|
-
await writeCompatSnapshot({
|
|
133
|
-
phase: 'compat-post',
|
|
134
|
-
requestId: ctx.requestId,
|
|
135
|
-
data: res,
|
|
136
|
-
entryEndpoint: ctx.entryEndpoint
|
|
137
|
-
});
|
|
138
|
-
}
|
|
139
|
-
catch { /* ignore */ }
|
|
140
|
-
return res;
|
|
141
|
-
}
|
|
142
|
-
}
|
|
143
|
-
//# sourceMappingURL=base-compatibility.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"base-compatibility.js","sourceRoot":"","sources":["../../../src/providers/compat/base-compatibility.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,4 +0,0 @@
|
|
|
1
|
-
import type { ModuleDependencies } from '../../modules/pipeline/types/module.types.js';
|
|
2
|
-
export declare function resolveCompatSearchDirs(): string[];
|
|
3
|
-
export declare function loadCompatibilityModulesFromDirs(dirs: string[], logger?: ModuleDependencies['logger']): Promise<void>;
|
|
4
|
-
export declare function registerCompatibilityModuleForTest(exported: unknown): Promise<void>;
|
|
@@ -1,85 +0,0 @@
|
|
|
1
|
-
import fs from 'node:fs/promises';
|
|
2
|
-
import path from 'node:path';
|
|
3
|
-
import os from 'node:os';
|
|
4
|
-
import { pathToFileURL } from 'node:url';
|
|
5
|
-
import { CompatibilityModuleFactory } from './compatibility-factory.js';
|
|
6
|
-
import { registerCompatibilityNamespace } from './register-compat-module.js';
|
|
7
|
-
const SUPPORTED_EXTENSIONS = new Set(['.js', '.mjs', '.cjs']);
|
|
8
|
-
export function resolveCompatSearchDirs() {
|
|
9
|
-
const env = process.env.ROUTECODEX_COMPAT_DIRS || process.env.ROUTECODEX_COMPAT_PATH || '';
|
|
10
|
-
const envDirs = env
|
|
11
|
-
.split(path.delimiter)
|
|
12
|
-
.map(dir => dir.trim())
|
|
13
|
-
.filter(Boolean)
|
|
14
|
-
.map(expandHome);
|
|
15
|
-
const defaults = [path.join(os.homedir(), '.routecodex', 'compat')];
|
|
16
|
-
const combined = [...envDirs, ...defaults];
|
|
17
|
-
const deduped = [];
|
|
18
|
-
for (const dir of combined) {
|
|
19
|
-
if (!dir) {
|
|
20
|
-
continue;
|
|
21
|
-
}
|
|
22
|
-
if (!deduped.includes(dir)) {
|
|
23
|
-
deduped.push(dir);
|
|
24
|
-
}
|
|
25
|
-
}
|
|
26
|
-
return deduped;
|
|
27
|
-
}
|
|
28
|
-
export async function loadCompatibilityModulesFromDirs(dirs, logger) {
|
|
29
|
-
for (const dir of dirs) {
|
|
30
|
-
try {
|
|
31
|
-
await registerModulesInDir(dir, logger);
|
|
32
|
-
}
|
|
33
|
-
catch (error) {
|
|
34
|
-
logger?.logError?.(error, { component: 'compat-directory-loader', dir });
|
|
35
|
-
}
|
|
36
|
-
}
|
|
37
|
-
}
|
|
38
|
-
async function registerModulesInDir(dir, logger) {
|
|
39
|
-
if (!dir) {
|
|
40
|
-
return;
|
|
41
|
-
}
|
|
42
|
-
let stats;
|
|
43
|
-
try {
|
|
44
|
-
stats = await fs.stat(dir);
|
|
45
|
-
}
|
|
46
|
-
catch {
|
|
47
|
-
return;
|
|
48
|
-
}
|
|
49
|
-
if (!stats.isDirectory()) {
|
|
50
|
-
return;
|
|
51
|
-
}
|
|
52
|
-
const files = await fs.readdir(dir);
|
|
53
|
-
for (const file of files) {
|
|
54
|
-
const fullPath = path.join(dir, file);
|
|
55
|
-
const ext = path.extname(fullPath).toLowerCase();
|
|
56
|
-
if (!SUPPORTED_EXTENSIONS.has(ext)) {
|
|
57
|
-
continue;
|
|
58
|
-
}
|
|
59
|
-
try {
|
|
60
|
-
const mod = await import(pathToFileURL(fullPath).href);
|
|
61
|
-
await registerModuleExport(mod, logger, fullPath);
|
|
62
|
-
}
|
|
63
|
-
catch (error) {
|
|
64
|
-
logger?.logError?.(error, { component: 'compat-module-import', file: fullPath });
|
|
65
|
-
}
|
|
66
|
-
}
|
|
67
|
-
}
|
|
68
|
-
async function registerModuleExport(mod, logger, source) {
|
|
69
|
-
try {
|
|
70
|
-
registerCompatibilityNamespace(CompatibilityModuleFactory, mod, source, logger);
|
|
71
|
-
}
|
|
72
|
-
catch (error) {
|
|
73
|
-
logger?.logError?.(error, { component: 'compat-module-register', source });
|
|
74
|
-
}
|
|
75
|
-
}
|
|
76
|
-
function expandHome(input) {
|
|
77
|
-
if (!input.startsWith('~/')) {
|
|
78
|
-
return input;
|
|
79
|
-
}
|
|
80
|
-
return path.join(os.homedir(), input.slice(2));
|
|
81
|
-
}
|
|
82
|
-
export async function registerCompatibilityModuleForTest(exported) {
|
|
83
|
-
await registerModuleExport(exported, undefined, 'test');
|
|
84
|
-
}
|
|
85
|
-
//# sourceMappingURL=compat-directory-loader.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"compat-directory-loader.js","sourceRoot":"","sources":["../../../src/providers/compat/compat-directory-loader.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,18 +0,0 @@
|
|
|
1
|
-
import type { PipelineModule, ModuleConfig } from '../../modules/pipeline/interfaces/pipeline-interfaces.js';
|
|
2
|
-
import type { UnknownObject } from '../../modules/pipeline/types/common-types.js';
|
|
3
|
-
import type { CompatibilityModule } from './compatibility-interface.js';
|
|
4
|
-
/**
|
|
5
|
-
* 适配器:将CompatibilityModule适配为PipelineModule接口
|
|
6
|
-
* 用于PipelineManager中集成compatibility模块
|
|
7
|
-
*/
|
|
8
|
-
export declare class CompatibilityToPipelineAdapter implements PipelineModule<UnknownObject, UnknownObject> {
|
|
9
|
-
readonly id: string;
|
|
10
|
-
readonly type: string;
|
|
11
|
-
readonly config: ModuleConfig;
|
|
12
|
-
private compatibilityModule;
|
|
13
|
-
constructor(compatibilityModule: CompatibilityModule, config: ModuleConfig);
|
|
14
|
-
initialize(): Promise<void>;
|
|
15
|
-
processIncoming(request: UnknownObject): Promise<UnknownObject>;
|
|
16
|
-
processOutgoing(response: UnknownObject): Promise<UnknownObject>;
|
|
17
|
-
cleanup(): Promise<void>;
|
|
18
|
-
}
|
|
@@ -1,104 +0,0 @@
|
|
|
1
|
-
function isRecord(value) {
|
|
2
|
-
return typeof value === 'object' && value !== null && !Array.isArray(value);
|
|
3
|
-
}
|
|
4
|
-
function getStringProperty(source, key) {
|
|
5
|
-
if (!source) {
|
|
6
|
-
return undefined;
|
|
7
|
-
}
|
|
8
|
-
const value = source[key];
|
|
9
|
-
return typeof value === 'string' ? value : undefined;
|
|
10
|
-
}
|
|
11
|
-
function normalizeMetadata(value) {
|
|
12
|
-
return isRecord(value) ? value : undefined;
|
|
13
|
-
}
|
|
14
|
-
function safeJsonSize(payload) {
|
|
15
|
-
try {
|
|
16
|
-
return JSON.stringify(payload).length;
|
|
17
|
-
}
|
|
18
|
-
catch {
|
|
19
|
-
return 0;
|
|
20
|
-
}
|
|
21
|
-
}
|
|
22
|
-
/**
|
|
23
|
-
* 适配器:将CompatibilityModule适配为PipelineModule接口
|
|
24
|
-
* 用于PipelineManager中集成compatibility模块
|
|
25
|
-
*/
|
|
26
|
-
export class CompatibilityToPipelineAdapter {
|
|
27
|
-
id;
|
|
28
|
-
type;
|
|
29
|
-
config;
|
|
30
|
-
compatibilityModule;
|
|
31
|
-
constructor(compatibilityModule, config) {
|
|
32
|
-
this.compatibilityModule = compatibilityModule;
|
|
33
|
-
this.config = config;
|
|
34
|
-
this.id = compatibilityModule.id;
|
|
35
|
-
this.type = compatibilityModule.type;
|
|
36
|
-
}
|
|
37
|
-
async initialize() {
|
|
38
|
-
return await this.compatibilityModule.initialize();
|
|
39
|
-
}
|
|
40
|
-
async processIncoming(request) {
|
|
41
|
-
const pipelineRequest = request;
|
|
42
|
-
const route = isRecord(pipelineRequest.route) ? pipelineRequest.route : undefined;
|
|
43
|
-
const metadataObj = normalizeMetadata(pipelineRequest.metadata);
|
|
44
|
-
const pipelineRequestId = getStringProperty(route, 'requestId') ||
|
|
45
|
-
getStringProperty(pipelineRequest, 'requestId') ||
|
|
46
|
-
`req_${Date.now()}`;
|
|
47
|
-
const entryEndpoint = getStringProperty(metadataObj, 'entryEndpoint') ||
|
|
48
|
-
getStringProperty(route, 'entryEndpoint') ||
|
|
49
|
-
'';
|
|
50
|
-
const context = {
|
|
51
|
-
compatibilityId: this.compatibilityModule.id,
|
|
52
|
-
profileId: `${this.compatibilityModule.providerType || 'default'}-${this.type}`,
|
|
53
|
-
providerType: this.compatibilityModule.providerType || this.type,
|
|
54
|
-
direction: 'incoming',
|
|
55
|
-
stage: 'request_processing',
|
|
56
|
-
requestId: pipelineRequestId,
|
|
57
|
-
executionId: `exec_${Date.now()}`,
|
|
58
|
-
timestamp: Date.now(),
|
|
59
|
-
startTime: Date.now(),
|
|
60
|
-
entryEndpoint,
|
|
61
|
-
metadata: {
|
|
62
|
-
dataSize: safeJsonSize(pipelineRequest),
|
|
63
|
-
dataKeys: Object.keys(pipelineRequest),
|
|
64
|
-
config: this.config,
|
|
65
|
-
...(metadataObj || {})
|
|
66
|
-
}
|
|
67
|
-
};
|
|
68
|
-
return await this.compatibilityModule.processIncoming(pipelineRequest, context);
|
|
69
|
-
}
|
|
70
|
-
async processOutgoing(response) {
|
|
71
|
-
const responseRoute = isRecord(response.route) ? response.route : undefined;
|
|
72
|
-
const responseMetadata = normalizeMetadata(response.metadata);
|
|
73
|
-
const pipelineRequestId = getStringProperty(responseRoute, 'requestId') ||
|
|
74
|
-
getStringProperty(response, 'requestId') ||
|
|
75
|
-
getStringProperty(responseMetadata, 'requestId') ||
|
|
76
|
-
`req_${Date.now()}`;
|
|
77
|
-
const entryEndpoint = getStringProperty(responseMetadata, 'entryEndpoint') ||
|
|
78
|
-
getStringProperty(responseRoute, 'entryEndpoint') ||
|
|
79
|
-
'';
|
|
80
|
-
const context = {
|
|
81
|
-
compatibilityId: this.compatibilityModule.id,
|
|
82
|
-
profileId: `${this.compatibilityModule.providerType || 'default'}-${this.type}`,
|
|
83
|
-
providerType: this.compatibilityModule.providerType || this.type,
|
|
84
|
-
direction: 'outgoing',
|
|
85
|
-
stage: 'response_processing',
|
|
86
|
-
requestId: pipelineRequestId,
|
|
87
|
-
executionId: `exec_${Date.now()}`,
|
|
88
|
-
timestamp: Date.now(),
|
|
89
|
-
startTime: Date.now(),
|
|
90
|
-
entryEndpoint,
|
|
91
|
-
metadata: {
|
|
92
|
-
dataSize: safeJsonSize(response),
|
|
93
|
-
dataKeys: Object.keys(response),
|
|
94
|
-
config: this.config,
|
|
95
|
-
...(responseMetadata || {})
|
|
96
|
-
}
|
|
97
|
-
};
|
|
98
|
-
return await this.compatibilityModule.processOutgoing(response, context);
|
|
99
|
-
}
|
|
100
|
-
async cleanup() {
|
|
101
|
-
return await this.compatibilityModule.cleanup();
|
|
102
|
-
}
|
|
103
|
-
}
|
|
104
|
-
//# sourceMappingURL=compatibility-adapter.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"compatibility-adapter.js","sourceRoot":"","sources":["../../../src/providers/compat/compatibility-adapter.ts"],"names":[],"mappings":"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"}
|