@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
@@ -0,0 +1,414 @@
1
+ # CopilotKit Server-Side Tools
2
+
3
+ Server-side tools run in the runtime process. They are the right choice when the tool needs
4
+ to touch server-only state: DB connections, API keys, filesystem, signed URLs.
5
+
6
+ `defineTool` returns a `ToolDefinition`. Pass an array of them to the Simple-Mode
7
+ `BuiltInAgent.config.tools`, or into the `tools:` option of `chat()` / `streamText()` inside
8
+ a Factory Mode factory.
9
+
10
+ ## Setup
11
+
12
+ ```typescript
13
+ import {
14
+ CopilotRuntime,
15
+ createCopilotRuntimeHandler,
16
+ BuiltInAgent,
17
+ defineTool,
18
+ } from "@copilotkit/runtime/v2";
19
+ import { z } from "zod";
20
+
21
+ const getInventory = defineTool({
22
+ name: "getInventory",
23
+ description: "Look up stock for a product SKU.",
24
+ parameters: z.object({ sku: z.string() }),
25
+ execute: async ({ sku }) => {
26
+ const row = await db.product.findUnique({ where: { sku } });
27
+ return { sku, inStock: row?.inStock ?? 0 };
28
+ },
29
+ });
30
+
31
+ const runtime = new CopilotRuntime({
32
+ agents: {
33
+ default: new BuiltInAgent({
34
+ model: "openai/gpt-4o",
35
+ maxSteps: 5,
36
+ tools: [getInventory],
37
+ }),
38
+ },
39
+ });
40
+
41
+ const handler = createCopilotRuntimeHandler({
42
+ runtime,
43
+ basePath: "/api/copilotkit",
44
+ });
45
+
46
+ export default { fetch: handler };
47
+
48
+ declare const db: {
49
+ product: { findUnique: (q: any) => Promise<{ inStock: number } | null> };
50
+ };
51
+ ```
52
+
53
+ ## Core Patterns
54
+
55
+ ### Zod parameters (most common)
56
+
57
+ ```typescript
58
+ import { defineTool } from "@copilotkit/runtime/v2";
59
+ import { z } from "zod";
60
+
61
+ const searchDocs = defineTool({
62
+ name: "searchDocs",
63
+ description: "Search the internal docs index.",
64
+ parameters: z.object({
65
+ query: z.string().min(1),
66
+ limit: z.number().int().min(1).max(20).default(5),
67
+ }),
68
+ execute: async ({ query, limit }) => {
69
+ const results = await searchIndex(query, limit);
70
+ return { results };
71
+ },
72
+ });
73
+
74
+ declare const searchIndex: (q: string, n: number) => Promise<unknown[]>;
75
+ ```
76
+
77
+ ### Valibot parameters (Standard Schema V1)
78
+
79
+ ```typescript
80
+ import { defineTool } from "@copilotkit/runtime/v2";
81
+ import * as v from "valibot";
82
+
83
+ const translate = defineTool({
84
+ name: "translate",
85
+ description: "Translate text between languages.",
86
+ parameters: v.object({
87
+ text: v.pipe(v.string(), v.minLength(1)),
88
+ target: v.picklist(["en", "es", "fr", "de"]),
89
+ }),
90
+ execute: async ({ text, target }) => ({ translated: `[${target}] ${text}` }),
91
+ });
92
+ ```
93
+
94
+ ### Graceful error handling inside execute
95
+
96
+ ```typescript
97
+ import { defineTool } from "@copilotkit/runtime/v2";
98
+ import { z } from "zod";
99
+
100
+ const runQuery = defineTool({
101
+ name: "runQuery",
102
+ description: "Run an analytics query.",
103
+ parameters: z.object({ sql: z.string() }),
104
+ execute: async ({ sql }) => {
105
+ try {
106
+ return { rows: await warehouse.query(sql) };
107
+ } catch (e) {
108
+ return { error: String(e), retryable: true };
109
+ }
110
+ },
111
+ });
112
+
113
+ declare const warehouse: { query: (sql: string) => Promise<unknown[]> };
114
+ ```
115
+
116
+ ### Server tool + client tool side by side
117
+
118
+ Server tools for I/O, client tools for UI. Both can coexist.
119
+
120
+ ```typescript
121
+ // server
122
+ import { defineTool } from "@copilotkit/runtime/v2";
123
+ import { z } from "zod";
124
+
125
+ export const fetchOrder = defineTool({
126
+ name: "fetchOrder",
127
+ description: "Fetch order details from the orders service.",
128
+ parameters: z.object({ orderId: z.string() }),
129
+ execute: async ({ orderId }) => fetchOrderFromService(orderId),
130
+ });
131
+ declare const fetchOrderFromService: (id: string) => Promise<unknown>;
132
+ ```
133
+
134
+ ```tsx
135
+ // client — a render-only tool lets the LLM display a modal
136
+ import { useComponent } from "@copilotkit/react-core/v2";
137
+ import { z } from "zod";
138
+
139
+ useComponent({
140
+ name: "showOrderDetails",
141
+ parameters: z.object({ orderId: z.string(), status: z.string() }),
142
+ // Schema fields arrive DIRECTLY as props (InferRenderProps<TSchema>) —
143
+ // no { args } wrapper. See packages/react-core/src/v2/hooks/use-component.tsx.
144
+ render: ({ orderId, status }) => (
145
+ <div className="modal">
146
+ Order {orderId} — {status}
147
+ </div>
148
+ ),
149
+ });
150
+ ```
151
+
152
+ ### Factory Mode — pass tools into the factory
153
+
154
+ Simple-Mode `config.tools` is ignored in Factory Mode.
155
+
156
+ ```typescript
157
+ import {
158
+ BuiltInAgent,
159
+ convertToolDefinitionsToVercelAITools,
160
+ convertMessagesToVercelAISDKMessages,
161
+ defineTool,
162
+ } from "@copilotkit/runtime/v2";
163
+ import { streamText } from "ai";
164
+ import { openai } from "@ai-sdk/openai";
165
+ import { z } from "zod";
166
+
167
+ const searchDocs = defineTool({
168
+ name: "searchDocs",
169
+ description: "Search the internal docs index.",
170
+ parameters: z.object({ query: z.string() }),
171
+ execute: async ({ query }) => ({ results: [] }),
172
+ });
173
+
174
+ new BuiltInAgent({
175
+ type: "aisdk",
176
+ factory: ({ input, abortSignal }) => {
177
+ const serverTools = convertToolDefinitionsToVercelAITools([searchDocs]);
178
+ return streamText({
179
+ model: openai("gpt-4o"),
180
+ messages: convertMessagesToVercelAISDKMessages(input.messages),
181
+ tools: serverTools,
182
+ abortSignal,
183
+ });
184
+ },
185
+ });
186
+ ```
187
+
188
+ ## Common Mistakes
189
+
190
+ ### HIGH Using defineTool for tools that should render UI
191
+
192
+ Wrong:
193
+
194
+ ```typescript
195
+ defineTool({
196
+ name: "showModal",
197
+ description: "Show a confirmation modal to the user.",
198
+ parameters: z.object({ title: z.string() }),
199
+ execute: async () => "rendered",
200
+ });
201
+ ```
202
+
203
+ Correct:
204
+
205
+ ```tsx
206
+ // Keep UI on the client — frontend tool with a renderer
207
+ import { useFrontendTool } from "@copilotkit/react-core/v2";
208
+ import { z } from "zod";
209
+
210
+ useFrontendTool({
211
+ name: "showModal",
212
+ parameters: z.object({ title: z.string() }),
213
+ handler: async (args) => ({ confirmed: true }),
214
+ });
215
+ ```
216
+
217
+ Server tools execute on the server and stream only results back. The browser never sees a
218
+ `TOOL_CALL_START` for a server tool, so there is nothing to mount a renderer against.
219
+
220
+ Source: `dev-docs/architecture/plugin-points.md:36-77`;
221
+ `docs/content/docs/integrations/built-in-agent/server-tools.mdx:9-14`.
222
+
223
+ ### MEDIUM Redefining AG-UI reserved names
224
+
225
+ Wrong:
226
+
227
+ ```typescript
228
+ defineTool({
229
+ name: "AGUISendStateSnapshot",
230
+ description: "My own snapshot tool.",
231
+ parameters: z.object({ snapshot: z.any() }),
232
+ execute: async () => ({ success: true }),
233
+ });
234
+ ```
235
+
236
+ Correct:
237
+
238
+ ```typescript
239
+ defineTool({
240
+ name: "mySnapshotExport",
241
+ description: "Export a user-facing state snapshot.",
242
+ parameters: z.object({ snapshot: z.any() }),
243
+ execute: async () => ({ success: true }),
244
+ });
245
+ ```
246
+
247
+ `AGUISendStateSnapshot` and `AGUISendStateDelta` are auto-injected by BuiltInAgent in
248
+ Simple Mode — redefining them silently overwrites the built-ins.
249
+
250
+ Source: `packages/runtime/src/agent/index.ts:1139-1177`.
251
+
252
+ ### MEDIUM Throwing from execute without a result
253
+
254
+ Wrong:
255
+
256
+ ```typescript
257
+ defineTool({
258
+ name: "runQuery",
259
+ description: "Run a database query.",
260
+ parameters: z.object({ sql: z.string() }),
261
+ execute: async () => {
262
+ throw new Error("db down");
263
+ },
264
+ });
265
+ ```
266
+
267
+ Correct:
268
+
269
+ ```typescript
270
+ defineTool({
271
+ name: "runQuery",
272
+ description: "Run a database query.",
273
+ parameters: z.object({ sql: z.string() }),
274
+ execute: async ({ sql }) => {
275
+ try {
276
+ return await db.query(sql);
277
+ } catch (e) {
278
+ return { error: String(e), retryable: true };
279
+ }
280
+ },
281
+ });
282
+ ```
283
+
284
+ Thrown errors kill the run; unserializable results (class instances, circular refs) become
285
+ the string `"[Unserializable tool result from X]"`. Return a plain-object error shape
286
+ instead and let the LLM retry.
287
+
288
+ Source: `packages/runtime/src/agent/index.ts:1469-1474`.
289
+
290
+ ### MEDIUM Passing a JSON-schema object as parameters
291
+
292
+ Wrong:
293
+
294
+ ```typescript
295
+ defineTool({
296
+ name: "x",
297
+ description: "...",
298
+ parameters: {
299
+ type: "object",
300
+ properties: { q: { type: "string" } },
301
+ required: ["q"],
302
+ } as any,
303
+ execute: async ({ q }) => q,
304
+ });
305
+ ```
306
+
307
+ Correct:
308
+
309
+ ```typescript
310
+ import { z } from "zod";
311
+
312
+ defineTool({
313
+ name: "x",
314
+ description: "...",
315
+ parameters: z.object({ q: z.string() }),
316
+ execute: async ({ q }) => q,
317
+ });
318
+ ```
319
+
320
+ `parameters` must be a Standard Schema V1 validator (Zod, Valibot, ArkType, ...). Plain
321
+ JSON Schema throws in `schemaToJsonSchema()`. Also, Standard Schema V1 preserves static
322
+ types — `execute`'s arg type is inferred.
323
+
324
+ Source: `packages/runtime/src/agent/index.ts:633-659`.
325
+
326
+ ### HIGH Unavailable in Factory Mode via config.tools
327
+
328
+ Wrong:
329
+
330
+ ```typescript
331
+ new BuiltInAgent({
332
+ type: "tanstack",
333
+ factory: myFactory,
334
+ tools: [searchDocs], // ignored in Factory Mode
335
+ } as any);
336
+ ```
337
+
338
+ Correct:
339
+
340
+ ```typescript
341
+ // Factory Mode — AI SDK factory: convert defineTool → Vercel AI SDK tools
342
+ import {
343
+ BuiltInAgent,
344
+ convertToolDefinitionsToVercelAITools,
345
+ convertMessagesToVercelAISDKMessages,
346
+ } from "@copilotkit/runtime/v2";
347
+ import { streamText } from "ai";
348
+ import { openai } from "@ai-sdk/openai";
349
+
350
+ new BuiltInAgent({
351
+ type: "aisdk",
352
+ factory: ({ input, abortSignal }) => {
353
+ const tools = convertToolDefinitionsToVercelAITools([searchDocs]);
354
+ return streamText({
355
+ model: openai("gpt-4o"),
356
+ messages: convertMessagesToVercelAISDKMessages(input.messages),
357
+ tools,
358
+ abortSignal,
359
+ });
360
+ },
361
+ });
362
+
363
+ // Factory Mode — TanStack AI factory: defineTool output is NOT a TanStack tool.
364
+ // There is no built-in converter in @copilotkit/runtime for TanStack. Either
365
+ // redefine the tool with TanStack's `toolDefinition()` API from `@tanstack/ai`,
366
+ // or write a small adapter that translates your `defineTool` output into
367
+ // TanStack's tool shape before passing it into `chat({ tools })`.
368
+ ```
369
+
370
+ Factory Mode ignores `config.tools`. Wire server tools through the factory's LLM call —
371
+ AI SDK has `convertToolDefinitionsToVercelAITools([...])` out of the box; TanStack AI has
372
+ its own `toolDefinition()` API you need to build the tools with directly.
373
+
374
+ Source: `packages/runtime/src/agent/index.ts:1581-1671`.
375
+
376
+ ### MEDIUM Shared name between client and server tool
377
+
378
+ Wrong:
379
+
380
+ ```tsx
381
+ // frontend
382
+ useFrontendTool({
383
+ name: "getWeather",
384
+ parameters: z.object({ city: z.string() }),
385
+ handler,
386
+ });
387
+
388
+ // server
389
+ defineTool({
390
+ name: "getWeather",
391
+ parameters: z.object({ city: z.string() }),
392
+ execute,
393
+ });
394
+ // Server silently wins on the merge — handler never fires
395
+ ```
396
+
397
+ Correct:
398
+
399
+ ```tsx
400
+ // Pick one side and give tools distinct names if both sides need their own
401
+ useFrontendTool({ name: "getWeatherClientSide" /* ... */ });
402
+ defineTool({ name: "getWeatherServer" /* ... */ });
403
+ ```
404
+
405
+ On collisions, `config.tools` (server) overwrites frontend-registered tools. The LLM sees
406
+ only one `getWeather` — the server version.
407
+
408
+ Source: `packages/runtime/src/agent/index.ts` (tool merge).
409
+
410
+ ## See also
411
+
412
+ - `copilotkit/built-in-agent` — `config.tools` only applies in Simple Mode
413
+ - `copilotkit/client-side-tools` (react-core) — browser-side tools, paired decision
414
+ - `copilotkit/rendering-tool-calls` (react-core) — rendering tool invocations in chat