@copilotkit/runtime 1.57.2 → 1.57.4

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (342) hide show
  1. package/dist/lib/runtime/copilot-runtime.cjs +2 -0
  2. package/dist/lib/runtime/copilot-runtime.cjs.map +1 -1
  3. package/dist/lib/runtime/copilot-runtime.d.cts.map +1 -1
  4. package/dist/lib/runtime/copilot-runtime.d.mts.map +1 -1
  5. package/dist/lib/runtime/copilot-runtime.mjs +2 -0
  6. package/dist/lib/runtime/copilot-runtime.mjs.map +1 -1
  7. package/dist/package.cjs +52 -19
  8. package/dist/package.mjs +52 -19
  9. package/dist/v2/runtime/core/runtime.cjs +4 -1
  10. package/dist/v2/runtime/core/runtime.cjs.map +1 -1
  11. package/dist/v2/runtime/core/runtime.d.cts.map +1 -1
  12. package/dist/v2/runtime/core/runtime.d.mts.map +1 -1
  13. package/dist/v2/runtime/core/runtime.mjs +4 -1
  14. package/dist/v2/runtime/core/runtime.mjs.map +1 -1
  15. package/dist/v2/runtime/handlers/get-runtime-info.cjs +1 -1
  16. package/dist/v2/runtime/handlers/get-runtime-info.mjs +1 -1
  17. package/dist/v2/runtime/handlers/handle-connect.cjs +1 -1
  18. package/dist/v2/runtime/handlers/handle-connect.mjs +1 -1
  19. package/dist/v2/runtime/handlers/handle-run.cjs +1 -1
  20. package/dist/v2/runtime/handlers/handle-run.mjs +1 -1
  21. package/dist/v2/runtime/handlers/shared/agent-utils.cjs +1 -1
  22. package/dist/v2/runtime/handlers/shared/agent-utils.cjs.map +1 -1
  23. package/dist/v2/runtime/handlers/shared/agent-utils.mjs +1 -1
  24. package/dist/v2/runtime/handlers/shared/agent-utils.mjs.map +1 -1
  25. package/dist/v2/runtime/telemetry/telemetry-client.cjs +22 -6
  26. package/dist/v2/runtime/telemetry/telemetry-client.cjs.map +1 -1
  27. package/dist/v2/runtime/telemetry/telemetry-client.mjs +27 -11
  28. package/dist/v2/runtime/telemetry/telemetry-client.mjs.map +1 -1
  29. package/package.json +8 -18
  30. package/skills/runtime/SKILL.md +98 -0
  31. package/skills/runtime/references/agent-runners-custom.md +161 -0
  32. package/skills/runtime/references/agent-runners-in-memory.md +64 -0
  33. package/skills/runtime/references/agent-runners-sqlite.md +90 -0
  34. package/skills/runtime/references/agent-runners.md +304 -0
  35. package/skills/runtime/references/built-in-agent-factory-modes.md +232 -0
  36. package/skills/runtime/references/built-in-agent-helper-utilities.md +123 -0
  37. package/skills/runtime/references/built-in-agent-model-identifiers.md +59 -0
  38. package/skills/runtime/references/built-in-agent.md +523 -0
  39. package/skills/runtime/references/intelligence-mode.md +336 -0
  40. package/skills/runtime/references/middleware.md +376 -0
  41. package/skills/runtime/references/server-side-tools.md +414 -0
  42. package/skills/runtime/references/setup-endpoint.md +503 -0
  43. package/skills/runtime/references/transcription.md +287 -0
  44. package/skills/runtime/references/wiring-a2a.md +40 -0
  45. package/skills/runtime/references/wiring-adk.md +45 -0
  46. package/skills/runtime/references/wiring-ag2.md +41 -0
  47. package/skills/runtime/references/wiring-agno.md +39 -0
  48. package/skills/runtime/references/wiring-aws-strands.md +59 -0
  49. package/skills/runtime/references/wiring-crewai-crews.md +51 -0
  50. package/skills/runtime/references/wiring-crewai-flows.md +45 -0
  51. package/skills/runtime/references/wiring-external-agents.md +348 -0
  52. package/skills/runtime/references/wiring-langgraph.md +50 -0
  53. package/skills/runtime/references/wiring-llamaindex.md +39 -0
  54. package/skills/runtime/references/wiring-mastra.md +70 -0
  55. package/skills/runtime/references/wiring-mcp-apps-middleware.md +68 -0
  56. package/skills/runtime/references/wiring-ms-agent-framework.md +41 -0
  57. package/skills/runtime/references/wiring-pydantic-ai.md +45 -0
  58. package/CHANGELOG.md +0 -3624
  59. package/__snapshots__/schema/schema.graphql +0 -371
  60. package/dist/v2/runtime/telemetry/scarf-client.cjs +0 -32
  61. package/dist/v2/runtime/telemetry/scarf-client.cjs.map +0 -1
  62. package/dist/v2/runtime/telemetry/scarf-client.mjs +0 -32
  63. package/dist/v2/runtime/telemetry/scarf-client.mjs.map +0 -1
  64. package/scripts/generate-gql-schema.ts +0 -16
  65. package/src/agent/__tests__/agent-test-helpers.ts +0 -476
  66. package/src/agent/__tests__/agent.test.ts +0 -593
  67. package/src/agent/__tests__/ai-sdk-v6-compat.test.ts +0 -116
  68. package/src/agent/__tests__/basic-agent.test.ts +0 -1698
  69. package/src/agent/__tests__/capabilities.test.ts +0 -81
  70. package/src/agent/__tests__/config-tools-execution.test.ts +0 -516
  71. package/src/agent/__tests__/converter-aisdk.test.ts +0 -692
  72. package/src/agent/__tests__/converter-custom.test.ts +0 -319
  73. package/src/agent/__tests__/converter-tanstack-input.test.ts +0 -211
  74. package/src/agent/__tests__/converter-tanstack.test.ts +0 -594
  75. package/src/agent/__tests__/mcp-clients.test.ts +0 -246
  76. package/src/agent/__tests__/mcp-servers-integration.test.ts +0 -373
  77. package/src/agent/__tests__/multimodal-tanstack.test.ts +0 -284
  78. package/src/agent/__tests__/multimodal.test.ts +0 -176
  79. package/src/agent/__tests__/property-overrides.test.ts +0 -598
  80. package/src/agent/__tests__/provider-id-collision.test.ts +0 -195
  81. package/src/agent/__tests__/standard-schema-tools.test.ts +0 -313
  82. package/src/agent/__tests__/standard-schema-types.test.ts +0 -158
  83. package/src/agent/__tests__/state-tools.test.ts +0 -436
  84. package/src/agent/__tests__/test-helpers.ts +0 -197
  85. package/src/agent/__tests__/utils.test.ts +0 -536
  86. package/src/agent/__tests__/zod-regression.test.ts +0 -350
  87. package/src/agent/converters/aisdk.ts +0 -326
  88. package/src/agent/converters/index.ts +0 -7
  89. package/src/agent/converters/tanstack.ts +0 -451
  90. package/src/agent/index.ts +0 -1743
  91. package/src/agents/langgraph/__tests__/event-source.test.ts +0 -256
  92. package/src/agents/langgraph/event-source.ts +0 -365
  93. package/src/agents/langgraph/events.ts +0 -394
  94. package/src/graphql/inputs/action.input.ts +0 -16
  95. package/src/graphql/inputs/agent-session.input.ts +0 -13
  96. package/src/graphql/inputs/agent-state.input.ts +0 -13
  97. package/src/graphql/inputs/cloud-guardrails.input.ts +0 -16
  98. package/src/graphql/inputs/cloud.input.ts +0 -8
  99. package/src/graphql/inputs/context-property.input.ts +0 -10
  100. package/src/graphql/inputs/copilot-context.input.ts +0 -10
  101. package/src/graphql/inputs/custom-property.input.ts +0 -15
  102. package/src/graphql/inputs/extensions.input.ts +0 -21
  103. package/src/graphql/inputs/forwarded-parameters.input.ts +0 -22
  104. package/src/graphql/inputs/frontend.input.ts +0 -14
  105. package/src/graphql/inputs/generate-copilot-response.input.ts +0 -59
  106. package/src/graphql/inputs/load-agent-state.input.ts +0 -10
  107. package/src/graphql/inputs/message.input.ts +0 -110
  108. package/src/graphql/inputs/meta-event.input.ts +0 -18
  109. package/src/graphql/message-conversion/agui-to-gql.test.ts +0 -1384
  110. package/src/graphql/message-conversion/agui-to-gql.ts +0 -384
  111. package/src/graphql/message-conversion/gql-to-agui.test.ts +0 -1653
  112. package/src/graphql/message-conversion/gql-to-agui.ts +0 -297
  113. package/src/graphql/message-conversion/index.ts +0 -2
  114. package/src/graphql/message-conversion/roundtrip-conversion.test.ts +0 -561
  115. package/src/graphql/resolvers/__tests__/resolve-message-id.test.ts +0 -25
  116. package/src/graphql/resolvers/copilot.resolver.ts +0 -785
  117. package/src/graphql/resolvers/resolve-message-id.ts +0 -14
  118. package/src/graphql/resolvers/state.resolver.ts +0 -30
  119. package/src/graphql/types/agents-response.type.ts +0 -19
  120. package/src/graphql/types/base/index.ts +0 -10
  121. package/src/graphql/types/converted/index.ts +0 -183
  122. package/src/graphql/types/copilot-response.type.ts +0 -141
  123. package/src/graphql/types/enums.ts +0 -38
  124. package/src/graphql/types/extensions-response.type.ts +0 -23
  125. package/src/graphql/types/guardrails-result.type.ts +0 -20
  126. package/src/graphql/types/load-agent-state-response.type.ts +0 -17
  127. package/src/graphql/types/message-status.type.ts +0 -48
  128. package/src/graphql/types/meta-events.type.ts +0 -78
  129. package/src/graphql/types/response-status.type.ts +0 -77
  130. package/src/index.ts +0 -3
  131. package/src/langgraph.ts +0 -1
  132. package/src/lib/__tests__/telemetry-disclosure.test.ts +0 -55
  133. package/src/lib/cloud/index.ts +0 -4
  134. package/src/lib/error-messages.ts +0 -211
  135. package/src/lib/index.ts +0 -52
  136. package/src/lib/integrations/index.ts +0 -6
  137. package/src/lib/integrations/nest/index.ts +0 -21
  138. package/src/lib/integrations/nextjs/app-router.ts +0 -47
  139. package/src/lib/integrations/nextjs/pages-router.ts +0 -45
  140. package/src/lib/integrations/node-express/index.ts +0 -21
  141. package/src/lib/integrations/node-http/__tests__/request-duck-type.test.ts +0 -66
  142. package/src/lib/integrations/node-http/index.ts +0 -187
  143. package/src/lib/integrations/node-http/request-handler.ts +0 -128
  144. package/src/lib/integrations/shared.ts +0 -112
  145. package/src/lib/logger.ts +0 -31
  146. package/src/lib/observability.ts +0 -167
  147. package/src/lib/runtime/__tests__/copilot-runtime-error.test.ts +0 -183
  148. package/src/lib/runtime/__tests__/handle-service-adapter.test.ts +0 -108
  149. package/src/lib/runtime/__tests__/mcp-tools-utils.test.ts +0 -499
  150. package/src/lib/runtime/__tests__/on-after-request.test.ts +0 -122
  151. package/src/lib/runtime/__tests__/retry-utils.test.ts +0 -137
  152. package/src/lib/runtime/__tests__/v1-agent-factory.test.ts +0 -109
  153. package/src/lib/runtime/agent-integrations/langgraph/__tests__/dispatch-event-filtering.test.ts +0 -345
  154. package/src/lib/runtime/agent-integrations/langgraph/__tests__/run-message-filtering.test.ts +0 -156
  155. package/src/lib/runtime/agent-integrations/langgraph/agent.ts +0 -263
  156. package/src/lib/runtime/agent-integrations/langgraph/consts.ts +0 -37
  157. package/src/lib/runtime/agent-integrations/langgraph/index.ts +0 -2
  158. package/src/lib/runtime/copilot-runtime.ts +0 -863
  159. package/src/lib/runtime/mcp-tools-utils.ts +0 -313
  160. package/src/lib/runtime/retry-utils.ts +0 -141
  161. package/src/lib/runtime/telemetry-agent-runner.ts +0 -151
  162. package/src/lib/runtime/types.ts +0 -48
  163. package/src/lib/runtime/utils.ts +0 -93
  164. package/src/lib/streaming.ts +0 -220
  165. package/src/lib/telemetry-client.ts +0 -66
  166. package/src/lib/telemetry-disclosure.ts +0 -53
  167. package/src/service-adapters/anthropic/anthropic-adapter.ts +0 -532
  168. package/src/service-adapters/anthropic/utils.ts +0 -219
  169. package/src/service-adapters/bedrock/bedrock-adapter.ts +0 -73
  170. package/src/service-adapters/conversion.test.ts +0 -56
  171. package/src/service-adapters/conversion.ts +0 -69
  172. package/src/service-adapters/empty/empty-adapter.ts +0 -38
  173. package/src/service-adapters/events.ts +0 -337
  174. package/src/service-adapters/experimental/ollama/ollama-adapter.ts +0 -84
  175. package/src/service-adapters/google/google-genai-adapter.test.ts +0 -151
  176. package/src/service-adapters/google/google-genai-adapter.ts +0 -95
  177. package/src/service-adapters/groq/groq-adapter.ts +0 -229
  178. package/src/service-adapters/index.ts +0 -18
  179. package/src/service-adapters/langchain/langchain-adapter.ts +0 -113
  180. package/src/service-adapters/langchain/langserve.ts +0 -88
  181. package/src/service-adapters/langchain/types.ts +0 -20
  182. package/src/service-adapters/langchain/utils.ts +0 -330
  183. package/src/service-adapters/openai/__tests__/openai-v5-compat.test.ts +0 -177
  184. package/src/service-adapters/openai/openai-adapter.ts +0 -324
  185. package/src/service-adapters/openai/openai-assistant-adapter.ts +0 -385
  186. package/src/service-adapters/openai/utils.ts +0 -305
  187. package/src/service-adapters/service-adapter.ts +0 -50
  188. package/src/service-adapters/shared/error-utils.ts +0 -64
  189. package/src/service-adapters/shared/index.ts +0 -2
  190. package/src/service-adapters/shared/sdk-client-utils.ts +0 -19
  191. package/src/service-adapters/unify/unify-adapter.ts +0 -165
  192. package/src/utils/failed-response-status-reasons.ts +0 -70
  193. package/src/utils/index.ts +0 -1
  194. package/src/v2/express.ts +0 -1
  195. package/src/v2/hono.ts +0 -1
  196. package/src/v2/index.ts +0 -5
  197. package/src/v2/node.ts +0 -1
  198. package/src/v2/runtime/__tests__/agents-factory.test.ts +0 -136
  199. package/src/v2/runtime/__tests__/backward-compat.test.ts +0 -261
  200. package/src/v2/runtime/__tests__/code-review-fixes.test.ts +0 -500
  201. package/src/v2/runtime/__tests__/cors-credentials.test.ts +0 -320
  202. package/src/v2/runtime/__tests__/debug-sse-response.test.ts +0 -302
  203. package/src/v2/runtime/__tests__/express-adapter.test.ts +0 -188
  204. package/src/v2/runtime/__tests__/express-body-order.test.ts +0 -76
  205. package/src/v2/runtime/__tests__/express-fetch-bridge.test.ts +0 -344
  206. package/src/v2/runtime/__tests__/express-single-sse.test.ts +0 -122
  207. package/src/v2/runtime/__tests__/express-single-telemetry.integration.test.ts +0 -65
  208. package/src/v2/runtime/__tests__/express-telemetry.integration.test.ts +0 -101
  209. package/src/v2/runtime/__tests__/fetch-cors.test.ts +0 -205
  210. package/src/v2/runtime/__tests__/fetch-handler-validation.test.ts +0 -440
  211. package/src/v2/runtime/__tests__/fetch-handler.test.ts +0 -456
  212. package/src/v2/runtime/__tests__/fetch-router.test.ts +0 -276
  213. package/src/v2/runtime/__tests__/get-runtime-info.test.ts +0 -335
  214. package/src/v2/runtime/__tests__/handle-connect.test.ts +0 -585
  215. package/src/v2/runtime/__tests__/handle-run.test.ts +0 -1388
  216. package/src/v2/runtime/__tests__/handle-threads.test.ts +0 -930
  217. package/src/v2/runtime/__tests__/handle-transcribe.test.ts +0 -301
  218. package/src/v2/runtime/__tests__/header-utils.test.ts +0 -88
  219. package/src/v2/runtime/__tests__/hono-adapter.test.ts +0 -150
  220. package/src/v2/runtime/__tests__/hono-single-telemetry.integration.test.ts +0 -46
  221. package/src/v2/runtime/__tests__/hono-telemetry.integration.test.ts +0 -99
  222. package/src/v2/runtime/__tests__/hooks-edge-cases.test.ts +0 -457
  223. package/src/v2/runtime/__tests__/hooks.test.ts +0 -557
  224. package/src/v2/runtime/__tests__/in-process-agent-runner-messages.test.ts +0 -230
  225. package/src/v2/runtime/__tests__/in-process-agent-runner.test.ts +0 -1030
  226. package/src/v2/runtime/__tests__/integration/bun/bun-servers.integration.test.ts +0 -27
  227. package/src/v2/runtime/__tests__/integration/bun/elysia-multi.ts +0 -32
  228. package/src/v2/runtime/__tests__/integration/bun/elysia-single.ts +0 -33
  229. package/src/v2/runtime/__tests__/integration/bun/hono-bun-multi.ts +0 -25
  230. package/src/v2/runtime/__tests__/integration/bun/hono-bun-single.ts +0 -32
  231. package/src/v2/runtime/__tests__/integration/helpers/create-test-runtime.ts +0 -15
  232. package/src/v2/runtime/__tests__/integration/helpers/sse-reader.ts +0 -45
  233. package/src/v2/runtime/__tests__/integration/helpers/test-agent.ts +0 -58
  234. package/src/v2/runtime/__tests__/integration/node-servers.integration.test.ts +0 -58
  235. package/src/v2/runtime/__tests__/integration/servers/express-multi.ts +0 -35
  236. package/src/v2/runtime/__tests__/integration/servers/express-single.ts +0 -36
  237. package/src/v2/runtime/__tests__/integration/servers/fetch-direct.ts +0 -39
  238. package/src/v2/runtime/__tests__/integration/servers/hono-multi.ts +0 -30
  239. package/src/v2/runtime/__tests__/integration/servers/hono-single.ts +0 -37
  240. package/src/v2/runtime/__tests__/integration/servers/node-multi.ts +0 -45
  241. package/src/v2/runtime/__tests__/integration/servers/node-single.ts +0 -46
  242. package/src/v2/runtime/__tests__/integration/servers/types.ts +0 -18
  243. package/src/v2/runtime/__tests__/integration/suites/debug-events.suite.ts +0 -253
  244. package/src/v2/runtime/__tests__/integration/suites/multi-endpoint.suite.ts +0 -358
  245. package/src/v2/runtime/__tests__/integration/suites/single-endpoint.suite.ts +0 -363
  246. package/src/v2/runtime/__tests__/intelligence-run-telemetry.test.ts +0 -194
  247. package/src/v2/runtime/__tests__/mcp-apps-middleware-integration.test.ts +0 -275
  248. package/src/v2/runtime/__tests__/middleware-express.test.ts +0 -208
  249. package/src/v2/runtime/__tests__/middleware-single-express.test.ts +0 -213
  250. package/src/v2/runtime/__tests__/middleware-single.test.ts +0 -225
  251. package/src/v2/runtime/__tests__/middleware-sse-parser.test.ts +0 -237
  252. package/src/v2/runtime/__tests__/middleware.test.ts +0 -250
  253. package/src/v2/runtime/__tests__/node-fetch-handler.test.ts +0 -157
  254. package/src/v2/runtime/__tests__/open-generative-ui-middleware.e2e.test.ts +0 -728
  255. package/src/v2/runtime/__tests__/router-edge-cases.test.ts +0 -217
  256. package/src/v2/runtime/__tests__/routing-express.test.ts +0 -174
  257. package/src/v2/runtime/__tests__/routing-single-express.test.ts +0 -168
  258. package/src/v2/runtime/__tests__/routing-single.test.ts +0 -193
  259. package/src/v2/runtime/__tests__/routing.test.ts +0 -257
  260. package/src/v2/runtime/__tests__/runtime.test.ts +0 -234
  261. package/src/v2/runtime/__tests__/sse-response-telemetry.test.ts +0 -108
  262. package/src/v2/runtime/__tests__/telemetry.test.ts +0 -167
  263. package/src/v2/runtime/__tests__/thread-names.test.ts +0 -188
  264. package/src/v2/runtime/core/__tests__/debug-event-bus.test.ts +0 -156
  265. package/src/v2/runtime/core/debug-event-bus.ts +0 -45
  266. package/src/v2/runtime/core/fetch-cors.ts +0 -136
  267. package/src/v2/runtime/core/fetch-handler.ts +0 -492
  268. package/src/v2/runtime/core/fetch-router.ts +0 -203
  269. package/src/v2/runtime/core/hooks.ts +0 -160
  270. package/src/v2/runtime/core/middleware-sse-parser.ts +0 -210
  271. package/src/v2/runtime/core/middleware.ts +0 -115
  272. package/src/v2/runtime/core/runtime.ts +0 -432
  273. package/src/v2/runtime/endpoints/express-fetch-bridge.ts +0 -137
  274. package/src/v2/runtime/endpoints/express-single.ts +0 -54
  275. package/src/v2/runtime/endpoints/express.ts +0 -179
  276. package/src/v2/runtime/endpoints/hono-single.ts +0 -60
  277. package/src/v2/runtime/endpoints/hono.ts +0 -89
  278. package/src/v2/runtime/endpoints/index.ts +0 -4
  279. package/src/v2/runtime/endpoints/node-fetch-handler.ts +0 -48
  280. package/src/v2/runtime/endpoints/node.ts +0 -28
  281. package/src/v2/runtime/endpoints/single-route-helpers.ts +0 -125
  282. package/src/v2/runtime/express.ts +0 -2
  283. package/src/v2/runtime/handlers/__tests__/handle-debug-events.test.ts +0 -176
  284. package/src/v2/runtime/handlers/get-runtime-info.ts +0 -101
  285. package/src/v2/runtime/handlers/handle-connect.ts +0 -80
  286. package/src/v2/runtime/handlers/handle-debug-events.ts +0 -52
  287. package/src/v2/runtime/handlers/handle-run.ts +0 -111
  288. package/src/v2/runtime/handlers/handle-stop.ts +0 -77
  289. package/src/v2/runtime/handlers/handle-threads.ts +0 -11
  290. package/src/v2/runtime/handlers/handle-transcribe.ts +0 -269
  291. package/src/v2/runtime/handlers/header-utils.ts +0 -24
  292. package/src/v2/runtime/handlers/intelligence/connect.ts +0 -102
  293. package/src/v2/runtime/handlers/intelligence/run.ts +0 -351
  294. package/src/v2/runtime/handlers/intelligence/thread-names.ts +0 -246
  295. package/src/v2/runtime/handlers/intelligence/threads.ts +0 -420
  296. package/src/v2/runtime/handlers/shared/agent-utils.ts +0 -154
  297. package/src/v2/runtime/handlers/shared/intelligence-utils.ts +0 -41
  298. package/src/v2/runtime/handlers/shared/json-response.ts +0 -9
  299. package/src/v2/runtime/handlers/shared/resolve-intelligence-user.ts +0 -28
  300. package/src/v2/runtime/handlers/shared/sse-response.ts +0 -215
  301. package/src/v2/runtime/handlers/sse/__tests__/sse-connect-agent-id.test.ts +0 -71
  302. package/src/v2/runtime/handlers/sse/connect.ts +0 -30
  303. package/src/v2/runtime/handlers/sse/run.ts +0 -40
  304. package/src/v2/runtime/hono.ts +0 -2
  305. package/src/v2/runtime/index.ts +0 -51
  306. package/src/v2/runtime/intelligence-platform/__tests__/client.test.ts +0 -601
  307. package/src/v2/runtime/intelligence-platform/__tests__/intelligence-mcp-helper.test.ts +0 -246
  308. package/src/v2/runtime/intelligence-platform/client.ts +0 -818
  309. package/src/v2/runtime/intelligence-platform/index.ts +0 -10
  310. package/src/v2/runtime/node.ts +0 -6
  311. package/src/v2/runtime/open-generative-ui-middleware.ts +0 -373
  312. package/src/v2/runtime/runner/__tests__/finalize-events.test.ts +0 -109
  313. package/src/v2/runtime/runner/__tests__/in-memory-runner.e2e.test.ts +0 -775
  314. package/src/v2/runtime/runner/__tests__/in-memory-runner.test.ts +0 -777
  315. package/src/v2/runtime/runner/__tests__/intelligence-runner.test.ts +0 -1039
  316. package/src/v2/runtime/runner/agent-runner.ts +0 -35
  317. package/src/v2/runtime/runner/in-memory.ts +0 -467
  318. package/src/v2/runtime/runner/index.ts +0 -4
  319. package/src/v2/runtime/runner/intelligence.ts +0 -498
  320. package/src/v2/runtime/telemetry/__tests__/instance-created.test.ts +0 -96
  321. package/src/v2/runtime/telemetry/events.ts +0 -35
  322. package/src/v2/runtime/telemetry/index.ts +0 -7
  323. package/src/v2/runtime/telemetry/instance-created.ts +0 -44
  324. package/src/v2/runtime/telemetry/scarf-client.ts +0 -39
  325. package/src/v2/runtime/telemetry/telemetry-client.ts +0 -70
  326. package/src/v2/runtime/transcription-service/transcription-service.ts +0 -11
  327. package/tests/global.d.ts +0 -1
  328. package/tests/service-adapters/anthropic/allowlist-approach.test.ts +0 -259
  329. package/tests/service-adapters/anthropic/anthropic-adapter-language-model.test.ts +0 -101
  330. package/tests/service-adapters/anthropic/anthropic-adapter.test.ts +0 -645
  331. package/tests/service-adapters/anthropic/utils-token-trimming.test.ts +0 -301
  332. package/tests/service-adapters/groq/groq-adapter-language-model.test.ts +0 -102
  333. package/tests/service-adapters/openai/allowlist-approach.test.ts +0 -294
  334. package/tests/service-adapters/openai/openai-adapter-language-model.test.ts +0 -122
  335. package/tests/service-adapters/openai/openai-adapter.test.ts +0 -291
  336. package/tests/service-adapters/shared/sdk-client-utils.test.ts +0 -36
  337. package/tests/setup.vitest.ts +0 -8
  338. package/tests/tsconfig.json +0 -10
  339. package/tsconfig.json +0 -20
  340. package/tsdown.config.ts +0 -45
  341. package/typedoc.json +0 -4
  342. 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