@jsonstudio/llms 0.4.2
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 +265 -0
- package/dist/api/index.d.ts +10 -0
- package/dist/api/index.js +11 -0
- package/dist/api/llmswitch-config.d.ts +15 -0
- package/dist/api/llmswitch-config.js +415 -0
- package/dist/api/llmswitch-types.d.ts +412 -0
- package/dist/api/llmswitch-types.js +60 -0
- package/dist/bridge/routecodex-adapter.d.ts +74 -0
- package/dist/bridge/routecodex-adapter.js +226 -0
- package/dist/config/index.d.ts +3 -0
- package/dist/config/index.js +5 -0
- package/dist/config-unified/enhanced-path-resolver.d.ts +5 -0
- package/dist/config-unified/enhanced-path-resolver.js +38 -0
- package/dist/config-unified/unified-config.d.ts +26 -0
- package/dist/config-unified/unified-config.js +187 -0
- package/dist/conversion/codec-registry.d.ts +10 -0
- package/dist/conversion/codec-registry.js +25 -0
- package/dist/conversion/codecs/anthropic-openai-codec.d.ts +23 -0
- package/dist/conversion/codecs/anthropic-openai-codec.js +546 -0
- package/dist/conversion/codecs/gemini-openai-codec.d.ts +16 -0
- package/dist/conversion/codecs/gemini-openai-codec.js +437 -0
- package/dist/conversion/codecs/openai-openai-codec.d.ts +12 -0
- package/dist/conversion/codecs/openai-openai-codec.js +125 -0
- package/dist/conversion/codecs/responses-openai-codec.d.ts +12 -0
- package/dist/conversion/codecs/responses-openai-codec.js +154 -0
- package/dist/conversion/config/config-manager.d.ts +212 -0
- package/dist/conversion/config/config-manager.js +310 -0
- package/dist/conversion/conversion-v3/adapters/index.d.ts +2 -0
- package/dist/conversion/conversion-v3/adapters/index.js +1 -0
- package/dist/conversion/conversion-v3/adapters/v3-to-standard-adapter.d.ts +38 -0
- package/dist/conversion/conversion-v3/adapters/v3-to-standard-adapter.js +55 -0
- package/dist/conversion/conversion-v3/compatibility/compatibility-profiles.d.ts +22 -0
- package/dist/conversion/conversion-v3/compatibility/compatibility-profiles.js +84 -0
- package/dist/conversion/conversion-v3/compatibility/compatibility-stages.d.ts +4 -0
- package/dist/conversion/conversion-v3/compatibility/compatibility-stages.js +285 -0
- package/dist/conversion/conversion-v3/compatibility/index.d.ts +3 -0
- package/dist/conversion/conversion-v3/compatibility/index.js +2 -0
- package/dist/conversion/conversion-v3/config/default-configs.d.ts +48 -0
- package/dist/conversion/conversion-v3/config/default-configs.js +1083 -0
- package/dist/conversion/conversion-v3/config/index.d.ts +5 -0
- package/dist/conversion/conversion-v3/config/index.js +5 -0
- package/dist/conversion/conversion-v3/config/pipeline-config-manager.d.ts +49 -0
- package/dist/conversion/conversion-v3/config/pipeline-config-manager.js +65 -0
- package/dist/conversion/conversion-v3/index.d.ts +11 -0
- package/dist/conversion/conversion-v3/index.js +17 -0
- package/dist/conversion/conversion-v3/nodes/index.d.ts +56 -0
- package/dist/conversion/conversion-v3/nodes/index.js +149 -0
- package/dist/conversion/conversion-v3/nodes/input/anthropic-input-node.d.ts +25 -0
- package/dist/conversion/conversion-v3/nodes/input/anthropic-input-node.js +56 -0
- package/dist/conversion/conversion-v3/nodes/input/base-input-node.d.ts +75 -0
- package/dist/conversion/conversion-v3/nodes/input/base-input-node.js +237 -0
- package/dist/conversion/conversion-v3/nodes/input/chat-input-node.d.ts +25 -0
- package/dist/conversion/conversion-v3/nodes/input/chat-input-node.js +56 -0
- package/dist/conversion/conversion-v3/nodes/input/chat-shape-helpers.d.ts +4 -0
- package/dist/conversion/conversion-v3/nodes/input/chat-shape-helpers.js +197 -0
- package/dist/conversion/conversion-v3/nodes/input/gemini-input-node.d.ts +16 -0
- package/dist/conversion/conversion-v3/nodes/input/gemini-input-node.js +125 -0
- package/dist/conversion/conversion-v3/nodes/input/index.d.ts +8 -0
- package/dist/conversion/conversion-v3/nodes/input/index.js +8 -0
- package/dist/conversion/conversion-v3/nodes/input/input-decision.d.ts +46 -0
- package/dist/conversion/conversion-v3/nodes/input/input-decision.js +125 -0
- package/dist/conversion/conversion-v3/nodes/input/responses-input-node.d.ts +20 -0
- package/dist/conversion/conversion-v3/nodes/input/responses-input-node.js +51 -0
- package/dist/conversion/conversion-v3/nodes/output/anthropic-output-node.d.ts +71 -0
- package/dist/conversion/conversion-v3/nodes/output/anthropic-output-node.js +320 -0
- package/dist/conversion/conversion-v3/nodes/output/base-output-node.d.ts +116 -0
- package/dist/conversion/conversion-v3/nodes/output/base-output-node.js +512 -0
- package/dist/conversion/conversion-v3/nodes/output/index.d.ts +7 -0
- package/dist/conversion/conversion-v3/nodes/output/index.js +7 -0
- package/dist/conversion/conversion-v3/nodes/output/openai-output-node.d.ts +71 -0
- package/dist/conversion/conversion-v3/nodes/output/openai-output-node.js +293 -0
- package/dist/conversion/conversion-v3/nodes/output/output-decision.d.ts +68 -0
- package/dist/conversion/conversion-v3/nodes/output/output-decision.js +161 -0
- package/dist/conversion/conversion-v3/nodes/output/responses-output-node.d.ts +64 -0
- package/dist/conversion/conversion-v3/nodes/output/responses-output-node.js +323 -0
- package/dist/conversion/conversion-v3/nodes/process/base-process-node.d.ts +72 -0
- package/dist/conversion/conversion-v3/nodes/process/base-process-node.js +246 -0
- package/dist/conversion/conversion-v3/nodes/process/chat-process-node.d.ts +135 -0
- package/dist/conversion/conversion-v3/nodes/process/chat-process-node.js +854 -0
- package/dist/conversion/conversion-v3/nodes/process/compatibility-process-node.d.ts +29 -0
- package/dist/conversion/conversion-v3/nodes/process/compatibility-process-node.js +181 -0
- package/dist/conversion/conversion-v3/nodes/process/index.d.ts +10 -0
- package/dist/conversion/conversion-v3/nodes/process/index.js +10 -0
- package/dist/conversion/conversion-v3/nodes/process/passthrough-process-node.d.ts +59 -0
- package/dist/conversion/conversion-v3/nodes/process/passthrough-process-node.js +243 -0
- package/dist/conversion/conversion-v3/nodes/process/response-process-node.d.ts +17 -0
- package/dist/conversion/conversion-v3/nodes/process/response-process-node.js +213 -0
- package/dist/conversion/conversion-v3/nodes/process/tool-process-node.d.ts +26 -0
- package/dist/conversion/conversion-v3/nodes/process/tool-process-node.js +299 -0
- package/dist/conversion/conversion-v3/nodes/process/virtual-router-process-node.d.ts +40 -0
- package/dist/conversion/conversion-v3/nodes/process/virtual-router-process-node.js +430 -0
- package/dist/conversion/conversion-v3/nodes/response/anthropic-response-input-node.d.ts +12 -0
- package/dist/conversion/conversion-v3/nodes/response/anthropic-response-input-node.js +129 -0
- package/dist/conversion/conversion-v3/nodes/response/chat-to-responses-response-node.d.ts +15 -0
- package/dist/conversion/conversion-v3/nodes/response/chat-to-responses-response-node.js +57 -0
- package/dist/conversion/conversion-v3/nodes/response/index.d.ts +4 -0
- package/dist/conversion/conversion-v3/nodes/response/index.js +4 -0
- package/dist/conversion/conversion-v3/nodes/response/openai-response-input-node.d.ts +15 -0
- package/dist/conversion/conversion-v3/nodes/response/openai-response-input-node.js +87 -0
- package/dist/conversion/conversion-v3/nodes/response/response-utils.d.ts +1 -0
- package/dist/conversion/conversion-v3/nodes/response/response-utils.js +1 -0
- package/dist/conversion/conversion-v3/nodes/response/responses-response-input-node.d.ts +12 -0
- package/dist/conversion/conversion-v3/nodes/response/responses-response-input-node.js +67 -0
- package/dist/conversion/conversion-v3/nodes/sse/index.d.ts +3 -0
- package/dist/conversion/conversion-v3/nodes/sse/index.js +3 -0
- package/dist/conversion/conversion-v3/nodes/sse/sse-input-node.d.ts +27 -0
- package/dist/conversion/conversion-v3/nodes/sse/sse-input-node.js +165 -0
- package/dist/conversion/conversion-v3/nodes/sse/sse-output-node.d.ts +19 -0
- package/dist/conversion/conversion-v3/nodes/sse/sse-output-node.js +267 -0
- package/dist/conversion/conversion-v3/nodes/sse/sse-passthrough-node.d.ts +18 -0
- package/dist/conversion/conversion-v3/nodes/sse/sse-passthrough-node.js +48 -0
- package/dist/conversion/conversion-v3/pipelines/index.d.ts +6 -0
- package/dist/conversion/conversion-v3/pipelines/index.js +6 -0
- package/dist/conversion/conversion-v3/pipelines/super-pipeline.d.ts +112 -0
- package/dist/conversion/conversion-v3/pipelines/super-pipeline.js +566 -0
- package/dist/conversion/conversion-v3/response/provider-response-converter.d.ts +28 -0
- package/dist/conversion/conversion-v3/response/provider-response-converter.js +249 -0
- package/dist/conversion/conversion-v3/sse/index.d.ts +140 -0
- package/dist/conversion/conversion-v3/sse/index.js +115 -0
- package/dist/conversion/conversion-v3/sse/json-to-sse/anthropic-json-to-sse-converter.d.ts +11 -0
- package/dist/conversion/conversion-v3/sse/json-to-sse/anthropic-json-to-sse-converter.js +79 -0
- package/dist/conversion/conversion-v3/sse/json-to-sse/chat-json-to-sse-converter.d.ts +79 -0
- package/dist/conversion/conversion-v3/sse/json-to-sse/chat-json-to-sse-converter.js +296 -0
- package/dist/conversion/conversion-v3/sse/json-to-sse/event-generators/chat.d.ts +55 -0
- package/dist/conversion/conversion-v3/sse/json-to-sse/event-generators/chat.js +233 -0
- package/dist/conversion/conversion-v3/sse/json-to-sse/event-generators/responses.d.ts +99 -0
- package/dist/conversion/conversion-v3/sse/json-to-sse/event-generators/responses.js +599 -0
- package/dist/conversion/conversion-v3/sse/json-to-sse/index.d.ts +6 -0
- package/dist/conversion/conversion-v3/sse/json-to-sse/index.js +7 -0
- package/dist/conversion/conversion-v3/sse/json-to-sse/responses-json-to-sse-converter.d.ts +79 -0
- package/dist/conversion/conversion-v3/sse/json-to-sse/responses-json-to-sse-converter.js +322 -0
- package/dist/conversion/conversion-v3/sse/json-to-sse/sequencers/chat-sequencer.d.ts +37 -0
- package/dist/conversion/conversion-v3/sse/json-to-sse/sequencers/chat-sequencer.js +218 -0
- package/dist/conversion/conversion-v3/sse/json-to-sse/sequencers/responses-sequencer.d.ts +40 -0
- package/dist/conversion/conversion-v3/sse/json-to-sse/sequencers/responses-sequencer.js +263 -0
- package/dist/conversion/conversion-v3/sse/registry/sse-codec-registry.d.ts +32 -0
- package/dist/conversion/conversion-v3/sse/registry/sse-codec-registry.js +106 -0
- package/dist/conversion/conversion-v3/sse/shared/chat-serializer.d.ts +4 -0
- package/dist/conversion/conversion-v3/sse/shared/chat-serializer.js +40 -0
- package/dist/conversion/conversion-v3/sse/shared/constants.d.ts +272 -0
- package/dist/conversion/conversion-v3/sse/shared/constants.js +321 -0
- package/dist/conversion/conversion-v3/sse/shared/serializers/base-serializer.d.ts +158 -0
- package/dist/conversion/conversion-v3/sse/shared/serializers/base-serializer.js +210 -0
- package/dist/conversion/conversion-v3/sse/shared/serializers/chat-event-serializer.d.ts +82 -0
- package/dist/conversion/conversion-v3/sse/shared/serializers/chat-event-serializer.js +275 -0
- package/dist/conversion/conversion-v3/sse/shared/serializers/index.d.ts +39 -0
- package/dist/conversion/conversion-v3/sse/shared/serializers/index.js +54 -0
- package/dist/conversion/conversion-v3/sse/shared/serializers/responses-event-serializer.d.ts +123 -0
- package/dist/conversion/conversion-v3/sse/shared/serializers/responses-event-serializer.js +356 -0
- package/dist/conversion/conversion-v3/sse/shared/serializers/types.d.ts +51 -0
- package/dist/conversion/conversion-v3/sse/shared/serializers/types.js +4 -0
- package/dist/conversion/conversion-v3/sse/shared/utils.d.ts +254 -0
- package/dist/conversion/conversion-v3/sse/shared/utils.js +543 -0
- package/dist/conversion/conversion-v3/sse/shared/writer.d.ts +111 -0
- package/dist/conversion/conversion-v3/sse/shared/writer.js +268 -0
- package/dist/conversion/conversion-v3/sse/sse-to-json/anthropic-sse-to-json-converter.d.ts +13 -0
- package/dist/conversion/conversion-v3/sse/sse-to-json/anthropic-sse-to-json-converter.js +139 -0
- package/dist/conversion/conversion-v3/sse/sse-to-json/builders/response-builder.d.ts +165 -0
- package/dist/conversion/conversion-v3/sse/sse-to-json/builders/response-builder.js +776 -0
- package/dist/conversion/conversion-v3/sse/sse-to-json/chat-sse-to-json-converter.d.ts +106 -0
- package/dist/conversion/conversion-v3/sse/sse-to-json/chat-sse-to-json-converter.js +540 -0
- package/dist/conversion/conversion-v3/sse/sse-to-json/index.d.ts +6 -0
- package/dist/conversion/conversion-v3/sse/sse-to-json/index.js +7 -0
- package/dist/conversion/conversion-v3/sse/sse-to-json/parsers/sse-parser.d.ts +73 -0
- package/dist/conversion/conversion-v3/sse/sse-to-json/parsers/sse-parser.js +332 -0
- package/dist/conversion/conversion-v3/sse/sse-to-json/responses-sse-to-json-converter.d.ts +59 -0
- package/dist/conversion/conversion-v3/sse/sse-to-json/responses-sse-to-json-converter.js +270 -0
- package/dist/conversion/conversion-v3/sse/types/anthropic-types.d.ts +87 -0
- package/dist/conversion/conversion-v3/sse/types/anthropic-types.js +5 -0
- package/dist/conversion/conversion-v3/sse/types/chat-types.d.ts +308 -0
- package/dist/conversion/conversion-v3/sse/types/chat-types.js +32 -0
- package/dist/conversion/conversion-v3/sse/types/conversion-context.d.ts +211 -0
- package/dist/conversion/conversion-v3/sse/types/conversion-context.js +20 -0
- package/dist/conversion/conversion-v3/sse/types/core-interfaces.d.ts +90 -0
- package/dist/conversion/conversion-v3/sse/types/core-interfaces.js +5 -0
- package/dist/conversion/conversion-v3/sse/types/index.d.ts +14 -0
- package/dist/conversion/conversion-v3/sse/types/index.js +7 -0
- package/dist/conversion/conversion-v3/sse/types/responses-types.d.ts +328 -0
- package/dist/conversion/conversion-v3/sse/types/responses-types.js +38 -0
- package/dist/conversion/conversion-v3/sse/types/sse-events.d.ts +180 -0
- package/dist/conversion/conversion-v3/sse/types/sse-events.js +150 -0
- package/dist/conversion/conversion-v3/sse/types/stream-state.d.ts +204 -0
- package/dist/conversion/conversion-v3/sse/types/stream-state.js +44 -0
- package/dist/conversion/conversion-v3/sse/types/utility-types.d.ts +230 -0
- package/dist/conversion/conversion-v3/sse/types/utility-types.js +49 -0
- package/dist/conversion/conversion-v3/standards/context-adapter.d.ts +146 -0
- package/dist/conversion/conversion-v3/standards/context-adapter.js +438 -0
- package/dist/conversion/conversion-v3/standards/errors.d.ts +38 -0
- package/dist/conversion/conversion-v3/standards/errors.js +27 -0
- package/dist/conversion/conversion-v3/standards/index.d.ts +15 -0
- package/dist/conversion/conversion-v3/standards/index.js +11 -0
- package/dist/conversion/conversion-v3/standards/node-capabilities.d.ts +123 -0
- package/dist/conversion/conversion-v3/standards/node-capabilities.js +330 -0
- package/dist/conversion/conversion-v3/standards/pipeline-context.d.ts +237 -0
- package/dist/conversion/conversion-v3/standards/pipeline-context.js +84 -0
- package/dist/conversion/conversion-v3/standards/pipeline-node.d.ts +196 -0
- package/dist/conversion/conversion-v3/standards/pipeline-node.js +316 -0
- package/dist/conversion/conversion-v3/standards/snapshot-handles.d.ts +24 -0
- package/dist/conversion/conversion-v3/standards/snapshot-handles.js +49 -0
- package/dist/conversion/conversion-v3/types/config-types.d.ts +242 -0
- package/dist/conversion/conversion-v3/types/config-types.js +13 -0
- package/dist/conversion/conversion-v3/types/index.d.ts +8 -0
- package/dist/conversion/conversion-v3/types/index.js +11 -0
- package/dist/conversion/conversion-v3/types/node-types.d.ts +211 -0
- package/dist/conversion/conversion-v3/types/node-types.js +20 -0
- package/dist/conversion/conversion-v3/types/pipeline-types.d.ts +246 -0
- package/dist/conversion/conversion-v3/types/pipeline-types.js +26 -0
- package/dist/conversion/conversion-v3/types/request-types.d.ts +293 -0
- package/dist/conversion/conversion-v3/types/request-types.js +26 -0
- package/dist/conversion/conversion-v3/utils/provider-payload-sanitizer.d.ts +10 -0
- package/dist/conversion/conversion-v3/utils/provider-payload-sanitizer.js +103 -0
- package/dist/conversion/conversion-v3/validations/index.d.ts +8 -0
- package/dist/conversion/conversion-v3/validations/index.js +7 -0
- package/dist/conversion/conversion-v3/validations/node-graph-validator.d.ts +116 -0
- package/dist/conversion/conversion-v3/validations/node-graph-validator.js +505 -0
- package/dist/conversion/conversion-v3/validations/tool-governance-enforcer.d.ts +139 -0
- package/dist/conversion/conversion-v3/validations/tool-governance-enforcer.js +338 -0
- package/dist/conversion/hub/config/types.d.ts +26 -0
- package/dist/conversion/hub/config/types.js +1 -0
- package/dist/conversion/hub/core/detour-registry.d.ts +9 -0
- package/dist/conversion/hub/core/detour-registry.js +23 -0
- package/dist/conversion/hub/core/hub-context.d.ts +21 -0
- package/dist/conversion/hub/core/hub-context.js +1 -0
- package/dist/conversion/hub/core/index.d.ts +3 -0
- package/dist/conversion/hub/core/index.js +3 -0
- package/dist/conversion/hub/core/stage-driver.d.ts +30 -0
- package/dist/conversion/hub/core/stage-driver.js +31 -0
- package/dist/conversion/hub/format-adapters/anthropic-format-adapter.d.ts +16 -0
- package/dist/conversion/hub/format-adapters/anthropic-format-adapter.js +23 -0
- package/dist/conversion/hub/format-adapters/chat-format-adapter.d.ts +17 -0
- package/dist/conversion/hub/format-adapters/chat-format-adapter.js +23 -0
- package/dist/conversion/hub/format-adapters/gemini-format-adapter.d.ts +16 -0
- package/dist/conversion/hub/format-adapters/gemini-format-adapter.js +23 -0
- package/dist/conversion/hub/format-adapters/index.d.ts +21 -0
- package/dist/conversion/hub/format-adapters/index.js +4 -0
- package/dist/conversion/hub/format-adapters/responses-format-adapter.d.ts +17 -0
- package/dist/conversion/hub/format-adapters/responses-format-adapter.js +23 -0
- package/dist/conversion/hub/hub-feature.d.ts +1 -0
- package/dist/conversion/hub/hub-feature.js +25 -0
- package/dist/conversion/hub/node-support.d.ts +19 -0
- package/dist/conversion/hub/node-support.js +115 -0
- package/dist/conversion/hub/pipeline/hub-pipeline.d.ts +68 -0
- package/dist/conversion/hub/pipeline/hub-pipeline.js +421 -0
- package/dist/conversion/hub/pipelines/inbound.d.ts +22 -0
- package/dist/conversion/hub/pipelines/inbound.js +64 -0
- package/dist/conversion/hub/pipelines/outbound.d.ts +22 -0
- package/dist/conversion/hub/pipelines/outbound.js +57 -0
- package/dist/conversion/hub/process/chat-process.d.ts +13 -0
- package/dist/conversion/hub/process/chat-process.js +50 -0
- package/dist/conversion/hub/registry.d.ts +28 -0
- package/dist/conversion/hub/registry.js +98 -0
- package/dist/conversion/hub/response/chat-response-utils.d.ts +6 -0
- package/dist/conversion/hub/response/chat-response-utils.js +89 -0
- package/dist/conversion/hub/response/provider-response.d.ts +20 -0
- package/dist/conversion/hub/response/provider-response.js +196 -0
- package/dist/conversion/hub/response/response-mappers.d.ts +19 -0
- package/dist/conversion/hub/response/response-mappers.js +23 -0
- package/dist/conversion/hub/response/response-runtime.d.ts +3 -0
- package/dist/conversion/hub/response/response-runtime.js +206 -0
- package/dist/conversion/hub/semantic-mappers/anthropic-mapper.d.ts +7 -0
- package/dist/conversion/hub/semantic-mappers/anthropic-mapper.js +308 -0
- package/dist/conversion/hub/semantic-mappers/chat-mapper.d.ts +7 -0
- package/dist/conversion/hub/semantic-mappers/chat-mapper.js +304 -0
- package/dist/conversion/hub/semantic-mappers/gemini-mapper.d.ts +7 -0
- package/dist/conversion/hub/semantic-mappers/gemini-mapper.js +477 -0
- package/dist/conversion/hub/semantic-mappers/index.d.ts +4 -0
- package/dist/conversion/hub/semantic-mappers/index.js +4 -0
- package/dist/conversion/hub/semantic-mappers/responses-mapper.d.ts +21 -0
- package/dist/conversion/hub/semantic-mappers/responses-mapper.js +379 -0
- package/dist/conversion/hub/snapshot-recorder.d.ts +12 -0
- package/dist/conversion/hub/snapshot-recorder.js +69 -0
- package/dist/conversion/hub/standardized-bridge.d.ts +12 -0
- package/dist/conversion/hub/standardized-bridge.js +248 -0
- package/dist/conversion/hub/types/chat-envelope.d.ts +67 -0
- package/dist/conversion/hub/types/chat-envelope.js +1 -0
- package/dist/conversion/hub/types/chat-schema.d.ts +112 -0
- package/dist/conversion/hub/types/chat-schema.js +1 -0
- package/dist/conversion/hub/types/errors.d.ts +5 -0
- package/dist/conversion/hub/types/errors.js +13 -0
- package/dist/conversion/hub/types/format-envelope.d.ts +7 -0
- package/dist/conversion/hub/types/format-envelope.js +1 -0
- package/dist/conversion/hub/types/index.d.ts +6 -0
- package/dist/conversion/hub/types/index.js +6 -0
- package/dist/conversion/hub/types/json.d.ts +9 -0
- package/dist/conversion/hub/types/json.js +9 -0
- package/dist/conversion/hub/types/node.d.ts +31 -0
- package/dist/conversion/hub/types/node.js +1 -0
- package/dist/conversion/hub/types/standardized.d.ts +94 -0
- package/dist/conversion/hub/types/standardized.js +1 -0
- package/dist/conversion/index.d.ts +28 -0
- package/dist/conversion/index.js +28 -0
- package/dist/conversion/responses/responses-openai-bridge.d.ts +95 -0
- package/dist/conversion/responses/responses-openai-bridge.js +1330 -0
- package/dist/conversion/schema-validator.d.ts +7 -0
- package/dist/conversion/schema-validator.js +67 -0
- package/dist/conversion/shared/args-mapping.d.ts +18 -0
- package/dist/conversion/shared/args-mapping.js +213 -0
- package/dist/conversion/shared/chat-request-filters.d.ts +9 -0
- package/dist/conversion/shared/chat-request-filters.js +74 -0
- package/dist/conversion/shared/jsonish.d.ts +3 -0
- package/dist/conversion/shared/jsonish.js +177 -0
- package/dist/conversion/shared/mcp-injection.d.ts +2 -0
- package/dist/conversion/shared/mcp-injection.js +89 -0
- package/dist/conversion/shared/media.d.ts +1 -0
- package/dist/conversion/shared/media.js +9 -0
- package/dist/conversion/shared/openai-finalizer.d.ts +9 -0
- package/dist/conversion/shared/openai-finalizer.js +104 -0
- package/dist/conversion/shared/openai-message-normalize.d.ts +1 -0
- package/dist/conversion/shared/openai-message-normalize.js +442 -0
- package/dist/conversion/shared/payload-budget.d.ts +13 -0
- package/dist/conversion/shared/payload-budget.js +248 -0
- package/dist/conversion/shared/reasoning-mapping.d.ts +5 -0
- package/dist/conversion/shared/reasoning-mapping.js +8 -0
- package/dist/conversion/shared/responses-conversation-store.d.ts +41 -0
- package/dist/conversion/shared/responses-conversation-store.js +285 -0
- package/dist/conversion/shared/responses-id-utils.d.ts +7 -0
- package/dist/conversion/shared/responses-id-utils.js +29 -0
- package/dist/conversion/shared/responses-instructions.d.ts +1 -0
- package/dist/conversion/shared/responses-instructions.js +113 -0
- package/dist/conversion/shared/responses-metadata.d.ts +1 -0
- package/dist/conversion/shared/responses-metadata.js +1 -0
- package/dist/conversion/shared/responses-request-adapter.d.ts +66 -0
- package/dist/conversion/shared/responses-request-adapter.js +461 -0
- package/dist/conversion/shared/snapshot-hooks.d.ts +12 -0
- package/dist/conversion/shared/snapshot-hooks.js +7 -0
- package/dist/conversion/shared/streaming-text-extractor.d.ts +26 -0
- package/dist/conversion/shared/streaming-text-extractor.js +145 -0
- package/dist/conversion/shared/text-markup-normalizer.d.ts +9 -0
- package/dist/conversion/shared/text-markup-normalizer.js +319 -0
- package/dist/conversion/shared/tool-canonicalizer.d.ts +2 -0
- package/dist/conversion/shared/tool-canonicalizer.js +50 -0
- package/dist/conversion/shared/tool-filter-pipeline.d.ts +17 -0
- package/dist/conversion/shared/tool-filter-pipeline.js +79 -0
- package/dist/conversion/shared/tool-governor.d.ts +27 -0
- package/dist/conversion/shared/tool-governor.js +269 -0
- package/dist/conversion/shared/tool-harvester.d.ts +31 -0
- package/dist/conversion/shared/tool-harvester.js +321 -0
- package/dist/conversion/shared/tool-mapping.d.ts +10 -0
- package/dist/conversion/shared/tool-mapping.js +10 -0
- package/dist/conversion/shared/tooling.d.ts +26 -0
- package/dist/conversion/shared/tooling.js +143 -0
- package/dist/conversion/types.d.ts +33 -0
- package/dist/conversion/types.js +1 -0
- package/dist/core/index.d.ts +6 -0
- package/dist/core/index.js +9 -0
- package/dist/core/llmswitch-engine-v2.d.ts +132 -0
- package/dist/core/llmswitch-engine-v2.js +649 -0
- package/dist/core/llmswitch-factory-v2.d.ts +123 -0
- package/dist/core/llmswitch-factory-v2.js +521 -0
- package/dist/endpoints/base-endpoint-handler.d.ts +128 -0
- package/dist/endpoints/base-endpoint-handler.js +545 -0
- package/dist/endpoints/chat-endpoint-handler.d.ts +115 -0
- package/dist/endpoints/chat-endpoint-handler.js +218 -0
- package/dist/endpoints/endpoint-router.d.ts +127 -0
- package/dist/endpoints/endpoint-router.js +438 -0
- package/dist/endpoints/index.d.ts +13 -0
- package/dist/endpoints/index.js +11 -0
- package/dist/endpoints/messages-endpoint-handler.d.ts +171 -0
- package/dist/endpoints/messages-endpoint-handler.js +238 -0
- package/dist/endpoints/responses-endpoint-handler.d.ts +147 -0
- package/dist/endpoints/responses-endpoint-handler.js +233 -0
- package/dist/filters/builtin/add-fields-filter.d.ts +8 -0
- package/dist/filters/builtin/add-fields-filter.js +16 -0
- package/dist/filters/builtin/blacklist-filter.d.ts +8 -0
- package/dist/filters/builtin/blacklist-filter.js +19 -0
- package/dist/filters/builtin/whitelist-filter.d.ts +8 -0
- package/dist/filters/builtin/whitelist-filter.js +19 -0
- package/dist/filters/engine.d.ts +16 -0
- package/dist/filters/engine.js +167 -0
- package/dist/filters/index.d.ts +19 -0
- package/dist/filters/index.js +24 -0
- package/dist/filters/special/request-streaming-to-nonstreaming.d.ts +12 -0
- package/dist/filters/special/request-streaming-to-nonstreaming.js +27 -0
- package/dist/filters/special/request-tool-choice-policy.d.ts +11 -0
- package/dist/filters/special/request-tool-choice-policy.js +27 -0
- package/dist/filters/special/request-tool-list-filter.d.ts +11 -0
- package/dist/filters/special/request-tool-list-filter.js +167 -0
- package/dist/filters/special/request-toolcalls-stringify.d.ts +10 -0
- package/dist/filters/special/request-toolcalls-stringify.js +44 -0
- package/dist/filters/special/request-tools-normalize.d.ts +12 -0
- package/dist/filters/special/request-tools-normalize.js +140 -0
- package/dist/filters/special/response-finish-invariants.d.ts +11 -0
- package/dist/filters/special/response-finish-invariants.js +30 -0
- package/dist/filters/special/response-openai-to-responses-bridge.d.ts +13 -0
- package/dist/filters/special/response-openai-to-responses-bridge.js +24 -0
- package/dist/filters/special/response-tool-arguments-blacklist.d.ts +12 -0
- package/dist/filters/special/response-tool-arguments-blacklist.js +63 -0
- package/dist/filters/special/response-tool-arguments-schema-converge.d.ts +13 -0
- package/dist/filters/special/response-tool-arguments-schema-converge.js +63 -0
- package/dist/filters/special/response-tool-arguments-stringify.d.ts +9 -0
- package/dist/filters/special/response-tool-arguments-stringify.js +134 -0
- package/dist/filters/special/response-tool-arguments-toon-decode.d.ts +10 -0
- package/dist/filters/special/response-tool-arguments-toon-decode.js +94 -0
- package/dist/filters/special/response-tool-arguments-whitelist.d.ts +11 -0
- package/dist/filters/special/response-tool-arguments-whitelist.js +56 -0
- package/dist/filters/special/response-tool-text-canonicalize.d.ts +10 -0
- package/dist/filters/special/response-tool-text-canonicalize.js +20 -0
- package/dist/filters/special/tool-filter-hooks.d.ts +19 -0
- package/dist/filters/special/tool-filter-hooks.js +341 -0
- package/dist/filters/special/tool-post-constraints.d.ts +31 -0
- package/dist/filters/special/tool-post-constraints.js +120 -0
- package/dist/filters/types.d.ts +68 -0
- package/dist/filters/types.js +3 -0
- package/dist/filters/utils/fieldmap-loader.d.ts +2 -0
- package/dist/filters/utils/fieldmap-loader.js +16 -0
- package/dist/filters/utils/snapshot-writer.d.ts +10 -0
- package/dist/filters/utils/snapshot-writer.js +47 -0
- package/dist/guidance/index.d.ts +3 -0
- package/dist/guidance/index.js +228 -0
- package/dist/hooks/hooks-integration.d.ts +161 -0
- package/dist/hooks/hooks-integration.js +519 -0
- package/dist/hooks/index.d.ts +10 -0
- package/dist/hooks/index.js +13 -0
- package/dist/html-to-markdown.d.ts +5 -0
- package/dist/html-to-markdown.js +66 -0
- package/dist/http/sse-response.d.ts +22 -0
- package/dist/http/sse-response.js +103 -0
- package/dist/index.d.ts +10 -0
- package/dist/index.js +10 -0
- package/dist/router/virtual-router/bootstrap.d.ts +6 -0
- package/dist/router/virtual-router/bootstrap.js +620 -0
- package/dist/router/virtual-router/classifier.d.ts +10 -0
- package/dist/router/virtual-router/classifier.js +99 -0
- package/dist/router/virtual-router/engine.d.ts +35 -0
- package/dist/router/virtual-router/engine.js +260 -0
- package/dist/router/virtual-router/error-center.d.ts +10 -0
- package/dist/router/virtual-router/error-center.js +39 -0
- package/dist/router/virtual-router/features.d.ts +3 -0
- package/dist/router/virtual-router/features.js +162 -0
- package/dist/router/virtual-router/health-manager.d.ts +18 -0
- package/dist/router/virtual-router/health-manager.js +98 -0
- package/dist/router/virtual-router/load-balancer.d.ts +18 -0
- package/dist/router/virtual-router/load-balancer.js +67 -0
- package/dist/router/virtual-router/provider-registry.d.ts +11 -0
- package/dist/router/virtual-router/provider-registry.js +74 -0
- package/dist/router/virtual-router/types.d.ts +206 -0
- package/dist/router/virtual-router/types.js +31 -0
- package/dist/sse/index.d.ts +140 -0
- package/dist/sse/index.js +115 -0
- package/dist/sse/json-to-sse/anthropic-json-to-sse-converter.d.ts +11 -0
- package/dist/sse/json-to-sse/anthropic-json-to-sse-converter.js +79 -0
- package/dist/sse/json-to-sse/chat-json-to-sse-converter.d.ts +79 -0
- package/dist/sse/json-to-sse/chat-json-to-sse-converter.js +296 -0
- package/dist/sse/json-to-sse/event-generators/chat.d.ts +55 -0
- package/dist/sse/json-to-sse/event-generators/chat.js +233 -0
- package/dist/sse/json-to-sse/event-generators/responses.d.ts +99 -0
- package/dist/sse/json-to-sse/event-generators/responses.js +599 -0
- package/dist/sse/json-to-sse/index.d.ts +6 -0
- package/dist/sse/json-to-sse/index.js +7 -0
- package/dist/sse/json-to-sse/responses-json-to-sse-converter.d.ts +79 -0
- package/dist/sse/json-to-sse/responses-json-to-sse-converter.js +322 -0
- package/dist/sse/json-to-sse/sequencers/chat-sequencer.d.ts +37 -0
- package/dist/sse/json-to-sse/sequencers/chat-sequencer.js +218 -0
- package/dist/sse/json-to-sse/sequencers/responses-sequencer.d.ts +40 -0
- package/dist/sse/json-to-sse/sequencers/responses-sequencer.js +263 -0
- package/dist/sse/registry/sse-codec-registry.d.ts +32 -0
- package/dist/sse/registry/sse-codec-registry.js +106 -0
- package/dist/sse/shared/chat-serializer.d.ts +4 -0
- package/dist/sse/shared/chat-serializer.js +40 -0
- package/dist/sse/shared/constants.d.ts +272 -0
- package/dist/sse/shared/constants.js +321 -0
- package/dist/sse/shared/serializers/base-serializer.d.ts +158 -0
- package/dist/sse/shared/serializers/base-serializer.js +210 -0
- package/dist/sse/shared/serializers/chat-event-serializer.d.ts +82 -0
- package/dist/sse/shared/serializers/chat-event-serializer.js +275 -0
- package/dist/sse/shared/serializers/index.d.ts +39 -0
- package/dist/sse/shared/serializers/index.js +54 -0
- package/dist/sse/shared/serializers/responses-event-serializer.d.ts +123 -0
- package/dist/sse/shared/serializers/responses-event-serializer.js +356 -0
- package/dist/sse/shared/serializers/types.d.ts +51 -0
- package/dist/sse/shared/serializers/types.js +4 -0
- package/dist/sse/shared/utils.d.ts +254 -0
- package/dist/sse/shared/utils.js +543 -0
- package/dist/sse/shared/writer.d.ts +111 -0
- package/dist/sse/shared/writer.js +268 -0
- package/dist/sse/sse-to-json/anthropic-sse-to-json-converter.d.ts +13 -0
- package/dist/sse/sse-to-json/anthropic-sse-to-json-converter.js +139 -0
- package/dist/sse/sse-to-json/builders/response-builder.d.ts +165 -0
- package/dist/sse/sse-to-json/builders/response-builder.js +776 -0
- package/dist/sse/sse-to-json/chat-sse-to-json-converter.d.ts +106 -0
- package/dist/sse/sse-to-json/chat-sse-to-json-converter.js +540 -0
- package/dist/sse/sse-to-json/index.d.ts +6 -0
- package/dist/sse/sse-to-json/index.js +7 -0
- package/dist/sse/sse-to-json/parsers/sse-parser.d.ts +73 -0
- package/dist/sse/sse-to-json/parsers/sse-parser.js +340 -0
- package/dist/sse/sse-to-json/responses-sse-to-json-converter.d.ts +59 -0
- package/dist/sse/sse-to-json/responses-sse-to-json-converter.js +270 -0
- package/dist/sse/types/anthropic-types.d.ts +87 -0
- package/dist/sse/types/anthropic-types.js +5 -0
- package/dist/sse/types/chat-types.d.ts +308 -0
- package/dist/sse/types/chat-types.js +32 -0
- package/dist/sse/types/conversion-context.d.ts +211 -0
- package/dist/sse/types/conversion-context.js +20 -0
- package/dist/sse/types/core-interfaces.d.ts +90 -0
- package/dist/sse/types/core-interfaces.js +5 -0
- package/dist/sse/types/index.d.ts +14 -0
- package/dist/sse/types/index.js +7 -0
- package/dist/sse/types/responses-types.d.ts +328 -0
- package/dist/sse/types/responses-types.js +38 -0
- package/dist/sse/types/sse-events.d.ts +180 -0
- package/dist/sse/types/sse-events.js +150 -0
- package/dist/sse/types/stream-state.d.ts +204 -0
- package/dist/sse/types/stream-state.js +44 -0
- package/dist/sse/types/utility-types.d.ts +230 -0
- package/dist/sse/types/utility-types.js +49 -0
- package/dist/tools/proxy/anthropic-tool-proxy.d.ts +19 -0
- package/dist/tools/proxy/anthropic-tool-proxy.js +57 -0
- package/dist/tools/proxy/executors/web-fetch.d.ts +6 -0
- package/dist/tools/proxy/executors/web-fetch.js +39 -0
- package/dist/tools/proxy/registry.d.ts +8 -0
- package/dist/tools/proxy/registry.js +14 -0
- package/dist/tools/proxy/types.d.ts +29 -0
- package/dist/tools/proxy/types.js +1 -0
- package/dist/tools/tool-registry.d.ts +8 -0
- package/dist/tools/tool-registry.js +154 -0
- package/dist/tools/web-fetch-html.d.ts +15 -0
- package/dist/tools/web-fetch-html.js +83 -0
- package/dist/utils/conversion-adapter.d.ts +65 -0
- package/dist/utils/conversion-adapter.js +183 -0
- package/dist/utils/error-factory.d.ts +88 -0
- package/dist/utils/error-factory.js +138 -0
- package/dist/utils/error-utils.d.ts +334 -0
- package/dist/utils/error-utils.js +782 -0
- package/dist/utils/index.d.ts +8 -0
- package/dist/utils/index.js +13 -0
- package/dist/utils/performance-utils.d.ts +205 -0
- package/dist/utils/performance-utils.js +440 -0
- package/dist/utils/profile-mapper.d.ts +32 -0
- package/dist/utils/profile-mapper.js +269 -0
- package/dist/utils/request-processor.d.ts +52 -0
- package/dist/utils/request-processor.js +210 -0
- package/dist/utils/request-utils.d.ts +117 -0
- package/dist/utils/request-utils.js +333 -0
- package/dist/utils/response-utils.d.ts +127 -0
- package/dist/utils/response-utils.js +516 -0
- package/dist/utils/token-counter.d.ts +89 -0
- package/dist/utils/token-counter.js +541 -0
- package/package.json +65 -0
package/README.md
ADDED
|
@@ -0,0 +1,265 @@
|
|
|
1
|
+
# rcc-llmswitch-core(RouteCodex LLM Switch 核心)
|
|
2
|
+
|
|
3
|
+
本包是 RouteCodex V2 的“工具治理唯一入口 + 协议转换核心”,实现严格的“前半段/后半段”双向流水线,并通过 `defaultSseCodecRegistry` 统一治理所有 SSE ↔ JSON 转换。核心事实:
|
|
4
|
+
|
|
5
|
+
1. **唯一入口**:所有 HTTP 请求(Chat/Responses/Anthropic/Gemini)必须先进入前半段 Conversion,SSE 输入一律由 `SSEInputNode` → `defaultSseCodecRegistry` → 对应协议 JSON,再映射为标准 Chat 请求。
|
|
6
|
+
2. **唯一治理点**:后半段 Chat Pipeline 是唯一可修改工具行为的位置;其他节点仅做形状转换或流式编解码。
|
|
7
|
+
3. **唯一出站规则**:响应阶段的 output 格式 (JSON/SSE) 只看原入口端点与入站 streaming 标记;providerType 只能决定 inbound converter 与 provider 调用,不得改写 outbound 协议。
|
|
8
|
+
|
|
9
|
+
- 前半段(Front-Half,Conversion):按端点最小映射为 OpenAI Chat 标准形状(不做工具治理、不兜底)。
|
|
10
|
+
- 后半段(Back-Half,Chat Pipeline):统一工具治理、参数修复、MCP 两步暴露、流/非流一致化与最终响应组装。
|
|
11
|
+
|
|
12
|
+
遵循 AGENTS.md 的 9 大架构原则:职责单一、最小兼容、Fail Fast、无兜底、配置驱动、统一出口/入口。
|
|
13
|
+
|
|
14
|
+
版本提示:
|
|
15
|
+
- 从 0.2.95 起,Responses→Chat 的映射严格“只做形状转换”,不再注入兜底文本或工具;所有治理只在后半段进行。
|
|
16
|
+
- 从 0.3.20 起,Anthropic/Chat/Responses 三端在 V2 前后半段上实现双向闭环:请求侧统一 Anth/Chat/Responses→Chat→providerProtocol,响应侧统一 providerProtocol→Chat→入口协议,所有工具调用/结果在 Anth↔Chat↔Anth 与 Responses↔Chat↔Responses 流程中保持字段/分组不变。
|
|
17
|
+
- 自 0.4.2 起,Responses ↔ Anthropic 走完整的 Chat 桥后可直接互通:Responses upstream SSE → Chat canonical → Anthropic outbound,以及 Anthropic inbound → Chat canonical → Responses outbound,工具调用/函数输出在双向往返中保持 shape,不再需要任何协议猜测或字段兜底。
|
|
18
|
+
- 规划中:Gemini/Chat 双向闭环(`gemini-messages` 协议)将按与 Anthropic 完全平行的方式接入,仅在前半段/后半段增加独立 codec,不影响现有 Chat/Responses/Anthropic 行为。
|
|
19
|
+
|
|
20
|
+
👉 **Hub Pipeline 是当前唯一入口。** 如果 Host 需要直接编排 Virtual Router,请参见 `docs/HUB_PIPELINE_USAGE.md`,了解如何通过 `bootstrapVirtualRouterConfig` + `HubPipeline` 完成初始化与热更新。
|
|
21
|
+
|
|
22
|
+
## 总览
|
|
23
|
+
|
|
24
|
+
```
|
|
25
|
+
入站请求(任意端点)
|
|
26
|
+
├─ Chat (/v1/chat) ┐
|
|
27
|
+
├─ Responses (/v1/responses) ├─ 前半段 Conversion → 规范化为 Chat 标准 JSON(非流)
|
|
28
|
+
└─ Anthropic (/v1/messages) ┘ - 仅做字段/形状映射;不做工具治理/文本收割
|
|
29
|
+
- 统一关闭上游直通,前半段需要时将 SSE 合成为非流 JSON
|
|
30
|
+
|
|
31
|
+
▼
|
|
32
|
+
Chat Back-Half(唯一治理入口)
|
|
33
|
+
- 工具治理(canonicalize/repair/去重/ID配对)
|
|
34
|
+
- MCP 两步暴露(列表→读取/模板)
|
|
35
|
+
- reasoning/think 标准化(按端点策略保留或过滤)
|
|
36
|
+
- finalize:确保 tool_calls / tool role、finish_reason、content 形状一致
|
|
37
|
+
|
|
38
|
+
▼
|
|
39
|
+
Provider(HTTP 通信,仅转发)
|
|
40
|
+
|
|
41
|
+
▼
|
|
42
|
+
出站响应(统一从 Chat 反向映射)
|
|
43
|
+
- Chat:直接输出标准 OpenAI Chat 形状
|
|
44
|
+
- Responses:从 Chat 还原 required_action / output / items
|
|
45
|
+
- Anthropic:映射为 Anthropic 支持的形状
|
|
46
|
+
```
|
|
47
|
+
|
|
48
|
+
要点:
|
|
49
|
+
- “后半段唯一治理点”:三端(Chat/Responses/Anthropic)最终都走同一套 Chat 后半段。
|
|
50
|
+
- Responses↔Anthropic 互通:Responses provider 输出先回落到 Chat,再由入口端点(例如 `/v1/messages`)决定重新构建 Anthropic wire 形状;反向同理,Anthropic 输入先 canonical 化为 Chat 后再落地 Responses 请求,由 outbound streaming 配置决定最终 SSE/JSON 行为。
|
|
51
|
+
- “前半段最小映射”:只做协议字段/工具形状转换,不做文本工具收割/兜底/治理。
|
|
52
|
+
- “流式一致”:默认不上游直通(upstream SSE OFF),前半段将流合成为非流 JSON,再走后半段,保证一致。
|
|
53
|
+
|
|
54
|
+
## Conversion V3 节点架构与工具治理约束
|
|
55
|
+
|
|
56
|
+
- **唯一入口**:RouteCodex 主包只能通过 `src/modules/llmswitch/bridge.ts` → `dist/bridge/routecodex-adapter.js` 调用 conversion v3;禁止旁路 import。
|
|
57
|
+
- **配置驱动管线**:`config/llmswitch/pipeline-config.json`(或通过 `LLMSWITCH_PIPELINE_CONFIG` 指定)声明每条入/出站线路的节点序列:`SSE Input → Provider Input → Chat Process → Provider Output → SSE Output`,Responses/Anthropic 线路结构一致。
|
|
58
|
+
- **节点职责**
|
|
59
|
+
- `nodes/sse/*`:入站 SSE 正规化、出站 SSE 序列化以及纯透传,占位但不改写业务数据。
|
|
60
|
+
- `nodes/input/*`:OpenAI Chat / Responses / Anthropic 请求解析器,校验 `model/messages`,输出 canonical `standardizedRequest`。
|
|
61
|
+
- `nodes/process/chat-process-node`:唯一的工具治理点,负责 tool_calls 修复、MCP 两步暴露、上下文与 streaming 策略、passthrough 判定等。
|
|
62
|
+
- `nodes/output/*`:基于 `processedRequest` 生成 Provider 协议响应(choices、usage、content blocks)。
|
|
63
|
+
- `nodes/response/*`:出站方向入口,把 Provider 响应重新映射为 canonical,再交由 output/sse 节点返回。
|
|
64
|
+
- **工具治理原则**
|
|
65
|
+
- 除 Compatibility 层为了满足 Provider/OpenAI 形状所做的最小字段修剪外,任何模块都不得修改工具语义。
|
|
66
|
+
- Input/Output/SSE/Response 节点只做格式转换或序列化;所有工具解析/修复/透传/执行判定必须发生在 `process` 链路。
|
|
67
|
+
- 如需新增与工具相关的功能,必须在 `chat-process-node` 中实现或扩展新的 process 节点,并由 pipeline 配置显式启用。
|
|
68
|
+
|
|
69
|
+
## 流水线节点与职能(入站→出站)
|
|
70
|
+
|
|
71
|
+
1) HTTP Server 入站(端点路由)
|
|
72
|
+
- 接收 /v1/chat、/v1/responses、/v1/messages 的原始请求体
|
|
73
|
+
- 写入 http-request 快照(可选:.parsed 摘要)
|
|
74
|
+
|
|
75
|
+
2) 前半段 Conversion(本包 v2/conversion/...)
|
|
76
|
+
- Chat:校验/轻量规范(保持 OpenAI Chat 标准)
|
|
77
|
+
- Responses:instructions + input 映射为 Chat.messages;function_call/tool_result → assistant.tool_calls / role='tool'(只形状,不治理)
|
|
78
|
+
- Anthropic:Claude 消息/工具映射为 OpenAI Chat(仅形状)
|
|
79
|
+
- SSE:如入站为 SSE,先在前半段合成为非流 JSON(默认),确保后续统一路径
|
|
80
|
+
|
|
81
|
+
3) 后半段 Chat Pipeline(本包 v2/conversion/openai-chat/...)
|
|
82
|
+
- request-shape:
|
|
83
|
+
- 统一 messages.content 为 string
|
|
84
|
+
- 删除不支持字段(如 stream)
|
|
85
|
+
- request-tools-stage:
|
|
86
|
+
- canonicalizeChatResponseTools:不变式(content=null,finish_reason=tool_calls)
|
|
87
|
+
- JSON/JSON5 风格参数修复,失败回退 "{}"
|
|
88
|
+
- 工具 ID 生成/去重
|
|
89
|
+
- MCP 两步暴露(仅在后半段)
|
|
90
|
+
- provider 调用(Provider 层):HTTP 转发 + 快照;不做工具处理
|
|
91
|
+
- response-shape:
|
|
92
|
+
- 统一 Chat 响应形状、finish_reason、content
|
|
93
|
+
- reasoning/think 清理或保留(按端点策略)
|
|
94
|
+
- response-tools-stage:
|
|
95
|
+
- 工具结果配对(role='tool' 与 tool_calls.id 对齐)
|
|
96
|
+
- Responses 反向桥接(仅映射,不治理):required_action + items/output 还原
|
|
97
|
+
|
|
98
|
+
4) 出站响应
|
|
99
|
+
- Chat:OpenAI Chat
|
|
100
|
+
- Responses:OpenAI Responses
|
|
101
|
+
- Anthropic:Anthropic Messages
|
|
102
|
+
|
|
103
|
+
## 三端前半段:具体滤波器与映射(伪代码)
|
|
104
|
+
|
|
105
|
+
### Chat 前半段
|
|
106
|
+
```
|
|
107
|
+
function chatFrontHalf(payload):
|
|
108
|
+
assert(Array.isArray(payload.messages))
|
|
109
|
+
drop(payload.stream) // 统一非流
|
|
110
|
+
ensureOpenAIChatShape(payload)
|
|
111
|
+
return payload
|
|
112
|
+
```
|
|
113
|
+
|
|
114
|
+
### Responses 前半段(严格不兜底)
|
|
115
|
+
```
|
|
116
|
+
function responsesFrontHalf(payload):
|
|
117
|
+
ctx = captureResponsesContext(payload)
|
|
118
|
+
tools = normalizeTools(payload.tools)
|
|
119
|
+
msgs = []
|
|
120
|
+
if ctx.instructions: msgs.push({role:'system', content:trim(ctx.instructions)})
|
|
121
|
+
|
|
122
|
+
for entry in payload.input:
|
|
123
|
+
switch(entry.type):
|
|
124
|
+
case 'function_call'|'tool_call':
|
|
125
|
+
name = entry.name || entry.function?.name
|
|
126
|
+
args = parseArguments(entry.arguments || entry.function?.arguments)
|
|
127
|
+
msgs.push({role:'assistant', tool_calls:[{id:genId(entry), type:'function', function:{name, arguments:stringify(args)}}]})
|
|
128
|
+
case 'function_call_output'|'tool_result'|'tool_message':
|
|
129
|
+
id = entry.tool_call_id || entry.call_id || entry.tool_use_id || entry.id
|
|
130
|
+
out = normalizeToolOutput(entry.output)
|
|
131
|
+
msgs.push({role:'tool', tool_call_id:id, content:String(out ?? '')})
|
|
132
|
+
default:
|
|
133
|
+
// 优先 entry.message.content[]
|
|
134
|
+
if entry.message?.content: text = collectText(entry.message.content)
|
|
135
|
+
else if entry.content: text = collectText(entry.content)
|
|
136
|
+
else if entry.text: text = entry.text
|
|
137
|
+
if text: msgs.push({role:normalizeRole(entry.role), content:text})
|
|
138
|
+
|
|
139
|
+
return { model, messages: msgs, tools: tools, tool_choice: payload.tool_choice }
|
|
140
|
+
```
|
|
141
|
+
|
|
142
|
+
注意:不注入“伪 user”,不做文本工具收割/治理,严格只做形状转换。
|
|
143
|
+
|
|
144
|
+
### Anthropic 前半段
|
|
145
|
+
```
|
|
146
|
+
function anthropicFrontHalf(payload):
|
|
147
|
+
// Claude → OpenAI Chat 映射
|
|
148
|
+
for m in payload.messages:
|
|
149
|
+
map role/parts → Chat message
|
|
150
|
+
map tools → OpenAI function tools
|
|
151
|
+
drop(stream)
|
|
152
|
+
return chatPayload
|
|
153
|
+
```
|
|
154
|
+
|
|
155
|
+
### Gemini 前半段(规划中)
|
|
156
|
+
|
|
157
|
+
Gemini REST 规范使用 `contents[].role` + `parts[]` + `tools.functionDeclarations` 的结构,与 Anthropic 的 Messages 协议类似,本包会以完全平行的方式接入一个 `gemini-messages` 协议线:
|
|
158
|
+
|
|
159
|
+
目标:
|
|
160
|
+
- 仅在前半段/后半段增加 `gemini-messages` 的 codec,既有 Chat/Responses/Anthropic 行为不受影响。
|
|
161
|
+
- 非 passthrough 流水线继续遵循统一约束:`entryProtocol → Chat → providerProtocol`(请求)与 `providerProtocol → Chat → entryProtocol`(响应),中段只认 Chat。
|
|
162
|
+
|
|
163
|
+
计划中的 main codec 文件:
|
|
164
|
+
- `src/conversion/codecs/gemini-openai-codec.ts`
|
|
165
|
+
- `buildOpenAIChatFromGeminiRequest(gReq)`:Gemini 请求 → OpenAI Chat 请求
|
|
166
|
+
- `buildGeminiRequestFromOpenAIChat(chatReq)`:OpenAI Chat 请求 → Gemini 请求
|
|
167
|
+
- `buildOpenAIChatFromGeminiResponse(gResp)`:Gemini 响应 → OpenAI Chat completion
|
|
168
|
+
- `buildGeminiFromOpenAIChat(chatResp)`:OpenAI Chat completion → Gemini 响应(用于“入口/出口都是 Gemini”的回环测试与 `/v1/gemini` 出口)
|
|
169
|
+
|
|
170
|
+
请求侧(Gemini → Chat)映射要点:
|
|
171
|
+
- `contents: Content[]`
|
|
172
|
+
- `Content.role`:
|
|
173
|
+
- `"user"` → Chat `role: "user"`
|
|
174
|
+
- `"model"` → Chat `role: "assistant"`
|
|
175
|
+
- `"system"` → Chat `role: "system"`(或汇总进顶层 systemInstruction,再统一收敛为 Chat system 消息)
|
|
176
|
+
- `"tool"` → Chat `role: "tool"`(对应 functionResponse)
|
|
177
|
+
- `Content.parts: Part[]`:
|
|
178
|
+
- `{ text }` → Chat message.content 文本(可继续使用 text-markup-normalizer 做轻量标准化,不做治理)
|
|
179
|
+
- `{ functionCall: { name, args } }` →
|
|
180
|
+
- 映射为 Chat `assistant.tool_calls[]`:
|
|
181
|
+
- `type: "function"`
|
|
182
|
+
- `function.name = name`
|
|
183
|
+
- `function.arguments = JSON 字符串`(通过现有 jsonish.repairArgumentsToString 进行安全修复)
|
|
184
|
+
- `{ functionResponse: { name, response } }` →
|
|
185
|
+
- 映射为 Chat `role: "tool"` 消息:
|
|
186
|
+
- `tool_call_id` 与前一轮 `tool_calls` 对齐(ID 生成与去重仍由后半段工具治理负责)
|
|
187
|
+
- `content` 为字符串化后的结果(不丢失结构,可放入 metadata 保留原始 JSON)
|
|
188
|
+
- 其它多模态部件(`inlineData/fileData/...`):
|
|
189
|
+
- 按“不丢失信息”原则,先透传到 Chat 消息的 `metadata.vendor.gemini.parts[]`,后续再根据需要扩展。
|
|
190
|
+
- `systemInstruction?: Content`:
|
|
191
|
+
- 统一转换为 Chat 顶层 system 消息(或合并进 messages 中的 system 段),保持与 Anthropic 一致的“所有系统指令在 Chat 段收敛”策略。
|
|
192
|
+
- `tools.functionDeclarations`:
|
|
193
|
+
- 映射为 Chat `tools[].function`,字段基本一一对应(`name/description/parameters`)。
|
|
194
|
+
- 采样/安全配置:
|
|
195
|
+
- `generationConfig.temperature/topP/topK/maxOutputTokens/stopSequences` 映射为 Chat 顶层采样参数;
|
|
196
|
+
- `safetySettings` 透传到 `metadata.vendor.gemini.safetySettings`,保证信息不丢。
|
|
197
|
+
|
|
198
|
+
响应侧(Gemini → Chat)映射要点:
|
|
199
|
+
- `candidates[0].content.parts[]`:
|
|
200
|
+
- text 部分 → Chat `choices[0].message.content`(多段合并)
|
|
201
|
+
- functionCall 部分 → Chat `choices[0].message.tool_calls[]`(与请求侧规则对应)
|
|
202
|
+
- `finishReason` → Chat `finish_reason`(STOP → "stop"、MAX_TOKENS → "length" 等)
|
|
203
|
+
- `usageMetadata` → Chat `usage`(prompt_tokens/output_tokens/total)
|
|
204
|
+
|
|
205
|
+
Chat → Gemini(请求与响应):
|
|
206
|
+
- 与 Anthropic 完全平行,在 `buildGeminiRequestFromOpenAIChat` / `buildGeminiFromOpenAIChat` 内按 Chat canonical 重新投影回 Gemini wire 形状:
|
|
207
|
+
- system → `systemInstruction` 或系统 Content;
|
|
208
|
+
- assistant + tool_calls → `role: "model", parts:[{ functionCall... }]`;
|
|
209
|
+
- `role: "tool"` → `role: "tool", parts:[{ functionResponse... }]`;
|
|
210
|
+
- tools → `functionDeclarations`;
|
|
211
|
+
- 采样/安全配置 → `generationConfig` / `safetySettings`。
|
|
212
|
+
|
|
213
|
+
与现有协议的隔离性:
|
|
214
|
+
- `gemini-messages` 只在 providerProtocol 显式配置为 `"gemini-messages"` 时参与路由,且 codec 文件和分支独立存在:
|
|
215
|
+
- 不修改 `openai-chat`、`openai-responses`、`anthropic-messages` 的现有逻辑;
|
|
216
|
+
- 中段 Chat 工具治理/最终器不依赖具体 provider 协议,只认 canonical Chat completion。
|
|
217
|
+
- RouteCodex 主包侧仅需:
|
|
218
|
+
- `providerType: "gemini"` → `providerProtocol: "gemini-messages"`;
|
|
219
|
+
- Provider 继续复用 OpenAIStandard,仅负责 HTTP 通信。
|
|
220
|
+
|
|
221
|
+
测试与回环(规划):
|
|
222
|
+
- 类似 Anthropic/Responses,将新增:
|
|
223
|
+
- `gemini-request-closed-loop.ts`:Gemini 请求 → Chat 请求 → Gemini 请求',检查字段/工具/role 数量与顺序一致。
|
|
224
|
+
- `gemini-in-out-closed-loop.ts`:通过 routecodex-adapter 的 `processIncoming` / `processOutgoing` 对真实 codex-samples 做闭环。
|
|
225
|
+
- 如有需要,扩展 streaming 测试,验证 `streamGenerateContent` → Chat SSE delta → Responses/Anthropic SSE 的一致性。
|
|
226
|
+
|
|
227
|
+
|
|
228
|
+
## 后半段:主要处理点与职责
|
|
229
|
+
|
|
230
|
+
- request-shape(v2/conversion/openai-chat/request-shape.ts)
|
|
231
|
+
- 统一 messages.content 为 string
|
|
232
|
+
- 删除不支持字段(如 stream)
|
|
233
|
+
- request-tools-stage(v2/conversion/openai-chat/request-tools-stage.ts)
|
|
234
|
+
- canonicalizeChatResponseTools:不变式(content=null,finish_reason=tool_calls)
|
|
235
|
+
- jsonish.repairArgumentsToString:把任意形态 arguments 修复为安全 JSON 字符串
|
|
236
|
+
- 工具 ID 生成/去重
|
|
237
|
+
- MCP 两步暴露(仅在后半段)
|
|
238
|
+
- response-shape(v2/conversion/openai-chat/response-shape.ts)
|
|
239
|
+
- Chat 响应标准化;think/推理文本按端点策略保留/清理
|
|
240
|
+
- response-tools-stage(v2/conversion/openai-chat/response-tools-stage.ts)
|
|
241
|
+
- role='tool' 与 tool_calls.id 配对
|
|
242
|
+
- Responses 反向桥接(仅映射,不治理):required_action + items/output 还原
|
|
243
|
+
|
|
244
|
+
## 流式(SSE)策略
|
|
245
|
+
- 默认不上游直通(provider 配置未显式允许时)。
|
|
246
|
+
- 前半段把 SSE 合成为非流 JSON;后半段统一处理,再需要时用本包 streaming 模块合成 Responses SSE。
|
|
247
|
+
|
|
248
|
+
## 快照与排错
|
|
249
|
+
- 快照目录:`~/.routecodex/codex-samples/<endpoint>/`
|
|
250
|
+
- `*_http-request.json` / `*_http-request.parsed.json`
|
|
251
|
+
- `*_pipeline.llmswitch.request.post.json`(进入后半段前的 Chat 形状)
|
|
252
|
+
- `*_pipeline.provider.request.pre.json`(上游请求体,顶层仅 Chat 字段)
|
|
253
|
+
- 常见 1214 根因:
|
|
254
|
+
- 缺失用户消息(Responses 输入未包含 user 文本,且前半段不兜底)
|
|
255
|
+
- 顶层出现 data/metadata/stream 等额外键(应移除“添加逻辑”,而非末端清理)
|
|
256
|
+
|
|
257
|
+
## 设计原则与边界
|
|
258
|
+
- 工具治理唯一在后半段;前半段绝不进行文本工具收割/参数修复
|
|
259
|
+
- 兼容层只做 provider 特定最小映射;Provider 只做 HTTP 通信
|
|
260
|
+
- Fail Fast:形状不合规直接报错,不做隐藏兜底
|
|
261
|
+
|
|
262
|
+
## 版本与构建
|
|
263
|
+
- 构建:`npm run build`
|
|
264
|
+
- 打包:`npm pack`
|
|
265
|
+
- 发布:`npm publish`
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* LLMSwitch V2 API - 统一对外接口
|
|
3
|
+
*
|
|
4
|
+
* 提供 V2 版统一对外接口,保持向后兼容,同时支持新功能
|
|
5
|
+
*/
|
|
6
|
+
export { LLMSwitchEngineV2 } from '../core/llmswitch-engine-v2.js';
|
|
7
|
+
export { LLMSwitchFactoryV2, createLLMSwitchV2 } from '../core/llmswitch-factory-v2.js';
|
|
8
|
+
export type { LLMSwitchV2Config, EndpointType, ProtocolType, ProcessingMode, LLMSwitchHookContext, LLMSwitchHookStage, SSEEvent, SSEProcessingResult, ProtocolConversionData, ToolProcessingData, LLMSwitchProcessingResult, LLMSwitchErrorInfo as LLMSwitchError, LLMSwitchMetrics, LLMSwitchHealthCheck, ILLMSwitchV2 } from './llmswitch-types.js';
|
|
9
|
+
export type { ConfigValidationResult } from './llmswitch-config.js';
|
|
10
|
+
export { DEFAULT_LLSWITCH_CONFIG, validateLLMSwitchConfig, mergeConfig, createConfigFromEnvironment } from './llmswitch-config.js';
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* LLMSwitch V2 API - 统一对外接口
|
|
3
|
+
*
|
|
4
|
+
* 提供 V2 版统一对外接口,保持向后兼容,同时支持新功能
|
|
5
|
+
*/
|
|
6
|
+
// 核心实现
|
|
7
|
+
export { LLMSwitchEngineV2 } from '../core/llmswitch-engine-v2.js';
|
|
8
|
+
export { LLMSwitchFactoryV2, createLLMSwitchV2 } from '../core/llmswitch-factory-v2.js';
|
|
9
|
+
// 默认配置和验证
|
|
10
|
+
export { DEFAULT_LLSWITCH_CONFIG, validateLLMSwitchConfig, mergeConfig, createConfigFromEnvironment } from './llmswitch-config.js';
|
|
11
|
+
// V2 与 V1 解耦:不再从此处导出任何 V1 相关接口
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* LLMSwitch V2 配置类型和默认配置
|
|
3
|
+
*
|
|
4
|
+
* 定义LLMSwitch V2的配置结构、验证和默认值
|
|
5
|
+
*/
|
|
6
|
+
import type { LLMSwitchV2Config } from './llmswitch-types.js';
|
|
7
|
+
export declare const DEFAULT_LLSWITCH_CONFIG: LLMSwitchV2Config;
|
|
8
|
+
export interface ConfigValidationResult {
|
|
9
|
+
valid: boolean;
|
|
10
|
+
errors: string[];
|
|
11
|
+
warnings: string[];
|
|
12
|
+
}
|
|
13
|
+
export declare function validateLLMSwitchConfig(config: Partial<LLMSwitchV2Config>): ConfigValidationResult;
|
|
14
|
+
export declare function mergeConfig(base: LLMSwitchV2Config, override: Partial<LLMSwitchV2Config>): LLMSwitchV2Config;
|
|
15
|
+
export declare function createConfigFromEnvironment(): Partial<LLMSwitchV2Config>;
|