@copilotkit/runtime 1.54.1 → 1.55.0-next.8

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 (337) hide show
  1. package/.eslintrc.js +4 -4
  2. package/CHANGELOG.md +125 -113
  3. package/dist/_virtual/_rolldown/runtime.mjs +25 -1
  4. package/dist/agent/index.cjs +654 -0
  5. package/dist/agent/index.cjs.map +1 -0
  6. package/dist/agent/index.d.cts +263 -0
  7. package/dist/agent/index.d.cts.map +1 -0
  8. package/dist/agent/index.d.mts +263 -0
  9. package/dist/agent/index.d.mts.map +1 -0
  10. package/dist/agent/index.mjs +646 -0
  11. package/dist/agent/index.mjs.map +1 -0
  12. package/dist/graphql/message-conversion/agui-to-gql.cjs.map +1 -1
  13. package/dist/graphql/message-conversion/agui-to-gql.mjs.map +1 -1
  14. package/dist/lib/integrations/nextjs/app-router.cjs +2 -2
  15. package/dist/lib/integrations/nextjs/app-router.cjs.map +1 -1
  16. package/dist/lib/integrations/nextjs/app-router.mjs +1 -1
  17. package/dist/lib/integrations/nextjs/app-router.mjs.map +1 -1
  18. package/dist/lib/integrations/node-http/index.cjs +2 -3
  19. package/dist/lib/integrations/node-http/index.cjs.map +1 -1
  20. package/dist/lib/integrations/node-http/index.mjs +1 -1
  21. package/dist/lib/integrations/node-http/index.mjs.map +1 -1
  22. package/dist/lib/runtime/agent-integrations/langgraph/agent.cjs +1 -1
  23. package/dist/lib/runtime/agent-integrations/langgraph/agent.d.cts +2 -2
  24. package/dist/lib/runtime/agent-integrations/langgraph/agent.d.cts.map +1 -1
  25. package/dist/lib/runtime/agent-integrations/langgraph/agent.d.mts +3 -3
  26. package/dist/lib/runtime/agent-integrations/langgraph/agent.d.mts.map +1 -1
  27. package/dist/lib/runtime/agent-integrations/langgraph/agent.mjs +1 -1
  28. package/dist/lib/runtime/copilot-runtime.cjs +7 -5
  29. package/dist/lib/runtime/copilot-runtime.cjs.map +1 -1
  30. package/dist/lib/runtime/copilot-runtime.d.cts +10 -8
  31. package/dist/lib/runtime/copilot-runtime.d.cts.map +1 -1
  32. package/dist/lib/runtime/copilot-runtime.d.mts +10 -8
  33. package/dist/lib/runtime/copilot-runtime.d.mts.map +1 -1
  34. package/dist/lib/runtime/copilot-runtime.mjs +7 -5
  35. package/dist/lib/runtime/copilot-runtime.mjs.map +1 -1
  36. package/dist/lib/runtime/telemetry-agent-runner.cjs +2 -2
  37. package/dist/lib/runtime/telemetry-agent-runner.cjs.map +1 -1
  38. package/dist/lib/runtime/telemetry-agent-runner.d.cts +2 -1
  39. package/dist/lib/runtime/telemetry-agent-runner.d.cts.map +1 -1
  40. package/dist/lib/runtime/telemetry-agent-runner.d.mts +2 -1
  41. package/dist/lib/runtime/telemetry-agent-runner.d.mts.map +1 -1
  42. package/dist/lib/runtime/telemetry-agent-runner.mjs +1 -1
  43. package/dist/lib/runtime/telemetry-agent-runner.mjs.map +1 -1
  44. package/dist/lib/telemetry-client.cjs +1 -1
  45. package/dist/lib/telemetry-client.mjs +1 -1
  46. package/dist/package.cjs +21 -4
  47. package/dist/package.mjs +21 -4
  48. package/dist/service-adapters/anthropic/anthropic-adapter.d.mts +1 -1
  49. package/dist/v2/index.cjs +41 -15
  50. package/dist/v2/index.d.cts +14 -2
  51. package/dist/v2/index.d.mts +14 -2
  52. package/dist/v2/index.mjs +13 -4
  53. package/dist/v2/runtime/endpoints/express-single.cjs +190 -0
  54. package/dist/v2/runtime/endpoints/express-single.cjs.map +1 -0
  55. package/dist/v2/runtime/endpoints/express-single.d.cts +16 -0
  56. package/dist/v2/runtime/endpoints/express-single.d.cts.map +1 -0
  57. package/dist/v2/runtime/endpoints/express-single.d.mts +16 -0
  58. package/dist/v2/runtime/endpoints/express-single.d.mts.map +1 -0
  59. package/dist/v2/runtime/endpoints/express-single.mjs +187 -0
  60. package/dist/v2/runtime/endpoints/express-single.mjs.map +1 -0
  61. package/dist/v2/runtime/endpoints/express-utils.cjs +119 -0
  62. package/dist/v2/runtime/endpoints/express-utils.cjs.map +1 -0
  63. package/dist/v2/runtime/endpoints/express-utils.mjs +117 -0
  64. package/dist/v2/runtime/endpoints/express-utils.mjs.map +1 -0
  65. package/dist/v2/runtime/endpoints/express.cjs +217 -0
  66. package/dist/v2/runtime/endpoints/express.cjs.map +1 -0
  67. package/dist/v2/runtime/endpoints/express.d.cts +16 -0
  68. package/dist/v2/runtime/endpoints/express.d.cts.map +1 -0
  69. package/dist/v2/runtime/endpoints/express.d.mts +16 -0
  70. package/dist/v2/runtime/endpoints/express.d.mts.map +1 -0
  71. package/dist/v2/runtime/endpoints/express.mjs +214 -0
  72. package/dist/v2/runtime/endpoints/express.mjs.map +1 -0
  73. package/dist/v2/runtime/endpoints/hono-single.cjs +141 -0
  74. package/dist/v2/runtime/endpoints/hono-single.cjs.map +1 -0
  75. package/dist/v2/runtime/endpoints/hono-single.d.cts +41 -0
  76. package/dist/v2/runtime/endpoints/hono-single.d.cts.map +1 -0
  77. package/dist/v2/runtime/endpoints/hono-single.d.mts +41 -0
  78. package/dist/v2/runtime/endpoints/hono-single.d.mts.map +1 -0
  79. package/dist/v2/runtime/endpoints/hono-single.mjs +140 -0
  80. package/dist/v2/runtime/endpoints/hono-single.mjs.map +1 -0
  81. package/dist/v2/runtime/endpoints/hono.cjs +248 -0
  82. package/dist/v2/runtime/endpoints/hono.cjs.map +1 -0
  83. package/dist/v2/runtime/endpoints/hono.d.cts +164 -0
  84. package/dist/v2/runtime/endpoints/hono.d.cts.map +1 -0
  85. package/dist/v2/runtime/endpoints/hono.d.mts +164 -0
  86. package/dist/v2/runtime/endpoints/hono.d.mts.map +1 -0
  87. package/dist/v2/runtime/endpoints/hono.mjs +247 -0
  88. package/dist/v2/runtime/endpoints/hono.mjs.map +1 -0
  89. package/dist/v2/runtime/endpoints/index.d.cts +5 -0
  90. package/dist/v2/runtime/endpoints/index.d.mts +5 -0
  91. package/dist/v2/runtime/endpoints/single-route-helpers.cjs +68 -0
  92. package/dist/v2/runtime/endpoints/single-route-helpers.cjs.map +1 -0
  93. package/dist/v2/runtime/endpoints/single-route-helpers.mjs +65 -0
  94. package/dist/v2/runtime/endpoints/single-route-helpers.mjs.map +1 -0
  95. package/dist/v2/runtime/handlers/get-runtime-info.cjs +51 -0
  96. package/dist/v2/runtime/handlers/get-runtime-info.cjs.map +1 -0
  97. package/dist/v2/runtime/handlers/get-runtime-info.mjs +51 -0
  98. package/dist/v2/runtime/handlers/get-runtime-info.mjs.map +1 -0
  99. package/dist/v2/runtime/handlers/handle-connect.cjs +49 -0
  100. package/dist/v2/runtime/handlers/handle-connect.cjs.map +1 -0
  101. package/dist/v2/runtime/handlers/handle-connect.mjs +49 -0
  102. package/dist/v2/runtime/handlers/handle-connect.mjs.map +1 -0
  103. package/dist/v2/runtime/handlers/handle-run.cjs +61 -0
  104. package/dist/v2/runtime/handlers/handle-run.cjs.map +1 -0
  105. package/dist/v2/runtime/handlers/handle-run.mjs +61 -0
  106. package/dist/v2/runtime/handlers/handle-run.mjs.map +1 -0
  107. package/dist/v2/runtime/handlers/handle-stop.cjs +47 -0
  108. package/dist/v2/runtime/handlers/handle-stop.cjs.map +1 -0
  109. package/dist/v2/runtime/handlers/handle-stop.mjs +46 -0
  110. package/dist/v2/runtime/handlers/handle-stop.mjs.map +1 -0
  111. package/dist/v2/runtime/handlers/handle-transcribe.cjs +112 -0
  112. package/dist/v2/runtime/handlers/handle-transcribe.cjs.map +1 -0
  113. package/dist/v2/runtime/handlers/handle-transcribe.mjs +111 -0
  114. package/dist/v2/runtime/handlers/handle-transcribe.mjs.map +1 -0
  115. package/dist/v2/runtime/handlers/header-utils.cjs +26 -0
  116. package/dist/v2/runtime/handlers/header-utils.cjs.map +1 -0
  117. package/dist/v2/runtime/handlers/header-utils.mjs +25 -0
  118. package/dist/v2/runtime/handlers/header-utils.mjs.map +1 -0
  119. package/dist/v2/runtime/handlers/intelligence/connect.cjs +37 -0
  120. package/dist/v2/runtime/handlers/intelligence/connect.cjs.map +1 -0
  121. package/dist/v2/runtime/handlers/intelligence/connect.mjs +37 -0
  122. package/dist/v2/runtime/handlers/intelligence/connect.mjs.map +1 -0
  123. package/dist/v2/runtime/handlers/intelligence/run.cjs +89 -0
  124. package/dist/v2/runtime/handlers/intelligence/run.cjs.map +1 -0
  125. package/dist/v2/runtime/handlers/intelligence/run.mjs +88 -0
  126. package/dist/v2/runtime/handlers/intelligence/run.mjs.map +1 -0
  127. package/dist/v2/runtime/handlers/intelligence/thread-names.cjs +146 -0
  128. package/dist/v2/runtime/handlers/intelligence/thread-names.cjs.map +1 -0
  129. package/dist/v2/runtime/handlers/intelligence/thread-names.mjs +145 -0
  130. package/dist/v2/runtime/handlers/intelligence/thread-names.mjs.map +1 -0
  131. package/dist/v2/runtime/handlers/intelligence/threads.cjs +159 -0
  132. package/dist/v2/runtime/handlers/intelligence/threads.cjs.map +1 -0
  133. package/dist/v2/runtime/handlers/intelligence/threads.mjs +154 -0
  134. package/dist/v2/runtime/handlers/intelligence/threads.mjs.map +1 -0
  135. package/dist/v2/runtime/handlers/shared/agent-utils.cjs +74 -0
  136. package/dist/v2/runtime/handlers/shared/agent-utils.cjs.map +1 -0
  137. package/dist/v2/runtime/handlers/shared/agent-utils.mjs +70 -0
  138. package/dist/v2/runtime/handlers/shared/agent-utils.mjs.map +1 -0
  139. package/dist/v2/runtime/handlers/shared/intelligence-utils.cjs +21 -0
  140. package/dist/v2/runtime/handlers/shared/intelligence-utils.cjs.map +1 -0
  141. package/dist/v2/runtime/handlers/shared/intelligence-utils.mjs +20 -0
  142. package/dist/v2/runtime/handlers/shared/intelligence-utils.mjs.map +1 -0
  143. package/dist/v2/runtime/handlers/shared/json-response.cjs +12 -0
  144. package/dist/v2/runtime/handlers/shared/json-response.cjs.map +1 -0
  145. package/dist/v2/runtime/handlers/shared/json-response.mjs +10 -0
  146. package/dist/v2/runtime/handlers/shared/json-response.mjs.map +1 -0
  147. package/dist/v2/runtime/handlers/shared/resolve-intelligence-user.cjs +20 -0
  148. package/dist/v2/runtime/handlers/shared/resolve-intelligence-user.cjs.map +1 -0
  149. package/dist/v2/runtime/handlers/shared/resolve-intelligence-user.mjs +20 -0
  150. package/dist/v2/runtime/handlers/shared/resolve-intelligence-user.mjs.map +1 -0
  151. package/dist/v2/runtime/handlers/shared/sse-response.cjs +69 -0
  152. package/dist/v2/runtime/handlers/shared/sse-response.cjs.map +1 -0
  153. package/dist/v2/runtime/handlers/shared/sse-response.mjs +68 -0
  154. package/dist/v2/runtime/handlers/shared/sse-response.mjs.map +1 -0
  155. package/dist/v2/runtime/handlers/sse/connect.cjs +18 -0
  156. package/dist/v2/runtime/handlers/sse/connect.cjs.map +1 -0
  157. package/dist/v2/runtime/handlers/sse/connect.mjs +18 -0
  158. package/dist/v2/runtime/handlers/sse/connect.mjs.map +1 -0
  159. package/dist/v2/runtime/handlers/sse/run.cjs +18 -0
  160. package/dist/v2/runtime/handlers/sse/run.cjs.map +1 -0
  161. package/dist/v2/runtime/handlers/sse/run.mjs +18 -0
  162. package/dist/v2/runtime/handlers/sse/run.mjs.map +1 -0
  163. package/dist/v2/runtime/index.d.cts +13 -0
  164. package/dist/v2/runtime/index.d.mts +14 -0
  165. package/dist/v2/runtime/intelligence-platform/client.cjs +333 -0
  166. package/dist/v2/runtime/intelligence-platform/client.cjs.map +1 -0
  167. package/dist/v2/runtime/intelligence-platform/client.d.cts +336 -0
  168. package/dist/v2/runtime/intelligence-platform/client.d.cts.map +1 -0
  169. package/dist/v2/runtime/intelligence-platform/client.d.mts +336 -0
  170. package/dist/v2/runtime/intelligence-platform/client.d.mts.map +1 -0
  171. package/dist/v2/runtime/intelligence-platform/client.mjs +331 -0
  172. package/dist/v2/runtime/intelligence-platform/client.mjs.map +1 -0
  173. package/dist/v2/runtime/intelligence-platform/index.d.mts +2 -0
  174. package/dist/v2/runtime/middleware-sse-parser.cjs +138 -0
  175. package/dist/v2/runtime/middleware-sse-parser.cjs.map +1 -0
  176. package/dist/v2/runtime/middleware-sse-parser.d.cts +22 -0
  177. package/dist/v2/runtime/middleware-sse-parser.d.cts.map +1 -0
  178. package/dist/v2/runtime/middleware-sse-parser.d.mts +22 -0
  179. package/dist/v2/runtime/middleware-sse-parser.d.mts.map +1 -0
  180. package/dist/v2/runtime/middleware-sse-parser.mjs +137 -0
  181. package/dist/v2/runtime/middleware-sse-parser.mjs.map +1 -0
  182. package/dist/v2/runtime/middleware.cjs +35 -0
  183. package/dist/v2/runtime/middleware.cjs.map +1 -0
  184. package/dist/v2/runtime/middleware.d.cts +32 -0
  185. package/dist/v2/runtime/middleware.d.cts.map +1 -0
  186. package/dist/v2/runtime/middleware.d.mts +32 -0
  187. package/dist/v2/runtime/middleware.d.mts.map +1 -0
  188. package/dist/v2/runtime/middleware.mjs +33 -0
  189. package/dist/v2/runtime/middleware.mjs.map +1 -0
  190. package/dist/v2/runtime/runner/agent-runner.cjs +8 -0
  191. package/dist/v2/runtime/runner/agent-runner.cjs.map +1 -0
  192. package/dist/v2/runtime/runner/agent-runner.d.cts +32 -0
  193. package/dist/v2/runtime/runner/agent-runner.d.cts.map +1 -0
  194. package/dist/v2/runtime/runner/agent-runner.d.mts +32 -0
  195. package/dist/v2/runtime/runner/agent-runner.d.mts.map +1 -0
  196. package/dist/v2/runtime/runner/agent-runner.mjs +7 -0
  197. package/dist/v2/runtime/runner/agent-runner.mjs.map +1 -0
  198. package/dist/v2/runtime/runner/in-memory.cjs +223 -0
  199. package/dist/v2/runtime/runner/in-memory.cjs.map +1 -0
  200. package/dist/v2/runtime/runner/in-memory.d.cts +15 -0
  201. package/dist/v2/runtime/runner/in-memory.d.cts.map +1 -0
  202. package/dist/v2/runtime/runner/in-memory.d.mts +15 -0
  203. package/dist/v2/runtime/runner/in-memory.d.mts.map +1 -0
  204. package/dist/v2/runtime/runner/in-memory.mjs +222 -0
  205. package/dist/v2/runtime/runner/in-memory.mjs.map +1 -0
  206. package/dist/v2/runtime/runner/index.d.cts +6 -0
  207. package/dist/v2/runtime/runner/index.d.mts +6 -0
  208. package/dist/v2/runtime/runner/index.mjs +7 -0
  209. package/dist/v2/runtime/runner/intelligence.cjs +246 -0
  210. package/dist/v2/runtime/runner/intelligence.cjs.map +1 -0
  211. package/dist/v2/runtime/runner/intelligence.d.cts +57 -0
  212. package/dist/v2/runtime/runner/intelligence.d.cts.map +1 -0
  213. package/dist/v2/runtime/runner/intelligence.d.mts +57 -0
  214. package/dist/v2/runtime/runner/intelligence.d.mts.map +1 -0
  215. package/dist/v2/runtime/runner/intelligence.mjs +245 -0
  216. package/dist/v2/runtime/runner/intelligence.mjs.map +1 -0
  217. package/dist/v2/runtime/runtime.cjs +101 -0
  218. package/dist/v2/runtime/runtime.cjs.map +1 -0
  219. package/dist/v2/runtime/runtime.d.cts +132 -0
  220. package/dist/v2/runtime/runtime.d.cts.map +1 -0
  221. package/dist/v2/runtime/runtime.d.mts +133 -0
  222. package/dist/v2/runtime/runtime.d.mts.map +1 -0
  223. package/dist/v2/runtime/runtime.mjs +97 -0
  224. package/dist/v2/runtime/runtime.mjs.map +1 -0
  225. package/dist/v2/runtime/telemetry/scarf-client.cjs +32 -0
  226. package/dist/v2/runtime/telemetry/scarf-client.cjs.map +1 -0
  227. package/dist/v2/runtime/telemetry/scarf-client.mjs +32 -0
  228. package/dist/v2/runtime/telemetry/scarf-client.mjs.map +1 -0
  229. package/dist/v2/runtime/telemetry/telemetry-client.cjs +35 -0
  230. package/dist/v2/runtime/telemetry/telemetry-client.cjs.map +1 -0
  231. package/dist/v2/runtime/telemetry/telemetry-client.mjs +35 -0
  232. package/dist/v2/runtime/telemetry/telemetry-client.mjs.map +1 -0
  233. package/dist/v2/runtime/transcription-service/transcription-service.cjs +8 -0
  234. package/dist/v2/runtime/transcription-service/transcription-service.cjs.map +1 -0
  235. package/dist/v2/runtime/transcription-service/transcription-service.d.cts +15 -0
  236. package/dist/v2/runtime/transcription-service/transcription-service.d.cts.map +1 -0
  237. package/dist/v2/runtime/transcription-service/transcription-service.d.mts +15 -0
  238. package/dist/v2/runtime/transcription-service/transcription-service.d.mts.map +1 -0
  239. package/dist/v2/runtime/transcription-service/transcription-service.mjs +7 -0
  240. package/dist/v2/runtime/transcription-service/transcription-service.mjs.map +1 -0
  241. package/package.json +24 -7
  242. package/src/agent/__tests__/ai-sdk-v6-compat.test.ts +116 -0
  243. package/src/agent/__tests__/basic-agent.test.ts +1698 -0
  244. package/src/agent/__tests__/config-tools-execution.test.ts +516 -0
  245. package/src/agent/__tests__/mcp-clients.test.ts +260 -0
  246. package/src/agent/__tests__/property-overrides.test.ts +598 -0
  247. package/src/agent/__tests__/standard-schema-tools.test.ts +313 -0
  248. package/src/agent/__tests__/standard-schema-types.test.ts +158 -0
  249. package/src/agent/__tests__/state-tools.test.ts +436 -0
  250. package/src/agent/__tests__/test-helpers.ts +193 -0
  251. package/src/agent/__tests__/utils.test.ts +536 -0
  252. package/src/agent/__tests__/zod-regression.test.ts +350 -0
  253. package/src/agent/index.ts +1329 -0
  254. package/src/graphql/message-conversion/agui-to-gql.test.ts +1 -1
  255. package/src/graphql/message-conversion/agui-to-gql.ts +1 -1
  256. package/src/graphql/message-conversion/gql-to-agui.ts +1 -1
  257. package/src/graphql/message-conversion/roundtrip-conversion.test.ts +1 -1
  258. package/src/lib/integrations/nextjs/app-router.ts +2 -2
  259. package/src/lib/integrations/node-http/index.ts +2 -2
  260. package/src/lib/runtime/copilot-runtime.ts +3 -5
  261. package/src/lib/runtime/telemetry-agent-runner.ts +1 -1
  262. package/src/service-adapters/conversion.test.ts +1 -1
  263. package/src/service-adapters/conversion.ts +1 -28
  264. package/src/v2/index.ts +5 -2
  265. package/src/v2/runtime/__tests__/cors-credentials.test.ts +320 -0
  266. package/src/v2/runtime/__tests__/express-abort-signal.test.ts +25 -0
  267. package/src/v2/runtime/__tests__/express-body-order.test.ts +76 -0
  268. package/src/v2/runtime/__tests__/express-single-sse.test.ts +122 -0
  269. package/src/v2/runtime/__tests__/get-runtime-info.test.ts +141 -0
  270. package/src/v2/runtime/__tests__/handle-connect.test.ts +423 -0
  271. package/src/v2/runtime/__tests__/handle-run.test.ts +910 -0
  272. package/src/v2/runtime/__tests__/handle-threads.test.ts +388 -0
  273. package/src/v2/runtime/__tests__/handle-transcribe.test.ts +301 -0
  274. package/src/v2/runtime/__tests__/header-utils.test.ts +88 -0
  275. package/src/v2/runtime/__tests__/in-process-agent-runner-messages.test.ts +230 -0
  276. package/src/v2/runtime/__tests__/in-process-agent-runner.test.ts +1030 -0
  277. package/src/v2/runtime/__tests__/middleware-express.test.ts +206 -0
  278. package/src/v2/runtime/__tests__/middleware-single-express.test.ts +211 -0
  279. package/src/v2/runtime/__tests__/middleware-single.test.ts +225 -0
  280. package/src/v2/runtime/__tests__/middleware-sse-parser.test.ts +187 -0
  281. package/src/v2/runtime/__tests__/middleware.test.ts +251 -0
  282. package/src/v2/runtime/__tests__/routing-express.test.ts +174 -0
  283. package/src/v2/runtime/__tests__/routing-single-express.test.ts +168 -0
  284. package/src/v2/runtime/__tests__/routing-single.test.ts +193 -0
  285. package/src/v2/runtime/__tests__/routing.test.ts +257 -0
  286. package/src/v2/runtime/__tests__/runtime.test.ts +123 -0
  287. package/src/v2/runtime/__tests__/telemetry.test.ts +167 -0
  288. package/src/v2/runtime/__tests__/thread-names.test.ts +188 -0
  289. package/src/v2/runtime/endpoints/express-single.ts +231 -0
  290. package/src/v2/runtime/endpoints/express-utils.ts +182 -0
  291. package/src/v2/runtime/endpoints/express.ts +275 -0
  292. package/src/v2/runtime/endpoints/hono-single.ts +212 -0
  293. package/src/v2/runtime/endpoints/hono.ts +314 -0
  294. package/src/v2/runtime/endpoints/index.ts +4 -0
  295. package/src/v2/runtime/endpoints/single-route-helpers.ts +125 -0
  296. package/src/v2/runtime/express.ts +2 -0
  297. package/src/v2/runtime/handler.ts +3 -0
  298. package/src/v2/runtime/handlers/get-runtime-info.ts +79 -0
  299. package/src/v2/runtime/handlers/handle-connect.ts +76 -0
  300. package/src/v2/runtime/handlers/handle-run.ts +89 -0
  301. package/src/v2/runtime/handlers/handle-stop.ts +76 -0
  302. package/src/v2/runtime/handlers/handle-threads.ts +7 -0
  303. package/src/v2/runtime/handlers/handle-transcribe.ts +256 -0
  304. package/src/v2/runtime/handlers/header-utils.ts +24 -0
  305. package/src/v2/runtime/handlers/intelligence/connect.ts +65 -0
  306. package/src/v2/runtime/handlers/intelligence/run.ts +152 -0
  307. package/src/v2/runtime/handlers/intelligence/thread-names.ts +246 -0
  308. package/src/v2/runtime/handlers/intelligence/threads.ts +233 -0
  309. package/src/v2/runtime/handlers/shared/agent-utils.ts +136 -0
  310. package/src/v2/runtime/handlers/shared/intelligence-utils.ts +21 -0
  311. package/src/v2/runtime/handlers/shared/json-response.ts +6 -0
  312. package/src/v2/runtime/handlers/shared/resolve-intelligence-user.ts +25 -0
  313. package/src/v2/runtime/handlers/shared/sse-response.ts +100 -0
  314. package/src/v2/runtime/handlers/sse/connect.ts +24 -0
  315. package/src/v2/runtime/handlers/sse/run.ts +27 -0
  316. package/src/v2/runtime/index.ts +20 -0
  317. package/src/v2/runtime/intelligence-platform/__tests__/client.test.ts +605 -0
  318. package/src/v2/runtime/intelligence-platform/client.ts +659 -0
  319. package/src/v2/runtime/intelligence-platform/index.ts +10 -0
  320. package/src/v2/runtime/middleware-sse-parser.ts +200 -0
  321. package/src/v2/runtime/middleware.ts +115 -0
  322. package/src/v2/runtime/runner/__tests__/finalize-events.test.ts +109 -0
  323. package/src/v2/runtime/runner/__tests__/in-memory-runner.e2e.test.ts +775 -0
  324. package/src/v2/runtime/runner/__tests__/in-memory-runner.test.ts +363 -0
  325. package/src/v2/runtime/runner/__tests__/intelligence-runner.test.ts +981 -0
  326. package/src/v2/runtime/runner/agent-runner.ts +36 -0
  327. package/src/v2/runtime/runner/in-memory.ts +381 -0
  328. package/src/v2/runtime/runner/index.ts +4 -0
  329. package/src/v2/runtime/runner/intelligence.ts +429 -0
  330. package/src/v2/runtime/runtime.ts +260 -0
  331. package/src/v2/runtime/telemetry/events.ts +35 -0
  332. package/src/v2/runtime/telemetry/index.ts +7 -0
  333. package/src/v2/runtime/telemetry/scarf-client.ts +39 -0
  334. package/src/v2/runtime/telemetry/telemetry-client.ts +70 -0
  335. package/src/v2/runtime/transcription-service/transcription-service.ts +11 -0
  336. package/tsconfig.json +9 -2
  337. package/tsdown.config.ts +1 -0
@@ -0,0 +1,436 @@
1
+ import { describe, it, expect, vi, beforeEach, afterEach } from "vitest";
2
+ import { BasicAgent } from "../index";
3
+ import { EventType, type RunAgentInput } from "@ag-ui/client";
4
+ import { streamText } from "ai";
5
+ import {
6
+ mockStreamTextResponse,
7
+ toolCallStreamingStart,
8
+ toolCall,
9
+ toolResult,
10
+ finish,
11
+ collectEvents,
12
+ } from "./test-helpers";
13
+
14
+ // Mock the ai module
15
+ vi.mock("ai", () => ({
16
+ streamText: vi.fn(),
17
+ tool: vi.fn((config) => config),
18
+ }));
19
+
20
+ // Mock the SDK clients
21
+ vi.mock("@ai-sdk/openai", () => ({
22
+ createOpenAI: vi.fn(() => (modelId: string) => ({
23
+ modelId,
24
+ provider: "openai",
25
+ })),
26
+ }));
27
+
28
+ describe("State Update Tools", () => {
29
+ const originalEnv = process.env;
30
+
31
+ beforeEach(() => {
32
+ vi.clearAllMocks();
33
+ process.env = { ...originalEnv };
34
+ process.env.OPENAI_API_KEY = "test-key";
35
+ });
36
+
37
+ afterEach(() => {
38
+ process.env = originalEnv;
39
+ });
40
+
41
+ describe("AGUISendStateSnapshot", () => {
42
+ it("should emit STATE_SNAPSHOT event when tool is called", async () => {
43
+ const agent = new BasicAgent({
44
+ model: "openai/gpt-4o",
45
+ });
46
+
47
+ const newState = { counter: 5, items: ["x", "y"] };
48
+
49
+ vi.mocked(streamText).mockReturnValue(
50
+ mockStreamTextResponse([
51
+ toolCallStreamingStart("call1", "AGUISendStateSnapshot"),
52
+ toolCall("call1", "AGUISendStateSnapshot"),
53
+ toolResult("call1", "AGUISendStateSnapshot", {
54
+ success: true,
55
+ snapshot: newState,
56
+ }),
57
+ finish(),
58
+ ]) as any,
59
+ );
60
+
61
+ const input: RunAgentInput = {
62
+ threadId: "thread1",
63
+ runId: "run1",
64
+ messages: [],
65
+ tools: [],
66
+ context: [],
67
+ state: { counter: 0 },
68
+ };
69
+
70
+ const events = await collectEvents(agent["run"](input));
71
+
72
+ // Find STATE_SNAPSHOT event
73
+ const snapshotEvent = events.find(
74
+ (e: any) => e.type === EventType.STATE_SNAPSHOT,
75
+ );
76
+ expect(snapshotEvent).toBeDefined();
77
+ expect(snapshotEvent).toMatchObject({
78
+ type: EventType.STATE_SNAPSHOT,
79
+ snapshot: newState,
80
+ });
81
+ });
82
+
83
+ it("should still emit TOOL_CALL_RESULT for the LLM", async () => {
84
+ const agent = new BasicAgent({
85
+ model: "openai/gpt-4o",
86
+ });
87
+
88
+ vi.mocked(streamText).mockReturnValue(
89
+ mockStreamTextResponse([
90
+ toolCallStreamingStart("call1", "AGUISendStateSnapshot"),
91
+ toolCall("call1", "AGUISendStateSnapshot"),
92
+ toolResult("call1", "AGUISendStateSnapshot", {
93
+ success: true,
94
+ snapshot: { value: 1 },
95
+ }),
96
+ finish(),
97
+ ]) as any,
98
+ );
99
+
100
+ const input: RunAgentInput = {
101
+ threadId: "thread1",
102
+ runId: "run1",
103
+ messages: [],
104
+ tools: [],
105
+ context: [],
106
+ state: {},
107
+ };
108
+
109
+ const events = await collectEvents(agent["run"](input));
110
+
111
+ // Should have both STATE_SNAPSHOT and TOOL_CALL_RESULT
112
+ const snapshotEvent = events.find(
113
+ (e: any) => e.type === EventType.STATE_SNAPSHOT,
114
+ );
115
+ const toolResultEvent = events.find(
116
+ (e: any) => e.type === EventType.TOOL_CALL_RESULT,
117
+ );
118
+
119
+ expect(snapshotEvent).toBeDefined();
120
+ expect(toolResultEvent).toBeDefined();
121
+ expect(toolResultEvent).toMatchObject({
122
+ type: EventType.TOOL_CALL_RESULT,
123
+ toolCallId: "call1",
124
+ });
125
+ });
126
+ });
127
+
128
+ describe("AGUISendStateDelta", () => {
129
+ it("should emit STATE_DELTA event when tool is called", async () => {
130
+ const agent = new BasicAgent({
131
+ model: "openai/gpt-4o",
132
+ });
133
+
134
+ const delta = [
135
+ { op: "replace", path: "/counter", value: 10 },
136
+ { op: "add", path: "/newField", value: "test" },
137
+ ];
138
+
139
+ vi.mocked(streamText).mockReturnValue(
140
+ mockStreamTextResponse([
141
+ toolCallStreamingStart("call1", "AGUISendStateDelta"),
142
+ toolCall("call1", "AGUISendStateDelta"),
143
+ toolResult("call1", "AGUISendStateDelta", { success: true, delta }),
144
+ finish(),
145
+ ]) as any,
146
+ );
147
+
148
+ const input: RunAgentInput = {
149
+ threadId: "thread1",
150
+ runId: "run1",
151
+ messages: [],
152
+ tools: [],
153
+ context: [],
154
+ state: { counter: 0 },
155
+ };
156
+
157
+ const events = await collectEvents(agent["run"](input));
158
+
159
+ // Find STATE_DELTA event
160
+ const deltaEvent = events.find(
161
+ (e: any) => e.type === EventType.STATE_DELTA,
162
+ );
163
+ expect(deltaEvent).toBeDefined();
164
+ expect(deltaEvent).toMatchObject({
165
+ type: EventType.STATE_DELTA,
166
+ delta,
167
+ });
168
+ });
169
+
170
+ it("should handle add operations", async () => {
171
+ const agent = new BasicAgent({
172
+ model: "openai/gpt-4o",
173
+ });
174
+
175
+ const delta = [{ op: "add", path: "/items/0", value: "new item" }];
176
+
177
+ vi.mocked(streamText).mockReturnValue(
178
+ mockStreamTextResponse([
179
+ toolCallStreamingStart("call1", "AGUISendStateDelta"),
180
+ toolCall("call1", "AGUISendStateDelta"),
181
+ toolResult("call1", "AGUISendStateDelta", { success: true, delta }),
182
+ finish(),
183
+ ]) as any,
184
+ );
185
+
186
+ const input: RunAgentInput = {
187
+ threadId: "thread1",
188
+ runId: "run1",
189
+ messages: [],
190
+ tools: [],
191
+ context: [],
192
+ state: { items: [] },
193
+ };
194
+
195
+ const events = await collectEvents(agent["run"](input));
196
+
197
+ const deltaEvent = events.find(
198
+ (e: any) => e.type === EventType.STATE_DELTA,
199
+ );
200
+ expect(deltaEvent?.delta).toEqual(delta);
201
+ });
202
+
203
+ it("should handle replace operations", async () => {
204
+ const agent = new BasicAgent({
205
+ model: "openai/gpt-4o",
206
+ });
207
+
208
+ const delta = [{ op: "replace", path: "/status", value: "active" }];
209
+
210
+ vi.mocked(streamText).mockReturnValue(
211
+ mockStreamTextResponse([
212
+ toolCallStreamingStart("call1", "AGUISendStateDelta"),
213
+ toolCall("call1", "AGUISendStateDelta"),
214
+ toolResult("call1", "AGUISendStateDelta", { success: true, delta }),
215
+ finish(),
216
+ ]) as any,
217
+ );
218
+
219
+ const input: RunAgentInput = {
220
+ threadId: "thread1",
221
+ runId: "run1",
222
+ messages: [],
223
+ tools: [],
224
+ context: [],
225
+ state: { status: "inactive" },
226
+ };
227
+
228
+ const events = await collectEvents(agent["run"](input));
229
+
230
+ const deltaEvent = events.find(
231
+ (e: any) => e.type === EventType.STATE_DELTA,
232
+ );
233
+ expect(deltaEvent?.delta).toEqual(delta);
234
+ });
235
+
236
+ it("should handle remove operations", async () => {
237
+ const agent = new BasicAgent({
238
+ model: "openai/gpt-4o",
239
+ });
240
+
241
+ const delta = [{ op: "remove", path: "/oldField" }];
242
+
243
+ vi.mocked(streamText).mockReturnValue(
244
+ mockStreamTextResponse([
245
+ toolCallStreamingStart("call1", "AGUISendStateDelta"),
246
+ toolCall("call1", "AGUISendStateDelta"),
247
+ toolResult("call1", "AGUISendStateDelta", { success: true, delta }),
248
+ finish(),
249
+ ]) as any,
250
+ );
251
+
252
+ const input: RunAgentInput = {
253
+ threadId: "thread1",
254
+ runId: "run1",
255
+ messages: [],
256
+ tools: [],
257
+ context: [],
258
+ state: { oldField: "value", keepField: "keep" },
259
+ };
260
+
261
+ const events = await collectEvents(agent["run"](input));
262
+
263
+ const deltaEvent = events.find(
264
+ (e: any) => e.type === EventType.STATE_DELTA,
265
+ );
266
+ expect(deltaEvent?.delta).toEqual(delta);
267
+ });
268
+
269
+ it("should handle multiple operations in a single delta", async () => {
270
+ const agent = new BasicAgent({
271
+ model: "openai/gpt-4o",
272
+ });
273
+
274
+ const delta = [
275
+ { op: "replace", path: "/counter", value: 5 },
276
+ { op: "add", path: "/items/-", value: "new" },
277
+ { op: "remove", path: "/temp" },
278
+ ];
279
+
280
+ vi.mocked(streamText).mockReturnValue(
281
+ mockStreamTextResponse([
282
+ toolCallStreamingStart("call1", "AGUISendStateDelta"),
283
+ toolCall("call1", "AGUISendStateDelta"),
284
+ toolResult("call1", "AGUISendStateDelta", { success: true, delta }),
285
+ finish(),
286
+ ]) as any,
287
+ );
288
+
289
+ const input: RunAgentInput = {
290
+ threadId: "thread1",
291
+ runId: "run1",
292
+ messages: [],
293
+ tools: [],
294
+ context: [],
295
+ state: { counter: 0, items: [], temp: "remove me" },
296
+ };
297
+
298
+ const events = await collectEvents(agent["run"](input));
299
+
300
+ const deltaEvent = events.find(
301
+ (e: any) => e.type === EventType.STATE_DELTA,
302
+ );
303
+ expect(deltaEvent?.delta).toEqual(delta);
304
+ });
305
+
306
+ it("should still emit TOOL_CALL_RESULT for the LLM", async () => {
307
+ const agent = new BasicAgent({
308
+ model: "openai/gpt-4o",
309
+ });
310
+
311
+ const delta = [{ op: "replace", path: "/value", value: 1 }];
312
+
313
+ vi.mocked(streamText).mockReturnValue(
314
+ mockStreamTextResponse([
315
+ toolCallStreamingStart("call1", "AGUISendStateDelta"),
316
+ toolCall("call1", "AGUISendStateDelta"),
317
+ toolResult("call1", "AGUISendStateDelta", { success: true, delta }),
318
+ finish(),
319
+ ]) as any,
320
+ );
321
+
322
+ const input: RunAgentInput = {
323
+ threadId: "thread1",
324
+ runId: "run1",
325
+ messages: [],
326
+ tools: [],
327
+ context: [],
328
+ state: {},
329
+ };
330
+
331
+ const events = await collectEvents(agent["run"](input));
332
+
333
+ // Should have both STATE_DELTA and TOOL_CALL_RESULT
334
+ const deltaEvent = events.find(
335
+ (e: any) => e.type === EventType.STATE_DELTA,
336
+ );
337
+ const toolResultEvent = events.find(
338
+ (e: any) => e.type === EventType.TOOL_CALL_RESULT,
339
+ );
340
+
341
+ expect(deltaEvent).toBeDefined();
342
+ expect(toolResultEvent).toBeDefined();
343
+ expect(toolResultEvent).toMatchObject({
344
+ type: EventType.TOOL_CALL_RESULT,
345
+ toolCallId: "call1",
346
+ });
347
+ });
348
+ });
349
+
350
+ describe("State Tools Integration", () => {
351
+ it("should handle both snapshot and delta in same run", async () => {
352
+ const agent = new BasicAgent({
353
+ model: "openai/gpt-4o",
354
+ });
355
+
356
+ vi.mocked(streamText).mockReturnValue(
357
+ mockStreamTextResponse([
358
+ toolCallStreamingStart("call1", "AGUISendStateSnapshot"),
359
+ toolCall("call1", "AGUISendStateSnapshot"),
360
+ toolResult("call1", "AGUISendStateSnapshot", {
361
+ success: true,
362
+ snapshot: { value: 1 },
363
+ }),
364
+ toolCallStreamingStart("call2", "AGUISendStateDelta"),
365
+ toolCall("call2", "AGUISendStateDelta"),
366
+ toolResult("call2", "AGUISendStateDelta", {
367
+ success: true,
368
+ delta: [{ op: "replace", path: "/value", value: 2 }],
369
+ }),
370
+ finish(),
371
+ ]) as any,
372
+ );
373
+
374
+ const input: RunAgentInput = {
375
+ threadId: "thread1",
376
+ runId: "run1",
377
+ messages: [],
378
+ tools: [],
379
+ context: [],
380
+ state: {},
381
+ };
382
+
383
+ const events = await collectEvents(agent["run"](input));
384
+
385
+ const snapshotEvents = events.filter(
386
+ (e: any) => e.type === EventType.STATE_SNAPSHOT,
387
+ );
388
+ const deltaEvents = events.filter(
389
+ (e: any) => e.type === EventType.STATE_DELTA,
390
+ );
391
+
392
+ expect(snapshotEvents).toHaveLength(1);
393
+ expect(deltaEvents).toHaveLength(1);
394
+ });
395
+
396
+ it("should not emit state events for non-state tools", async () => {
397
+ const agent = new BasicAgent({
398
+ model: "openai/gpt-4o",
399
+ });
400
+
401
+ vi.mocked(streamText).mockReturnValue(
402
+ mockStreamTextResponse([
403
+ toolCallStreamingStart("call1", "otherTool"),
404
+ toolCall("call1", "otherTool"),
405
+ toolResult("call1", "otherTool", { result: "data" }),
406
+ finish(),
407
+ ]) as any,
408
+ );
409
+
410
+ const input: RunAgentInput = {
411
+ threadId: "thread1",
412
+ runId: "run1",
413
+ messages: [],
414
+ tools: [
415
+ {
416
+ name: "otherTool",
417
+ description: "Other tool",
418
+ parameters: { type: "object", properties: {} },
419
+ },
420
+ ],
421
+ context: [],
422
+ state: {},
423
+ };
424
+
425
+ const events = await collectEvents(agent["run"](input));
426
+
427
+ const stateEvents = events.filter(
428
+ (e: any) =>
429
+ e.type === EventType.STATE_SNAPSHOT ||
430
+ e.type === EventType.STATE_DELTA,
431
+ );
432
+
433
+ expect(stateEvents).toHaveLength(0);
434
+ });
435
+ });
436
+ });
@@ -0,0 +1,193 @@
1
+ /**
2
+ * Test helpers for mocking streamText responses
3
+ */
4
+
5
+ import type { streamText } from "ai";
6
+ import type { Observable } from "rxjs";
7
+ import type { BaseEvent } from "@ag-ui/client";
8
+
9
+ export interface MockStreamEvent {
10
+ type: string;
11
+ [key: string]: unknown;
12
+ }
13
+
14
+ /**
15
+ * Creates a mock streamText response with controlled events.
16
+ */
17
+ export function mockStreamTextResponse(
18
+ events: MockStreamEvent[],
19
+ ): ReturnType<typeof streamText> {
20
+ return {
21
+ fullStream: (async function* () {
22
+ for (const event of events) {
23
+ yield event;
24
+ }
25
+ })(),
26
+ } as unknown as ReturnType<typeof streamText>;
27
+ }
28
+
29
+ /**
30
+ * Helper to create a text-start event
31
+ */
32
+ export function textStart(id?: string): MockStreamEvent {
33
+ const event: MockStreamEvent = {
34
+ type: "text-start",
35
+ };
36
+ if (id !== undefined) {
37
+ event.id = id;
38
+ }
39
+ return event;
40
+ }
41
+
42
+ /**
43
+ * Helper to create a text delta event
44
+ */
45
+ export function textDelta(text: string): MockStreamEvent {
46
+ return {
47
+ type: "text-delta",
48
+ text,
49
+ };
50
+ }
51
+
52
+ /**
53
+ * Helper to create a tool call streaming start event
54
+ */
55
+ export function toolCallStreamingStart(
56
+ toolCallId: string,
57
+ toolName: string,
58
+ ): MockStreamEvent {
59
+ return {
60
+ type: "tool-input-start",
61
+ id: toolCallId,
62
+ toolName,
63
+ };
64
+ }
65
+
66
+ /**
67
+ * Helper to create a tool call delta event
68
+ */
69
+ export function toolCallDelta(
70
+ toolCallId: string,
71
+ argsTextDelta: string,
72
+ ): MockStreamEvent {
73
+ return {
74
+ type: "tool-input-delta",
75
+ id: toolCallId,
76
+ delta: argsTextDelta,
77
+ };
78
+ }
79
+
80
+ /**
81
+ * Helper to create a tool call event
82
+ */
83
+ export function toolCall(
84
+ toolCallId: string,
85
+ toolName: string,
86
+ input: unknown = {},
87
+ ): MockStreamEvent {
88
+ return {
89
+ type: "tool-call",
90
+ toolCallId,
91
+ toolName,
92
+ input,
93
+ };
94
+ }
95
+
96
+ /**
97
+ * Helper to create a tool result event
98
+ */
99
+ export function toolResult(
100
+ toolCallId: string,
101
+ toolName: string,
102
+ output: unknown,
103
+ ): MockStreamEvent {
104
+ return {
105
+ type: "tool-result",
106
+ toolCallId,
107
+ toolName,
108
+ output,
109
+ };
110
+ }
111
+
112
+ /**
113
+ * Helper to create a reasoning-start event
114
+ */
115
+ export function reasoningStart(id?: string): MockStreamEvent {
116
+ const event: MockStreamEvent = {
117
+ type: "reasoning-start",
118
+ };
119
+ if (id !== undefined) {
120
+ event.id = id;
121
+ }
122
+ return event;
123
+ }
124
+
125
+ /**
126
+ * Helper to create a reasoning-delta event
127
+ */
128
+ export function reasoningDelta(text: string): MockStreamEvent {
129
+ return {
130
+ type: "reasoning-delta",
131
+ text,
132
+ };
133
+ }
134
+
135
+ /**
136
+ * Helper to create a reasoning-end event
137
+ */
138
+ export function reasoningEnd(): MockStreamEvent {
139
+ return {
140
+ type: "reasoning-end",
141
+ };
142
+ }
143
+
144
+ /**
145
+ * Helper to create a finish event
146
+ */
147
+ export function finish(): MockStreamEvent {
148
+ return {
149
+ type: "finish",
150
+ finishReason: "stop",
151
+ };
152
+ }
153
+
154
+ /**
155
+ * Helper to create an abort event
156
+ */
157
+ export function abort(): MockStreamEvent {
158
+ return {
159
+ type: "abort",
160
+ };
161
+ }
162
+
163
+ /**
164
+ * Helper to create an error event
165
+ */
166
+ export function error(errorMessage: string): MockStreamEvent {
167
+ return {
168
+ type: "error",
169
+ error: new Error(errorMessage),
170
+ };
171
+ }
172
+
173
+ /**
174
+ * Collects all events from an Observable<BaseEvent> into an array.
175
+ */
176
+ export async function collectEvents(
177
+ observable: Observable<BaseEvent>,
178
+ ): Promise<BaseEvent[]> {
179
+ return new Promise((resolve, reject) => {
180
+ const events: BaseEvent[] = [];
181
+ const subscription = observable.subscribe({
182
+ next: (event) => events.push(event),
183
+ error: (err: unknown) => reject(err),
184
+ complete: () => resolve(events),
185
+ });
186
+
187
+ // Set a timeout to prevent hanging tests
188
+ setTimeout(() => {
189
+ subscription.unsubscribe();
190
+ reject(new Error("Observable did not complete within timeout"));
191
+ }, 5000);
192
+ });
193
+ }