@scoutqa/mastra-core 0.24.6-fork.1

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 (1064) hide show
  1. package/CHANGELOG.md +5844 -0
  2. package/LICENSE.md +15 -0
  3. package/README.md +59 -0
  4. package/a2a.d.ts +1 -0
  5. package/action.d.ts +1 -0
  6. package/agent/input-processor/processors.d.ts +1 -0
  7. package/agent.d.ts +1 -0
  8. package/ai-tracing.d.ts +1 -0
  9. package/base.d.ts +1 -0
  10. package/bundler.d.ts +1 -0
  11. package/cache.d.ts +1 -0
  12. package/deployer.d.ts +1 -0
  13. package/di.d.ts +1 -0
  14. package/dist/a2a/error.d.ts +24 -0
  15. package/dist/a2a/error.d.ts.map +1 -0
  16. package/dist/a2a/index.cjs +80 -0
  17. package/dist/a2a/index.cjs.map +1 -0
  18. package/dist/a2a/index.d.ts +4 -0
  19. package/dist/a2a/index.d.ts.map +1 -0
  20. package/dist/a2a/index.js +72 -0
  21. package/dist/a2a/index.js.map +1 -0
  22. package/dist/a2a/types.d.ts +93 -0
  23. package/dist/a2a/types.d.ts.map +1 -0
  24. package/dist/action/index.d.ts +36 -0
  25. package/dist/action/index.d.ts.map +1 -0
  26. package/dist/agent/__tests__/mock-model.d.ts +6 -0
  27. package/dist/agent/__tests__/mock-model.d.ts.map +1 -0
  28. package/dist/agent/agent.d.ts +728 -0
  29. package/dist/agent/agent.d.ts.map +1 -0
  30. package/dist/agent/agent.types.d.ts +130 -0
  31. package/dist/agent/agent.types.d.ts.map +1 -0
  32. package/dist/agent/index.cjs +53 -0
  33. package/dist/agent/index.cjs.map +1 -0
  34. package/dist/agent/index.d.ts +10 -0
  35. package/dist/agent/index.d.ts.map +1 -0
  36. package/dist/agent/index.js +4 -0
  37. package/dist/agent/index.js.map +1 -0
  38. package/dist/agent/index.warning.d.ts +13 -0
  39. package/dist/agent/index.warning.d.ts.map +1 -0
  40. package/dist/agent/input-processor/index.cjs +28 -0
  41. package/dist/agent/input-processor/index.cjs.map +1 -0
  42. package/dist/agent/input-processor/index.d.ts +10 -0
  43. package/dist/agent/input-processor/index.d.ts.map +1 -0
  44. package/dist/agent/input-processor/index.js +3 -0
  45. package/dist/agent/input-processor/index.js.map +1 -0
  46. package/dist/agent/input-processor/processors/index.d.ts +6 -0
  47. package/dist/agent/input-processor/processors/index.d.ts.map +1 -0
  48. package/dist/agent/input-processor/processors/language-detector.d.ts +18 -0
  49. package/dist/agent/input-processor/processors/language-detector.d.ts.map +1 -0
  50. package/dist/agent/input-processor/processors/moderation.d.ts +18 -0
  51. package/dist/agent/input-processor/processors/moderation.d.ts.map +1 -0
  52. package/dist/agent/input-processor/processors/pii-detector.d.ts +18 -0
  53. package/dist/agent/input-processor/processors/pii-detector.d.ts.map +1 -0
  54. package/dist/agent/input-processor/processors/prompt-injection-detector.d.ts +18 -0
  55. package/dist/agent/input-processor/processors/prompt-injection-detector.d.ts.map +1 -0
  56. package/dist/agent/input-processor/processors/unicode-normalizer.d.ts +18 -0
  57. package/dist/agent/input-processor/processors/unicode-normalizer.d.ts.map +1 -0
  58. package/dist/agent/message-list/index.d.ts +305 -0
  59. package/dist/agent/message-list/index.d.ts.map +1 -0
  60. package/dist/agent/message-list/prompt/attachments-to-parts.d.ts +11 -0
  61. package/dist/agent/message-list/prompt/attachments-to-parts.d.ts.map +1 -0
  62. package/dist/agent/message-list/prompt/convert-file.d.ts +7 -0
  63. package/dist/agent/message-list/prompt/convert-file.d.ts.map +1 -0
  64. package/dist/agent/message-list/prompt/convert-to-mastra-v1.d.ts +4 -0
  65. package/dist/agent/message-list/prompt/convert-to-mastra-v1.d.ts.map +1 -0
  66. package/dist/agent/message-list/prompt/data-content.d.ts +17 -0
  67. package/dist/agent/message-list/prompt/data-content.d.ts.map +1 -0
  68. package/dist/agent/message-list/prompt/download-assets.d.ts +15 -0
  69. package/dist/agent/message-list/prompt/download-assets.d.ts.map +1 -0
  70. package/dist/agent/message-list/prompt/image-utils.d.ts +86 -0
  71. package/dist/agent/message-list/prompt/image-utils.d.ts.map +1 -0
  72. package/dist/agent/message-list/prompt/invalid-content-error.d.ts +14 -0
  73. package/dist/agent/message-list/prompt/invalid-content-error.d.ts.map +1 -0
  74. package/dist/agent/message-list/types.d.ts +3 -0
  75. package/dist/agent/message-list/types.d.ts.map +1 -0
  76. package/dist/agent/message-list/utils/ai-v4-v5/core-model-message.d.ts +3 -0
  77. package/dist/agent/message-list/utils/ai-v4-v5/core-model-message.d.ts.map +1 -0
  78. package/dist/agent/message-list/utils/ai-v4-v5/ui-message.d.ts +3 -0
  79. package/dist/agent/message-list/utils/ai-v4-v5/ui-message.d.ts.map +1 -0
  80. package/dist/agent/message-list/utils/ai-v5/gemini-compatibility.d.ts +22 -0
  81. package/dist/agent/message-list/utils/ai-v5/gemini-compatibility.d.ts.map +1 -0
  82. package/dist/agent/message-list/utils/ai-v5/tool.d.ts +16 -0
  83. package/dist/agent/message-list/utils/ai-v5/tool.d.ts.map +1 -0
  84. package/dist/agent/message-list/utils/convert-messages.d.ts +91 -0
  85. package/dist/agent/message-list/utils/convert-messages.d.ts.map +1 -0
  86. package/dist/agent/save-queue/index.d.ts +68 -0
  87. package/dist/agent/save-queue/index.d.ts.map +1 -0
  88. package/dist/agent/test-utils.d.ts +82 -0
  89. package/dist/agent/test-utils.d.ts.map +1 -0
  90. package/dist/agent/trip-wire.d.ts +18 -0
  91. package/dist/agent/trip-wire.d.ts.map +1 -0
  92. package/dist/agent/types.d.ts +358 -0
  93. package/dist/agent/types.d.ts.map +1 -0
  94. package/dist/agent/utils.d.ts +104 -0
  95. package/dist/agent/utils.d.ts.map +1 -0
  96. package/dist/agent/workflows/prepare-stream/index.d.ts +158 -0
  97. package/dist/agent/workflows/prepare-stream/index.d.ts.map +1 -0
  98. package/dist/agent/workflows/prepare-stream/map-results-step.d.ts +35 -0
  99. package/dist/agent/workflows/prepare-stream/map-results-step.d.ts.map +1 -0
  100. package/dist/agent/workflows/prepare-stream/prepare-memory-step.d.ts +90 -0
  101. package/dist/agent/workflows/prepare-stream/prepare-memory-step.d.ts.map +1 -0
  102. package/dist/agent/workflows/prepare-stream/prepare-tools-step.d.ts +75 -0
  103. package/dist/agent/workflows/prepare-stream/prepare-tools-step.d.ts.map +1 -0
  104. package/dist/agent/workflows/prepare-stream/schema.d.ts +179 -0
  105. package/dist/agent/workflows/prepare-stream/schema.d.ts.map +1 -0
  106. package/dist/agent/workflows/prepare-stream/stream-step.d.ts +36 -0
  107. package/dist/agent/workflows/prepare-stream/stream-step.d.ts.map +1 -0
  108. package/dist/ai-tracing/context.d.ts +21 -0
  109. package/dist/ai-tracing/context.d.ts.map +1 -0
  110. package/dist/ai-tracing/exporters/base.d.ts +111 -0
  111. package/dist/ai-tracing/exporters/base.d.ts.map +1 -0
  112. package/dist/ai-tracing/exporters/cloud.d.ts +30 -0
  113. package/dist/ai-tracing/exporters/cloud.d.ts.map +1 -0
  114. package/dist/ai-tracing/exporters/console.d.ts +10 -0
  115. package/dist/ai-tracing/exporters/console.d.ts.map +1 -0
  116. package/dist/ai-tracing/exporters/default.d.ts +98 -0
  117. package/dist/ai-tracing/exporters/default.d.ts.map +1 -0
  118. package/dist/ai-tracing/exporters/index.d.ts +9 -0
  119. package/dist/ai-tracing/exporters/index.d.ts.map +1 -0
  120. package/dist/ai-tracing/index.cjs +148 -0
  121. package/dist/ai-tracing/index.cjs.map +1 -0
  122. package/dist/ai-tracing/index.d.ts +13 -0
  123. package/dist/ai-tracing/index.d.ts.map +1 -0
  124. package/dist/ai-tracing/index.js +3 -0
  125. package/dist/ai-tracing/index.js.map +1 -0
  126. package/dist/ai-tracing/model-tracing.d.ts +63 -0
  127. package/dist/ai-tracing/model-tracing.d.ts.map +1 -0
  128. package/dist/ai-tracing/registry.d.ts +51 -0
  129. package/dist/ai-tracing/registry.d.ts.map +1 -0
  130. package/dist/ai-tracing/span_processors/index.d.ts +5 -0
  131. package/dist/ai-tracing/span_processors/index.d.ts.map +1 -0
  132. package/dist/ai-tracing/span_processors/sensitive-data-filter.d.ts +85 -0
  133. package/dist/ai-tracing/span_processors/sensitive-data-filter.d.ts.map +1 -0
  134. package/dist/ai-tracing/spans/base.d.ts +65 -0
  135. package/dist/ai-tracing/spans/base.d.ts.map +1 -0
  136. package/dist/ai-tracing/spans/default.d.ts +13 -0
  137. package/dist/ai-tracing/spans/default.d.ts.map +1 -0
  138. package/dist/ai-tracing/spans/index.d.ts +7 -0
  139. package/dist/ai-tracing/spans/index.d.ts.map +1 -0
  140. package/dist/ai-tracing/spans/no-op.d.ts +15 -0
  141. package/dist/ai-tracing/spans/no-op.d.ts.map +1 -0
  142. package/dist/ai-tracing/tracers/base.d.ts +105 -0
  143. package/dist/ai-tracing/tracers/base.d.ts.map +1 -0
  144. package/dist/ai-tracing/tracers/default.d.ts +7 -0
  145. package/dist/ai-tracing/tracers/default.d.ts.map +1 -0
  146. package/dist/ai-tracing/tracers/index.d.ts +6 -0
  147. package/dist/ai-tracing/tracers/index.d.ts.map +1 -0
  148. package/dist/ai-tracing/types.d.ts +696 -0
  149. package/dist/ai-tracing/types.d.ts.map +1 -0
  150. package/dist/ai-tracing/utils.d.ts +68 -0
  151. package/dist/ai-tracing/utils.d.ts.map +1 -0
  152. package/dist/base.cjs +12 -0
  153. package/dist/base.cjs.map +1 -0
  154. package/dist/base.d.ts +34 -0
  155. package/dist/base.d.ts.map +1 -0
  156. package/dist/base.js +3 -0
  157. package/dist/base.js.map +1 -0
  158. package/dist/base.warning.d.ts +9 -0
  159. package/dist/base.warning.d.ts.map +1 -0
  160. package/dist/bundler/index.cjs +12 -0
  161. package/dist/bundler/index.cjs.map +1 -0
  162. package/dist/bundler/index.d.ts +31 -0
  163. package/dist/bundler/index.d.ts.map +1 -0
  164. package/dist/bundler/index.js +3 -0
  165. package/dist/bundler/index.js.map +1 -0
  166. package/dist/bundler/index.warning.d.ts +9 -0
  167. package/dist/bundler/index.warning.d.ts.map +1 -0
  168. package/dist/bundler/types.d.ts +6 -0
  169. package/dist/bundler/types.d.ts.map +1 -0
  170. package/dist/cache/base.d.ts +14 -0
  171. package/dist/cache/base.d.ts.map +1 -0
  172. package/dist/cache/index.cjs +16 -0
  173. package/dist/cache/index.cjs.map +1 -0
  174. package/dist/cache/index.d.ts +3 -0
  175. package/dist/cache/index.d.ts.map +1 -0
  176. package/dist/cache/index.js +3 -0
  177. package/dist/cache/index.js.map +1 -0
  178. package/dist/cache/inmemory.d.ts +13 -0
  179. package/dist/cache/inmemory.d.ts.map +1 -0
  180. package/dist/chunk-3HXBPDKN.js +105 -0
  181. package/dist/chunk-3HXBPDKN.js.map +1 -0
  182. package/dist/chunk-3NTOFNIU.js +60 -0
  183. package/dist/chunk-3NTOFNIU.js.map +1 -0
  184. package/dist/chunk-3PSWNGBF.js +3 -0
  185. package/dist/chunk-3PSWNGBF.js.map +1 -0
  186. package/dist/chunk-42RUESSD.cjs +3203 -0
  187. package/dist/chunk-42RUESSD.cjs.map +1 -0
  188. package/dist/chunk-436FFEF6.js +34 -0
  189. package/dist/chunk-436FFEF6.js.map +1 -0
  190. package/dist/chunk-46XGIEXM.cjs +47 -0
  191. package/dist/chunk-46XGIEXM.cjs.map +1 -0
  192. package/dist/chunk-4D4KB75Y.cjs +9 -0
  193. package/dist/chunk-4D4KB75Y.cjs.map +1 -0
  194. package/dist/chunk-4L63C6E5.cjs +2554 -0
  195. package/dist/chunk-4L63C6E5.cjs.map +1 -0
  196. package/dist/chunk-4LSFAAZW.js +3 -0
  197. package/dist/chunk-4LSFAAZW.js.map +1 -0
  198. package/dist/chunk-4R2TBRS7.cjs +191 -0
  199. package/dist/chunk-4R2TBRS7.cjs.map +1 -0
  200. package/dist/chunk-4WQYXT2I.cjs +12 -0
  201. package/dist/chunk-4WQYXT2I.cjs.map +1 -0
  202. package/dist/chunk-5NTO7S5I.cjs +173 -0
  203. package/dist/chunk-5NTO7S5I.cjs.map +1 -0
  204. package/dist/chunk-5O52O25J.js +65 -0
  205. package/dist/chunk-5O52O25J.js.map +1 -0
  206. package/dist/chunk-5X4TQR6K.js +12 -0
  207. package/dist/chunk-5X4TQR6K.js.map +1 -0
  208. package/dist/chunk-6D2K2CAA.js +776 -0
  209. package/dist/chunk-6D2K2CAA.js.map +1 -0
  210. package/dist/chunk-6KOL2B3A.cjs +75 -0
  211. package/dist/chunk-6KOL2B3A.cjs.map +1 -0
  212. package/dist/chunk-6TEQIYXV.cjs +96 -0
  213. package/dist/chunk-6TEQIYXV.cjs.map +1 -0
  214. package/dist/chunk-6VOPKVYH.cjs +57 -0
  215. package/dist/chunk-6VOPKVYH.cjs.map +1 -0
  216. package/dist/chunk-6XCINXZ7.cjs +194 -0
  217. package/dist/chunk-6XCINXZ7.cjs.map +1 -0
  218. package/dist/chunk-7J5DS33F.js +3 -0
  219. package/dist/chunk-7J5DS33F.js.map +1 -0
  220. package/dist/chunk-A5KDVZDL.cjs +124 -0
  221. package/dist/chunk-A5KDVZDL.cjs.map +1 -0
  222. package/dist/chunk-AAYCOJUL.cjs +14 -0
  223. package/dist/chunk-AAYCOJUL.cjs.map +1 -0
  224. package/dist/chunk-ABJOUEVA.cjs +10 -0
  225. package/dist/chunk-ABJOUEVA.cjs.map +1 -0
  226. package/dist/chunk-AQGLVU53.cjs +603 -0
  227. package/dist/chunk-AQGLVU53.cjs.map +1 -0
  228. package/dist/chunk-B7V6NYWH.cjs +67 -0
  229. package/dist/chunk-B7V6NYWH.cjs.map +1 -0
  230. package/dist/chunk-BJ6XIEC6.js +13 -0
  231. package/dist/chunk-BJ6XIEC6.js.map +1 -0
  232. package/dist/chunk-BLUDYAPI.js +596 -0
  233. package/dist/chunk-BLUDYAPI.js.map +1 -0
  234. package/dist/chunk-BVUMKER5.js +7 -0
  235. package/dist/chunk-BVUMKER5.js.map +1 -0
  236. package/dist/chunk-BWYU7D33.js +192 -0
  237. package/dist/chunk-BWYU7D33.js.map +1 -0
  238. package/dist/chunk-CNMPROPI.js +24 -0
  239. package/dist/chunk-CNMPROPI.js.map +1 -0
  240. package/dist/chunk-CT2DMHGC.cjs +271 -0
  241. package/dist/chunk-CT2DMHGC.cjs.map +1 -0
  242. package/dist/chunk-CYEQK4PM.cjs +778 -0
  243. package/dist/chunk-CYEQK4PM.cjs.map +1 -0
  244. package/dist/chunk-DMBN72QF.cjs +39 -0
  245. package/dist/chunk-DMBN72QF.cjs.map +1 -0
  246. package/dist/chunk-EBVYYC2Q.cjs +111 -0
  247. package/dist/chunk-EBVYYC2Q.cjs.map +1 -0
  248. package/dist/chunk-F7GI2OYP.js +3 -0
  249. package/dist/chunk-F7GI2OYP.js.map +1 -0
  250. package/dist/chunk-FUVNHPNL.cjs +4 -0
  251. package/dist/chunk-FUVNHPNL.cjs.map +1 -0
  252. package/dist/chunk-FVIT6JZ5.cjs +4 -0
  253. package/dist/chunk-FVIT6JZ5.cjs.map +1 -0
  254. package/dist/chunk-G3KSVDML.cjs +1310 -0
  255. package/dist/chunk-G3KSVDML.cjs.map +1 -0
  256. package/dist/chunk-GPWMM745.cjs +80 -0
  257. package/dist/chunk-GPWMM745.cjs.map +1 -0
  258. package/dist/chunk-GXSERFAG.js +3 -0
  259. package/dist/chunk-GXSERFAG.js.map +1 -0
  260. package/dist/chunk-HCCXJ5YJ.js +466 -0
  261. package/dist/chunk-HCCXJ5YJ.js.map +1 -0
  262. package/dist/chunk-HLRWYUFN.js +78 -0
  263. package/dist/chunk-HLRWYUFN.js.map +1 -0
  264. package/dist/chunk-HQDX7PWJ.cjs +26 -0
  265. package/dist/chunk-HQDX7PWJ.cjs.map +1 -0
  266. package/dist/chunk-HSX2K7HB.js +164 -0
  267. package/dist/chunk-HSX2K7HB.js.map +1 -0
  268. package/dist/chunk-IAJHRFO4.cjs +2936 -0
  269. package/dist/chunk-IAJHRFO4.cjs.map +1 -0
  270. package/dist/chunk-INOOZ2A2.js +3144 -0
  271. package/dist/chunk-INOOZ2A2.js.map +1 -0
  272. package/dist/chunk-IWU4YSYT.cjs +166 -0
  273. package/dist/chunk-IWU4YSYT.cjs.map +1 -0
  274. package/dist/chunk-JQE3BLYA.js +3 -0
  275. package/dist/chunk-JQE3BLYA.js.map +1 -0
  276. package/dist/chunk-JVV5LREI.js +431 -0
  277. package/dist/chunk-JVV5LREI.js.map +1 -0
  278. package/dist/chunk-LZPOIBOR.js +87 -0
  279. package/dist/chunk-LZPOIBOR.js.map +1 -0
  280. package/dist/chunk-MKCC5K77.js +90 -0
  281. package/dist/chunk-MKCC5K77.js.map +1 -0
  282. package/dist/chunk-N2ILP2YD.js +2539 -0
  283. package/dist/chunk-N2ILP2YD.js.map +1 -0
  284. package/dist/chunk-NLNKQD2T.js +7 -0
  285. package/dist/chunk-NLNKQD2T.js.map +1 -0
  286. package/dist/chunk-NPNGPMT2.js +39 -0
  287. package/dist/chunk-NPNGPMT2.js.map +1 -0
  288. package/dist/chunk-NSIYMRY7.cjs +91 -0
  289. package/dist/chunk-NSIYMRY7.cjs.map +1 -0
  290. package/dist/chunk-OIT3PCWA.js +72 -0
  291. package/dist/chunk-OIT3PCWA.js.map +1 -0
  292. package/dist/chunk-PAOBGBU7.cjs +471 -0
  293. package/dist/chunk-PAOBGBU7.cjs.map +1 -0
  294. package/dist/chunk-PE3V7GUL.cjs +4 -0
  295. package/dist/chunk-PE3V7GUL.cjs.map +1 -0
  296. package/dist/chunk-PFXXH2RP.js +91 -0
  297. package/dist/chunk-PFXXH2RP.js.map +1 -0
  298. package/dist/chunk-PJKCPRYF.js +3 -0
  299. package/dist/chunk-PJKCPRYF.js.map +1 -0
  300. package/dist/chunk-PZUZNPFM.js +166 -0
  301. package/dist/chunk-PZUZNPFM.js.map +1 -0
  302. package/dist/chunk-Q6LWNLAJ.js +3177 -0
  303. package/dist/chunk-Q6LWNLAJ.js.map +1 -0
  304. package/dist/chunk-QLMWFSDC.js +653 -0
  305. package/dist/chunk-QLMWFSDC.js.map +1 -0
  306. package/dist/chunk-R6XC4DV5.js +170 -0
  307. package/dist/chunk-R6XC4DV5.js.map +1 -0
  308. package/dist/chunk-RJOVFHWN.cjs +3160 -0
  309. package/dist/chunk-RJOVFHWN.cjs.map +1 -0
  310. package/dist/chunk-SJMKDSRF.js +179 -0
  311. package/dist/chunk-SJMKDSRF.js.map +1 -0
  312. package/dist/chunk-TCHOIK53.cjs +4 -0
  313. package/dist/chunk-TCHOIK53.cjs.map +1 -0
  314. package/dist/chunk-TEORHM5O.js +1222 -0
  315. package/dist/chunk-TEORHM5O.js.map +1 -0
  316. package/dist/chunk-TSNDVBUU.cjs +90 -0
  317. package/dist/chunk-TSNDVBUU.cjs.map +1 -0
  318. package/dist/chunk-TTELJD4F.js +86 -0
  319. package/dist/chunk-TTELJD4F.js.map +1 -0
  320. package/dist/chunk-TX4TTPYJ.cjs +436 -0
  321. package/dist/chunk-TX4TTPYJ.cjs.map +1 -0
  322. package/dist/chunk-UCPGYU55.cjs +15 -0
  323. package/dist/chunk-UCPGYU55.cjs.map +1 -0
  324. package/dist/chunk-UWTYVVVZ.js +42 -0
  325. package/dist/chunk-UWTYVVVZ.js.map +1 -0
  326. package/dist/chunk-UXG7PYML.js +118 -0
  327. package/dist/chunk-UXG7PYML.js.map +1 -0
  328. package/dist/chunk-V3VLOOSW.cjs +36 -0
  329. package/dist/chunk-V3VLOOSW.cjs.map +1 -0
  330. package/dist/chunk-VED2OIYL.cjs +4 -0
  331. package/dist/chunk-VED2OIYL.cjs.map +1 -0
  332. package/dist/chunk-VF676YCO.cjs +150 -0
  333. package/dist/chunk-VF676YCO.cjs.map +1 -0
  334. package/dist/chunk-VHEA3YXS.js +72 -0
  335. package/dist/chunk-VHEA3YXS.js.map +1 -0
  336. package/dist/chunk-VQASQG5D.js +55 -0
  337. package/dist/chunk-VQASQG5D.js.map +1 -0
  338. package/dist/chunk-VXHOOZSK.js +446 -0
  339. package/dist/chunk-VXHOOZSK.js.map +1 -0
  340. package/dist/chunk-W4UVO3HL.cjs +82 -0
  341. package/dist/chunk-W4UVO3HL.cjs.map +1 -0
  342. package/dist/chunk-WIMFJ2BA.js +2880 -0
  343. package/dist/chunk-WIMFJ2BA.js.map +1 -0
  344. package/dist/chunk-WM4RO23J.js +145 -0
  345. package/dist/chunk-WM4RO23J.js.map +1 -0
  346. package/dist/chunk-WMTXUQC4.cjs +657 -0
  347. package/dist/chunk-WMTXUQC4.cjs.map +1 -0
  348. package/dist/chunk-WNV57BEW.cjs +1705 -0
  349. package/dist/chunk-WNV57BEW.cjs.map +1 -0
  350. package/dist/chunk-X4RMXTXF.cjs +4 -0
  351. package/dist/chunk-X4RMXTXF.cjs.map +1 -0
  352. package/dist/chunk-X7F4CSGR.cjs +67 -0
  353. package/dist/chunk-X7F4CSGR.cjs.map +1 -0
  354. package/dist/chunk-XWGHD4C7.cjs +450 -0
  355. package/dist/chunk-XWGHD4C7.cjs.map +1 -0
  356. package/dist/chunk-YFKTLS32.js +1700 -0
  357. package/dist/chunk-YFKTLS32.js.map +1 -0
  358. package/dist/chunk-ZABG3SZ2.cjs +93 -0
  359. package/dist/chunk-ZABG3SZ2.cjs.map +1 -0
  360. package/dist/chunk-ZIWN73GQ.js +267 -0
  361. package/dist/chunk-ZIWN73GQ.js.map +1 -0
  362. package/dist/chunk-ZOYE65RA.cjs +173 -0
  363. package/dist/chunk-ZOYE65RA.cjs.map +1 -0
  364. package/dist/deployer/index.cjs +12 -0
  365. package/dist/deployer/index.cjs.map +1 -0
  366. package/dist/deployer/index.d.ts +12 -0
  367. package/dist/deployer/index.d.ts.map +1 -0
  368. package/dist/deployer/index.js +3 -0
  369. package/dist/deployer/index.js.map +1 -0
  370. package/dist/deployer/index.warning.d.ts +9 -0
  371. package/dist/deployer/index.warning.d.ts.map +1 -0
  372. package/dist/di/index.cjs +12 -0
  373. package/dist/di/index.cjs.map +1 -0
  374. package/dist/di/index.d.ts +2 -0
  375. package/dist/di/index.d.ts.map +1 -0
  376. package/dist/di/index.js +3 -0
  377. package/dist/di/index.js.map +1 -0
  378. package/dist/error/index.cjs +28 -0
  379. package/dist/error/index.cjs.map +1 -0
  380. package/dist/error/index.d.ts +89 -0
  381. package/dist/error/index.d.ts.map +1 -0
  382. package/dist/error/index.js +3 -0
  383. package/dist/error/index.js.map +1 -0
  384. package/dist/error/utils.d.ts +36 -0
  385. package/dist/error/utils.d.ts.map +1 -0
  386. package/dist/eval/evaluation.d.ts +14 -0
  387. package/dist/eval/evaluation.d.ts.map +1 -0
  388. package/dist/eval/index.cjs +16 -0
  389. package/dist/eval/index.cjs.map +1 -0
  390. package/dist/eval/index.d.ts +4 -0
  391. package/dist/eval/index.d.ts.map +1 -0
  392. package/dist/eval/index.js +3 -0
  393. package/dist/eval/index.js.map +1 -0
  394. package/dist/eval/metric.d.ts +8 -0
  395. package/dist/eval/metric.d.ts.map +1 -0
  396. package/dist/eval/types.d.ts +9 -0
  397. package/dist/eval/types.d.ts.map +1 -0
  398. package/dist/events/event-emitter.d.ts +11 -0
  399. package/dist/events/event-emitter.d.ts.map +1 -0
  400. package/dist/events/index.cjs +12 -0
  401. package/dist/events/index.cjs.map +1 -0
  402. package/dist/events/index.d.ts +3 -0
  403. package/dist/events/index.d.ts.map +1 -0
  404. package/dist/events/index.js +3 -0
  405. package/dist/events/index.js.map +1 -0
  406. package/dist/events/processor.d.ts +11 -0
  407. package/dist/events/processor.d.ts.map +1 -0
  408. package/dist/events/pubsub.d.ts +8 -0
  409. package/dist/events/pubsub.d.ts.map +1 -0
  410. package/dist/events/types.d.ts +8 -0
  411. package/dist/events/types.d.ts.map +1 -0
  412. package/dist/hooks/index.cjs +20 -0
  413. package/dist/hooks/index.cjs.map +1 -0
  414. package/dist/hooks/index.d.ts +36 -0
  415. package/dist/hooks/index.d.ts.map +1 -0
  416. package/dist/hooks/index.js +3 -0
  417. package/dist/hooks/index.js.map +1 -0
  418. package/dist/hooks/mitt.d.ts +22 -0
  419. package/dist/hooks/mitt.d.ts.map +1 -0
  420. package/dist/index.cjs +371 -0
  421. package/dist/index.cjs.map +1 -0
  422. package/dist/index.d.ts +19 -0
  423. package/dist/index.d.ts.map +1 -0
  424. package/dist/index.js +120 -0
  425. package/dist/index.js.map +1 -0
  426. package/dist/integration/index.cjs +16 -0
  427. package/dist/integration/index.cjs.map +1 -0
  428. package/dist/integration/index.d.ts +3 -0
  429. package/dist/integration/index.d.ts.map +1 -0
  430. package/dist/integration/index.js +3 -0
  431. package/dist/integration/index.js.map +1 -0
  432. package/dist/integration/index.warning.d.ts +3 -0
  433. package/dist/integration/index.warning.d.ts.map +1 -0
  434. package/dist/integration/integration.d.ts +21 -0
  435. package/dist/integration/integration.d.ts.map +1 -0
  436. package/dist/integration/integration.warning.d.ts +5 -0
  437. package/dist/integration/integration.warning.d.ts.map +1 -0
  438. package/dist/integration/openapi-toolset.d.ts +16 -0
  439. package/dist/integration/openapi-toolset.d.ts.map +1 -0
  440. package/dist/integration/openapi-toolset.warning.d.ts +5 -0
  441. package/dist/integration/openapi-toolset.warning.d.ts.map +1 -0
  442. package/dist/llm/index.cjs +48 -0
  443. package/dist/llm/index.cjs.map +1 -0
  444. package/dist/llm/index.d.ts +83 -0
  445. package/dist/llm/index.d.ts.map +1 -0
  446. package/dist/llm/index.js +7 -0
  447. package/dist/llm/index.js.map +1 -0
  448. package/dist/llm/model/aisdk/v5/model.d.ts +47 -0
  449. package/dist/llm/model/aisdk/v5/model.d.ts.map +1 -0
  450. package/dist/llm/model/base.types.d.ts +100 -0
  451. package/dist/llm/model/base.types.d.ts.map +1 -0
  452. package/dist/llm/model/embedding-router.d.ts +50 -0
  453. package/dist/llm/model/embedding-router.d.ts.map +1 -0
  454. package/dist/llm/model/gateway-resolver.d.ts +11 -0
  455. package/dist/llm/model/gateway-resolver.d.ts.map +1 -0
  456. package/dist/llm/model/gateways/base.d.ts +50 -0
  457. package/dist/llm/model/gateways/base.d.ts.map +1 -0
  458. package/dist/llm/model/gateways/constants.d.ts +3 -0
  459. package/dist/llm/model/gateways/constants.d.ts.map +1 -0
  460. package/dist/llm/model/gateways/index.d.ts +11 -0
  461. package/dist/llm/model/gateways/index.d.ts.map +1 -0
  462. package/dist/llm/model/gateways/models-dev.d.ts +19 -0
  463. package/dist/llm/model/gateways/models-dev.d.ts.map +1 -0
  464. package/dist/llm/model/gateways/netlify.d.ts +25 -0
  465. package/dist/llm/model/gateways/netlify.d.ts.map +1 -0
  466. package/dist/llm/model/index.d.ts +6 -0
  467. package/dist/llm/model/index.d.ts.map +1 -0
  468. package/dist/llm/model/is-v2-model.d.ts +3 -0
  469. package/dist/llm/model/is-v2-model.d.ts.map +1 -0
  470. package/dist/llm/model/model-method-from-agent.d.ts +4 -0
  471. package/dist/llm/model/model-method-from-agent.d.ts.map +1 -0
  472. package/dist/llm/model/model.d.ts +36 -0
  473. package/dist/llm/model/model.d.ts.map +1 -0
  474. package/dist/llm/model/model.loop.d.ts +26 -0
  475. package/dist/llm/model/model.loop.d.ts.map +1 -0
  476. package/dist/llm/model/model.loop.types.d.ts +31 -0
  477. package/dist/llm/model/model.loop.types.d.ts.map +1 -0
  478. package/dist/llm/model/provider-options.d.ts +42 -0
  479. package/dist/llm/model/provider-options.d.ts.map +1 -0
  480. package/dist/llm/model/provider-registry.d.ts +108 -0
  481. package/dist/llm/model/provider-registry.d.ts.map +1 -0
  482. package/dist/llm/model/provider-types.generated.d.ts +1205 -0
  483. package/dist/llm/model/registry-generator.d.ts +41 -0
  484. package/dist/llm/model/registry-generator.d.ts.map +1 -0
  485. package/dist/llm/model/resolve-model.d.ts +46 -0
  486. package/dist/llm/model/resolve-model.d.ts.map +1 -0
  487. package/dist/llm/model/router.d.ts +30 -0
  488. package/dist/llm/model/router.d.ts.map +1 -0
  489. package/dist/llm/model/shared.types.d.ts +40 -0
  490. package/dist/llm/model/shared.types.d.ts.map +1 -0
  491. package/dist/logger/constants.d.ts +28 -0
  492. package/dist/logger/constants.d.ts.map +1 -0
  493. package/dist/logger/default-logger.d.ts +49 -0
  494. package/dist/logger/default-logger.d.ts.map +1 -0
  495. package/dist/logger/index.cjs +45 -0
  496. package/dist/logger/index.cjs.map +1 -0
  497. package/dist/logger/index.d.ts +7 -0
  498. package/dist/logger/index.d.ts.map +1 -0
  499. package/dist/logger/index.js +4 -0
  500. package/dist/logger/index.js.map +1 -0
  501. package/dist/logger/logger.d.ts +88 -0
  502. package/dist/logger/logger.d.ts.map +1 -0
  503. package/dist/logger/multi-logger.d.ts +46 -0
  504. package/dist/logger/multi-logger.d.ts.map +1 -0
  505. package/dist/logger/noop-logger.d.ts +3 -0
  506. package/dist/logger/noop-logger.d.ts.map +1 -0
  507. package/dist/logger/transport.d.ts +46 -0
  508. package/dist/logger/transport.d.ts.map +1 -0
  509. package/dist/loop/index.cjs +12 -0
  510. package/dist/loop/index.cjs.map +1 -0
  511. package/dist/loop/index.d.ts +2 -0
  512. package/dist/loop/index.d.ts.map +1 -0
  513. package/dist/loop/index.js +3 -0
  514. package/dist/loop/index.js.map +1 -0
  515. package/dist/loop/loop.d.ts +6 -0
  516. package/dist/loop/loop.d.ts.map +1 -0
  517. package/dist/loop/network/index.d.ts +145 -0
  518. package/dist/loop/network/index.d.ts.map +1 -0
  519. package/dist/loop/telemetry/index.d.ts +36 -0
  520. package/dist/loop/telemetry/index.d.ts.map +1 -0
  521. package/dist/loop/telemetry/noop.d.ts +3 -0
  522. package/dist/loop/telemetry/noop.d.ts.map +1 -0
  523. package/dist/loop/test-utils/MastraLanguageModelV2Mock.d.ts +37 -0
  524. package/dist/loop/test-utils/MastraLanguageModelV2Mock.d.ts.map +1 -0
  525. package/dist/loop/test-utils/fullStream.d.ts +6 -0
  526. package/dist/loop/test-utils/fullStream.d.ts.map +1 -0
  527. package/dist/loop/test-utils/generateText.d.ts +6 -0
  528. package/dist/loop/test-utils/generateText.d.ts.map +1 -0
  529. package/dist/loop/test-utils/mock-server-response.d.ts +28 -0
  530. package/dist/loop/test-utils/mock-server-response.d.ts.map +1 -0
  531. package/dist/loop/test-utils/mockTracer.d.ts +47 -0
  532. package/dist/loop/test-utils/mockTracer.d.ts.map +1 -0
  533. package/dist/loop/test-utils/options.d.ts +6 -0
  534. package/dist/loop/test-utils/options.d.ts.map +1 -0
  535. package/dist/loop/test-utils/resultObject.d.ts +6 -0
  536. package/dist/loop/test-utils/resultObject.d.ts.map +1 -0
  537. package/dist/loop/test-utils/streamObject.d.ts +15 -0
  538. package/dist/loop/test-utils/streamObject.d.ts.map +1 -0
  539. package/dist/loop/test-utils/telemetry.d.ts +6 -0
  540. package/dist/loop/test-utils/telemetry.d.ts.map +1 -0
  541. package/dist/loop/test-utils/textStream.d.ts +6 -0
  542. package/dist/loop/test-utils/textStream.d.ts.map +1 -0
  543. package/dist/loop/test-utils/toUIMessageStream.d.ts +6 -0
  544. package/dist/loop/test-utils/toUIMessageStream.d.ts.map +1 -0
  545. package/dist/loop/test-utils/tools.d.ts +6 -0
  546. package/dist/loop/test-utils/tools.d.ts.map +1 -0
  547. package/dist/loop/test-utils/utils.d.ts +45 -0
  548. package/dist/loop/test-utils/utils.d.ts.map +1 -0
  549. package/dist/loop/types.d.ts +111 -0
  550. package/dist/loop/types.d.ts.map +1 -0
  551. package/dist/loop/workflows/agentic-execution/index.d.ts +939 -0
  552. package/dist/loop/workflows/agentic-execution/index.d.ts.map +1 -0
  553. package/dist/loop/workflows/agentic-execution/llm-execution-step.d.ts +629 -0
  554. package/dist/loop/workflows/agentic-execution/llm-execution-step.d.ts.map +1 -0
  555. package/dist/loop/workflows/agentic-execution/llm-mapping-step.d.ts +348 -0
  556. package/dist/loop/workflows/agentic-execution/llm-mapping-step.d.ts.map +1 -0
  557. package/dist/loop/workflows/agentic-execution/tool-call-step.d.ts +58 -0
  558. package/dist/loop/workflows/agentic-execution/tool-call-step.d.ts.map +1 -0
  559. package/dist/loop/workflows/agentic-loop/index.d.ts +945 -0
  560. package/dist/loop/workflows/agentic-loop/index.d.ts.map +1 -0
  561. package/dist/loop/workflows/run-state.d.ts +29 -0
  562. package/dist/loop/workflows/run-state.d.ts.map +1 -0
  563. package/dist/loop/workflows/schema.d.ts +479 -0
  564. package/dist/loop/workflows/schema.d.ts.map +1 -0
  565. package/dist/loop/workflows/stream.d.ts +20 -0
  566. package/dist/loop/workflows/stream.d.ts.map +1 -0
  567. package/dist/mastra/hooks.d.ts +6 -0
  568. package/dist/mastra/hooks.d.ts.map +1 -0
  569. package/dist/mastra/index.cjs +12 -0
  570. package/dist/mastra/index.cjs.map +1 -0
  571. package/dist/mastra/index.d.ts +892 -0
  572. package/dist/mastra/index.d.ts.map +1 -0
  573. package/dist/mastra/index.js +3 -0
  574. package/dist/mastra/index.js.map +1 -0
  575. package/dist/mcp/index.cjs +112 -0
  576. package/dist/mcp/index.cjs.map +1 -0
  577. package/dist/mcp/index.d.ts +158 -0
  578. package/dist/mcp/index.d.ts.map +1 -0
  579. package/dist/mcp/index.js +106 -0
  580. package/dist/mcp/index.js.map +1 -0
  581. package/dist/mcp/types.d.ts +255 -0
  582. package/dist/mcp/types.d.ts.map +1 -0
  583. package/dist/memory/index.cjs +20 -0
  584. package/dist/memory/index.cjs.map +1 -0
  585. package/dist/memory/index.d.ts +3 -0
  586. package/dist/memory/index.d.ts.map +1 -0
  587. package/dist/memory/index.js +3 -0
  588. package/dist/memory/index.js.map +1 -0
  589. package/dist/memory/index.warning.d.ts +6 -0
  590. package/dist/memory/index.warning.d.ts.map +1 -0
  591. package/dist/memory/memory.d.ts +272 -0
  592. package/dist/memory/memory.d.ts.map +1 -0
  593. package/dist/memory/types.d.ts +393 -0
  594. package/dist/memory/types.d.ts.map +1 -0
  595. package/dist/models-dev-LJ4O6FNF.js +3 -0
  596. package/dist/models-dev-LJ4O6FNF.js.map +1 -0
  597. package/dist/models-dev-T2CXOEDH.cjs +12 -0
  598. package/dist/models-dev-T2CXOEDH.cjs.map +1 -0
  599. package/dist/netlify-BAEMIQNH.cjs +12 -0
  600. package/dist/netlify-BAEMIQNH.cjs.map +1 -0
  601. package/dist/netlify-L7AZ74PV.js +3 -0
  602. package/dist/netlify-L7AZ74PV.js.map +1 -0
  603. package/dist/processors/index.cjs +48 -0
  604. package/dist/processors/index.cjs.map +1 -0
  605. package/dist/processors/index.d.ts +43 -0
  606. package/dist/processors/index.d.ts.map +1 -0
  607. package/dist/processors/index.js +3 -0
  608. package/dist/processors/index.js.map +1 -0
  609. package/dist/processors/processors/batch-parts.d.ts +47 -0
  610. package/dist/processors/processors/batch-parts.d.ts.map +1 -0
  611. package/dist/processors/processors/index.d.ts +10 -0
  612. package/dist/processors/processors/index.d.ts.map +1 -0
  613. package/dist/processors/processors/language-detector.d.ts +153 -0
  614. package/dist/processors/processors/language-detector.d.ts.map +1 -0
  615. package/dist/processors/processors/moderation.d.ts +138 -0
  616. package/dist/processors/processors/moderation.d.ts.map +1 -0
  617. package/dist/processors/processors/pii-detector.d.ts +203 -0
  618. package/dist/processors/processors/pii-detector.d.ts.map +1 -0
  619. package/dist/processors/processors/prompt-injection-detector.d.ts +116 -0
  620. package/dist/processors/processors/prompt-injection-detector.d.ts.map +1 -0
  621. package/dist/processors/processors/structured-output.d.ts +53 -0
  622. package/dist/processors/processors/structured-output.d.ts.map +1 -0
  623. package/dist/processors/processors/system-prompt-scrubber.d.ts +105 -0
  624. package/dist/processors/processors/system-prompt-scrubber.d.ts.map +1 -0
  625. package/dist/processors/processors/token-limiter.d.ts +66 -0
  626. package/dist/processors/processors/token-limiter.d.ts.map +1 -0
  627. package/dist/processors/processors/unicode-normalizer.d.ts +34 -0
  628. package/dist/processors/processors/unicode-normalizer.d.ts.map +1 -0
  629. package/dist/processors/runner.d.ts +46 -0
  630. package/dist/processors/runner.d.ts.map +1 -0
  631. package/dist/provider-registry-RUDYHG7J.cjs +40 -0
  632. package/dist/provider-registry-RUDYHG7J.cjs.map +1 -0
  633. package/dist/provider-registry-THITZUJ7.js +3 -0
  634. package/dist/provider-registry-THITZUJ7.js.map +1 -0
  635. package/dist/provider-registry.json +2748 -0
  636. package/dist/registry-generator-DL42NMBM.cjs +134 -0
  637. package/dist/registry-generator-DL42NMBM.cjs.map +1 -0
  638. package/dist/registry-generator-I6S4ARS6.js +124 -0
  639. package/dist/registry-generator-I6S4ARS6.js.map +1 -0
  640. package/dist/relevance/cohere/index.d.ts +9 -0
  641. package/dist/relevance/cohere/index.d.ts.map +1 -0
  642. package/dist/relevance/index.cjs +20 -0
  643. package/dist/relevance/index.cjs.map +1 -0
  644. package/dist/relevance/index.d.ts +4 -0
  645. package/dist/relevance/index.d.ts.map +1 -0
  646. package/dist/relevance/index.js +3 -0
  647. package/dist/relevance/index.js.map +1 -0
  648. package/dist/relevance/mastra-agent/index.d.ts +8 -0
  649. package/dist/relevance/mastra-agent/index.d.ts.map +1 -0
  650. package/dist/relevance/relevance-score-provider.d.ts +5 -0
  651. package/dist/relevance/relevance-score-provider.d.ts.map +1 -0
  652. package/dist/run/types.d.ts +6 -0
  653. package/dist/run/types.d.ts.map +1 -0
  654. package/dist/runtime-context/index.cjs +12 -0
  655. package/dist/runtime-context/index.cjs.map +1 -0
  656. package/dist/runtime-context/index.d.ts +57 -0
  657. package/dist/runtime-context/index.d.ts.map +1 -0
  658. package/dist/runtime-context/index.js +3 -0
  659. package/dist/runtime-context/index.js.map +1 -0
  660. package/dist/scores/base.d.ts +141 -0
  661. package/dist/scores/base.d.ts.map +1 -0
  662. package/dist/scores/base.test-utils.d.ts +124 -0
  663. package/dist/scores/base.test-utils.d.ts.map +1 -0
  664. package/dist/scores/hooks.d.ts +19 -0
  665. package/dist/scores/hooks.d.ts.map +1 -0
  666. package/dist/scores/index.cjs +37 -0
  667. package/dist/scores/index.cjs.map +1 -0
  668. package/dist/scores/index.d.ts +4 -0
  669. package/dist/scores/index.d.ts.map +1 -0
  670. package/dist/scores/index.js +4 -0
  671. package/dist/scores/index.js.map +1 -0
  672. package/dist/scores/run-experiment/index.d.ts +61 -0
  673. package/dist/scores/run-experiment/index.d.ts.map +1 -0
  674. package/dist/scores/run-experiment/scorerAccumulator.d.ts +12 -0
  675. package/dist/scores/run-experiment/scorerAccumulator.d.ts.map +1 -0
  676. package/dist/scores/scoreTraces/index.cjs +431 -0
  677. package/dist/scores/scoreTraces/index.cjs.map +1 -0
  678. package/dist/scores/scoreTraces/index.d.ts +3 -0
  679. package/dist/scores/scoreTraces/index.d.ts.map +1 -0
  680. package/dist/scores/scoreTraces/index.js +423 -0
  681. package/dist/scores/scoreTraces/index.js.map +1 -0
  682. package/dist/scores/scoreTraces/scoreTraces.d.ts +10 -0
  683. package/dist/scores/scoreTraces/scoreTraces.d.ts.map +1 -0
  684. package/dist/scores/scoreTraces/scoreTracesWorkflow.d.ts +95 -0
  685. package/dist/scores/scoreTraces/scoreTracesWorkflow.d.ts.map +1 -0
  686. package/dist/scores/scoreTraces/utils.d.ts +21 -0
  687. package/dist/scores/scoreTraces/utils.d.ts.map +1 -0
  688. package/dist/scores/types.d.ts +191 -0
  689. package/dist/scores/types.d.ts.map +1 -0
  690. package/dist/server/auth.d.ts +36 -0
  691. package/dist/server/auth.d.ts.map +1 -0
  692. package/dist/server/composite-auth.d.ts +9 -0
  693. package/dist/server/composite-auth.d.ts.map +1 -0
  694. package/dist/server/index.cjs +185 -0
  695. package/dist/server/index.cjs.map +1 -0
  696. package/dist/server/index.d.ts +37 -0
  697. package/dist/server/index.d.ts.map +1 -0
  698. package/dist/server/index.js +180 -0
  699. package/dist/server/index.js.map +1 -0
  700. package/dist/server/simple-auth.d.ts +32 -0
  701. package/dist/server/simple-auth.d.ts.map +1 -0
  702. package/dist/server/types.d.ts +140 -0
  703. package/dist/server/types.d.ts.map +1 -0
  704. package/dist/storage/base.d.ts +360 -0
  705. package/dist/storage/base.d.ts.map +1 -0
  706. package/dist/storage/base.warning.d.ts +8 -0
  707. package/dist/storage/base.warning.d.ts.map +1 -0
  708. package/dist/storage/constants.d.ts +14 -0
  709. package/dist/storage/constants.d.ts.map +1 -0
  710. package/dist/storage/domains/index.d.ts +8 -0
  711. package/dist/storage/domains/index.d.ts.map +1 -0
  712. package/dist/storage/domains/legacy-evals/base.d.ts +13 -0
  713. package/dist/storage/domains/legacy-evals/base.d.ts.map +1 -0
  714. package/dist/storage/domains/legacy-evals/index.d.ts +2 -0
  715. package/dist/storage/domains/legacy-evals/index.d.ts.map +1 -0
  716. package/dist/storage/domains/legacy-evals/inmemory.d.ts +17 -0
  717. package/dist/storage/domains/legacy-evals/inmemory.d.ts.map +1 -0
  718. package/dist/storage/domains/memory/base.d.ts +96 -0
  719. package/dist/storage/domains/memory/base.d.ts.map +1 -0
  720. package/dist/storage/domains/memory/index.d.ts +3 -0
  721. package/dist/storage/domains/memory/index.d.ts.map +1 -0
  722. package/dist/storage/domains/memory/inmemory.d.ts +85 -0
  723. package/dist/storage/domains/memory/inmemory.d.ts.map +1 -0
  724. package/dist/storage/domains/observability/base.d.ts +60 -0
  725. package/dist/storage/domains/observability/base.d.ts.map +1 -0
  726. package/dist/storage/domains/observability/index.d.ts +3 -0
  727. package/dist/storage/domains/observability/index.d.ts.map +1 -0
  728. package/dist/storage/domains/observability/inmemory.d.ts +48 -0
  729. package/dist/storage/domains/observability/inmemory.d.ts.map +1 -0
  730. package/dist/storage/domains/operations/base.d.ts +68 -0
  731. package/dist/storage/domains/operations/base.d.ts.map +1 -0
  732. package/dist/storage/domains/operations/index.d.ts +3 -0
  733. package/dist/storage/domains/operations/index.d.ts.map +1 -0
  734. package/dist/storage/domains/operations/inmemory.d.ts +37 -0
  735. package/dist/storage/domains/operations/inmemory.d.ts.map +1 -0
  736. package/dist/storage/domains/scores/base.d.ts +46 -0
  737. package/dist/storage/domains/scores/base.d.ts.map +1 -0
  738. package/dist/storage/domains/scores/index.d.ts +3 -0
  739. package/dist/storage/domains/scores/index.d.ts.map +1 -0
  740. package/dist/storage/domains/scores/inmemory.d.ts +50 -0
  741. package/dist/storage/domains/scores/inmemory.d.ts.map +1 -0
  742. package/dist/storage/domains/traces/base.d.ts +14 -0
  743. package/dist/storage/domains/traces/base.d.ts.map +1 -0
  744. package/dist/storage/domains/traces/index.d.ts +3 -0
  745. package/dist/storage/domains/traces/index.d.ts.map +1 -0
  746. package/dist/storage/domains/traces/inmemory.d.ts +22 -0
  747. package/dist/storage/domains/traces/inmemory.d.ts.map +1 -0
  748. package/dist/storage/domains/workflows/base.d.ts +47 -0
  749. package/dist/storage/domains/workflows/base.d.ts.map +1 -0
  750. package/dist/storage/domains/workflows/index.d.ts +3 -0
  751. package/dist/storage/domains/workflows/index.d.ts.map +1 -0
  752. package/dist/storage/domains/workflows/inmemory.d.ts +54 -0
  753. package/dist/storage/domains/workflows/inmemory.d.ts.map +1 -0
  754. package/dist/storage/index.cjs +1821 -0
  755. package/dist/storage/index.cjs.map +1 -0
  756. package/dist/storage/index.d.ts +7 -0
  757. package/dist/storage/index.d.ts.map +1 -0
  758. package/dist/storage/index.js +1746 -0
  759. package/dist/storage/index.js.map +1 -0
  760. package/dist/storage/index.warning.d.ts +3 -0
  761. package/dist/storage/index.warning.d.ts.map +1 -0
  762. package/dist/storage/mock.d.ts +242 -0
  763. package/dist/storage/mock.d.ts.map +1 -0
  764. package/dist/storage/storageWithInit.d.ts +3 -0
  765. package/dist/storage/storageWithInit.d.ts.map +1 -0
  766. package/dist/storage/types.d.ts +206 -0
  767. package/dist/storage/types.d.ts.map +1 -0
  768. package/dist/storage/utils.d.ts +2 -0
  769. package/dist/storage/utils.d.ts.map +1 -0
  770. package/dist/stream/MastraAgentNetworkStream.d.ts +22 -0
  771. package/dist/stream/MastraAgentNetworkStream.d.ts.map +1 -0
  772. package/dist/stream/MastraWorkflowStream.d.ts +19 -0
  773. package/dist/stream/MastraWorkflowStream.d.ts.map +1 -0
  774. package/dist/stream/RunOutput.d.ts +72 -0
  775. package/dist/stream/RunOutput.d.ts.map +1 -0
  776. package/dist/stream/aisdk/v4/input.d.ts +16 -0
  777. package/dist/stream/aisdk/v4/input.d.ts.map +1 -0
  778. package/dist/stream/aisdk/v4/transform.d.ts +5 -0
  779. package/dist/stream/aisdk/v4/transform.d.ts.map +1 -0
  780. package/dist/stream/aisdk/v5/compat/consume-stream.d.ts +8 -0
  781. package/dist/stream/aisdk/v5/compat/consume-stream.d.ts.map +1 -0
  782. package/dist/stream/aisdk/v5/compat/content.d.ts +7 -0
  783. package/dist/stream/aisdk/v5/compat/content.d.ts.map +1 -0
  784. package/dist/stream/aisdk/v5/compat/delayed-promise.d.ts +23 -0
  785. package/dist/stream/aisdk/v5/compat/delayed-promise.d.ts.map +1 -0
  786. package/dist/stream/aisdk/v5/compat/index.d.ts +8 -0
  787. package/dist/stream/aisdk/v5/compat/index.d.ts.map +1 -0
  788. package/dist/stream/aisdk/v5/compat/media.d.ts +91 -0
  789. package/dist/stream/aisdk/v5/compat/media.d.ts.map +1 -0
  790. package/dist/stream/aisdk/v5/compat/prepare-tools.d.ts +11 -0
  791. package/dist/stream/aisdk/v5/compat/prepare-tools.d.ts.map +1 -0
  792. package/dist/stream/aisdk/v5/compat/ui-message.d.ts +20 -0
  793. package/dist/stream/aisdk/v5/compat/ui-message.d.ts.map +1 -0
  794. package/dist/stream/aisdk/v5/compat/validation.d.ts +17 -0
  795. package/dist/stream/aisdk/v5/compat/validation.d.ts.map +1 -0
  796. package/dist/stream/aisdk/v5/execute.d.ts +41 -0
  797. package/dist/stream/aisdk/v5/execute.d.ts.map +1 -0
  798. package/dist/stream/aisdk/v5/file.d.ts +38 -0
  799. package/dist/stream/aisdk/v5/file.d.ts.map +1 -0
  800. package/dist/stream/aisdk/v5/input.d.ts +16 -0
  801. package/dist/stream/aisdk/v5/input.d.ts.map +1 -0
  802. package/dist/stream/aisdk/v5/output-helpers.d.ts +66 -0
  803. package/dist/stream/aisdk/v5/output-helpers.d.ts.map +1 -0
  804. package/dist/stream/aisdk/v5/output.d.ts +173 -0
  805. package/dist/stream/aisdk/v5/output.d.ts.map +1 -0
  806. package/dist/stream/aisdk/v5/test-utils.d.ts +19 -0
  807. package/dist/stream/aisdk/v5/test-utils.d.ts.map +1 -0
  808. package/dist/stream/aisdk/v5/transform.d.ts +27 -0
  809. package/dist/stream/aisdk/v5/transform.d.ts.map +1 -0
  810. package/dist/stream/base/base.d.ts +7 -0
  811. package/dist/stream/base/base.d.ts.map +1 -0
  812. package/dist/stream/base/consume-stream.d.ts +5 -0
  813. package/dist/stream/base/consume-stream.d.ts.map +1 -0
  814. package/dist/stream/base/index.d.ts +2 -0
  815. package/dist/stream/base/index.d.ts.map +1 -0
  816. package/dist/stream/base/input.d.ts +16 -0
  817. package/dist/stream/base/input.d.ts.map +1 -0
  818. package/dist/stream/base/output-format-handlers.d.ts +29 -0
  819. package/dist/stream/base/output-format-handlers.d.ts.map +1 -0
  820. package/dist/stream/base/output.d.ts +313 -0
  821. package/dist/stream/base/output.d.ts.map +1 -0
  822. package/dist/stream/base/schema.d.ts +31 -0
  823. package/dist/stream/base/schema.d.ts.map +1 -0
  824. package/dist/stream/index.cjs +45 -0
  825. package/dist/stream/index.cjs.map +1 -0
  826. package/dist/stream/index.d.ts +11 -0
  827. package/dist/stream/index.d.ts.map +1 -0
  828. package/dist/stream/index.js +4 -0
  829. package/dist/stream/index.js.map +1 -0
  830. package/dist/stream/types.d.ts +734 -0
  831. package/dist/stream/types.d.ts.map +1 -0
  832. package/dist/telemetry/composite-exporter.d.ts +10 -0
  833. package/dist/telemetry/composite-exporter.d.ts.map +1 -0
  834. package/dist/telemetry/index.cjs +32 -0
  835. package/dist/telemetry/index.cjs.map +1 -0
  836. package/dist/telemetry/index.d.ts +6 -0
  837. package/dist/telemetry/index.d.ts.map +1 -0
  838. package/dist/telemetry/index.js +3 -0
  839. package/dist/telemetry/index.js.map +1 -0
  840. package/dist/telemetry/otel-vendor.cjs +105 -0
  841. package/dist/telemetry/otel-vendor.cjs.map +1 -0
  842. package/dist/telemetry/otel-vendor.d.ts +11 -0
  843. package/dist/telemetry/otel-vendor.d.ts.map +1 -0
  844. package/dist/telemetry/otel-vendor.js +59 -0
  845. package/dist/telemetry/otel-vendor.js.map +1 -0
  846. package/dist/telemetry/storage-exporter.d.ts +21 -0
  847. package/dist/telemetry/storage-exporter.d.ts.map +1 -0
  848. package/dist/telemetry/telemetry.d.ts +59 -0
  849. package/dist/telemetry/telemetry.d.ts.map +1 -0
  850. package/dist/telemetry/telemetry.decorators.d.ts +15 -0
  851. package/dist/telemetry/telemetry.decorators.d.ts.map +1 -0
  852. package/dist/telemetry/types.d.ts +74 -0
  853. package/dist/telemetry/types.d.ts.map +1 -0
  854. package/dist/telemetry/utility.d.ts +15 -0
  855. package/dist/telemetry/utility.d.ts.map +1 -0
  856. package/dist/test-utils/llm-mock.cjs +181 -0
  857. package/dist/test-utils/llm-mock.cjs.map +1 -0
  858. package/dist/test-utils/llm-mock.d.ts +21 -0
  859. package/dist/test-utils/llm-mock.d.ts.map +1 -0
  860. package/dist/test-utils/llm-mock.js +178 -0
  861. package/dist/test-utils/llm-mock.js.map +1 -0
  862. package/dist/tools/index.cjs +25 -0
  863. package/dist/tools/index.cjs.map +1 -0
  864. package/dist/tools/index.d.ts +6 -0
  865. package/dist/tools/index.d.ts.map +1 -0
  866. package/dist/tools/index.js +4 -0
  867. package/dist/tools/index.js.map +1 -0
  868. package/dist/tools/index.warning.d.ts +8 -0
  869. package/dist/tools/index.warning.d.ts.map +1 -0
  870. package/dist/tools/is-vercel-tool.cjs +12 -0
  871. package/dist/tools/is-vercel-tool.cjs.map +1 -0
  872. package/dist/tools/is-vercel-tool.d.ts +2 -0
  873. package/dist/tools/is-vercel-tool.d.ts.map +1 -0
  874. package/dist/tools/is-vercel-tool.js +3 -0
  875. package/dist/tools/is-vercel-tool.js.map +1 -0
  876. package/dist/tools/stream.d.ts +19 -0
  877. package/dist/tools/stream.d.ts.map +1 -0
  878. package/dist/tools/tool-builder/builder.d.ts +28 -0
  879. package/dist/tools/tool-builder/builder.d.ts.map +1 -0
  880. package/dist/tools/tool.d.ts +186 -0
  881. package/dist/tools/tool.d.ts.map +1 -0
  882. package/dist/tools/toolchecks.d.ts +9 -0
  883. package/dist/tools/toolchecks.d.ts.map +1 -0
  884. package/dist/tools/types.d.ts +70 -0
  885. package/dist/tools/types.d.ts.map +1 -0
  886. package/dist/tools/ui-types.d.ts +39 -0
  887. package/dist/tools/ui-types.d.ts.map +1 -0
  888. package/dist/tools/validation.d.ts +19 -0
  889. package/dist/tools/validation.d.ts.map +1 -0
  890. package/dist/tts/index.cjs +12 -0
  891. package/dist/tts/index.cjs.map +1 -0
  892. package/dist/tts/index.d.ts +22 -0
  893. package/dist/tts/index.d.ts.map +1 -0
  894. package/dist/tts/index.js +3 -0
  895. package/dist/tts/index.js.map +1 -0
  896. package/dist/tts/index.warning.d.ts +7 -0
  897. package/dist/tts/index.warning.d.ts.map +1 -0
  898. package/dist/types/dynamic-argument.d.ts +9 -0
  899. package/dist/types/dynamic-argument.d.ts.map +1 -0
  900. package/dist/types/index.cjs +4 -0
  901. package/dist/types/index.cjs.map +1 -0
  902. package/dist/types/index.d.ts +2 -0
  903. package/dist/types/index.d.ts.map +1 -0
  904. package/dist/types/index.js +3 -0
  905. package/dist/types/index.js.map +1 -0
  906. package/dist/types/zod-compat.d.ts +23 -0
  907. package/dist/types/zod-compat.d.ts.map +1 -0
  908. package/dist/utils.cjs +72 -0
  909. package/dist/utils.cjs.map +1 -0
  910. package/dist/utils.d.ts +148 -0
  911. package/dist/utils.d.ts.map +1 -0
  912. package/dist/utils.js +3 -0
  913. package/dist/utils.js.map +1 -0
  914. package/dist/vector/embed.d.ts +3 -0
  915. package/dist/vector/embed.d.ts.map +1 -0
  916. package/dist/vector/filter/base.d.ts +128 -0
  917. package/dist/vector/filter/base.d.ts.map +1 -0
  918. package/dist/vector/filter/index.cjs +12 -0
  919. package/dist/vector/filter/index.cjs.map +1 -0
  920. package/dist/vector/filter/index.d.ts +2 -0
  921. package/dist/vector/filter/index.d.ts.map +1 -0
  922. package/dist/vector/filter/index.js +3 -0
  923. package/dist/vector/filter/index.js.map +1 -0
  924. package/dist/vector/index.cjs +25 -0
  925. package/dist/vector/index.cjs.map +1 -0
  926. package/dist/vector/index.d.ts +5 -0
  927. package/dist/vector/index.d.ts.map +1 -0
  928. package/dist/vector/index.js +4 -0
  929. package/dist/vector/index.js.map +1 -0
  930. package/dist/vector/index.warning.d.ts +6 -0
  931. package/dist/vector/index.warning.d.ts.map +1 -0
  932. package/dist/vector/types.d.ts +152 -0
  933. package/dist/vector/types.d.ts.map +1 -0
  934. package/dist/vector/vector.d.ts +57 -0
  935. package/dist/vector/vector.d.ts.map +1 -0
  936. package/dist/voice/aisdk/index.d.ts +3 -0
  937. package/dist/voice/aisdk/index.d.ts.map +1 -0
  938. package/dist/voice/aisdk/speech.d.ts +23 -0
  939. package/dist/voice/aisdk/speech.d.ts.map +1 -0
  940. package/dist/voice/aisdk/transcription.d.ts +22 -0
  941. package/dist/voice/aisdk/transcription.d.ts.map +1 -0
  942. package/dist/voice/composite-voice.d.ts +78 -0
  943. package/dist/voice/composite-voice.d.ts.map +1 -0
  944. package/dist/voice/default-voice.d.ts +13 -0
  945. package/dist/voice/default-voice.d.ts.map +1 -0
  946. package/dist/voice/index.cjs +28 -0
  947. package/dist/voice/index.cjs.map +1 -0
  948. package/dist/voice/index.d.ts +5 -0
  949. package/dist/voice/index.d.ts.map +1 -0
  950. package/dist/voice/index.js +3 -0
  951. package/dist/voice/index.js.map +1 -0
  952. package/dist/voice/voice.d.ts +132 -0
  953. package/dist/voice/voice.d.ts.map +1 -0
  954. package/dist/workflows/constants.cjs +16 -0
  955. package/dist/workflows/constants.cjs.map +1 -0
  956. package/dist/workflows/constants.d.ts +3 -0
  957. package/dist/workflows/constants.d.ts.map +1 -0
  958. package/dist/workflows/constants.js +3 -0
  959. package/dist/workflows/constants.js.map +1 -0
  960. package/dist/workflows/default.d.ts +345 -0
  961. package/dist/workflows/default.d.ts.map +1 -0
  962. package/dist/workflows/evented/execution-engine.d.ts +41 -0
  963. package/dist/workflows/evented/execution-engine.d.ts.map +1 -0
  964. package/dist/workflows/evented/index.cjs +44 -0
  965. package/dist/workflows/evented/index.cjs.map +1 -0
  966. package/dist/workflows/evented/index.d.ts +5 -0
  967. package/dist/workflows/evented/index.d.ts.map +1 -0
  968. package/dist/workflows/evented/index.js +3 -0
  969. package/dist/workflows/evented/index.js.map +1 -0
  970. package/dist/workflows/evented/step-executor.d.ts +90 -0
  971. package/dist/workflows/evented/step-executor.d.ts.map +1 -0
  972. package/dist/workflows/evented/workflow-event-processor/index.d.ts +54 -0
  973. package/dist/workflows/evented/workflow-event-processor/index.d.ts.map +1 -0
  974. package/dist/workflows/evented/workflow-event-processor/loop.d.ts +21 -0
  975. package/dist/workflows/evented/workflow-event-processor/loop.d.ts.map +1 -0
  976. package/dist/workflows/evented/workflow-event-processor/parallel.d.ts +18 -0
  977. package/dist/workflows/evented/workflow-event-processor/parallel.d.ts.map +1 -0
  978. package/dist/workflows/evented/workflow-event-processor/sleep.d.ts +24 -0
  979. package/dist/workflows/evented/workflow-event-processor/sleep.d.ts.map +1 -0
  980. package/dist/workflows/evented/workflow-event-processor/utils.d.ts +30 -0
  981. package/dist/workflows/evented/workflow-event-processor/utils.d.ts.map +1 -0
  982. package/dist/workflows/evented/workflow.d.ts +81 -0
  983. package/dist/workflows/evented/workflow.d.ts.map +1 -0
  984. package/dist/workflows/execution-engine.d.ts +75 -0
  985. package/dist/workflows/execution-engine.d.ts.map +1 -0
  986. package/dist/workflows/index.cjs +60 -0
  987. package/dist/workflows/index.cjs.map +1 -0
  988. package/dist/workflows/index.d.ts +7 -0
  989. package/dist/workflows/index.d.ts.map +1 -0
  990. package/dist/workflows/index.js +3 -0
  991. package/dist/workflows/index.js.map +1 -0
  992. package/dist/workflows/index.warning.d.ts +6 -0
  993. package/dist/workflows/index.warning.d.ts.map +1 -0
  994. package/dist/workflows/legacy/index.cjs +92 -0
  995. package/dist/workflows/legacy/index.cjs.map +1 -0
  996. package/dist/workflows/legacy/index.d.ts +5 -0
  997. package/dist/workflows/legacy/index.d.ts.map +1 -0
  998. package/dist/workflows/legacy/index.js +3 -0
  999. package/dist/workflows/legacy/index.js.map +1 -0
  1000. package/dist/workflows/legacy/machine.d.ts +386 -0
  1001. package/dist/workflows/legacy/machine.d.ts.map +1 -0
  1002. package/dist/workflows/legacy/step.d.ts +15 -0
  1003. package/dist/workflows/legacy/step.d.ts.map +1 -0
  1004. package/dist/workflows/legacy/types.d.ts +397 -0
  1005. package/dist/workflows/legacy/types.d.ts.map +1 -0
  1006. package/dist/workflows/legacy/utils.d.ts +68 -0
  1007. package/dist/workflows/legacy/utils.d.ts.map +1 -0
  1008. package/dist/workflows/legacy/workflow-instance.d.ts +97 -0
  1009. package/dist/workflows/legacy/workflow-instance.d.ts.map +1 -0
  1010. package/dist/workflows/legacy/workflow.d.ts +109 -0
  1011. package/dist/workflows/legacy/workflow.d.ts.map +1 -0
  1012. package/dist/workflows/step.d.ts +64 -0
  1013. package/dist/workflows/step.d.ts.map +1 -0
  1014. package/dist/workflows/types.d.ts +351 -0
  1015. package/dist/workflows/types.d.ts.map +1 -0
  1016. package/dist/workflows/utils.d.ts +19 -0
  1017. package/dist/workflows/utils.d.ts.map +1 -0
  1018. package/dist/workflows/workflow.d.ts +493 -0
  1019. package/dist/workflows/workflow.d.ts.map +1 -0
  1020. package/dist/workflows/workflow.warning.d.ts +9 -0
  1021. package/dist/workflows/workflow.warning.d.ts.map +1 -0
  1022. package/dist/zod-to-json.cjs +12 -0
  1023. package/dist/zod-to-json.cjs.map +1 -0
  1024. package/dist/zod-to-json.d.ts +2 -0
  1025. package/dist/zod-to-json.d.ts.map +1 -0
  1026. package/dist/zod-to-json.js +3 -0
  1027. package/dist/zod-to-json.js.map +1 -0
  1028. package/error.d.ts +1 -0
  1029. package/eval.d.ts +1 -0
  1030. package/events.d.ts +1 -0
  1031. package/hooks.d.ts +1 -0
  1032. package/integration.d.ts +1 -0
  1033. package/llm.d.ts +1 -0
  1034. package/logger.d.ts +1 -0
  1035. package/loop.d.ts +1 -0
  1036. package/mastra.d.ts +1 -0
  1037. package/mcp.d.ts +1 -0
  1038. package/memory.d.ts +1 -0
  1039. package/package.json +305 -0
  1040. package/processors.d.ts +1 -0
  1041. package/relevance.d.ts +1 -0
  1042. package/runtime-context.d.ts +1 -0
  1043. package/scores/scoreTraces.d.ts +1 -0
  1044. package/scores.d.ts +1 -0
  1045. package/server.d.ts +1 -0
  1046. package/src/llm/model/provider-types.generated.d.ts +1205 -0
  1047. package/storage.d.ts +1 -0
  1048. package/stream.d.ts +1 -0
  1049. package/telemetry/otel-vendor.d.ts +1 -0
  1050. package/telemetry.d.ts +1 -0
  1051. package/test-utils/llm-mock.d.ts +1 -0
  1052. package/tools/is-vercel-tool.d.ts +1 -0
  1053. package/tools.d.ts +1 -0
  1054. package/tts.d.ts +1 -0
  1055. package/types.d.ts +1 -0
  1056. package/utils/zod-to-json.d.ts +1 -0
  1057. package/utils.d.ts +1 -0
  1058. package/vector/filter.d.ts +1 -0
  1059. package/vector.d.ts +1 -0
  1060. package/voice.d.ts +1 -0
  1061. package/workflows/_constants.d.ts +1 -0
  1062. package/workflows/evented.d.ts +1 -0
  1063. package/workflows/legacy.d.ts +1 -0
  1064. package/workflows.d.ts +1 -0
@@ -0,0 +1,2539 @@
1
+ import { validateStepInput, getStepResult, Workflow, Run, ExecutionEngine } from './chunk-TEORHM5O.js';
2
+ import { STREAM_FORMAT_SYMBOL, EMITTER_SYMBOL } from './chunk-NLNKQD2T.js';
3
+ import { RuntimeContext } from './chunk-HLRWYUFN.js';
4
+ import { MastraError } from './chunk-PZUZNPFM.js';
5
+ import { Tool } from './chunk-WM4RO23J.js';
6
+ import { MastraBase } from './chunk-VQASQG5D.js';
7
+ import { RegisteredLogger } from './chunk-UXG7PYML.js';
8
+ import EventEmitter from 'events';
9
+ import { randomUUID } from 'crypto';
10
+ import z from 'zod';
11
+
12
+ var StepExecutor = class extends MastraBase {
13
+ mastra;
14
+ constructor({ mastra }) {
15
+ super({ name: "StepExecutor", component: RegisteredLogger.WORKFLOW });
16
+ this.mastra = mastra;
17
+ }
18
+ __registerMastra(mastra) {
19
+ this.mastra = mastra;
20
+ }
21
+ async execute(params) {
22
+ const { step, stepResults, runId, runtimeContext, runCount = 0 } = params;
23
+ const abortController = new AbortController();
24
+ let suspended;
25
+ let bailed;
26
+ const startedAt = Date.now();
27
+ const { inputData, validationError } = await validateStepInput({
28
+ prevOutput: typeof params.foreachIdx === "number" ? params.input?.[params.foreachIdx] : params.input,
29
+ step,
30
+ validateInputs: params.validateInputs ?? false
31
+ });
32
+ let stepInfo = {
33
+ ...stepResults[step.id],
34
+ startedAt,
35
+ payload: (typeof params.foreachIdx === "number" ? params.input : inputData) ?? {}
36
+ };
37
+ if (params.resumeData) {
38
+ delete stepInfo.suspendPayload?.["__workflow_meta"];
39
+ stepInfo.resumePayload = params.resumeData;
40
+ stepInfo.resumedAt = Date.now();
41
+ }
42
+ try {
43
+ if (validationError) {
44
+ throw validationError;
45
+ }
46
+ const stepResult = await step.execute({
47
+ workflowId: params.workflowId,
48
+ runId,
49
+ mastra: this.mastra,
50
+ runtimeContext,
51
+ inputData,
52
+ state: params.state,
53
+ setState: (state) => {
54
+ params.state = state;
55
+ },
56
+ runCount,
57
+ resumeData: params.resumeData,
58
+ getInitData: () => stepResults?.input,
59
+ getStepResult: getStepResult.bind(this, stepResults),
60
+ suspend: async (suspendPayload) => {
61
+ suspended = { payload: { ...suspendPayload, __workflow_meta: { runId, path: [step.id] } } };
62
+ },
63
+ bail: (result) => {
64
+ bailed = { payload: result };
65
+ },
66
+ // TODO
67
+ writer: void 0,
68
+ abort: () => {
69
+ abortController?.abort();
70
+ },
71
+ [EMITTER_SYMBOL]: params.emitter,
72
+ // TODO: refactor this to use our PubSub actually
73
+ [STREAM_FORMAT_SYMBOL]: void 0,
74
+ // TODO
75
+ engine: {},
76
+ abortSignal: abortController?.signal,
77
+ // TODO
78
+ tracingContext: {}
79
+ });
80
+ const endedAt = Date.now();
81
+ let finalResult;
82
+ if (suspended) {
83
+ finalResult = {
84
+ ...stepInfo,
85
+ status: "suspended",
86
+ suspendedAt: endedAt
87
+ };
88
+ if (suspended.payload) {
89
+ finalResult.suspendPayload = suspended.payload;
90
+ }
91
+ } else if (bailed) {
92
+ finalResult = {
93
+ ...stepInfo,
94
+ // @ts-ignore
95
+ status: "bailed",
96
+ endedAt,
97
+ output: bailed.payload
98
+ };
99
+ } else {
100
+ finalResult = {
101
+ ...stepInfo,
102
+ status: "success",
103
+ endedAt,
104
+ output: stepResult
105
+ };
106
+ }
107
+ return finalResult;
108
+ } catch (error) {
109
+ const endedAt = Date.now();
110
+ return {
111
+ ...stepInfo,
112
+ status: "failed",
113
+ endedAt,
114
+ error: error instanceof Error ? error?.stack ?? error.message : error
115
+ };
116
+ }
117
+ }
118
+ async evaluateConditions(params) {
119
+ const { step, stepResults, runId, runtimeContext, runCount = 0 } = params;
120
+ const abortController = new AbortController();
121
+ const ee = new EventEmitter();
122
+ const results = await Promise.all(
123
+ step.conditions.map((condition) => {
124
+ try {
125
+ return this.evaluateCondition({
126
+ workflowId: params.workflowId,
127
+ condition,
128
+ runId,
129
+ runtimeContext,
130
+ inputData: params.input,
131
+ state: params.state,
132
+ runCount,
133
+ resumeData: params.resumeData,
134
+ abortController,
135
+ stepResults,
136
+ emitter: ee,
137
+ iterationCount: 0
138
+ });
139
+ } catch (e) {
140
+ console.error("error evaluating condition", e);
141
+ return false;
142
+ }
143
+ })
144
+ );
145
+ const idxs = results.reduce((acc, result, idx) => {
146
+ if (result) {
147
+ acc.push(idx);
148
+ }
149
+ return acc;
150
+ }, []);
151
+ return idxs;
152
+ }
153
+ async evaluateCondition({
154
+ workflowId,
155
+ condition,
156
+ runId,
157
+ inputData,
158
+ resumeData,
159
+ stepResults,
160
+ state,
161
+ runtimeContext,
162
+ emitter,
163
+ abortController,
164
+ runCount = 0,
165
+ iterationCount
166
+ }) {
167
+ return condition({
168
+ workflowId,
169
+ runId,
170
+ mastra: this.mastra,
171
+ runtimeContext,
172
+ inputData,
173
+ state,
174
+ setState: (_state) => {
175
+ },
176
+ runCount,
177
+ resumeData,
178
+ getInitData: () => stepResults?.input,
179
+ getStepResult: getStepResult.bind(this, stepResults),
180
+ suspend: async (_suspendPayload) => {
181
+ throw new Error("Not implemented");
182
+ },
183
+ bail: (_result) => {
184
+ throw new Error("Not implemented");
185
+ },
186
+ // TODO
187
+ writer: void 0,
188
+ abort: () => {
189
+ abortController?.abort();
190
+ },
191
+ [EMITTER_SYMBOL]: emitter,
192
+ // TODO: refactor this to use our PubSub actually
193
+ [STREAM_FORMAT_SYMBOL]: void 0,
194
+ // TODO
195
+ engine: {},
196
+ abortSignal: abortController?.signal,
197
+ // TODO
198
+ tracingContext: {},
199
+ iterationCount
200
+ });
201
+ }
202
+ async resolveSleep(params) {
203
+ const { step, stepResults, runId, runtimeContext, runCount = 0 } = params;
204
+ const abortController = new AbortController();
205
+ const ee = new EventEmitter();
206
+ if (step.duration) {
207
+ return step.duration;
208
+ }
209
+ if (!step.fn) {
210
+ return 0;
211
+ }
212
+ try {
213
+ return await step.fn({
214
+ workflowId: params.workflowId,
215
+ runId,
216
+ mastra: this.mastra,
217
+ runtimeContext,
218
+ inputData: params.input,
219
+ // TODO: implement state
220
+ state: {},
221
+ setState: (_state) => {
222
+ },
223
+ runCount,
224
+ resumeData: params.resumeData,
225
+ getInitData: () => stepResults?.input,
226
+ getStepResult: getStepResult.bind(this, stepResults),
227
+ suspend: async (_suspendPayload) => {
228
+ throw new Error("Not implemented");
229
+ },
230
+ bail: (_result) => {
231
+ throw new Error("Not implemented");
232
+ },
233
+ abort: () => {
234
+ abortController?.abort();
235
+ },
236
+ // TODO
237
+ writer: void 0,
238
+ [EMITTER_SYMBOL]: ee,
239
+ // TODO: refactor this to use our PubSub actually
240
+ [STREAM_FORMAT_SYMBOL]: void 0,
241
+ // TODO
242
+ engine: {},
243
+ abortSignal: abortController?.signal,
244
+ // TODO
245
+ tracingContext: {}
246
+ });
247
+ } catch (e) {
248
+ console.error("error evaluating condition", e);
249
+ return 0;
250
+ }
251
+ }
252
+ async resolveSleepUntil(params) {
253
+ const { step, stepResults, runId, runtimeContext, runCount = 0 } = params;
254
+ const abortController = new AbortController();
255
+ const ee = new EventEmitter();
256
+ if (step.date) {
257
+ return step.date.getTime() - Date.now();
258
+ }
259
+ if (!step.fn) {
260
+ return 0;
261
+ }
262
+ try {
263
+ const result = await step.fn({
264
+ workflowId: params.workflowId,
265
+ runId,
266
+ mastra: this.mastra,
267
+ runtimeContext,
268
+ inputData: params.input,
269
+ // TODO: implement state
270
+ state: {},
271
+ setState: (_state) => {
272
+ },
273
+ runCount,
274
+ resumeData: params.resumeData,
275
+ getInitData: () => stepResults?.input,
276
+ getStepResult: getStepResult.bind(this, stepResults),
277
+ suspend: async (_suspendPayload) => {
278
+ throw new Error("Not implemented");
279
+ },
280
+ bail: (_result) => {
281
+ throw new Error("Not implemented");
282
+ },
283
+ abort: () => {
284
+ abortController?.abort();
285
+ },
286
+ // TODO
287
+ writer: void 0,
288
+ [EMITTER_SYMBOL]: ee,
289
+ // TODO: refactor this to use our PubSub actually
290
+ [STREAM_FORMAT_SYMBOL]: void 0,
291
+ // TODO
292
+ engine: {},
293
+ abortSignal: abortController?.signal,
294
+ // TODO
295
+ tracingContext: {}
296
+ });
297
+ return result.getTime() - Date.now();
298
+ } catch (e) {
299
+ console.error("error evaluating condition", e);
300
+ return 0;
301
+ }
302
+ }
303
+ };
304
+
305
+ // src/events/processor.ts
306
+ var EventProcessor = class {
307
+ mastra;
308
+ __registerMastra(mastra) {
309
+ this.mastra = mastra;
310
+ }
311
+ constructor({ mastra }) {
312
+ this.mastra = mastra;
313
+ }
314
+ };
315
+ async function processWorkflowLoop({
316
+ workflowId,
317
+ prevResult,
318
+ runId,
319
+ executionPath,
320
+ stepResults,
321
+ activeSteps,
322
+ resumeSteps,
323
+ resumeData,
324
+ parentWorkflow,
325
+ runtimeContext,
326
+ runCount = 0
327
+ }, {
328
+ pubsub,
329
+ stepExecutor,
330
+ step,
331
+ stepResult
332
+ }) {
333
+ const loopCondition = await stepExecutor.evaluateCondition({
334
+ workflowId,
335
+ condition: step.condition,
336
+ runId,
337
+ stepResults,
338
+ // TODO: implement state
339
+ state: {},
340
+ emitter: new EventEmitter(),
341
+ // TODO
342
+ runtimeContext: new RuntimeContext(),
343
+ // TODO
344
+ inputData: prevResult?.status === "success" ? prevResult.output : void 0,
345
+ resumeData,
346
+ abortController: new AbortController(),
347
+ runCount,
348
+ iterationCount: 0
349
+ //TODO: implement
350
+ });
351
+ if (step.loopType === "dountil") {
352
+ if (loopCondition) {
353
+ await pubsub.publish("workflows", {
354
+ type: "workflow.step.end",
355
+ runId,
356
+ data: {
357
+ parentWorkflow,
358
+ workflowId,
359
+ runId,
360
+ executionPath,
361
+ resumeSteps,
362
+ stepResults,
363
+ prevResult: stepResult,
364
+ resumeData,
365
+ activeSteps,
366
+ runtimeContext
367
+ }
368
+ });
369
+ } else {
370
+ await pubsub.publish("workflows", {
371
+ type: "workflow.step.run",
372
+ runId,
373
+ data: {
374
+ parentWorkflow,
375
+ workflowId,
376
+ runId,
377
+ executionPath,
378
+ resumeSteps,
379
+ stepResults,
380
+ prevResult: stepResult,
381
+ resumeData,
382
+ activeSteps,
383
+ runtimeContext,
384
+ runCount
385
+ }
386
+ });
387
+ }
388
+ } else {
389
+ if (loopCondition) {
390
+ await pubsub.publish("workflows", {
391
+ type: "workflow.step.run",
392
+ runId,
393
+ data: {
394
+ parentWorkflow,
395
+ workflowId,
396
+ runId,
397
+ executionPath,
398
+ resumeSteps,
399
+ stepResults,
400
+ prevResult: stepResult,
401
+ resumeData,
402
+ activeSteps,
403
+ runtimeContext,
404
+ runCount
405
+ }
406
+ });
407
+ } else {
408
+ await pubsub.publish("workflows", {
409
+ type: "workflow.step.end",
410
+ runId,
411
+ data: {
412
+ parentWorkflow,
413
+ workflowId,
414
+ runId,
415
+ executionPath,
416
+ resumeSteps,
417
+ stepResults,
418
+ prevResult: stepResult,
419
+ resumeData,
420
+ activeSteps,
421
+ runtimeContext
422
+ }
423
+ });
424
+ }
425
+ }
426
+ }
427
+ async function processWorkflowForEach({
428
+ workflowId,
429
+ prevResult,
430
+ runId,
431
+ executionPath,
432
+ stepResults,
433
+ activeSteps,
434
+ resumeSteps,
435
+ resumeData,
436
+ parentWorkflow,
437
+ runtimeContext
438
+ }, {
439
+ pubsub,
440
+ mastra,
441
+ step
442
+ }) {
443
+ const currentResult = stepResults[step.step.id];
444
+ const idx = currentResult?.output?.length ?? 0;
445
+ const targetLen = prevResult?.output?.length ?? 0;
446
+ if (idx >= targetLen && currentResult.output.filter((r) => r !== null).length >= targetLen) {
447
+ await pubsub.publish("workflows", {
448
+ type: "workflow.step.run",
449
+ runId,
450
+ data: {
451
+ parentWorkflow,
452
+ workflowId,
453
+ runId,
454
+ executionPath: executionPath.slice(0, -1).concat([executionPath[executionPath.length - 1] + 1]),
455
+ resumeSteps,
456
+ stepResults,
457
+ prevResult: currentResult,
458
+ resumeData,
459
+ activeSteps,
460
+ runtimeContext
461
+ }
462
+ });
463
+ return;
464
+ } else if (idx >= targetLen) {
465
+ return;
466
+ }
467
+ if (executionPath.length === 1 && idx === 0) {
468
+ const concurrency = Math.min(step.opts.concurrency ?? 1, targetLen);
469
+ const dummyResult = Array.from({ length: concurrency }, () => null);
470
+ await mastra.getStorage()?.updateWorkflowResults({
471
+ workflowName: workflowId,
472
+ runId,
473
+ stepId: step.step.id,
474
+ result: {
475
+ status: "succcess",
476
+ output: dummyResult,
477
+ startedAt: Date.now(),
478
+ payload: prevResult?.output
479
+ },
480
+ runtimeContext
481
+ });
482
+ for (let i = 0; i < concurrency; i++) {
483
+ await pubsub.publish("workflows", {
484
+ type: "workflow.step.run",
485
+ runId,
486
+ data: {
487
+ parentWorkflow,
488
+ workflowId,
489
+ runId,
490
+ executionPath: [executionPath[0], i],
491
+ resumeSteps,
492
+ stepResults,
493
+ prevResult,
494
+ resumeData,
495
+ activeSteps,
496
+ runtimeContext
497
+ }
498
+ });
499
+ }
500
+ return;
501
+ }
502
+ currentResult.output.push(null);
503
+ await mastra.getStorage()?.updateWorkflowResults({
504
+ workflowName: workflowId,
505
+ runId,
506
+ stepId: step.step.id,
507
+ result: {
508
+ status: "succcess",
509
+ output: currentResult.output,
510
+ startedAt: Date.now(),
511
+ payload: prevResult?.output
512
+ },
513
+ runtimeContext
514
+ });
515
+ await pubsub.publish("workflows", {
516
+ type: "workflow.step.run",
517
+ runId,
518
+ data: {
519
+ parentWorkflow,
520
+ workflowId,
521
+ runId,
522
+ executionPath: [executionPath[0], idx],
523
+ resumeSteps,
524
+ stepResults,
525
+ prevResult,
526
+ resumeData,
527
+ activeSteps,
528
+ runtimeContext
529
+ }
530
+ });
531
+ }
532
+ async function processWorkflowParallel({
533
+ workflowId,
534
+ runId,
535
+ executionPath,
536
+ stepResults,
537
+ activeSteps,
538
+ resumeSteps,
539
+ prevResult,
540
+ resumeData,
541
+ parentWorkflow,
542
+ runtimeContext
543
+ }, {
544
+ pubsub,
545
+ step
546
+ }) {
547
+ for (let i = 0; i < step.steps.length; i++) {
548
+ const nestedStep = step.steps[i];
549
+ if (nestedStep?.type === "step") {
550
+ activeSteps[nestedStep.step.id] = true;
551
+ }
552
+ }
553
+ await Promise.all(
554
+ step.steps.map(async (_step, idx) => {
555
+ return pubsub.publish("workflows", {
556
+ type: "workflow.step.run",
557
+ runId,
558
+ data: {
559
+ workflowId,
560
+ runId,
561
+ executionPath: executionPath.concat([idx]),
562
+ resumeSteps,
563
+ stepResults,
564
+ prevResult,
565
+ resumeData,
566
+ parentWorkflow,
567
+ activeSteps,
568
+ runtimeContext
569
+ }
570
+ });
571
+ })
572
+ );
573
+ }
574
+ async function processWorkflowConditional({
575
+ workflowId,
576
+ runId,
577
+ executionPath,
578
+ stepResults,
579
+ activeSteps,
580
+ resumeSteps,
581
+ prevResult,
582
+ resumeData,
583
+ parentWorkflow,
584
+ runtimeContext
585
+ }, {
586
+ pubsub,
587
+ stepExecutor,
588
+ step
589
+ }) {
590
+ const idxs = await stepExecutor.evaluateConditions({
591
+ workflowId,
592
+ step,
593
+ runId,
594
+ stepResults,
595
+ // TODO: implement state
596
+ state: {},
597
+ emitter: new EventEmitter(),
598
+ // TODO
599
+ runtimeContext: new RuntimeContext(),
600
+ // TODO
601
+ input: prevResult?.status === "success" ? prevResult.output : void 0,
602
+ resumeData
603
+ });
604
+ const truthyIdxs = {};
605
+ for (let i = 0; i < idxs.length; i++) {
606
+ truthyIdxs[idxs[i]] = true;
607
+ }
608
+ await Promise.all(
609
+ step.steps.map(async (step2, idx) => {
610
+ if (truthyIdxs[idx]) {
611
+ if (step2?.type === "step") {
612
+ activeSteps[step2.step.id] = true;
613
+ }
614
+ return pubsub.publish("workflows", {
615
+ type: "workflow.step.run",
616
+ runId,
617
+ data: {
618
+ workflowId,
619
+ runId,
620
+ executionPath: executionPath.concat([idx]),
621
+ resumeSteps,
622
+ stepResults,
623
+ prevResult,
624
+ resumeData,
625
+ parentWorkflow,
626
+ activeSteps,
627
+ runtimeContext
628
+ }
629
+ });
630
+ } else {
631
+ return pubsub.publish("workflows", {
632
+ type: "workflow.step.end",
633
+ runId,
634
+ data: {
635
+ workflowId,
636
+ runId,
637
+ executionPath: executionPath.concat([idx]),
638
+ resumeSteps,
639
+ stepResults,
640
+ prevResult: { status: "skipped" },
641
+ resumeData,
642
+ parentWorkflow,
643
+ activeSteps,
644
+ runtimeContext
645
+ }
646
+ });
647
+ }
648
+ })
649
+ );
650
+ }
651
+ async function processWorkflowWaitForEvent(workflowData, {
652
+ pubsub,
653
+ eventName,
654
+ currentState
655
+ }) {
656
+ const executionPath = currentState?.waitingPaths[eventName];
657
+ if (!executionPath) {
658
+ return;
659
+ }
660
+ const currentStep = getStep(workflowData.workflow, executionPath);
661
+ const prevResult = {
662
+ status: "success",
663
+ output: currentState?.context[currentStep?.id ?? "input"]?.payload
664
+ };
665
+ await pubsub.publish("workflows", {
666
+ type: "workflow.step.run",
667
+ runId: workflowData.runId,
668
+ data: {
669
+ workflowId: workflowData.workflowId,
670
+ runId: workflowData.runId,
671
+ executionPath,
672
+ resumeSteps: [],
673
+ resumeData: workflowData.resumeData,
674
+ parentWorkflow: workflowData.parentWorkflow,
675
+ stepResults: currentState?.context,
676
+ prevResult,
677
+ activeSteps: [],
678
+ runtimeContext: currentState?.runtimeContext
679
+ }
680
+ });
681
+ }
682
+ async function processWorkflowSleep({
683
+ workflowId,
684
+ runId,
685
+ executionPath,
686
+ stepResults,
687
+ activeSteps,
688
+ resumeSteps,
689
+ prevResult,
690
+ resumeData,
691
+ parentWorkflow,
692
+ runtimeContext
693
+ }, {
694
+ pubsub,
695
+ stepExecutor,
696
+ step
697
+ }) {
698
+ const startedAt = Date.now();
699
+ await pubsub.publish(`workflow.events.v2.${runId}`, {
700
+ type: "watch",
701
+ runId,
702
+ data: {
703
+ type: "workflow-step-waiting",
704
+ payload: {
705
+ id: step.id,
706
+ status: "waiting",
707
+ payload: prevResult.status === "success" ? prevResult.output : void 0,
708
+ startedAt
709
+ }
710
+ }
711
+ });
712
+ const duration = await stepExecutor.resolveSleep({
713
+ workflowId,
714
+ step,
715
+ runId,
716
+ stepResults,
717
+ emitter: new EventEmitter(),
718
+ // TODO
719
+ runtimeContext: new RuntimeContext(),
720
+ // TODO
721
+ input: prevResult?.status === "success" ? prevResult.output : void 0,
722
+ resumeData
723
+ });
724
+ setTimeout(
725
+ async () => {
726
+ await pubsub.publish(`workflow.events.v2.${runId}`, {
727
+ type: "watch",
728
+ runId,
729
+ data: {
730
+ type: "workflow-step-result",
731
+ payload: {
732
+ id: step.id,
733
+ status: "success",
734
+ payload: prevResult.status === "success" ? prevResult.output : void 0,
735
+ output: prevResult.status === "success" ? prevResult.output : void 0,
736
+ startedAt,
737
+ endedAt: Date.now()
738
+ }
739
+ }
740
+ });
741
+ await pubsub.publish(`workflow.events.v2.${runId}`, {
742
+ type: "watch",
743
+ runId,
744
+ data: {
745
+ type: "workflow-step-finish",
746
+ payload: {
747
+ id: step.id,
748
+ metadata: {}
749
+ }
750
+ }
751
+ });
752
+ await pubsub.publish("workflows", {
753
+ type: "workflow.step.run",
754
+ runId,
755
+ data: {
756
+ workflowId,
757
+ runId,
758
+ executionPath: executionPath.slice(0, -1).concat([executionPath[executionPath.length - 1] + 1]),
759
+ resumeSteps,
760
+ stepResults,
761
+ prevResult,
762
+ resumeData,
763
+ parentWorkflow,
764
+ activeSteps,
765
+ runtimeContext
766
+ }
767
+ });
768
+ },
769
+ duration < 0 ? 0 : duration
770
+ );
771
+ }
772
+ async function processWorkflowSleepUntil({
773
+ workflowId,
774
+ runId,
775
+ executionPath,
776
+ stepResults,
777
+ activeSteps,
778
+ resumeSteps,
779
+ prevResult,
780
+ resumeData,
781
+ parentWorkflow,
782
+ runtimeContext
783
+ }, {
784
+ pubsub,
785
+ stepExecutor,
786
+ step
787
+ }) {
788
+ const startedAt = Date.now();
789
+ const duration = await stepExecutor.resolveSleepUntil({
790
+ workflowId,
791
+ step,
792
+ runId,
793
+ stepResults,
794
+ emitter: new EventEmitter(),
795
+ // TODO
796
+ runtimeContext: new RuntimeContext(),
797
+ // TODO
798
+ input: prevResult?.status === "success" ? prevResult.output : void 0,
799
+ resumeData
800
+ });
801
+ await pubsub.publish(`workflow.events.v2.${runId}`, {
802
+ type: "watch",
803
+ runId,
804
+ data: {
805
+ type: "workflow-step-waiting",
806
+ payload: {
807
+ id: step.id,
808
+ status: "waiting",
809
+ payload: prevResult.status === "success" ? prevResult.output : void 0,
810
+ startedAt
811
+ }
812
+ }
813
+ });
814
+ setTimeout(
815
+ async () => {
816
+ await pubsub.publish(`workflow.events.v2.${runId}`, {
817
+ type: "watch",
818
+ runId,
819
+ data: {
820
+ type: "workflow-step-result",
821
+ payload: {
822
+ id: step.id,
823
+ status: "success",
824
+ payload: prevResult.status === "success" ? prevResult.output : void 0,
825
+ output: prevResult.status === "success" ? prevResult.output : void 0,
826
+ startedAt,
827
+ endedAt: Date.now()
828
+ }
829
+ }
830
+ });
831
+ await pubsub.publish(`workflow.events.v2.${runId}`, {
832
+ type: "watch",
833
+ runId,
834
+ data: {
835
+ type: "workflow-step-finish",
836
+ payload: {
837
+ id: step.id,
838
+ metadata: {}
839
+ }
840
+ }
841
+ });
842
+ await pubsub.publish("workflows", {
843
+ type: "workflow.step.run",
844
+ runId,
845
+ data: {
846
+ workflowId,
847
+ runId,
848
+ executionPath: executionPath.slice(0, -1).concat([executionPath[executionPath.length - 1] + 1]),
849
+ resumeSteps,
850
+ stepResults,
851
+ prevResult,
852
+ resumeData,
853
+ parentWorkflow,
854
+ activeSteps,
855
+ runtimeContext
856
+ }
857
+ });
858
+ },
859
+ duration < 0 ? 0 : duration
860
+ );
861
+ }
862
+
863
+ // src/workflows/evented/workflow-event-processor/index.ts
864
+ var WorkflowEventProcessor = class extends EventProcessor {
865
+ stepExecutor;
866
+ constructor({ mastra }) {
867
+ super({ mastra });
868
+ this.stepExecutor = new StepExecutor({ mastra });
869
+ }
870
+ __registerMastra(mastra) {
871
+ super.__registerMastra(mastra);
872
+ this.stepExecutor.__registerMastra(mastra);
873
+ }
874
+ async errorWorkflow({
875
+ parentWorkflow,
876
+ workflowId,
877
+ runId,
878
+ resumeSteps,
879
+ stepResults,
880
+ resumeData,
881
+ runtimeContext
882
+ }, e) {
883
+ await this.mastra.pubsub.publish("workflows", {
884
+ type: "workflow.fail",
885
+ runId,
886
+ data: {
887
+ workflowId,
888
+ runId,
889
+ executionPath: [],
890
+ resumeSteps,
891
+ stepResults,
892
+ prevResult: { status: "failed", error: e.stack ?? e.message },
893
+ runtimeContext,
894
+ resumeData,
895
+ activeSteps: {},
896
+ parentWorkflow
897
+ }
898
+ });
899
+ }
900
+ async processWorkflowCancel({ workflowId, runId }) {
901
+ const currentState = await this.mastra.getStorage()?.updateWorkflowState({
902
+ workflowName: workflowId,
903
+ runId,
904
+ opts: {
905
+ status: "canceled"
906
+ }
907
+ });
908
+ await this.endWorkflow({
909
+ workflow: void 0,
910
+ workflowId,
911
+ runId,
912
+ stepResults: currentState?.context,
913
+ prevResult: { status: "canceled" },
914
+ runtimeContext: currentState?.runtimeContext,
915
+ executionPath: [],
916
+ activeSteps: {},
917
+ resumeSteps: [],
918
+ resumeData: void 0,
919
+ parentWorkflow: void 0
920
+ });
921
+ }
922
+ async processWorkflowStart({
923
+ workflow,
924
+ parentWorkflow,
925
+ workflowId,
926
+ runId,
927
+ resumeSteps,
928
+ prevResult,
929
+ resumeData,
930
+ executionPath,
931
+ stepResults,
932
+ runtimeContext
933
+ }) {
934
+ await this.mastra.getStorage()?.persistWorkflowSnapshot({
935
+ workflowName: workflow.id,
936
+ runId,
937
+ snapshot: {
938
+ activePaths: [],
939
+ suspendedPaths: {},
940
+ resumeLabels: {},
941
+ waitingPaths: {},
942
+ serializedStepGraph: workflow.serializedStepGraph,
943
+ timestamp: Date.now(),
944
+ runId,
945
+ status: "running",
946
+ context: stepResults ?? {
947
+ input: prevResult?.status === "success" ? prevResult.output : void 0
948
+ },
949
+ value: {}
950
+ }
951
+ });
952
+ await this.mastra.pubsub.publish("workflows", {
953
+ type: "workflow.step.run",
954
+ runId,
955
+ data: {
956
+ parentWorkflow,
957
+ workflowId,
958
+ runId,
959
+ executionPath: executionPath ?? [0],
960
+ resumeSteps,
961
+ stepResults: stepResults ?? {
962
+ input: prevResult?.status === "success" ? prevResult.output : void 0
963
+ },
964
+ prevResult,
965
+ runtimeContext,
966
+ resumeData,
967
+ activeSteps: {}
968
+ }
969
+ });
970
+ }
971
+ async endWorkflow(args) {
972
+ const { stepResults, workflowId, runId, prevResult } = args;
973
+ await this.mastra.getStorage()?.updateWorkflowState({
974
+ workflowName: workflowId,
975
+ runId,
976
+ opts: {
977
+ status: "success",
978
+ result: prevResult
979
+ }
980
+ });
981
+ await this.mastra.pubsub.publish(`workflow.events.${runId}`, {
982
+ type: "watch",
983
+ runId,
984
+ data: {
985
+ type: "watch",
986
+ payload: {
987
+ currentStep: void 0,
988
+ workflowState: {
989
+ status: prevResult.status,
990
+ steps: stepResults,
991
+ result: prevResult.status === "success" ? prevResult.output : null,
992
+ error: prevResult.error ?? null
993
+ }
994
+ },
995
+ eventTimestamp: Date.now()
996
+ }
997
+ });
998
+ await this.mastra.pubsub.publish(`workflow.events.v2.${runId}`, {
999
+ type: "watch",
1000
+ runId,
1001
+ data: {
1002
+ type: "workflow-finish",
1003
+ payload: {
1004
+ runId
1005
+ }
1006
+ }
1007
+ });
1008
+ await this.mastra.pubsub.publish("workflows", {
1009
+ type: "workflow.end",
1010
+ runId,
1011
+ data: { ...args, workflow: void 0 }
1012
+ });
1013
+ }
1014
+ async processWorkflowEnd(args) {
1015
+ const { resumeSteps, prevResult, resumeData, parentWorkflow, activeSteps, runtimeContext, runId } = args;
1016
+ if (parentWorkflow) {
1017
+ await this.mastra.pubsub.publish("workflows", {
1018
+ type: "workflow.step.end",
1019
+ runId,
1020
+ data: {
1021
+ workflowId: parentWorkflow.workflowId,
1022
+ runId: parentWorkflow.runId,
1023
+ executionPath: parentWorkflow.executionPath,
1024
+ resumeSteps,
1025
+ stepResults: parentWorkflow.stepResults,
1026
+ prevResult,
1027
+ resumeData,
1028
+ activeSteps,
1029
+ parentWorkflow: parentWorkflow.parentWorkflow,
1030
+ parentContext: parentWorkflow,
1031
+ runtimeContext
1032
+ }
1033
+ });
1034
+ }
1035
+ await this.mastra.pubsub.publish("workflows-finish", {
1036
+ type: "workflow.end",
1037
+ runId,
1038
+ data: { ...args, workflow: void 0 }
1039
+ });
1040
+ }
1041
+ async processWorkflowSuspend(args) {
1042
+ const { resumeSteps, prevResult, resumeData, parentWorkflow, activeSteps, runId, runtimeContext } = args;
1043
+ if (parentWorkflow) {
1044
+ await this.mastra.pubsub.publish("workflows", {
1045
+ type: "workflow.step.end",
1046
+ runId,
1047
+ data: {
1048
+ workflowId: parentWorkflow.workflowId,
1049
+ runId: parentWorkflow.runId,
1050
+ executionPath: parentWorkflow.executionPath,
1051
+ resumeSteps,
1052
+ stepResults: parentWorkflow.stepResults,
1053
+ prevResult: {
1054
+ ...prevResult,
1055
+ suspendPayload: {
1056
+ ...prevResult.suspendPayload,
1057
+ __workflow_meta: {
1058
+ runId,
1059
+ path: parentWorkflow?.stepId ? [parentWorkflow.stepId].concat(prevResult.suspendPayload?.__workflow_meta?.path ?? []) : prevResult.suspendPayload?.__workflow_meta?.path ?? []
1060
+ }
1061
+ }
1062
+ },
1063
+ resumeData,
1064
+ activeSteps,
1065
+ runtimeContext,
1066
+ parentWorkflow: parentWorkflow.parentWorkflow,
1067
+ parentContext: parentWorkflow
1068
+ }
1069
+ });
1070
+ }
1071
+ await this.mastra.pubsub.publish("workflows-finish", {
1072
+ type: "workflow.suspend",
1073
+ runId,
1074
+ data: { ...args, workflow: void 0 }
1075
+ });
1076
+ }
1077
+ async processWorkflowFail(args) {
1078
+ const { workflowId, runId, resumeSteps, prevResult, resumeData, parentWorkflow, activeSteps, runtimeContext } = args;
1079
+ await this.mastra.getStorage()?.updateWorkflowState({
1080
+ workflowName: workflowId,
1081
+ runId,
1082
+ opts: {
1083
+ status: "failed",
1084
+ error: prevResult.error
1085
+ }
1086
+ });
1087
+ if (parentWorkflow) {
1088
+ await this.mastra.pubsub.publish("workflows", {
1089
+ type: "workflow.step.end",
1090
+ runId,
1091
+ data: {
1092
+ workflowId: parentWorkflow.workflowId,
1093
+ runId: parentWorkflow.runId,
1094
+ executionPath: parentWorkflow.executionPath,
1095
+ resumeSteps,
1096
+ stepResults: parentWorkflow.stepResults,
1097
+ prevResult,
1098
+ resumeData,
1099
+ activeSteps,
1100
+ runtimeContext,
1101
+ parentWorkflow: parentWorkflow.parentWorkflow,
1102
+ parentContext: parentWorkflow
1103
+ }
1104
+ });
1105
+ }
1106
+ await this.mastra.pubsub.publish("workflows-finish", {
1107
+ type: "workflow.fail",
1108
+ runId,
1109
+ data: { ...args, workflow: void 0 }
1110
+ });
1111
+ }
1112
+ async processWorkflowStepRun({
1113
+ workflow,
1114
+ workflowId,
1115
+ runId,
1116
+ executionPath,
1117
+ stepResults,
1118
+ activeSteps,
1119
+ resumeSteps,
1120
+ prevResult,
1121
+ resumeData,
1122
+ parentWorkflow,
1123
+ runtimeContext,
1124
+ runCount = 0
1125
+ }) {
1126
+ let stepGraph = workflow.stepGraph;
1127
+ if (!executionPath?.length) {
1128
+ return this.errorWorkflow(
1129
+ {
1130
+ workflowId,
1131
+ runId,
1132
+ executionPath,
1133
+ stepResults,
1134
+ activeSteps,
1135
+ resumeSteps,
1136
+ prevResult,
1137
+ resumeData,
1138
+ parentWorkflow,
1139
+ runtimeContext
1140
+ },
1141
+ new MastraError({
1142
+ id: "MASTRA_WORKFLOW",
1143
+ text: `Execution path is empty: ${JSON.stringify(executionPath)}`,
1144
+ domain: "MASTRA_WORKFLOW" /* MASTRA_WORKFLOW */,
1145
+ category: "SYSTEM" /* SYSTEM */
1146
+ })
1147
+ );
1148
+ }
1149
+ let step = stepGraph[executionPath[0]];
1150
+ if (!step) {
1151
+ return this.errorWorkflow(
1152
+ {
1153
+ workflowId,
1154
+ runId,
1155
+ executionPath,
1156
+ stepResults,
1157
+ activeSteps,
1158
+ resumeSteps,
1159
+ prevResult,
1160
+ resumeData,
1161
+ parentWorkflow,
1162
+ runtimeContext
1163
+ },
1164
+ new MastraError({
1165
+ id: "MASTRA_WORKFLOW",
1166
+ text: `Step not found in step graph: ${JSON.stringify(executionPath)}`,
1167
+ domain: "MASTRA_WORKFLOW" /* MASTRA_WORKFLOW */,
1168
+ category: "SYSTEM" /* SYSTEM */
1169
+ })
1170
+ );
1171
+ }
1172
+ if ((step.type === "parallel" || step.type === "conditional") && executionPath.length > 1) {
1173
+ step = step.steps[executionPath[1]];
1174
+ } else if (step.type === "parallel") {
1175
+ return processWorkflowParallel(
1176
+ {
1177
+ workflowId,
1178
+ runId,
1179
+ executionPath,
1180
+ stepResults,
1181
+ activeSteps,
1182
+ resumeSteps,
1183
+ prevResult,
1184
+ resumeData,
1185
+ parentWorkflow,
1186
+ runtimeContext
1187
+ },
1188
+ {
1189
+ pubsub: this.mastra.pubsub,
1190
+ step
1191
+ }
1192
+ );
1193
+ } else if (step?.type === "conditional") {
1194
+ return processWorkflowConditional(
1195
+ {
1196
+ workflowId,
1197
+ runId,
1198
+ executionPath,
1199
+ stepResults,
1200
+ activeSteps,
1201
+ resumeSteps,
1202
+ prevResult,
1203
+ resumeData,
1204
+ parentWorkflow,
1205
+ runtimeContext
1206
+ },
1207
+ {
1208
+ pubsub: this.mastra.pubsub,
1209
+ stepExecutor: this.stepExecutor,
1210
+ step
1211
+ }
1212
+ );
1213
+ } else if (step?.type === "sleep") {
1214
+ return processWorkflowSleep(
1215
+ {
1216
+ workflowId,
1217
+ runId,
1218
+ executionPath,
1219
+ stepResults,
1220
+ activeSteps,
1221
+ resumeSteps,
1222
+ prevResult,
1223
+ resumeData,
1224
+ parentWorkflow,
1225
+ runtimeContext
1226
+ },
1227
+ {
1228
+ pubsub: this.mastra.pubsub,
1229
+ stepExecutor: this.stepExecutor,
1230
+ step
1231
+ }
1232
+ );
1233
+ } else if (step?.type === "sleepUntil") {
1234
+ return processWorkflowSleepUntil(
1235
+ {
1236
+ workflowId,
1237
+ runId,
1238
+ executionPath,
1239
+ stepResults,
1240
+ activeSteps,
1241
+ resumeSteps,
1242
+ prevResult,
1243
+ resumeData,
1244
+ parentWorkflow,
1245
+ runtimeContext
1246
+ },
1247
+ {
1248
+ pubsub: this.mastra.pubsub,
1249
+ stepExecutor: this.stepExecutor,
1250
+ step
1251
+ }
1252
+ );
1253
+ } else if (step?.type === "waitForEvent" && !resumeData) {
1254
+ await this.mastra.getStorage()?.updateWorkflowResults({
1255
+ workflowName: workflowId,
1256
+ runId,
1257
+ stepId: step.step.id,
1258
+ result: {
1259
+ startedAt: Date.now(),
1260
+ status: "waiting",
1261
+ payload: prevResult.status === "success" ? prevResult.output : void 0
1262
+ },
1263
+ runtimeContext
1264
+ });
1265
+ await this.mastra.getStorage()?.updateWorkflowState({
1266
+ workflowName: workflowId,
1267
+ runId,
1268
+ opts: {
1269
+ status: "waiting",
1270
+ waitingPaths: {
1271
+ [step.event]: executionPath
1272
+ }
1273
+ }
1274
+ });
1275
+ await this.mastra.pubsub.publish(`workflow.events.v2.${runId}`, {
1276
+ type: "watch",
1277
+ runId,
1278
+ data: {
1279
+ type: "workflow-step-waiting",
1280
+ payload: {
1281
+ id: step.step.id,
1282
+ status: "waiting",
1283
+ payload: prevResult.status === "success" ? prevResult.output : void 0,
1284
+ startedAt: Date.now()
1285
+ }
1286
+ }
1287
+ });
1288
+ return;
1289
+ } else if (step?.type === "foreach" && executionPath.length === 1) {
1290
+ return processWorkflowForEach(
1291
+ {
1292
+ workflowId,
1293
+ runId,
1294
+ executionPath,
1295
+ stepResults,
1296
+ activeSteps,
1297
+ resumeSteps,
1298
+ prevResult,
1299
+ resumeData,
1300
+ parentWorkflow,
1301
+ runtimeContext
1302
+ },
1303
+ {
1304
+ pubsub: this.mastra.pubsub,
1305
+ mastra: this.mastra,
1306
+ step
1307
+ }
1308
+ );
1309
+ }
1310
+ if (!isExecutableStep(step)) {
1311
+ return this.errorWorkflow(
1312
+ {
1313
+ workflowId,
1314
+ runId,
1315
+ executionPath,
1316
+ stepResults,
1317
+ activeSteps,
1318
+ resumeSteps,
1319
+ prevResult,
1320
+ resumeData,
1321
+ parentWorkflow,
1322
+ runtimeContext
1323
+ },
1324
+ new MastraError({
1325
+ id: "MASTRA_WORKFLOW",
1326
+ text: `Step is not executable: ${step?.type} -- ${JSON.stringify(executionPath)}`,
1327
+ domain: "MASTRA_WORKFLOW" /* MASTRA_WORKFLOW */,
1328
+ category: "SYSTEM" /* SYSTEM */
1329
+ })
1330
+ );
1331
+ }
1332
+ activeSteps[step.step.id] = true;
1333
+ if (step.step instanceof EventedWorkflow) {
1334
+ if (resumeSteps?.length > 1) {
1335
+ const stepData = stepResults[step.step.id];
1336
+ const nestedRunId = stepData?.suspendPayload?.__workflow_meta?.runId;
1337
+ if (!nestedRunId) {
1338
+ return this.errorWorkflow(
1339
+ {
1340
+ workflowId,
1341
+ runId,
1342
+ executionPath,
1343
+ stepResults,
1344
+ activeSteps,
1345
+ resumeSteps,
1346
+ prevResult,
1347
+ resumeData,
1348
+ parentWorkflow,
1349
+ runtimeContext
1350
+ },
1351
+ new MastraError({
1352
+ id: "MASTRA_WORKFLOW",
1353
+ text: `Nested workflow run id not found: ${JSON.stringify(stepResults)}`,
1354
+ domain: "MASTRA_WORKFLOW" /* MASTRA_WORKFLOW */,
1355
+ category: "SYSTEM" /* SYSTEM */
1356
+ })
1357
+ );
1358
+ }
1359
+ const snapshot = await this.mastra?.getStorage()?.loadWorkflowSnapshot({
1360
+ workflowName: step.step.id,
1361
+ runId: nestedRunId
1362
+ });
1363
+ const nestedStepResults = snapshot?.context;
1364
+ const nestedSteps = resumeSteps.slice(1);
1365
+ await this.mastra.pubsub.publish("workflows", {
1366
+ type: "workflow.resume",
1367
+ runId,
1368
+ data: {
1369
+ workflowId: step.step.id,
1370
+ parentWorkflow: {
1371
+ stepId: step.step.id,
1372
+ workflowId,
1373
+ runId,
1374
+ executionPath,
1375
+ resumeSteps,
1376
+ stepResults,
1377
+ input: prevResult,
1378
+ parentWorkflow
1379
+ },
1380
+ executionPath: snapshot?.suspendedPaths?.[nestedSteps[0]],
1381
+ runId: nestedRunId,
1382
+ resumeSteps: nestedSteps,
1383
+ stepResults: nestedStepResults,
1384
+ prevResult,
1385
+ resumeData,
1386
+ activeSteps,
1387
+ runtimeContext
1388
+ }
1389
+ });
1390
+ } else {
1391
+ await this.mastra.pubsub.publish("workflows", {
1392
+ type: "workflow.start",
1393
+ runId,
1394
+ data: {
1395
+ workflowId: step.step.id,
1396
+ parentWorkflow: {
1397
+ stepId: step.step.id,
1398
+ workflowId,
1399
+ runId,
1400
+ executionPath,
1401
+ resumeSteps,
1402
+ stepResults,
1403
+ input: prevResult,
1404
+ parentWorkflow
1405
+ },
1406
+ executionPath: [0],
1407
+ runId: randomUUID(),
1408
+ resumeSteps,
1409
+ prevResult,
1410
+ resumeData,
1411
+ activeSteps,
1412
+ runtimeContext
1413
+ }
1414
+ });
1415
+ }
1416
+ return;
1417
+ }
1418
+ if (step.type === "step" || step.type === "waitForEvent") {
1419
+ await this.mastra.pubsub.publish(`workflow.events.${runId}`, {
1420
+ type: "watch",
1421
+ runId,
1422
+ data: {
1423
+ type: "watch",
1424
+ payload: {
1425
+ currentStep: { id: step.step.id, status: "running" },
1426
+ workflowState: {
1427
+ status: "running",
1428
+ steps: stepResults,
1429
+ error: null,
1430
+ result: null
1431
+ }
1432
+ },
1433
+ eventTimestamp: Date.now()
1434
+ }
1435
+ });
1436
+ await this.mastra.pubsub.publish(`workflow.events.v2.${runId}`, {
1437
+ type: "watch",
1438
+ runId,
1439
+ data: {
1440
+ type: "workflow-step-start",
1441
+ payload: {
1442
+ id: step.step.id,
1443
+ startedAt: Date.now(),
1444
+ payload: prevResult.status === "success" ? prevResult.output : void 0,
1445
+ status: "running"
1446
+ }
1447
+ }
1448
+ });
1449
+ }
1450
+ const ee = new EventEmitter();
1451
+ ee.on("watch-v2", async (event) => {
1452
+ await this.mastra.pubsub.publish(`workflow.events.v2.${runId}`, {
1453
+ type: "watch",
1454
+ runId,
1455
+ data: event
1456
+ });
1457
+ });
1458
+ const rc = new RuntimeContext();
1459
+ for (const [key, value] of Object.entries(runtimeContext)) {
1460
+ rc.set(key, value);
1461
+ }
1462
+ const stepResult = await this.stepExecutor.execute({
1463
+ workflowId,
1464
+ step: step.step,
1465
+ runId,
1466
+ stepResults,
1467
+ // TODO: implement state
1468
+ state: {},
1469
+ emitter: ee,
1470
+ runtimeContext: rc,
1471
+ input: prevResult?.output,
1472
+ resumeData: step.type === "waitForEvent" || resumeSteps?.length === 1 && resumeSteps?.[0] === step.step.id ? resumeData : void 0,
1473
+ runCount,
1474
+ foreachIdx: step.type === "foreach" ? executionPath[1] : void 0,
1475
+ validateInputs: workflow.options.validateInputs
1476
+ });
1477
+ runtimeContext = Object.fromEntries(rc.entries());
1478
+ if (stepResult.status === "bailed") {
1479
+ stepResult.status = "success";
1480
+ await this.endWorkflow({
1481
+ workflow,
1482
+ resumeData,
1483
+ parentWorkflow,
1484
+ workflowId,
1485
+ runId,
1486
+ executionPath,
1487
+ resumeSteps,
1488
+ stepResults: {
1489
+ ...stepResults,
1490
+ [step.step.id]: stepResult
1491
+ },
1492
+ prevResult: stepResult,
1493
+ activeSteps,
1494
+ runtimeContext
1495
+ });
1496
+ return;
1497
+ }
1498
+ if (stepResult.status === "failed") {
1499
+ if (runCount >= (workflow.retryConfig.attempts ?? 0)) {
1500
+ await this.mastra.pubsub.publish("workflows", {
1501
+ type: "workflow.step.end",
1502
+ runId,
1503
+ data: {
1504
+ parentWorkflow,
1505
+ workflowId,
1506
+ runId,
1507
+ executionPath,
1508
+ resumeSteps,
1509
+ stepResults,
1510
+ prevResult: stepResult,
1511
+ activeSteps,
1512
+ runtimeContext
1513
+ }
1514
+ });
1515
+ } else {
1516
+ return this.mastra.pubsub.publish("workflows", {
1517
+ type: "workflow.step.run",
1518
+ runId,
1519
+ data: {
1520
+ parentWorkflow,
1521
+ workflowId,
1522
+ runId,
1523
+ executionPath,
1524
+ resumeSteps,
1525
+ stepResults,
1526
+ prevResult,
1527
+ activeSteps,
1528
+ runtimeContext,
1529
+ runCount: runCount + 1
1530
+ }
1531
+ });
1532
+ }
1533
+ }
1534
+ if (step.type === "loop") {
1535
+ await processWorkflowLoop(
1536
+ {
1537
+ workflowId,
1538
+ prevResult: stepResult,
1539
+ runId,
1540
+ executionPath,
1541
+ stepResults,
1542
+ activeSteps,
1543
+ resumeSteps,
1544
+ resumeData,
1545
+ parentWorkflow,
1546
+ runtimeContext,
1547
+ runCount: runCount + 1
1548
+ },
1549
+ {
1550
+ pubsub: this.mastra.pubsub,
1551
+ stepExecutor: this.stepExecutor,
1552
+ step,
1553
+ stepResult
1554
+ }
1555
+ );
1556
+ } else {
1557
+ await this.mastra.pubsub.publish("workflows", {
1558
+ type: "workflow.step.end",
1559
+ runId,
1560
+ data: {
1561
+ parentWorkflow,
1562
+ workflowId,
1563
+ runId,
1564
+ executionPath,
1565
+ resumeSteps,
1566
+ stepResults,
1567
+ prevResult: stepResult,
1568
+ activeSteps,
1569
+ runtimeContext
1570
+ }
1571
+ });
1572
+ }
1573
+ }
1574
+ async processWorkflowStepEnd({
1575
+ workflow,
1576
+ workflowId,
1577
+ runId,
1578
+ executionPath,
1579
+ resumeSteps,
1580
+ prevResult,
1581
+ parentWorkflow,
1582
+ stepResults,
1583
+ activeSteps,
1584
+ parentContext,
1585
+ runtimeContext
1586
+ }) {
1587
+ let step = workflow.stepGraph[executionPath[0]];
1588
+ if ((step?.type === "parallel" || step?.type === "conditional") && executionPath.length > 1) {
1589
+ step = step.steps[executionPath[1]];
1590
+ }
1591
+ if (!step) {
1592
+ return this.errorWorkflow(
1593
+ {
1594
+ workflowId,
1595
+ runId,
1596
+ executionPath,
1597
+ resumeSteps,
1598
+ prevResult,
1599
+ stepResults,
1600
+ activeSteps,
1601
+ runtimeContext
1602
+ },
1603
+ new MastraError({
1604
+ id: "MASTRA_WORKFLOW",
1605
+ text: `Step not found: ${JSON.stringify(executionPath)}`,
1606
+ domain: "MASTRA_WORKFLOW" /* MASTRA_WORKFLOW */,
1607
+ category: "SYSTEM" /* SYSTEM */
1608
+ })
1609
+ );
1610
+ }
1611
+ if (step.type === "foreach") {
1612
+ const snapshot = await this.mastra.getStorage()?.loadWorkflowSnapshot({
1613
+ workflowName: workflowId,
1614
+ runId
1615
+ });
1616
+ const currentIdx = executionPath[1];
1617
+ const currentResult = snapshot?.context?.[step.step.id]?.output;
1618
+ let newResult = prevResult;
1619
+ if (currentIdx !== void 0) {
1620
+ if (currentResult) {
1621
+ currentResult[currentIdx] = prevResult.output;
1622
+ newResult = { ...prevResult, output: currentResult };
1623
+ } else {
1624
+ newResult = { ...prevResult, output: [prevResult.output] };
1625
+ }
1626
+ }
1627
+ const newStepResults = await this.mastra.getStorage()?.updateWorkflowResults({
1628
+ workflowName: workflow.id,
1629
+ runId,
1630
+ stepId: step.step.id,
1631
+ result: newResult,
1632
+ runtimeContext
1633
+ });
1634
+ if (!newStepResults) {
1635
+ return;
1636
+ }
1637
+ stepResults = newStepResults;
1638
+ } else if (isExecutableStep(step)) {
1639
+ delete activeSteps[step.step.id];
1640
+ if (parentContext) {
1641
+ prevResult = stepResults[step.step.id] = {
1642
+ ...prevResult,
1643
+ payload: parentContext.input?.output ?? {}
1644
+ };
1645
+ }
1646
+ const newStepResults = await this.mastra.getStorage()?.updateWorkflowResults({
1647
+ workflowName: workflow.id,
1648
+ runId,
1649
+ stepId: step.step.id,
1650
+ result: prevResult,
1651
+ runtimeContext
1652
+ });
1653
+ if (!newStepResults) {
1654
+ return;
1655
+ }
1656
+ stepResults = newStepResults;
1657
+ }
1658
+ if (!prevResult?.status || prevResult.status === "failed") {
1659
+ await this.mastra.pubsub.publish("workflows", {
1660
+ type: "workflow.fail",
1661
+ runId,
1662
+ data: {
1663
+ workflowId,
1664
+ runId,
1665
+ executionPath,
1666
+ resumeSteps,
1667
+ parentWorkflow,
1668
+ stepResults,
1669
+ prevResult,
1670
+ activeSteps,
1671
+ runtimeContext
1672
+ }
1673
+ });
1674
+ return;
1675
+ } else if (prevResult.status === "suspended") {
1676
+ const suspendedPaths = {};
1677
+ const suspendedStep = getStep(workflow, executionPath);
1678
+ if (suspendedStep) {
1679
+ suspendedPaths[suspendedStep.id] = executionPath;
1680
+ }
1681
+ await this.mastra.getStorage()?.updateWorkflowState({
1682
+ workflowName: workflowId,
1683
+ runId,
1684
+ opts: {
1685
+ status: "suspended",
1686
+ result: prevResult,
1687
+ suspendedPaths
1688
+ }
1689
+ });
1690
+ await this.mastra.pubsub.publish("workflows", {
1691
+ type: "workflow.suspend",
1692
+ runId,
1693
+ data: {
1694
+ workflowId,
1695
+ runId,
1696
+ executionPath,
1697
+ resumeSteps,
1698
+ parentWorkflow,
1699
+ stepResults,
1700
+ prevResult,
1701
+ activeSteps,
1702
+ runtimeContext
1703
+ }
1704
+ });
1705
+ await this.mastra.pubsub.publish(`workflow.events.${runId}`, {
1706
+ type: "watch",
1707
+ runId,
1708
+ data: {
1709
+ type: "watch",
1710
+ payload: {
1711
+ currentStep: { ...prevResult, id: step?.step?.id },
1712
+ workflowState: {
1713
+ status: "suspended",
1714
+ steps: stepResults,
1715
+ suspendPayload: prevResult.suspendPayload
1716
+ }
1717
+ }
1718
+ }
1719
+ });
1720
+ await this.mastra.pubsub.publish(`workflow.events.v2.${runId}`, {
1721
+ type: "watch",
1722
+ runId,
1723
+ data: {
1724
+ type: "workflow-step-suspended",
1725
+ payload: {
1726
+ id: step?.step?.id,
1727
+ ...prevResult,
1728
+ suspendedAt: Date.now(),
1729
+ suspendPayload: prevResult.suspendPayload
1730
+ }
1731
+ }
1732
+ });
1733
+ return;
1734
+ }
1735
+ if (step?.type === "step" || step?.type === "waitForEvent") {
1736
+ await this.mastra.pubsub.publish(`workflow.events.${runId}`, {
1737
+ type: "watch",
1738
+ runId,
1739
+ data: {
1740
+ type: "watch",
1741
+ payload: {
1742
+ currentStep: { ...prevResult, id: step.step.id },
1743
+ workflowState: {
1744
+ status: "running",
1745
+ steps: stepResults,
1746
+ error: null,
1747
+ result: null
1748
+ }
1749
+ },
1750
+ eventTimestamp: Date.now()
1751
+ }
1752
+ });
1753
+ await this.mastra.pubsub.publish(`workflow.events.v2.${runId}`, {
1754
+ type: "watch",
1755
+ runId,
1756
+ data: {
1757
+ type: "workflow-step-result",
1758
+ payload: {
1759
+ id: step.step.id,
1760
+ ...prevResult
1761
+ }
1762
+ }
1763
+ });
1764
+ if (prevResult.status === "success") {
1765
+ await this.mastra.pubsub.publish(`workflow.events.v2.${runId}`, {
1766
+ type: "watch",
1767
+ runId,
1768
+ data: {
1769
+ type: "workflow-step-finish",
1770
+ payload: {
1771
+ id: step.step.id,
1772
+ metadata: {}
1773
+ }
1774
+ }
1775
+ });
1776
+ }
1777
+ }
1778
+ step = workflow.stepGraph[executionPath[0]];
1779
+ if ((step?.type === "parallel" || step?.type === "conditional") && executionPath.length > 1) {
1780
+ let skippedCount = 0;
1781
+ const allResults = step.steps.reduce(
1782
+ (acc, step2) => {
1783
+ if (isExecutableStep(step2)) {
1784
+ const res = stepResults?.[step2.step.id];
1785
+ if (res && res.status === "success") {
1786
+ acc[step2.step.id] = res?.output;
1787
+ } else if (res?.status === "skipped") {
1788
+ skippedCount++;
1789
+ }
1790
+ }
1791
+ return acc;
1792
+ },
1793
+ {}
1794
+ );
1795
+ const keys = Object.keys(allResults);
1796
+ if (keys.length + skippedCount < step.steps.length) {
1797
+ return;
1798
+ }
1799
+ await this.mastra.pubsub.publish("workflows", {
1800
+ type: "workflow.step.end",
1801
+ runId,
1802
+ data: {
1803
+ parentWorkflow,
1804
+ workflowId,
1805
+ runId,
1806
+ executionPath: executionPath.slice(0, -1),
1807
+ resumeSteps,
1808
+ stepResults,
1809
+ prevResult: { status: "success", output: allResults },
1810
+ activeSteps,
1811
+ runtimeContext
1812
+ }
1813
+ });
1814
+ } else if (step?.type === "foreach") {
1815
+ await this.mastra.pubsub.publish("workflows", {
1816
+ type: "workflow.step.run",
1817
+ runId,
1818
+ data: {
1819
+ workflowId,
1820
+ runId,
1821
+ executionPath: executionPath.slice(0, -1),
1822
+ resumeSteps,
1823
+ parentWorkflow,
1824
+ stepResults,
1825
+ prevResult: { ...prevResult, output: prevResult?.payload },
1826
+ activeSteps,
1827
+ runtimeContext
1828
+ }
1829
+ });
1830
+ } else if (executionPath[0] >= workflow.stepGraph.length - 1) {
1831
+ await this.endWorkflow({
1832
+ workflow,
1833
+ parentWorkflow,
1834
+ workflowId,
1835
+ runId,
1836
+ executionPath,
1837
+ resumeSteps,
1838
+ stepResults,
1839
+ prevResult,
1840
+ activeSteps,
1841
+ runtimeContext
1842
+ });
1843
+ } else {
1844
+ await this.mastra.pubsub.publish("workflows", {
1845
+ type: "workflow.step.run",
1846
+ runId,
1847
+ data: {
1848
+ workflowId,
1849
+ runId,
1850
+ executionPath: executionPath.slice(0, -1).concat([executionPath[executionPath.length - 1] + 1]),
1851
+ resumeSteps,
1852
+ parentWorkflow,
1853
+ stepResults,
1854
+ prevResult,
1855
+ activeSteps,
1856
+ runtimeContext
1857
+ }
1858
+ });
1859
+ }
1860
+ }
1861
+ async loadData({
1862
+ workflowId,
1863
+ runId
1864
+ }) {
1865
+ const snapshot = await this.mastra.getStorage()?.loadWorkflowSnapshot({
1866
+ workflowName: workflowId,
1867
+ runId
1868
+ });
1869
+ return snapshot;
1870
+ }
1871
+ async process(event, ack) {
1872
+ const { type, data } = event;
1873
+ const workflowData = data;
1874
+ const currentState = await this.loadData({
1875
+ workflowId: workflowData.workflowId,
1876
+ runId: workflowData.runId
1877
+ });
1878
+ if (currentState?.status === "canceled" && type !== "workflow.end") {
1879
+ return;
1880
+ }
1881
+ if (type.startsWith("workflow.user-event.")) {
1882
+ await processWorkflowWaitForEvent(
1883
+ {
1884
+ ...workflowData,
1885
+ workflow: this.mastra.getWorkflow(workflowData.workflowId)
1886
+ },
1887
+ {
1888
+ pubsub: this.mastra.pubsub,
1889
+ eventName: type.split(".").slice(2).join("."),
1890
+ currentState
1891
+ }
1892
+ );
1893
+ return;
1894
+ }
1895
+ let workflow;
1896
+ if (this.mastra.__hasInternalWorkflow(workflowData.workflowId)) {
1897
+ workflow = this.mastra.__getInternalWorkflow(workflowData.workflowId);
1898
+ } else if (workflowData.parentWorkflow) {
1899
+ workflow = getNestedWorkflow(this.mastra, workflowData.parentWorkflow);
1900
+ } else {
1901
+ workflow = this.mastra.getWorkflow(workflowData.workflowId);
1902
+ }
1903
+ if (!workflow) {
1904
+ return this.errorWorkflow(
1905
+ workflowData,
1906
+ new MastraError({
1907
+ id: "MASTRA_WORKFLOW",
1908
+ text: `Workflow not found: ${workflowData.workflowId}`,
1909
+ domain: "MASTRA_WORKFLOW" /* MASTRA_WORKFLOW */,
1910
+ category: "SYSTEM" /* SYSTEM */
1911
+ })
1912
+ );
1913
+ }
1914
+ if (type === "workflow.start" || type === "workflow.resume") {
1915
+ const { runId } = workflowData;
1916
+ await this.mastra.pubsub.publish(`workflow.events.v2.${runId}`, {
1917
+ type: "watch",
1918
+ runId,
1919
+ data: {
1920
+ type: "workflow-start",
1921
+ payload: {
1922
+ runId
1923
+ }
1924
+ }
1925
+ });
1926
+ }
1927
+ switch (type) {
1928
+ case "workflow.cancel":
1929
+ await this.processWorkflowCancel({
1930
+ workflow,
1931
+ ...workflowData
1932
+ });
1933
+ break;
1934
+ case "workflow.start":
1935
+ await this.processWorkflowStart({
1936
+ workflow,
1937
+ ...workflowData
1938
+ });
1939
+ break;
1940
+ case "workflow.resume":
1941
+ await this.processWorkflowStart({
1942
+ workflow,
1943
+ ...workflowData
1944
+ });
1945
+ break;
1946
+ case "workflow.end":
1947
+ await this.processWorkflowEnd({
1948
+ workflow,
1949
+ ...workflowData
1950
+ });
1951
+ break;
1952
+ case "workflow.step.end":
1953
+ await this.processWorkflowStepEnd({
1954
+ workflow,
1955
+ ...workflowData
1956
+ });
1957
+ break;
1958
+ case "workflow.step.run":
1959
+ await this.processWorkflowStepRun({
1960
+ workflow,
1961
+ ...workflowData
1962
+ });
1963
+ break;
1964
+ case "workflow.suspend":
1965
+ await this.processWorkflowSuspend({
1966
+ workflow,
1967
+ ...workflowData
1968
+ });
1969
+ break;
1970
+ case "workflow.fail":
1971
+ await this.processWorkflowFail({
1972
+ workflow,
1973
+ ...workflowData
1974
+ });
1975
+ break;
1976
+ }
1977
+ try {
1978
+ await ack?.();
1979
+ } catch (e) {
1980
+ console.error("Error acking event", e);
1981
+ }
1982
+ }
1983
+ };
1984
+
1985
+ // src/workflows/evented/workflow.ts
1986
+ function cloneWorkflow(workflow, opts) {
1987
+ const wf = new Workflow({
1988
+ id: opts.id,
1989
+ inputSchema: workflow.inputSchema,
1990
+ outputSchema: workflow.outputSchema,
1991
+ steps: workflow.stepDefs,
1992
+ mastra: workflow.mastra
1993
+ });
1994
+ wf.setStepFlow(workflow.stepGraph);
1995
+ wf.commit();
1996
+ return wf;
1997
+ }
1998
+ function cloneStep(step, opts) {
1999
+ return {
2000
+ id: opts.id,
2001
+ description: step.description,
2002
+ inputSchema: step.inputSchema,
2003
+ outputSchema: step.outputSchema,
2004
+ execute: step.execute,
2005
+ component: step.component
2006
+ };
2007
+ }
2008
+ function isAgent(params) {
2009
+ return params?.component === "AGENT";
2010
+ }
2011
+ function isTool(params) {
2012
+ return params instanceof Tool;
2013
+ }
2014
+ function createStep(params) {
2015
+ if (isAgent(params)) {
2016
+ return {
2017
+ id: params.name,
2018
+ description: params.getDescription(),
2019
+ // @ts-ignore
2020
+ inputSchema: z.object({
2021
+ prompt: z.string()
2022
+ // resourceId: z.string().optional(),
2023
+ // threadId: z.string().optional(),
2024
+ }),
2025
+ // @ts-ignore
2026
+ outputSchema: z.object({
2027
+ text: z.string()
2028
+ }),
2029
+ execute: async ({ inputData, [EMITTER_SYMBOL]: emitter, runtimeContext, abortSignal, abort }) => {
2030
+ let streamPromise = {};
2031
+ streamPromise.promise = new Promise((resolve, reject) => {
2032
+ streamPromise.resolve = resolve;
2033
+ streamPromise.reject = reject;
2034
+ });
2035
+ const { fullStream } = await params.streamLegacy(inputData.prompt, {
2036
+ // resourceId: inputData.resourceId,
2037
+ // threadId: inputData.threadId,
2038
+ runtimeContext,
2039
+ onFinish: (result) => {
2040
+ streamPromise.resolve(result.text);
2041
+ },
2042
+ abortSignal
2043
+ });
2044
+ if (abortSignal.aborted) {
2045
+ return abort();
2046
+ }
2047
+ const toolData = {
2048
+ name: params.name,
2049
+ args: inputData
2050
+ };
2051
+ await emitter.emit("watch-v2", {
2052
+ type: "tool-call-streaming-start",
2053
+ ...toolData ?? {}
2054
+ });
2055
+ for await (const chunk of fullStream) {
2056
+ if (chunk.type === "text-delta") {
2057
+ await emitter.emit("watch-v2", {
2058
+ type: "tool-call-delta",
2059
+ ...toolData ?? {},
2060
+ argsTextDelta: chunk.textDelta
2061
+ });
2062
+ }
2063
+ }
2064
+ await emitter.emit("watch-v2", {
2065
+ type: "tool-call-streaming-finish",
2066
+ ...toolData ?? {}
2067
+ });
2068
+ return {
2069
+ text: await streamPromise.promise
2070
+ };
2071
+ },
2072
+ component: params.component
2073
+ };
2074
+ }
2075
+ if (isTool(params)) {
2076
+ if (!params.inputSchema || !params.outputSchema) {
2077
+ throw new Error("Tool must have input and output schemas defined");
2078
+ }
2079
+ return {
2080
+ // TODO: tool probably should have strong id type
2081
+ // @ts-ignore
2082
+ id: params.id,
2083
+ description: params.description,
2084
+ inputSchema: params.inputSchema,
2085
+ outputSchema: params.outputSchema,
2086
+ suspendSchema: params.suspendSchema,
2087
+ resumeSchema: params.resumeSchema,
2088
+ execute: async ({ inputData, mastra, runtimeContext, suspend, resumeData }) => {
2089
+ return params.execute({
2090
+ context: inputData,
2091
+ mastra,
2092
+ runtimeContext,
2093
+ // TODO: Pass proper tracing context when evented workflows support tracing
2094
+ tracingContext: { currentSpan: void 0 },
2095
+ suspend,
2096
+ resumeData
2097
+ });
2098
+ },
2099
+ component: "TOOL"
2100
+ };
2101
+ }
2102
+ return {
2103
+ id: params.id,
2104
+ description: params.description,
2105
+ inputSchema: params.inputSchema,
2106
+ outputSchema: params.outputSchema,
2107
+ resumeSchema: params.resumeSchema,
2108
+ suspendSchema: params.suspendSchema,
2109
+ execute: params.execute
2110
+ };
2111
+ }
2112
+ function createWorkflow(params) {
2113
+ const eventProcessor = new WorkflowEventProcessor({ mastra: params.mastra });
2114
+ const executionEngine = new EventedExecutionEngine({
2115
+ mastra: params.mastra,
2116
+ eventProcessor,
2117
+ options: {
2118
+ validateInputs: params.options?.validateInputs ?? false,
2119
+ shouldPersistSnapshot: params.options?.shouldPersistSnapshot ?? (() => true),
2120
+ tracingPolicy: params.options?.tracingPolicy
2121
+ }
2122
+ });
2123
+ return new EventedWorkflow({
2124
+ ...params,
2125
+ executionEngine
2126
+ });
2127
+ }
2128
+ var EventedWorkflow = class extends Workflow {
2129
+ constructor(params) {
2130
+ super(params);
2131
+ }
2132
+ __registerMastra(mastra) {
2133
+ super.__registerMastra(mastra);
2134
+ this.executionEngine.__registerMastra(mastra);
2135
+ }
2136
+ async createRunAsync(options) {
2137
+ const runIdToUse = options?.runId || randomUUID();
2138
+ const run = this.runs.get(runIdToUse) ?? new EventedRun({
2139
+ workflowId: this.id,
2140
+ runId: runIdToUse,
2141
+ executionEngine: this.executionEngine,
2142
+ executionGraph: this.executionGraph,
2143
+ serializedStepGraph: this.serializedStepGraph,
2144
+ mastra: this.mastra,
2145
+ retryConfig: this.retryConfig,
2146
+ cleanup: () => this.runs.delete(runIdToUse),
2147
+ workflowSteps: this.steps
2148
+ });
2149
+ this.runs.set(runIdToUse, run);
2150
+ const shouldPersistSnapshot = this.options?.shouldPersistSnapshot?.({
2151
+ workflowStatus: run.workflowRunStatus,
2152
+ stepResults: {}
2153
+ });
2154
+ const workflowSnapshotInStorage = await this.getWorkflowRunExecutionResult(runIdToUse, false);
2155
+ if (!workflowSnapshotInStorage && shouldPersistSnapshot) {
2156
+ await this.mastra?.getStorage()?.persistWorkflowSnapshot({
2157
+ workflowName: this.id,
2158
+ runId: runIdToUse,
2159
+ snapshot: {
2160
+ runId: runIdToUse,
2161
+ status: "pending",
2162
+ value: {},
2163
+ context: {},
2164
+ activePaths: [],
2165
+ serializedStepGraph: this.serializedStepGraph,
2166
+ suspendedPaths: {},
2167
+ resumeLabels: {},
2168
+ waitingPaths: {},
2169
+ result: void 0,
2170
+ error: void 0,
2171
+ // @ts-ignore
2172
+ timestamp: Date.now()
2173
+ }
2174
+ });
2175
+ }
2176
+ return run;
2177
+ }
2178
+ };
2179
+ var EventedRun = class extends Run {
2180
+ constructor(params) {
2181
+ super(params);
2182
+ this.serializedStepGraph = params.serializedStepGraph;
2183
+ }
2184
+ async start({
2185
+ inputData,
2186
+ initialState,
2187
+ runtimeContext
2188
+ }) {
2189
+ if (this.serializedStepGraph.length === 0) {
2190
+ throw new Error(
2191
+ "Execution flow of workflow is not defined. Add steps to the workflow via .then(), .branch(), etc."
2192
+ );
2193
+ }
2194
+ if (!this.executionGraph.steps) {
2195
+ throw new Error("Uncommitted step flow changes detected. Call .commit() to register the steps.");
2196
+ }
2197
+ runtimeContext = runtimeContext ?? new RuntimeContext();
2198
+ await this.mastra?.getStorage()?.persistWorkflowSnapshot({
2199
+ workflowName: this.workflowId,
2200
+ runId: this.runId,
2201
+ snapshot: {
2202
+ runId: this.runId,
2203
+ serializedStepGraph: this.serializedStepGraph,
2204
+ value: {},
2205
+ context: {},
2206
+ runtimeContext: Object.fromEntries(runtimeContext.entries()),
2207
+ activePaths: [],
2208
+ suspendedPaths: {},
2209
+ resumeLabels: {},
2210
+ waitingPaths: {},
2211
+ timestamp: Date.now(),
2212
+ status: "running"
2213
+ }
2214
+ });
2215
+ const inputDataToUse = await this._validateInput(inputData);
2216
+ const initialStateToUse = await this._validateInitialState(initialState ?? {});
2217
+ const result = await this.executionEngine.execute({
2218
+ workflowId: this.workflowId,
2219
+ runId: this.runId,
2220
+ graph: this.executionGraph,
2221
+ serializedStepGraph: this.serializedStepGraph,
2222
+ input: inputDataToUse,
2223
+ initialState: initialStateToUse,
2224
+ emitter: {
2225
+ emit: async (event, data) => {
2226
+ this.emitter.emit(event, data);
2227
+ },
2228
+ on: (event, callback) => {
2229
+ this.emitter.on(event, callback);
2230
+ },
2231
+ off: (event, callback) => {
2232
+ this.emitter.off(event, callback);
2233
+ },
2234
+ once: (event, callback) => {
2235
+ this.emitter.once(event, callback);
2236
+ }
2237
+ },
2238
+ retryConfig: this.retryConfig,
2239
+ runtimeContext,
2240
+ abortController: this.abortController
2241
+ });
2242
+ if (result.status !== "suspended") {
2243
+ this.cleanup?.();
2244
+ }
2245
+ return result;
2246
+ }
2247
+ // TODO: stream
2248
+ async resume(params) {
2249
+ const steps = (Array.isArray(params.step) ? params.step : [params.step]).map(
2250
+ (step) => typeof step === "string" ? step : step?.id
2251
+ );
2252
+ if (steps.length === 0) {
2253
+ throw new Error("No steps provided to resume");
2254
+ }
2255
+ const snapshot = await this.mastra?.getStorage()?.loadWorkflowSnapshot({
2256
+ workflowName: this.workflowId,
2257
+ runId: this.runId
2258
+ });
2259
+ const resumePath = snapshot?.suspendedPaths?.[steps[0]];
2260
+ if (!resumePath) {
2261
+ throw new Error(
2262
+ `No resume path found for step ${JSON.stringify(steps)}, currently suspended paths are ${JSON.stringify(snapshot?.suspendedPaths)}`
2263
+ );
2264
+ }
2265
+ console.dir(
2266
+ { resume: { runtimeContextObj: snapshot?.runtimeContext, runtimeContext: params.runtimeContext } },
2267
+ { depth: null }
2268
+ );
2269
+ const runtimeContextObj = snapshot?.runtimeContext ?? {};
2270
+ const runtimeContext = new RuntimeContext();
2271
+ for (const [key, value] of Object.entries(runtimeContextObj)) {
2272
+ runtimeContext.set(key, value);
2273
+ }
2274
+ if (params.runtimeContext) {
2275
+ for (const [key, value] of params.runtimeContext.entries()) {
2276
+ runtimeContext.set(key, value);
2277
+ }
2278
+ }
2279
+ const suspendedStep = this.workflowSteps[steps?.[0] ?? ""];
2280
+ const resumeDataToUse = await this._validateResumeData(params.resumeData, suspendedStep);
2281
+ const executionResultPromise = this.executionEngine.execute({
2282
+ workflowId: this.workflowId,
2283
+ runId: this.runId,
2284
+ graph: this.executionGraph,
2285
+ serializedStepGraph: this.serializedStepGraph,
2286
+ input: resumeDataToUse,
2287
+ resume: {
2288
+ steps,
2289
+ stepResults: snapshot?.context,
2290
+ resumePayload: resumeDataToUse,
2291
+ resumePath
2292
+ },
2293
+ emitter: {
2294
+ emit: (event, data) => {
2295
+ this.emitter.emit(event, data);
2296
+ return Promise.resolve();
2297
+ },
2298
+ on: (event, callback) => {
2299
+ this.emitter.on(event, callback);
2300
+ },
2301
+ off: (event, callback) => {
2302
+ this.emitter.off(event, callback);
2303
+ },
2304
+ once: (event, callback) => {
2305
+ this.emitter.once(event, callback);
2306
+ }
2307
+ },
2308
+ runtimeContext,
2309
+ abortController: this.abortController
2310
+ }).then((result) => {
2311
+ if (result.status !== "suspended") {
2312
+ this.closeStreamAction?.().catch(() => {
2313
+ });
2314
+ }
2315
+ return result;
2316
+ });
2317
+ this.executionResults = executionResultPromise;
2318
+ return executionResultPromise;
2319
+ }
2320
+ watch(cb, type = "watch") {
2321
+ const watchCb = async (event, ack) => {
2322
+ if (event.runId !== this.runId) {
2323
+ return;
2324
+ }
2325
+ cb(event.data);
2326
+ await ack?.();
2327
+ };
2328
+ if (type === "watch-v2") {
2329
+ this.mastra?.pubsub.subscribe(`workflow.events.v2.${this.runId}`, watchCb).catch(() => {
2330
+ });
2331
+ } else {
2332
+ this.mastra?.pubsub.subscribe(`workflow.events.${this.runId}`, watchCb).catch(() => {
2333
+ });
2334
+ }
2335
+ return () => {
2336
+ if (type === "watch-v2") {
2337
+ this.mastra?.pubsub.unsubscribe(`workflow.events.v2.${this.runId}`, watchCb).catch(() => {
2338
+ });
2339
+ } else {
2340
+ this.mastra?.pubsub.unsubscribe(`workflow.events.${this.runId}`, watchCb).catch(() => {
2341
+ });
2342
+ }
2343
+ };
2344
+ }
2345
+ async watchAsync(cb, type = "watch") {
2346
+ const watchCb = async (event, ack) => {
2347
+ if (event.runId !== this.runId) {
2348
+ return;
2349
+ }
2350
+ cb(event.data);
2351
+ await ack?.();
2352
+ };
2353
+ if (type === "watch-v2") {
2354
+ await this.mastra?.pubsub.subscribe(`workflow.events.v2.${this.runId}`, watchCb).catch(() => {
2355
+ });
2356
+ } else {
2357
+ await this.mastra?.pubsub.subscribe(`workflow.events.${this.runId}`, watchCb).catch(() => {
2358
+ });
2359
+ }
2360
+ return async () => {
2361
+ if (type === "watch-v2") {
2362
+ await this.mastra?.pubsub.unsubscribe(`workflow.events.v2.${this.runId}`, watchCb).catch(() => {
2363
+ });
2364
+ } else {
2365
+ await this.mastra?.pubsub.unsubscribe(`workflow.events.${this.runId}`, watchCb).catch(() => {
2366
+ });
2367
+ }
2368
+ };
2369
+ }
2370
+ async cancel() {
2371
+ await this.mastra?.pubsub.publish("workflows", {
2372
+ type: "workflow.cancel",
2373
+ runId: this.runId,
2374
+ data: {
2375
+ workflowId: this.workflowId,
2376
+ runId: this.runId
2377
+ }
2378
+ });
2379
+ }
2380
+ async sendEvent(eventName, data) {
2381
+ await this.mastra?.pubsub.publish("workflows", {
2382
+ type: `workflow.user-event.${eventName}`,
2383
+ runId: this.runId,
2384
+ data: {
2385
+ workflowId: this.workflowId,
2386
+ runId: this.runId,
2387
+ resumeData: data
2388
+ }
2389
+ });
2390
+ }
2391
+ };
2392
+
2393
+ // src/workflows/evented/workflow-event-processor/utils.ts
2394
+ function getNestedWorkflow(mastra, { workflowId, executionPath, parentWorkflow }) {
2395
+ let workflow = null;
2396
+ if (parentWorkflow) {
2397
+ const nestedWorkflow = getNestedWorkflow(mastra, parentWorkflow);
2398
+ if (!nestedWorkflow) {
2399
+ return null;
2400
+ }
2401
+ workflow = nestedWorkflow;
2402
+ }
2403
+ workflow = workflow ?? mastra.getWorkflow(workflowId);
2404
+ const stepGraph = workflow.stepGraph;
2405
+ let parentStep = stepGraph[executionPath[0]];
2406
+ if (parentStep?.type === "parallel" || parentStep?.type === "conditional") {
2407
+ parentStep = parentStep.steps[executionPath[1]];
2408
+ }
2409
+ if (parentStep?.type === "step" || parentStep?.type === "loop") {
2410
+ return parentStep.step;
2411
+ }
2412
+ return null;
2413
+ }
2414
+ function getStep(workflow, executionPath) {
2415
+ let idx = 0;
2416
+ const stepGraph = workflow.stepGraph;
2417
+ let parentStep = stepGraph[executionPath[0]];
2418
+ if (parentStep?.type === "parallel" || parentStep?.type === "conditional") {
2419
+ parentStep = parentStep.steps[executionPath[1]];
2420
+ idx++;
2421
+ } else if (parentStep?.type === "foreach") {
2422
+ return parentStep.step;
2423
+ }
2424
+ if (!(parentStep?.type === "step" || parentStep?.type === "loop" || parentStep?.type === "waitForEvent")) {
2425
+ return null;
2426
+ }
2427
+ if (parentStep instanceof EventedWorkflow) {
2428
+ return getStep(parentStep, executionPath.slice(idx + 1));
2429
+ }
2430
+ return parentStep.step;
2431
+ }
2432
+ function isExecutableStep(step) {
2433
+ return step.type === "step" || step.type === "loop" || step.type === "waitForEvent" || step.type === "foreach";
2434
+ }
2435
+
2436
+ // src/workflows/evented/execution-engine.ts
2437
+ var EventedExecutionEngine = class extends ExecutionEngine {
2438
+ eventProcessor;
2439
+ constructor({
2440
+ mastra,
2441
+ eventProcessor,
2442
+ options
2443
+ }) {
2444
+ super({ mastra, options });
2445
+ this.eventProcessor = eventProcessor;
2446
+ }
2447
+ __registerMastra(mastra) {
2448
+ this.mastra = mastra;
2449
+ this.eventProcessor.__registerMastra(mastra);
2450
+ }
2451
+ /**
2452
+ * Executes a workflow run with the provided execution graph and input
2453
+ * @param graph The execution graph to execute
2454
+ * @param input The input data for the workflow
2455
+ * @returns A promise that resolves to the workflow output
2456
+ */
2457
+ async execute(params) {
2458
+ const pubsub = this.mastra?.pubsub;
2459
+ if (!pubsub) {
2460
+ throw new Error("No Pubsub adapter configured on the Mastra instance");
2461
+ }
2462
+ if (params.resume) {
2463
+ const prevStep = getStep(this.mastra.getWorkflow(params.workflowId), params.resume.resumePath);
2464
+ const prevResult = params.resume.stepResults[prevStep?.id ?? "input"];
2465
+ await pubsub.publish("workflows", {
2466
+ type: "workflow.resume",
2467
+ runId: params.runId,
2468
+ data: {
2469
+ workflowId: params.workflowId,
2470
+ runId: params.runId,
2471
+ executionPath: params.resume.resumePath,
2472
+ stepResults: params.resume.stepResults,
2473
+ resumeSteps: params.resume.steps,
2474
+ prevResult: { status: "success", output: prevResult?.payload },
2475
+ resumeData: params.resume.resumePayload,
2476
+ runtimeContext: Object.fromEntries(params.runtimeContext.entries()),
2477
+ format: params.format
2478
+ }
2479
+ });
2480
+ } else {
2481
+ await pubsub.publish("workflows", {
2482
+ type: "workflow.start",
2483
+ runId: params.runId,
2484
+ data: {
2485
+ workflowId: params.workflowId,
2486
+ runId: params.runId,
2487
+ prevResult: { status: "success", output: params.input },
2488
+ runtimeContext: Object.fromEntries(params.runtimeContext.entries()),
2489
+ format: params.format
2490
+ }
2491
+ });
2492
+ }
2493
+ const resultData = await new Promise((resolve) => {
2494
+ const finishCb = async (event, ack) => {
2495
+ if (event.runId !== params.runId) {
2496
+ await ack?.();
2497
+ return;
2498
+ }
2499
+ if (["workflow.end", "workflow.fail", "workflow.suspend"].includes(event.type)) {
2500
+ await ack?.();
2501
+ await pubsub.unsubscribe("workflows-finish", finishCb);
2502
+ resolve(event.data);
2503
+ return;
2504
+ }
2505
+ await ack?.();
2506
+ };
2507
+ pubsub.subscribe("workflows-finish", finishCb).catch(() => {
2508
+ });
2509
+ });
2510
+ if (resultData.prevResult.status === "failed") {
2511
+ return {
2512
+ status: "failed",
2513
+ error: resultData.prevResult.error,
2514
+ steps: resultData.stepResults
2515
+ };
2516
+ } else if (resultData.prevResult.status === "suspended") {
2517
+ const suspendedSteps = Object.entries(resultData.stepResults).map(([_stepId, stepResult]) => {
2518
+ if (stepResult.status === "suspended") {
2519
+ return stepResult.suspendPayload?.__workflow_meta?.path ?? [];
2520
+ }
2521
+ return null;
2522
+ }).filter(Boolean);
2523
+ return {
2524
+ status: "suspended",
2525
+ steps: resultData.stepResults,
2526
+ suspended: suspendedSteps
2527
+ };
2528
+ }
2529
+ return {
2530
+ status: resultData.prevResult.status,
2531
+ result: resultData.prevResult?.output,
2532
+ steps: resultData.stepResults
2533
+ };
2534
+ }
2535
+ };
2536
+
2537
+ export { EventedExecutionEngine, EventedRun, EventedWorkflow, StepExecutor, WorkflowEventProcessor, cloneStep, cloneWorkflow, createStep, createWorkflow };
2538
+ //# sourceMappingURL=chunk-N2ILP2YD.js.map
2539
+ //# sourceMappingURL=chunk-N2ILP2YD.js.map