@copilotkit/runtime 1.57.2 → 1.57.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/dist/lib/runtime/copilot-runtime.cjs +2 -0
- package/dist/lib/runtime/copilot-runtime.cjs.map +1 -1
- package/dist/lib/runtime/copilot-runtime.d.cts.map +1 -1
- package/dist/lib/runtime/copilot-runtime.d.mts.map +1 -1
- package/dist/lib/runtime/copilot-runtime.mjs +2 -0
- package/dist/lib/runtime/copilot-runtime.mjs.map +1 -1
- package/dist/package.cjs +52 -19
- package/dist/package.mjs +52 -19
- package/dist/v2/runtime/core/runtime.cjs +4 -1
- package/dist/v2/runtime/core/runtime.cjs.map +1 -1
- package/dist/v2/runtime/core/runtime.d.cts.map +1 -1
- package/dist/v2/runtime/core/runtime.d.mts.map +1 -1
- package/dist/v2/runtime/core/runtime.mjs +4 -1
- package/dist/v2/runtime/core/runtime.mjs.map +1 -1
- package/dist/v2/runtime/handlers/get-runtime-info.cjs +1 -1
- package/dist/v2/runtime/handlers/get-runtime-info.mjs +1 -1
- package/dist/v2/runtime/handlers/handle-connect.cjs +1 -1
- package/dist/v2/runtime/handlers/handle-connect.mjs +1 -1
- package/dist/v2/runtime/handlers/handle-run.cjs +1 -1
- package/dist/v2/runtime/handlers/handle-run.mjs +1 -1
- package/dist/v2/runtime/handlers/shared/agent-utils.cjs +1 -1
- package/dist/v2/runtime/handlers/shared/agent-utils.cjs.map +1 -1
- package/dist/v2/runtime/handlers/shared/agent-utils.mjs +1 -1
- package/dist/v2/runtime/handlers/shared/agent-utils.mjs.map +1 -1
- package/dist/v2/runtime/telemetry/telemetry-client.cjs +22 -6
- package/dist/v2/runtime/telemetry/telemetry-client.cjs.map +1 -1
- package/dist/v2/runtime/telemetry/telemetry-client.mjs +27 -11
- package/dist/v2/runtime/telemetry/telemetry-client.mjs.map +1 -1
- package/package.json +8 -18
- package/skills/runtime/SKILL.md +98 -0
- package/skills/runtime/references/agent-runners-custom.md +161 -0
- package/skills/runtime/references/agent-runners-in-memory.md +64 -0
- package/skills/runtime/references/agent-runners-sqlite.md +90 -0
- package/skills/runtime/references/agent-runners.md +304 -0
- package/skills/runtime/references/built-in-agent-factory-modes.md +232 -0
- package/skills/runtime/references/built-in-agent-helper-utilities.md +123 -0
- package/skills/runtime/references/built-in-agent-model-identifiers.md +59 -0
- package/skills/runtime/references/built-in-agent.md +523 -0
- package/skills/runtime/references/intelligence-mode.md +336 -0
- package/skills/runtime/references/middleware.md +376 -0
- package/skills/runtime/references/server-side-tools.md +414 -0
- package/skills/runtime/references/setup-endpoint.md +503 -0
- package/skills/runtime/references/transcription.md +287 -0
- package/skills/runtime/references/wiring-a2a.md +40 -0
- package/skills/runtime/references/wiring-adk.md +45 -0
- package/skills/runtime/references/wiring-ag2.md +41 -0
- package/skills/runtime/references/wiring-agno.md +39 -0
- package/skills/runtime/references/wiring-aws-strands.md +59 -0
- package/skills/runtime/references/wiring-crewai-crews.md +51 -0
- package/skills/runtime/references/wiring-crewai-flows.md +45 -0
- package/skills/runtime/references/wiring-external-agents.md +348 -0
- package/skills/runtime/references/wiring-langgraph.md +50 -0
- package/skills/runtime/references/wiring-llamaindex.md +39 -0
- package/skills/runtime/references/wiring-mastra.md +70 -0
- package/skills/runtime/references/wiring-mcp-apps-middleware.md +68 -0
- package/skills/runtime/references/wiring-ms-agent-framework.md +41 -0
- package/skills/runtime/references/wiring-pydantic-ai.md +45 -0
- package/CHANGELOG.md +0 -3624
- package/__snapshots__/schema/schema.graphql +0 -371
- package/dist/v2/runtime/telemetry/scarf-client.cjs +0 -32
- package/dist/v2/runtime/telemetry/scarf-client.cjs.map +0 -1
- package/dist/v2/runtime/telemetry/scarf-client.mjs +0 -32
- package/dist/v2/runtime/telemetry/scarf-client.mjs.map +0 -1
- package/scripts/generate-gql-schema.ts +0 -16
- package/src/agent/__tests__/agent-test-helpers.ts +0 -476
- package/src/agent/__tests__/agent.test.ts +0 -593
- package/src/agent/__tests__/ai-sdk-v6-compat.test.ts +0 -116
- package/src/agent/__tests__/basic-agent.test.ts +0 -1698
- package/src/agent/__tests__/capabilities.test.ts +0 -81
- package/src/agent/__tests__/config-tools-execution.test.ts +0 -516
- package/src/agent/__tests__/converter-aisdk.test.ts +0 -692
- package/src/agent/__tests__/converter-custom.test.ts +0 -319
- package/src/agent/__tests__/converter-tanstack-input.test.ts +0 -211
- package/src/agent/__tests__/converter-tanstack.test.ts +0 -594
- package/src/agent/__tests__/mcp-clients.test.ts +0 -246
- package/src/agent/__tests__/mcp-servers-integration.test.ts +0 -373
- package/src/agent/__tests__/multimodal-tanstack.test.ts +0 -284
- package/src/agent/__tests__/multimodal.test.ts +0 -176
- package/src/agent/__tests__/property-overrides.test.ts +0 -598
- package/src/agent/__tests__/provider-id-collision.test.ts +0 -195
- package/src/agent/__tests__/standard-schema-tools.test.ts +0 -313
- package/src/agent/__tests__/standard-schema-types.test.ts +0 -158
- package/src/agent/__tests__/state-tools.test.ts +0 -436
- package/src/agent/__tests__/test-helpers.ts +0 -197
- package/src/agent/__tests__/utils.test.ts +0 -536
- package/src/agent/__tests__/zod-regression.test.ts +0 -350
- package/src/agent/converters/aisdk.ts +0 -326
- package/src/agent/converters/index.ts +0 -7
- package/src/agent/converters/tanstack.ts +0 -451
- package/src/agent/index.ts +0 -1743
- package/src/agents/langgraph/__tests__/event-source.test.ts +0 -256
- package/src/agents/langgraph/event-source.ts +0 -365
- package/src/agents/langgraph/events.ts +0 -394
- package/src/graphql/inputs/action.input.ts +0 -16
- package/src/graphql/inputs/agent-session.input.ts +0 -13
- package/src/graphql/inputs/agent-state.input.ts +0 -13
- package/src/graphql/inputs/cloud-guardrails.input.ts +0 -16
- package/src/graphql/inputs/cloud.input.ts +0 -8
- package/src/graphql/inputs/context-property.input.ts +0 -10
- package/src/graphql/inputs/copilot-context.input.ts +0 -10
- package/src/graphql/inputs/custom-property.input.ts +0 -15
- package/src/graphql/inputs/extensions.input.ts +0 -21
- package/src/graphql/inputs/forwarded-parameters.input.ts +0 -22
- package/src/graphql/inputs/frontend.input.ts +0 -14
- package/src/graphql/inputs/generate-copilot-response.input.ts +0 -59
- package/src/graphql/inputs/load-agent-state.input.ts +0 -10
- package/src/graphql/inputs/message.input.ts +0 -110
- package/src/graphql/inputs/meta-event.input.ts +0 -18
- package/src/graphql/message-conversion/agui-to-gql.test.ts +0 -1384
- package/src/graphql/message-conversion/agui-to-gql.ts +0 -384
- package/src/graphql/message-conversion/gql-to-agui.test.ts +0 -1653
- package/src/graphql/message-conversion/gql-to-agui.ts +0 -297
- package/src/graphql/message-conversion/index.ts +0 -2
- package/src/graphql/message-conversion/roundtrip-conversion.test.ts +0 -561
- package/src/graphql/resolvers/__tests__/resolve-message-id.test.ts +0 -25
- package/src/graphql/resolvers/copilot.resolver.ts +0 -785
- package/src/graphql/resolvers/resolve-message-id.ts +0 -14
- package/src/graphql/resolvers/state.resolver.ts +0 -30
- package/src/graphql/types/agents-response.type.ts +0 -19
- package/src/graphql/types/base/index.ts +0 -10
- package/src/graphql/types/converted/index.ts +0 -183
- package/src/graphql/types/copilot-response.type.ts +0 -141
- package/src/graphql/types/enums.ts +0 -38
- package/src/graphql/types/extensions-response.type.ts +0 -23
- package/src/graphql/types/guardrails-result.type.ts +0 -20
- package/src/graphql/types/load-agent-state-response.type.ts +0 -17
- package/src/graphql/types/message-status.type.ts +0 -48
- package/src/graphql/types/meta-events.type.ts +0 -78
- package/src/graphql/types/response-status.type.ts +0 -77
- package/src/index.ts +0 -3
- package/src/langgraph.ts +0 -1
- package/src/lib/__tests__/telemetry-disclosure.test.ts +0 -55
- package/src/lib/cloud/index.ts +0 -4
- package/src/lib/error-messages.ts +0 -211
- package/src/lib/index.ts +0 -52
- package/src/lib/integrations/index.ts +0 -6
- package/src/lib/integrations/nest/index.ts +0 -21
- package/src/lib/integrations/nextjs/app-router.ts +0 -47
- package/src/lib/integrations/nextjs/pages-router.ts +0 -45
- package/src/lib/integrations/node-express/index.ts +0 -21
- package/src/lib/integrations/node-http/__tests__/request-duck-type.test.ts +0 -66
- package/src/lib/integrations/node-http/index.ts +0 -187
- package/src/lib/integrations/node-http/request-handler.ts +0 -128
- package/src/lib/integrations/shared.ts +0 -112
- package/src/lib/logger.ts +0 -31
- package/src/lib/observability.ts +0 -167
- package/src/lib/runtime/__tests__/copilot-runtime-error.test.ts +0 -183
- package/src/lib/runtime/__tests__/handle-service-adapter.test.ts +0 -108
- package/src/lib/runtime/__tests__/mcp-tools-utils.test.ts +0 -499
- package/src/lib/runtime/__tests__/on-after-request.test.ts +0 -122
- package/src/lib/runtime/__tests__/retry-utils.test.ts +0 -137
- package/src/lib/runtime/__tests__/v1-agent-factory.test.ts +0 -109
- package/src/lib/runtime/agent-integrations/langgraph/__tests__/dispatch-event-filtering.test.ts +0 -345
- package/src/lib/runtime/agent-integrations/langgraph/__tests__/run-message-filtering.test.ts +0 -156
- package/src/lib/runtime/agent-integrations/langgraph/agent.ts +0 -263
- package/src/lib/runtime/agent-integrations/langgraph/consts.ts +0 -37
- package/src/lib/runtime/agent-integrations/langgraph/index.ts +0 -2
- package/src/lib/runtime/copilot-runtime.ts +0 -863
- package/src/lib/runtime/mcp-tools-utils.ts +0 -313
- package/src/lib/runtime/retry-utils.ts +0 -141
- package/src/lib/runtime/telemetry-agent-runner.ts +0 -151
- package/src/lib/runtime/types.ts +0 -48
- package/src/lib/runtime/utils.ts +0 -93
- package/src/lib/streaming.ts +0 -220
- package/src/lib/telemetry-client.ts +0 -66
- package/src/lib/telemetry-disclosure.ts +0 -53
- package/src/service-adapters/anthropic/anthropic-adapter.ts +0 -532
- package/src/service-adapters/anthropic/utils.ts +0 -219
- package/src/service-adapters/bedrock/bedrock-adapter.ts +0 -73
- package/src/service-adapters/conversion.test.ts +0 -56
- package/src/service-adapters/conversion.ts +0 -69
- package/src/service-adapters/empty/empty-adapter.ts +0 -38
- package/src/service-adapters/events.ts +0 -337
- package/src/service-adapters/experimental/ollama/ollama-adapter.ts +0 -84
- package/src/service-adapters/google/google-genai-adapter.test.ts +0 -151
- package/src/service-adapters/google/google-genai-adapter.ts +0 -95
- package/src/service-adapters/groq/groq-adapter.ts +0 -229
- package/src/service-adapters/index.ts +0 -18
- package/src/service-adapters/langchain/langchain-adapter.ts +0 -113
- package/src/service-adapters/langchain/langserve.ts +0 -88
- package/src/service-adapters/langchain/types.ts +0 -20
- package/src/service-adapters/langchain/utils.ts +0 -330
- package/src/service-adapters/openai/__tests__/openai-v5-compat.test.ts +0 -177
- package/src/service-adapters/openai/openai-adapter.ts +0 -324
- package/src/service-adapters/openai/openai-assistant-adapter.ts +0 -385
- package/src/service-adapters/openai/utils.ts +0 -305
- package/src/service-adapters/service-adapter.ts +0 -50
- package/src/service-adapters/shared/error-utils.ts +0 -64
- package/src/service-adapters/shared/index.ts +0 -2
- package/src/service-adapters/shared/sdk-client-utils.ts +0 -19
- package/src/service-adapters/unify/unify-adapter.ts +0 -165
- package/src/utils/failed-response-status-reasons.ts +0 -70
- package/src/utils/index.ts +0 -1
- package/src/v2/express.ts +0 -1
- package/src/v2/hono.ts +0 -1
- package/src/v2/index.ts +0 -5
- package/src/v2/node.ts +0 -1
- package/src/v2/runtime/__tests__/agents-factory.test.ts +0 -136
- package/src/v2/runtime/__tests__/backward-compat.test.ts +0 -261
- package/src/v2/runtime/__tests__/code-review-fixes.test.ts +0 -500
- package/src/v2/runtime/__tests__/cors-credentials.test.ts +0 -320
- package/src/v2/runtime/__tests__/debug-sse-response.test.ts +0 -302
- package/src/v2/runtime/__tests__/express-adapter.test.ts +0 -188
- package/src/v2/runtime/__tests__/express-body-order.test.ts +0 -76
- package/src/v2/runtime/__tests__/express-fetch-bridge.test.ts +0 -344
- package/src/v2/runtime/__tests__/express-single-sse.test.ts +0 -122
- package/src/v2/runtime/__tests__/express-single-telemetry.integration.test.ts +0 -65
- package/src/v2/runtime/__tests__/express-telemetry.integration.test.ts +0 -101
- package/src/v2/runtime/__tests__/fetch-cors.test.ts +0 -205
- package/src/v2/runtime/__tests__/fetch-handler-validation.test.ts +0 -440
- package/src/v2/runtime/__tests__/fetch-handler.test.ts +0 -456
- package/src/v2/runtime/__tests__/fetch-router.test.ts +0 -276
- package/src/v2/runtime/__tests__/get-runtime-info.test.ts +0 -335
- package/src/v2/runtime/__tests__/handle-connect.test.ts +0 -585
- package/src/v2/runtime/__tests__/handle-run.test.ts +0 -1388
- package/src/v2/runtime/__tests__/handle-threads.test.ts +0 -930
- package/src/v2/runtime/__tests__/handle-transcribe.test.ts +0 -301
- package/src/v2/runtime/__tests__/header-utils.test.ts +0 -88
- package/src/v2/runtime/__tests__/hono-adapter.test.ts +0 -150
- package/src/v2/runtime/__tests__/hono-single-telemetry.integration.test.ts +0 -46
- package/src/v2/runtime/__tests__/hono-telemetry.integration.test.ts +0 -99
- package/src/v2/runtime/__tests__/hooks-edge-cases.test.ts +0 -457
- package/src/v2/runtime/__tests__/hooks.test.ts +0 -557
- package/src/v2/runtime/__tests__/in-process-agent-runner-messages.test.ts +0 -230
- package/src/v2/runtime/__tests__/in-process-agent-runner.test.ts +0 -1030
- package/src/v2/runtime/__tests__/integration/bun/bun-servers.integration.test.ts +0 -27
- package/src/v2/runtime/__tests__/integration/bun/elysia-multi.ts +0 -32
- package/src/v2/runtime/__tests__/integration/bun/elysia-single.ts +0 -33
- package/src/v2/runtime/__tests__/integration/bun/hono-bun-multi.ts +0 -25
- package/src/v2/runtime/__tests__/integration/bun/hono-bun-single.ts +0 -32
- package/src/v2/runtime/__tests__/integration/helpers/create-test-runtime.ts +0 -15
- package/src/v2/runtime/__tests__/integration/helpers/sse-reader.ts +0 -45
- package/src/v2/runtime/__tests__/integration/helpers/test-agent.ts +0 -58
- package/src/v2/runtime/__tests__/integration/node-servers.integration.test.ts +0 -58
- package/src/v2/runtime/__tests__/integration/servers/express-multi.ts +0 -35
- package/src/v2/runtime/__tests__/integration/servers/express-single.ts +0 -36
- package/src/v2/runtime/__tests__/integration/servers/fetch-direct.ts +0 -39
- package/src/v2/runtime/__tests__/integration/servers/hono-multi.ts +0 -30
- package/src/v2/runtime/__tests__/integration/servers/hono-single.ts +0 -37
- package/src/v2/runtime/__tests__/integration/servers/node-multi.ts +0 -45
- package/src/v2/runtime/__tests__/integration/servers/node-single.ts +0 -46
- package/src/v2/runtime/__tests__/integration/servers/types.ts +0 -18
- package/src/v2/runtime/__tests__/integration/suites/debug-events.suite.ts +0 -253
- package/src/v2/runtime/__tests__/integration/suites/multi-endpoint.suite.ts +0 -358
- package/src/v2/runtime/__tests__/integration/suites/single-endpoint.suite.ts +0 -363
- package/src/v2/runtime/__tests__/intelligence-run-telemetry.test.ts +0 -194
- package/src/v2/runtime/__tests__/mcp-apps-middleware-integration.test.ts +0 -275
- package/src/v2/runtime/__tests__/middleware-express.test.ts +0 -208
- package/src/v2/runtime/__tests__/middleware-single-express.test.ts +0 -213
- package/src/v2/runtime/__tests__/middleware-single.test.ts +0 -225
- package/src/v2/runtime/__tests__/middleware-sse-parser.test.ts +0 -237
- package/src/v2/runtime/__tests__/middleware.test.ts +0 -250
- package/src/v2/runtime/__tests__/node-fetch-handler.test.ts +0 -157
- package/src/v2/runtime/__tests__/open-generative-ui-middleware.e2e.test.ts +0 -728
- package/src/v2/runtime/__tests__/router-edge-cases.test.ts +0 -217
- package/src/v2/runtime/__tests__/routing-express.test.ts +0 -174
- package/src/v2/runtime/__tests__/routing-single-express.test.ts +0 -168
- package/src/v2/runtime/__tests__/routing-single.test.ts +0 -193
- package/src/v2/runtime/__tests__/routing.test.ts +0 -257
- package/src/v2/runtime/__tests__/runtime.test.ts +0 -234
- package/src/v2/runtime/__tests__/sse-response-telemetry.test.ts +0 -108
- package/src/v2/runtime/__tests__/telemetry.test.ts +0 -167
- package/src/v2/runtime/__tests__/thread-names.test.ts +0 -188
- package/src/v2/runtime/core/__tests__/debug-event-bus.test.ts +0 -156
- package/src/v2/runtime/core/debug-event-bus.ts +0 -45
- package/src/v2/runtime/core/fetch-cors.ts +0 -136
- package/src/v2/runtime/core/fetch-handler.ts +0 -492
- package/src/v2/runtime/core/fetch-router.ts +0 -203
- package/src/v2/runtime/core/hooks.ts +0 -160
- package/src/v2/runtime/core/middleware-sse-parser.ts +0 -210
- package/src/v2/runtime/core/middleware.ts +0 -115
- package/src/v2/runtime/core/runtime.ts +0 -432
- package/src/v2/runtime/endpoints/express-fetch-bridge.ts +0 -137
- package/src/v2/runtime/endpoints/express-single.ts +0 -54
- package/src/v2/runtime/endpoints/express.ts +0 -179
- package/src/v2/runtime/endpoints/hono-single.ts +0 -60
- package/src/v2/runtime/endpoints/hono.ts +0 -89
- package/src/v2/runtime/endpoints/index.ts +0 -4
- package/src/v2/runtime/endpoints/node-fetch-handler.ts +0 -48
- package/src/v2/runtime/endpoints/node.ts +0 -28
- package/src/v2/runtime/endpoints/single-route-helpers.ts +0 -125
- package/src/v2/runtime/express.ts +0 -2
- package/src/v2/runtime/handlers/__tests__/handle-debug-events.test.ts +0 -176
- package/src/v2/runtime/handlers/get-runtime-info.ts +0 -101
- package/src/v2/runtime/handlers/handle-connect.ts +0 -80
- package/src/v2/runtime/handlers/handle-debug-events.ts +0 -52
- package/src/v2/runtime/handlers/handle-run.ts +0 -111
- package/src/v2/runtime/handlers/handle-stop.ts +0 -77
- package/src/v2/runtime/handlers/handle-threads.ts +0 -11
- package/src/v2/runtime/handlers/handle-transcribe.ts +0 -269
- package/src/v2/runtime/handlers/header-utils.ts +0 -24
- package/src/v2/runtime/handlers/intelligence/connect.ts +0 -102
- package/src/v2/runtime/handlers/intelligence/run.ts +0 -351
- package/src/v2/runtime/handlers/intelligence/thread-names.ts +0 -246
- package/src/v2/runtime/handlers/intelligence/threads.ts +0 -420
- package/src/v2/runtime/handlers/shared/agent-utils.ts +0 -154
- package/src/v2/runtime/handlers/shared/intelligence-utils.ts +0 -41
- package/src/v2/runtime/handlers/shared/json-response.ts +0 -9
- package/src/v2/runtime/handlers/shared/resolve-intelligence-user.ts +0 -28
- package/src/v2/runtime/handlers/shared/sse-response.ts +0 -215
- package/src/v2/runtime/handlers/sse/__tests__/sse-connect-agent-id.test.ts +0 -71
- package/src/v2/runtime/handlers/sse/connect.ts +0 -30
- package/src/v2/runtime/handlers/sse/run.ts +0 -40
- package/src/v2/runtime/hono.ts +0 -2
- package/src/v2/runtime/index.ts +0 -51
- package/src/v2/runtime/intelligence-platform/__tests__/client.test.ts +0 -601
- package/src/v2/runtime/intelligence-platform/__tests__/intelligence-mcp-helper.test.ts +0 -246
- package/src/v2/runtime/intelligence-platform/client.ts +0 -818
- package/src/v2/runtime/intelligence-platform/index.ts +0 -10
- package/src/v2/runtime/node.ts +0 -6
- package/src/v2/runtime/open-generative-ui-middleware.ts +0 -373
- package/src/v2/runtime/runner/__tests__/finalize-events.test.ts +0 -109
- package/src/v2/runtime/runner/__tests__/in-memory-runner.e2e.test.ts +0 -775
- package/src/v2/runtime/runner/__tests__/in-memory-runner.test.ts +0 -777
- package/src/v2/runtime/runner/__tests__/intelligence-runner.test.ts +0 -1039
- package/src/v2/runtime/runner/agent-runner.ts +0 -35
- package/src/v2/runtime/runner/in-memory.ts +0 -467
- package/src/v2/runtime/runner/index.ts +0 -4
- package/src/v2/runtime/runner/intelligence.ts +0 -498
- package/src/v2/runtime/telemetry/__tests__/instance-created.test.ts +0 -96
- package/src/v2/runtime/telemetry/events.ts +0 -35
- package/src/v2/runtime/telemetry/index.ts +0 -7
- package/src/v2/runtime/telemetry/instance-created.ts +0 -44
- package/src/v2/runtime/telemetry/scarf-client.ts +0 -39
- package/src/v2/runtime/telemetry/telemetry-client.ts +0 -70
- package/src/v2/runtime/transcription-service/transcription-service.ts +0 -11
- package/tests/global.d.ts +0 -1
- package/tests/service-adapters/anthropic/allowlist-approach.test.ts +0 -259
- package/tests/service-adapters/anthropic/anthropic-adapter-language-model.test.ts +0 -101
- package/tests/service-adapters/anthropic/anthropic-adapter.test.ts +0 -645
- package/tests/service-adapters/anthropic/utils-token-trimming.test.ts +0 -301
- package/tests/service-adapters/groq/groq-adapter-language-model.test.ts +0 -102
- package/tests/service-adapters/openai/allowlist-approach.test.ts +0 -294
- package/tests/service-adapters/openai/openai-adapter-language-model.test.ts +0 -122
- package/tests/service-adapters/openai/openai-adapter.test.ts +0 -291
- package/tests/service-adapters/shared/sdk-client-utils.test.ts +0 -36
- package/tests/setup.vitest.ts +0 -8
- package/tests/tsconfig.json +0 -10
- package/tsconfig.json +0 -20
- package/tsdown.config.ts +0 -45
- package/typedoc.json +0 -4
- package/vitest.config.mjs +0 -13
|
@@ -1,350 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Regression tests proving that the agent package's defineTool and
|
|
3
|
-
* convertToolDefinitionsToVercelAITools still work identically with
|
|
4
|
-
* Zod schemas after the Standard Schema migration.
|
|
5
|
-
*
|
|
6
|
-
* Covers:
|
|
7
|
-
* 1. defineTool with complex Zod schemas
|
|
8
|
-
* 2. convertToolDefinitionsToVercelAITools passes Zod schemas directly
|
|
9
|
-
* (not through JSON Schema conversion — critical behavioral regression)
|
|
10
|
-
* 3. BuiltInAgent with Zod tools still works end-to-end
|
|
11
|
-
* 4. execute callback receives correctly shaped args
|
|
12
|
-
*/
|
|
13
|
-
import { describe, it, expect, vi, beforeEach, afterEach } from "vitest";
|
|
14
|
-
import { z } from "zod";
|
|
15
|
-
import {
|
|
16
|
-
defineTool,
|
|
17
|
-
convertToolDefinitionsToVercelAITools,
|
|
18
|
-
BuiltInAgent,
|
|
19
|
-
} from "../index";
|
|
20
|
-
import type { RunAgentInput } from "@ag-ui/client";
|
|
21
|
-
import { streamText } from "ai";
|
|
22
|
-
import { mockStreamTextResponse, finish, collectEvents } from "./test-helpers";
|
|
23
|
-
|
|
24
|
-
vi.mock("ai", async () => {
|
|
25
|
-
const actual = await vi.importActual("ai");
|
|
26
|
-
return {
|
|
27
|
-
...actual,
|
|
28
|
-
streamText: vi.fn(),
|
|
29
|
-
tool: vi.fn((config) => config),
|
|
30
|
-
stepCountIs: vi.fn((count: number) => ({ type: "stepCount", count })),
|
|
31
|
-
};
|
|
32
|
-
});
|
|
33
|
-
|
|
34
|
-
vi.mock("@ai-sdk/openai", () => ({
|
|
35
|
-
createOpenAI: vi.fn(() => (modelId: string) => ({
|
|
36
|
-
modelId,
|
|
37
|
-
provider: "openai",
|
|
38
|
-
})),
|
|
39
|
-
}));
|
|
40
|
-
|
|
41
|
-
describe("defineTool Zod regression", () => {
|
|
42
|
-
it("complex Zod schema with nested objects, arrays, unions", () => {
|
|
43
|
-
const tool = defineTool({
|
|
44
|
-
name: "complexTool",
|
|
45
|
-
description: "A complex tool",
|
|
46
|
-
parameters: z.object({
|
|
47
|
-
query: z.string().describe("Search query"),
|
|
48
|
-
filters: z
|
|
49
|
-
.object({
|
|
50
|
-
category: z.enum(["books", "movies", "music"]).optional(),
|
|
51
|
-
minRating: z.number().min(0).max(5).optional(),
|
|
52
|
-
tags: z.array(z.string()).optional(),
|
|
53
|
-
})
|
|
54
|
-
.optional(),
|
|
55
|
-
pagination: z
|
|
56
|
-
.object({
|
|
57
|
-
page: z.number().int().positive().default(1),
|
|
58
|
-
perPage: z.number().int().positive().default(20),
|
|
59
|
-
})
|
|
60
|
-
.optional(),
|
|
61
|
-
}),
|
|
62
|
-
execute: async (args) => {
|
|
63
|
-
return { query: args.query };
|
|
64
|
-
},
|
|
65
|
-
});
|
|
66
|
-
|
|
67
|
-
expect(tool.name).toBe("complexTool");
|
|
68
|
-
expect(tool.parameters["~standard"].vendor).toBe("zod");
|
|
69
|
-
expect(tool.parameters["~standard"].version).toBe(1);
|
|
70
|
-
});
|
|
71
|
-
|
|
72
|
-
it("Zod schema with discriminated union", () => {
|
|
73
|
-
const tool = defineTool({
|
|
74
|
-
name: "actionTool",
|
|
75
|
-
description: "An action tool",
|
|
76
|
-
parameters: z.object({
|
|
77
|
-
action: z.discriminatedUnion("type", [
|
|
78
|
-
z.object({ type: z.literal("search"), query: z.string() }),
|
|
79
|
-
z.object({ type: z.literal("navigate"), url: z.string().url() }),
|
|
80
|
-
z.object({
|
|
81
|
-
type: z.literal("execute"),
|
|
82
|
-
code: z.string(),
|
|
83
|
-
language: z.enum(["javascript", "python"]),
|
|
84
|
-
}),
|
|
85
|
-
]),
|
|
86
|
-
}),
|
|
87
|
-
execute: async (args) => {
|
|
88
|
-
return { action: args.action.type };
|
|
89
|
-
},
|
|
90
|
-
});
|
|
91
|
-
|
|
92
|
-
expect(tool.name).toBe("actionTool");
|
|
93
|
-
expect(tool.parameters["~standard"].vendor).toBe("zod");
|
|
94
|
-
});
|
|
95
|
-
|
|
96
|
-
it("Zod schema with nullable and record fields", () => {
|
|
97
|
-
const tool = defineTool({
|
|
98
|
-
name: "flexTool",
|
|
99
|
-
description: "Flexible tool",
|
|
100
|
-
parameters: z.object({
|
|
101
|
-
title: z.string(),
|
|
102
|
-
description: z.string().nullable(),
|
|
103
|
-
metadata: z.record(z.string(), z.unknown()).optional(),
|
|
104
|
-
}),
|
|
105
|
-
execute: async (args) => {
|
|
106
|
-
return { title: args.title };
|
|
107
|
-
},
|
|
108
|
-
});
|
|
109
|
-
|
|
110
|
-
expect(tool.name).toBe("flexTool");
|
|
111
|
-
expect(tool.parameters["~standard"].vendor).toBe("zod");
|
|
112
|
-
});
|
|
113
|
-
|
|
114
|
-
it("execute callback receives correctly typed args", async () => {
|
|
115
|
-
const receivedArgs: unknown[] = [];
|
|
116
|
-
|
|
117
|
-
const tool = defineTool({
|
|
118
|
-
name: "argCapture",
|
|
119
|
-
description: "Captures args",
|
|
120
|
-
parameters: z.object({
|
|
121
|
-
city: z.string(),
|
|
122
|
-
units: z.enum(["celsius", "fahrenheit"]),
|
|
123
|
-
}),
|
|
124
|
-
execute: async (args) => {
|
|
125
|
-
receivedArgs.push(args);
|
|
126
|
-
return { temp: 22 };
|
|
127
|
-
},
|
|
128
|
-
});
|
|
129
|
-
|
|
130
|
-
await tool.execute({ city: "Berlin", units: "celsius" });
|
|
131
|
-
|
|
132
|
-
expect(receivedArgs).toHaveLength(1);
|
|
133
|
-
expect(receivedArgs[0]).toEqual({ city: "Berlin", units: "celsius" });
|
|
134
|
-
});
|
|
135
|
-
});
|
|
136
|
-
|
|
137
|
-
describe("convertToolDefinitionsToVercelAITools Zod regression", () => {
|
|
138
|
-
it("Zod schemas are passed directly to AI SDK (not converted via JSON Schema)", () => {
|
|
139
|
-
const zodSchema = z.object({
|
|
140
|
-
city: z.string(),
|
|
141
|
-
units: z.enum(["celsius", "fahrenheit"]).optional(),
|
|
142
|
-
});
|
|
143
|
-
|
|
144
|
-
const tools = [
|
|
145
|
-
defineTool({
|
|
146
|
-
name: "weather",
|
|
147
|
-
description: "Get weather",
|
|
148
|
-
parameters: zodSchema,
|
|
149
|
-
execute: async () => ({ temp: 22 }),
|
|
150
|
-
}),
|
|
151
|
-
];
|
|
152
|
-
|
|
153
|
-
const aiTools = convertToolDefinitionsToVercelAITools(tools);
|
|
154
|
-
|
|
155
|
-
expect(aiTools).toHaveProperty("weather");
|
|
156
|
-
// The inputSchema should be the original Zod schema (passed directly),
|
|
157
|
-
// NOT a jsonSchema() wrapper. We verify by checking the Zod-specific
|
|
158
|
-
// ~standard.vendor property is preserved on the schema.
|
|
159
|
-
const inputSchema = aiTools.weather.inputSchema;
|
|
160
|
-
expect(inputSchema).toBeDefined();
|
|
161
|
-
// For Zod schemas, the AI SDK receives the raw Zod object (which has ~standard.vendor === "zod")
|
|
162
|
-
// If it went through jsonSchema(), it would lose the ~standard property
|
|
163
|
-
expect(inputSchema["~standard"]?.vendor).toBe("zod");
|
|
164
|
-
});
|
|
165
|
-
|
|
166
|
-
it("multiple Zod tools all get direct pass-through", () => {
|
|
167
|
-
const tools = [
|
|
168
|
-
defineTool({
|
|
169
|
-
name: "tool1",
|
|
170
|
-
description: "Tool 1",
|
|
171
|
-
parameters: z.object({ a: z.string() }),
|
|
172
|
-
execute: async () => ({}),
|
|
173
|
-
}),
|
|
174
|
-
defineTool({
|
|
175
|
-
name: "tool2",
|
|
176
|
-
description: "Tool 2",
|
|
177
|
-
parameters: z.object({ b: z.number(), c: z.boolean().optional() }),
|
|
178
|
-
execute: async () => ({}),
|
|
179
|
-
}),
|
|
180
|
-
defineTool({
|
|
181
|
-
name: "tool3",
|
|
182
|
-
description: "Tool 3",
|
|
183
|
-
parameters: z.object({
|
|
184
|
-
nested: z.object({ x: z.number(), y: z.number() }),
|
|
185
|
-
}),
|
|
186
|
-
execute: async () => ({}),
|
|
187
|
-
}),
|
|
188
|
-
];
|
|
189
|
-
|
|
190
|
-
const aiTools = convertToolDefinitionsToVercelAITools(tools);
|
|
191
|
-
|
|
192
|
-
for (const name of ["tool1", "tool2", "tool3"]) {
|
|
193
|
-
expect(aiTools).toHaveProperty(name);
|
|
194
|
-
expect(aiTools[name].inputSchema["~standard"]?.vendor).toBe("zod");
|
|
195
|
-
expect(typeof aiTools[name].execute).toBe("function");
|
|
196
|
-
}
|
|
197
|
-
});
|
|
198
|
-
|
|
199
|
-
it("preserves tool description and execute function", () => {
|
|
200
|
-
const executeFn = vi.fn().mockResolvedValue({ result: "ok" });
|
|
201
|
-
|
|
202
|
-
const tools = [
|
|
203
|
-
defineTool({
|
|
204
|
-
name: "myTool",
|
|
205
|
-
description: "My custom tool description",
|
|
206
|
-
parameters: z.object({ input: z.string() }),
|
|
207
|
-
execute: executeFn,
|
|
208
|
-
}),
|
|
209
|
-
];
|
|
210
|
-
|
|
211
|
-
const aiTools = convertToolDefinitionsToVercelAITools(tools);
|
|
212
|
-
|
|
213
|
-
expect(aiTools.myTool.description).toBe("My custom tool description");
|
|
214
|
-
expect(aiTools.myTool.execute).toBeDefined();
|
|
215
|
-
});
|
|
216
|
-
});
|
|
217
|
-
|
|
218
|
-
describe("BuiltInAgent Zod regression", () => {
|
|
219
|
-
const originalEnv = process.env;
|
|
220
|
-
|
|
221
|
-
beforeEach(() => {
|
|
222
|
-
vi.clearAllMocks();
|
|
223
|
-
process.env = { ...originalEnv };
|
|
224
|
-
process.env.OPENAI_API_KEY = "test-key";
|
|
225
|
-
});
|
|
226
|
-
|
|
227
|
-
afterEach(() => {
|
|
228
|
-
process.env = originalEnv;
|
|
229
|
-
});
|
|
230
|
-
|
|
231
|
-
it("Zod tools are included in streamText call", async () => {
|
|
232
|
-
const agent = new BuiltInAgent({
|
|
233
|
-
model: "openai/gpt-4o",
|
|
234
|
-
tools: [
|
|
235
|
-
defineTool({
|
|
236
|
-
name: "weather",
|
|
237
|
-
description: "Get weather",
|
|
238
|
-
parameters: z.object({
|
|
239
|
-
city: z.string(),
|
|
240
|
-
units: z.enum(["celsius", "fahrenheit"]).optional(),
|
|
241
|
-
}),
|
|
242
|
-
execute: async () => ({ temp: 22 }),
|
|
243
|
-
}),
|
|
244
|
-
],
|
|
245
|
-
});
|
|
246
|
-
|
|
247
|
-
vi.mocked(streamText).mockReturnValue(
|
|
248
|
-
mockStreamTextResponse([finish()]) as any,
|
|
249
|
-
);
|
|
250
|
-
|
|
251
|
-
const input: RunAgentInput = {
|
|
252
|
-
threadId: "thread1",
|
|
253
|
-
runId: "run1",
|
|
254
|
-
messages: [],
|
|
255
|
-
tools: [],
|
|
256
|
-
context: [],
|
|
257
|
-
state: {},
|
|
258
|
-
};
|
|
259
|
-
|
|
260
|
-
await collectEvents(agent["run"](input));
|
|
261
|
-
|
|
262
|
-
const callArgs = vi.mocked(streamText).mock.calls[0][0];
|
|
263
|
-
expect(callArgs.tools).toHaveProperty("weather");
|
|
264
|
-
expect(typeof callArgs.tools?.weather.execute).toBe("function");
|
|
265
|
-
});
|
|
266
|
-
|
|
267
|
-
it("multiple Zod tools coexist with built-in state tools", async () => {
|
|
268
|
-
const agent = new BuiltInAgent({
|
|
269
|
-
model: "openai/gpt-4o",
|
|
270
|
-
tools: [
|
|
271
|
-
defineTool({
|
|
272
|
-
name: "search",
|
|
273
|
-
description: "Search",
|
|
274
|
-
parameters: z.object({ query: z.string() }),
|
|
275
|
-
execute: async () => ({}),
|
|
276
|
-
}),
|
|
277
|
-
defineTool({
|
|
278
|
-
name: "calculate",
|
|
279
|
-
description: "Calculate",
|
|
280
|
-
parameters: z.object({
|
|
281
|
-
expression: z.string(),
|
|
282
|
-
precision: z.number().int().optional(),
|
|
283
|
-
}),
|
|
284
|
-
execute: async () => ({}),
|
|
285
|
-
}),
|
|
286
|
-
],
|
|
287
|
-
});
|
|
288
|
-
|
|
289
|
-
vi.mocked(streamText).mockReturnValue(
|
|
290
|
-
mockStreamTextResponse([finish()]) as any,
|
|
291
|
-
);
|
|
292
|
-
|
|
293
|
-
const input: RunAgentInput = {
|
|
294
|
-
threadId: "thread1",
|
|
295
|
-
runId: "run1",
|
|
296
|
-
messages: [],
|
|
297
|
-
tools: [],
|
|
298
|
-
context: [],
|
|
299
|
-
state: {},
|
|
300
|
-
};
|
|
301
|
-
|
|
302
|
-
await collectEvents(agent["run"](input));
|
|
303
|
-
|
|
304
|
-
const callArgs = vi.mocked(streamText).mock.calls[0][0];
|
|
305
|
-
// User-defined Zod tools
|
|
306
|
-
expect(callArgs.tools).toHaveProperty("search");
|
|
307
|
-
expect(callArgs.tools).toHaveProperty("calculate");
|
|
308
|
-
// Built-in state tools
|
|
309
|
-
expect(callArgs.tools).toHaveProperty("AGUISendStateSnapshot");
|
|
310
|
-
expect(callArgs.tools).toHaveProperty("AGUISendStateDelta");
|
|
311
|
-
});
|
|
312
|
-
|
|
313
|
-
it("Zod tool execute is invocable after conversion", async () => {
|
|
314
|
-
const executeFn = vi.fn().mockResolvedValue({ temp: 22 });
|
|
315
|
-
|
|
316
|
-
const agent = new BuiltInAgent({
|
|
317
|
-
model: "openai/gpt-4o",
|
|
318
|
-
tools: [
|
|
319
|
-
defineTool({
|
|
320
|
-
name: "weather",
|
|
321
|
-
description: "Get weather",
|
|
322
|
-
parameters: z.object({ city: z.string() }),
|
|
323
|
-
execute: executeFn,
|
|
324
|
-
}),
|
|
325
|
-
],
|
|
326
|
-
});
|
|
327
|
-
|
|
328
|
-
vi.mocked(streamText).mockReturnValue(
|
|
329
|
-
mockStreamTextResponse([finish()]) as any,
|
|
330
|
-
);
|
|
331
|
-
|
|
332
|
-
const input: RunAgentInput = {
|
|
333
|
-
threadId: "thread1",
|
|
334
|
-
runId: "run1",
|
|
335
|
-
messages: [],
|
|
336
|
-
tools: [],
|
|
337
|
-
context: [],
|
|
338
|
-
state: {},
|
|
339
|
-
};
|
|
340
|
-
|
|
341
|
-
await collectEvents(agent["run"](input));
|
|
342
|
-
|
|
343
|
-
const callArgs = vi.mocked(streamText).mock.calls[0][0];
|
|
344
|
-
const weatherTool = callArgs.tools?.weather;
|
|
345
|
-
|
|
346
|
-
// Invoke the execute function to verify it's wired correctly
|
|
347
|
-
await weatherTool.execute({ city: "Berlin" });
|
|
348
|
-
expect(executeFn).toHaveBeenCalledWith({ city: "Berlin" });
|
|
349
|
-
});
|
|
350
|
-
});
|
|
@@ -1,326 +0,0 @@
|
|
|
1
|
-
import {
|
|
2
|
-
BaseEvent,
|
|
3
|
-
EventType,
|
|
4
|
-
ReasoningEndEvent,
|
|
5
|
-
ReasoningMessageContentEvent,
|
|
6
|
-
ReasoningMessageEndEvent,
|
|
7
|
-
ReasoningMessageStartEvent,
|
|
8
|
-
ReasoningStartEvent,
|
|
9
|
-
TextMessageChunkEvent,
|
|
10
|
-
ToolCallArgsEvent,
|
|
11
|
-
ToolCallEndEvent,
|
|
12
|
-
ToolCallStartEvent,
|
|
13
|
-
ToolCallResultEvent,
|
|
14
|
-
StateSnapshotEvent,
|
|
15
|
-
StateDeltaEvent,
|
|
16
|
-
} from "@ag-ui/client";
|
|
17
|
-
import { randomUUID } from "@copilotkit/shared";
|
|
18
|
-
|
|
19
|
-
/**
|
|
20
|
-
* Converts an AI SDK `fullStream` into AG-UI `BaseEvent` objects.
|
|
21
|
-
*
|
|
22
|
-
* This is a pure converter — it does NOT emit lifecycle events
|
|
23
|
-
* (RUN_STARTED / RUN_FINISHED / RUN_ERROR). The caller (Agent class)
|
|
24
|
-
* is responsible for those.
|
|
25
|
-
*
|
|
26
|
-
* Terminal stream events (finish, error, abort) cause the generator to
|
|
27
|
-
* return so the caller can handle lifecycle appropriately.
|
|
28
|
-
*/
|
|
29
|
-
export async function* convertAISDKStream(
|
|
30
|
-
fullStream: AsyncIterable<unknown>,
|
|
31
|
-
abortSignal: AbortSignal,
|
|
32
|
-
): AsyncGenerator<BaseEvent> {
|
|
33
|
-
let messageId = randomUUID();
|
|
34
|
-
let reasoningMessageId = randomUUID();
|
|
35
|
-
let isInReasoning = false;
|
|
36
|
-
|
|
37
|
-
const toolCallStates = new Map<
|
|
38
|
-
string,
|
|
39
|
-
{
|
|
40
|
-
started: boolean;
|
|
41
|
-
hasArgsDelta: boolean;
|
|
42
|
-
ended: boolean;
|
|
43
|
-
toolName?: string;
|
|
44
|
-
}
|
|
45
|
-
>();
|
|
46
|
-
|
|
47
|
-
const ensureToolCallState = (toolCallId: string) => {
|
|
48
|
-
let state = toolCallStates.get(toolCallId);
|
|
49
|
-
if (!state) {
|
|
50
|
-
state = { started: false, hasArgsDelta: false, ended: false };
|
|
51
|
-
toolCallStates.set(toolCallId, state);
|
|
52
|
-
}
|
|
53
|
-
return state;
|
|
54
|
-
};
|
|
55
|
-
|
|
56
|
-
/**
|
|
57
|
-
* Auto-close an open reasoning lifecycle.
|
|
58
|
-
* Some AI SDK providers (notably @ai-sdk/anthropic) never emit "reasoning-end",
|
|
59
|
-
* which leaves downstream state machines stuck. This helper emits the
|
|
60
|
-
* missing REASONING_MESSAGE_END + REASONING_END events so the stream
|
|
61
|
-
* can transition to text, tool-call, or finish phases.
|
|
62
|
-
*/
|
|
63
|
-
function* closeReasoningIfOpen(): Generator<BaseEvent> {
|
|
64
|
-
if (!isInReasoning) return;
|
|
65
|
-
isInReasoning = false;
|
|
66
|
-
const reasoningMsgEnd: ReasoningMessageEndEvent = {
|
|
67
|
-
type: EventType.REASONING_MESSAGE_END,
|
|
68
|
-
messageId: reasoningMessageId,
|
|
69
|
-
};
|
|
70
|
-
yield reasoningMsgEnd;
|
|
71
|
-
const reasoningEnd: ReasoningEndEvent = {
|
|
72
|
-
type: EventType.REASONING_END,
|
|
73
|
-
messageId: reasoningMessageId,
|
|
74
|
-
};
|
|
75
|
-
yield reasoningEnd;
|
|
76
|
-
}
|
|
77
|
-
|
|
78
|
-
try {
|
|
79
|
-
for await (const part of fullStream) {
|
|
80
|
-
const p = part as Record<string, unknown>;
|
|
81
|
-
|
|
82
|
-
// Close any open reasoning lifecycle on every event except
|
|
83
|
-
// reasoning-delta, which arrives mid-block and must not interrupt it.
|
|
84
|
-
if (p.type !== "reasoning-delta") {
|
|
85
|
-
yield* closeReasoningIfOpen();
|
|
86
|
-
}
|
|
87
|
-
|
|
88
|
-
switch (p.type) {
|
|
89
|
-
case "abort": {
|
|
90
|
-
// Terminal — let the caller handle lifecycle
|
|
91
|
-
return;
|
|
92
|
-
}
|
|
93
|
-
|
|
94
|
-
case "reasoning-start": {
|
|
95
|
-
// Use SDK-provided id, or generate a fresh UUID if id is falsy/"0"
|
|
96
|
-
// to prevent consecutive reasoning blocks from sharing a messageId
|
|
97
|
-
const providedId = "id" in p ? p.id : undefined;
|
|
98
|
-
reasoningMessageId =
|
|
99
|
-
providedId && providedId !== "0"
|
|
100
|
-
? (providedId as string)
|
|
101
|
-
: randomUUID();
|
|
102
|
-
const reasoningStartEvent: ReasoningStartEvent = {
|
|
103
|
-
type: EventType.REASONING_START,
|
|
104
|
-
messageId: reasoningMessageId,
|
|
105
|
-
};
|
|
106
|
-
yield reasoningStartEvent;
|
|
107
|
-
const reasoningMessageStart: ReasoningMessageStartEvent = {
|
|
108
|
-
type: EventType.REASONING_MESSAGE_START,
|
|
109
|
-
messageId: reasoningMessageId,
|
|
110
|
-
role: "reasoning",
|
|
111
|
-
};
|
|
112
|
-
yield reasoningMessageStart;
|
|
113
|
-
isInReasoning = true;
|
|
114
|
-
break;
|
|
115
|
-
}
|
|
116
|
-
|
|
117
|
-
case "reasoning-delta": {
|
|
118
|
-
const delta = (p.text as string) ?? "";
|
|
119
|
-
if (!delta) break; // skip — @ag-ui/core schema requires delta to be non-empty
|
|
120
|
-
const reasoningDeltaEvent: ReasoningMessageContentEvent = {
|
|
121
|
-
type: EventType.REASONING_MESSAGE_CONTENT,
|
|
122
|
-
messageId: reasoningMessageId,
|
|
123
|
-
delta,
|
|
124
|
-
};
|
|
125
|
-
yield reasoningDeltaEvent;
|
|
126
|
-
break;
|
|
127
|
-
}
|
|
128
|
-
|
|
129
|
-
case "reasoning-end": {
|
|
130
|
-
// closeReasoningIfOpen() already called before the switch — no-op here
|
|
131
|
-
// if the SDK never emits this event (e.g. @ai-sdk/anthropic).
|
|
132
|
-
break;
|
|
133
|
-
}
|
|
134
|
-
|
|
135
|
-
case "tool-input-start": {
|
|
136
|
-
const toolCallId = p.id as string;
|
|
137
|
-
const state = ensureToolCallState(toolCallId);
|
|
138
|
-
state.toolName = p.toolName as string;
|
|
139
|
-
if (!state.started) {
|
|
140
|
-
state.started = true;
|
|
141
|
-
const startEvent: ToolCallStartEvent = {
|
|
142
|
-
type: EventType.TOOL_CALL_START,
|
|
143
|
-
parentMessageId: messageId,
|
|
144
|
-
toolCallId,
|
|
145
|
-
toolCallName: p.toolName as string,
|
|
146
|
-
};
|
|
147
|
-
yield startEvent;
|
|
148
|
-
}
|
|
149
|
-
break;
|
|
150
|
-
}
|
|
151
|
-
|
|
152
|
-
case "tool-input-delta": {
|
|
153
|
-
const toolCallId = p.id as string;
|
|
154
|
-
const state = ensureToolCallState(toolCallId);
|
|
155
|
-
state.hasArgsDelta = true;
|
|
156
|
-
const argsEvent: ToolCallArgsEvent = {
|
|
157
|
-
type: EventType.TOOL_CALL_ARGS,
|
|
158
|
-
toolCallId,
|
|
159
|
-
delta: p.delta as string,
|
|
160
|
-
};
|
|
161
|
-
yield argsEvent;
|
|
162
|
-
break;
|
|
163
|
-
}
|
|
164
|
-
|
|
165
|
-
case "tool-input-end": {
|
|
166
|
-
// No direct event – the subsequent "tool-call" part marks completion.
|
|
167
|
-
break;
|
|
168
|
-
}
|
|
169
|
-
|
|
170
|
-
case "text-start": {
|
|
171
|
-
// New text message starting - use the SDK-provided id
|
|
172
|
-
// Use randomUUID() if part.id is falsy or "0" to prevent message merging issues
|
|
173
|
-
const providedId = "id" in p ? p.id : undefined;
|
|
174
|
-
messageId =
|
|
175
|
-
providedId && providedId !== "0"
|
|
176
|
-
? (providedId as string)
|
|
177
|
-
: randomUUID();
|
|
178
|
-
break;
|
|
179
|
-
}
|
|
180
|
-
|
|
181
|
-
case "text-delta": {
|
|
182
|
-
// AI SDK text-delta events use 'text' (not 'delta')
|
|
183
|
-
const textDelta = "text" in p ? (p.text as string) : "";
|
|
184
|
-
const textEvent: TextMessageChunkEvent = {
|
|
185
|
-
type: EventType.TEXT_MESSAGE_CHUNK,
|
|
186
|
-
role: "assistant",
|
|
187
|
-
messageId,
|
|
188
|
-
delta: textDelta,
|
|
189
|
-
};
|
|
190
|
-
yield textEvent;
|
|
191
|
-
break;
|
|
192
|
-
}
|
|
193
|
-
|
|
194
|
-
case "tool-call": {
|
|
195
|
-
const toolCallId = p.toolCallId as string;
|
|
196
|
-
const state = ensureToolCallState(toolCallId);
|
|
197
|
-
state.toolName = (p.toolName as string) ?? state.toolName;
|
|
198
|
-
|
|
199
|
-
if (!state.started) {
|
|
200
|
-
state.started = true;
|
|
201
|
-
const startEvent: ToolCallStartEvent = {
|
|
202
|
-
type: EventType.TOOL_CALL_START,
|
|
203
|
-
parentMessageId: messageId,
|
|
204
|
-
toolCallId,
|
|
205
|
-
toolCallName: p.toolName as string,
|
|
206
|
-
};
|
|
207
|
-
yield startEvent;
|
|
208
|
-
}
|
|
209
|
-
|
|
210
|
-
if (!state.hasArgsDelta && "input" in p && p.input !== undefined) {
|
|
211
|
-
let serializedInput = "";
|
|
212
|
-
if (typeof p.input === "string") {
|
|
213
|
-
serializedInput = p.input;
|
|
214
|
-
} else {
|
|
215
|
-
try {
|
|
216
|
-
serializedInput = JSON.stringify(p.input);
|
|
217
|
-
} catch {
|
|
218
|
-
serializedInput = String(p.input);
|
|
219
|
-
}
|
|
220
|
-
}
|
|
221
|
-
|
|
222
|
-
if (serializedInput.length > 0) {
|
|
223
|
-
const argsEvent: ToolCallArgsEvent = {
|
|
224
|
-
type: EventType.TOOL_CALL_ARGS,
|
|
225
|
-
toolCallId,
|
|
226
|
-
delta: serializedInput,
|
|
227
|
-
};
|
|
228
|
-
yield argsEvent;
|
|
229
|
-
state.hasArgsDelta = true;
|
|
230
|
-
}
|
|
231
|
-
}
|
|
232
|
-
|
|
233
|
-
if (!state.ended) {
|
|
234
|
-
state.ended = true;
|
|
235
|
-
const endEvent: ToolCallEndEvent = {
|
|
236
|
-
type: EventType.TOOL_CALL_END,
|
|
237
|
-
toolCallId,
|
|
238
|
-
};
|
|
239
|
-
yield endEvent;
|
|
240
|
-
}
|
|
241
|
-
break;
|
|
242
|
-
}
|
|
243
|
-
|
|
244
|
-
case "tool-result": {
|
|
245
|
-
// AI SDK tool-result uses "output"; older versions used "result" — check both
|
|
246
|
-
const toolResult =
|
|
247
|
-
"output" in p ? p.output : "result" in p ? p.result : null;
|
|
248
|
-
const toolName = "toolName" in p ? (p.toolName as string) : "";
|
|
249
|
-
toolCallStates.delete(p.toolCallId as string);
|
|
250
|
-
|
|
251
|
-
// Check if this is a state update tool
|
|
252
|
-
if (
|
|
253
|
-
toolName === "AGUISendStateSnapshot" &&
|
|
254
|
-
toolResult &&
|
|
255
|
-
typeof toolResult === "object"
|
|
256
|
-
) {
|
|
257
|
-
const snapshot = (toolResult as Record<string, unknown>).snapshot;
|
|
258
|
-
if (snapshot !== undefined) {
|
|
259
|
-
const stateSnapshotEvent: StateSnapshotEvent = {
|
|
260
|
-
type: EventType.STATE_SNAPSHOT,
|
|
261
|
-
snapshot,
|
|
262
|
-
};
|
|
263
|
-
yield stateSnapshotEvent;
|
|
264
|
-
}
|
|
265
|
-
} else if (
|
|
266
|
-
toolName === "AGUISendStateDelta" &&
|
|
267
|
-
toolResult &&
|
|
268
|
-
typeof toolResult === "object"
|
|
269
|
-
) {
|
|
270
|
-
const delta = (toolResult as Record<string, unknown>).delta;
|
|
271
|
-
if (delta !== undefined) {
|
|
272
|
-
const stateDeltaEvent: StateDeltaEvent = {
|
|
273
|
-
type: EventType.STATE_DELTA,
|
|
274
|
-
delta,
|
|
275
|
-
};
|
|
276
|
-
yield stateDeltaEvent;
|
|
277
|
-
}
|
|
278
|
-
}
|
|
279
|
-
|
|
280
|
-
// Always emit the tool result event for the LLM
|
|
281
|
-
let serializedResult: string;
|
|
282
|
-
try {
|
|
283
|
-
serializedResult = JSON.stringify(toolResult);
|
|
284
|
-
} catch {
|
|
285
|
-
serializedResult = `[Unserializable tool result from ${toolName || "unknown tool"}]`;
|
|
286
|
-
}
|
|
287
|
-
const resultEvent: ToolCallResultEvent = {
|
|
288
|
-
type: EventType.TOOL_CALL_RESULT,
|
|
289
|
-
role: "tool",
|
|
290
|
-
messageId: randomUUID(),
|
|
291
|
-
toolCallId: p.toolCallId as string,
|
|
292
|
-
content: serializedResult,
|
|
293
|
-
};
|
|
294
|
-
yield resultEvent;
|
|
295
|
-
break;
|
|
296
|
-
}
|
|
297
|
-
|
|
298
|
-
case "finish": {
|
|
299
|
-
// Terminal — let the caller handle lifecycle
|
|
300
|
-
return;
|
|
301
|
-
}
|
|
302
|
-
|
|
303
|
-
case "error": {
|
|
304
|
-
if (abortSignal.aborted) {
|
|
305
|
-
return;
|
|
306
|
-
}
|
|
307
|
-
// Re-throw so the caller can emit RUN_ERROR
|
|
308
|
-
const err = p.error ?? p.message ?? p.cause;
|
|
309
|
-
if (err instanceof Error) throw err;
|
|
310
|
-
throw new Error(
|
|
311
|
-
typeof err === "string"
|
|
312
|
-
? err
|
|
313
|
-
: `AI SDK stream error: ${JSON.stringify(p)}`,
|
|
314
|
-
);
|
|
315
|
-
}
|
|
316
|
-
|
|
317
|
-
default:
|
|
318
|
-
// Unknown event types are silently ignored
|
|
319
|
-
break;
|
|
320
|
-
}
|
|
321
|
-
}
|
|
322
|
-
} finally {
|
|
323
|
-
// Always close reasoning on exit (normal or exceptional)
|
|
324
|
-
yield* closeReasoningIfOpen();
|
|
325
|
-
}
|
|
326
|
-
}
|