@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.
Files changed (346) hide show
  1. package/dist/lib/observability.d.cts +1 -1
  2. package/dist/lib/observability.d.cts.map +1 -1
  3. package/dist/lib/observability.d.mts +1 -1
  4. package/dist/lib/observability.d.mts.map +1 -1
  5. package/dist/lib/runtime/copilot-runtime.cjs +2 -0
  6. package/dist/lib/runtime/copilot-runtime.cjs.map +1 -1
  7. package/dist/lib/runtime/copilot-runtime.d.cts.map +1 -1
  8. package/dist/lib/runtime/copilot-runtime.d.mts.map +1 -1
  9. package/dist/lib/runtime/copilot-runtime.mjs +2 -0
  10. package/dist/lib/runtime/copilot-runtime.mjs.map +1 -1
  11. package/dist/package.cjs +5 -8
  12. package/dist/package.mjs +5 -8
  13. package/dist/v2/runtime/core/runtime.cjs +4 -1
  14. package/dist/v2/runtime/core/runtime.cjs.map +1 -1
  15. package/dist/v2/runtime/core/runtime.d.cts.map +1 -1
  16. package/dist/v2/runtime/core/runtime.d.mts.map +1 -1
  17. package/dist/v2/runtime/core/runtime.mjs +4 -1
  18. package/dist/v2/runtime/core/runtime.mjs.map +1 -1
  19. package/dist/v2/runtime/handlers/get-runtime-info.cjs +1 -1
  20. package/dist/v2/runtime/handlers/get-runtime-info.mjs +1 -1
  21. package/dist/v2/runtime/handlers/handle-connect.cjs +1 -1
  22. package/dist/v2/runtime/handlers/handle-connect.mjs +1 -1
  23. package/dist/v2/runtime/handlers/handle-run.cjs +1 -1
  24. package/dist/v2/runtime/handlers/handle-run.mjs +1 -1
  25. package/dist/v2/runtime/handlers/shared/agent-utils.cjs +1 -1
  26. package/dist/v2/runtime/handlers/shared/agent-utils.cjs.map +1 -1
  27. package/dist/v2/runtime/handlers/shared/agent-utils.mjs +1 -1
  28. package/dist/v2/runtime/handlers/shared/agent-utils.mjs.map +1 -1
  29. package/dist/v2/runtime/telemetry/telemetry-client.cjs +22 -6
  30. package/dist/v2/runtime/telemetry/telemetry-client.cjs.map +1 -1
  31. package/dist/v2/runtime/telemetry/telemetry-client.mjs +27 -11
  32. package/dist/v2/runtime/telemetry/telemetry-client.mjs.map +1 -1
  33. package/package.json +9 -19
  34. package/skills/runtime/SKILL.md +98 -0
  35. package/skills/runtime/references/agent-runners-custom.md +161 -0
  36. package/skills/runtime/references/agent-runners-in-memory.md +64 -0
  37. package/skills/runtime/references/agent-runners-sqlite.md +90 -0
  38. package/skills/runtime/references/agent-runners.md +304 -0
  39. package/skills/runtime/references/built-in-agent-factory-modes.md +232 -0
  40. package/skills/runtime/references/built-in-agent-helper-utilities.md +123 -0
  41. package/skills/runtime/references/built-in-agent-model-identifiers.md +59 -0
  42. package/skills/runtime/references/built-in-agent.md +523 -0
  43. package/skills/runtime/references/intelligence-mode.md +336 -0
  44. package/skills/runtime/references/middleware.md +376 -0
  45. package/skills/runtime/references/server-side-tools.md +414 -0
  46. package/skills/runtime/references/setup-endpoint.md +503 -0
  47. package/skills/runtime/references/transcription.md +287 -0
  48. package/skills/runtime/references/wiring-a2a.md +40 -0
  49. package/skills/runtime/references/wiring-adk.md +45 -0
  50. package/skills/runtime/references/wiring-ag2.md +41 -0
  51. package/skills/runtime/references/wiring-agno.md +39 -0
  52. package/skills/runtime/references/wiring-aws-strands.md +59 -0
  53. package/skills/runtime/references/wiring-crewai-crews.md +51 -0
  54. package/skills/runtime/references/wiring-crewai-flows.md +45 -0
  55. package/skills/runtime/references/wiring-external-agents.md +348 -0
  56. package/skills/runtime/references/wiring-langgraph.md +50 -0
  57. package/skills/runtime/references/wiring-llamaindex.md +39 -0
  58. package/skills/runtime/references/wiring-mastra.md +70 -0
  59. package/skills/runtime/references/wiring-mcp-apps-middleware.md +68 -0
  60. package/skills/runtime/references/wiring-ms-agent-framework.md +41 -0
  61. package/skills/runtime/references/wiring-pydantic-ai.md +45 -0
  62. package/CHANGELOG.md +0 -3624
  63. package/__snapshots__/schema/schema.graphql +0 -371
  64. package/dist/v2/runtime/telemetry/scarf-client.cjs +0 -32
  65. package/dist/v2/runtime/telemetry/scarf-client.cjs.map +0 -1
  66. package/dist/v2/runtime/telemetry/scarf-client.mjs +0 -32
  67. package/dist/v2/runtime/telemetry/scarf-client.mjs.map +0 -1
  68. package/scripts/generate-gql-schema.ts +0 -16
  69. package/src/agent/__tests__/agent-test-helpers.ts +0 -476
  70. package/src/agent/__tests__/agent.test.ts +0 -593
  71. package/src/agent/__tests__/ai-sdk-v6-compat.test.ts +0 -116
  72. package/src/agent/__tests__/basic-agent.test.ts +0 -1698
  73. package/src/agent/__tests__/capabilities.test.ts +0 -81
  74. package/src/agent/__tests__/config-tools-execution.test.ts +0 -516
  75. package/src/agent/__tests__/converter-aisdk.test.ts +0 -692
  76. package/src/agent/__tests__/converter-custom.test.ts +0 -319
  77. package/src/agent/__tests__/converter-tanstack-input.test.ts +0 -211
  78. package/src/agent/__tests__/converter-tanstack.test.ts +0 -594
  79. package/src/agent/__tests__/mcp-clients.test.ts +0 -246
  80. package/src/agent/__tests__/mcp-servers-integration.test.ts +0 -373
  81. package/src/agent/__tests__/multimodal-tanstack.test.ts +0 -284
  82. package/src/agent/__tests__/multimodal.test.ts +0 -176
  83. package/src/agent/__tests__/property-overrides.test.ts +0 -598
  84. package/src/agent/__tests__/provider-id-collision.test.ts +0 -195
  85. package/src/agent/__tests__/standard-schema-tools.test.ts +0 -313
  86. package/src/agent/__tests__/standard-schema-types.test.ts +0 -158
  87. package/src/agent/__tests__/state-tools.test.ts +0 -436
  88. package/src/agent/__tests__/test-helpers.ts +0 -197
  89. package/src/agent/__tests__/utils.test.ts +0 -536
  90. package/src/agent/__tests__/zod-regression.test.ts +0 -350
  91. package/src/agent/converters/aisdk.ts +0 -326
  92. package/src/agent/converters/index.ts +0 -7
  93. package/src/agent/converters/tanstack.ts +0 -451
  94. package/src/agent/index.ts +0 -1743
  95. package/src/agents/langgraph/__tests__/event-source.test.ts +0 -256
  96. package/src/agents/langgraph/event-source.ts +0 -365
  97. package/src/agents/langgraph/events.ts +0 -394
  98. package/src/graphql/inputs/action.input.ts +0 -16
  99. package/src/graphql/inputs/agent-session.input.ts +0 -13
  100. package/src/graphql/inputs/agent-state.input.ts +0 -13
  101. package/src/graphql/inputs/cloud-guardrails.input.ts +0 -16
  102. package/src/graphql/inputs/cloud.input.ts +0 -8
  103. package/src/graphql/inputs/context-property.input.ts +0 -10
  104. package/src/graphql/inputs/copilot-context.input.ts +0 -10
  105. package/src/graphql/inputs/custom-property.input.ts +0 -15
  106. package/src/graphql/inputs/extensions.input.ts +0 -21
  107. package/src/graphql/inputs/forwarded-parameters.input.ts +0 -22
  108. package/src/graphql/inputs/frontend.input.ts +0 -14
  109. package/src/graphql/inputs/generate-copilot-response.input.ts +0 -59
  110. package/src/graphql/inputs/load-agent-state.input.ts +0 -10
  111. package/src/graphql/inputs/message.input.ts +0 -110
  112. package/src/graphql/inputs/meta-event.input.ts +0 -18
  113. package/src/graphql/message-conversion/agui-to-gql.test.ts +0 -1384
  114. package/src/graphql/message-conversion/agui-to-gql.ts +0 -384
  115. package/src/graphql/message-conversion/gql-to-agui.test.ts +0 -1653
  116. package/src/graphql/message-conversion/gql-to-agui.ts +0 -297
  117. package/src/graphql/message-conversion/index.ts +0 -2
  118. package/src/graphql/message-conversion/roundtrip-conversion.test.ts +0 -561
  119. package/src/graphql/resolvers/__tests__/resolve-message-id.test.ts +0 -25
  120. package/src/graphql/resolvers/copilot.resolver.ts +0 -785
  121. package/src/graphql/resolvers/resolve-message-id.ts +0 -14
  122. package/src/graphql/resolvers/state.resolver.ts +0 -30
  123. package/src/graphql/types/agents-response.type.ts +0 -19
  124. package/src/graphql/types/base/index.ts +0 -10
  125. package/src/graphql/types/converted/index.ts +0 -183
  126. package/src/graphql/types/copilot-response.type.ts +0 -141
  127. package/src/graphql/types/enums.ts +0 -38
  128. package/src/graphql/types/extensions-response.type.ts +0 -23
  129. package/src/graphql/types/guardrails-result.type.ts +0 -20
  130. package/src/graphql/types/load-agent-state-response.type.ts +0 -17
  131. package/src/graphql/types/message-status.type.ts +0 -48
  132. package/src/graphql/types/meta-events.type.ts +0 -78
  133. package/src/graphql/types/response-status.type.ts +0 -77
  134. package/src/index.ts +0 -3
  135. package/src/langgraph.ts +0 -1
  136. package/src/lib/__tests__/telemetry-disclosure.test.ts +0 -55
  137. package/src/lib/cloud/index.ts +0 -4
  138. package/src/lib/error-messages.ts +0 -211
  139. package/src/lib/index.ts +0 -52
  140. package/src/lib/integrations/index.ts +0 -6
  141. package/src/lib/integrations/nest/index.ts +0 -21
  142. package/src/lib/integrations/nextjs/app-router.ts +0 -47
  143. package/src/lib/integrations/nextjs/pages-router.ts +0 -45
  144. package/src/lib/integrations/node-express/index.ts +0 -21
  145. package/src/lib/integrations/node-http/__tests__/request-duck-type.test.ts +0 -66
  146. package/src/lib/integrations/node-http/index.ts +0 -187
  147. package/src/lib/integrations/node-http/request-handler.ts +0 -128
  148. package/src/lib/integrations/shared.ts +0 -112
  149. package/src/lib/logger.ts +0 -31
  150. package/src/lib/observability.ts +0 -167
  151. package/src/lib/runtime/__tests__/copilot-runtime-error.test.ts +0 -183
  152. package/src/lib/runtime/__tests__/handle-service-adapter.test.ts +0 -108
  153. package/src/lib/runtime/__tests__/mcp-tools-utils.test.ts +0 -499
  154. package/src/lib/runtime/__tests__/on-after-request.test.ts +0 -122
  155. package/src/lib/runtime/__tests__/retry-utils.test.ts +0 -137
  156. package/src/lib/runtime/__tests__/v1-agent-factory.test.ts +0 -109
  157. package/src/lib/runtime/agent-integrations/langgraph/__tests__/dispatch-event-filtering.test.ts +0 -345
  158. package/src/lib/runtime/agent-integrations/langgraph/__tests__/run-message-filtering.test.ts +0 -156
  159. package/src/lib/runtime/agent-integrations/langgraph/agent.ts +0 -263
  160. package/src/lib/runtime/agent-integrations/langgraph/consts.ts +0 -37
  161. package/src/lib/runtime/agent-integrations/langgraph/index.ts +0 -2
  162. package/src/lib/runtime/copilot-runtime.ts +0 -863
  163. package/src/lib/runtime/mcp-tools-utils.ts +0 -313
  164. package/src/lib/runtime/retry-utils.ts +0 -141
  165. package/src/lib/runtime/telemetry-agent-runner.ts +0 -151
  166. package/src/lib/runtime/types.ts +0 -48
  167. package/src/lib/runtime/utils.ts +0 -93
  168. package/src/lib/streaming.ts +0 -220
  169. package/src/lib/telemetry-client.ts +0 -66
  170. package/src/lib/telemetry-disclosure.ts +0 -53
  171. package/src/service-adapters/anthropic/anthropic-adapter.ts +0 -532
  172. package/src/service-adapters/anthropic/utils.ts +0 -219
  173. package/src/service-adapters/bedrock/bedrock-adapter.ts +0 -73
  174. package/src/service-adapters/conversion.test.ts +0 -56
  175. package/src/service-adapters/conversion.ts +0 -69
  176. package/src/service-adapters/empty/empty-adapter.ts +0 -38
  177. package/src/service-adapters/events.ts +0 -337
  178. package/src/service-adapters/experimental/ollama/ollama-adapter.ts +0 -84
  179. package/src/service-adapters/google/google-genai-adapter.test.ts +0 -151
  180. package/src/service-adapters/google/google-genai-adapter.ts +0 -95
  181. package/src/service-adapters/groq/groq-adapter.ts +0 -229
  182. package/src/service-adapters/index.ts +0 -18
  183. package/src/service-adapters/langchain/langchain-adapter.ts +0 -113
  184. package/src/service-adapters/langchain/langserve.ts +0 -88
  185. package/src/service-adapters/langchain/types.ts +0 -20
  186. package/src/service-adapters/langchain/utils.ts +0 -330
  187. package/src/service-adapters/openai/__tests__/openai-v5-compat.test.ts +0 -177
  188. package/src/service-adapters/openai/openai-adapter.ts +0 -324
  189. package/src/service-adapters/openai/openai-assistant-adapter.ts +0 -385
  190. package/src/service-adapters/openai/utils.ts +0 -305
  191. package/src/service-adapters/service-adapter.ts +0 -50
  192. package/src/service-adapters/shared/error-utils.ts +0 -64
  193. package/src/service-adapters/shared/index.ts +0 -2
  194. package/src/service-adapters/shared/sdk-client-utils.ts +0 -19
  195. package/src/service-adapters/unify/unify-adapter.ts +0 -165
  196. package/src/utils/failed-response-status-reasons.ts +0 -70
  197. package/src/utils/index.ts +0 -1
  198. package/src/v2/express.ts +0 -1
  199. package/src/v2/hono.ts +0 -1
  200. package/src/v2/index.ts +0 -5
  201. package/src/v2/node.ts +0 -1
  202. package/src/v2/runtime/__tests__/agents-factory.test.ts +0 -136
  203. package/src/v2/runtime/__tests__/backward-compat.test.ts +0 -261
  204. package/src/v2/runtime/__tests__/code-review-fixes.test.ts +0 -500
  205. package/src/v2/runtime/__tests__/cors-credentials.test.ts +0 -320
  206. package/src/v2/runtime/__tests__/debug-sse-response.test.ts +0 -302
  207. package/src/v2/runtime/__tests__/express-adapter.test.ts +0 -188
  208. package/src/v2/runtime/__tests__/express-body-order.test.ts +0 -76
  209. package/src/v2/runtime/__tests__/express-fetch-bridge.test.ts +0 -344
  210. package/src/v2/runtime/__tests__/express-single-sse.test.ts +0 -122
  211. package/src/v2/runtime/__tests__/express-single-telemetry.integration.test.ts +0 -65
  212. package/src/v2/runtime/__tests__/express-telemetry.integration.test.ts +0 -101
  213. package/src/v2/runtime/__tests__/fetch-cors.test.ts +0 -205
  214. package/src/v2/runtime/__tests__/fetch-handler-validation.test.ts +0 -440
  215. package/src/v2/runtime/__tests__/fetch-handler.test.ts +0 -456
  216. package/src/v2/runtime/__tests__/fetch-router.test.ts +0 -276
  217. package/src/v2/runtime/__tests__/get-runtime-info.test.ts +0 -335
  218. package/src/v2/runtime/__tests__/handle-connect.test.ts +0 -585
  219. package/src/v2/runtime/__tests__/handle-run.test.ts +0 -1388
  220. package/src/v2/runtime/__tests__/handle-threads.test.ts +0 -930
  221. package/src/v2/runtime/__tests__/handle-transcribe.test.ts +0 -301
  222. package/src/v2/runtime/__tests__/header-utils.test.ts +0 -88
  223. package/src/v2/runtime/__tests__/hono-adapter.test.ts +0 -150
  224. package/src/v2/runtime/__tests__/hono-single-telemetry.integration.test.ts +0 -46
  225. package/src/v2/runtime/__tests__/hono-telemetry.integration.test.ts +0 -99
  226. package/src/v2/runtime/__tests__/hooks-edge-cases.test.ts +0 -457
  227. package/src/v2/runtime/__tests__/hooks.test.ts +0 -557
  228. package/src/v2/runtime/__tests__/in-process-agent-runner-messages.test.ts +0 -230
  229. package/src/v2/runtime/__tests__/in-process-agent-runner.test.ts +0 -1030
  230. package/src/v2/runtime/__tests__/integration/bun/bun-servers.integration.test.ts +0 -27
  231. package/src/v2/runtime/__tests__/integration/bun/elysia-multi.ts +0 -32
  232. package/src/v2/runtime/__tests__/integration/bun/elysia-single.ts +0 -33
  233. package/src/v2/runtime/__tests__/integration/bun/hono-bun-multi.ts +0 -25
  234. package/src/v2/runtime/__tests__/integration/bun/hono-bun-single.ts +0 -32
  235. package/src/v2/runtime/__tests__/integration/helpers/create-test-runtime.ts +0 -15
  236. package/src/v2/runtime/__tests__/integration/helpers/sse-reader.ts +0 -45
  237. package/src/v2/runtime/__tests__/integration/helpers/test-agent.ts +0 -58
  238. package/src/v2/runtime/__tests__/integration/node-servers.integration.test.ts +0 -58
  239. package/src/v2/runtime/__tests__/integration/servers/express-multi.ts +0 -35
  240. package/src/v2/runtime/__tests__/integration/servers/express-single.ts +0 -36
  241. package/src/v2/runtime/__tests__/integration/servers/fetch-direct.ts +0 -39
  242. package/src/v2/runtime/__tests__/integration/servers/hono-multi.ts +0 -30
  243. package/src/v2/runtime/__tests__/integration/servers/hono-single.ts +0 -37
  244. package/src/v2/runtime/__tests__/integration/servers/node-multi.ts +0 -45
  245. package/src/v2/runtime/__tests__/integration/servers/node-single.ts +0 -46
  246. package/src/v2/runtime/__tests__/integration/servers/types.ts +0 -18
  247. package/src/v2/runtime/__tests__/integration/suites/debug-events.suite.ts +0 -253
  248. package/src/v2/runtime/__tests__/integration/suites/multi-endpoint.suite.ts +0 -358
  249. package/src/v2/runtime/__tests__/integration/suites/single-endpoint.suite.ts +0 -363
  250. package/src/v2/runtime/__tests__/intelligence-run-telemetry.test.ts +0 -194
  251. package/src/v2/runtime/__tests__/mcp-apps-middleware-integration.test.ts +0 -275
  252. package/src/v2/runtime/__tests__/middleware-express.test.ts +0 -208
  253. package/src/v2/runtime/__tests__/middleware-single-express.test.ts +0 -213
  254. package/src/v2/runtime/__tests__/middleware-single.test.ts +0 -225
  255. package/src/v2/runtime/__tests__/middleware-sse-parser.test.ts +0 -237
  256. package/src/v2/runtime/__tests__/middleware.test.ts +0 -250
  257. package/src/v2/runtime/__tests__/node-fetch-handler.test.ts +0 -157
  258. package/src/v2/runtime/__tests__/open-generative-ui-middleware.e2e.test.ts +0 -728
  259. package/src/v2/runtime/__tests__/router-edge-cases.test.ts +0 -217
  260. package/src/v2/runtime/__tests__/routing-express.test.ts +0 -174
  261. package/src/v2/runtime/__tests__/routing-single-express.test.ts +0 -168
  262. package/src/v2/runtime/__tests__/routing-single.test.ts +0 -193
  263. package/src/v2/runtime/__tests__/routing.test.ts +0 -257
  264. package/src/v2/runtime/__tests__/runtime.test.ts +0 -234
  265. package/src/v2/runtime/__tests__/sse-response-telemetry.test.ts +0 -108
  266. package/src/v2/runtime/__tests__/telemetry.test.ts +0 -167
  267. package/src/v2/runtime/__tests__/thread-names.test.ts +0 -188
  268. package/src/v2/runtime/core/__tests__/debug-event-bus.test.ts +0 -156
  269. package/src/v2/runtime/core/debug-event-bus.ts +0 -45
  270. package/src/v2/runtime/core/fetch-cors.ts +0 -136
  271. package/src/v2/runtime/core/fetch-handler.ts +0 -492
  272. package/src/v2/runtime/core/fetch-router.ts +0 -203
  273. package/src/v2/runtime/core/hooks.ts +0 -160
  274. package/src/v2/runtime/core/middleware-sse-parser.ts +0 -210
  275. package/src/v2/runtime/core/middleware.ts +0 -115
  276. package/src/v2/runtime/core/runtime.ts +0 -432
  277. package/src/v2/runtime/endpoints/express-fetch-bridge.ts +0 -137
  278. package/src/v2/runtime/endpoints/express-single.ts +0 -54
  279. package/src/v2/runtime/endpoints/express.ts +0 -179
  280. package/src/v2/runtime/endpoints/hono-single.ts +0 -60
  281. package/src/v2/runtime/endpoints/hono.ts +0 -89
  282. package/src/v2/runtime/endpoints/index.ts +0 -4
  283. package/src/v2/runtime/endpoints/node-fetch-handler.ts +0 -48
  284. package/src/v2/runtime/endpoints/node.ts +0 -28
  285. package/src/v2/runtime/endpoints/single-route-helpers.ts +0 -125
  286. package/src/v2/runtime/express.ts +0 -2
  287. package/src/v2/runtime/handlers/__tests__/handle-debug-events.test.ts +0 -176
  288. package/src/v2/runtime/handlers/get-runtime-info.ts +0 -101
  289. package/src/v2/runtime/handlers/handle-connect.ts +0 -80
  290. package/src/v2/runtime/handlers/handle-debug-events.ts +0 -52
  291. package/src/v2/runtime/handlers/handle-run.ts +0 -111
  292. package/src/v2/runtime/handlers/handle-stop.ts +0 -77
  293. package/src/v2/runtime/handlers/handle-threads.ts +0 -11
  294. package/src/v2/runtime/handlers/handle-transcribe.ts +0 -269
  295. package/src/v2/runtime/handlers/header-utils.ts +0 -24
  296. package/src/v2/runtime/handlers/intelligence/connect.ts +0 -102
  297. package/src/v2/runtime/handlers/intelligence/run.ts +0 -351
  298. package/src/v2/runtime/handlers/intelligence/thread-names.ts +0 -246
  299. package/src/v2/runtime/handlers/intelligence/threads.ts +0 -420
  300. package/src/v2/runtime/handlers/shared/agent-utils.ts +0 -154
  301. package/src/v2/runtime/handlers/shared/intelligence-utils.ts +0 -41
  302. package/src/v2/runtime/handlers/shared/json-response.ts +0 -9
  303. package/src/v2/runtime/handlers/shared/resolve-intelligence-user.ts +0 -28
  304. package/src/v2/runtime/handlers/shared/sse-response.ts +0 -215
  305. package/src/v2/runtime/handlers/sse/__tests__/sse-connect-agent-id.test.ts +0 -71
  306. package/src/v2/runtime/handlers/sse/connect.ts +0 -30
  307. package/src/v2/runtime/handlers/sse/run.ts +0 -40
  308. package/src/v2/runtime/hono.ts +0 -2
  309. package/src/v2/runtime/index.ts +0 -51
  310. package/src/v2/runtime/intelligence-platform/__tests__/client.test.ts +0 -601
  311. package/src/v2/runtime/intelligence-platform/__tests__/intelligence-mcp-helper.test.ts +0 -246
  312. package/src/v2/runtime/intelligence-platform/client.ts +0 -818
  313. package/src/v2/runtime/intelligence-platform/index.ts +0 -10
  314. package/src/v2/runtime/node.ts +0 -6
  315. package/src/v2/runtime/open-generative-ui-middleware.ts +0 -373
  316. package/src/v2/runtime/runner/__tests__/finalize-events.test.ts +0 -109
  317. package/src/v2/runtime/runner/__tests__/in-memory-runner.e2e.test.ts +0 -775
  318. package/src/v2/runtime/runner/__tests__/in-memory-runner.test.ts +0 -777
  319. package/src/v2/runtime/runner/__tests__/intelligence-runner.test.ts +0 -1039
  320. package/src/v2/runtime/runner/agent-runner.ts +0 -35
  321. package/src/v2/runtime/runner/in-memory.ts +0 -467
  322. package/src/v2/runtime/runner/index.ts +0 -4
  323. package/src/v2/runtime/runner/intelligence.ts +0 -498
  324. package/src/v2/runtime/telemetry/__tests__/instance-created.test.ts +0 -96
  325. package/src/v2/runtime/telemetry/events.ts +0 -35
  326. package/src/v2/runtime/telemetry/index.ts +0 -7
  327. package/src/v2/runtime/telemetry/instance-created.ts +0 -44
  328. package/src/v2/runtime/telemetry/scarf-client.ts +0 -39
  329. package/src/v2/runtime/telemetry/telemetry-client.ts +0 -70
  330. package/src/v2/runtime/transcription-service/transcription-service.ts +0 -11
  331. package/tests/global.d.ts +0 -1
  332. package/tests/service-adapters/anthropic/allowlist-approach.test.ts +0 -259
  333. package/tests/service-adapters/anthropic/anthropic-adapter-language-model.test.ts +0 -101
  334. package/tests/service-adapters/anthropic/anthropic-adapter.test.ts +0 -645
  335. package/tests/service-adapters/anthropic/utils-token-trimming.test.ts +0 -301
  336. package/tests/service-adapters/groq/groq-adapter-language-model.test.ts +0 -102
  337. package/tests/service-adapters/openai/allowlist-approach.test.ts +0 -294
  338. package/tests/service-adapters/openai/openai-adapter-language-model.test.ts +0 -122
  339. package/tests/service-adapters/openai/openai-adapter.test.ts +0 -291
  340. package/tests/service-adapters/shared/sdk-client-utils.test.ts +0 -36
  341. package/tests/setup.vitest.ts +0 -8
  342. package/tests/tsconfig.json +0 -10
  343. package/tsconfig.json +0 -20
  344. package/tsdown.config.ts +0 -45
  345. package/typedoc.json +0 -4
  346. package/vitest.config.mjs +0 -13
@@ -1,498 +0,0 @@
1
- import {
2
- AgentRunner,
3
- AgentRunnerConnectRequest,
4
- AgentRunnerIsRunningRequest,
5
- AgentRunnerRunRequest,
6
- type AgentRunnerStopRequest,
7
- } from "./agent-runner";
8
- import { EMPTY, Observable, from } from "rxjs";
9
- import { catchError, finalize } from "rxjs/operators";
10
- import {
11
- AbstractAgent,
12
- BaseEvent,
13
- EventType,
14
- RunStartedEvent,
15
- } from "@ag-ui/client";
16
- import {
17
- finalizeRunEvents,
18
- AG_UI_CHANNEL_EVENT,
19
- phoenixExponentialBackoff,
20
- } from "@copilotkit/shared";
21
- import { Socket, Channel } from "phoenix";
22
- import { randomUUID } from "node:crypto";
23
-
24
- export interface IntelligenceAgentRunnerOptions {
25
- /** Phoenix runner websocket URL, e.g. "ws://localhost:4000/runner" */
26
- url: string;
27
- /** Optional Phoenix socket auth token used during websocket connect. */
28
- authToken?: string;
29
- /** Max delay (ms) for WebSocket reconnect backoff. @default 10_000 */
30
- maxReconnectMs?: number;
31
- /** Max delay (ms) for channel rejoin backoff. @default 30_000 */
32
- maxRejoinMs?: number;
33
- }
34
-
35
- export interface RunnerStartupBoundary {
36
- events: Observable<BaseEvent>;
37
- startup: Promise<void>;
38
- }
39
-
40
- interface ThreadState {
41
- socket: Socket;
42
- channel: Channel;
43
- isRunning: boolean;
44
- stopRequested: boolean;
45
- agent: AbstractAgent | null;
46
- currentEvents: BaseEvent[];
47
- nextEventSeq: number;
48
- hasRunStarted: boolean;
49
- }
50
-
51
- export class IntelligenceAgentRunner extends AgentRunner {
52
- private options: IntelligenceAgentRunnerOptions;
53
- private threads = new Map<string, ThreadState>();
54
-
55
- constructor(options: IntelligenceAgentRunnerOptions) {
56
- super();
57
- // Store config — sockets are created per-run, not eagerly.
58
- this.options = options;
59
- }
60
-
61
- /**
62
- * Create a new Phoenix socket with explicit exponential backoff.
63
- *
64
- * Each run/connect gets its own socket so that:
65
- * - A socket failure only affects a single thread, not all threads.
66
- * - Cleanup is simple: channel.leave() + socket.disconnect() tears
67
- * down everything for that run with no shared-state concerns.
68
- * - Each run gets its own independent retry budget.
69
- *
70
- * reconnectAfterMs — delay before Phoenix reconnects the WebSocket
71
- * after an unclean close. 100ms base, doubling up to maxReconnectMs (default 10s).
72
- *
73
- * rejoinAfterMs — delay before Phoenix re-joins a channel that
74
- * entered the "errored" state. 1s base, doubling up to maxRejoinMs (default 30s).
75
- *
76
- * These are set explicitly because Phoenix's default schedule is a
77
- * fixed stepped array (not exponential), and any code that calls
78
- * socket.disconnect() in an onError handler will set
79
- * closeWasClean = true and reset the reconnect timer — permanently
80
- * killing retries.
81
- */
82
- private createSocket(): Socket {
83
- const socket = new Socket(this.options.url, {
84
- ...(this.options.authToken ? { authToken: this.options.authToken } : {}),
85
- reconnectAfterMs: phoenixExponentialBackoff(
86
- 100,
87
- this.options.maxReconnectMs ?? 10_000,
88
- ),
89
- rejoinAfterMs: phoenixExponentialBackoff(
90
- 1_000,
91
- this.options.maxRejoinMs ?? 30_000,
92
- ),
93
- });
94
- socket.connect();
95
- return socket;
96
- }
97
-
98
- private createRunnerEventPayload(
99
- event: BaseEvent,
100
- request: AgentRunnerRunRequest,
101
- state: ThreadState,
102
- ): Record<string, unknown> {
103
- const canonicalEvent = this.stampRunnerMetadata(
104
- this.stampCanonicalRunOwnership(event, request),
105
- state,
106
- );
107
- const payload = {
108
- ...(canonicalEvent as Record<string, unknown>),
109
- };
110
-
111
- payload.threadId = request.threadId;
112
- payload.runId = request.input.runId;
113
- payload.thread_id = request.threadId;
114
- payload.run_id = request.input.runId;
115
-
116
- return payload;
117
- }
118
-
119
- private stampCanonicalRunOwnership(
120
- event: BaseEvent,
121
- request: AgentRunnerRunRequest,
122
- ): BaseEvent {
123
- return {
124
- ...(event as BaseEvent & Record<string, unknown>),
125
- threadId: request.threadId,
126
- runId: request.input.runId,
127
- } as BaseEvent;
128
- }
129
-
130
- private stampRunnerMetadata(event: BaseEvent, state: ThreadState): BaseEvent {
131
- const eventRecord = event as BaseEvent & {
132
- metadata?: Record<string, unknown>;
133
- };
134
-
135
- const existingMetadata = eventRecord.metadata ?? {};
136
- const hasEventId = typeof existingMetadata.cpki_event_id === "string";
137
- const hasEventSeq = typeof existingMetadata.cpki_event_seq === "number";
138
-
139
- if (hasEventId && hasEventSeq) {
140
- const eventSeq = existingMetadata.cpki_event_seq as number;
141
- state.nextEventSeq = Math.max(state.nextEventSeq, eventSeq + 1);
142
- return eventRecord;
143
- }
144
-
145
- const eventSeq = state.nextEventSeq++;
146
-
147
- return {
148
- ...eventRecord,
149
- metadata: {
150
- ...existingMetadata,
151
- cpki_event_id:
152
- typeof existingMetadata.cpki_event_id === "string"
153
- ? existingMetadata.cpki_event_id
154
- : randomUUID(),
155
- cpki_event_seq: eventSeq,
156
- },
157
- };
158
- }
159
-
160
- run(request: AgentRunnerRunRequest): Observable<BaseEvent> {
161
- return this.createRunObservable(request);
162
- }
163
-
164
- runWithStartupBoundary(
165
- request: AgentRunnerRunRequest,
166
- ): RunnerStartupBoundary {
167
- let resolveStartup: (() => void) | undefined;
168
- let rejectStartup: ((reason: Error) => void) | undefined;
169
- const startup = new Promise<void>((resolve, reject) => {
170
- resolveStartup = resolve;
171
- rejectStartup = reject;
172
- });
173
-
174
- return {
175
- events: this.createRunObservable(request, {
176
- resolveStartup: () => resolveStartup?.(),
177
- rejectStartup: (error) => rejectStartup?.(error),
178
- }),
179
- startup,
180
- };
181
- }
182
-
183
- private createRunObservable(
184
- request: AgentRunnerRunRequest,
185
- startupBoundary?: {
186
- resolveStartup: () => void;
187
- rejectStartup: (error: Error) => void;
188
- },
189
- ): Observable<BaseEvent> {
190
- const { threadId, agent, input } = request;
191
-
192
- const existing = this.threads.get(threadId);
193
- if (existing?.isRunning) {
194
- throw new Error("Thread already running");
195
- }
196
-
197
- return new Observable((observer) => {
198
- const socket = this.createSocket();
199
-
200
- const channel = socket.channel(`ingestion:${input.runId}`, {
201
- thread_id: threadId,
202
- run_id: input.runId,
203
- });
204
-
205
- const state: ThreadState = {
206
- socket,
207
- channel,
208
- isRunning: true,
209
- stopRequested: false,
210
- agent,
211
- currentEvents: [],
212
- nextEventSeq: 1,
213
- hasRunStarted: false,
214
- };
215
- this.threads.set(threadId, state);
216
-
217
- // Track consecutive socket errors for this run. Phoenix retries
218
- // automatically via reconnectAfterMs, but if the connection fails
219
- // repeatedly we abort the agent — otherwise runAgent() completes
220
- // normally, finalization events buffer silently on the dead
221
- // channel, and the client never receives them.
222
- //
223
- // Aborting the agent is the single trigger that cascades through
224
- // the existing error pipeline: runAgent() rejects → catchError
225
- // pushes RUN_ERROR → finalize calls finalizeRunEvents +
226
- // removeThread → channel.leave() + socket.disconnect().
227
- const MAX_CONSECUTIVE_ERRORS = 5;
228
- let consecutiveErrors = 0;
229
-
230
- socket.onError(() => {
231
- consecutiveErrors++;
232
- if (consecutiveErrors >= MAX_CONSECUTIVE_ERRORS && state.agent) {
233
- try {
234
- state.agent.abortRun();
235
- } catch {
236
- // Ignore abort errors.
237
- }
238
- }
239
- // Otherwise: Phoenix retries automatically using the exponential
240
- // backoff schedule configured in createSocket().
241
- });
242
-
243
- socket.onOpen(() => {
244
- // A successful (re)connection resets the counter so transient
245
- // network blips don't accumulate across recoveries.
246
- consecutiveErrors = 0;
247
- });
248
-
249
- // Listen for custom "stop" events pushed by the client over the
250
- // channel. This must be registered before channel.join() so the
251
- // handler is in place by the time the server starts relaying messages.
252
- // The client sends the stop event before leaving the channel, so the
253
- // runner is guaranteed to receive it while still joined.
254
- channel.on(AG_UI_CHANNEL_EVENT, (payload: BaseEvent) => {
255
- if (
256
- payload.type === EventType.CUSTOM &&
257
- (payload as BaseEvent & { name?: string }).name === "stop"
258
- ) {
259
- this.stop({ threadId });
260
- }
261
- });
262
-
263
- channel
264
- .join()
265
- .receive("ok", () => {
266
- startupBoundary?.resolveStartup();
267
- this.executeAgentRun(request, state, threadId).subscribe({
268
- complete: () => observer.complete(),
269
- });
270
- })
271
- .receive("error", (resp) => {
272
- const error = new Error(
273
- `Failed to join channel: ${JSON.stringify(resp)}`,
274
- );
275
- const errorEvent = {
276
- type: EventType.RUN_ERROR,
277
- message: error.message,
278
- code: "CHANNEL_JOIN_ERROR",
279
- } as BaseEvent;
280
- observer.next(errorEvent);
281
- state.currentEvents.push(errorEvent);
282
- this.removeThread(threadId);
283
- startupBoundary?.rejectStartup(error);
284
- observer.complete();
285
- })
286
- .receive("timeout", () => {
287
- const error = new Error("Timed out joining channel");
288
- const errorEvent = {
289
- type: EventType.RUN_ERROR,
290
- message: error.message,
291
- code: "CHANNEL_JOIN_TIMEOUT",
292
- } as BaseEvent;
293
- observer.next(errorEvent);
294
- state.currentEvents.push(errorEvent);
295
- this.removeThread(threadId);
296
- startupBoundary?.rejectStartup(error);
297
- observer.complete();
298
- });
299
-
300
- return () => {
301
- this.removeThread(threadId);
302
- };
303
- });
304
- }
305
-
306
- connect(request: AgentRunnerConnectRequest): Observable<BaseEvent> {
307
- const { threadId } = request;
308
-
309
- return new Observable((observer) => {
310
- const socket = this.createSocket();
311
-
312
- const channel = socket.channel(`thread:${threadId}`);
313
-
314
- channel.on("ag_ui_event", (payload: BaseEvent) => {
315
- observer.next(payload);
316
-
317
- if (
318
- payload.type === EventType.RUN_FINISHED ||
319
- payload.type === EventType.RUN_ERROR
320
- ) {
321
- observer.complete();
322
- }
323
- });
324
-
325
- const cleanup = () => {
326
- channel.leave();
327
- socket.disconnect();
328
- };
329
-
330
- channel
331
- .join()
332
- .receive("ok", () => undefined)
333
- .receive("error", (resp) => {
334
- observer.error(
335
- new Error(`Failed to join channel: ${JSON.stringify(resp)}`),
336
- );
337
- cleanup();
338
- })
339
- .receive("timeout", () => {
340
- observer.error(new Error("Timed out joining channel"));
341
- cleanup();
342
- });
343
-
344
- return () => {
345
- cleanup();
346
- };
347
- });
348
- }
349
-
350
- isRunning(request: AgentRunnerIsRunningRequest): Promise<boolean> {
351
- const state = this.threads.get(request.threadId);
352
- return Promise.resolve(state?.isRunning ?? false);
353
- }
354
-
355
- stop(request: AgentRunnerStopRequest): Promise<boolean | undefined> {
356
- const state = this.threads.get(request.threadId);
357
- if (!state || !state.isRunning || state.stopRequested) {
358
- return Promise.resolve(false);
359
- }
360
-
361
- state.stopRequested = true;
362
-
363
- // Direct local abort — the runtime is the authority.
364
- if (state.agent) {
365
- try {
366
- state.agent.abortRun();
367
- } catch {
368
- // Ignore abort errors.
369
- }
370
- }
371
-
372
- return Promise.resolve(true);
373
- }
374
-
375
- private executeAgentRun(
376
- request: AgentRunnerRunRequest,
377
- state: ThreadState,
378
- threadId: string,
379
- ): Observable<void> {
380
- const { currentEvents, channel } = state;
381
- const pushCanonicalEvent = (event: BaseEvent): void => {
382
- const canonicalEvent = this.stampRunnerMetadata(
383
- this.stampCanonicalRunOwnership(event, request),
384
- state,
385
- );
386
- currentEvents.push(canonicalEvent);
387
-
388
- if (canonicalEvent.type === EventType.RUN_STARTED) {
389
- state.hasRunStarted = true;
390
- }
391
-
392
- channel.push(
393
- "event",
394
- this.createRunnerEventPayload(canonicalEvent, request, state),
395
- );
396
- };
397
-
398
- const getPersistedInputMessages = () =>
399
- request.persistedInputMessages ?? request.input.messages;
400
-
401
- const buildRunStartedEvent = (
402
- source?: RunStartedEvent,
403
- ): RunStartedEvent => {
404
- const baseInput = source?.input ?? request.input;
405
- const persistedInputMessages = getPersistedInputMessages();
406
-
407
- return {
408
- ...(source ?? {
409
- type: EventType.RUN_STARTED,
410
- threadId: request.threadId,
411
- runId: request.input.runId,
412
- }),
413
- threadId: request.threadId,
414
- runId: request.input.runId,
415
- input: {
416
- ...baseInput,
417
- threadId: request.threadId,
418
- runId: request.input.runId,
419
- ...(persistedInputMessages !== undefined
420
- ? { messages: persistedInputMessages }
421
- : {}),
422
- },
423
- } as RunStartedEvent;
424
- };
425
-
426
- const ensureRunStarted = (): void => {
427
- if (!state.hasRunStarted) {
428
- state.hasRunStarted = true;
429
- pushCanonicalEvent(buildRunStartedEvent());
430
- }
431
- };
432
-
433
- return from(
434
- request.agent.runAgent(request.input, {
435
- onEvent: ({ event }: { event: BaseEvent }) => {
436
- if (event.type === EventType.RUN_STARTED) {
437
- pushCanonicalEvent(buildRunStartedEvent(event as RunStartedEvent));
438
- return;
439
- }
440
-
441
- ensureRunStarted();
442
- pushCanonicalEvent(event);
443
- },
444
- }),
445
- ).pipe(
446
- catchError((error) => {
447
- ensureRunStarted();
448
- const errorEvent = {
449
- type: EventType.RUN_ERROR,
450
- message: error instanceof Error ? error.message : String(error),
451
- } as BaseEvent;
452
- pushCanonicalEvent(errorEvent);
453
- return EMPTY;
454
- }),
455
- finalize(() => {
456
- ensureRunStarted();
457
- const appended = finalizeRunEvents(currentEvents, {
458
- stopRequested: state.stopRequested,
459
- });
460
- for (const event of appended) {
461
- channel.push(
462
- "event",
463
- this.createRunnerEventPayload(event, request, state),
464
- );
465
- }
466
- this.removeThread(threadId);
467
- }),
468
- );
469
- }
470
-
471
- /**
472
- * Tear down all resources for a thread: leave the channel,
473
- * disconnect the per-run socket, and remove the thread state.
474
- *
475
- * Idempotent — safe to call multiple times for the same threadId
476
- * (e.g. from join error handlers, finalize, and Observable teardown).
477
- */
478
- private removeThread(threadId: string): void {
479
- const state = this.threads.get(threadId);
480
- if (!state) {
481
- return;
482
- }
483
-
484
- // Delete first so concurrent calls see the entry as already removed.
485
- this.threads.delete(threadId);
486
-
487
- try {
488
- state.channel.leave();
489
- } catch {
490
- // Channel may already be closed/left.
491
- }
492
- try {
493
- state.socket.disconnect();
494
- } catch {
495
- // Socket may already be disconnected.
496
- }
497
- }
498
- }
@@ -1,96 +0,0 @@
1
- import { describe, it, expect, vi, beforeEach, afterEach } from "vitest";
2
- import { telemetry } from "..";
3
- import { fireInstanceCreatedTelemetry } from "../instance-created";
4
- import type { CopilotRuntimeLike } from "../../core/runtime";
5
-
6
- // Minimal runtime stub: we only use `agents` from CopilotRuntimeLike inside
7
- // the helper, so we cast the stub rather than construct a full runtime.
8
- function makeRuntime(
9
- agents:
10
- | Record<string, unknown>
11
- | Promise<Record<string, unknown>>
12
- | ((ctx: { request: Request }) => Record<string, unknown>),
13
- ): CopilotRuntimeLike {
14
- return { agents } as unknown as CopilotRuntimeLike;
15
- }
16
-
17
- describe("fireInstanceCreatedTelemetry", () => {
18
- let captureSpy: ReturnType<typeof vi.spyOn>;
19
-
20
- beforeEach(() => {
21
- captureSpy = vi.spyOn(telemetry, "capture").mockResolvedValue(undefined);
22
- });
23
-
24
- afterEach(() => {
25
- captureSpy.mockRestore();
26
- });
27
-
28
- it("captures instance_created with agent count from static agents record", async () => {
29
- fireInstanceCreatedTelemetry({
30
- runtime: makeRuntime({ a1: {}, a2: {}, a3: {} }),
31
- });
32
-
33
- await vi.waitFor(() => expect(captureSpy).toHaveBeenCalled());
34
-
35
- expect(captureSpy).toHaveBeenCalledWith("oss.runtime.instance_created", {
36
- actionsAmount: 0,
37
- endpointTypes: [],
38
- endpointsAmount: 0,
39
- agentsAmount: 3,
40
- "cloud.api_key_provided": false,
41
- });
42
- });
43
-
44
- it("awaits Promise-based agents before capturing", async () => {
45
- fireInstanceCreatedTelemetry({
46
- runtime: makeRuntime(Promise.resolve({ only: {} })),
47
- });
48
-
49
- await vi.waitFor(() => expect(captureSpy).toHaveBeenCalled());
50
-
51
- const call = captureSpy.mock.calls[0][1] as { agentsAmount: number | null };
52
- expect(call.agentsAmount).toBe(1);
53
- });
54
-
55
- it("reports agentsAmount: null when agents is a factory (cannot resolve without request)", async () => {
56
- fireInstanceCreatedTelemetry({
57
- runtime: makeRuntime(() => ({ x: {} })),
58
- });
59
-
60
- await vi.waitFor(() => expect(captureSpy).toHaveBeenCalled());
61
-
62
- const call = captureSpy.mock.calls[0][1] as { agentsAmount: number | null };
63
- expect(call.agentsAmount).toBeNull();
64
- });
65
-
66
- it("does not hardcode cloud.api_key_provided — it is false at handler-creation time by design (key arrives per-request via header)", async () => {
67
- fireInstanceCreatedTelemetry({
68
- runtime: makeRuntime({ a1: {} }),
69
- });
70
-
71
- await vi.waitFor(() => expect(captureSpy).toHaveBeenCalled());
72
-
73
- const call = captureSpy.mock.calls[0][1] as {
74
- "cloud.api_key_provided": boolean;
75
- };
76
- expect(call["cloud.api_key_provided"]).toBe(false);
77
- });
78
-
79
- it("does not throw or reject when agents Promise rejects", async () => {
80
- // Swallow the unhandled rejection from the input Promise itself — the
81
- // Promise we pass in rejects synchronously regardless of whether we
82
- // attach a .catch downstream.
83
- const rejectingAgents = Promise.reject(new Error("boom"));
84
- rejectingAgents.catch(() => {});
85
-
86
- expect(() =>
87
- fireInstanceCreatedTelemetry({
88
- runtime: makeRuntime(rejectingAgents as any),
89
- }),
90
- ).not.toThrow();
91
-
92
- // Wait a microtask to let the internal catch fire; no capture should happen.
93
- await new Promise((resolve) => setTimeout(resolve, 10));
94
- expect(captureSpy).not.toHaveBeenCalled();
95
- });
96
- });
@@ -1,35 +0,0 @@
1
- export type AnalyticsEvents = {
2
- "oss.runtime.instance_created": RuntimeInstanceCreatedInfo;
3
- "oss.runtime.copilot_request_created": {
4
- "cloud.guardrails.enabled": boolean;
5
- requestType: string;
6
- "cloud.api_key_provided": boolean;
7
- "cloud.public_api_key"?: string;
8
- "cloud.base_url"?: string;
9
- };
10
- "oss.runtime.agent_execution_stream_started": { hashedLgcKey?: string };
11
- "oss.runtime.agent_execution_stream_ended": AgentExecutionResponseInfo;
12
- "oss.runtime.agent_execution_stream_errored": {
13
- hashedLgcKey?: string;
14
- error?: string;
15
- };
16
- };
17
-
18
- export interface RuntimeInstanceCreatedInfo {
19
- actionsAmount: number;
20
- endpointTypes: string[];
21
- hashedLgcKey?: string;
22
- endpointsAmount: number;
23
- agentsAmount?: number | null;
24
- "cloud.api_key_provided": boolean;
25
- "cloud.public_api_key"?: string;
26
- "cloud.base_url"?: string;
27
- }
28
-
29
- export interface AgentExecutionResponseInfo {
30
- provider?: string;
31
- model?: string;
32
- langGraphHost?: string;
33
- langGraphVersion?: string;
34
- hashedLgcKey?: string;
35
- }
@@ -1,7 +0,0 @@
1
- export { default as telemetry } from "./telemetry-client";
2
- export { TelemetryClient, isTelemetryDisabled } from "./telemetry-client";
3
- export type {
4
- AnalyticsEvents,
5
- RuntimeInstanceCreatedInfo,
6
- AgentExecutionResponseInfo,
7
- } from "./events";
@@ -1,44 +0,0 @@
1
- import { telemetry } from ".";
2
- import type { CopilotRuntimeLike } from "../core/runtime";
3
-
4
- /**
5
- * Fire the `oss.runtime.instance_created` telemetry event for a v2 runtime
6
- * handler. Called once per handler factory invocation (not per request).
7
- *
8
- * v2 does not have a concept of remote endpoints or standalone actions, so
9
- * those counts are 0 / []. `cloud.api_key_provided` is false at this level
10
- * because in v2 the cloud public key arrives per-request via the
11
- * `x-copilotcloud-public-api-key` header — not at handler creation time.
12
- * See `handlers/handle-run.ts` for the per-request event that DOES carry
13
- * the key when present.
14
- *
15
- * Errors resolving agents are swallowed — telemetry must never break
16
- * runtime setup.
17
- */
18
- export function fireInstanceCreatedTelemetry({
19
- runtime,
20
- }: {
21
- runtime: CopilotRuntimeLike;
22
- }): void {
23
- // agents can be a static Record, a Promise, or a per-request factory.
24
- // Factory configs cannot be resolved at handler-creation time (no Request
25
- // context), so report agentsAmount as null in that case.
26
- const agentsPromise =
27
- typeof runtime.agents === "function"
28
- ? Promise.resolve<Record<string, unknown> | null>(null)
29
- : Promise.resolve(runtime.agents);
30
-
31
- agentsPromise
32
- .then((agents) => {
33
- telemetry.capture("oss.runtime.instance_created", {
34
- actionsAmount: 0,
35
- endpointTypes: [],
36
- endpointsAmount: 0,
37
- agentsAmount: agents ? Object.keys(agents).length : null,
38
- "cloud.api_key_provided": false,
39
- });
40
- })
41
- .catch(() => {
42
- // Swallow — telemetry must not break runtime creation.
43
- });
44
- }