@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
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@copilotkit/runtime",
3
- "version": "1.57.3",
3
+ "version": "1.58.0-canary.thread-id-propagation",
4
4
  "private": false,
5
5
  "keywords": [
6
6
  "ai",
@@ -12,6 +12,7 @@
12
12
  "nextjs",
13
13
  "nodejs",
14
14
  "react",
15
+ "tanstack-intent",
15
16
  "textarea"
16
17
  ],
17
18
  "homepage": "https://github.com/CopilotKit/CopilotKit",
@@ -20,6 +21,10 @@
20
21
  "type": "git",
21
22
  "url": "https://github.com/CopilotKit/CopilotKit.git"
22
23
  },
24
+ "files": [
25
+ "dist",
26
+ "skills"
27
+ ],
23
28
  "sideEffects": [
24
29
  "./dist/index.mjs",
25
30
  "./dist/index.cjs",
@@ -29,22 +34,6 @@
29
34
  "main": "./dist/index.cjs",
30
35
  "module": "./dist/index.mjs",
31
36
  "types": "./dist/index.d.cts",
32
- "typesVersions": {
33
- "*": {
34
- "v2": [
35
- "./dist/v2/index.d.cts"
36
- ],
37
- "v2/express": [
38
- "./dist/v2/express.d.cts"
39
- ],
40
- "v2/hono": [
41
- "./dist/v2/hono.d.cts"
42
- ],
43
- "v2/node": [
44
- "./dist/v2/node.d.cts"
45
- ]
46
- }
47
- },
48
37
  "exports": {
49
38
  ".": {
50
39
  "import": "./dist/index.mjs",
@@ -80,7 +69,7 @@
80
69
  "@ag-ui/client": "0.0.53",
81
70
  "@ag-ui/core": "0.0.53",
82
71
  "@ag-ui/encoder": "0.0.53",
83
- "@ag-ui/langgraph": "0.0.31",
72
+ "@ag-ui/langgraph": "0.0.34",
84
73
  "@ag-ui/mcp-apps-middleware": "0.0.3",
85
74
  "@ai-sdk/anthropic": "^3.0.49",
86
75
  "@ai-sdk/google": "^3.0.33",
@@ -115,11 +104,12 @@
115
104
  "uuid": "^10.0.0",
116
105
  "ws": "^8.18.0",
117
106
  "zod": "^3.23.3",
118
- "@copilotkit/shared": "1.57.3"
107
+ "@copilotkit/shared": "1.58.0-canary.thread-id-propagation"
119
108
  },
120
109
  "devDependencies": {
121
110
  "@copilotkit/aimock": "latest",
122
111
  "@swc/core": "1.5.28",
112
+ "@tanstack/intent": "^0.0.29",
123
113
  "@types/cors": "^2.8.17",
124
114
  "@types/express": "^4.17.21",
125
115
  "@types/node": "^18.11.17",
@@ -0,0 +1,98 @@
1
+ ---
2
+ name: runtime
3
+ description: >
4
+ @copilotkit/runtime — mount a fetch-native CopilotRuntime on any JS server, wire
5
+ middleware, pick an AgentRunner, instantiate BuiltInAgent (Factory Mode with TanStack AI
6
+ is the preferred default) or plug in any of 12 external agent frameworks (Mastra,
7
+ LangGraph, CrewAI Crews/Flows, PydanticAI, ADK, LlamaIndex, Agno, AWS Strands, MS Agent
8
+ Framework, AG2, A2A), enable Intelligence mode for durable threads + websocket,
9
+ register server-side tools via defineTool, and wire voice transcription. Uses the
10
+ fetch-based createCopilotRuntimeHandler primitive — the Express/Hono adapters are
11
+ discouraged. Load the reference under references/ that matches your task.
12
+ type: core
13
+ library: copilotkit
14
+ library_version: "1.56.2"
15
+ requires: []
16
+ sources:
17
+ - "CopilotKit/CopilotKit:packages/runtime/src/v2/runtime/core/fetch-handler.ts"
18
+ - "CopilotKit/CopilotKit:packages/runtime/src/v2/runtime/core/runtime.ts"
19
+ - "CopilotKit/CopilotKit:packages/runtime/src/v2/runtime/core/hooks.ts"
20
+ - "CopilotKit/CopilotKit:packages/runtime/src/v2/runtime/core/middleware.ts"
21
+ - "CopilotKit/CopilotKit:packages/runtime/src/v2/runtime/runner/agent-runner.ts"
22
+ - "CopilotKit/CopilotKit:packages/runtime/src/v2/runtime/runner/in-memory.ts"
23
+ - "CopilotKit/CopilotKit:packages/runtime/src/v2/runtime/runner/intelligence.ts"
24
+ - "CopilotKit/CopilotKit:packages/runtime/src/v2/runtime/intelligence-platform/client.ts"
25
+ - "CopilotKit/CopilotKit:packages/runtime/src/v2/runtime/transcription-service/transcription-service.ts"
26
+ - "CopilotKit/CopilotKit:packages/runtime/src/v2/runtime/handlers/handle-transcribe.ts"
27
+ - "CopilotKit/CopilotKit:packages/runtime/src/agent/index.ts"
28
+ - "CopilotKit/CopilotKit:packages/runtime/src/agent/converters/tanstack.ts"
29
+ - "CopilotKit/CopilotKit:packages/sqlite-runner/src/sqlite-runner.ts"
30
+ - "CopilotKit/CopilotKit:packages/shared/src/transcription-errors.ts"
31
+ ---
32
+
33
+ # CopilotKit Runtime
34
+
35
+ `@copilotkit/runtime` is the server half of CopilotKit: it accepts AG-UI protocol
36
+ requests, dispatches them to an `AbstractAgent` (built-in or external), runs the
37
+ stream through an `AgentRunner`, and responds as Server-Sent Events.
38
+
39
+ This SKILL.md is the **index**. Read the reference under `references/` that matches
40
+ your task — do not try to absorb the whole package from this file.
41
+
42
+ ## Mental Model — the three dictionaries you hand to `CopilotRuntime`
43
+
44
+ ```ts
45
+ new CopilotRuntime({
46
+ agents, // Record<string, AbstractAgent> — see wiring-external-agents or built-in-agent
47
+ runner, // AgentRunner (optional) — see agent-runners
48
+ intelligence, // CopilotKitIntelligence (optional) — see intelligence-mode (auto-wires runner)
49
+ mcpApps, // McpAppsConfig (optional) — see wiring-mcp-apps-middleware
50
+ a2ui, // A2UIConfig (optional) — see packages/a2ui-renderer skill
51
+ hooks, // { onRequest, onBeforeHandler } — see middleware
52
+ beforeRequestMiddleware,
53
+ afterRequestMiddleware, // legacy — see middleware
54
+ transcription, // TranscriptionService (optional) — see transcription
55
+ });
56
+ ```
57
+
58
+ You then mount it:
59
+
60
+ ```ts
61
+ import { createCopilotRuntimeHandler } from "@copilotkit/runtime/v2";
62
+ const handler = createCopilotRuntimeHandler({
63
+ runtime,
64
+ basePath: "/api/copilotkit",
65
+ });
66
+ export default { fetch: handler };
67
+ ```
68
+
69
+ ## When to load which reference
70
+
71
+ | Task | Reference |
72
+ | ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------ | -------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
73
+ | Mounting on any fetch-native server (Cloudflare Workers, Bun, Deno, Vercel Edge, Next.js App Router, React Router v7, TanStack Start) or delegating from Express/Node | `references/setup-endpoint.md` |
74
+ | Auth / logging / rate-limit / request-scoped guards via `hooks.onRequest` / `hooks.onBeforeHandler` (preferred) or legacy `beforeRequestMiddleware` / `afterRequestMiddleware` | `references/middleware.md` |
75
+ | Choosing between `InMemoryAgentRunner`, `SqliteAgentRunner`, or a custom subclass — including thread-locking semantics and the runner/Intelligence mutual exclusion | `references/agent-runners.md` (+ `-in-memory.md`, `-sqlite.md`, `-custom.md` for backend-specific detail) |
76
+ | Enabling durable threads + realtime websocket via CopilotKit Cloud (Intelligence is **Cloud-only**, not self-hostable) | `references/intelligence-mode.md` |
77
+ | Voice transcription — implementing a `TranscriptionService` subclass for the `/transcribe` endpoint | `references/transcription.md` |
78
+ | Instantiating `BuiltInAgent` — Simple Mode (classic) or Factory Mode with TanStack AI (preferred AG-UI-compliant default), AI SDK, or custom factory | `references/built-in-agent.md` (+ `-factory-modes.md`, `-helper-utilities.md`, `-model-identifiers.md`) |
79
+ | Defining server-side tools via `defineTool` for `BuiltInAgent.config.tools` (Simple Mode only) | `references/server-side-tools.md` |
80
+ | Wiring an external agent framework into `CopilotRuntime({ agents })` | `references/wiring-external-agents.md` (index) + per-framework refs (`wiring-mastra.md`, `wiring-langgraph.md`, `wiring-crewai-crews.md`, `wiring-crewai-flows.md`, `wiring-pydantic-ai.md`, `wiring-adk.md`, `wiring-llamaindex.md`, `wiring-agno.md`, `wiring-aws-strands.md`, `wiring-ms-agent-framework.md`, `wiring-ag2.md`, `wiring-a2a.md`) |
81
+ | Wiring MCP Apps (runtime-level middleware, not an agent) | `references/wiring-mcp-apps-middleware.md` |
82
+
83
+ ## Invariants and gotchas (load-once, before any reference)
84
+
85
+ - `createCopilotRuntimeHandler` is the canonical primitive. `createCopilotExpressHandler` / `createCopilotHonoHandler` exist but are **avoid at all costs** — delegate from Express/Hono routes to the fetch primitive instead.
86
+ - `publicLicenseKey` is the canonical provider-side field. `publicApiKey` is a **deprecated alias** — expect to see it in legacy code, emit the canonical name in new code.
87
+ - Intelligence mode auto-wires `IntelligenceAgentRunner`. Passing both `runner` and `intelligence` to `CopilotRuntime` is rejected at construction.
88
+ - Intelligence mode targets CopilotKit Cloud (`api.cloud.copilotkit.ai`) and is **not self-hostable**.
89
+ - `hooks.onRequest` runs **before** `beforeRequestMiddleware` (hook-based middleware wins for Response short-circuits). `beforeRequestMiddleware` runs **after** `hooks.onRequest` (see `fetch-handler.ts:136-147`).
90
+ - `identifyUser` (Intelligence) does **not** forward thrown `Response` objects — convert to 500. Gate auth rejection in `hooks.onRequest`, which does forward Responses.
91
+ - `agents__unsafe_dev_only` and `selfManagedAgents` are dev-only aliases of each other; do not reach for them in production. Either signals that the SPA is in dev mode.
92
+
93
+ ## Reading order for a first-time reader
94
+
95
+ 1. `setup-endpoint` — the primitive.
96
+ 2. `built-in-agent` **or** pick one from `wiring-external-agents` — the agent.
97
+ 3. `agent-runners` — production persistence choice.
98
+ 4. Optional: `middleware`, `intelligence-mode`, `server-side-tools`, `transcription`.
@@ -0,0 +1,161 @@
1
+ Custom AgentRunner — subclass the abstract `AgentRunner` to back thread state with Redis,
2
+ Postgres, Durable Objects, or anything else you own.
3
+
4
+ ## The abstract contract
5
+
6
+ ```typescript
7
+ // packages/runtime/src/v2/runtime/runner/agent-runner.ts
8
+ import {
9
+ AbstractAgent,
10
+ BaseEvent,
11
+ Message,
12
+ RunAgentInput,
13
+ } from "@ag-ui/client";
14
+ import { Observable } from "rxjs";
15
+
16
+ export interface AgentRunnerRunRequest {
17
+ threadId: string;
18
+ agent: AbstractAgent;
19
+ input: RunAgentInput;
20
+ joinCode?: string;
21
+ persistedInputMessages?: Message[];
22
+ }
23
+ export interface AgentRunnerConnectRequest {
24
+ threadId: string;
25
+ headers?: Record<string, string>;
26
+ joinCode?: string;
27
+ }
28
+ export interface AgentRunnerIsRunningRequest {
29
+ threadId: string;
30
+ }
31
+ export interface AgentRunnerStopRequest {
32
+ threadId: string;
33
+ }
34
+
35
+ export abstract class AgentRunner {
36
+ abstract run(request: AgentRunnerRunRequest): Observable<BaseEvent>;
37
+ abstract connect(request: AgentRunnerConnectRequest): Observable<BaseEvent>;
38
+ abstract isRunning(request: AgentRunnerIsRunningRequest): Promise<boolean>;
39
+ abstract stop(request: AgentRunnerStopRequest): Promise<boolean | undefined>;
40
+ }
41
+ ```
42
+
43
+ ## Redis-backed skeleton (for reference)
44
+
45
+ ```typescript
46
+ import { AgentRunner } from "@copilotkit/runtime/v2";
47
+ import type {
48
+ AgentRunnerRunRequest,
49
+ AgentRunnerConnectRequest,
50
+ AgentRunnerIsRunningRequest,
51
+ AgentRunnerStopRequest,
52
+ } from "@copilotkit/runtime/v2";
53
+ import { Observable, ReplaySubject } from "rxjs";
54
+ import type { BaseEvent } from "@ag-ui/client";
55
+ import { Redis } from "ioredis";
56
+
57
+ const RUNNING_KEY = (t: string) => `copilotkit:running:${t}`;
58
+ const STREAM_KEY = (t: string) => `copilotkit:stream:${t}`;
59
+
60
+ export class RedisAgentRunner extends AgentRunner {
61
+ constructor(private redis: Redis) {
62
+ super();
63
+ }
64
+
65
+ run(request: AgentRunnerRunRequest): Observable<BaseEvent> {
66
+ const { threadId, agent, input } = request;
67
+ const subject = new ReplaySubject<BaseEvent>();
68
+
69
+ (async () => {
70
+ // NX guard — return 409-equivalent if another instance is running this thread
71
+ const acquired = await this.redis.set(
72
+ RUNNING_KEY(threadId),
73
+ "1",
74
+ "EX",
75
+ 600,
76
+ "NX",
77
+ );
78
+ if (!acquired) {
79
+ subject.error(new Error("Thread already running"));
80
+ return;
81
+ }
82
+
83
+ const sub = agent.run(input).subscribe({
84
+ next: async (event) => {
85
+ subject.next(event);
86
+ await this.redis.xadd(
87
+ STREAM_KEY(threadId),
88
+ "*",
89
+ "event",
90
+ JSON.stringify(event),
91
+ );
92
+ },
93
+ error: async (err) => {
94
+ subject.error(err);
95
+ await this.redis.del(RUNNING_KEY(threadId));
96
+ },
97
+ complete: async () => {
98
+ subject.complete();
99
+ await this.redis.del(RUNNING_KEY(threadId));
100
+ },
101
+ });
102
+
103
+ // stop hook
104
+ this.stopHandlers.set(threadId, () => sub.unsubscribe());
105
+ })();
106
+
107
+ return subject.asObservable();
108
+ }
109
+
110
+ connect(request: AgentRunnerConnectRequest): Observable<BaseEvent> {
111
+ const subject = new ReplaySubject<BaseEvent>();
112
+ (async () => {
113
+ const entries = await this.redis.xrange(
114
+ STREAM_KEY(request.threadId),
115
+ "-",
116
+ "+",
117
+ );
118
+ for (const [, fields] of entries) {
119
+ const eventStr = fields[1];
120
+ if (eventStr) subject.next(JSON.parse(eventStr));
121
+ }
122
+ subject.complete();
123
+ })();
124
+ return subject.asObservable();
125
+ }
126
+
127
+ async isRunning(request: AgentRunnerIsRunningRequest): Promise<boolean> {
128
+ return (await this.redis.exists(RUNNING_KEY(request.threadId))) === 1;
129
+ }
130
+
131
+ async stop(request: AgentRunnerStopRequest): Promise<boolean | undefined> {
132
+ const stop = this.stopHandlers.get(request.threadId);
133
+ if (stop) {
134
+ stop();
135
+ this.stopHandlers.delete(request.threadId);
136
+ }
137
+ await this.redis.del(RUNNING_KEY(request.threadId));
138
+ return true;
139
+ }
140
+
141
+ private stopHandlers = new Map<string, () => void>();
142
+ }
143
+ ```
144
+
145
+ ## Contract gotchas
146
+
147
+ - `run()` must throw `Error("Thread already running")` (or let a distributed lock return a
148
+ non-acquired state) when a run is already active. Intelligence mode surfaces the 409 to
149
+ the client as the typed `agent_thread_locked` error code; SSE mode (direct runner use)
150
+ only emits a generic 500 response with the error message — so clients cannot depend on
151
+ the typed code there, and should additionally guard with a busy flag on submit.
152
+ - `connect()` must replay historic events so late clients can catch up on an active run.
153
+ - `stop()` is optional to implement in the sense that returning `undefined` is allowed, but
154
+ surface cancellations through `abortController.abort()` to the underlying agent if you can.
155
+ - The runner does not persist user messages on its own — that is the Intelligence platform's
156
+ job. A custom runner that persists only its own event stream is still a drop-in replacement
157
+ for `InMemoryAgentRunner` / `SqliteAgentRunner`.
158
+
159
+ Source: `packages/runtime/src/v2/runtime/runner/agent-runner.ts`,
160
+ `packages/runtime/src/v2/runtime/runner/in-memory.ts`,
161
+ `packages/sqlite-runner/src/sqlite-runner.ts`.
@@ -0,0 +1,64 @@
1
+ InMemoryAgentRunner — default ephemeral runner. Keyed on a `globalThis` Symbol so thread state survives hot-module reloads during development.
2
+
3
+ ## Store layout
4
+
5
+ ```typescript
6
+ // packages/runtime/src/v2/runtime/runner/in-memory.ts
7
+ const GLOBAL_STORE_KEY = Symbol.for("@copilotkit/runtime/in-memory-store");
8
+
9
+ interface GlobalStoreData {
10
+ stores: Map<string, InMemoryEventStore>; // per-threadId
11
+ historicRunsBackup: Map<string, HistoricRun[]>; // restored after HMR
12
+ }
13
+ ```
14
+
15
+ One `InMemoryEventStore` per `threadId`. Each store tracks:
16
+
17
+ - `subject: ReplaySubject<BaseEvent> | null` — current consumers
18
+ - `isRunning: boolean` — gate for the `"Thread already running"` throw
19
+ - `currentRunId: string | null`
20
+ - `historicRuns: HistoricRun[]` — completed runs (backed up across HMR)
21
+ - `agent: AbstractAgent | null` — the instance that owns the active run
22
+ - `runSubject`, `currentEvents`, `stopRequested`
23
+
24
+ ## Lifecycle
25
+
26
+ 1. `run({ threadId, agent, input })` — if `store.isRunning` throw `Error("Thread already running")`. Otherwise create a `ReplaySubject`, subscribe to `agent.run(input)`, push events into the subject, track them in `currentEvents`, mark the store `isRunning`.
27
+ 2. On `RunFinishedEvent` / `RunErrorEvent`: finalize the run, push its events into `historicRuns`, clear `isRunning`, `currentRunId`, `agent`.
28
+ 3. `connect({ threadId })` — returns a `ReplaySubject` that replays the active run events or (if no active run) the most recent historic run.
29
+ 4. `stop({ threadId })` — sets `stopRequested = true`; the active subscription checks the flag on each event and tears down.
30
+
31
+ ## Hot reload (development)
32
+
33
+ In dev, bundlers replace modules. `GLOBAL_STORE_KEY` uses `Symbol.for(...)` so the same well-known symbol is reused across module instances — `globalThis[KEY]` survives. On module re-evaluation, if the `stores` map is empty but `historicRunsBackup` still has entries, the runner rehydrates historic-only stores from the backup (active runs are lost, historic runs come back).
34
+
35
+ ## When NOT to use
36
+
37
+ - Multi-instance production deploys — each process has its own store.
38
+ - Long-lived servers — restart wipes active threads (historic runs are only preserved in the HMR-dev backup, not across process exit).
39
+ - Load-balanced serverless with cold starts — new workers see empty stores.
40
+
41
+ ## When it is OK
42
+
43
+ - Local development.
44
+ - Single-instance preview environments.
45
+ - Tests (each `new InMemoryAgentRunner()` still shares the globalThis store — pass a fresh threadId per test, or clear the captured store in place between tests). Do NOT `delete globalThis[Symbol.for("@copilotkit/runtime/in-memory-store")]`: `in-memory.ts:98` captures `GLOBAL_STORE = getGlobalStore()` as a module-level const referencing the inner `stores` Map, so replacing `globalThis[KEY]` creates a new object that the module no longer consults. Mutate the existing maps in place:
46
+
47
+ ```ts
48
+ // test setup
49
+ const storeKey = Symbol.for("@copilotkit/runtime/in-memory-store");
50
+ const data = (globalThis as any)[storeKey] as
51
+ | {
52
+ stores: Map<string, unknown>;
53
+ historicRunsBackup: Map<string, unknown>;
54
+ }
55
+ | undefined;
56
+ if (data) {
57
+ data.stores.clear();
58
+ data.historicRunsBackup.clear();
59
+ }
60
+ ```
61
+
62
+ The runtime does not yet expose an official reset helper — a `__TEST_ONLY_clearGlobalStore` export would be a reasonable follow-up.
63
+
64
+ Source: `packages/runtime/src/v2/runtime/runner/in-memory.ts`.
@@ -0,0 +1,90 @@
1
+ SqliteAgentRunner — file-backed agent runner in `@copilotkit/sqlite-runner`. Uses `better-sqlite3` as a required peer dep.
2
+
3
+ ## Install
4
+
5
+ ```bash
6
+ pnpm add @copilotkit/sqlite-runner better-sqlite3
7
+ ```
8
+
9
+ If `better-sqlite3` is missing, the `import` of `@copilotkit/sqlite-runner` itself fails
10
+ at module load (`Cannot find module 'better-sqlite3'`). The runner's constructor has a
11
+ friendlier multi-line install hint as a fallback, but you will see the bare resolution
12
+ error first — install the peer before the runner import resolves.
13
+
14
+ ## Configure
15
+
16
+ ```typescript
17
+ import { CopilotRuntime } from "@copilotkit/runtime/v2";
18
+ import { SqliteAgentRunner } from "@copilotkit/sqlite-runner";
19
+
20
+ const runtime = new CopilotRuntime({
21
+ agents: {
22
+ /* ... */
23
+ } as any,
24
+ runner: new SqliteAgentRunner({
25
+ dbPath: "./data/threads.db", // REQUIRED — default is ":memory:"
26
+ }),
27
+ });
28
+ ```
29
+
30
+ `dbPath: ":memory:"` is the default if omitted — that reverts to an in-memory store and
31
+ loses data at restart. Always set a file path in production.
32
+
33
+ ## Schema
34
+
35
+ Three tables are created on first use (`packages/sqlite-runner/src/sqlite-runner.ts:75-109`):
36
+
37
+ ```sql
38
+ CREATE TABLE IF NOT EXISTS agent_runs (
39
+ id INTEGER PRIMARY KEY AUTOINCREMENT,
40
+ thread_id TEXT NOT NULL,
41
+ run_id TEXT NOT NULL UNIQUE,
42
+ parent_run_id TEXT,
43
+ events TEXT NOT NULL, -- JSON-encoded BaseEvent[]
44
+ input TEXT NOT NULL, -- JSON-encoded RunAgentInput
45
+ created_at INTEGER NOT NULL,
46
+ version INTEGER NOT NULL
47
+ );
48
+ CREATE TABLE IF NOT EXISTS run_state (
49
+ thread_id TEXT PRIMARY KEY,
50
+ is_running INTEGER DEFAULT 0,
51
+ current_run_id TEXT,
52
+ updated_at INTEGER NOT NULL
53
+ );
54
+ CREATE TABLE IF NOT EXISTS schema_version (
55
+ version INTEGER PRIMARY KEY,
56
+ applied_at INTEGER NOT NULL
57
+ );
58
+ CREATE INDEX IF NOT EXISTS idx_thread_id ON agent_runs(thread_id);
59
+ CREATE INDEX IF NOT EXISTS idx_parent_run_id ON agent_runs(parent_run_id);
60
+ ```
61
+
62
+ `agent_runs` is append-only — one row per completed run, full event log in the `events`
63
+ column. `run_state` gates concurrent runs (the `"Thread already running"` check).
64
+ `schema_version` tracks applied migrations so future releases can upgrade existing
65
+ databases in place.
66
+
67
+ ## Retention
68
+
69
+ There is no automatic retention. If you need bounded history, add a periodic purge:
70
+
71
+ ```typescript
72
+ import Database from "better-sqlite3";
73
+
74
+ const db = new Database("./data/threads.db");
75
+ setInterval(
76
+ () => {
77
+ const cutoff = Date.now() - 30 * 24 * 60 * 60 * 1000; // 30 days
78
+ db.prepare("DELETE FROM agent_runs WHERE created_at < ?").run(cutoff);
79
+ },
80
+ 60 * 60 * 1000,
81
+ );
82
+ ```
83
+
84
+ ## When NOT to use
85
+
86
+ - Multi-instance deploys without shared storage — each instance would have its own DB file.
87
+ Either put the DB on a shared volume (EFS, persistent disk) with a single writer, or
88
+ choose Intelligence mode or a custom Redis/Postgres runner.
89
+
90
+ Source: `packages/sqlite-runner/src/sqlite-runner.ts`.