@mastra/server 0.0.0-cloudflare-deployer-dont-install-deps-20250714111754 → 0.0.0-configure-project-root-for-private-packages-20250919100548

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 (320) hide show
  1. package/CHANGELOG.md +3722 -0
  2. package/README.md +0 -5
  3. package/dist/{chunk-SDPGVWQJ.cjs → chunk-3THIIWWW.cjs} +108 -136
  4. package/dist/chunk-3THIIWWW.cjs.map +1 -0
  5. package/dist/{chunk-RSEO4XPX.js → chunk-4QCXUEAT.js} +11 -2
  6. package/dist/chunk-4QCXUEAT.js.map +1 -0
  7. package/dist/chunk-4RRMWXQ2.js +3522 -0
  8. package/dist/chunk-4RRMWXQ2.js.map +1 -0
  9. package/dist/chunk-5DP5XZH6.cjs +928 -0
  10. package/dist/chunk-5DP5XZH6.cjs.map +1 -0
  11. package/dist/{chunk-GHC4YV6R.js → chunk-5QUKZCEF.js} +107 -135
  12. package/dist/chunk-5QUKZCEF.js.map +1 -0
  13. package/dist/chunk-66YYHFGF.js +761 -0
  14. package/dist/chunk-66YYHFGF.js.map +1 -0
  15. package/dist/chunk-6GMFZ5LK.js +2774 -0
  16. package/dist/chunk-6GMFZ5LK.js.map +1 -0
  17. package/dist/chunk-743UIDHI.cjs +2013 -0
  18. package/dist/chunk-743UIDHI.cjs.map +1 -0
  19. package/dist/{chunk-2KZFMI6P.cjs → chunk-7NADHFD2.cjs} +2 -0
  20. package/dist/chunk-7NADHFD2.cjs.map +1 -0
  21. package/dist/chunk-7QEJ5QG5.js +151 -0
  22. package/dist/chunk-7QEJ5QG5.js.map +1 -0
  23. package/dist/{chunk-4D66QEKC.js → chunk-A3AL7EWJ.js} +5 -3
  24. package/dist/chunk-A3AL7EWJ.js.map +1 -0
  25. package/dist/chunk-AK2FXLLB.cjs +849 -0
  26. package/dist/chunk-AK2FXLLB.cjs.map +1 -0
  27. package/dist/{chunk-LF7P5PLR.js → chunk-CY4TP3FK.js} +3 -1
  28. package/dist/chunk-CY4TP3FK.js.map +1 -0
  29. package/dist/chunk-EMMSS5I5.cjs +37 -0
  30. package/dist/chunk-EMMSS5I5.cjs.map +1 -0
  31. package/dist/chunk-EMNGA4R4.js +845 -0
  32. package/dist/chunk-EMNGA4R4.js.map +1 -0
  33. package/dist/chunk-FALVL2VV.cjs +3525 -0
  34. package/dist/chunk-FALVL2VV.cjs.map +1 -0
  35. package/dist/chunk-FQNT7PI4.js +937 -0
  36. package/dist/chunk-FQNT7PI4.js.map +1 -0
  37. package/dist/chunk-G3PMV62Z.js +33 -0
  38. package/dist/chunk-G3PMV62Z.js.map +1 -0
  39. package/dist/chunk-G4PUALCE.cjs +28 -0
  40. package/dist/chunk-G4PUALCE.cjs.map +1 -0
  41. package/dist/chunk-G7PLDFT6.js +15711 -0
  42. package/dist/chunk-G7PLDFT6.js.map +1 -0
  43. package/dist/chunk-GU4EWMZB.cjs +769 -0
  44. package/dist/chunk-GU4EWMZB.cjs.map +1 -0
  45. package/dist/chunk-GUI3CROV.cjs +159 -0
  46. package/dist/chunk-GUI3CROV.cjs.map +1 -0
  47. package/dist/chunk-HJ4EQIE6.cjs +15747 -0
  48. package/dist/chunk-HJ4EQIE6.cjs.map +1 -0
  49. package/dist/chunk-HJQKWRKQ.cjs +764 -0
  50. package/dist/chunk-HJQKWRKQ.cjs.map +1 -0
  51. package/dist/{chunk-LI436ITD.cjs → chunk-HVBBFCDH.cjs} +1041 -762
  52. package/dist/chunk-HVBBFCDH.cjs.map +1 -0
  53. package/dist/chunk-HZJRQ5L3.cjs +1411 -0
  54. package/dist/chunk-HZJRQ5L3.cjs.map +1 -0
  55. package/dist/chunk-IGFMAZZ5.cjs +1150 -0
  56. package/dist/chunk-IGFMAZZ5.cjs.map +1 -0
  57. package/dist/chunk-ILESGJ6N.js +524 -0
  58. package/dist/chunk-ILESGJ6N.js.map +1 -0
  59. package/dist/chunk-IOQGI4ML.js +931 -0
  60. package/dist/chunk-IOQGI4ML.js.map +1 -0
  61. package/dist/chunk-J7BPKKOG.cjs +163 -0
  62. package/dist/chunk-J7BPKKOG.cjs.map +1 -0
  63. package/dist/{chunk-KHZKYUNR.js → chunk-JRDEOHAJ.js} +23 -13
  64. package/dist/chunk-JRDEOHAJ.js.map +1 -0
  65. package/dist/{chunk-H7DMHBKY.js → chunk-K4GZBPXF.js} +235 -57
  66. package/dist/chunk-K4GZBPXF.js.map +1 -0
  67. package/dist/{chunk-JMLYCXMK.cjs → chunk-KNGXRN26.cjs} +48 -45
  68. package/dist/chunk-KNGXRN26.cjs.map +1 -0
  69. package/dist/{chunk-RG473F6Y.js → chunk-KV6VHX4V.js} +24 -5
  70. package/dist/chunk-KV6VHX4V.js.map +1 -0
  71. package/dist/chunk-L265APUD.cjs +69 -0
  72. package/dist/chunk-L265APUD.cjs.map +1 -0
  73. package/dist/chunk-LF2ZLOFP.js +767 -0
  74. package/dist/chunk-LF2ZLOFP.js.map +1 -0
  75. package/dist/chunk-LYPU75T6.js +1147 -0
  76. package/dist/chunk-LYPU75T6.js.map +1 -0
  77. package/dist/{chunk-LCM566I4.js → chunk-MMROOK5J.js} +2 -0
  78. package/dist/chunk-MMROOK5J.js.map +1 -0
  79. package/dist/chunk-N35YCWQ5.cjs +540 -0
  80. package/dist/chunk-N35YCWQ5.cjs.map +1 -0
  81. package/dist/{chunk-MEGCYGBU.js → chunk-N7F33WAD.js} +1013 -762
  82. package/dist/chunk-N7F33WAD.js.map +1 -0
  83. package/dist/chunk-NG5IVLEZ.js +1012 -0
  84. package/dist/chunk-NG5IVLEZ.js.map +1 -0
  85. package/dist/chunk-NLWACBE7.cjs +128 -0
  86. package/dist/chunk-NLWACBE7.cjs.map +1 -0
  87. package/dist/chunk-NZMDHQVP.cjs +697 -0
  88. package/dist/chunk-NZMDHQVP.cjs.map +1 -0
  89. package/dist/chunk-OGW6HHVI.js +1408 -0
  90. package/dist/chunk-OGW6HHVI.js.map +1 -0
  91. package/dist/chunk-OZLRIVC4.cjs +588 -0
  92. package/dist/chunk-OZLRIVC4.cjs.map +1 -0
  93. package/dist/chunk-P7CIEIJ3.js +925 -0
  94. package/dist/chunk-P7CIEIJ3.js.map +1 -0
  95. package/dist/chunk-P7RBMCBE.cjs +934 -0
  96. package/dist/chunk-P7RBMCBE.cjs.map +1 -0
  97. package/dist/chunk-PPYGWINI.cjs +2777 -0
  98. package/dist/chunk-PPYGWINI.cjs.map +1 -0
  99. package/dist/{chunk-G7KH752Y.cjs → chunk-PWTXZZTR.cjs} +28 -8
  100. package/dist/chunk-PWTXZZTR.cjs.map +1 -0
  101. package/dist/chunk-R7NOGUZG.js +65 -0
  102. package/dist/chunk-R7NOGUZG.js.map +1 -0
  103. package/dist/chunk-RCHEPTZZ.js +2006 -0
  104. package/dist/chunk-RCHEPTZZ.js.map +1 -0
  105. package/dist/{chunk-PZQDCRPV.cjs → chunk-RE4RPXT2.cjs} +4 -2
  106. package/dist/chunk-RE4RPXT2.cjs.map +1 -0
  107. package/dist/chunk-SIGXR3JT.cjs +1043 -0
  108. package/dist/chunk-SIGXR3JT.cjs.map +1 -0
  109. package/dist/{chunk-QGX47B5D.cjs → chunk-SPLSYTYW.cjs} +11 -9
  110. package/dist/chunk-SPLSYTYW.cjs.map +1 -0
  111. package/dist/chunk-SQY4T6EJ.js +571 -0
  112. package/dist/chunk-SQY4T6EJ.js.map +1 -0
  113. package/dist/{chunk-LRCAAFUA.js → chunk-SYRRSBGL.js} +46 -12
  114. package/dist/chunk-SYRRSBGL.js.map +1 -0
  115. package/dist/{chunk-7TP2LX5L.cjs → chunk-T3TIA3O6.cjs} +20 -18
  116. package/dist/chunk-T3TIA3O6.cjs.map +1 -0
  117. package/dist/{chunk-5PQQ42EZ.js → chunk-TTHEEIZ3.js} +13 -10
  118. package/dist/chunk-TTHEEIZ3.js.map +1 -0
  119. package/dist/chunk-TVSIG4JE.cjs +940 -0
  120. package/dist/chunk-TVSIG4JE.cjs.map +1 -0
  121. package/dist/{chunk-WNVFNNWN.js → chunk-WHN4VX55.js} +5 -3
  122. package/dist/chunk-WHN4VX55.js.map +1 -0
  123. package/dist/dist-26HWEQY6.js +3 -0
  124. package/dist/dist-26HWEQY6.js.map +1 -0
  125. package/dist/dist-3A5DXB37.cjs +20 -0
  126. package/dist/dist-3A5DXB37.cjs.map +1 -0
  127. package/dist/dist-3SJKQJGY.cjs +16 -0
  128. package/dist/dist-3SJKQJGY.cjs.map +1 -0
  129. package/dist/dist-4ZQSPE5K.js +3 -0
  130. package/dist/dist-4ZQSPE5K.js.map +1 -0
  131. package/dist/dist-5W5QNRTD.js +3 -0
  132. package/dist/dist-5W5QNRTD.js.map +1 -0
  133. package/dist/dist-653SRMPL.js +3 -0
  134. package/dist/dist-653SRMPL.js.map +1 -0
  135. package/dist/dist-6U6EFC5C.cjs +16 -0
  136. package/dist/dist-6U6EFC5C.cjs.map +1 -0
  137. package/dist/dist-7IHNNYMF.cjs +16 -0
  138. package/dist/dist-7IHNNYMF.cjs.map +1 -0
  139. package/dist/dist-B5IPRF6W.js +3 -0
  140. package/dist/dist-B5IPRF6W.js.map +1 -0
  141. package/dist/dist-EOMYFT4Y.cjs +16 -0
  142. package/dist/dist-EOMYFT4Y.cjs.map +1 -0
  143. package/dist/dist-EZZMMMNT.cjs +16 -0
  144. package/dist/dist-EZZMMMNT.cjs.map +1 -0
  145. package/dist/dist-F2ET4MNO.cjs +16 -0
  146. package/dist/dist-F2ET4MNO.cjs.map +1 -0
  147. package/dist/dist-H64VX6DE.js +3 -0
  148. package/dist/dist-H64VX6DE.js.map +1 -0
  149. package/dist/dist-HY7RMLJQ.cjs +16 -0
  150. package/dist/dist-HY7RMLJQ.cjs.map +1 -0
  151. package/dist/dist-M6S4P3FJ.js +3 -0
  152. package/dist/dist-M6S4P3FJ.js.map +1 -0
  153. package/dist/dist-NR7QSCQT.js +3 -0
  154. package/dist/dist-NR7QSCQT.js.map +1 -0
  155. package/dist/dist-QLFMCMCX.js +3 -0
  156. package/dist/dist-QLFMCMCX.js.map +1 -0
  157. package/dist/dist-UY46BFRP.js +3 -0
  158. package/dist/dist-UY46BFRP.js.map +1 -0
  159. package/dist/dist-WCQDRTIV.cjs +16 -0
  160. package/dist/dist-WCQDRTIV.cjs.map +1 -0
  161. package/dist/dist-WKYB3LTJ.cjs +16 -0
  162. package/dist/dist-WKYB3LTJ.cjs.map +1 -0
  163. package/dist/index.cjs +6 -0
  164. package/dist/index.cjs.map +1 -0
  165. package/dist/index.d.ts +1 -0
  166. package/dist/index.d.ts.map +1 -0
  167. package/dist/index.js +5 -0
  168. package/dist/index.js.map +1 -0
  169. package/dist/server/a2a/protocol.d.ts +8 -0
  170. package/dist/server/a2a/protocol.d.ts.map +1 -0
  171. package/dist/server/a2a/store.cjs +25 -0
  172. package/dist/server/a2a/store.cjs.map +1 -0
  173. package/dist/server/a2a/store.d.ts +14 -0
  174. package/dist/server/a2a/store.d.ts.map +1 -0
  175. package/dist/server/a2a/store.js +23 -0
  176. package/dist/server/a2a/store.js.map +1 -0
  177. package/dist/server/a2a/tasks.d.ts +20 -0
  178. package/dist/server/a2a/tasks.d.ts.map +1 -0
  179. package/dist/server/handlers/a2a.cjs +13 -11
  180. package/dist/server/handlers/a2a.cjs.map +1 -0
  181. package/dist/server/handlers/a2a.d.ts +68 -6
  182. package/dist/server/handlers/a2a.d.ts.map +1 -0
  183. package/dist/server/handlers/a2a.js +3 -1
  184. package/dist/server/handlers/a2a.js.map +1 -0
  185. package/dist/server/handlers/agent-builder.cjs +68 -0
  186. package/dist/server/handlers/agent-builder.cjs.map +1 -0
  187. package/dist/server/handlers/agent-builder.d.ts +88 -0
  188. package/dist/server/handlers/agent-builder.d.ts.map +1 -0
  189. package/dist/server/handlers/agent-builder.js +3 -0
  190. package/dist/server/handlers/agent-builder.js.map +1 -0
  191. package/dist/server/handlers/agents.cjs +41 -7
  192. package/dist/server/handlers/agents.cjs.map +1 -0
  193. package/dist/server/handlers/agents.d.ts +139 -6
  194. package/dist/server/handlers/agents.d.ts.map +1 -0
  195. package/dist/server/handlers/agents.js +3 -1
  196. package/dist/server/handlers/agents.js.map +1 -0
  197. package/dist/server/handlers/error.cjs +4 -2
  198. package/dist/server/handlers/error.cjs.map +1 -0
  199. package/dist/server/handlers/error.d.ts +2 -1
  200. package/dist/server/handlers/error.d.ts.map +1 -0
  201. package/dist/server/handlers/error.js +3 -1
  202. package/dist/server/handlers/error.js.map +1 -0
  203. package/dist/server/handlers/legacyWorkflows.cjs +13 -11
  204. package/dist/server/handlers/legacyWorkflows.cjs.map +1 -0
  205. package/dist/server/handlers/legacyWorkflows.d.ts +59 -10
  206. package/dist/server/handlers/legacyWorkflows.d.ts.map +1 -0
  207. package/dist/server/handlers/legacyWorkflows.js +3 -1
  208. package/dist/server/handlers/legacyWorkflows.js.map +1 -0
  209. package/dist/server/handlers/logs.cjs +6 -4
  210. package/dist/server/handlers/logs.cjs.map +1 -0
  211. package/dist/server/handlers/logs.d.ts +34 -3
  212. package/dist/server/handlers/logs.d.ts.map +1 -0
  213. package/dist/server/handlers/logs.js +3 -1
  214. package/dist/server/handlers/logs.js.map +1 -0
  215. package/dist/server/handlers/memory.cjs +33 -11
  216. package/dist/server/handlers/memory.cjs.map +1 -0
  217. package/dist/server/handlers/memory.d.ts +118 -10
  218. package/dist/server/handlers/memory.d.ts.map +1 -0
  219. package/dist/server/handlers/memory.js +3 -1
  220. package/dist/server/handlers/memory.js.map +1 -0
  221. package/dist/server/handlers/observability.cjs +16 -0
  222. package/dist/server/handlers/observability.cjs.map +1 -0
  223. package/dist/server/handlers/observability.d.ts +23 -0
  224. package/dist/server/handlers/observability.d.ts.map +1 -0
  225. package/dist/server/handlers/observability.js +3 -0
  226. package/dist/server/handlers/observability.js.map +1 -0
  227. package/dist/server/handlers/scores.cjs +32 -0
  228. package/dist/server/handlers/scores.cjs.map +1 -0
  229. package/dist/server/handlers/scores.d.ts +49 -0
  230. package/dist/server/handlers/scores.d.ts.map +1 -0
  231. package/dist/server/handlers/scores.js +3 -0
  232. package/dist/server/handlers/scores.js.map +1 -0
  233. package/dist/server/handlers/telemetry.cjs +9 -3
  234. package/dist/server/handlers/telemetry.cjs.map +1 -0
  235. package/dist/server/handlers/telemetry.d.ts +33 -2
  236. package/dist/server/handlers/telemetry.d.ts.map +1 -0
  237. package/dist/server/handlers/telemetry.js +3 -1
  238. package/dist/server/handlers/telemetry.js.map +1 -0
  239. package/dist/server/handlers/tools.cjs +11 -5
  240. package/dist/server/handlers/tools.cjs.map +1 -0
  241. package/dist/server/handlers/tools.d.ts +25 -4
  242. package/dist/server/handlers/tools.d.ts.map +1 -0
  243. package/dist/server/handlers/tools.js +3 -1
  244. package/dist/server/handlers/tools.js.map +1 -0
  245. package/dist/server/handlers/utils.cjs +8 -2
  246. package/dist/server/handlers/utils.cjs.map +1 -0
  247. package/dist/server/handlers/utils.d.ts +8 -1
  248. package/dist/server/handlers/utils.d.ts.map +1 -0
  249. package/dist/server/handlers/utils.js +3 -1
  250. package/dist/server/handlers/utils.js.map +1 -0
  251. package/dist/server/handlers/vNextNetwork.cjs +26 -24
  252. package/dist/server/handlers/vNextNetwork.cjs.map +1 -0
  253. package/dist/server/handlers/vNextNetwork.d.ts +246 -6
  254. package/dist/server/handlers/vNextNetwork.d.ts.map +1 -0
  255. package/dist/server/handlers/vNextNetwork.js +11 -9
  256. package/dist/server/handlers/vNextNetwork.js.map +1 -0
  257. package/dist/server/handlers/vector.cjs +9 -7
  258. package/dist/server/handlers/vector.cjs.map +1 -0
  259. package/dist/server/handlers/vector.d.ts +51 -6
  260. package/dist/server/handlers/vector.d.ts.map +1 -0
  261. package/dist/server/handlers/vector.js +3 -1
  262. package/dist/server/handlers/vector.js.map +1 -0
  263. package/dist/server/handlers/voice.cjs +7 -5
  264. package/dist/server/handlers/voice.cjs.map +1 -0
  265. package/dist/server/handlers/voice.d.ts +41 -4
  266. package/dist/server/handlers/voice.d.ts.map +1 -0
  267. package/dist/server/handlers/voice.js +3 -1
  268. package/dist/server/handlers/voice.js.map +1 -0
  269. package/dist/server/handlers/workflows.cjs +29 -15
  270. package/dist/server/handlers/workflows.cjs.map +1 -0
  271. package/dist/server/handlers/workflows.d.ts +82 -14
  272. package/dist/server/handlers/workflows.d.ts.map +1 -0
  273. package/dist/server/handlers/workflows.js +3 -1
  274. package/dist/server/handlers/workflows.js.map +1 -0
  275. package/dist/server/handlers.cjs +44 -32
  276. package/dist/server/handlers.cjs.map +1 -0
  277. package/dist/server/handlers.d.ts +14 -11
  278. package/dist/server/handlers.d.ts.map +1 -0
  279. package/dist/server/handlers.js +15 -11
  280. package/dist/server/handlers.js.map +1 -0
  281. package/dist/server/http-exception.d.ts +87 -0
  282. package/dist/server/http-exception.d.ts.map +1 -0
  283. package/dist/server/types.d.ts +10 -0
  284. package/dist/server/types.d.ts.map +1 -0
  285. package/dist/server/utils.d.ts +42 -0
  286. package/dist/server/utils.d.ts.map +1 -0
  287. package/package.json +45 -14
  288. package/dist/_tsup-dts-rollup.d.cts +0 -1107
  289. package/dist/_tsup-dts-rollup.d.ts +0 -1107
  290. package/dist/chunk-2SLFAFTR.cjs +0 -148
  291. package/dist/chunk-3CNDE7QY.cjs +0 -308
  292. package/dist/chunk-75ZPJI57.cjs +0 -9
  293. package/dist/chunk-B2PAS2IB.cjs +0 -514
  294. package/dist/chunk-BK4XT6EG.js +0 -270
  295. package/dist/chunk-CCGRCYWJ.cjs +0 -18
  296. package/dist/chunk-CRCR3ZUK.js +0 -142
  297. package/dist/chunk-FRVBFMO2.cjs +0 -128
  298. package/dist/chunk-KOHWJYJT.js +0 -296
  299. package/dist/chunk-LZ3VJXSO.cjs +0 -278
  300. package/dist/chunk-MLKGABMK.js +0 -7
  301. package/dist/chunk-RHSWAXKB.cjs +0 -118
  302. package/dist/index.d.cts +0 -1
  303. package/dist/server/handlers/a2a.d.cts +0 -6
  304. package/dist/server/handlers/agents.d.cts +0 -6
  305. package/dist/server/handlers/error.d.cts +0 -1
  306. package/dist/server/handlers/legacyWorkflows.d.cts +0 -10
  307. package/dist/server/handlers/logs.d.cts +0 -3
  308. package/dist/server/handlers/memory.d.cts +0 -10
  309. package/dist/server/handlers/network.cjs +0 -22
  310. package/dist/server/handlers/network.d.cts +0 -4
  311. package/dist/server/handlers/network.d.ts +0 -4
  312. package/dist/server/handlers/network.js +0 -1
  313. package/dist/server/handlers/telemetry.d.cts +0 -2
  314. package/dist/server/handlers/tools.d.cts +0 -4
  315. package/dist/server/handlers/utils.d.cts +0 -1
  316. package/dist/server/handlers/vNextNetwork.d.cts +0 -6
  317. package/dist/server/handlers/vector.d.cts +0 -6
  318. package/dist/server/handlers/voice.d.cts +0 -4
  319. package/dist/server/handlers/workflows.d.cts +0 -14
  320. package/dist/server/handlers.d.cts +0 -11
@@ -1,8 +1,9 @@
1
- import { stringify, esm_default } from './chunk-MEGCYGBU.js';
2
- import { handleError } from './chunk-LF7P5PLR.js';
3
- import { HTTPException } from './chunk-LCM566I4.js';
4
- import { __export } from './chunk-MLKGABMK.js';
5
- import { ReadableStream } from 'stream/web';
1
+ import { stringify } from './chunk-LF2ZLOFP.js';
2
+ import { handleError } from './chunk-CY4TP3FK.js';
3
+ import { HTTPException } from './chunk-MMROOK5J.js';
4
+ import { __export } from './chunk-G3PMV62Z.js';
5
+ import { ReadableStream, TransformStream } from 'stream/web';
6
+ import { zodToJsonSchema } from '@mastra/core/utils/zod-to-json';
6
7
 
7
8
  // src/server/handlers/workflows.ts
8
9
  var workflows_exports = {};
@@ -14,11 +15,14 @@ __export(workflows_exports, {
14
15
  getWorkflowRunExecutionResultHandler: () => getWorkflowRunExecutionResultHandler,
15
16
  getWorkflowRunsHandler: () => getWorkflowRunsHandler,
16
17
  getWorkflowsHandler: () => getWorkflowsHandler,
18
+ observeStreamWorkflowHandler: () => observeStreamWorkflowHandler,
17
19
  resumeAsyncWorkflowHandler: () => resumeAsyncWorkflowHandler,
20
+ resumeStreamWorkflowHandler: () => resumeStreamWorkflowHandler,
18
21
  resumeWorkflowHandler: () => resumeWorkflowHandler,
19
22
  sendWorkflowRunEventHandler: () => sendWorkflowRunEventHandler,
20
23
  startAsyncWorkflowHandler: () => startAsyncWorkflowHandler,
21
24
  startWorkflowRunHandler: () => startWorkflowRunHandler,
25
+ streamVNextWorkflowHandler: () => streamVNextWorkflowHandler,
22
26
  streamWorkflowHandler: () => streamWorkflowHandler,
23
27
  watchWorkflowHandler: () => watchWorkflowHandler
24
28
  });
@@ -28,10 +32,10 @@ function getSteps(steps, path) {
28
32
  acc[fullKey] = {
29
33
  id: step.id,
30
34
  description: step.description,
31
- inputSchema: step.inputSchema ? stringify(esm_default(step.inputSchema)) : void 0,
32
- outputSchema: step.outputSchema ? stringify(esm_default(step.outputSchema)) : void 0,
33
- resumeSchema: step.resumeSchema ? stringify(esm_default(step.resumeSchema)) : void 0,
34
- suspendSchema: step.suspendSchema ? stringify(esm_default(step.suspendSchema)) : void 0,
35
+ inputSchema: step.inputSchema ? stringify(zodToJsonSchema(step.inputSchema)) : void 0,
36
+ outputSchema: step.outputSchema ? stringify(zodToJsonSchema(step.outputSchema)) : void 0,
37
+ resumeSchema: step.resumeSchema ? stringify(zodToJsonSchema(step.resumeSchema)) : void 0,
38
+ suspendSchema: step.suspendSchema ? stringify(zodToJsonSchema(step.suspendSchema)) : void 0,
35
39
  isWorkflow: step.component === "WORKFLOW"
36
40
  };
37
41
  if (step.component === "WORKFLOW" && step.steps) {
@@ -41,29 +45,99 @@ function getSteps(steps, path) {
41
45
  return acc;
42
46
  }, {});
43
47
  }
48
+ function getWorkflowInfo(workflow) {
49
+ return {
50
+ name: workflow.name,
51
+ description: workflow.description,
52
+ steps: Object.entries(workflow.steps).reduce((acc, [key, step]) => {
53
+ acc[key] = {
54
+ id: step.id,
55
+ description: step.description,
56
+ inputSchema: step.inputSchema ? stringify(zodToJsonSchema(step.inputSchema)) : void 0,
57
+ outputSchema: step.outputSchema ? stringify(zodToJsonSchema(step.outputSchema)) : void 0,
58
+ resumeSchema: step.resumeSchema ? stringify(zodToJsonSchema(step.resumeSchema)) : void 0,
59
+ suspendSchema: step.suspendSchema ? stringify(zodToJsonSchema(step.suspendSchema)) : void 0
60
+ };
61
+ return acc;
62
+ }, {}),
63
+ allSteps: getSteps(workflow.steps) || {},
64
+ stepGraph: workflow.serializedStepGraph,
65
+ inputSchema: workflow.inputSchema ? stringify(zodToJsonSchema(workflow.inputSchema)) : void 0,
66
+ outputSchema: workflow.outputSchema ? stringify(zodToJsonSchema(workflow.outputSchema)) : void 0
67
+ };
68
+ }
69
+ var WorkflowRegistry = class {
70
+ static additionalWorkflows = {};
71
+ /**
72
+ * Register a workflow temporarily
73
+ */
74
+ static registerTemporaryWorkflow(id, workflow) {
75
+ this.additionalWorkflows[id] = workflow;
76
+ }
77
+ /**
78
+ * Register all workflows from map
79
+ */
80
+ static registerTemporaryWorkflows(workflows, mastra) {
81
+ for (const [id, workflow] of Object.entries(workflows)) {
82
+ if (mastra) {
83
+ workflow.__registerMastra(mastra);
84
+ workflow.__registerPrimitives({
85
+ logger: mastra.getLogger(),
86
+ telemetry: mastra.getTelemetry(),
87
+ storage: mastra.getStorage(),
88
+ memory: mastra.getMemory(),
89
+ agents: mastra.getAgents(),
90
+ tts: mastra.getTTS(),
91
+ vectors: mastra.getVectors()
92
+ });
93
+ }
94
+ this.additionalWorkflows[id] = workflow;
95
+ }
96
+ }
97
+ /**
98
+ * Get a workflow by ID from the registry (returns undefined if not found)
99
+ */
100
+ static getWorkflow(workflowId) {
101
+ return this.additionalWorkflows[workflowId];
102
+ }
103
+ /**
104
+ * Get all workflows from the registry
105
+ */
106
+ static getAllWorkflows() {
107
+ return { ...this.additionalWorkflows };
108
+ }
109
+ /**
110
+ * Clean up a temporary workflow
111
+ */
112
+ static cleanupTemporaryWorkflow(workflowId) {
113
+ delete this.additionalWorkflows[workflowId];
114
+ }
115
+ /**
116
+ * Clean up all registered workflows
117
+ */
118
+ static cleanup() {
119
+ this.additionalWorkflows = {};
120
+ }
121
+ /**
122
+ * Check if a workflow ID is a valid agent-builder workflow
123
+ */
124
+ static isAgentBuilderWorkflow(workflowId) {
125
+ return workflowId in this.additionalWorkflows;
126
+ }
127
+ /**
128
+ * Get all registered temporary workflow IDs (for debugging)
129
+ */
130
+ static getRegisteredWorkflowIds() {
131
+ return Object.keys(this.additionalWorkflows);
132
+ }
133
+ };
134
+
135
+ // src/server/handlers/workflows.ts
44
136
  async function getWorkflowsHandler({ mastra }) {
45
137
  try {
46
138
  const workflows = mastra.getWorkflows({ serialized: false });
47
139
  const _workflows = Object.entries(workflows).reduce((acc, [key, workflow]) => {
48
- acc[key] = {
49
- name: workflow.name,
50
- description: workflow.description,
51
- steps: Object.entries(workflow.steps).reduce((acc2, [key2, step]) => {
52
- acc2[key2] = {
53
- id: step.id,
54
- description: step.description,
55
- inputSchema: step.inputSchema ? stringify(esm_default(step.inputSchema)) : void 0,
56
- outputSchema: step.outputSchema ? stringify(esm_default(step.outputSchema)) : void 0,
57
- resumeSchema: step.resumeSchema ? stringify(esm_default(step.resumeSchema)) : void 0,
58
- suspendSchema: step.suspendSchema ? stringify(esm_default(step.suspendSchema)) : void 0
59
- };
60
- return acc2;
61
- }, {}),
62
- allSteps: getSteps(workflow.steps) || {},
63
- stepGraph: workflow.serializedStepGraph,
64
- inputSchema: workflow.inputSchema ? stringify(esm_default(workflow.inputSchema)) : void 0,
65
- outputSchema: workflow.outputSchema ? stringify(esm_default(workflow.outputSchema)) : void 0
66
- };
140
+ acc[key] = getWorkflowInfo(workflow);
67
141
  return acc;
68
142
  }, {});
69
143
  return _workflows;
@@ -77,10 +151,13 @@ async function getWorkflowsFromSystem({ mastra, workflowId }) {
77
151
  throw new HTTPException(400, { message: "Workflow ID is required" });
78
152
  }
79
153
  let workflow;
80
- try {
81
- workflow = mastra.getWorkflow(workflowId);
82
- } catch (error) {
83
- logger.debug("Error getting workflow, searching agents for workflow", error);
154
+ workflow = WorkflowRegistry.getWorkflow(workflowId);
155
+ if (!workflow) {
156
+ try {
157
+ workflow = mastra.getWorkflow(workflowId);
158
+ } catch (error) {
159
+ logger.debug("Error getting workflow, searching agents for workflow", error);
160
+ }
84
161
  }
85
162
  if (!workflow) {
86
163
  logger.debug("Workflow not found, searching agents for workflow", { workflowId });
@@ -114,25 +191,7 @@ async function getWorkflowByIdHandler({ mastra, workflowId }) {
114
191
  if (!workflow) {
115
192
  throw new HTTPException(404, { message: "Workflow not found" });
116
193
  }
117
- return {
118
- steps: Object.entries(workflow.steps).reduce((acc, [key, step]) => {
119
- acc[key] = {
120
- id: step.id,
121
- description: step.description,
122
- inputSchema: step.inputSchema ? stringify(esm_default(step.inputSchema)) : void 0,
123
- outputSchema: step.outputSchema ? stringify(esm_default(step.outputSchema)) : void 0,
124
- resumeSchema: step.resumeSchema ? stringify(esm_default(step.resumeSchema)) : void 0,
125
- suspendSchema: step.suspendSchema ? stringify(esm_default(step.suspendSchema)) : void 0
126
- };
127
- return acc;
128
- }, {}),
129
- allSteps: getSteps(workflow.steps) || {},
130
- name: workflow.name,
131
- description: workflow.description,
132
- stepGraph: workflow.serializedStepGraph,
133
- inputSchema: workflow.inputSchema ? stringify(esm_default(workflow.inputSchema)) : void 0,
134
- outputSchema: workflow.outputSchema ? stringify(esm_default(workflow.outputSchema)) : void 0
135
- };
194
+ return getWorkflowInfo(workflow);
136
195
  } catch (error) {
137
196
  return handleError(error, "Error getting workflow");
138
197
  }
@@ -266,7 +325,8 @@ async function startWorkflowRunHandler({
266
325
  async function watchWorkflowHandler({
267
326
  mastra,
268
327
  workflowId,
269
- runId
328
+ runId,
329
+ eventType = "watch"
270
330
  }) {
271
331
  try {
272
332
  if (!workflowId) {
@@ -288,22 +348,27 @@ async function watchWorkflowHandler({
288
348
  let asyncRef = null;
289
349
  const stream = new ReadableStream({
290
350
  start(controller) {
291
- unwatch = _run.watch(({ type, payload, eventTimestamp }) => {
351
+ unwatch = _run.watch((event) => {
352
+ const { type, payload, eventTimestamp } = event;
292
353
  controller.enqueue(JSON.stringify({ type, payload, eventTimestamp, runId }));
293
354
  if (asyncRef) {
294
355
  clearImmediate(asyncRef);
295
356
  asyncRef = null;
296
357
  }
297
358
  asyncRef = setImmediate(async () => {
298
- const runDone = payload.workflowState.status !== "running";
359
+ const runDone = eventType === "watch" ? payload.workflowState.status !== "running" : type === "finish";
299
360
  if (runDone) {
300
361
  controller.close();
301
362
  unwatch?.();
302
363
  }
303
364
  });
304
- });
365
+ }, eventType);
305
366
  },
306
367
  cancel() {
368
+ if (asyncRef) {
369
+ clearImmediate(asyncRef);
370
+ asyncRef = null;
371
+ }
307
372
  unwatch?.();
308
373
  }
309
374
  });
@@ -330,16 +395,91 @@ async function streamWorkflowHandler({
330
395
  if (!workflow) {
331
396
  throw new HTTPException(404, { message: "Workflow not found" });
332
397
  }
398
+ const serverCache = mastra.getServerCache();
333
399
  const run = await workflow.createRunAsync({ runId });
334
400
  const result = run.stream({
335
401
  inputData,
336
- runtimeContext
402
+ runtimeContext,
403
+ onChunk: async (chunk) => {
404
+ if (serverCache) {
405
+ const cacheKey = runId;
406
+ await serverCache.listPush(cacheKey, chunk);
407
+ }
408
+ }
337
409
  });
338
410
  return result;
339
411
  } catch (error) {
340
412
  return handleError(error, "Error executing workflow");
341
413
  }
342
414
  }
415
+ async function observeStreamWorkflowHandler({
416
+ mastra,
417
+ workflowId,
418
+ runId
419
+ }) {
420
+ try {
421
+ if (!workflowId) {
422
+ throw new HTTPException(400, { message: "Workflow ID is required" });
423
+ }
424
+ if (!runId) {
425
+ throw new HTTPException(400, { message: "runId required to observe workflow stream" });
426
+ }
427
+ const { workflow } = await getWorkflowsFromSystem({ mastra, workflowId });
428
+ if (!workflow) {
429
+ throw new HTTPException(404, { message: "Workflow not found" });
430
+ }
431
+ const run = await workflow.getWorkflowRunById(runId);
432
+ if (!run) {
433
+ throw new HTTPException(404, { message: "Workflow run not found" });
434
+ }
435
+ const _run = await workflow.createRunAsync({ runId });
436
+ const serverCache = mastra.getServerCache();
437
+ if (!serverCache) {
438
+ throw new HTTPException(500, { message: "Server cache not found" });
439
+ }
440
+ const transformStream = new TransformStream();
441
+ const writer = transformStream.writable.getWriter();
442
+ const cachedRunChunks = await serverCache.listFromTo(runId, 0);
443
+ for (const chunk of cachedRunChunks) {
444
+ await writer.write(chunk);
445
+ }
446
+ writer.releaseLock();
447
+ const result = _run.observeStream();
448
+ return result.stream?.pipeThrough(transformStream);
449
+ } catch (error) {
450
+ return handleError(error, "Error observing workflow stream");
451
+ }
452
+ }
453
+ async function streamVNextWorkflowHandler({
454
+ mastra,
455
+ runtimeContext,
456
+ workflowId,
457
+ runId,
458
+ inputData,
459
+ closeOnSuspend
460
+ }) {
461
+ try {
462
+ if (!workflowId) {
463
+ throw new HTTPException(400, { message: "Workflow ID is required" });
464
+ }
465
+ if (!runId) {
466
+ throw new HTTPException(400, { message: "runId required to stream workflow" });
467
+ }
468
+ const { workflow } = await getWorkflowsFromSystem({ mastra, workflowId });
469
+ if (!workflow) {
470
+ throw new HTTPException(404, { message: "Workflow not found" });
471
+ }
472
+ const run = await workflow.createRunAsync({ runId });
473
+ const result = run.streamVNext({
474
+ inputData,
475
+ runtimeContext,
476
+ closeOnSuspend
477
+ });
478
+ return result;
479
+ } catch (error) {
480
+ return handleError(error, "Error streaming workflow");
481
+ }
482
+ }
343
483
  async function resumeAsyncWorkflowHandler({
344
484
  mastra,
345
485
  workflowId,
@@ -412,6 +552,42 @@ async function resumeWorkflowHandler({
412
552
  return handleError(error, "Error resuming workflow");
413
553
  }
414
554
  }
555
+ async function resumeStreamWorkflowHandler({
556
+ mastra,
557
+ workflowId,
558
+ runId,
559
+ body,
560
+ runtimeContext
561
+ }) {
562
+ try {
563
+ if (!workflowId) {
564
+ throw new HTTPException(400, { message: "Workflow ID is required" });
565
+ }
566
+ if (!runId) {
567
+ throw new HTTPException(400, { message: "runId required to resume workflow" });
568
+ }
569
+ if (!body.step) {
570
+ throw new HTTPException(400, { message: "step required to resume workflow" });
571
+ }
572
+ const { workflow } = await getWorkflowsFromSystem({ mastra, workflowId });
573
+ if (!workflow) {
574
+ throw new HTTPException(404, { message: "Workflow not found" });
575
+ }
576
+ const run = await workflow.getWorkflowRunById(runId);
577
+ if (!run) {
578
+ throw new HTTPException(404, { message: "Workflow run not found" });
579
+ }
580
+ const _run = await workflow.createRunAsync({ runId });
581
+ const stream = await _run.resumeStreamVNext({
582
+ step: body.step,
583
+ resumeData: body.resumeData,
584
+ runtimeContext
585
+ });
586
+ return stream;
587
+ } catch (error) {
588
+ return handleError(error, "Error resuming workflow");
589
+ }
590
+ }
415
591
  async function getWorkflowRunsHandler({
416
592
  mastra,
417
593
  workflowId,
@@ -495,4 +671,6 @@ async function sendWorkflowRunEventHandler({
495
671
  }
496
672
  }
497
673
 
498
- export { cancelWorkflowRunHandler, createWorkflowRunHandler, getWorkflowByIdHandler, getWorkflowRunByIdHandler, getWorkflowRunExecutionResultHandler, getWorkflowRunsHandler, getWorkflowsHandler, resumeAsyncWorkflowHandler, resumeWorkflowHandler, sendWorkflowRunEventHandler, startAsyncWorkflowHandler, startWorkflowRunHandler, streamWorkflowHandler, watchWorkflowHandler, workflows_exports };
674
+ export { WorkflowRegistry, cancelWorkflowRunHandler, createWorkflowRunHandler, getWorkflowByIdHandler, getWorkflowInfo, getWorkflowRunByIdHandler, getWorkflowRunExecutionResultHandler, getWorkflowRunsHandler, getWorkflowsHandler, observeStreamWorkflowHandler, resumeAsyncWorkflowHandler, resumeStreamWorkflowHandler, resumeWorkflowHandler, sendWorkflowRunEventHandler, startAsyncWorkflowHandler, startWorkflowRunHandler, streamVNextWorkflowHandler, streamWorkflowHandler, watchWorkflowHandler, workflows_exports };
675
+ //# sourceMappingURL=chunk-K4GZBPXF.js.map
676
+ //# sourceMappingURL=chunk-K4GZBPXF.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/server/handlers/workflows.ts","../src/server/utils.ts"],"names":[],"mappings":"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","file":"chunk-K4GZBPXF.js","sourcesContent":["import { ReadableStream, TransformStream } from 'node:stream/web';\nimport type { RuntimeContext } from '@mastra/core/di';\nimport type { WorkflowRuns } from '@mastra/core/storage';\nimport type { Workflow, WatchEvent, WorkflowInfo, StreamEvent } from '@mastra/core/workflows';\nimport { HTTPException } from '../http-exception';\nimport type { Context } from '../types';\nimport { getWorkflowInfo, WorkflowRegistry } from '../utils';\nimport { handleError } from './error';\n\nexport interface WorkflowContext extends Context {\n workflowId?: string;\n runId?: string;\n}\n\nexport async function getWorkflowsHandler({ mastra }: WorkflowContext) {\n try {\n const workflows = mastra.getWorkflows({ serialized: false });\n const _workflows = Object.entries(workflows).reduce<Record<string, WorkflowInfo>>((acc, [key, workflow]) => {\n acc[key] = getWorkflowInfo(workflow);\n return acc;\n }, {});\n return _workflows;\n } catch (error) {\n return handleError(error, 'Error getting workflows');\n }\n}\n\nasync function getWorkflowsFromSystem({ mastra, workflowId }: WorkflowContext) {\n const logger = mastra.getLogger();\n\n if (!workflowId) {\n throw new HTTPException(400, { message: 'Workflow ID is required' });\n }\n\n let workflow;\n\n // First check registry for temporary workflows\n workflow = WorkflowRegistry.getWorkflow(workflowId);\n\n if (!workflow) {\n try {\n workflow = mastra.getWorkflow(workflowId);\n } catch (error) {\n logger.debug('Error getting workflow, searching agents for workflow', error);\n }\n }\n\n if (!workflow) {\n logger.debug('Workflow not found, searching agents for workflow', { workflowId });\n const agents = mastra.getAgents();\n\n if (Object.keys(agents || {}).length) {\n for (const [_, agent] of Object.entries(agents)) {\n try {\n const workflows = await agent.getWorkflows();\n\n if (workflows[workflowId]) {\n workflow = workflows[workflowId];\n break;\n }\n break;\n } catch (error) {\n logger.debug('Error getting workflow from agent', error);\n }\n }\n }\n }\n\n if (!workflow) {\n throw new HTTPException(404, { message: 'Workflow not found' });\n }\n\n return { workflow };\n}\n\nexport async function getWorkflowByIdHandler({ mastra, workflowId }: WorkflowContext): Promise<WorkflowInfo> {\n try {\n if (!workflowId) {\n throw new HTTPException(400, { message: 'Workflow ID is required' });\n }\n\n const { workflow } = await getWorkflowsFromSystem({ mastra, workflowId });\n\n if (!workflow) {\n throw new HTTPException(404, { message: 'Workflow not found' });\n }\n\n return getWorkflowInfo(workflow);\n } catch (error) {\n return handleError(error, 'Error getting workflow');\n }\n}\n\nexport async function getWorkflowRunByIdHandler({\n mastra,\n workflowId,\n runId,\n}: Pick<WorkflowContext, 'mastra' | 'workflowId' | 'runId'>): Promise<ReturnType<Workflow['getWorkflowRunById']>> {\n try {\n if (!workflowId) {\n throw new HTTPException(400, { message: 'Workflow ID is required' });\n }\n\n if (!runId) {\n throw new HTTPException(400, { message: 'Run ID is required' });\n }\n\n const { workflow } = await getWorkflowsFromSystem({ mastra, workflowId });\n\n if (!workflow) {\n throw new HTTPException(404, { message: 'Workflow not found' });\n }\n\n const run = await workflow.getWorkflowRunById(runId);\n\n if (!run) {\n throw new HTTPException(404, { message: 'Workflow run not found' });\n }\n\n return run;\n } catch (error) {\n return handleError(error, 'Error getting workflow run');\n }\n}\n\nexport async function getWorkflowRunExecutionResultHandler({\n mastra,\n workflowId,\n runId,\n}: Pick<WorkflowContext, 'mastra' | 'workflowId' | 'runId'>): Promise<WatchEvent['payload']['workflowState']> {\n try {\n if (!workflowId) {\n throw new HTTPException(400, { message: 'Workflow ID is required' });\n }\n\n if (!runId) {\n throw new HTTPException(400, { message: 'Run ID is required' });\n }\n\n const workflow = mastra.getWorkflow(workflowId);\n\n if (!workflow) {\n throw new HTTPException(404, { message: 'Workflow not found' });\n }\n\n const executionResult = await workflow.getWorkflowRunExecutionResult(runId);\n\n if (!executionResult) {\n throw new HTTPException(404, { message: 'Workflow run execution result not found' });\n }\n\n return executionResult;\n } catch (error) {\n return handleError(error, 'Error getting workflow run execution result');\n }\n}\n\nexport async function createWorkflowRunHandler({\n mastra,\n workflowId,\n runId: prevRunId,\n}: Pick<WorkflowContext, 'mastra' | 'workflowId' | 'runId'>) {\n try {\n if (!workflowId) {\n throw new HTTPException(400, { message: 'Workflow ID is required' });\n }\n\n const { workflow } = await getWorkflowsFromSystem({ mastra, workflowId });\n\n if (!workflow) {\n throw new HTTPException(404, { message: 'Workflow not found' });\n }\n\n const run = await workflow.createRunAsync({ runId: prevRunId });\n\n return { runId: run.runId };\n } catch (error) {\n return handleError(error, 'Error creating workflow run');\n }\n}\n\nexport async function startAsyncWorkflowHandler({\n mastra,\n runtimeContext,\n workflowId,\n runId,\n inputData,\n}: Pick<WorkflowContext, 'mastra' | 'workflowId' | 'runId'> & {\n inputData?: unknown;\n runtimeContext?: RuntimeContext;\n}) {\n try {\n if (!workflowId) {\n throw new HTTPException(400, { message: 'Workflow ID is required' });\n }\n\n const { workflow } = await getWorkflowsFromSystem({ mastra, workflowId });\n\n if (!workflow) {\n throw new HTTPException(404, { message: 'Workflow not found' });\n }\n\n const _run = await workflow.createRunAsync({ runId });\n const result = await _run.start({\n inputData,\n runtimeContext,\n });\n return result;\n } catch (error) {\n return handleError(error, 'Error starting async workflow');\n }\n}\n\nexport async function startWorkflowRunHandler({\n mastra,\n runtimeContext,\n workflowId,\n runId,\n inputData,\n}: Pick<WorkflowContext, 'mastra' | 'workflowId' | 'runId'> & {\n inputData?: unknown;\n runtimeContext?: RuntimeContext;\n}) {\n try {\n if (!workflowId) {\n throw new HTTPException(400, { message: 'Workflow ID is required' });\n }\n\n if (!runId) {\n throw new HTTPException(400, { message: 'runId required to start run' });\n }\n\n const { workflow } = await getWorkflowsFromSystem({ mastra, workflowId });\n\n if (!workflow) {\n throw new HTTPException(404, { message: 'Workflow not found' });\n }\n\n const run = await workflow.getWorkflowRunById(runId);\n\n if (!run) {\n throw new HTTPException(404, { message: 'Workflow run not found' });\n }\n\n const _run = await workflow.createRunAsync({ runId });\n void _run.start({\n inputData,\n runtimeContext,\n });\n\n return { message: 'Workflow run started' };\n } catch (e) {\n return handleError(e, 'Error starting workflow run');\n }\n}\n\nexport async function watchWorkflowHandler({\n mastra,\n workflowId,\n runId,\n eventType = 'watch',\n}: Pick<WorkflowContext, 'mastra' | 'workflowId' | 'runId'> & {\n eventType?: 'watch' | 'watch-v2';\n}): Promise<ReadableStream<string>> {\n try {\n if (!workflowId) {\n throw new HTTPException(400, { message: 'Workflow ID is required' });\n }\n\n if (!runId) {\n throw new HTTPException(400, { message: 'runId required to watch workflow' });\n }\n\n const { workflow } = await getWorkflowsFromSystem({ mastra, workflowId });\n\n if (!workflow) {\n throw new HTTPException(404, { message: 'Workflow not found' });\n }\n\n const run = await workflow.getWorkflowRunById(runId);\n\n if (!run) {\n throw new HTTPException(404, { message: 'Workflow run not found' });\n }\n\n const _run = await workflow.createRunAsync({ runId });\n let unwatch: () => void;\n let asyncRef: NodeJS.Immediate | null = null;\n const stream = new ReadableStream<string>({\n start(controller) {\n unwatch = _run.watch((event: any) => {\n const { type, payload, eventTimestamp } = event;\n controller.enqueue(JSON.stringify({ type, payload, eventTimestamp, runId }));\n\n if (asyncRef) {\n clearImmediate(asyncRef);\n asyncRef = null;\n }\n\n // a run is finished if the status is not running\n asyncRef = setImmediate(async () => {\n const runDone = eventType === 'watch' ? payload.workflowState.status !== 'running' : type === 'finish';\n if (runDone) {\n controller.close();\n unwatch?.();\n }\n });\n }, eventType);\n },\n cancel() {\n if (asyncRef) {\n clearImmediate(asyncRef);\n asyncRef = null;\n }\n unwatch?.();\n },\n });\n\n return stream;\n } catch (error) {\n return handleError(error, 'Error watching workflow');\n }\n}\n\nexport async function streamWorkflowHandler({\n mastra,\n runtimeContext,\n workflowId,\n runId,\n inputData,\n}: Pick<WorkflowContext, 'mastra' | 'workflowId' | 'runId'> & {\n inputData?: unknown;\n runtimeContext?: RuntimeContext;\n}) {\n try {\n if (!workflowId) {\n throw new HTTPException(400, { message: 'Workflow ID is required' });\n }\n\n if (!runId) {\n throw new HTTPException(400, { message: 'runId required to resume workflow' });\n }\n\n const { workflow } = await getWorkflowsFromSystem({ mastra, workflowId });\n\n if (!workflow) {\n throw new HTTPException(404, { message: 'Workflow not found' });\n }\n\n const serverCache = mastra.getServerCache();\n\n const run = await workflow.createRunAsync({ runId });\n const result = run.stream({\n inputData,\n runtimeContext,\n onChunk: async chunk => {\n if (serverCache) {\n const cacheKey = runId;\n await serverCache.listPush(cacheKey, chunk);\n }\n },\n });\n\n return result;\n } catch (error) {\n return handleError(error, 'Error executing workflow');\n }\n}\n\nexport async function observeStreamWorkflowHandler({\n mastra,\n workflowId,\n runId,\n}: Pick<WorkflowContext, 'mastra' | 'workflowId' | 'runId'>) {\n try {\n if (!workflowId) {\n throw new HTTPException(400, { message: 'Workflow ID is required' });\n }\n\n if (!runId) {\n throw new HTTPException(400, { message: 'runId required to observe workflow stream' });\n }\n\n const { workflow } = await getWorkflowsFromSystem({ mastra, workflowId });\n\n if (!workflow) {\n throw new HTTPException(404, { message: 'Workflow not found' });\n }\n\n const run = await workflow.getWorkflowRunById(runId);\n\n if (!run) {\n throw new HTTPException(404, { message: 'Workflow run not found' });\n }\n\n const _run = await workflow.createRunAsync({ runId });\n const serverCache = mastra.getServerCache();\n if (!serverCache) {\n throw new HTTPException(500, { message: 'Server cache not found' });\n }\n\n const transformStream = new TransformStream<StreamEvent, StreamEvent>();\n\n const writer = transformStream.writable.getWriter();\n\n const cachedRunChunks = await serverCache.listFromTo(runId, 0);\n\n for (const chunk of cachedRunChunks) {\n await writer.write(chunk as any);\n }\n\n writer.releaseLock();\n\n const result = _run.observeStream();\n return result.stream?.pipeThrough(transformStream);\n } catch (error) {\n return handleError(error, 'Error observing workflow stream');\n }\n}\n\nexport async function streamVNextWorkflowHandler({\n mastra,\n runtimeContext,\n workflowId,\n runId,\n inputData,\n closeOnSuspend,\n}: Pick<WorkflowContext, 'mastra' | 'workflowId' | 'runId'> & {\n inputData?: unknown;\n runtimeContext?: RuntimeContext;\n closeOnSuspend?: boolean;\n}) {\n try {\n if (!workflowId) {\n throw new HTTPException(400, { message: 'Workflow ID is required' });\n }\n\n if (!runId) {\n throw new HTTPException(400, { message: 'runId required to stream workflow' });\n }\n\n const { workflow } = await getWorkflowsFromSystem({ mastra, workflowId });\n\n if (!workflow) {\n throw new HTTPException(404, { message: 'Workflow not found' });\n }\n\n const run = await workflow.createRunAsync({ runId });\n const result = run.streamVNext({\n inputData,\n runtimeContext,\n closeOnSuspend,\n });\n return result;\n } catch (error) {\n return handleError(error, 'Error streaming workflow');\n }\n}\n\nexport async function resumeAsyncWorkflowHandler({\n mastra,\n workflowId,\n runId,\n body,\n runtimeContext,\n}: WorkflowContext & {\n body: { step: string | string[]; resumeData?: unknown };\n runtimeContext?: RuntimeContext;\n}) {\n try {\n if (!workflowId) {\n throw new HTTPException(400, { message: 'Workflow ID is required' });\n }\n\n if (!runId) {\n throw new HTTPException(400, { message: 'runId required to resume workflow' });\n }\n\n if (!body.step) {\n throw new HTTPException(400, { message: 'step required to resume workflow' });\n }\n\n const { workflow } = await getWorkflowsFromSystem({ mastra, workflowId });\n\n if (!workflow) {\n throw new HTTPException(404, { message: 'Workflow not found' });\n }\n\n const run = await workflow.getWorkflowRunById(runId);\n\n if (!run) {\n throw new HTTPException(404, { message: 'Workflow run not found' });\n }\n\n const _run = await workflow.createRunAsync({ runId });\n const result = await _run.resume({\n step: body.step,\n resumeData: body.resumeData,\n runtimeContext,\n });\n\n return result;\n } catch (error) {\n return handleError(error, 'Error resuming workflow step');\n }\n}\n\nexport async function resumeWorkflowHandler({\n mastra,\n workflowId,\n runId,\n body,\n runtimeContext,\n}: WorkflowContext & {\n body: { step: string | string[]; resumeData?: unknown };\n runtimeContext?: RuntimeContext;\n}) {\n try {\n if (!workflowId) {\n throw new HTTPException(400, { message: 'Workflow ID is required' });\n }\n\n if (!runId) {\n throw new HTTPException(400, { message: 'runId required to resume workflow' });\n }\n\n if (!body.step) {\n throw new HTTPException(400, { message: 'step required to resume workflow' });\n }\n\n const { workflow } = await getWorkflowsFromSystem({ mastra, workflowId });\n\n if (!workflow) {\n throw new HTTPException(404, { message: 'Workflow not found' });\n }\n\n const run = await workflow.getWorkflowRunById(runId);\n\n if (!run) {\n throw new HTTPException(404, { message: 'Workflow run not found' });\n }\n\n const _run = await workflow.createRunAsync({ runId });\n\n void _run.resume({\n step: body.step,\n resumeData: body.resumeData,\n runtimeContext,\n });\n\n return { message: 'Workflow run resumed' };\n } catch (error) {\n return handleError(error, 'Error resuming workflow');\n }\n}\n\nexport async function resumeStreamWorkflowHandler({\n mastra,\n workflowId,\n runId,\n body,\n runtimeContext,\n}: WorkflowContext & {\n body: { step: string | string[]; resumeData?: unknown };\n runtimeContext?: RuntimeContext;\n}) {\n try {\n if (!workflowId) {\n throw new HTTPException(400, { message: 'Workflow ID is required' });\n }\n\n if (!runId) {\n throw new HTTPException(400, { message: 'runId required to resume workflow' });\n }\n\n if (!body.step) {\n throw new HTTPException(400, { message: 'step required to resume workflow' });\n }\n\n const { workflow } = await getWorkflowsFromSystem({ mastra, workflowId });\n\n if (!workflow) {\n throw new HTTPException(404, { message: 'Workflow not found' });\n }\n\n const run = await workflow.getWorkflowRunById(runId);\n\n if (!run) {\n throw new HTTPException(404, { message: 'Workflow run not found' });\n }\n\n const _run = await workflow.createRunAsync({ runId });\n\n const stream = await _run.resumeStreamVNext({\n step: body.step,\n resumeData: body.resumeData,\n runtimeContext,\n });\n\n return stream;\n } catch (error) {\n return handleError(error, 'Error resuming workflow');\n }\n}\n\nexport async function getWorkflowRunsHandler({\n mastra,\n workflowId,\n fromDate,\n toDate,\n limit,\n offset,\n resourceId,\n}: WorkflowContext & {\n fromDate?: Date;\n toDate?: Date;\n limit?: number;\n offset?: number;\n resourceId?: string;\n}): Promise<WorkflowRuns> {\n try {\n if (!workflowId) {\n throw new HTTPException(400, { message: 'Workflow ID is required' });\n }\n\n const { workflow } = await getWorkflowsFromSystem({ mastra, workflowId });\n\n if (!workflow) {\n throw new HTTPException(404, { message: 'Workflow not found' });\n }\n\n const workflowRuns = (await workflow.getWorkflowRuns({ fromDate, toDate, limit, offset, resourceId })) || {\n runs: [],\n total: 0,\n };\n return workflowRuns;\n } catch (error) {\n return handleError(error, 'Error getting workflow runs');\n }\n}\n\nexport async function cancelWorkflowRunHandler({\n mastra,\n workflowId,\n runId,\n}: Pick<WorkflowContext, 'mastra' | 'workflowId' | 'runId'>) {\n try {\n if (!workflowId) {\n throw new HTTPException(400, { message: 'Workflow ID is required' });\n }\n\n if (!runId) {\n throw new HTTPException(400, { message: 'runId required to cancel workflow run' });\n }\n\n const { workflow } = await getWorkflowsFromSystem({ mastra, workflowId });\n\n if (!workflow) {\n throw new HTTPException(404, { message: 'Workflow not found' });\n }\n\n const run = await workflow.getWorkflowRunById(runId);\n\n if (!run) {\n throw new HTTPException(404, { message: 'Workflow run not found' });\n }\n\n const _run = await workflow.createRunAsync({ runId });\n\n await _run.cancel();\n\n return { message: 'Workflow run cancelled' };\n } catch (error) {\n return handleError(error, 'Error canceling workflow run');\n }\n}\n\nexport async function sendWorkflowRunEventHandler({\n mastra,\n workflowId,\n runId,\n event,\n data,\n}: Pick<WorkflowContext, 'mastra' | 'workflowId' | 'runId'> & {\n event: string;\n data: unknown;\n}) {\n try {\n if (!workflowId) {\n throw new HTTPException(400, { message: 'Workflow ID is required' });\n }\n\n if (!runId) {\n throw new HTTPException(400, { message: 'runId required to send workflow run event' });\n }\n\n const { workflow } = await getWorkflowsFromSystem({ mastra, workflowId });\n\n if (!workflow) {\n throw new HTTPException(404, { message: 'Workflow not found' });\n }\n\n const run = await workflow.getWorkflowRunById(runId);\n\n if (!run) {\n throw new HTTPException(404, { message: 'Workflow run not found' });\n }\n\n const _run = await workflow.createRunAsync({ runId });\n\n await _run.sendEvent(event, data);\n\n return { message: 'Workflow run event sent' };\n } catch (error) {\n return handleError(error, 'Error sending workflow run event');\n }\n}\n","import { zodToJsonSchema } from '@mastra/core/utils/zod-to-json';\nimport type { StepWithComponent, Workflow, WorkflowInfo } from '@mastra/core/workflows';\nimport { stringify } from 'superjson';\n\nfunction getSteps(steps: Record<string, StepWithComponent>, path?: string) {\n return Object.entries(steps).reduce<any>((acc, [key, step]) => {\n const fullKey = path ? `${path}.${key}` : key;\n acc[fullKey] = {\n id: step.id,\n description: step.description,\n inputSchema: step.inputSchema ? stringify(zodToJsonSchema(step.inputSchema)) : undefined,\n outputSchema: step.outputSchema ? stringify(zodToJsonSchema(step.outputSchema)) : undefined,\n resumeSchema: step.resumeSchema ? stringify(zodToJsonSchema(step.resumeSchema)) : undefined,\n suspendSchema: step.suspendSchema ? stringify(zodToJsonSchema(step.suspendSchema)) : undefined,\n isWorkflow: step.component === 'WORKFLOW',\n };\n\n if (step.component === 'WORKFLOW' && step.steps) {\n const nestedSteps = getSteps(step.steps, fullKey) || {};\n acc = { ...acc, ...nestedSteps };\n }\n\n return acc;\n }, {});\n}\n\nexport function getWorkflowInfo(workflow: Workflow): WorkflowInfo {\n return {\n name: workflow.name,\n description: workflow.description,\n steps: Object.entries(workflow.steps).reduce<any>((acc, [key, step]) => {\n acc[key] = {\n id: step.id,\n description: step.description,\n inputSchema: step.inputSchema ? stringify(zodToJsonSchema(step.inputSchema)) : undefined,\n outputSchema: step.outputSchema ? stringify(zodToJsonSchema(step.outputSchema)) : undefined,\n resumeSchema: step.resumeSchema ? stringify(zodToJsonSchema(step.resumeSchema)) : undefined,\n suspendSchema: step.suspendSchema ? stringify(zodToJsonSchema(step.suspendSchema)) : undefined,\n };\n return acc;\n }, {}),\n allSteps: getSteps(workflow.steps) || {},\n stepGraph: workflow.serializedStepGraph,\n inputSchema: workflow.inputSchema ? stringify(zodToJsonSchema(workflow.inputSchema)) : undefined,\n outputSchema: workflow.outputSchema ? stringify(zodToJsonSchema(workflow.outputSchema)) : undefined,\n };\n}\n\n/**\n * Workflow Registry for temporarily registering additional workflows\n * that are not part of the user's Mastra instance (e.g., internal template workflows)\n */\nexport class WorkflowRegistry {\n private static additionalWorkflows: Record<string, Workflow> = {};\n\n /**\n * Register a workflow temporarily\n */\n static registerTemporaryWorkflow(id: string, workflow: Workflow): void {\n this.additionalWorkflows[id] = workflow;\n }\n\n /**\n * Register all workflows from map\n */\n static registerTemporaryWorkflows(workflows: Record<string, Workflow>, mastra?: any): void {\n for (const [id, workflow] of Object.entries(workflows)) {\n // Register Mastra instance with the workflow if provided\n if (mastra) {\n workflow.__registerMastra(mastra);\n workflow.__registerPrimitives({\n logger: mastra.getLogger(),\n telemetry: mastra.getTelemetry(),\n storage: mastra.getStorage(),\n memory: mastra.getMemory(),\n agents: mastra.getAgents(),\n tts: mastra.getTTS(),\n vectors: mastra.getVectors(),\n });\n }\n this.additionalWorkflows[id] = workflow;\n }\n }\n\n /**\n * Get a workflow by ID from the registry (returns undefined if not found)\n */\n static getWorkflow(workflowId: string): Workflow | undefined {\n return this.additionalWorkflows[workflowId];\n }\n\n /**\n * Get all workflows from the registry\n */\n static getAllWorkflows(): Record<string, Workflow> {\n return { ...this.additionalWorkflows };\n }\n\n /**\n * Clean up a temporary workflow\n */\n static cleanupTemporaryWorkflow(workflowId: string): void {\n delete this.additionalWorkflows[workflowId];\n }\n /**\n * Clean up all registered workflows\n */\n static cleanup(): void {\n // Clear all workflows (since we register all agent-builder workflows each time)\n this.additionalWorkflows = {};\n }\n\n /**\n * Check if a workflow ID is a valid agent-builder workflow\n */\n static isAgentBuilderWorkflow(workflowId: string): boolean {\n return workflowId in this.additionalWorkflows;\n }\n\n /**\n * Get all registered temporary workflow IDs (for debugging)\n */\n static getRegisteredWorkflowIds(): string[] {\n return Object.keys(this.additionalWorkflows);\n }\n}\n"]}