@mastra/core 1.0.0-beta.11 → 1.0.0-beta.13

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 (394) hide show
  1. package/CHANGELOG.md +173 -0
  2. package/dist/_types/@internal_ai-sdk-v4/dist/index.d.ts +7549 -0
  3. package/dist/_types/@internal_ai-sdk-v4/dist/test.d.ts +65 -0
  4. package/dist/_types/@internal_ai-sdk-v5/dist/index.d.ts +8396 -0
  5. package/dist/_types/@internal_ai-sdk-v5/dist/test.d.ts +1708 -0
  6. package/dist/_types/@internal_external-types/dist/index.d.ts +858 -0
  7. package/dist/agent/agent-legacy.d.ts +1 -1
  8. package/dist/agent/agent.d.ts +1 -1
  9. package/dist/agent/agent.d.ts.map +1 -1
  10. package/dist/agent/agent.types.d.ts +5 -1
  11. package/dist/agent/agent.types.d.ts.map +1 -1
  12. package/dist/agent/index.cjs +9 -9
  13. package/dist/agent/index.js +2 -2
  14. package/dist/agent/message-list/index.cjs +3 -3
  15. package/dist/agent/message-list/index.d.ts +4 -3
  16. package/dist/agent/message-list/index.d.ts.map +1 -1
  17. package/dist/agent/message-list/index.js +1 -1
  18. package/dist/agent/message-list/prompt/attachments-to-parts.d.ts +1 -1
  19. package/dist/agent/message-list/prompt/invalid-content-error.d.ts +1 -1
  20. package/dist/agent/message-list/types.d.ts +3 -3
  21. package/dist/agent/message-list/types.d.ts.map +1 -1
  22. package/dist/agent/message-list/utils/ai-v4-v5/core-model-message.d.ts +1 -1
  23. package/dist/agent/message-list/utils/ai-v4-v5/ui-message.d.ts +1 -1
  24. package/dist/agent/message-list/utils/ai-v5/gemini-compatibility.d.ts +2 -2
  25. package/dist/agent/message-list/utils/ai-v5/gemini-compatibility.d.ts.map +1 -1
  26. package/dist/agent/message-list/utils/convert-messages.d.ts +2 -2
  27. package/dist/agent/message-list/utils/convert-messages.d.ts.map +1 -1
  28. package/dist/agent/types.d.ts +3 -3
  29. package/dist/agent/utils.d.ts +3 -3
  30. package/dist/agent/utils.d.ts.map +1 -1
  31. package/dist/agent/workflows/prepare-stream/index.d.ts +2 -1
  32. package/dist/agent/workflows/prepare-stream/index.d.ts.map +1 -1
  33. package/dist/agent/workflows/prepare-stream/prepare-tools-step.d.ts.map +1 -1
  34. package/dist/agent/workflows/prepare-stream/stream-step.d.ts +3 -1
  35. package/dist/agent/workflows/prepare-stream/stream-step.d.ts.map +1 -1
  36. package/dist/bundler/types.d.ts +14 -1
  37. package/dist/bundler/types.d.ts.map +1 -1
  38. package/dist/{chunk-U3XOLEPX.js → chunk-2IU4RGU5.js} +6 -32
  39. package/dist/chunk-2IU4RGU5.js.map +1 -0
  40. package/dist/chunk-2SQB3WBT.js +4574 -0
  41. package/dist/chunk-2SQB3WBT.js.map +1 -0
  42. package/dist/{chunk-THZTRBFS.js → chunk-373OC54J.js} +8 -8
  43. package/dist/chunk-373OC54J.js.map +1 -0
  44. package/dist/{chunk-F2GAJSBI.js → chunk-4BC5FUAO.js} +8 -6
  45. package/dist/{chunk-F2GAJSBI.js.map → chunk-4BC5FUAO.js.map} +1 -1
  46. package/dist/chunk-55VPMN3N.js +250 -0
  47. package/dist/chunk-55VPMN3N.js.map +1 -0
  48. package/dist/{chunk-QM5SRDJX.js → chunk-5PTZG26U.js} +66 -84
  49. package/dist/chunk-5PTZG26U.js.map +1 -0
  50. package/dist/chunk-5VZGJTPR.js +4837 -0
  51. package/dist/chunk-5VZGJTPR.js.map +1 -0
  52. package/dist/{chunk-C36YRTZ6.js → chunk-62Q7K656.js} +6 -7
  53. package/dist/chunk-62Q7K656.js.map +1 -0
  54. package/dist/chunk-6PMMP3FR.js +7 -0
  55. package/dist/chunk-6PMMP3FR.js.map +1 -0
  56. package/dist/{chunk-DZUJEN5N.cjs → chunk-6SZKM6EC.cjs} +10 -3
  57. package/dist/{chunk-DZUJEN5N.cjs.map → chunk-6SZKM6EC.cjs.map} +1 -1
  58. package/dist/{chunk-5WRI5ZAA.js → chunk-7D4SUZUM.js} +10 -4
  59. package/dist/{chunk-5WRI5ZAA.js.map → chunk-7D4SUZUM.js.map} +1 -1
  60. package/dist/{chunk-YWMMBIOM.cjs → chunk-7HEAVZRS.cjs} +15 -15
  61. package/dist/{chunk-YWMMBIOM.cjs.map → chunk-7HEAVZRS.cjs.map} +1 -1
  62. package/dist/{chunk-BUKY6CTR.cjs → chunk-AGHLXC4I.cjs} +106 -36
  63. package/dist/chunk-AGHLXC4I.cjs.map +1 -0
  64. package/dist/{chunk-PK2A5WBG.js → chunk-ARAQIW6E.js} +222 -604
  65. package/dist/chunk-ARAQIW6E.js.map +1 -0
  66. package/dist/{chunk-US2U7ECW.js → chunk-BQDZIQ3G.js} +156 -90
  67. package/dist/chunk-BQDZIQ3G.js.map +1 -0
  68. package/dist/chunk-D22XABFZ.js +79 -0
  69. package/dist/chunk-D22XABFZ.js.map +1 -0
  70. package/dist/{chunk-2ULLRN4Y.js → chunk-E5BQRAJK.js} +943 -626
  71. package/dist/chunk-E5BQRAJK.js.map +1 -0
  72. package/dist/chunk-FST2G2FQ.cjs +84 -0
  73. package/dist/chunk-FST2G2FQ.cjs.map +1 -0
  74. package/dist/chunk-FVQTJUBD.cjs +2120 -0
  75. package/dist/chunk-FVQTJUBD.cjs.map +1 -0
  76. package/dist/chunk-G6E6V2Z4.js +2070 -0
  77. package/dist/chunk-G6E6V2Z4.js.map +1 -0
  78. package/dist/{chunk-7P6BNIJH.js → chunk-GIWC35YQ.js} +105 -35
  79. package/dist/chunk-GIWC35YQ.js.map +1 -0
  80. package/dist/{chunk-4JKEUSCC.cjs → chunk-H4VUIOWU.cjs} +22 -20
  81. package/dist/chunk-H4VUIOWU.cjs.map +1 -0
  82. package/dist/{chunk-TWH4PTDG.cjs → chunk-HWMMIRIF.cjs} +32 -27
  83. package/dist/chunk-HWMMIRIF.cjs.map +1 -0
  84. package/dist/chunk-IXZ2T2QX.cjs +448 -0
  85. package/dist/chunk-IXZ2T2QX.cjs.map +1 -0
  86. package/dist/chunk-L3NKIMF5.cjs +10 -0
  87. package/dist/chunk-L3NKIMF5.cjs.map +1 -0
  88. package/dist/chunk-L4JCRWDY.cjs +252 -0
  89. package/dist/chunk-L4JCRWDY.cjs.map +1 -0
  90. package/dist/{chunk-BJXKH4LG.cjs → chunk-LGB4VNZI.cjs} +43 -78
  91. package/dist/chunk-LGB4VNZI.cjs.map +1 -0
  92. package/dist/{chunk-PG5H6QIO.cjs → chunk-MLKE7HRS.cjs} +41 -21
  93. package/dist/chunk-MLKE7HRS.cjs.map +1 -0
  94. package/dist/{chunk-OEIVMCWX.js → chunk-MRRFTNF4.js} +2537 -84
  95. package/dist/chunk-MRRFTNF4.js.map +1 -0
  96. package/dist/chunk-MXBVP7HX.cjs +4842 -0
  97. package/dist/chunk-MXBVP7HX.cjs.map +1 -0
  98. package/dist/chunk-NESKUIRE.cjs +4586 -0
  99. package/dist/chunk-NESKUIRE.cjs.map +1 -0
  100. package/dist/{chunk-SVLMF4UZ.cjs → chunk-NIOEY3N3.cjs} +66 -85
  101. package/dist/chunk-NIOEY3N3.cjs.map +1 -0
  102. package/dist/{chunk-CZEJQSWB.cjs → chunk-OWIEOL55.cjs} +295 -677
  103. package/dist/chunk-OWIEOL55.cjs.map +1 -0
  104. package/dist/{chunk-WTSZBHIZ.cjs → chunk-PJAK4U6R.cjs} +24 -24
  105. package/dist/{chunk-WTSZBHIZ.cjs.map → chunk-PJAK4U6R.cjs.map} +1 -1
  106. package/dist/{chunk-52RSUALV.cjs → chunk-R5AJGM55.cjs} +1314 -995
  107. package/dist/chunk-R5AJGM55.cjs.map +1 -0
  108. package/dist/{chunk-IVV5TOMD.js → chunk-RCJLMMTO.js} +32 -12
  109. package/dist/chunk-RCJLMMTO.js.map +1 -0
  110. package/dist/{chunk-S73Z3PBJ.cjs → chunk-SZYSDJTN.cjs} +27 -28
  111. package/dist/chunk-SZYSDJTN.cjs.map +1 -0
  112. package/dist/{chunk-YC6PJEPH.cjs → chunk-U4CSOY6T.cjs} +188 -122
  113. package/dist/chunk-U4CSOY6T.cjs.map +1 -0
  114. package/dist/chunk-UBSPZTQX.js +434 -0
  115. package/dist/chunk-UBSPZTQX.js.map +1 -0
  116. package/dist/{chunk-SCUWP4II.cjs → chunk-VEPP75C4.cjs} +47 -74
  117. package/dist/chunk-VEPP75C4.cjs.map +1 -0
  118. package/dist/{chunk-JIGDJK2O.js → chunk-VETAQUW3.js} +4 -39
  119. package/dist/chunk-VETAQUW3.js.map +1 -0
  120. package/dist/{chunk-Z57R5WS4.js → chunk-WPTTKULS.js} +4 -4
  121. package/dist/{chunk-Z57R5WS4.js.map → chunk-WPTTKULS.js.map} +1 -1
  122. package/dist/{chunk-O2BJW7YA.js → chunk-WYGUWVTF.js} +5 -5
  123. package/dist/{chunk-O2BJW7YA.js.map → chunk-WYGUWVTF.js.map} +1 -1
  124. package/dist/{chunk-SXNQRJQD.js → chunk-WYWRMIQC.js} +127 -22
  125. package/dist/chunk-WYWRMIQC.js.map +1 -0
  126. package/dist/{chunk-5Q6WAYEY.cjs → chunk-X6IBA7FP.cjs} +137 -50
  127. package/dist/chunk-X6IBA7FP.cjs.map +1 -0
  128. package/dist/{chunk-MRFUISXC.cjs → chunk-Y7MZ5LJT.cjs} +2632 -179
  129. package/dist/chunk-Y7MZ5LJT.cjs.map +1 -0
  130. package/dist/{chunk-JJ5O45LH.js → chunk-YPLZDWG7.js} +32 -27
  131. package/dist/chunk-YPLZDWG7.js.map +1 -0
  132. package/dist/{chunk-MGCGWPQJ.cjs → chunk-Z55SJVEC.cjs} +8 -8
  133. package/dist/chunk-Z55SJVEC.cjs.map +1 -0
  134. package/dist/error/index.cjs +6 -6
  135. package/dist/error/index.d.ts +26 -20
  136. package/dist/error/index.d.ts.map +1 -1
  137. package/dist/error/index.js +1 -1
  138. package/dist/error/utils.d.ts +19 -5
  139. package/dist/error/utils.d.ts.map +1 -1
  140. package/dist/evals/index.cjs +4 -4
  141. package/dist/evals/index.js +1 -1
  142. package/dist/evals/run/index.d.ts +1 -1
  143. package/dist/evals/scoreTraces/index.cjs +8 -8
  144. package/dist/evals/scoreTraces/index.js +2 -2
  145. package/dist/evals/types.d.ts +1 -1
  146. package/dist/events/event-emitter.d.ts +6 -1
  147. package/dist/events/event-emitter.d.ts.map +1 -1
  148. package/dist/index.cjs +2 -2
  149. package/dist/index.js +1 -1
  150. package/dist/integration/index.cjs +2 -2
  151. package/dist/integration/index.js +1 -1
  152. package/dist/llm/index.cjs +15 -15
  153. package/dist/llm/index.d.ts +2 -2
  154. package/dist/llm/index.d.ts.map +1 -1
  155. package/dist/llm/index.js +5 -5
  156. package/dist/llm/model/aisdk/v5/model.d.ts +1 -1
  157. package/dist/llm/model/base.types.d.ts +2 -2
  158. package/dist/llm/model/model.d.ts +1 -1
  159. package/dist/llm/model/model.d.ts.map +1 -1
  160. package/dist/llm/model/model.loop.d.ts +2 -2
  161. package/dist/llm/model/model.loop.d.ts.map +1 -1
  162. package/dist/llm/model/model.loop.types.d.ts +1 -1
  163. package/dist/llm/model/model.loop.types.d.ts.map +1 -1
  164. package/dist/llm/model/provider-types.generated.d.ts +51 -11
  165. package/dist/llm/model/shared.types.d.ts +1 -1
  166. package/dist/loop/index.cjs +2 -2
  167. package/dist/loop/index.js +1 -1
  168. package/dist/loop/loop.d.ts +2 -2
  169. package/dist/loop/loop.d.ts.map +1 -1
  170. package/dist/loop/test-utils/MastraLanguageModelV2Mock.d.ts +1 -1
  171. package/dist/loop/test-utils/MastraLanguageModelV2Mock.d.ts.map +1 -1
  172. package/dist/loop/test-utils/options.d.ts.map +1 -1
  173. package/dist/loop/test-utils/streamObject.d.ts +1 -1
  174. package/dist/loop/test-utils/streamObject.d.ts.map +1 -1
  175. package/dist/loop/test-utils/tools.d.ts.map +1 -1
  176. package/dist/loop/types.d.ts +3 -1
  177. package/dist/loop/types.d.ts.map +1 -1
  178. package/dist/loop/workflows/agentic-execution/index.d.ts +13 -13
  179. package/dist/loop/workflows/agentic-execution/index.d.ts.map +1 -1
  180. package/dist/loop/workflows/agentic-execution/llm-execution-step.d.ts +10 -10
  181. package/dist/loop/workflows/agentic-execution/llm-execution-step.d.ts.map +1 -1
  182. package/dist/loop/workflows/agentic-execution/llm-mapping-step.d.ts +5 -5
  183. package/dist/loop/workflows/agentic-execution/llm-mapping-step.d.ts.map +1 -1
  184. package/dist/loop/workflows/agentic-execution/tool-call-step.d.ts +22 -21
  185. package/dist/loop/workflows/agentic-execution/tool-call-step.d.ts.map +1 -1
  186. package/dist/loop/workflows/agentic-loop/index.d.ts +13 -13
  187. package/dist/loop/workflows/agentic-loop/index.d.ts.map +1 -1
  188. package/dist/loop/workflows/schema.d.ts +6 -6
  189. package/dist/loop/workflows/schema.d.ts.map +1 -1
  190. package/dist/loop/workflows/stream.d.ts +2 -2
  191. package/dist/loop/workflows/stream.d.ts.map +1 -1
  192. package/dist/mastra/index.cjs +2 -2
  193. package/dist/mastra/index.js +1 -1
  194. package/dist/mcp/index.cjs +4 -4
  195. package/dist/mcp/index.js +1 -1
  196. package/dist/memory/index.cjs +6 -6
  197. package/dist/memory/index.js +1 -1
  198. package/dist/memory/memory.d.ts +1 -1
  199. package/dist/memory/types.d.ts +3 -3
  200. package/dist/memory/types.d.ts.map +1 -1
  201. package/dist/models-dev-D3EKFGAO.cjs +12 -0
  202. package/dist/{models-dev-EO3SUIY2.cjs.map → models-dev-D3EKFGAO.cjs.map} +1 -1
  203. package/dist/models-dev-EO22XOXQ.js +3 -0
  204. package/dist/{models-dev-23RN2WHG.js.map → models-dev-EO22XOXQ.js.map} +1 -1
  205. package/dist/netlify-AE4LNCAI.js +3 -0
  206. package/dist/{netlify-GXJ5D5DD.js.map → netlify-AE4LNCAI.js.map} +1 -1
  207. package/dist/netlify-WE42TZIT.cjs +12 -0
  208. package/dist/{netlify-KJLY3GFS.cjs.map → netlify-WE42TZIT.cjs.map} +1 -1
  209. package/dist/processors/index.cjs +37 -37
  210. package/dist/processors/index.d.ts +2 -2
  211. package/dist/processors/index.d.ts.map +1 -1
  212. package/dist/processors/index.js +1 -1
  213. package/dist/processors/step-schema.d.ts +1267 -1267
  214. package/dist/processors/step-schema.d.ts.map +1 -1
  215. package/dist/provider-registry-6LF3NGC5.js +3 -0
  216. package/dist/{provider-registry-F67Y6OF2.js.map → provider-registry-6LF3NGC5.js.map} +1 -1
  217. package/dist/provider-registry-73FKMXJV.cjs +40 -0
  218. package/dist/{provider-registry-3TG2KUD2.cjs.map → provider-registry-73FKMXJV.cjs.map} +1 -1
  219. package/dist/provider-registry.json +100 -30
  220. package/dist/{registry-generator-UMTNPBJX.js → registry-generator-AVQXI3GX.js} +2 -2
  221. package/dist/{registry-generator-UMTNPBJX.js.map → registry-generator-AVQXI3GX.js.map} +1 -1
  222. package/dist/{registry-generator-34SC4TAU.cjs → registry-generator-KOFNIIWJ.cjs} +2 -2
  223. package/dist/{registry-generator-34SC4TAU.cjs.map → registry-generator-KOFNIIWJ.cjs.map} +1 -1
  224. package/dist/relevance/index.cjs +2 -2
  225. package/dist/relevance/index.js +1 -1
  226. package/dist/server/index.cjs +5 -5
  227. package/dist/server/index.js +1 -1
  228. package/dist/storage/base.d.ts +2 -10
  229. package/dist/storage/base.d.ts.map +1 -1
  230. package/dist/storage/domains/workflows/base.d.ts +2 -8
  231. package/dist/storage/domains/workflows/base.d.ts.map +1 -1
  232. package/dist/storage/domains/workflows/inmemory.d.ts +2 -8
  233. package/dist/storage/domains/workflows/inmemory.d.ts.map +1 -1
  234. package/dist/storage/index.cjs +38 -38
  235. package/dist/storage/index.js +1 -1
  236. package/dist/storage/mock.d.ts +2 -8
  237. package/dist/storage/mock.d.ts.map +1 -1
  238. package/dist/storage/types.d.ts +9 -1
  239. package/dist/storage/types.d.ts.map +1 -1
  240. package/dist/stream/RunOutput.d.ts +1 -1
  241. package/dist/stream/aisdk/v4/input.d.ts +1 -1
  242. package/dist/stream/aisdk/v5/compat/content.d.ts +1 -1
  243. package/dist/stream/aisdk/v5/compat/content.d.ts.map +1 -1
  244. package/dist/stream/aisdk/v5/compat/prepare-tools.d.ts +1 -1
  245. package/dist/stream/aisdk/v5/compat/prepare-tools.d.ts.map +1 -1
  246. package/dist/stream/aisdk/v5/compat/ui-message.d.ts +1 -1
  247. package/dist/stream/aisdk/v5/compat/ui-message.d.ts.map +1 -1
  248. package/dist/stream/aisdk/v5/compat/validation.d.ts +1 -1
  249. package/dist/stream/aisdk/v5/compat/validation.d.ts.map +1 -1
  250. package/dist/stream/aisdk/v5/execute.d.ts +2 -2
  251. package/dist/stream/aisdk/v5/execute.d.ts.map +1 -1
  252. package/dist/stream/aisdk/v5/input.d.ts +1 -1
  253. package/dist/stream/aisdk/v5/input.d.ts.map +1 -1
  254. package/dist/stream/aisdk/v5/output-helpers.d.ts +12 -27
  255. package/dist/stream/aisdk/v5/output-helpers.d.ts.map +1 -1
  256. package/dist/stream/aisdk/v5/output.d.ts +41 -91
  257. package/dist/stream/aisdk/v5/output.d.ts.map +1 -1
  258. package/dist/stream/aisdk/v5/transform.d.ts +1 -1
  259. package/dist/stream/aisdk/v5/transform.d.ts.map +1 -1
  260. package/dist/stream/base/input.d.ts +1 -1
  261. package/dist/stream/base/output.d.ts +9 -31
  262. package/dist/stream/base/output.d.ts.map +1 -1
  263. package/dist/stream/base/schema.d.ts +2 -2
  264. package/dist/stream/base/schema.d.ts.map +1 -1
  265. package/dist/stream/index.cjs +12 -12
  266. package/dist/stream/index.js +2 -2
  267. package/dist/stream/types.d.ts +3 -2
  268. package/dist/stream/types.d.ts.map +1 -1
  269. package/dist/test-utils/llm-mock.cjs +14587 -14
  270. package/dist/test-utils/llm-mock.cjs.map +1 -1
  271. package/dist/test-utils/llm-mock.d.ts +3 -3
  272. package/dist/test-utils/llm-mock.d.ts.map +1 -1
  273. package/dist/test-utils/llm-mock.js +14577 -4
  274. package/dist/test-utils/llm-mock.js.map +1 -1
  275. package/dist/token-6GSAFR2W-SGVIXFCP.cjs +63 -0
  276. package/dist/token-6GSAFR2W-SGVIXFCP.cjs.map +1 -0
  277. package/dist/token-6GSAFR2W-SPYPLMBM.js +61 -0
  278. package/dist/token-6GSAFR2W-SPYPLMBM.js.map +1 -0
  279. package/dist/token-util-NEHG7TUY-7GMW5FXI.cjs +10 -0
  280. package/dist/token-util-NEHG7TUY-7GMW5FXI.cjs.map +1 -0
  281. package/dist/token-util-NEHG7TUY-JRJTGTAB.js +8 -0
  282. package/dist/token-util-NEHG7TUY-JRJTGTAB.js.map +1 -0
  283. package/dist/tools/index.cjs +4 -4
  284. package/dist/tools/index.js +1 -1
  285. package/dist/tools/is-vercel-tool.cjs +2 -2
  286. package/dist/tools/is-vercel-tool.js +1 -1
  287. package/dist/tools/tool-builder/builder.d.ts +2 -1
  288. package/dist/tools/tool-builder/builder.d.ts.map +1 -1
  289. package/dist/tools/tool.d.ts.map +1 -1
  290. package/dist/tools/types.d.ts +5 -5
  291. package/dist/tools/types.d.ts.map +1 -1
  292. package/dist/utils.cjs +22 -22
  293. package/dist/utils.d.ts +3 -3
  294. package/dist/utils.d.ts.map +1 -1
  295. package/dist/utils.js +1 -1
  296. package/dist/vector/embed.d.ts +2 -2
  297. package/dist/vector/embed.d.ts.map +1 -1
  298. package/dist/vector/index.cjs +11 -11
  299. package/dist/vector/index.js +3 -3
  300. package/dist/vector/vector.d.ts +1 -1
  301. package/dist/voice/aisdk/speech.d.ts +1 -1
  302. package/dist/voice/aisdk/speech.d.ts.map +1 -1
  303. package/dist/voice/aisdk/transcription.d.ts +1 -1
  304. package/dist/voice/aisdk/transcription.d.ts.map +1 -1
  305. package/dist/voice/composite-voice.d.ts +1 -1
  306. package/dist/voice/composite-voice.d.ts.map +1 -1
  307. package/dist/voice/index.cjs +6 -6
  308. package/dist/voice/index.js +1 -1
  309. package/dist/workflows/constants.cjs +4 -4
  310. package/dist/workflows/constants.d.ts +1 -1
  311. package/dist/workflows/constants.d.ts.map +1 -1
  312. package/dist/workflows/constants.js +1 -1
  313. package/dist/workflows/default.d.ts +9 -16
  314. package/dist/workflows/default.d.ts.map +1 -1
  315. package/dist/workflows/evented/execution-engine.d.ts +3 -2
  316. package/dist/workflows/evented/execution-engine.d.ts.map +1 -1
  317. package/dist/workflows/evented/index.cjs +10 -10
  318. package/dist/workflows/evented/index.js +1 -1
  319. package/dist/workflows/evented/step-executor.d.ts +1 -1
  320. package/dist/workflows/evented/step-executor.d.ts.map +1 -1
  321. package/dist/workflows/evented/workflow-event-processor/index.d.ts +1 -1
  322. package/dist/workflows/evented/workflow-event-processor/index.d.ts.map +1 -1
  323. package/dist/workflows/evented/workflow.d.ts +15 -0
  324. package/dist/workflows/evented/workflow.d.ts.map +1 -1
  325. package/dist/workflows/execution-engine.d.ts +25 -2
  326. package/dist/workflows/execution-engine.d.ts.map +1 -1
  327. package/dist/workflows/handlers/control-flow.d.ts +6 -5
  328. package/dist/workflows/handlers/control-flow.d.ts.map +1 -1
  329. package/dist/workflows/handlers/entry.d.ts +5 -3
  330. package/dist/workflows/handlers/entry.d.ts.map +1 -1
  331. package/dist/workflows/handlers/sleep.d.ts +4 -3
  332. package/dist/workflows/handlers/sleep.d.ts.map +1 -1
  333. package/dist/workflows/handlers/step.d.ts +5 -3
  334. package/dist/workflows/handlers/step.d.ts.map +1 -1
  335. package/dist/workflows/index.cjs +26 -22
  336. package/dist/workflows/index.js +1 -1
  337. package/dist/workflows/step.d.ts +5 -4
  338. package/dist/workflows/step.d.ts.map +1 -1
  339. package/dist/workflows/types.d.ts +66 -14
  340. package/dist/workflows/types.d.ts.map +1 -1
  341. package/dist/workflows/utils.d.ts +11 -0
  342. package/dist/workflows/utils.d.ts.map +1 -1
  343. package/dist/workflows/workflow.d.ts +26 -8
  344. package/dist/workflows/workflow.d.ts.map +1 -1
  345. package/package.json +12 -11
  346. package/src/llm/model/provider-types.generated.d.ts +51 -11
  347. package/dist/agent/__tests__/mock-model.d.ts +0 -8
  348. package/dist/agent/__tests__/mock-model.d.ts.map +0 -1
  349. package/dist/agent/agent-types.test-d.d.ts +0 -2
  350. package/dist/agent/agent-types.test-d.d.ts.map +0 -1
  351. package/dist/ai-sdk.types.d.ts +0 -4705
  352. package/dist/chunk-2ULLRN4Y.js.map +0 -1
  353. package/dist/chunk-3E3ILV6T.cjs +0 -518
  354. package/dist/chunk-3E3ILV6T.cjs.map +0 -1
  355. package/dist/chunk-4JKEUSCC.cjs.map +0 -1
  356. package/dist/chunk-52RSUALV.cjs.map +0 -1
  357. package/dist/chunk-5PAEYE3Q.js +0 -513
  358. package/dist/chunk-5PAEYE3Q.js.map +0 -1
  359. package/dist/chunk-5Q6WAYEY.cjs.map +0 -1
  360. package/dist/chunk-7P6BNIJH.js.map +0 -1
  361. package/dist/chunk-ABJOUEVA.cjs +0 -10
  362. package/dist/chunk-ABJOUEVA.cjs.map +0 -1
  363. package/dist/chunk-BJXKH4LG.cjs.map +0 -1
  364. package/dist/chunk-BUKY6CTR.cjs.map +0 -1
  365. package/dist/chunk-C36YRTZ6.js.map +0 -1
  366. package/dist/chunk-CZEJQSWB.cjs.map +0 -1
  367. package/dist/chunk-IVV5TOMD.js.map +0 -1
  368. package/dist/chunk-JIGDJK2O.js.map +0 -1
  369. package/dist/chunk-JJ5O45LH.js.map +0 -1
  370. package/dist/chunk-MGCGWPQJ.cjs.map +0 -1
  371. package/dist/chunk-MRFUISXC.cjs.map +0 -1
  372. package/dist/chunk-NLNKQD2T.js +0 -7
  373. package/dist/chunk-NLNKQD2T.js.map +0 -1
  374. package/dist/chunk-OEIVMCWX.js.map +0 -1
  375. package/dist/chunk-PG5H6QIO.cjs.map +0 -1
  376. package/dist/chunk-PK2A5WBG.js.map +0 -1
  377. package/dist/chunk-QM5SRDJX.js.map +0 -1
  378. package/dist/chunk-S73Z3PBJ.cjs.map +0 -1
  379. package/dist/chunk-SCUWP4II.cjs.map +0 -1
  380. package/dist/chunk-SVLMF4UZ.cjs.map +0 -1
  381. package/dist/chunk-SXNQRJQD.js.map +0 -1
  382. package/dist/chunk-THZTRBFS.js.map +0 -1
  383. package/dist/chunk-TWH4PTDG.cjs.map +0 -1
  384. package/dist/chunk-U3XOLEPX.js.map +0 -1
  385. package/dist/chunk-US2U7ECW.js.map +0 -1
  386. package/dist/chunk-YC6PJEPH.cjs.map +0 -1
  387. package/dist/models-dev-23RN2WHG.js +0 -3
  388. package/dist/models-dev-EO3SUIY2.cjs +0 -12
  389. package/dist/netlify-GXJ5D5DD.js +0 -3
  390. package/dist/netlify-KJLY3GFS.cjs +0 -12
  391. package/dist/provider-registry-3TG2KUD2.cjs +0 -40
  392. package/dist/provider-registry-F67Y6OF2.js +0 -3
  393. package/dist/tools/tool-stream-types.test-d.d.ts +0 -2
  394. package/dist/tools/tool-stream-types.test-d.d.ts.map +0 -1
@@ -1,8 +1,8 @@
1
- import { validateStepInput, createDeprecationProxy, getStepResult, validateStepSuspendData, runCountDeprecationMessage, createTimeTravelExecutionParams, validateStepResumeData, Workflow, Run, ExecutionEngine } from './chunk-2ULLRN4Y.js';
2
- import { STREAM_FORMAT_SYMBOL, EMITTER_SYMBOL } from './chunk-NLNKQD2T.js';
3
- import { getErrorFromUnknown, MastraError } from './chunk-JJ5O45LH.js';
4
- import { Tool } from './chunk-THZTRBFS.js';
1
+ import { validateStepInput, createDeprecationProxy, EventEmitterPubSub, getStepResult, validateStepSuspendData, runCountDeprecationMessage, createTimeTravelExecutionParams, validateStepResumeData, Workflow, Run, ExecutionEngine, hydrateSerializedStepErrors } from './chunk-E5BQRAJK.js';
2
+ import { STREAM_FORMAT_SYMBOL, PUBSUB_SYMBOL } from './chunk-6PMMP3FR.js';
3
+ import { Tool } from './chunk-373OC54J.js';
5
4
  import { RequestContext } from './chunk-6TBWJV35.js';
5
+ import { getErrorFromUnknown, MastraError } from './chunk-YPLZDWG7.js';
6
6
  import { MastraBase } from './chunk-LSHPJWM5.js';
7
7
  import { RegisteredLogger } from './chunk-NRUZYMHE.js';
8
8
  import EventEmitter from 'events';
@@ -84,8 +84,7 @@ var StepExecutor = class extends MastraBase {
84
84
  abort: () => {
85
85
  abortController?.abort();
86
86
  },
87
- [EMITTER_SYMBOL]: params.emitter,
88
- // TODO: refactor this to use our PubSub actually
87
+ [PUBSUB_SYMBOL]: this.mastra?.pubsub ?? new EventEmitterPubSub(params.emitter),
89
88
  [STREAM_FORMAT_SYMBOL]: void 0,
90
89
  // TODO
91
90
  engine: {},
@@ -132,14 +131,14 @@ var StepExecutor = class extends MastraBase {
132
131
  } catch (error) {
133
132
  const endedAt = Date.now();
134
133
  const errorInstance = getErrorFromUnknown(error, {
135
- includeStack: false,
134
+ serializeStack: false,
136
135
  fallbackMessage: "Unknown step execution error"
137
136
  });
138
137
  return {
139
138
  ...stepInfo,
140
139
  status: "failed",
141
140
  endedAt,
142
- error: `Error: ${errorInstance.message}`
141
+ error: errorInstance
143
142
  };
144
143
  }
145
144
  }
@@ -213,8 +212,7 @@ var StepExecutor = class extends MastraBase {
213
212
  abort: () => {
214
213
  abortController?.abort();
215
214
  },
216
- [EMITTER_SYMBOL]: emitter,
217
- // TODO: refactor this to use our PubSub actually
215
+ [PUBSUB_SYMBOL]: this.mastra?.pubsub ?? new EventEmitterPubSub(emitter),
218
216
  [STREAM_FORMAT_SYMBOL]: void 0,
219
217
  // TODO
220
218
  engine: {},
@@ -269,8 +267,7 @@ var StepExecutor = class extends MastraBase {
269
267
  },
270
268
  // TODO
271
269
  writer: void 0,
272
- [EMITTER_SYMBOL]: ee,
273
- // TODO: refactor this to use our PubSub actually
270
+ [PUBSUB_SYMBOL]: this.mastra?.pubsub ?? new EventEmitterPubSub(ee),
274
271
  [STREAM_FORMAT_SYMBOL]: void 0,
275
272
  // TODO
276
273
  engine: {},
@@ -328,8 +325,7 @@ var StepExecutor = class extends MastraBase {
328
325
  },
329
326
  // TODO
330
327
  writer: void 0,
331
- [EMITTER_SYMBOL]: ee,
332
- // TODO: refactor this to use our PubSub actually
328
+ [PUBSUB_SYMBOL]: this.mastra?.pubsub ?? new EventEmitterPubSub(ee),
333
329
  [STREAM_FORMAT_SYMBOL]: void 0,
334
330
  // TODO
335
331
  engine: {},
@@ -951,7 +947,7 @@ var WorkflowEventProcessor = class extends EventProcessor {
951
947
  executionPath: [],
952
948
  resumeSteps,
953
949
  stepResults,
954
- prevResult: { status: "failed", error: e.stack ?? e.message },
950
+ prevResult: { status: "failed", error: getErrorFromUnknown(e).toJSON() },
955
951
  requestContext,
956
952
  resumeData,
957
953
  activeSteps: {},
@@ -960,26 +956,27 @@ var WorkflowEventProcessor = class extends EventProcessor {
960
956
  });
961
957
  }
962
958
  async processWorkflowCancel({ workflowId, runId }) {
963
- const currentState = await this.mastra.getStorage()?.updateWorkflowState({
959
+ const storage = this.mastra.getStorage();
960
+ const currentState = await storage?.loadWorkflowSnapshot({
964
961
  workflowName: workflowId,
965
- runId,
966
- opts: {
967
- status: "canceled"
968
- }
969
- });
970
- await this.endWorkflow({
971
- workflow: void 0,
972
- workflowId,
973
- runId,
974
- stepResults: currentState?.context,
975
- prevResult: { status: "canceled" },
976
- requestContext: currentState?.requestContext,
977
- executionPath: [],
978
- activeSteps: {},
979
- resumeSteps: [],
980
- resumeData: void 0,
981
- parentWorkflow: void 0
962
+ runId
982
963
  });
964
+ await this.endWorkflow(
965
+ {
966
+ workflow: void 0,
967
+ workflowId,
968
+ runId,
969
+ stepResults: currentState?.context ?? {},
970
+ prevResult: { status: "canceled" },
971
+ requestContext: currentState?.requestContext ?? {},
972
+ executionPath: [],
973
+ activeSteps: {},
974
+ resumeSteps: [],
975
+ resumeData: void 0,
976
+ parentWorkflow: void 0
977
+ },
978
+ "canceled"
979
+ );
983
980
  }
984
981
  async processWorkflowStart({
985
982
  workflow,
@@ -994,9 +991,12 @@ var WorkflowEventProcessor = class extends EventProcessor {
994
991
  stepResults,
995
992
  requestContext
996
993
  }) {
994
+ const existingRun = await this.mastra.getStorage()?.getWorkflowRunById({ runId, workflowName: workflow.id });
995
+ const resourceId = existingRun?.resourceId;
997
996
  await this.mastra.getStorage()?.persistWorkflowSnapshot({
998
997
  workflowName: workflow.id,
999
998
  runId,
999
+ resourceId,
1000
1000
  snapshot: {
1001
1001
  activePaths: [],
1002
1002
  suspendedPaths: {},
@@ -1033,13 +1033,13 @@ var WorkflowEventProcessor = class extends EventProcessor {
1033
1033
  }
1034
1034
  });
1035
1035
  }
1036
- async endWorkflow(args) {
1036
+ async endWorkflow(args, status = "success") {
1037
1037
  const { workflowId, runId, prevResult } = args;
1038
1038
  await this.mastra.getStorage()?.updateWorkflowState({
1039
1039
  workflowName: workflowId,
1040
1040
  runId,
1041
1041
  opts: {
1042
- status: "success",
1042
+ status,
1043
1043
  result: prevResult
1044
1044
  }
1045
1045
  });
@@ -1922,7 +1922,7 @@ var WorkflowEventProcessor = class extends EventProcessor {
1922
1922
  workflowId: workflowData.workflowId,
1923
1923
  runId: workflowData.runId
1924
1924
  });
1925
- if (currentState?.status === "canceled" && type !== "workflow.end") {
1925
+ if (currentState?.status === "canceled" && type !== "workflow.end" && type !== "workflow.cancel") {
1926
1926
  return;
1927
1927
  }
1928
1928
  if (type.startsWith("workflow.user-event.")) {
@@ -2079,7 +2079,7 @@ function createStep(params) {
2079
2079
  outputSchema: z.object({
2080
2080
  text: z.string()
2081
2081
  }),
2082
- execute: async ({ inputData, [EMITTER_SYMBOL]: emitter, requestContext, abortSignal, abort }) => {
2082
+ execute: async ({ inputData, runId, [PUBSUB_SYMBOL]: pubsub, requestContext, abortSignal, abort }) => {
2083
2083
  let streamPromise = {};
2084
2084
  streamPromise.promise = new Promise((resolve, reject) => {
2085
2085
  streamPromise.resolve = resolve;
@@ -2101,22 +2101,24 @@ function createStep(params) {
2101
2101
  name: params.name,
2102
2102
  args: inputData
2103
2103
  };
2104
- await emitter.emit("watch", {
2105
- type: "tool-call-streaming-start",
2106
- ...toolData ?? {}
2104
+ await pubsub.publish(`workflow.events.v2.${runId}`, {
2105
+ type: "watch",
2106
+ runId,
2107
+ data: { type: "tool-call-streaming-start", ...toolData ?? {} }
2107
2108
  });
2108
2109
  for await (const chunk of fullStream) {
2109
2110
  if (chunk.type === "text-delta") {
2110
- await emitter.emit("watch", {
2111
- type: "tool-call-delta",
2112
- ...toolData ?? {},
2113
- argsTextDelta: chunk.textDelta
2111
+ await pubsub.publish(`workflow.events.v2.${runId}`, {
2112
+ type: "watch",
2113
+ runId,
2114
+ data: { type: "tool-call-delta", ...toolData ?? {}, argsTextDelta: chunk.textDelta }
2114
2115
  });
2115
2116
  }
2116
2117
  }
2117
- await emitter.emit("watch", {
2118
- type: "tool-call-streaming-finish",
2119
- ...toolData ?? {}
2118
+ await pubsub.publish(`workflow.events.v2.${runId}`, {
2119
+ type: "watch",
2120
+ runId,
2121
+ data: { type: "tool-call-streaming-finish", ...toolData ?? {} }
2120
2122
  });
2121
2123
  return {
2122
2124
  text: await streamPromise.promise
@@ -2187,7 +2189,9 @@ function createWorkflow(params) {
2187
2189
  options: {
2188
2190
  validateInputs: params.options?.validateInputs ?? true,
2189
2191
  shouldPersistSnapshot: params.options?.shouldPersistSnapshot ?? (() => true),
2190
- tracingPolicy: params.options?.tracingPolicy
2192
+ tracingPolicy: params.options?.tracingPolicy,
2193
+ onFinish: params.options?.onFinish,
2194
+ onError: params.options?.onError
2191
2195
  }
2192
2196
  });
2193
2197
  return new EventedWorkflow({
@@ -2209,6 +2213,7 @@ var EventedWorkflow = class extends Workflow {
2209
2213
  const run = this.runs.get(runIdToUse) ?? new EventedRun({
2210
2214
  workflowId: this.id,
2211
2215
  runId: runIdToUse,
2216
+ resourceId: options?.resourceId,
2212
2217
  executionEngine: this.executionEngine,
2213
2218
  executionGraph: this.executionGraph,
2214
2219
  serializedStepGraph: this.serializedStepGraph,
@@ -2229,6 +2234,7 @@ var EventedWorkflow = class extends Workflow {
2229
2234
  await this.mastra?.getStorage()?.persistWorkflowSnapshot({
2230
2235
  workflowName: this.id,
2231
2236
  runId: runIdToUse,
2237
+ resourceId: options?.resourceId,
2232
2238
  snapshot: {
2233
2239
  runId: runIdToUse,
2234
2240
  status: "pending",
@@ -2272,6 +2278,7 @@ var EventedRun = class extends Run {
2272
2278
  await this.mastra?.getStorage()?.persistWorkflowSnapshot({
2273
2279
  workflowName: this.workflowId,
2274
2280
  runId: this.runId,
2281
+ resourceId: this.resourceId,
2275
2282
  snapshot: {
2276
2283
  runId: this.runId,
2277
2284
  serializedStepGraph: this.serializedStepGraph,
@@ -2289,6 +2296,9 @@ var EventedRun = class extends Run {
2289
2296
  });
2290
2297
  const inputDataToUse = await this._validateInput(inputData);
2291
2298
  const initialStateToUse = await this._validateInitialState(initialState ?? {});
2299
+ if (!this.mastra?.pubsub) {
2300
+ throw new Error("Mastra instance with pubsub is required for workflow execution");
2301
+ }
2292
2302
  const result = await this.executionEngine.execute({
2293
2303
  workflowId: this.workflowId,
2294
2304
  runId: this.runId,
@@ -2296,20 +2306,7 @@ var EventedRun = class extends Run {
2296
2306
  serializedStepGraph: this.serializedStepGraph,
2297
2307
  input: inputDataToUse,
2298
2308
  initialState: initialStateToUse,
2299
- emitter: {
2300
- emit: async (event, data) => {
2301
- this.emitter.emit(event, data);
2302
- },
2303
- on: (event, callback) => {
2304
- this.emitter.on(event, callback);
2305
- },
2306
- off: (event, callback) => {
2307
- this.emitter.off(event, callback);
2308
- },
2309
- once: (event, callback) => {
2310
- this.emitter.once(event, callback);
2311
- }
2312
- },
2309
+ pubsub: this.mastra.pubsub,
2313
2310
  retryConfig: this.retryConfig,
2314
2311
  requestContext,
2315
2312
  abortController: this.abortController
@@ -2319,6 +2316,62 @@ var EventedRun = class extends Run {
2319
2316
  }
2320
2317
  return result;
2321
2318
  }
2319
+ /**
2320
+ * Starts the workflow execution without waiting for completion (fire-and-forget).
2321
+ * Returns immediately with the runId. The workflow executes in the background via pubsub.
2322
+ * Use this when you don't need to wait for the result or want to avoid polling failures.
2323
+ */
2324
+ async startAsync({
2325
+ inputData,
2326
+ initialState,
2327
+ requestContext
2328
+ }) {
2329
+ if (this.serializedStepGraph.length === 0) {
2330
+ throw new Error(
2331
+ "Execution flow of workflow is not defined. Add steps to the workflow via .then(), .branch(), etc."
2332
+ );
2333
+ }
2334
+ if (!this.executionGraph.steps) {
2335
+ throw new Error("Uncommitted step flow changes detected. Call .commit() to register the steps.");
2336
+ }
2337
+ requestContext = requestContext ?? new RequestContext();
2338
+ await this.mastra?.getStorage()?.persistWorkflowSnapshot({
2339
+ workflowName: this.workflowId,
2340
+ runId: this.runId,
2341
+ resourceId: this.resourceId,
2342
+ snapshot: {
2343
+ runId: this.runId,
2344
+ serializedStepGraph: this.serializedStepGraph,
2345
+ status: "running",
2346
+ value: {},
2347
+ context: {},
2348
+ requestContext: Object.fromEntries(requestContext.entries()),
2349
+ activePaths: [],
2350
+ activeStepsPath: {},
2351
+ suspendedPaths: {},
2352
+ resumeLabels: {},
2353
+ waitingPaths: {},
2354
+ timestamp: Date.now()
2355
+ }
2356
+ });
2357
+ const inputDataToUse = await this._validateInput(inputData);
2358
+ const initialStateToUse = await this._validateInitialState(initialState ?? {});
2359
+ if (!this.mastra?.pubsub) {
2360
+ throw new Error("Mastra instance with pubsub is required for workflow execution");
2361
+ }
2362
+ await this.mastra.pubsub.publish("workflows", {
2363
+ type: "workflow.start",
2364
+ runId: this.runId,
2365
+ data: {
2366
+ workflowId: this.workflowId,
2367
+ runId: this.runId,
2368
+ prevResult: { status: "success", output: inputDataToUse },
2369
+ requestContext: Object.fromEntries(requestContext.entries()),
2370
+ initialState: initialStateToUse
2371
+ }
2372
+ });
2373
+ return { runId: this.runId };
2374
+ }
2322
2375
  // TODO: stream
2323
2376
  async resume(params) {
2324
2377
  let steps = [];
@@ -2358,6 +2411,9 @@ var EventedRun = class extends Run {
2358
2411
  }
2359
2412
  const suspendedStep = this.workflowSteps[steps?.[0] ?? ""];
2360
2413
  const resumeDataToUse = await this._validateResumeData(params.resumeData, suspendedStep);
2414
+ if (!this.mastra?.pubsub) {
2415
+ throw new Error("Mastra instance with pubsub is required for workflow execution");
2416
+ }
2361
2417
  const executionResultPromise = this.executionEngine.execute({
2362
2418
  workflowId: this.workflowId,
2363
2419
  runId: this.runId,
@@ -2370,21 +2426,7 @@ var EventedRun = class extends Run {
2370
2426
  resumePayload: resumeDataToUse,
2371
2427
  resumePath
2372
2428
  },
2373
- emitter: {
2374
- emit: (event, data) => {
2375
- this.emitter.emit(event, data);
2376
- return Promise.resolve();
2377
- },
2378
- on: (event, callback) => {
2379
- this.emitter.on(event, callback);
2380
- },
2381
- off: (event, callback) => {
2382
- this.emitter.off(event, callback);
2383
- },
2384
- once: (event, callback) => {
2385
- this.emitter.once(event, callback);
2386
- }
2387
- },
2429
+ pubsub: this.mastra.pubsub,
2388
2430
  requestContext,
2389
2431
  abortController: this.abortController
2390
2432
  }).then((result) => {
@@ -2428,6 +2470,13 @@ var EventedRun = class extends Run {
2428
2470
  };
2429
2471
  }
2430
2472
  async cancel() {
2473
+ await this.mastra?.getStorage()?.updateWorkflowState({
2474
+ workflowName: this.workflowId,
2475
+ runId: this.runId,
2476
+ opts: {
2477
+ status: "canceled"
2478
+ }
2479
+ });
2431
2480
  await this.mastra?.pubsub.publish("workflows", {
2432
2481
  type: "workflow.cancel",
2433
2482
  runId: this.runId,
@@ -2556,7 +2605,7 @@ var EventedExecutionEngine = class extends ExecutionEngine {
2556
2605
  }
2557
2606
  });
2558
2607
  }
2559
- const resultData = await new Promise((resolve) => {
2608
+ const resultData = await new Promise((resolve, reject) => {
2560
2609
  const finishCb = async (event, ack) => {
2561
2610
  if (event.runId !== params.runId) {
2562
2611
  await ack?.();
@@ -2565,41 +2614,58 @@ var EventedExecutionEngine = class extends ExecutionEngine {
2565
2614
  if (["workflow.end", "workflow.fail", "workflow.suspend"].includes(event.type)) {
2566
2615
  await ack?.();
2567
2616
  await pubsub.unsubscribe("workflows-finish", finishCb);
2617
+ if (event.type === "workflow.fail" && event.data.stepResults) {
2618
+ event.data.stepResults = hydrateSerializedStepErrors(event.data.stepResults);
2619
+ }
2568
2620
  resolve(event.data);
2569
2621
  return;
2570
2622
  }
2571
2623
  await ack?.();
2572
2624
  };
2573
- pubsub.subscribe("workflows-finish", finishCb).catch(() => {
2625
+ pubsub.subscribe("workflows-finish", finishCb).catch((err) => {
2626
+ console.error("Failed to subscribe to workflows-finish:", err);
2627
+ reject(err);
2574
2628
  });
2575
2629
  });
2630
+ let callbackArg;
2576
2631
  if (resultData.prevResult.status === "failed") {
2577
- return {
2632
+ callbackArg = {
2578
2633
  status: "failed",
2579
2634
  error: resultData.prevResult.error,
2580
2635
  steps: resultData.stepResults
2581
2636
  };
2582
2637
  } else if (resultData.prevResult.status === "suspended") {
2638
+ callbackArg = {
2639
+ status: "suspended",
2640
+ steps: resultData.stepResults
2641
+ };
2642
+ } else {
2643
+ callbackArg = {
2644
+ status: resultData.prevResult.status,
2645
+ result: resultData.prevResult?.output,
2646
+ steps: resultData.stepResults
2647
+ };
2648
+ }
2649
+ await this.invokeLifecycleCallbacks(callbackArg);
2650
+ let result;
2651
+ if (resultData.prevResult.status === "suspended") {
2583
2652
  const suspendedSteps = Object.entries(resultData.stepResults).map(([_stepId, stepResult]) => {
2584
2653
  if (stepResult.status === "suspended") {
2585
2654
  return stepResult.suspendPayload?.__workflow_meta?.path ?? [];
2586
2655
  }
2587
2656
  return null;
2588
2657
  }).filter(Boolean);
2589
- return {
2590
- status: "suspended",
2591
- steps: resultData.stepResults,
2658
+ result = {
2659
+ ...callbackArg,
2592
2660
  suspended: suspendedSteps
2593
2661
  };
2662
+ } else {
2663
+ result = callbackArg;
2594
2664
  }
2595
- return {
2596
- status: resultData.prevResult.status,
2597
- result: resultData.prevResult?.output,
2598
- steps: resultData.stepResults
2599
- };
2665
+ return result;
2600
2666
  }
2601
2667
  };
2602
2668
 
2603
2669
  export { EventedExecutionEngine, EventedRun, EventedWorkflow, StepExecutor, WorkflowEventProcessor, cloneStep, cloneWorkflow, createStep, createWorkflow };
2604
- //# sourceMappingURL=chunk-US2U7ECW.js.map
2605
- //# sourceMappingURL=chunk-US2U7ECW.js.map
2670
+ //# sourceMappingURL=chunk-BQDZIQ3G.js.map
2671
+ //# sourceMappingURL=chunk-BQDZIQ3G.js.map