@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,215 +0,0 @@
|
|
|
1
|
-
import { BaseEvent } from "@ag-ui/client";
|
|
2
|
-
import { EventEncoder } from "@ag-ui/encoder";
|
|
3
|
-
import { Observable, Subscription } from "rxjs";
|
|
4
|
-
import { ResolvedDebugConfig } from "@copilotkit/shared";
|
|
5
|
-
import {
|
|
6
|
-
createLogger,
|
|
7
|
-
type CopilotRuntimeLogger,
|
|
8
|
-
} from "../../../../lib/logger";
|
|
9
|
-
import { telemetry } from "../../telemetry";
|
|
10
|
-
import { DebugEventBus } from "../../core/debug-event-bus";
|
|
11
|
-
|
|
12
|
-
interface CreateSseEventResponseParams {
|
|
13
|
-
request: Request;
|
|
14
|
-
observableFactory: () =>
|
|
15
|
-
| Promise<Observable<BaseEvent>>
|
|
16
|
-
| Observable<BaseEvent>;
|
|
17
|
-
debugEventBus?: DebugEventBus;
|
|
18
|
-
agentId?: string;
|
|
19
|
-
debug?: ResolvedDebugConfig;
|
|
20
|
-
/** Pre-created logger instance to avoid creating a new pino logger per request. */
|
|
21
|
-
logger?: CopilotRuntimeLogger;
|
|
22
|
-
}
|
|
23
|
-
|
|
24
|
-
export function createSseEventResponse({
|
|
25
|
-
request,
|
|
26
|
-
observableFactory,
|
|
27
|
-
debugEventBus,
|
|
28
|
-
agentId,
|
|
29
|
-
debug,
|
|
30
|
-
logger,
|
|
31
|
-
}: CreateSseEventResponseParams): Response {
|
|
32
|
-
const stream = new TransformStream();
|
|
33
|
-
const writer = stream.writable.getWriter();
|
|
34
|
-
const encoder = new EventEncoder();
|
|
35
|
-
let streamClosed = false;
|
|
36
|
-
let debugThreadId = "";
|
|
37
|
-
let debugRunId = "";
|
|
38
|
-
|
|
39
|
-
const debugLogger = debug?.enabled
|
|
40
|
-
? (logger ??
|
|
41
|
-
createLogger({ level: "debug", component: "copilotkit-debug" }))
|
|
42
|
-
: undefined;
|
|
43
|
-
|
|
44
|
-
const closeStream = async () => {
|
|
45
|
-
if (!streamClosed) {
|
|
46
|
-
try {
|
|
47
|
-
await writer.close();
|
|
48
|
-
streamClosed = true;
|
|
49
|
-
} catch {
|
|
50
|
-
// Stream already closed.
|
|
51
|
-
}
|
|
52
|
-
}
|
|
53
|
-
};
|
|
54
|
-
|
|
55
|
-
const logError = (error: unknown) => {
|
|
56
|
-
console.error("Error running agent:", error);
|
|
57
|
-
console.error(
|
|
58
|
-
"Error stack:",
|
|
59
|
-
error instanceof Error ? error.stack : "No stack trace",
|
|
60
|
-
);
|
|
61
|
-
console.error("Error details:", {
|
|
62
|
-
name: error instanceof Error ? error.name : "Unknown",
|
|
63
|
-
message: error instanceof Error ? error.message : String(error),
|
|
64
|
-
cause: error instanceof Error ? error.cause : undefined,
|
|
65
|
-
});
|
|
66
|
-
};
|
|
67
|
-
|
|
68
|
-
let subscription: Subscription | undefined;
|
|
69
|
-
|
|
70
|
-
(async () => {
|
|
71
|
-
const observable = await observableFactory();
|
|
72
|
-
|
|
73
|
-
telemetry.capture("oss.runtime.agent_execution_stream_started", {});
|
|
74
|
-
|
|
75
|
-
if (debug?.lifecycle) {
|
|
76
|
-
debugLogger!.debug("SSE stream opened");
|
|
77
|
-
}
|
|
78
|
-
|
|
79
|
-
let eventCount = 0;
|
|
80
|
-
let loggedEventCount = 0;
|
|
81
|
-
|
|
82
|
-
subscription = observable.subscribe({
|
|
83
|
-
next: async (event) => {
|
|
84
|
-
// Extract threadId/runId from RUN_STARTED
|
|
85
|
-
if (event.type === "RUN_STARTED") {
|
|
86
|
-
const e = event as { threadId?: string; runId?: string };
|
|
87
|
-
debugThreadId = e.threadId ?? "";
|
|
88
|
-
debugRunId = e.runId ?? "";
|
|
89
|
-
}
|
|
90
|
-
|
|
91
|
-
// Broadcast to debug listeners BEFORE the stream-closed gate below.
|
|
92
|
-
// Intentional: debug subscribers (e.g. the VS Code Inspector panel)
|
|
93
|
-
// should still receive trailing events after the SSE client for
|
|
94
|
-
// this request closed its connection — they're independent
|
|
95
|
-
// consumers observing the underlying runtime, not the request's
|
|
96
|
-
// response stream.
|
|
97
|
-
//
|
|
98
|
-
// Wrapped in try/catch so a buggy debug subscriber can't propagate
|
|
99
|
-
// an exception into this observer — if the throw reached the
|
|
100
|
-
// `next` callback it would get routed to `error` by RxJS, closing
|
|
101
|
-
// the SSE stream for an unrelated reason. Log via `logError` and
|
|
102
|
-
// move on.
|
|
103
|
-
if (debugEventBus) {
|
|
104
|
-
try {
|
|
105
|
-
debugEventBus.broadcast(event, {
|
|
106
|
-
agentId: agentId ?? "",
|
|
107
|
-
threadId: debugThreadId,
|
|
108
|
-
runId: debugRunId,
|
|
109
|
-
});
|
|
110
|
-
} catch (broadcastError) {
|
|
111
|
-
logError(broadcastError);
|
|
112
|
-
}
|
|
113
|
-
}
|
|
114
|
-
|
|
115
|
-
if (!request.signal.aborted && !streamClosed) {
|
|
116
|
-
try {
|
|
117
|
-
eventCount++;
|
|
118
|
-
if (debug?.events) {
|
|
119
|
-
loggedEventCount++;
|
|
120
|
-
if (debug.verbose) {
|
|
121
|
-
debugLogger!.debug({ event }, "Event emitted");
|
|
122
|
-
} else {
|
|
123
|
-
debugLogger!.debug(
|
|
124
|
-
{ type: event.type, ...summarizeEvent(event) },
|
|
125
|
-
"Event emitted",
|
|
126
|
-
);
|
|
127
|
-
}
|
|
128
|
-
}
|
|
129
|
-
await writer.write(encoder.encode(event));
|
|
130
|
-
} catch (error) {
|
|
131
|
-
if (error instanceof Error && error.name === "AbortError") {
|
|
132
|
-
streamClosed = true;
|
|
133
|
-
} else {
|
|
134
|
-
// Non-abort write failures (backpressure disconnects,
|
|
135
|
-
// transform-stream exceptions, …) were previously swallowed
|
|
136
|
-
// silently — `streamClosed` stayed `false` and the next
|
|
137
|
-
// event re-attempted a broken writer. Log and mark the
|
|
138
|
-
// stream closed so we stop trying.
|
|
139
|
-
logError(error);
|
|
140
|
-
streamClosed = true;
|
|
141
|
-
}
|
|
142
|
-
}
|
|
143
|
-
}
|
|
144
|
-
},
|
|
145
|
-
error: async (error) => {
|
|
146
|
-
telemetry.capture("oss.runtime.agent_execution_stream_errored", {
|
|
147
|
-
error: error instanceof Error ? error.message : String(error),
|
|
148
|
-
});
|
|
149
|
-
if (debug?.lifecycle) {
|
|
150
|
-
debugLogger!.debug(
|
|
151
|
-
{ error: error instanceof Error ? error.message : String(error) },
|
|
152
|
-
"SSE stream errored",
|
|
153
|
-
);
|
|
154
|
-
}
|
|
155
|
-
logError(error);
|
|
156
|
-
await closeStream();
|
|
157
|
-
},
|
|
158
|
-
complete: async () => {
|
|
159
|
-
telemetry.capture("oss.runtime.agent_execution_stream_ended", {});
|
|
160
|
-
if (debug?.lifecycle) {
|
|
161
|
-
debugLogger!.debug(
|
|
162
|
-
{ eventCount, loggedEventCount },
|
|
163
|
-
"SSE stream completed",
|
|
164
|
-
);
|
|
165
|
-
}
|
|
166
|
-
await closeStream();
|
|
167
|
-
},
|
|
168
|
-
});
|
|
169
|
-
|
|
170
|
-
// If the client disconnected before the subscription was created,
|
|
171
|
-
// unsubscribe immediately to avoid leaking the observable.
|
|
172
|
-
if (request.signal.aborted) {
|
|
173
|
-
subscription.unsubscribe();
|
|
174
|
-
}
|
|
175
|
-
})().catch(async (error) => {
|
|
176
|
-
logError(error);
|
|
177
|
-
await closeStream();
|
|
178
|
-
});
|
|
179
|
-
|
|
180
|
-
request.signal.addEventListener("abort", () => {
|
|
181
|
-
subscription?.unsubscribe();
|
|
182
|
-
});
|
|
183
|
-
|
|
184
|
-
return new Response(stream.readable, {
|
|
185
|
-
status: 200,
|
|
186
|
-
headers: {
|
|
187
|
-
"Content-Type": "text/event-stream",
|
|
188
|
-
"Cache-Control": "no-cache",
|
|
189
|
-
Connection: "keep-alive",
|
|
190
|
-
},
|
|
191
|
-
});
|
|
192
|
-
}
|
|
193
|
-
|
|
194
|
-
function summarizeEvent(event: BaseEvent): Record<string, unknown> {
|
|
195
|
-
const e = event as any;
|
|
196
|
-
const summary: Record<string, unknown> = {};
|
|
197
|
-
|
|
198
|
-
if (e.messageId) summary.messageId = e.messageId;
|
|
199
|
-
if (e.toolCallId) summary.toolCallId = e.toolCallId;
|
|
200
|
-
if (e.toolCallName) summary.toolCallName = e.toolCallName;
|
|
201
|
-
if (e.role) summary.role = e.role;
|
|
202
|
-
if (e.delta != null && typeof e.delta === "string")
|
|
203
|
-
summary.deltaLength = e.delta.length;
|
|
204
|
-
if (e.snapshot && typeof e.snapshot === "object")
|
|
205
|
-
summary.snapshotKeys = Object.keys(e.snapshot);
|
|
206
|
-
if (e.delta && Array.isArray(e.delta))
|
|
207
|
-
summary.operationCount = e.delta.length;
|
|
208
|
-
if (e.threadId) summary.threadId = e.threadId;
|
|
209
|
-
if (e.runId) summary.runId = e.runId;
|
|
210
|
-
if (e.message) summary.message = e.message;
|
|
211
|
-
if (e.code) summary.code = e.code;
|
|
212
|
-
if (e.stepName) summary.stepName = e.stepName;
|
|
213
|
-
|
|
214
|
-
return summary;
|
|
215
|
-
}
|
|
@@ -1,71 +0,0 @@
|
|
|
1
|
-
import { describe, it, expect, vi } from "vitest";
|
|
2
|
-
import { of } from "rxjs";
|
|
3
|
-
import { EventType, type BaseEvent } from "@ag-ui/client";
|
|
4
|
-
|
|
5
|
-
vi.mock("pino", () => ({
|
|
6
|
-
default: vi.fn(() => ({
|
|
7
|
-
child: vi.fn(() => ({ debug: vi.fn() })),
|
|
8
|
-
debug: vi.fn(),
|
|
9
|
-
})),
|
|
10
|
-
}));
|
|
11
|
-
vi.mock("pino-pretty", () => ({ default: vi.fn() }));
|
|
12
|
-
vi.mock("../../../telemetry", () => ({
|
|
13
|
-
telemetry: { capture: vi.fn() },
|
|
14
|
-
}));
|
|
15
|
-
|
|
16
|
-
import { handleSseConnect } from "../connect";
|
|
17
|
-
import { DebugEventBus } from "../../../core/debug-event-bus";
|
|
18
|
-
|
|
19
|
-
/**
|
|
20
|
-
* Regression guard for the agentId forwarding fix. `handleSseConnect` used
|
|
21
|
-
* to hardcode `agentId: "connect"` in every debug envelope emitted on
|
|
22
|
-
* /agent/:agentId/connect; the fix threads the route-resolved agentId
|
|
23
|
-
* through to `createSseEventResponse`. Reverting that change would make
|
|
24
|
-
* this test fail — the /run-based integration coverage wouldn't catch it
|
|
25
|
-
* because /run is a different code path.
|
|
26
|
-
*/
|
|
27
|
-
describe("handleSseConnect → debug envelope agentId", () => {
|
|
28
|
-
it("forwards the real agentId into envelopes on /connect", async () => {
|
|
29
|
-
const bus = new DebugEventBus();
|
|
30
|
-
const received: Array<{ agentId: string }> = [];
|
|
31
|
-
bus.subscribe((envelope) => {
|
|
32
|
-
received.push({ agentId: envelope.agentId });
|
|
33
|
-
});
|
|
34
|
-
|
|
35
|
-
const event: BaseEvent = {
|
|
36
|
-
type: EventType.RUN_STARTED,
|
|
37
|
-
threadId: "t-1",
|
|
38
|
-
runId: "r-1",
|
|
39
|
-
} as BaseEvent;
|
|
40
|
-
|
|
41
|
-
const fakeRuntime = {
|
|
42
|
-
debugEventBus: bus,
|
|
43
|
-
runner: {
|
|
44
|
-
connect: () => of(event),
|
|
45
|
-
},
|
|
46
|
-
} as any;
|
|
47
|
-
|
|
48
|
-
const response = handleSseConnect({
|
|
49
|
-
runtime: fakeRuntime,
|
|
50
|
-
request: new Request("http://localhost/agent/weather-agent/connect", {
|
|
51
|
-
method: "POST",
|
|
52
|
-
}),
|
|
53
|
-
agentId: "weather-agent",
|
|
54
|
-
threadId: "t-1",
|
|
55
|
-
});
|
|
56
|
-
|
|
57
|
-
// Drain to let the observable subscription fire.
|
|
58
|
-
const reader = response.body!.getReader();
|
|
59
|
-
while (true) {
|
|
60
|
-
const { done } = await reader.read();
|
|
61
|
-
if (done) break;
|
|
62
|
-
}
|
|
63
|
-
|
|
64
|
-
expect(received.length).toBeGreaterThan(0);
|
|
65
|
-
for (const env of received) {
|
|
66
|
-
// A revert to the pre-fix hardcoded "connect" would fail this
|
|
67
|
-
// positive assertion — no need for a separate not-toBe guard.
|
|
68
|
-
expect(env.agentId).toBe("weather-agent");
|
|
69
|
-
}
|
|
70
|
-
});
|
|
71
|
-
});
|
|
@@ -1,30 +0,0 @@
|
|
|
1
|
-
import { CopilotRuntimeLike } from "../../core/runtime";
|
|
2
|
-
import { createSseEventResponse } from "../shared/sse-response";
|
|
3
|
-
import { extractForwardableHeaders } from "../header-utils";
|
|
4
|
-
|
|
5
|
-
interface HandleSseConnectParams {
|
|
6
|
-
runtime: CopilotRuntimeLike;
|
|
7
|
-
request: Request;
|
|
8
|
-
agentId: string;
|
|
9
|
-
threadId: string;
|
|
10
|
-
}
|
|
11
|
-
|
|
12
|
-
export function handleSseConnect({
|
|
13
|
-
runtime,
|
|
14
|
-
request,
|
|
15
|
-
agentId,
|
|
16
|
-
threadId,
|
|
17
|
-
}: HandleSseConnectParams): Response {
|
|
18
|
-
return createSseEventResponse({
|
|
19
|
-
request,
|
|
20
|
-
debugEventBus: runtime.debugEventBus,
|
|
21
|
-
// Forward the real agentId so debug envelopes reflect the agent the
|
|
22
|
-
// route resolved to — not the literal string "connect".
|
|
23
|
-
agentId,
|
|
24
|
-
observableFactory: () =>
|
|
25
|
-
runtime.runner.connect({
|
|
26
|
-
threadId,
|
|
27
|
-
headers: extractForwardableHeaders(request),
|
|
28
|
-
}),
|
|
29
|
-
});
|
|
30
|
-
}
|
|
@@ -1,40 +0,0 @@
|
|
|
1
|
-
import { AbstractAgent, RunAgentInput } from "@ag-ui/client";
|
|
2
|
-
import { ResolvedDebugConfig } from "@copilotkit/shared";
|
|
3
|
-
import { type CopilotRuntimeLogger } from "../../../../lib/logger";
|
|
4
|
-
import { CopilotRuntimeLike } from "../../core/runtime";
|
|
5
|
-
import { createSseEventResponse } from "../shared/sse-response";
|
|
6
|
-
|
|
7
|
-
interface HandleSseRunParams {
|
|
8
|
-
runtime: CopilotRuntimeLike;
|
|
9
|
-
request: Request;
|
|
10
|
-
agent: AbstractAgent;
|
|
11
|
-
input: RunAgentInput;
|
|
12
|
-
agentId: string;
|
|
13
|
-
debug?: ResolvedDebugConfig;
|
|
14
|
-
/** Pre-created logger instance to avoid creating a new pino logger per request. */
|
|
15
|
-
logger?: CopilotRuntimeLogger;
|
|
16
|
-
}
|
|
17
|
-
|
|
18
|
-
export function handleSseRun({
|
|
19
|
-
runtime,
|
|
20
|
-
request,
|
|
21
|
-
agent,
|
|
22
|
-
input,
|
|
23
|
-
agentId,
|
|
24
|
-
debug,
|
|
25
|
-
logger,
|
|
26
|
-
}: HandleSseRunParams): Response {
|
|
27
|
-
return createSseEventResponse({
|
|
28
|
-
request,
|
|
29
|
-
debugEventBus: runtime.debugEventBus,
|
|
30
|
-
agentId,
|
|
31
|
-
debug,
|
|
32
|
-
logger,
|
|
33
|
-
observableFactory: () =>
|
|
34
|
-
runtime.runner.run({
|
|
35
|
-
threadId: input.threadId,
|
|
36
|
-
agent,
|
|
37
|
-
input,
|
|
38
|
-
}),
|
|
39
|
-
});
|
|
40
|
-
}
|
package/src/v2/runtime/hono.ts
DELETED
package/src/v2/runtime/index.ts
DELETED
|
@@ -1,51 +0,0 @@
|
|
|
1
|
-
export * from "./core/runtime";
|
|
2
|
-
export * from "./endpoints";
|
|
3
|
-
|
|
4
|
-
// Export agent runners and base types
|
|
5
|
-
export * from "./runner";
|
|
6
|
-
|
|
7
|
-
// Export transcription services
|
|
8
|
-
export * from "./transcription-service/transcription-service";
|
|
9
|
-
|
|
10
|
-
// Export intelligence platform client and types
|
|
11
|
-
export {
|
|
12
|
-
CopilotKitIntelligence,
|
|
13
|
-
type CopilotKitIntelligenceConfig,
|
|
14
|
-
type CreateThreadRequest,
|
|
15
|
-
type ThreadSummary,
|
|
16
|
-
type ListThreadsResponse,
|
|
17
|
-
type SubscribeToThreadsRequest,
|
|
18
|
-
type SubscribeToThreadsResponse,
|
|
19
|
-
type UpdateThreadRequest,
|
|
20
|
-
} from "./intelligence-platform";
|
|
21
|
-
|
|
22
|
-
// Re-export `@ai-sdk/mcp` stable types so consumers don't need to depend on
|
|
23
|
-
// it directly to type their MCP wiring. `MCPClient` is the value users pass
|
|
24
|
-
// into `mcpClients`; `MCPTransport` is the contract for custom transports.
|
|
25
|
-
export type { MCPClient, MCPTransport } from "@ai-sdk/mcp";
|
|
26
|
-
|
|
27
|
-
// Export framework-agnostic fetch handler
|
|
28
|
-
export { createCopilotRuntimeHandler } from "./core/fetch-handler";
|
|
29
|
-
export type {
|
|
30
|
-
CopilotRuntimeHandlerOptions,
|
|
31
|
-
CopilotRuntimeFetchHandler,
|
|
32
|
-
} from "./core/fetch-handler";
|
|
33
|
-
|
|
34
|
-
// Export hook types
|
|
35
|
-
export type {
|
|
36
|
-
CopilotRuntimeHooks,
|
|
37
|
-
HookContext,
|
|
38
|
-
HandlerHookContext,
|
|
39
|
-
ResponseHookContext,
|
|
40
|
-
ErrorHookContext,
|
|
41
|
-
RouteInfo,
|
|
42
|
-
} from "./core/hooks";
|
|
43
|
-
|
|
44
|
-
// Export CORS config type
|
|
45
|
-
export type { CopilotCorsConfig } from "./core/fetch-cors";
|
|
46
|
-
|
|
47
|
-
// Deprecated type aliases for backward compatibility
|
|
48
|
-
/** @deprecated Use `CopilotRuntimeFetchHandler` instead. Note: the new type takes `Request` directly, not `{ request: Request }`. */
|
|
49
|
-
export type CopilotKitRequestHandler = (params: {
|
|
50
|
-
request: Request;
|
|
51
|
-
}) => Promise<Response>;
|