@jsonstudio/llms 0.4.2 → 0.4.4
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 +3 -1
- package/dist/bridge/routecodex-adapter.js +6 -3
- package/dist/config-unified/enhanced-path-resolver.js +14 -6
- package/dist/config-unified/unified-config.js +103 -59
- package/dist/conversion/codec-registry.js +4 -2
- package/dist/conversion/hub/pipeline/hub-pipeline.js +4 -5
- package/dist/conversion/hub/process/chat-process.js +258 -41
- package/dist/conversion/hub/response/provider-response.js +8 -2
- package/dist/conversion/hub/tool-governance/engine.d.ts +16 -0
- package/dist/conversion/hub/tool-governance/engine.js +266 -0
- package/dist/conversion/hub/tool-governance/index.d.ts +3 -0
- package/dist/conversion/hub/tool-governance/index.js +2 -0
- package/dist/conversion/hub/tool-governance/rules.d.ts +2 -0
- package/dist/conversion/hub/tool-governance/rules.js +76 -0
- package/dist/conversion/hub/tool-governance/types.d.ts +38 -0
- package/dist/conversion/index.d.ts +1 -0
- package/dist/conversion/index.js +1 -0
- package/dist/conversion/responses/responses-openai-bridge.js +5 -3
- package/dist/conversion/shared/responses-id-utils.js +18 -5
- package/dist/sse/sse-to-json/builders/response-builder.js +2 -1
- package/dist/sse/sse-to-json/chat-sse-to-json-converter.js +37 -23
- package/dist/sse/sse-to-json/parsers/sse-parser.js +20 -12
- package/dist/sse/sse-to-json/responses-sse-to-json-converter.d.ts +1 -0
- package/dist/sse/sse-to-json/responses-sse-to-json-converter.js +10 -8
- package/dist/sse/types/chat-types.d.ts +9 -6
- package/dist/sse/types/conversion-context.d.ts +14 -11
- package/dist/sse/types/core-interfaces.d.ts +6 -2
- package/dist/sse/types/index.d.ts +1 -1
- package/dist/sse/types/responses-types.d.ts +20 -20
- package/dist/sse/types/sse-events.d.ts +4 -3
- package/dist/sse/types/stream-state.d.ts +34 -39
- package/dist/sse/types/utility-types.d.ts +47 -43
- package/dist/sse/types/utility-types.js +10 -13
- package/dist/tools/tool-registry.js +156 -98
- package/package.json +6 -6
- package/dist/api/index.d.ts +0 -10
- package/dist/api/index.js +0 -11
- package/dist/api/llmswitch-config.d.ts +0 -15
- package/dist/api/llmswitch-config.js +0 -415
- package/dist/api/llmswitch-types.d.ts +0 -412
- package/dist/api/llmswitch-types.js +0 -60
- package/dist/bridge/routecodex-adapter.d.ts +0 -74
- package/dist/config/index.d.ts +0 -3
- package/dist/config/index.js +0 -5
- package/dist/config-unified/enhanced-path-resolver.d.ts +0 -5
- package/dist/config-unified/unified-config.d.ts +0 -26
- package/dist/conversion/codec-registry.d.ts +0 -10
- package/dist/conversion/codecs/anthropic-openai-codec.d.ts +0 -23
- package/dist/conversion/codecs/gemini-openai-codec.d.ts +0 -16
- package/dist/conversion/codecs/openai-openai-codec.d.ts +0 -12
- package/dist/conversion/codecs/responses-openai-codec.d.ts +0 -12
- package/dist/conversion/config/config-manager.d.ts +0 -212
- package/dist/conversion/conversion-v3/adapters/index.d.ts +0 -2
- package/dist/conversion/conversion-v3/adapters/index.js +0 -1
- package/dist/conversion/conversion-v3/adapters/v3-to-standard-adapter.d.ts +0 -38
- package/dist/conversion/conversion-v3/adapters/v3-to-standard-adapter.js +0 -55
- package/dist/conversion/conversion-v3/compatibility/compatibility-profiles.d.ts +0 -22
- package/dist/conversion/conversion-v3/compatibility/compatibility-profiles.js +0 -84
- package/dist/conversion/conversion-v3/compatibility/compatibility-stages.d.ts +0 -4
- package/dist/conversion/conversion-v3/compatibility/compatibility-stages.js +0 -285
- package/dist/conversion/conversion-v3/compatibility/index.d.ts +0 -3
- package/dist/conversion/conversion-v3/compatibility/index.js +0 -2
- package/dist/conversion/conversion-v3/config/default-configs.d.ts +0 -48
- package/dist/conversion/conversion-v3/config/default-configs.js +0 -1083
- package/dist/conversion/conversion-v3/config/index.d.ts +0 -5
- package/dist/conversion/conversion-v3/config/index.js +0 -5
- package/dist/conversion/conversion-v3/config/pipeline-config-manager.d.ts +0 -49
- package/dist/conversion/conversion-v3/config/pipeline-config-manager.js +0 -65
- package/dist/conversion/conversion-v3/index.d.ts +0 -11
- package/dist/conversion/conversion-v3/index.js +0 -17
- package/dist/conversion/conversion-v3/nodes/index.d.ts +0 -56
- package/dist/conversion/conversion-v3/nodes/index.js +0 -149
- package/dist/conversion/conversion-v3/nodes/input/anthropic-input-node.d.ts +0 -25
- package/dist/conversion/conversion-v3/nodes/input/anthropic-input-node.js +0 -56
- package/dist/conversion/conversion-v3/nodes/input/base-input-node.d.ts +0 -75
- package/dist/conversion/conversion-v3/nodes/input/base-input-node.js +0 -237
- package/dist/conversion/conversion-v3/nodes/input/chat-input-node.d.ts +0 -25
- package/dist/conversion/conversion-v3/nodes/input/chat-input-node.js +0 -56
- package/dist/conversion/conversion-v3/nodes/input/chat-shape-helpers.d.ts +0 -4
- package/dist/conversion/conversion-v3/nodes/input/chat-shape-helpers.js +0 -197
- package/dist/conversion/conversion-v3/nodes/input/gemini-input-node.d.ts +0 -16
- package/dist/conversion/conversion-v3/nodes/input/gemini-input-node.js +0 -125
- package/dist/conversion/conversion-v3/nodes/input/index.d.ts +0 -8
- package/dist/conversion/conversion-v3/nodes/input/index.js +0 -8
- package/dist/conversion/conversion-v3/nodes/input/input-decision.d.ts +0 -46
- package/dist/conversion/conversion-v3/nodes/input/input-decision.js +0 -125
- package/dist/conversion/conversion-v3/nodes/input/responses-input-node.d.ts +0 -20
- package/dist/conversion/conversion-v3/nodes/input/responses-input-node.js +0 -51
- package/dist/conversion/conversion-v3/nodes/output/anthropic-output-node.d.ts +0 -71
- package/dist/conversion/conversion-v3/nodes/output/anthropic-output-node.js +0 -320
- package/dist/conversion/conversion-v3/nodes/output/base-output-node.d.ts +0 -116
- package/dist/conversion/conversion-v3/nodes/output/base-output-node.js +0 -512
- package/dist/conversion/conversion-v3/nodes/output/index.d.ts +0 -7
- package/dist/conversion/conversion-v3/nodes/output/index.js +0 -7
- package/dist/conversion/conversion-v3/nodes/output/openai-output-node.d.ts +0 -71
- package/dist/conversion/conversion-v3/nodes/output/openai-output-node.js +0 -293
- package/dist/conversion/conversion-v3/nodes/output/output-decision.d.ts +0 -68
- package/dist/conversion/conversion-v3/nodes/output/output-decision.js +0 -161
- package/dist/conversion/conversion-v3/nodes/output/responses-output-node.d.ts +0 -64
- package/dist/conversion/conversion-v3/nodes/output/responses-output-node.js +0 -323
- package/dist/conversion/conversion-v3/nodes/process/base-process-node.d.ts +0 -72
- package/dist/conversion/conversion-v3/nodes/process/base-process-node.js +0 -246
- package/dist/conversion/conversion-v3/nodes/process/chat-process-node.d.ts +0 -135
- package/dist/conversion/conversion-v3/nodes/process/chat-process-node.js +0 -854
- package/dist/conversion/conversion-v3/nodes/process/compatibility-process-node.d.ts +0 -29
- package/dist/conversion/conversion-v3/nodes/process/compatibility-process-node.js +0 -181
- package/dist/conversion/conversion-v3/nodes/process/index.d.ts +0 -10
- package/dist/conversion/conversion-v3/nodes/process/index.js +0 -10
- package/dist/conversion/conversion-v3/nodes/process/passthrough-process-node.d.ts +0 -59
- package/dist/conversion/conversion-v3/nodes/process/passthrough-process-node.js +0 -243
- package/dist/conversion/conversion-v3/nodes/process/response-process-node.d.ts +0 -17
- package/dist/conversion/conversion-v3/nodes/process/response-process-node.js +0 -213
- package/dist/conversion/conversion-v3/nodes/process/tool-process-node.d.ts +0 -26
- package/dist/conversion/conversion-v3/nodes/process/tool-process-node.js +0 -299
- package/dist/conversion/conversion-v3/nodes/process/virtual-router-process-node.d.ts +0 -40
- package/dist/conversion/conversion-v3/nodes/process/virtual-router-process-node.js +0 -430
- package/dist/conversion/conversion-v3/nodes/response/anthropic-response-input-node.d.ts +0 -12
- package/dist/conversion/conversion-v3/nodes/response/anthropic-response-input-node.js +0 -129
- package/dist/conversion/conversion-v3/nodes/response/chat-to-responses-response-node.d.ts +0 -15
- package/dist/conversion/conversion-v3/nodes/response/chat-to-responses-response-node.js +0 -57
- package/dist/conversion/conversion-v3/nodes/response/index.d.ts +0 -4
- package/dist/conversion/conversion-v3/nodes/response/index.js +0 -4
- package/dist/conversion/conversion-v3/nodes/response/openai-response-input-node.d.ts +0 -15
- package/dist/conversion/conversion-v3/nodes/response/openai-response-input-node.js +0 -87
- package/dist/conversion/conversion-v3/nodes/response/response-utils.d.ts +0 -1
- package/dist/conversion/conversion-v3/nodes/response/response-utils.js +0 -1
- package/dist/conversion/conversion-v3/nodes/response/responses-response-input-node.d.ts +0 -12
- package/dist/conversion/conversion-v3/nodes/response/responses-response-input-node.js +0 -67
- package/dist/conversion/conversion-v3/nodes/sse/index.d.ts +0 -3
- package/dist/conversion/conversion-v3/nodes/sse/index.js +0 -3
- package/dist/conversion/conversion-v3/nodes/sse/sse-input-node.d.ts +0 -27
- package/dist/conversion/conversion-v3/nodes/sse/sse-input-node.js +0 -165
- package/dist/conversion/conversion-v3/nodes/sse/sse-output-node.d.ts +0 -19
- package/dist/conversion/conversion-v3/nodes/sse/sse-output-node.js +0 -267
- package/dist/conversion/conversion-v3/nodes/sse/sse-passthrough-node.d.ts +0 -18
- package/dist/conversion/conversion-v3/nodes/sse/sse-passthrough-node.js +0 -48
- package/dist/conversion/conversion-v3/pipelines/index.d.ts +0 -6
- package/dist/conversion/conversion-v3/pipelines/index.js +0 -6
- package/dist/conversion/conversion-v3/pipelines/super-pipeline.d.ts +0 -112
- package/dist/conversion/conversion-v3/pipelines/super-pipeline.js +0 -566
- package/dist/conversion/conversion-v3/response/provider-response-converter.d.ts +0 -28
- package/dist/conversion/conversion-v3/response/provider-response-converter.js +0 -249
- package/dist/conversion/conversion-v3/sse/index.d.ts +0 -140
- package/dist/conversion/conversion-v3/sse/index.js +0 -115
- package/dist/conversion/conversion-v3/sse/json-to-sse/anthropic-json-to-sse-converter.d.ts +0 -11
- package/dist/conversion/conversion-v3/sse/json-to-sse/anthropic-json-to-sse-converter.js +0 -79
- package/dist/conversion/conversion-v3/sse/json-to-sse/chat-json-to-sse-converter.d.ts +0 -79
- package/dist/conversion/conversion-v3/sse/json-to-sse/chat-json-to-sse-converter.js +0 -296
- package/dist/conversion/conversion-v3/sse/json-to-sse/event-generators/chat.d.ts +0 -55
- package/dist/conversion/conversion-v3/sse/json-to-sse/event-generators/chat.js +0 -233
- package/dist/conversion/conversion-v3/sse/json-to-sse/event-generators/responses.d.ts +0 -99
- package/dist/conversion/conversion-v3/sse/json-to-sse/event-generators/responses.js +0 -599
- package/dist/conversion/conversion-v3/sse/json-to-sse/index.d.ts +0 -6
- package/dist/conversion/conversion-v3/sse/json-to-sse/index.js +0 -7
- package/dist/conversion/conversion-v3/sse/json-to-sse/responses-json-to-sse-converter.d.ts +0 -79
- package/dist/conversion/conversion-v3/sse/json-to-sse/responses-json-to-sse-converter.js +0 -322
- package/dist/conversion/conversion-v3/sse/json-to-sse/sequencers/chat-sequencer.d.ts +0 -37
- package/dist/conversion/conversion-v3/sse/json-to-sse/sequencers/chat-sequencer.js +0 -218
- package/dist/conversion/conversion-v3/sse/json-to-sse/sequencers/responses-sequencer.d.ts +0 -40
- package/dist/conversion/conversion-v3/sse/json-to-sse/sequencers/responses-sequencer.js +0 -263
- package/dist/conversion/conversion-v3/sse/registry/sse-codec-registry.d.ts +0 -32
- package/dist/conversion/conversion-v3/sse/registry/sse-codec-registry.js +0 -106
- package/dist/conversion/conversion-v3/sse/shared/chat-serializer.d.ts +0 -4
- package/dist/conversion/conversion-v3/sse/shared/chat-serializer.js +0 -40
- package/dist/conversion/conversion-v3/sse/shared/constants.d.ts +0 -272
- package/dist/conversion/conversion-v3/sse/shared/constants.js +0 -321
- package/dist/conversion/conversion-v3/sse/shared/serializers/base-serializer.d.ts +0 -158
- package/dist/conversion/conversion-v3/sse/shared/serializers/base-serializer.js +0 -210
- package/dist/conversion/conversion-v3/sse/shared/serializers/chat-event-serializer.d.ts +0 -82
- package/dist/conversion/conversion-v3/sse/shared/serializers/chat-event-serializer.js +0 -275
- package/dist/conversion/conversion-v3/sse/shared/serializers/index.d.ts +0 -39
- package/dist/conversion/conversion-v3/sse/shared/serializers/index.js +0 -54
- package/dist/conversion/conversion-v3/sse/shared/serializers/responses-event-serializer.d.ts +0 -123
- package/dist/conversion/conversion-v3/sse/shared/serializers/responses-event-serializer.js +0 -356
- package/dist/conversion/conversion-v3/sse/shared/serializers/types.d.ts +0 -51
- package/dist/conversion/conversion-v3/sse/shared/serializers/types.js +0 -4
- package/dist/conversion/conversion-v3/sse/shared/utils.d.ts +0 -254
- package/dist/conversion/conversion-v3/sse/shared/utils.js +0 -543
- package/dist/conversion/conversion-v3/sse/shared/writer.d.ts +0 -111
- package/dist/conversion/conversion-v3/sse/shared/writer.js +0 -268
- package/dist/conversion/conversion-v3/sse/sse-to-json/anthropic-sse-to-json-converter.d.ts +0 -13
- package/dist/conversion/conversion-v3/sse/sse-to-json/anthropic-sse-to-json-converter.js +0 -139
- package/dist/conversion/conversion-v3/sse/sse-to-json/builders/response-builder.d.ts +0 -165
- package/dist/conversion/conversion-v3/sse/sse-to-json/builders/response-builder.js +0 -776
- package/dist/conversion/conversion-v3/sse/sse-to-json/chat-sse-to-json-converter.d.ts +0 -106
- package/dist/conversion/conversion-v3/sse/sse-to-json/chat-sse-to-json-converter.js +0 -540
- package/dist/conversion/conversion-v3/sse/sse-to-json/index.d.ts +0 -6
- package/dist/conversion/conversion-v3/sse/sse-to-json/index.js +0 -7
- package/dist/conversion/conversion-v3/sse/sse-to-json/parsers/sse-parser.d.ts +0 -73
- package/dist/conversion/conversion-v3/sse/sse-to-json/parsers/sse-parser.js +0 -332
- package/dist/conversion/conversion-v3/sse/sse-to-json/responses-sse-to-json-converter.d.ts +0 -59
- package/dist/conversion/conversion-v3/sse/sse-to-json/responses-sse-to-json-converter.js +0 -270
- package/dist/conversion/conversion-v3/sse/types/anthropic-types.d.ts +0 -87
- package/dist/conversion/conversion-v3/sse/types/anthropic-types.js +0 -5
- package/dist/conversion/conversion-v3/sse/types/chat-types.d.ts +0 -308
- package/dist/conversion/conversion-v3/sse/types/chat-types.js +0 -32
- package/dist/conversion/conversion-v3/sse/types/conversion-context.d.ts +0 -211
- package/dist/conversion/conversion-v3/sse/types/conversion-context.js +0 -20
- package/dist/conversion/conversion-v3/sse/types/core-interfaces.d.ts +0 -90
- package/dist/conversion/conversion-v3/sse/types/core-interfaces.js +0 -5
- package/dist/conversion/conversion-v3/sse/types/index.d.ts +0 -14
- package/dist/conversion/conversion-v3/sse/types/index.js +0 -7
- package/dist/conversion/conversion-v3/sse/types/responses-types.d.ts +0 -328
- package/dist/conversion/conversion-v3/sse/types/responses-types.js +0 -38
- package/dist/conversion/conversion-v3/sse/types/sse-events.d.ts +0 -180
- package/dist/conversion/conversion-v3/sse/types/sse-events.js +0 -150
- package/dist/conversion/conversion-v3/sse/types/stream-state.d.ts +0 -204
- package/dist/conversion/conversion-v3/sse/types/stream-state.js +0 -44
- package/dist/conversion/conversion-v3/sse/types/utility-types.d.ts +0 -230
- package/dist/conversion/conversion-v3/sse/types/utility-types.js +0 -49
- package/dist/conversion/conversion-v3/standards/context-adapter.d.ts +0 -146
- package/dist/conversion/conversion-v3/standards/context-adapter.js +0 -438
- package/dist/conversion/conversion-v3/standards/errors.d.ts +0 -38
- package/dist/conversion/conversion-v3/standards/errors.js +0 -27
- package/dist/conversion/conversion-v3/standards/index.d.ts +0 -15
- package/dist/conversion/conversion-v3/standards/index.js +0 -11
- package/dist/conversion/conversion-v3/standards/node-capabilities.d.ts +0 -123
- package/dist/conversion/conversion-v3/standards/node-capabilities.js +0 -330
- package/dist/conversion/conversion-v3/standards/pipeline-context.d.ts +0 -237
- package/dist/conversion/conversion-v3/standards/pipeline-context.js +0 -84
- package/dist/conversion/conversion-v3/standards/pipeline-node.d.ts +0 -196
- package/dist/conversion/conversion-v3/standards/pipeline-node.js +0 -316
- package/dist/conversion/conversion-v3/standards/snapshot-handles.d.ts +0 -24
- package/dist/conversion/conversion-v3/standards/snapshot-handles.js +0 -49
- package/dist/conversion/conversion-v3/types/config-types.d.ts +0 -242
- package/dist/conversion/conversion-v3/types/config-types.js +0 -13
- package/dist/conversion/conversion-v3/types/index.d.ts +0 -8
- package/dist/conversion/conversion-v3/types/index.js +0 -11
- package/dist/conversion/conversion-v3/types/node-types.d.ts +0 -211
- package/dist/conversion/conversion-v3/types/node-types.js +0 -20
- package/dist/conversion/conversion-v3/types/pipeline-types.d.ts +0 -246
- package/dist/conversion/conversion-v3/types/pipeline-types.js +0 -26
- package/dist/conversion/conversion-v3/types/request-types.d.ts +0 -293
- package/dist/conversion/conversion-v3/types/request-types.js +0 -26
- package/dist/conversion/conversion-v3/utils/provider-payload-sanitizer.d.ts +0 -10
- package/dist/conversion/conversion-v3/utils/provider-payload-sanitizer.js +0 -103
- package/dist/conversion/conversion-v3/validations/index.d.ts +0 -8
- package/dist/conversion/conversion-v3/validations/index.js +0 -7
- package/dist/conversion/conversion-v3/validations/node-graph-validator.d.ts +0 -116
- package/dist/conversion/conversion-v3/validations/node-graph-validator.js +0 -505
- package/dist/conversion/conversion-v3/validations/tool-governance-enforcer.d.ts +0 -139
- package/dist/conversion/conversion-v3/validations/tool-governance-enforcer.js +0 -338
- package/dist/conversion/hub/config/types.d.ts +0 -26
- package/dist/conversion/hub/core/detour-registry.d.ts +0 -9
- package/dist/conversion/hub/core/hub-context.d.ts +0 -21
- package/dist/conversion/hub/core/index.d.ts +0 -3
- package/dist/conversion/hub/core/stage-driver.d.ts +0 -30
- package/dist/conversion/hub/format-adapters/anthropic-format-adapter.d.ts +0 -16
- package/dist/conversion/hub/format-adapters/chat-format-adapter.d.ts +0 -17
- package/dist/conversion/hub/format-adapters/gemini-format-adapter.d.ts +0 -16
- package/dist/conversion/hub/format-adapters/index.d.ts +0 -21
- package/dist/conversion/hub/format-adapters/responses-format-adapter.d.ts +0 -17
- package/dist/conversion/hub/hub-feature.d.ts +0 -1
- package/dist/conversion/hub/node-support.d.ts +0 -19
- package/dist/conversion/hub/pipeline/hub-pipeline.d.ts +0 -68
- package/dist/conversion/hub/pipelines/inbound.d.ts +0 -22
- package/dist/conversion/hub/pipelines/outbound.d.ts +0 -22
- package/dist/conversion/hub/process/chat-process.d.ts +0 -13
- package/dist/conversion/hub/registry.d.ts +0 -28
- package/dist/conversion/hub/response/chat-response-utils.d.ts +0 -6
- package/dist/conversion/hub/response/provider-response.d.ts +0 -20
- package/dist/conversion/hub/response/response-mappers.d.ts +0 -19
- package/dist/conversion/hub/response/response-runtime.d.ts +0 -3
- package/dist/conversion/hub/semantic-mappers/anthropic-mapper.d.ts +0 -7
- package/dist/conversion/hub/semantic-mappers/chat-mapper.d.ts +0 -7
- package/dist/conversion/hub/semantic-mappers/gemini-mapper.d.ts +0 -7
- package/dist/conversion/hub/semantic-mappers/index.d.ts +0 -4
- package/dist/conversion/hub/semantic-mappers/responses-mapper.d.ts +0 -21
- package/dist/conversion/hub/snapshot-recorder.d.ts +0 -12
- package/dist/conversion/hub/standardized-bridge.d.ts +0 -12
- package/dist/conversion/hub/types/chat-envelope.d.ts +0 -67
- package/dist/conversion/hub/types/chat-schema.d.ts +0 -112
- package/dist/conversion/hub/types/errors.d.ts +0 -5
- package/dist/conversion/hub/types/format-envelope.d.ts +0 -7
- package/dist/conversion/hub/types/index.d.ts +0 -6
- package/dist/conversion/hub/types/json.d.ts +0 -9
- package/dist/conversion/hub/types/node.d.ts +0 -31
- package/dist/conversion/hub/types/standardized.d.ts +0 -94
- package/dist/conversion/responses/responses-openai-bridge.d.ts +0 -95
- package/dist/conversion/schema-validator.d.ts +0 -7
- package/dist/conversion/shared/args-mapping.d.ts +0 -18
- package/dist/conversion/shared/chat-request-filters.d.ts +0 -9
- package/dist/conversion/shared/jsonish.d.ts +0 -3
- package/dist/conversion/shared/mcp-injection.d.ts +0 -2
- package/dist/conversion/shared/media.d.ts +0 -1
- package/dist/conversion/shared/openai-finalizer.d.ts +0 -9
- package/dist/conversion/shared/openai-message-normalize.d.ts +0 -1
- package/dist/conversion/shared/payload-budget.d.ts +0 -13
- package/dist/conversion/shared/reasoning-mapping.d.ts +0 -5
- package/dist/conversion/shared/responses-conversation-store.d.ts +0 -41
- package/dist/conversion/shared/responses-id-utils.d.ts +0 -7
- package/dist/conversion/shared/responses-instructions.d.ts +0 -1
- package/dist/conversion/shared/responses-metadata.d.ts +0 -1
- package/dist/conversion/shared/responses-request-adapter.d.ts +0 -66
- package/dist/conversion/shared/snapshot-hooks.d.ts +0 -12
- package/dist/conversion/shared/streaming-text-extractor.d.ts +0 -26
- package/dist/conversion/shared/text-markup-normalizer.d.ts +0 -9
- package/dist/conversion/shared/tool-canonicalizer.d.ts +0 -2
- package/dist/conversion/shared/tool-filter-pipeline.d.ts +0 -17
- package/dist/conversion/shared/tool-governor.d.ts +0 -27
- package/dist/conversion/shared/tool-harvester.d.ts +0 -31
- package/dist/conversion/shared/tool-mapping.d.ts +0 -10
- package/dist/conversion/shared/tooling.d.ts +0 -26
- package/dist/conversion/types.d.ts +0 -33
- package/dist/core/index.d.ts +0 -6
- package/dist/core/index.js +0 -9
- package/dist/core/llmswitch-engine-v2.d.ts +0 -132
- package/dist/core/llmswitch-engine-v2.js +0 -649
- package/dist/core/llmswitch-factory-v2.d.ts +0 -123
- package/dist/core/llmswitch-factory-v2.js +0 -521
- package/dist/endpoints/base-endpoint-handler.d.ts +0 -128
- package/dist/endpoints/base-endpoint-handler.js +0 -545
- package/dist/endpoints/chat-endpoint-handler.d.ts +0 -115
- package/dist/endpoints/chat-endpoint-handler.js +0 -218
- package/dist/endpoints/endpoint-router.d.ts +0 -127
- package/dist/endpoints/endpoint-router.js +0 -438
- package/dist/endpoints/index.d.ts +0 -13
- package/dist/endpoints/index.js +0 -11
- package/dist/endpoints/messages-endpoint-handler.d.ts +0 -171
- package/dist/endpoints/messages-endpoint-handler.js +0 -238
- package/dist/endpoints/responses-endpoint-handler.d.ts +0 -147
- package/dist/endpoints/responses-endpoint-handler.js +0 -233
- package/dist/filters/builtin/add-fields-filter.d.ts +0 -8
- package/dist/filters/builtin/blacklist-filter.d.ts +0 -8
- package/dist/filters/builtin/whitelist-filter.d.ts +0 -8
- package/dist/filters/engine.d.ts +0 -16
- package/dist/filters/index.d.ts +0 -19
- package/dist/filters/special/request-streaming-to-nonstreaming.d.ts +0 -12
- package/dist/filters/special/request-tool-choice-policy.d.ts +0 -11
- package/dist/filters/special/request-tool-list-filter.d.ts +0 -11
- package/dist/filters/special/request-toolcalls-stringify.d.ts +0 -10
- package/dist/filters/special/request-tools-normalize.d.ts +0 -12
- package/dist/filters/special/response-finish-invariants.d.ts +0 -11
- package/dist/filters/special/response-openai-to-responses-bridge.d.ts +0 -13
- package/dist/filters/special/response-tool-arguments-blacklist.d.ts +0 -12
- package/dist/filters/special/response-tool-arguments-schema-converge.d.ts +0 -13
- package/dist/filters/special/response-tool-arguments-stringify.d.ts +0 -9
- package/dist/filters/special/response-tool-arguments-toon-decode.d.ts +0 -10
- package/dist/filters/special/response-tool-arguments-whitelist.d.ts +0 -11
- package/dist/filters/special/response-tool-text-canonicalize.d.ts +0 -10
- package/dist/filters/special/tool-filter-hooks.d.ts +0 -19
- package/dist/filters/special/tool-post-constraints.d.ts +0 -31
- package/dist/filters/types.d.ts +0 -68
- package/dist/filters/utils/fieldmap-loader.d.ts +0 -2
- package/dist/filters/utils/snapshot-writer.d.ts +0 -10
- package/dist/guidance/index.d.ts +0 -3
- package/dist/hooks/hooks-integration.d.ts +0 -161
- package/dist/hooks/hooks-integration.js +0 -519
- package/dist/hooks/index.d.ts +0 -10
- package/dist/hooks/index.js +0 -13
- package/dist/html-to-markdown.d.ts +0 -5
- package/dist/html-to-markdown.js +0 -66
- package/dist/http/sse-response.d.ts +0 -22
- package/dist/router/virtual-router/bootstrap.d.ts +0 -6
- package/dist/router/virtual-router/classifier.d.ts +0 -10
- package/dist/router/virtual-router/engine.d.ts +0 -35
- package/dist/router/virtual-router/error-center.d.ts +0 -10
- package/dist/router/virtual-router/features.d.ts +0 -3
- package/dist/router/virtual-router/health-manager.d.ts +0 -18
- package/dist/router/virtual-router/load-balancer.d.ts +0 -18
- package/dist/router/virtual-router/provider-registry.d.ts +0 -11
- package/dist/router/virtual-router/types.d.ts +0 -206
- package/dist/sse/json-to-sse/anthropic-json-to-sse-converter.d.ts +0 -11
- package/dist/sse/json-to-sse/chat-json-to-sse-converter.d.ts +0 -79
- package/dist/sse/json-to-sse/event-generators/chat.d.ts +0 -55
- package/dist/sse/json-to-sse/event-generators/responses.d.ts +0 -99
- package/dist/sse/json-to-sse/index.d.ts +0 -6
- package/dist/sse/json-to-sse/responses-json-to-sse-converter.d.ts +0 -79
- package/dist/sse/json-to-sse/sequencers/chat-sequencer.d.ts +0 -37
- package/dist/sse/json-to-sse/sequencers/responses-sequencer.d.ts +0 -40
- package/dist/sse/registry/sse-codec-registry.d.ts +0 -32
- package/dist/sse/shared/chat-serializer.d.ts +0 -4
- package/dist/sse/shared/constants.d.ts +0 -272
- package/dist/sse/shared/serializers/base-serializer.d.ts +0 -158
- package/dist/sse/shared/serializers/chat-event-serializer.d.ts +0 -82
- package/dist/sse/shared/serializers/index.d.ts +0 -39
- package/dist/sse/shared/serializers/responses-event-serializer.d.ts +0 -123
- package/dist/sse/shared/serializers/types.d.ts +0 -51
- package/dist/sse/shared/utils.d.ts +0 -254
- package/dist/sse/shared/writer.d.ts +0 -111
- package/dist/sse/sse-to-json/anthropic-sse-to-json-converter.d.ts +0 -13
- package/dist/sse/sse-to-json/builders/response-builder.d.ts +0 -165
- package/dist/sse/sse-to-json/chat-sse-to-json-converter.d.ts +0 -106
- package/dist/sse/sse-to-json/index.d.ts +0 -6
- package/dist/sse/sse-to-json/parsers/sse-parser.d.ts +0 -73
- package/dist/sse/types/anthropic-types.d.ts +0 -87
- package/dist/tools/proxy/anthropic-tool-proxy.d.ts +0 -19
- package/dist/tools/proxy/anthropic-tool-proxy.js +0 -57
- package/dist/tools/proxy/executors/web-fetch.d.ts +0 -6
- package/dist/tools/proxy/executors/web-fetch.js +0 -39
- package/dist/tools/proxy/registry.d.ts +0 -8
- package/dist/tools/proxy/registry.js +0 -14
- package/dist/tools/proxy/types.d.ts +0 -29
- package/dist/tools/tool-registry.d.ts +0 -8
- package/dist/tools/web-fetch-html.d.ts +0 -15
- package/dist/tools/web-fetch-html.js +0 -83
- package/dist/utils/conversion-adapter.d.ts +0 -65
- package/dist/utils/conversion-adapter.js +0 -183
- package/dist/utils/error-factory.d.ts +0 -88
- package/dist/utils/error-factory.js +0 -138
- package/dist/utils/error-utils.d.ts +0 -334
- package/dist/utils/error-utils.js +0 -782
- package/dist/utils/index.d.ts +0 -8
- package/dist/utils/index.js +0 -13
- package/dist/utils/performance-utils.d.ts +0 -205
- package/dist/utils/performance-utils.js +0 -440
- package/dist/utils/profile-mapper.d.ts +0 -32
- package/dist/utils/profile-mapper.js +0 -269
- package/dist/utils/request-processor.d.ts +0 -52
- package/dist/utils/request-processor.js +0 -210
- package/dist/utils/request-utils.d.ts +0 -117
- package/dist/utils/request-utils.js +0 -333
- package/dist/utils/response-utils.d.ts +0 -127
- package/dist/utils/response-utils.js +0 -516
- package/dist/utils/token-counter.d.ts +0 -89
- package/dist/utils/token-counter.js +0 -541
- /package/dist/{tools/proxy → conversion/hub/tool-governance}/types.js +0 -0
|
@@ -5,6 +5,7 @@ import { buildProcessedRequestFromChatResponse } from './chat-response-utils.js'
|
|
|
5
5
|
import { buildAnthropicResponseFromChat } from './response-runtime.js';
|
|
6
6
|
import { buildResponsesPayloadFromChat } from '../../responses/responses-openai-bridge.js';
|
|
7
7
|
import { defaultSseCodecRegistry } from '../../../sse/registry/sse-codec-registry.js';
|
|
8
|
+
import { ToolGovernanceEngine } from '../tool-governance/index.js';
|
|
8
9
|
import { ChatFormatAdapter } from '../format-adapters/chat-format-adapter.js';
|
|
9
10
|
import { ResponsesFormatAdapter } from '../format-adapters/responses-format-adapter.js';
|
|
10
11
|
import { AnthropicFormatAdapter } from '../format-adapters/anthropic-format-adapter.js';
|
|
@@ -21,6 +22,7 @@ const STAGES = {
|
|
|
21
22
|
ssePre: 'resp_sse_output_pre',
|
|
22
23
|
ssePost: 'resp_sse_output_post'
|
|
23
24
|
};
|
|
25
|
+
const toolGovernanceEngine = new ToolGovernanceEngine();
|
|
24
26
|
const PROVIDER_RESPONSE_REGISTRY = {
|
|
25
27
|
'openai-chat': {
|
|
26
28
|
protocol: 'openai-chat',
|
|
@@ -155,12 +157,16 @@ export async function convertProviderResponse(options) {
|
|
|
155
157
|
recordStage(options.stageRecorder, STAGES.formatParse, formatEnvelope);
|
|
156
158
|
const chatResponse = await mapper.toChatCompletion(formatEnvelope, options.context);
|
|
157
159
|
recordStage(options.stageRecorder, STAGES.semanticMap, chatResponse);
|
|
158
|
-
const
|
|
160
|
+
const filtered = await runChatResponseToolFilters(chatResponse, {
|
|
159
161
|
entryEndpoint: options.entryEndpoint,
|
|
160
162
|
requestId: options.context.requestId,
|
|
161
163
|
profile: 'openai-chat'
|
|
162
164
|
});
|
|
163
|
-
|
|
165
|
+
const { payload: governed, summary: responseGovernance } = toolGovernanceEngine.governResponse(filtered, clientProtocol);
|
|
166
|
+
recordStage(options.stageRecorder, STAGES.governance, {
|
|
167
|
+
...governed,
|
|
168
|
+
__toolGovernanceSummary: responseGovernance
|
|
169
|
+
});
|
|
164
170
|
const finalized = await finalizeOpenAIChatResponse(governed, {
|
|
165
171
|
requestId: options.context.requestId,
|
|
166
172
|
endpoint: options.entryEndpoint,
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import type { JsonObject } from '../types/json.js';
|
|
2
|
+
import type { StandardizedRequest } from '../types/standardized.js';
|
|
3
|
+
import type { GovernedChatCompletionPayload, GovernedStandardizedRequest, ToolGovernanceProtocol, ToolGovernanceRegistry } from './types.js';
|
|
4
|
+
export declare class ToolGovernanceError extends Error {
|
|
5
|
+
readonly protocol: ToolGovernanceProtocol;
|
|
6
|
+
readonly direction: 'request' | 'response';
|
|
7
|
+
readonly field: string;
|
|
8
|
+
constructor(message: string, protocol: ToolGovernanceProtocol, direction: 'request' | 'response', field: string);
|
|
9
|
+
}
|
|
10
|
+
export declare class ToolGovernanceEngine {
|
|
11
|
+
private readonly registry;
|
|
12
|
+
constructor(registry?: ToolGovernanceRegistry);
|
|
13
|
+
governRequest(request: StandardizedRequest, protocol: ToolGovernanceProtocol): GovernedStandardizedRequest;
|
|
14
|
+
governResponse(payload: JsonObject, protocol: ToolGovernanceProtocol): GovernedChatCompletionPayload;
|
|
15
|
+
private resolveRules;
|
|
16
|
+
}
|
|
@@ -0,0 +1,266 @@
|
|
|
1
|
+
import { DEFAULT_TOOL_GOVERNANCE_RULES } from './rules.js';
|
|
2
|
+
export class ToolGovernanceError extends Error {
|
|
3
|
+
protocol;
|
|
4
|
+
direction;
|
|
5
|
+
field;
|
|
6
|
+
constructor(message, protocol, direction, field) {
|
|
7
|
+
super(message);
|
|
8
|
+
this.protocol = protocol;
|
|
9
|
+
this.direction = direction;
|
|
10
|
+
this.field = field;
|
|
11
|
+
this.name = 'ToolGovernanceError';
|
|
12
|
+
}
|
|
13
|
+
}
|
|
14
|
+
function normalizeProtocol(protocol) {
|
|
15
|
+
if (!protocol)
|
|
16
|
+
return 'openai-chat';
|
|
17
|
+
const normalized = String(protocol).toLowerCase();
|
|
18
|
+
if (normalized === 'anthropic-messages') {
|
|
19
|
+
return 'anthropic';
|
|
20
|
+
}
|
|
21
|
+
if (normalized === 'gemini-chat') {
|
|
22
|
+
return 'gemini';
|
|
23
|
+
}
|
|
24
|
+
if (normalized === 'responses' || normalized === 'openai-responses') {
|
|
25
|
+
return 'openai-responses';
|
|
26
|
+
}
|
|
27
|
+
if (normalized === 'openai-chat') {
|
|
28
|
+
return 'openai-chat';
|
|
29
|
+
}
|
|
30
|
+
return protocol;
|
|
31
|
+
}
|
|
32
|
+
export class ToolGovernanceEngine {
|
|
33
|
+
registry;
|
|
34
|
+
constructor(registry = DEFAULT_TOOL_GOVERNANCE_RULES) {
|
|
35
|
+
this.registry = registry;
|
|
36
|
+
}
|
|
37
|
+
governRequest(request, protocol) {
|
|
38
|
+
const rules = this.resolveRules(protocol, 'request');
|
|
39
|
+
if (!rules) {
|
|
40
|
+
return {
|
|
41
|
+
request,
|
|
42
|
+
summary: buildSummary(protocol, 'request', false)
|
|
43
|
+
};
|
|
44
|
+
}
|
|
45
|
+
const stats = createStats(protocol, 'request');
|
|
46
|
+
const sanitizedMessages = request.messages.map((msg) => sanitizeStandardizedMessage(msg, rules, stats));
|
|
47
|
+
const sanitizedTools = request.tools?.map((tool) => sanitizeStandardizedTool(tool, rules, stats));
|
|
48
|
+
const governed = {
|
|
49
|
+
...request,
|
|
50
|
+
messages: sanitizedMessages,
|
|
51
|
+
tools: sanitizedTools,
|
|
52
|
+
metadata: {
|
|
53
|
+
...request.metadata,
|
|
54
|
+
toolGovernance: {
|
|
55
|
+
...request.metadata?.toolGovernance,
|
|
56
|
+
request: finalizeSummary(stats)
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
};
|
|
60
|
+
return {
|
|
61
|
+
request: governed,
|
|
62
|
+
summary: finalizeSummary(stats)
|
|
63
|
+
};
|
|
64
|
+
}
|
|
65
|
+
governResponse(payload, protocol) {
|
|
66
|
+
const rules = this.resolveRules(protocol, 'response');
|
|
67
|
+
if (!rules) {
|
|
68
|
+
return {
|
|
69
|
+
payload,
|
|
70
|
+
summary: buildSummary(protocol, 'response', false)
|
|
71
|
+
};
|
|
72
|
+
}
|
|
73
|
+
const stats = createStats(protocol, 'response');
|
|
74
|
+
const cloned = JSON.parse(JSON.stringify(payload));
|
|
75
|
+
const choices = Array.isArray(cloned?.choices) ? cloned.choices : [];
|
|
76
|
+
for (const choice of choices) {
|
|
77
|
+
sanitizeChatCompletionChoice(choice, rules, stats);
|
|
78
|
+
}
|
|
79
|
+
if (Array.isArray(cloned?.tool_calls)) {
|
|
80
|
+
cloned.tool_calls = cloned.tool_calls.map((tc) => sanitizeChatCompletionToolCall(tc, rules, stats));
|
|
81
|
+
}
|
|
82
|
+
return {
|
|
83
|
+
payload: cloned,
|
|
84
|
+
summary: finalizeSummary(stats)
|
|
85
|
+
};
|
|
86
|
+
}
|
|
87
|
+
resolveRules(protocol, direction) {
|
|
88
|
+
const resolved = normalizeProtocol(protocol);
|
|
89
|
+
const entry = this.registry[resolved] ?? this.registry['openai-chat'];
|
|
90
|
+
return entry?.[direction];
|
|
91
|
+
}
|
|
92
|
+
}
|
|
93
|
+
function sanitizeStandardizedMessage(message, rules, stats) {
|
|
94
|
+
let changed = false;
|
|
95
|
+
const next = { ...message };
|
|
96
|
+
if (Array.isArray(message.tool_calls) && message.tool_calls.length) {
|
|
97
|
+
next.tool_calls = message.tool_calls.map((call) => sanitizeToolCall(call, rules, stats));
|
|
98
|
+
if (next.tool_calls !== message.tool_calls) {
|
|
99
|
+
changed = true;
|
|
100
|
+
}
|
|
101
|
+
}
|
|
102
|
+
if (typeof message.name === 'string' || message.role === 'tool') {
|
|
103
|
+
const sanitizedName = sanitizeName(message.name, rules, stats, 'message.name');
|
|
104
|
+
if (sanitizedName !== message.name) {
|
|
105
|
+
next.name = sanitizedName;
|
|
106
|
+
changed = true;
|
|
107
|
+
}
|
|
108
|
+
}
|
|
109
|
+
return changed ? next : message;
|
|
110
|
+
}
|
|
111
|
+
function sanitizeStandardizedTool(tool, rules, stats) {
|
|
112
|
+
const sanitizedName = sanitizeName(tool.function?.name, rules, stats, 'tool.function.name');
|
|
113
|
+
if (sanitizedName === tool.function?.name) {
|
|
114
|
+
return tool;
|
|
115
|
+
}
|
|
116
|
+
return {
|
|
117
|
+
...tool,
|
|
118
|
+
function: {
|
|
119
|
+
...tool.function,
|
|
120
|
+
name: sanitizedName
|
|
121
|
+
}
|
|
122
|
+
};
|
|
123
|
+
}
|
|
124
|
+
function sanitizeToolCall(call, rules, stats) {
|
|
125
|
+
if (!call?.function) {
|
|
126
|
+
return call;
|
|
127
|
+
}
|
|
128
|
+
const sanitizedName = sanitizeName(call.function.name, rules, stats, 'tool_call.function.name');
|
|
129
|
+
if (sanitizedName === call.function.name) {
|
|
130
|
+
return call;
|
|
131
|
+
}
|
|
132
|
+
return {
|
|
133
|
+
...call,
|
|
134
|
+
function: {
|
|
135
|
+
...call.function,
|
|
136
|
+
name: sanitizedName
|
|
137
|
+
}
|
|
138
|
+
};
|
|
139
|
+
}
|
|
140
|
+
function sanitizeChatCompletionChoice(choice, rules, stats) {
|
|
141
|
+
const message = choice?.message;
|
|
142
|
+
if (!message || typeof message !== 'object') {
|
|
143
|
+
return;
|
|
144
|
+
}
|
|
145
|
+
const msg = message;
|
|
146
|
+
if (Array.isArray(msg.tool_calls)) {
|
|
147
|
+
msg.tool_calls = msg.tool_calls.map((tc, index) => sanitizeChatCompletionToolCall(tc, rules, stats, `choices[].message.tool_calls[${index}].function.name`));
|
|
148
|
+
}
|
|
149
|
+
if (msg.function_call && typeof msg.function_call === 'object') {
|
|
150
|
+
const orig = msg.function_call.name;
|
|
151
|
+
const sanitizedName = sanitizeName(orig, rules, stats, 'choices[].message.function_call.name');
|
|
152
|
+
msg.function_call.name = sanitizedName;
|
|
153
|
+
}
|
|
154
|
+
if (typeof msg.name === 'string' || msg.role === 'tool') {
|
|
155
|
+
msg.name = sanitizeName(msg.name, rules, stats, 'choices[].message.name');
|
|
156
|
+
}
|
|
157
|
+
}
|
|
158
|
+
function sanitizeChatCompletionToolCall(tc, rules, stats, context = 'choices[].message.tool_calls[].function.name') {
|
|
159
|
+
if (!tc || typeof tc !== 'object') {
|
|
160
|
+
return tc;
|
|
161
|
+
}
|
|
162
|
+
const fn = tc.function;
|
|
163
|
+
if (!fn || typeof fn !== 'object') {
|
|
164
|
+
return tc;
|
|
165
|
+
}
|
|
166
|
+
const sanitizedName = sanitizeName(fn.name, rules, stats, context);
|
|
167
|
+
if (sanitizedName === fn.name) {
|
|
168
|
+
return tc;
|
|
169
|
+
}
|
|
170
|
+
return {
|
|
171
|
+
...tc,
|
|
172
|
+
function: {
|
|
173
|
+
...fn,
|
|
174
|
+
name: sanitizedName
|
|
175
|
+
}
|
|
176
|
+
};
|
|
177
|
+
}
|
|
178
|
+
function createStats(protocol, direction) {
|
|
179
|
+
return {
|
|
180
|
+
protocol,
|
|
181
|
+
direction,
|
|
182
|
+
applied: false,
|
|
183
|
+
sanitizedNames: 0,
|
|
184
|
+
truncatedNames: 0,
|
|
185
|
+
defaultedNames: 0
|
|
186
|
+
};
|
|
187
|
+
}
|
|
188
|
+
function sanitizeName(rawName, rules, stats, field) {
|
|
189
|
+
const defaultName = rules.defaultName ?? 'tool';
|
|
190
|
+
let next = typeof rawName === 'string' ? rawName : '';
|
|
191
|
+
let changed = false;
|
|
192
|
+
if (rules.trimWhitespace !== false) {
|
|
193
|
+
next = next.trim();
|
|
194
|
+
}
|
|
195
|
+
if (!next) {
|
|
196
|
+
next = defaultName;
|
|
197
|
+
stats.defaultedNames += 1;
|
|
198
|
+
changed = true;
|
|
199
|
+
}
|
|
200
|
+
if (rules.forceCase === 'lower') {
|
|
201
|
+
const forced = next.toLowerCase();
|
|
202
|
+
if (forced !== next) {
|
|
203
|
+
next = forced;
|
|
204
|
+
changed = true;
|
|
205
|
+
}
|
|
206
|
+
}
|
|
207
|
+
else if (rules.forceCase === 'upper') {
|
|
208
|
+
const forced = next.toUpperCase();
|
|
209
|
+
if (forced !== next) {
|
|
210
|
+
next = forced;
|
|
211
|
+
changed = true;
|
|
212
|
+
}
|
|
213
|
+
}
|
|
214
|
+
if (rules.allowedCharacters) {
|
|
215
|
+
const matcher = new RegExp(rules.allowedCharacters.source);
|
|
216
|
+
const filtered = next
|
|
217
|
+
.split('')
|
|
218
|
+
.filter((ch) => matcher.test(ch))
|
|
219
|
+
.join('');
|
|
220
|
+
matcher.lastIndex = 0;
|
|
221
|
+
if (filtered.length === 0) {
|
|
222
|
+
next = defaultName;
|
|
223
|
+
stats.defaultedNames += 1;
|
|
224
|
+
changed = true;
|
|
225
|
+
}
|
|
226
|
+
else if (filtered !== next) {
|
|
227
|
+
next = filtered;
|
|
228
|
+
changed = true;
|
|
229
|
+
}
|
|
230
|
+
}
|
|
231
|
+
if (rules.maxNameLength && next.length > rules.maxNameLength) {
|
|
232
|
+
if (rules.onViolation === 'reject') {
|
|
233
|
+
throw new ToolGovernanceError(`Tool name exceeds max length of ${rules.maxNameLength}`, stats.protocol, stats.direction, field);
|
|
234
|
+
}
|
|
235
|
+
next = next.slice(0, rules.maxNameLength);
|
|
236
|
+
stats.truncatedNames += 1;
|
|
237
|
+
changed = true;
|
|
238
|
+
}
|
|
239
|
+
if (changed || (typeof rawName === 'string' && rawName !== next)) {
|
|
240
|
+
stats.sanitizedNames += 1;
|
|
241
|
+
}
|
|
242
|
+
stats.applied = true;
|
|
243
|
+
return next || defaultName;
|
|
244
|
+
}
|
|
245
|
+
function finalizeSummary(stats) {
|
|
246
|
+
return {
|
|
247
|
+
protocol: stats.protocol,
|
|
248
|
+
direction: stats.direction,
|
|
249
|
+
applied: stats.applied,
|
|
250
|
+
sanitizedNames: stats.sanitizedNames,
|
|
251
|
+
truncatedNames: stats.truncatedNames,
|
|
252
|
+
defaultedNames: stats.defaultedNames,
|
|
253
|
+
timestamp: Date.now()
|
|
254
|
+
};
|
|
255
|
+
}
|
|
256
|
+
function buildSummary(protocol, direction, applied) {
|
|
257
|
+
return {
|
|
258
|
+
protocol,
|
|
259
|
+
direction,
|
|
260
|
+
applied,
|
|
261
|
+
sanitizedNames: 0,
|
|
262
|
+
truncatedNames: 0,
|
|
263
|
+
defaultedNames: 0,
|
|
264
|
+
timestamp: Date.now()
|
|
265
|
+
};
|
|
266
|
+
}
|
|
@@ -0,0 +1,76 @@
|
|
|
1
|
+
const ALPHA_NUMERIC = /[A-Za-z0-9._-]/;
|
|
2
|
+
const LOWER_SNAKE = /[a-z0-9._-]/;
|
|
3
|
+
function clonePattern(pattern) {
|
|
4
|
+
if (!pattern)
|
|
5
|
+
return undefined;
|
|
6
|
+
const flags = pattern.flags.replace(/g/g, '');
|
|
7
|
+
return new RegExp(pattern.source, flags);
|
|
8
|
+
}
|
|
9
|
+
export const DEFAULT_TOOL_GOVERNANCE_RULES = {
|
|
10
|
+
'openai-chat': {
|
|
11
|
+
request: {
|
|
12
|
+
maxNameLength: 64,
|
|
13
|
+
allowedCharacters: clonePattern(ALPHA_NUMERIC),
|
|
14
|
+
defaultName: 'tool',
|
|
15
|
+
trimWhitespace: true,
|
|
16
|
+
onViolation: 'truncate'
|
|
17
|
+
},
|
|
18
|
+
response: {
|
|
19
|
+
maxNameLength: 64,
|
|
20
|
+
allowedCharacters: clonePattern(ALPHA_NUMERIC),
|
|
21
|
+
defaultName: 'tool',
|
|
22
|
+
trimWhitespace: true,
|
|
23
|
+
onViolation: 'truncate'
|
|
24
|
+
}
|
|
25
|
+
},
|
|
26
|
+
'openai-responses': {
|
|
27
|
+
request: {
|
|
28
|
+
maxNameLength: 64,
|
|
29
|
+
allowedCharacters: clonePattern(ALPHA_NUMERIC),
|
|
30
|
+
defaultName: 'tool',
|
|
31
|
+
trimWhitespace: true,
|
|
32
|
+
onViolation: 'truncate'
|
|
33
|
+
},
|
|
34
|
+
response: {
|
|
35
|
+
maxNameLength: 64,
|
|
36
|
+
allowedCharacters: clonePattern(ALPHA_NUMERIC),
|
|
37
|
+
defaultName: 'tool',
|
|
38
|
+
trimWhitespace: true,
|
|
39
|
+
onViolation: 'truncate'
|
|
40
|
+
}
|
|
41
|
+
},
|
|
42
|
+
anthropic: {
|
|
43
|
+
request: {
|
|
44
|
+
maxNameLength: 64,
|
|
45
|
+
allowedCharacters: clonePattern(LOWER_SNAKE),
|
|
46
|
+
forceCase: 'lower',
|
|
47
|
+
defaultName: 'tool',
|
|
48
|
+
trimWhitespace: true,
|
|
49
|
+
onViolation: 'truncate'
|
|
50
|
+
},
|
|
51
|
+
response: {
|
|
52
|
+
maxNameLength: 64,
|
|
53
|
+
allowedCharacters: clonePattern(LOWER_SNAKE),
|
|
54
|
+
forceCase: 'lower',
|
|
55
|
+
defaultName: 'tool',
|
|
56
|
+
trimWhitespace: true,
|
|
57
|
+
onViolation: 'truncate'
|
|
58
|
+
}
|
|
59
|
+
},
|
|
60
|
+
gemini: {
|
|
61
|
+
request: {
|
|
62
|
+
maxNameLength: 64,
|
|
63
|
+
allowedCharacters: clonePattern(ALPHA_NUMERIC),
|
|
64
|
+
defaultName: 'tool',
|
|
65
|
+
trimWhitespace: true,
|
|
66
|
+
onViolation: 'truncate'
|
|
67
|
+
},
|
|
68
|
+
response: {
|
|
69
|
+
maxNameLength: 64,
|
|
70
|
+
allowedCharacters: clonePattern(ALPHA_NUMERIC),
|
|
71
|
+
defaultName: 'tool',
|
|
72
|
+
trimWhitespace: true,
|
|
73
|
+
onViolation: 'truncate'
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
};
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
import type { JsonObject } from '../types/json.js';
|
|
2
|
+
import type { StandardizedMessage, StandardizedRequest, StandardizedTool } from '../types/standardized.js';
|
|
3
|
+
export type ToolGovernanceProtocol = 'openai-chat' | 'openai-responses' | 'anthropic' | 'gemini' | string;
|
|
4
|
+
export type ToolGovernanceViolationMode = 'truncate' | 'reject';
|
|
5
|
+
export interface ToolGovernanceRules {
|
|
6
|
+
maxNameLength?: number;
|
|
7
|
+
allowedCharacters?: RegExp;
|
|
8
|
+
forceCase?: 'lower' | 'upper';
|
|
9
|
+
defaultName?: string;
|
|
10
|
+
trimWhitespace?: boolean;
|
|
11
|
+
onViolation?: ToolGovernanceViolationMode;
|
|
12
|
+
}
|
|
13
|
+
export interface ToolGovernanceRegistryEntry {
|
|
14
|
+
request?: ToolGovernanceRules;
|
|
15
|
+
response?: ToolGovernanceRules;
|
|
16
|
+
}
|
|
17
|
+
export type ToolGovernanceRegistry = Record<ToolGovernanceProtocol, ToolGovernanceRegistryEntry>;
|
|
18
|
+
export interface ToolGovernanceSummary {
|
|
19
|
+
protocol: ToolGovernanceProtocol;
|
|
20
|
+
direction: 'request' | 'response';
|
|
21
|
+
applied: boolean;
|
|
22
|
+
sanitizedNames: number;
|
|
23
|
+
truncatedNames: number;
|
|
24
|
+
defaultedNames: number;
|
|
25
|
+
timestamp: number;
|
|
26
|
+
}
|
|
27
|
+
export interface GovernedStandardizedRequest {
|
|
28
|
+
request: StandardizedRequest;
|
|
29
|
+
summary: ToolGovernanceSummary;
|
|
30
|
+
}
|
|
31
|
+
export interface GovernedChatCompletionPayload {
|
|
32
|
+
payload: JsonObject;
|
|
33
|
+
summary: ToolGovernanceSummary;
|
|
34
|
+
}
|
|
35
|
+
export type MutableStandardizedMessage = StandardizedMessage & {
|
|
36
|
+
tool_calls?: StandardizedMessage['tool_calls'];
|
|
37
|
+
};
|
|
38
|
+
export type MutableStandardizedTool = StandardizedTool;
|
|
@@ -7,6 +7,7 @@ export * from './hub/registry.js';
|
|
|
7
7
|
export * from './hub/pipelines/inbound.js';
|
|
8
8
|
export * from './hub/pipelines/outbound.js';
|
|
9
9
|
export * from './hub/response/provider-response.js';
|
|
10
|
+
export * from './hub/response/response-runtime.js';
|
|
10
11
|
export * from './hub/pipeline/hub-pipeline.js';
|
|
11
12
|
export * from './hub/format-adapters/index.js';
|
|
12
13
|
export * from './hub/semantic-mappers/index.js';
|
package/dist/conversion/index.js
CHANGED
|
@@ -7,6 +7,7 @@ export * from './hub/registry.js';
|
|
|
7
7
|
export * from './hub/pipelines/inbound.js';
|
|
8
8
|
export * from './hub/pipelines/outbound.js';
|
|
9
9
|
export * from './hub/response/provider-response.js';
|
|
10
|
+
export * from './hub/response/response-runtime.js';
|
|
10
11
|
export * from './hub/pipeline/hub-pipeline.js';
|
|
11
12
|
export * from './hub/format-adapters/index.js';
|
|
12
13
|
export * from './hub/semantic-mappers/index.js';
|
|
@@ -237,8 +237,8 @@ export function buildResponsesRequestFromChat(payload, ctx) {
|
|
|
237
237
|
if (anyT.type === 'function' && anyT.function && typeof anyT.function === 'object') {
|
|
238
238
|
const fn = anyT.function;
|
|
239
239
|
const base = { type: 'function' };
|
|
240
|
-
if (typeof fn.name === 'string')
|
|
241
|
-
base.name = fn.name;
|
|
240
|
+
if (typeof fn.name === 'string' && fn.name.trim())
|
|
241
|
+
base.name = fn.name.trim();
|
|
242
242
|
if (typeof fn.description === 'string')
|
|
243
243
|
base.description = fn.description;
|
|
244
244
|
if (Object.prototype.hasOwnProperty.call(fn, 'parameters'))
|
|
@@ -385,7 +385,9 @@ export function buildResponsesRequestFromChat(payload, ctx) {
|
|
|
385
385
|
toolCallIdAliases.set(rawId, normalizedCallId);
|
|
386
386
|
}
|
|
387
387
|
const fn = tc?.function || {};
|
|
388
|
-
const name = typeof fn?.name === 'string'
|
|
388
|
+
const name = typeof fn?.name === 'string' && fn.name.trim()
|
|
389
|
+
? String(fn.name).trim()
|
|
390
|
+
: 'tool';
|
|
389
391
|
const argsRaw = fn?.arguments;
|
|
390
392
|
const args = typeof argsRaw === 'string' ? argsRaw : normalizeArgumentsBySchema(argsRaw, name, out.tools);
|
|
391
393
|
const entry = {
|
|
@@ -1,16 +1,29 @@
|
|
|
1
|
+
function sanitizeCore(value) {
|
|
2
|
+
return value
|
|
3
|
+
.replace(/[^A-Za-z0-9_-]/g, '_')
|
|
4
|
+
.replace(/_{2,}/g, '_')
|
|
5
|
+
.replace(/^_+/, '')
|
|
6
|
+
.replace(/_+$/, '');
|
|
7
|
+
}
|
|
1
8
|
function stripPrefix(value) {
|
|
2
9
|
if (typeof value !== 'string')
|
|
3
10
|
return null;
|
|
4
11
|
const trimmed = value.trim();
|
|
5
12
|
if (!trimmed)
|
|
6
13
|
return null;
|
|
7
|
-
|
|
8
|
-
|
|
14
|
+
let sanitized = sanitizeCore(trimmed);
|
|
15
|
+
if (!sanitized)
|
|
16
|
+
return null;
|
|
17
|
+
if (/^fc[_-]/i.test(sanitized)) {
|
|
18
|
+
sanitized = sanitized.replace(/^fc[_-]?/i, '');
|
|
19
|
+
}
|
|
20
|
+
else if (/^call[_-]/i.test(sanitized)) {
|
|
21
|
+
sanitized = sanitized.replace(/^call[_-]?/i, '');
|
|
9
22
|
}
|
|
10
|
-
if (
|
|
11
|
-
|
|
23
|
+
if (!sanitized) {
|
|
24
|
+
sanitized = Math.random().toString(36).slice(2, 10);
|
|
12
25
|
}
|
|
13
|
-
return `fc_${
|
|
26
|
+
return `fc_${sanitized}`;
|
|
14
27
|
}
|
|
15
28
|
function normalizeWithFallback(options) {
|
|
16
29
|
const normalized = stripPrefix(options.callId);
|
|
@@ -594,7 +594,8 @@ export class ResponsesResponseBuilder {
|
|
|
594
594
|
* 处理错误事件
|
|
595
595
|
*/
|
|
596
596
|
handleError(event) {
|
|
597
|
-
const
|
|
597
|
+
const payload = event.data;
|
|
598
|
+
const msg = typeof payload?.error?.message === 'string' ? payload.error.message : undefined;
|
|
598
599
|
// 容错:若无有效错误消息或当前响应已标记 completed,则将错误降级为非致命告警
|
|
599
600
|
const status = this.response?.status;
|
|
600
601
|
if (!msg || status === 'completed' || this.config.enableEventRecovery) {
|