@copilotkit/runtime 1.57.3 → 1.58.0-canary.thread-id-propagation
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/observability.d.cts +1 -1
- package/dist/lib/observability.d.cts.map +1 -1
- package/dist/lib/observability.d.mts +1 -1
- package/dist/lib/observability.d.mts.map +1 -1
- 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 +5 -8
- package/dist/package.mjs +5 -8
- 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 +9 -19
- 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,420 +0,0 @@
|
|
|
1
|
-
import {
|
|
2
|
-
CopilotIntelligenceRuntimeLike,
|
|
3
|
-
CopilotRuntimeLike,
|
|
4
|
-
isIntelligenceRuntime,
|
|
5
|
-
} from "../../core/runtime";
|
|
6
|
-
import { logger } from "@copilotkit/shared";
|
|
7
|
-
import { errorResponse, isHandlerResponse } from "../shared/json-response";
|
|
8
|
-
import { isValidIdentifier } from "../shared/intelligence-utils";
|
|
9
|
-
import { resolveIntelligenceUser } from "../shared/resolve-intelligence-user";
|
|
10
|
-
import { InMemoryAgentRunner } from "../../runner/in-memory";
|
|
11
|
-
|
|
12
|
-
interface ThreadsHandlerParams {
|
|
13
|
-
runtime: CopilotRuntimeLike;
|
|
14
|
-
request: Request;
|
|
15
|
-
}
|
|
16
|
-
|
|
17
|
-
interface ThreadMutationParams extends ThreadsHandlerParams {
|
|
18
|
-
threadId: string;
|
|
19
|
-
}
|
|
20
|
-
|
|
21
|
-
interface ThreadMutationContext {
|
|
22
|
-
userId: string;
|
|
23
|
-
agentId: string;
|
|
24
|
-
body: Record<string, unknown>;
|
|
25
|
-
}
|
|
26
|
-
|
|
27
|
-
async function parseJsonBody(
|
|
28
|
-
request: Request,
|
|
29
|
-
): Promise<Record<string, unknown> | Response> {
|
|
30
|
-
try {
|
|
31
|
-
return (await request.json()) as Record<string, unknown>;
|
|
32
|
-
} catch (error) {
|
|
33
|
-
logger.error({ err: error }, "Malformed JSON in request body");
|
|
34
|
-
return errorResponse("Invalid request body", 400);
|
|
35
|
-
}
|
|
36
|
-
}
|
|
37
|
-
|
|
38
|
-
function requireIntelligenceRuntime(
|
|
39
|
-
runtime: CopilotRuntimeLike,
|
|
40
|
-
): CopilotIntelligenceRuntimeLike | Response {
|
|
41
|
-
if (!isIntelligenceRuntime(runtime)) {
|
|
42
|
-
return errorResponse(
|
|
43
|
-
"Missing CopilotKitIntelligence configuration. Thread operations require a CopilotKitIntelligence instance to be provided in CopilotRuntime options.",
|
|
44
|
-
422,
|
|
45
|
-
);
|
|
46
|
-
}
|
|
47
|
-
|
|
48
|
-
return runtime;
|
|
49
|
-
}
|
|
50
|
-
|
|
51
|
-
async function resolveThreadMutationContext(
|
|
52
|
-
runtime: CopilotIntelligenceRuntimeLike,
|
|
53
|
-
request: Request,
|
|
54
|
-
): Promise<ThreadMutationContext | Response> {
|
|
55
|
-
const body = await parseJsonBody(request);
|
|
56
|
-
if (isHandlerResponse(body)) return body;
|
|
57
|
-
|
|
58
|
-
const user = await resolveIntelligenceUser({ runtime, request });
|
|
59
|
-
if (isHandlerResponse(user)) return user;
|
|
60
|
-
|
|
61
|
-
const agentId = body.agentId;
|
|
62
|
-
if (!isValidIdentifier(agentId)) {
|
|
63
|
-
return errorResponse("Valid agentId is required", 400);
|
|
64
|
-
}
|
|
65
|
-
|
|
66
|
-
return {
|
|
67
|
-
body,
|
|
68
|
-
userId: user.id,
|
|
69
|
-
agentId,
|
|
70
|
-
};
|
|
71
|
-
}
|
|
72
|
-
|
|
73
|
-
export async function handleListThreads({
|
|
74
|
-
runtime,
|
|
75
|
-
request,
|
|
76
|
-
}: ThreadsHandlerParams): Promise<Response> {
|
|
77
|
-
// Intelligence platform path
|
|
78
|
-
if (isIntelligenceRuntime(runtime)) {
|
|
79
|
-
try {
|
|
80
|
-
const url = new URL(request.url);
|
|
81
|
-
const agentId = url.searchParams.get("agentId");
|
|
82
|
-
const includeArchived =
|
|
83
|
-
url.searchParams.get("includeArchived") === "true";
|
|
84
|
-
const limitParam = url.searchParams.get("limit");
|
|
85
|
-
const cursor = url.searchParams.get("cursor");
|
|
86
|
-
const user = await resolveIntelligenceUser({ runtime, request });
|
|
87
|
-
if (isHandlerResponse(user)) return user;
|
|
88
|
-
|
|
89
|
-
if (!isValidIdentifier(agentId)) {
|
|
90
|
-
return errorResponse("Valid agentId query param is required", 400);
|
|
91
|
-
}
|
|
92
|
-
|
|
93
|
-
const data = await runtime.intelligence.listThreads({
|
|
94
|
-
userId: user.id,
|
|
95
|
-
agentId,
|
|
96
|
-
...(includeArchived ? { includeArchived: true } : {}),
|
|
97
|
-
...(limitParam ? { limit: Number(limitParam) } : {}),
|
|
98
|
-
...(cursor ? { cursor } : {}),
|
|
99
|
-
});
|
|
100
|
-
|
|
101
|
-
return Response.json(data);
|
|
102
|
-
} catch (error) {
|
|
103
|
-
logger.error({ err: error }, "Error listing threads");
|
|
104
|
-
return errorResponse("Failed to list threads", 500);
|
|
105
|
-
}
|
|
106
|
-
}
|
|
107
|
-
|
|
108
|
-
// Local in-memory fallback — useful for local development without Intelligence
|
|
109
|
-
if (runtime.runner instanceof InMemoryAgentRunner) {
|
|
110
|
-
const url = new URL(request.url);
|
|
111
|
-
const agentId = url.searchParams.get("agentId");
|
|
112
|
-
let threads = runtime.runner.listThreads();
|
|
113
|
-
if (agentId) {
|
|
114
|
-
threads = threads.filter((t) => t.agentId === agentId);
|
|
115
|
-
}
|
|
116
|
-
return Response.json({ threads, nextCursor: null });
|
|
117
|
-
}
|
|
118
|
-
|
|
119
|
-
return errorResponse(
|
|
120
|
-
"Missing CopilotKitIntelligence configuration. Thread operations require a CopilotKitIntelligence instance to be provided in CopilotRuntime options.",
|
|
121
|
-
422,
|
|
122
|
-
);
|
|
123
|
-
}
|
|
124
|
-
|
|
125
|
-
/**
|
|
126
|
-
* Clears all in-memory thread history for the local-dev InMemory fallback.
|
|
127
|
-
*
|
|
128
|
-
* The local-dev fallback exposes this so consumers (e.g. the demo's Clear
|
|
129
|
-
* button) can wipe in-memory thread history without restarting the runtime.
|
|
130
|
-
* Intentionally a no-op when the Intelligence platform is configured: real
|
|
131
|
-
* thread history lives in the database and must not be wiped by a
|
|
132
|
-
* client-side page load.
|
|
133
|
-
*/
|
|
134
|
-
export function handleClearThreads({
|
|
135
|
-
runtime,
|
|
136
|
-
}: ThreadsHandlerParams): Response {
|
|
137
|
-
if (runtime.runner instanceof InMemoryAgentRunner) {
|
|
138
|
-
runtime.runner.clearThreads();
|
|
139
|
-
}
|
|
140
|
-
return new Response(null, { status: 204 });
|
|
141
|
-
}
|
|
142
|
-
|
|
143
|
-
export async function handleUpdateThread({
|
|
144
|
-
runtime,
|
|
145
|
-
request,
|
|
146
|
-
threadId,
|
|
147
|
-
}: ThreadMutationParams): Promise<Response> {
|
|
148
|
-
const intelligenceRuntime = requireIntelligenceRuntime(runtime);
|
|
149
|
-
if (isHandlerResponse(intelligenceRuntime)) {
|
|
150
|
-
return intelligenceRuntime;
|
|
151
|
-
}
|
|
152
|
-
|
|
153
|
-
try {
|
|
154
|
-
const mutation = await resolveThreadMutationContext(
|
|
155
|
-
intelligenceRuntime,
|
|
156
|
-
request,
|
|
157
|
-
);
|
|
158
|
-
if (isHandlerResponse(mutation)) return mutation;
|
|
159
|
-
|
|
160
|
-
const updates = { ...mutation.body };
|
|
161
|
-
delete updates.agentId;
|
|
162
|
-
delete updates.userId;
|
|
163
|
-
|
|
164
|
-
const thread = await intelligenceRuntime.intelligence.updateThread({
|
|
165
|
-
threadId,
|
|
166
|
-
userId: mutation.userId,
|
|
167
|
-
agentId: mutation.agentId,
|
|
168
|
-
updates,
|
|
169
|
-
});
|
|
170
|
-
|
|
171
|
-
return Response.json(thread);
|
|
172
|
-
} catch (error) {
|
|
173
|
-
logger.error({ err: error, threadId }, "Error updating thread");
|
|
174
|
-
return errorResponse("Failed to update thread", 500);
|
|
175
|
-
}
|
|
176
|
-
}
|
|
177
|
-
|
|
178
|
-
export async function handleSubscribeToThreads({
|
|
179
|
-
runtime,
|
|
180
|
-
request,
|
|
181
|
-
}: ThreadsHandlerParams): Promise<Response> {
|
|
182
|
-
const intelligenceRuntime = requireIntelligenceRuntime(runtime);
|
|
183
|
-
if (isHandlerResponse(intelligenceRuntime)) {
|
|
184
|
-
return intelligenceRuntime;
|
|
185
|
-
}
|
|
186
|
-
|
|
187
|
-
try {
|
|
188
|
-
const user = await resolveIntelligenceUser({
|
|
189
|
-
runtime: intelligenceRuntime,
|
|
190
|
-
request,
|
|
191
|
-
});
|
|
192
|
-
if (isHandlerResponse(user)) return user;
|
|
193
|
-
|
|
194
|
-
const credentials =
|
|
195
|
-
await intelligenceRuntime.intelligence.ɵsubscribeToThreads({
|
|
196
|
-
userId: user.id,
|
|
197
|
-
});
|
|
198
|
-
|
|
199
|
-
return Response.json({ joinToken: credentials.joinToken });
|
|
200
|
-
} catch (error) {
|
|
201
|
-
logger.error({ err: error }, "Error subscribing to threads");
|
|
202
|
-
return errorResponse("Failed to subscribe to threads", 500);
|
|
203
|
-
}
|
|
204
|
-
}
|
|
205
|
-
|
|
206
|
-
export async function handleArchiveThread({
|
|
207
|
-
runtime,
|
|
208
|
-
request,
|
|
209
|
-
threadId,
|
|
210
|
-
}: ThreadMutationParams): Promise<Response> {
|
|
211
|
-
const intelligenceRuntime = requireIntelligenceRuntime(runtime);
|
|
212
|
-
if (isHandlerResponse(intelligenceRuntime)) {
|
|
213
|
-
return intelligenceRuntime;
|
|
214
|
-
}
|
|
215
|
-
|
|
216
|
-
try {
|
|
217
|
-
const mutation = await resolveThreadMutationContext(
|
|
218
|
-
intelligenceRuntime,
|
|
219
|
-
request,
|
|
220
|
-
);
|
|
221
|
-
if (isHandlerResponse(mutation)) return mutation;
|
|
222
|
-
|
|
223
|
-
await intelligenceRuntime.intelligence.archiveThread({
|
|
224
|
-
threadId,
|
|
225
|
-
userId: mutation.userId,
|
|
226
|
-
agentId: mutation.agentId,
|
|
227
|
-
});
|
|
228
|
-
|
|
229
|
-
return Response.json({ threadId, archived: true });
|
|
230
|
-
} catch (error) {
|
|
231
|
-
logger.error({ err: error, threadId }, "Error archiving thread");
|
|
232
|
-
return errorResponse("Failed to archive thread", 500);
|
|
233
|
-
}
|
|
234
|
-
}
|
|
235
|
-
|
|
236
|
-
export async function handleDeleteThread({
|
|
237
|
-
runtime,
|
|
238
|
-
request,
|
|
239
|
-
threadId,
|
|
240
|
-
}: ThreadMutationParams): Promise<Response> {
|
|
241
|
-
const intelligenceRuntime = requireIntelligenceRuntime(runtime);
|
|
242
|
-
if (isHandlerResponse(intelligenceRuntime)) {
|
|
243
|
-
return intelligenceRuntime;
|
|
244
|
-
}
|
|
245
|
-
|
|
246
|
-
try {
|
|
247
|
-
const mutation = await resolveThreadMutationContext(
|
|
248
|
-
intelligenceRuntime,
|
|
249
|
-
request,
|
|
250
|
-
);
|
|
251
|
-
if (isHandlerResponse(mutation)) return mutation;
|
|
252
|
-
|
|
253
|
-
await intelligenceRuntime.intelligence.deleteThread({
|
|
254
|
-
threadId,
|
|
255
|
-
userId: mutation.userId,
|
|
256
|
-
agentId: mutation.agentId,
|
|
257
|
-
});
|
|
258
|
-
|
|
259
|
-
return Response.json({ threadId, deleted: true });
|
|
260
|
-
} catch (error) {
|
|
261
|
-
logger.error({ err: error, threadId }, "Error deleting thread");
|
|
262
|
-
return errorResponse("Failed to delete thread", 500);
|
|
263
|
-
}
|
|
264
|
-
}
|
|
265
|
-
|
|
266
|
-
export async function handleGetThreadMessages({
|
|
267
|
-
runtime,
|
|
268
|
-
request,
|
|
269
|
-
threadId,
|
|
270
|
-
}: ThreadMutationParams): Promise<Response> {
|
|
271
|
-
// Intelligence platform path
|
|
272
|
-
if (isIntelligenceRuntime(runtime)) {
|
|
273
|
-
try {
|
|
274
|
-
const user = await resolveIntelligenceUser({ runtime, request });
|
|
275
|
-
if (isHandlerResponse(user)) return user;
|
|
276
|
-
|
|
277
|
-
const data = await runtime.intelligence.getThreadMessages({ threadId });
|
|
278
|
-
return Response.json(data);
|
|
279
|
-
} catch (error) {
|
|
280
|
-
logger.error({ err: error, threadId }, "Error fetching thread messages");
|
|
281
|
-
return errorResponse("Failed to fetch thread messages", 500);
|
|
282
|
-
}
|
|
283
|
-
}
|
|
284
|
-
|
|
285
|
-
// Local in-memory fallback — useful for local development without Intelligence
|
|
286
|
-
if (runtime.runner instanceof InMemoryAgentRunner) {
|
|
287
|
-
const messages = runtime.runner.getThreadMessages(threadId);
|
|
288
|
-
// Map ag-ui Message objects to the same shape the Intelligence platform
|
|
289
|
-
// returns. Switching on the discriminant `role` lets each branch read
|
|
290
|
-
// the narrowed message arm directly, instead of laundering through
|
|
291
|
-
// `Record<string, unknown>` and chained `as` casts.
|
|
292
|
-
const mapped = messages.map((msg) => {
|
|
293
|
-
switch (msg.role) {
|
|
294
|
-
case "assistant": {
|
|
295
|
-
const toolCalls = msg.toolCalls ?? [];
|
|
296
|
-
return {
|
|
297
|
-
id: msg.id,
|
|
298
|
-
role: msg.role,
|
|
299
|
-
...(msg.content !== undefined ? { content: msg.content } : {}),
|
|
300
|
-
...(toolCalls.length > 0
|
|
301
|
-
? {
|
|
302
|
-
toolCalls: toolCalls.map((tc) => ({
|
|
303
|
-
id: tc.id,
|
|
304
|
-
name: tc.function.name,
|
|
305
|
-
args: tc.function.arguments,
|
|
306
|
-
})),
|
|
307
|
-
}
|
|
308
|
-
: {}),
|
|
309
|
-
};
|
|
310
|
-
}
|
|
311
|
-
case "tool":
|
|
312
|
-
return {
|
|
313
|
-
id: msg.id,
|
|
314
|
-
role: msg.role,
|
|
315
|
-
content: msg.content,
|
|
316
|
-
toolCallId: msg.toolCallId,
|
|
317
|
-
};
|
|
318
|
-
default:
|
|
319
|
-
return {
|
|
320
|
-
id: msg.id,
|
|
321
|
-
role: msg.role,
|
|
322
|
-
...("content" in msg && msg.content !== undefined
|
|
323
|
-
? { content: msg.content }
|
|
324
|
-
: {}),
|
|
325
|
-
};
|
|
326
|
-
}
|
|
327
|
-
});
|
|
328
|
-
return Response.json({ messages: mapped });
|
|
329
|
-
}
|
|
330
|
-
|
|
331
|
-
return errorResponse(
|
|
332
|
-
"Missing CopilotKitIntelligence configuration. Thread operations require a CopilotKitIntelligence instance to be provided in CopilotRuntime options.",
|
|
333
|
-
422,
|
|
334
|
-
);
|
|
335
|
-
}
|
|
336
|
-
|
|
337
|
-
export async function handleGetThreadEvents({
|
|
338
|
-
runtime,
|
|
339
|
-
request,
|
|
340
|
-
threadId,
|
|
341
|
-
}: ThreadMutationParams): Promise<Response> {
|
|
342
|
-
// Intelligence platform path. Delegates to the platform's `_inspect`
|
|
343
|
-
// endpoint (Intelligence PR #144). Auth still flows through the standard
|
|
344
|
-
// identifyUser → API key path; threadId scoping happens server-side.
|
|
345
|
-
if (isIntelligenceRuntime(runtime)) {
|
|
346
|
-
try {
|
|
347
|
-
const user = await resolveIntelligenceUser({ runtime, request });
|
|
348
|
-
if (isHandlerResponse(user)) return user;
|
|
349
|
-
|
|
350
|
-
const data = await runtime.intelligence.getThreadEvents({ threadId });
|
|
351
|
-
// Strip platform-internal fields (`decodeErrorRowIds`, `truncated`)
|
|
352
|
-
// before returning to the inspector — those describe persistence-side
|
|
353
|
-
// concerns the inspector currently has no UI for. The shape becomes
|
|
354
|
-
// `{ events }`, matching the in-memory branch below.
|
|
355
|
-
return Response.json({ events: data.events });
|
|
356
|
-
} catch (error) {
|
|
357
|
-
logger.error({ err: error, threadId }, "Error fetching thread events");
|
|
358
|
-
return errorResponse("Failed to fetch thread events", 500);
|
|
359
|
-
}
|
|
360
|
-
}
|
|
361
|
-
|
|
362
|
-
// Local in-memory fallback
|
|
363
|
-
if (runtime.runner instanceof InMemoryAgentRunner) {
|
|
364
|
-
try {
|
|
365
|
-
const events = runtime.runner.getThreadEvents(threadId);
|
|
366
|
-
return Response.json({ events });
|
|
367
|
-
} catch (error) {
|
|
368
|
-
logger.error({ err: error, threadId }, "Error fetching thread events");
|
|
369
|
-
return errorResponse("Failed to fetch thread events", 500);
|
|
370
|
-
}
|
|
371
|
-
}
|
|
372
|
-
|
|
373
|
-
return errorResponse(
|
|
374
|
-
"Missing CopilotKitIntelligence configuration. Thread operations require a CopilotKitIntelligence instance to be provided in CopilotRuntime options.",
|
|
375
|
-
422,
|
|
376
|
-
);
|
|
377
|
-
}
|
|
378
|
-
|
|
379
|
-
export async function handleGetThreadState({
|
|
380
|
-
runtime,
|
|
381
|
-
request,
|
|
382
|
-
threadId,
|
|
383
|
-
}: ThreadMutationParams): Promise<Response> {
|
|
384
|
-
// Intelligence platform path. Delegates to the platform's `_inspect`
|
|
385
|
-
// state endpoint, which folds STATE_DELTA events onto the latest
|
|
386
|
-
// STATE_SNAPSHOT to return the thread's current state.
|
|
387
|
-
if (isIntelligenceRuntime(runtime)) {
|
|
388
|
-
try {
|
|
389
|
-
const user = await resolveIntelligenceUser({ runtime, request });
|
|
390
|
-
if (isHandlerResponse(user)) return user;
|
|
391
|
-
|
|
392
|
-
const data = await runtime.intelligence.getThreadState({ threadId });
|
|
393
|
-
// Flatten the discriminated `ThreadStateResult` to the wire shape the
|
|
394
|
-
// inspector consumes (`{ state: <value> | null }`). Missing snapshot
|
|
395
|
-
// and decode-error both surface as `null`; the inspector renders an
|
|
396
|
-
// empty state branch for null and the platform's decode-error case is
|
|
397
|
-
// already logged platform-side.
|
|
398
|
-
const state = data.kind === "snapshot" ? data.state : null;
|
|
399
|
-
return Response.json({ state });
|
|
400
|
-
} catch (error) {
|
|
401
|
-
logger.error({ err: error, threadId }, "Error fetching thread state");
|
|
402
|
-
return errorResponse("Failed to fetch thread state", 500);
|
|
403
|
-
}
|
|
404
|
-
}
|
|
405
|
-
|
|
406
|
-
if (runtime.runner instanceof InMemoryAgentRunner) {
|
|
407
|
-
try {
|
|
408
|
-
const state = runtime.runner.getThreadState(threadId);
|
|
409
|
-
return Response.json({ state });
|
|
410
|
-
} catch (error) {
|
|
411
|
-
logger.error({ err: error, threadId }, "Error fetching thread state");
|
|
412
|
-
return errorResponse("Failed to fetch thread state", 500);
|
|
413
|
-
}
|
|
414
|
-
}
|
|
415
|
-
|
|
416
|
-
return errorResponse(
|
|
417
|
-
"Missing CopilotKitIntelligence configuration. Thread operations require a CopilotKitIntelligence instance to be provided in CopilotRuntime options.",
|
|
418
|
-
422,
|
|
419
|
-
);
|
|
420
|
-
}
|
|
@@ -1,154 +0,0 @@
|
|
|
1
|
-
import type { AbstractAgent, RunAgentInput } from "@ag-ui/client";
|
|
2
|
-
import { RunAgentInputSchema } from "@ag-ui/client";
|
|
3
|
-
import { A2UIMiddleware } from "@ag-ui/a2ui-middleware";
|
|
4
|
-
import { MCPAppsMiddleware } from "@ag-ui/mcp-apps-middleware";
|
|
5
|
-
import type { CopilotRuntimeLike } from "../../core/runtime";
|
|
6
|
-
import { resolveAgents } from "../../core/runtime";
|
|
7
|
-
import { OpenGenerativeUIMiddleware } from "../../open-generative-ui-middleware";
|
|
8
|
-
import { extractForwardableHeaders } from "../header-utils";
|
|
9
|
-
import { logger } from "@copilotkit/shared";
|
|
10
|
-
|
|
11
|
-
type MiddlewareCapableAgent = AbstractAgent & {
|
|
12
|
-
use?: (middleware: unknown) => void;
|
|
13
|
-
headers?: Record<string, string>;
|
|
14
|
-
};
|
|
15
|
-
|
|
16
|
-
export interface RunAgentParameters {
|
|
17
|
-
request: Request;
|
|
18
|
-
runtime: CopilotRuntimeLike;
|
|
19
|
-
agentId: string;
|
|
20
|
-
}
|
|
21
|
-
|
|
22
|
-
export interface ConnectRequestBody extends RunAgentInput {
|
|
23
|
-
lastSeenEventId?: string | null;
|
|
24
|
-
}
|
|
25
|
-
|
|
26
|
-
export async function cloneAgentForRequest(
|
|
27
|
-
runtime: CopilotRuntimeLike,
|
|
28
|
-
agentId: string,
|
|
29
|
-
request?: Request,
|
|
30
|
-
): Promise<AbstractAgent | Response> {
|
|
31
|
-
const agents = await resolveAgents(runtime.agents, request);
|
|
32
|
-
|
|
33
|
-
if (!agents[agentId]) {
|
|
34
|
-
return new Response(
|
|
35
|
-
JSON.stringify({
|
|
36
|
-
error: "Agent not found",
|
|
37
|
-
message: `Agent '${agentId}' does not exist`,
|
|
38
|
-
}),
|
|
39
|
-
{
|
|
40
|
-
status: 404,
|
|
41
|
-
headers: { "Content-Type": "application/json" },
|
|
42
|
-
},
|
|
43
|
-
);
|
|
44
|
-
}
|
|
45
|
-
|
|
46
|
-
return (agents[agentId] as AbstractAgent).clone() as AbstractAgent;
|
|
47
|
-
}
|
|
48
|
-
|
|
49
|
-
export function configureAgentForRequest(params: {
|
|
50
|
-
runtime: CopilotRuntimeLike;
|
|
51
|
-
request: Request;
|
|
52
|
-
agentId: string;
|
|
53
|
-
agent: AbstractAgent;
|
|
54
|
-
}): void {
|
|
55
|
-
const { runtime, request, agentId } = params;
|
|
56
|
-
const agent = params.agent as MiddlewareCapableAgent;
|
|
57
|
-
|
|
58
|
-
if (runtime.a2ui) {
|
|
59
|
-
const { agents: targetAgents, ...a2uiOptions } = runtime.a2ui;
|
|
60
|
-
const shouldApply = !targetAgents || targetAgents.includes(agentId);
|
|
61
|
-
if (shouldApply && typeof agent.use === "function") {
|
|
62
|
-
agent.use(new A2UIMiddleware(a2uiOptions));
|
|
63
|
-
}
|
|
64
|
-
}
|
|
65
|
-
|
|
66
|
-
if (runtime.mcpApps?.servers?.length) {
|
|
67
|
-
const mcpServers = runtime.mcpApps.servers
|
|
68
|
-
.filter((server) => !server.agentId || server.agentId === agentId)
|
|
69
|
-
.map((server) => {
|
|
70
|
-
const mcpServer = { ...server };
|
|
71
|
-
delete mcpServer.agentId;
|
|
72
|
-
return mcpServer;
|
|
73
|
-
});
|
|
74
|
-
|
|
75
|
-
if (mcpServers.length > 0 && typeof agent.use === "function") {
|
|
76
|
-
agent.use(new MCPAppsMiddleware({ mcpServers }));
|
|
77
|
-
}
|
|
78
|
-
}
|
|
79
|
-
|
|
80
|
-
if (runtime.openGenerativeUI) {
|
|
81
|
-
const config = runtime.openGenerativeUI;
|
|
82
|
-
const targetAgents = typeof config === "object" ? config.agents : undefined;
|
|
83
|
-
const shouldApply = !targetAgents || targetAgents.includes(agentId);
|
|
84
|
-
if (shouldApply && typeof agent.use === "function") {
|
|
85
|
-
agent.use(new OpenGenerativeUIMiddleware());
|
|
86
|
-
}
|
|
87
|
-
}
|
|
88
|
-
|
|
89
|
-
if (agent.headers) {
|
|
90
|
-
agent.headers = {
|
|
91
|
-
...agent.headers,
|
|
92
|
-
...extractForwardableHeaders(request),
|
|
93
|
-
};
|
|
94
|
-
}
|
|
95
|
-
}
|
|
96
|
-
|
|
97
|
-
export async function parseRunRequest(
|
|
98
|
-
request: Request,
|
|
99
|
-
): Promise<RunAgentInput | Response> {
|
|
100
|
-
try {
|
|
101
|
-
const requestBody = await request.json();
|
|
102
|
-
return RunAgentInputSchema.parse(requestBody);
|
|
103
|
-
} catch (error) {
|
|
104
|
-
logger.error("Invalid run request body:", error);
|
|
105
|
-
return new Response(
|
|
106
|
-
JSON.stringify({
|
|
107
|
-
error: "Invalid request body",
|
|
108
|
-
details: error instanceof Error ? error.message : String(error),
|
|
109
|
-
}),
|
|
110
|
-
{
|
|
111
|
-
status: 400,
|
|
112
|
-
headers: { "Content-Type": "application/json" },
|
|
113
|
-
},
|
|
114
|
-
);
|
|
115
|
-
}
|
|
116
|
-
}
|
|
117
|
-
|
|
118
|
-
export async function parseConnectRequest(request: Request): Promise<
|
|
119
|
-
| Response
|
|
120
|
-
| {
|
|
121
|
-
input: RunAgentInput;
|
|
122
|
-
lastSeenEventId: string | null;
|
|
123
|
-
}
|
|
124
|
-
> {
|
|
125
|
-
try {
|
|
126
|
-
const requestBody = await request.json();
|
|
127
|
-
const input = RunAgentInputSchema.parse(requestBody);
|
|
128
|
-
let lastSeenEventId: string | null = null;
|
|
129
|
-
|
|
130
|
-
if (
|
|
131
|
-
"lastSeenEventId" in (requestBody as Record<string, unknown>) &&
|
|
132
|
-
(typeof (requestBody as Record<string, unknown>).lastSeenEventId ===
|
|
133
|
-
"string" ||
|
|
134
|
-
(requestBody as Record<string, unknown>).lastSeenEventId === null)
|
|
135
|
-
) {
|
|
136
|
-
lastSeenEventId =
|
|
137
|
-
(requestBody as ConnectRequestBody).lastSeenEventId ?? null;
|
|
138
|
-
}
|
|
139
|
-
|
|
140
|
-
return { input, lastSeenEventId };
|
|
141
|
-
} catch (error) {
|
|
142
|
-
logger.error("Invalid connect request body:", error);
|
|
143
|
-
return new Response(
|
|
144
|
-
JSON.stringify({
|
|
145
|
-
error: "Invalid request body",
|
|
146
|
-
details: error instanceof Error ? error.message : String(error),
|
|
147
|
-
}),
|
|
148
|
-
{
|
|
149
|
-
status: 400,
|
|
150
|
-
headers: { "Content-Type": "application/json" },
|
|
151
|
-
},
|
|
152
|
-
);
|
|
153
|
-
}
|
|
154
|
-
}
|
|
@@ -1,41 +0,0 @@
|
|
|
1
|
-
import { PlatformRequestError } from "../../intelligence-platform/client";
|
|
2
|
-
|
|
3
|
-
/**
|
|
4
|
-
* Returns the HTTP status carried by platform request errors.
|
|
5
|
-
*/
|
|
6
|
-
export function getPlatformErrorStatus(error: unknown): number | undefined {
|
|
7
|
-
if (error instanceof PlatformRequestError) {
|
|
8
|
-
return error.status;
|
|
9
|
-
}
|
|
10
|
-
|
|
11
|
-
if (
|
|
12
|
-
error !== null &&
|
|
13
|
-
typeof error === "object" &&
|
|
14
|
-
"status" in error &&
|
|
15
|
-
typeof error.status === "number"
|
|
16
|
-
) {
|
|
17
|
-
return error.status;
|
|
18
|
-
}
|
|
19
|
-
|
|
20
|
-
return undefined;
|
|
21
|
-
}
|
|
22
|
-
|
|
23
|
-
export function isPlatformNotFoundError(error: unknown): boolean {
|
|
24
|
-
return getPlatformErrorStatus(error) === 404;
|
|
25
|
-
}
|
|
26
|
-
|
|
27
|
-
const MAX_ID_LENGTH = 128;
|
|
28
|
-
const SAFE_ID_PATTERN = /^[\w.@:=-]+$/;
|
|
29
|
-
|
|
30
|
-
/**
|
|
31
|
-
* Validates that a string identifier (userId, agentId) is safe to pass through.
|
|
32
|
-
* Returns `true` if valid, `false` otherwise.
|
|
33
|
-
*/
|
|
34
|
-
export function isValidIdentifier(value: unknown): value is string {
|
|
35
|
-
return (
|
|
36
|
-
typeof value === "string" &&
|
|
37
|
-
value.length > 0 &&
|
|
38
|
-
value.length <= MAX_ID_LENGTH &&
|
|
39
|
-
SAFE_ID_PATTERN.test(value)
|
|
40
|
-
);
|
|
41
|
-
}
|
|
@@ -1,9 +0,0 @@
|
|
|
1
|
-
export const errorResponse = (message: string, status: number) =>
|
|
2
|
-
new Response(JSON.stringify({ error: message }), {
|
|
3
|
-
status,
|
|
4
|
-
headers: { "Content-Type": "application/json" },
|
|
5
|
-
});
|
|
6
|
-
|
|
7
|
-
export function isHandlerResponse(value: unknown): value is Response {
|
|
8
|
-
return value instanceof Response;
|
|
9
|
-
}
|
|
@@ -1,28 +0,0 @@
|
|
|
1
|
-
import {
|
|
2
|
-
CopilotIntelligenceRuntimeLike,
|
|
3
|
-
CopilotRuntimeUser,
|
|
4
|
-
} from "../../core/runtime";
|
|
5
|
-
import { errorResponse } from "./json-response";
|
|
6
|
-
import { isValidIdentifier } from "./intelligence-utils";
|
|
7
|
-
|
|
8
|
-
export async function resolveIntelligenceUser(params: {
|
|
9
|
-
runtime: CopilotIntelligenceRuntimeLike;
|
|
10
|
-
request: Request;
|
|
11
|
-
}): Promise<CopilotRuntimeUser | Response> {
|
|
12
|
-
const { runtime, request } = params;
|
|
13
|
-
|
|
14
|
-
try {
|
|
15
|
-
const user = await runtime.identifyUser(request);
|
|
16
|
-
if (!isValidIdentifier(user?.id)) {
|
|
17
|
-
return errorResponse("identifyUser must return a valid user id", 400);
|
|
18
|
-
}
|
|
19
|
-
if (typeof user?.name !== "string" || user.name.trim().length === 0) {
|
|
20
|
-
return errorResponse("identifyUser must return a valid user name", 400);
|
|
21
|
-
}
|
|
22
|
-
|
|
23
|
-
return { id: user.id, name: user.name };
|
|
24
|
-
} catch (error) {
|
|
25
|
-
console.error("Error identifying intelligence user:", error);
|
|
26
|
-
return errorResponse("Failed to identify user", 500);
|
|
27
|
-
}
|
|
28
|
-
}
|