@mastra/server 0.0.0-vector-query-tool-provider-options-20250828222356 → 0.0.0-vector-extension-schema-20250922130418

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 (212) hide show
  1. package/CHANGELOG.md +3745 -0
  2. package/README.md +0 -5
  3. package/dist/{chunk-OW4FX5TS.js → chunk-4QCXUEAT.js} +10 -3
  4. package/dist/chunk-4QCXUEAT.js.map +1 -0
  5. package/dist/chunk-4RRMWXQ2.js +3522 -0
  6. package/dist/chunk-4RRMWXQ2.js.map +1 -0
  7. package/dist/{chunk-V5EWBGBF.cjs → chunk-57HWW2TY.cjs} +112 -59
  8. package/dist/chunk-57HWW2TY.cjs.map +1 -0
  9. package/dist/chunk-5DP5XZH6.cjs +928 -0
  10. package/dist/chunk-5DP5XZH6.cjs.map +1 -0
  11. package/dist/chunk-66YYHFGF.js +761 -0
  12. package/dist/chunk-66YYHFGF.js.map +1 -0
  13. package/dist/chunk-6GMFZ5LK.js +2774 -0
  14. package/dist/chunk-6GMFZ5LK.js.map +1 -0
  15. package/dist/chunk-743UIDHI.cjs +2013 -0
  16. package/dist/chunk-743UIDHI.cjs.map +1 -0
  17. package/dist/chunk-7JYXPDM4.js +15712 -0
  18. package/dist/chunk-7JYXPDM4.js.map +1 -0
  19. package/dist/{chunk-ROA7BCHD.js → chunk-A3AL7EWJ.js} +3 -3
  20. package/dist/{chunk-ROA7BCHD.js.map → chunk-A3AL7EWJ.js.map} +1 -1
  21. package/dist/chunk-AK2FXLLB.cjs +849 -0
  22. package/dist/chunk-AK2FXLLB.cjs.map +1 -0
  23. package/dist/{chunk-3THIIWWW.cjs → chunk-AVEPEUN4.cjs} +4 -3
  24. package/dist/chunk-AVEPEUN4.cjs.map +1 -0
  25. package/dist/chunk-CNU4A2XU.js +129 -0
  26. package/dist/chunk-CNU4A2XU.js.map +1 -0
  27. package/dist/chunk-EMNGA4R4.js +845 -0
  28. package/dist/chunk-EMNGA4R4.js.map +1 -0
  29. package/dist/chunk-FALVL2VV.cjs +3525 -0
  30. package/dist/chunk-FALVL2VV.cjs.map +1 -0
  31. package/dist/chunk-FQNT7PI4.js +937 -0
  32. package/dist/chunk-FQNT7PI4.js.map +1 -0
  33. package/dist/{chunk-4QSNRCOT.cjs → chunk-G4PUALCE.cjs} +10 -2
  34. package/dist/chunk-G4PUALCE.cjs.map +1 -0
  35. package/dist/{chunk-ID37OH5Z.js → chunk-G662L2YZ.js} +110 -59
  36. package/dist/chunk-G662L2YZ.js.map +1 -0
  37. package/dist/chunk-GDWMF6SB.cjs +133 -0
  38. package/dist/chunk-GDWMF6SB.cjs.map +1 -0
  39. package/dist/chunk-HJQKWRKQ.cjs +764 -0
  40. package/dist/chunk-HJQKWRKQ.cjs.map +1 -0
  41. package/dist/chunk-HVBBFCDH.cjs +2321 -0
  42. package/dist/chunk-HVBBFCDH.cjs.map +1 -0
  43. package/dist/chunk-HZJRQ5L3.cjs +1411 -0
  44. package/dist/chunk-HZJRQ5L3.cjs.map +1 -0
  45. package/dist/chunk-IGFMAZZ5.cjs +1150 -0
  46. package/dist/chunk-IGFMAZZ5.cjs.map +1 -0
  47. package/dist/chunk-ILESGJ6N.js +524 -0
  48. package/dist/chunk-ILESGJ6N.js.map +1 -0
  49. package/dist/chunk-IOQGI4ML.js +931 -0
  50. package/dist/chunk-IOQGI4ML.js.map +1 -0
  51. package/dist/{chunk-A3FNPSBB.cjs → chunk-J7BPKKOG.cjs} +32 -4
  52. package/dist/chunk-J7BPKKOG.cjs.map +1 -0
  53. package/dist/{chunk-QBWF6U7Z.js → chunk-JRDEOHAJ.js} +20 -12
  54. package/dist/chunk-JRDEOHAJ.js.map +1 -0
  55. package/dist/{chunk-PHZHWQZP.js → chunk-KV6VHX4V.js} +21 -4
  56. package/dist/chunk-KV6VHX4V.js.map +1 -0
  57. package/dist/chunk-LYPU75T6.js +1147 -0
  58. package/dist/chunk-LYPU75T6.js.map +1 -0
  59. package/dist/chunk-N35YCWQ5.cjs +540 -0
  60. package/dist/chunk-N35YCWQ5.cjs.map +1 -0
  61. package/dist/chunk-N7F33WAD.js +2290 -0
  62. package/dist/chunk-N7F33WAD.js.map +1 -0
  63. package/dist/chunk-NG5IVLEZ.js +1012 -0
  64. package/dist/chunk-NG5IVLEZ.js.map +1 -0
  65. package/dist/{chunk-KLCYAQBL.cjs → chunk-NLWACBE7.cjs} +21 -13
  66. package/dist/chunk-NLWACBE7.cjs.map +1 -0
  67. package/dist/chunk-OGW6HHVI.js +1408 -0
  68. package/dist/chunk-OGW6HHVI.js.map +1 -0
  69. package/dist/chunk-OJQOYXHU.cjs +15748 -0
  70. package/dist/chunk-OJQOYXHU.cjs.map +1 -0
  71. package/dist/{chunk-UVKXRPMV.cjs → chunk-OZLRIVC4.cjs} +14 -14
  72. package/dist/{chunk-UVKXRPMV.cjs.map → chunk-OZLRIVC4.cjs.map} +1 -1
  73. package/dist/chunk-P7CIEIJ3.js +925 -0
  74. package/dist/chunk-P7CIEIJ3.js.map +1 -0
  75. package/dist/chunk-P7RBMCBE.cjs +934 -0
  76. package/dist/chunk-P7RBMCBE.cjs.map +1 -0
  77. package/dist/chunk-PPYGWINI.cjs +2777 -0
  78. package/dist/chunk-PPYGWINI.cjs.map +1 -0
  79. package/dist/{chunk-5QUKZCEF.js → chunk-PUYSH3IL.js} +4 -3
  80. package/dist/chunk-PUYSH3IL.js.map +1 -0
  81. package/dist/{chunk-B2L53BNJ.cjs → chunk-PWTXZZTR.cjs} +21 -3
  82. package/dist/chunk-PWTXZZTR.cjs.map +1 -0
  83. package/dist/chunk-RCHEPTZZ.js +2006 -0
  84. package/dist/chunk-RCHEPTZZ.js.map +1 -0
  85. package/dist/chunk-SIGXR3JT.cjs +1043 -0
  86. package/dist/chunk-SIGXR3JT.cjs.map +1 -0
  87. package/dist/{chunk-NPE3X7FQ.cjs → chunk-SPLSYTYW.cjs} +5 -5
  88. package/dist/{chunk-NPE3X7FQ.cjs.map → chunk-SPLSYTYW.cjs.map} +1 -1
  89. package/dist/{chunk-LUPY3MQY.js → chunk-SQY4T6EJ.js} +3 -3
  90. package/dist/{chunk-LUPY3MQY.js.map → chunk-SQY4T6EJ.js.map} +1 -1
  91. package/dist/{chunk-BUMPRH7R.js → chunk-SYRRSBGL.js} +31 -4
  92. package/dist/chunk-SYRRSBGL.js.map +1 -0
  93. package/dist/chunk-TVSIG4JE.cjs +940 -0
  94. package/dist/chunk-TVSIG4JE.cjs.map +1 -0
  95. package/dist/dist-26HWEQY6.js +3 -0
  96. package/dist/dist-26HWEQY6.js.map +1 -0
  97. package/dist/dist-3A5DXB37.cjs +20 -0
  98. package/dist/dist-3A5DXB37.cjs.map +1 -0
  99. package/dist/dist-3SJKQJGY.cjs +16 -0
  100. package/dist/dist-3SJKQJGY.cjs.map +1 -0
  101. package/dist/dist-4ZQSPE5K.js +3 -0
  102. package/dist/dist-4ZQSPE5K.js.map +1 -0
  103. package/dist/dist-5W5QNRTD.js +3 -0
  104. package/dist/dist-5W5QNRTD.js.map +1 -0
  105. package/dist/dist-653SRMPL.js +3 -0
  106. package/dist/dist-653SRMPL.js.map +1 -0
  107. package/dist/dist-6U6EFC5C.cjs +16 -0
  108. package/dist/dist-6U6EFC5C.cjs.map +1 -0
  109. package/dist/dist-7IHNNYMF.cjs +16 -0
  110. package/dist/dist-7IHNNYMF.cjs.map +1 -0
  111. package/dist/dist-B5IPRF6W.js +3 -0
  112. package/dist/dist-B5IPRF6W.js.map +1 -0
  113. package/dist/dist-EOMYFT4Y.cjs +16 -0
  114. package/dist/dist-EOMYFT4Y.cjs.map +1 -0
  115. package/dist/dist-EZZMMMNT.cjs +16 -0
  116. package/dist/dist-EZZMMMNT.cjs.map +1 -0
  117. package/dist/dist-F2ET4MNO.cjs +16 -0
  118. package/dist/dist-F2ET4MNO.cjs.map +1 -0
  119. package/dist/dist-H64VX6DE.js +3 -0
  120. package/dist/dist-H64VX6DE.js.map +1 -0
  121. package/dist/dist-HY7RMLJQ.cjs +16 -0
  122. package/dist/dist-HY7RMLJQ.cjs.map +1 -0
  123. package/dist/dist-M6S4P3FJ.js +3 -0
  124. package/dist/dist-M6S4P3FJ.js.map +1 -0
  125. package/dist/dist-NR7QSCQT.js +3 -0
  126. package/dist/dist-NR7QSCQT.js.map +1 -0
  127. package/dist/dist-QLFMCMCX.js +3 -0
  128. package/dist/dist-QLFMCMCX.js.map +1 -0
  129. package/dist/dist-UY46BFRP.js +3 -0
  130. package/dist/dist-UY46BFRP.js.map +1 -0
  131. package/dist/dist-WCQDRTIV.cjs +16 -0
  132. package/dist/dist-WCQDRTIV.cjs.map +1 -0
  133. package/dist/dist-WKYB3LTJ.cjs +16 -0
  134. package/dist/dist-WKYB3LTJ.cjs.map +1 -0
  135. package/dist/index.cjs +4 -0
  136. package/dist/index.cjs.map +1 -1
  137. package/dist/index.js +3 -0
  138. package/dist/index.js.map +1 -1
  139. package/dist/server/handlers/a2a.cjs +7 -7
  140. package/dist/server/handlers/a2a.d.ts.map +1 -1
  141. package/dist/server/handlers/a2a.js +1 -1
  142. package/dist/server/handlers/agent-builder.cjs +68 -0
  143. package/dist/server/handlers/agent-builder.cjs.map +1 -0
  144. package/dist/server/handlers/agent-builder.d.ts +88 -0
  145. package/dist/server/handlers/agent-builder.d.ts.map +1 -0
  146. package/dist/server/handlers/agent-builder.js +3 -0
  147. package/dist/server/handlers/agent-builder.js.map +1 -0
  148. package/dist/server/handlers/agents.cjs +24 -12
  149. package/dist/server/handlers/agents.d.ts +37 -9
  150. package/dist/server/handlers/agents.d.ts.map +1 -1
  151. package/dist/server/handlers/agents.js +1 -1
  152. package/dist/server/handlers/logs.cjs +4 -4
  153. package/dist/server/handlers/logs.js +1 -1
  154. package/dist/server/handlers/memory.cjs +16 -16
  155. package/dist/server/handlers/memory.js +1 -1
  156. package/dist/server/handlers/telemetry.cjs +7 -3
  157. package/dist/server/handlers/telemetry.d.ts +1 -0
  158. package/dist/server/handlers/telemetry.d.ts.map +1 -1
  159. package/dist/server/handlers/telemetry.js +1 -1
  160. package/dist/server/handlers/tools.cjs +9 -5
  161. package/dist/server/handlers/tools.d.ts +4 -0
  162. package/dist/server/handlers/tools.d.ts.map +1 -1
  163. package/dist/server/handlers/tools.js +1 -1
  164. package/dist/server/handlers/utils.cjs +6 -2
  165. package/dist/server/handlers/utils.d.ts +6 -0
  166. package/dist/server/handlers/utils.d.ts.map +1 -1
  167. package/dist/server/handlers/utils.js +1 -1
  168. package/dist/server/handlers/vNextNetwork.cjs +5 -5
  169. package/dist/server/handlers/vNextNetwork.d.ts +77 -10
  170. package/dist/server/handlers/vNextNetwork.d.ts.map +1 -1
  171. package/dist/server/handlers/vNextNetwork.js +1 -1
  172. package/dist/server/handlers/voice.cjs +5 -5
  173. package/dist/server/handlers/voice.d.ts +6 -4
  174. package/dist/server/handlers/voice.d.ts.map +1 -1
  175. package/dist/server/handlers/voice.js +1 -1
  176. package/dist/server/handlers/workflows.cjs +24 -16
  177. package/dist/server/handlers/workflows.d.ts +20 -10
  178. package/dist/server/handlers/workflows.d.ts.map +1 -1
  179. package/dist/server/handlers/workflows.js +1 -1
  180. package/dist/server/handlers.cjs +25 -25
  181. package/dist/server/handlers.d.ts +1 -1
  182. package/dist/server/handlers.d.ts.map +1 -1
  183. package/dist/server/handlers.js +9 -9
  184. package/dist/server/utils.d.ts +41 -0
  185. package/dist/server/utils.d.ts.map +1 -1
  186. package/package.json +20 -9
  187. package/dist/chunk-3THIIWWW.cjs.map +0 -1
  188. package/dist/chunk-4QSNRCOT.cjs.map +0 -1
  189. package/dist/chunk-5QUKZCEF.js.map +0 -1
  190. package/dist/chunk-A3FNPSBB.cjs.map +0 -1
  191. package/dist/chunk-B2L53BNJ.cjs.map +0 -1
  192. package/dist/chunk-B43YAQJR.js +0 -144
  193. package/dist/chunk-B43YAQJR.js.map +0 -1
  194. package/dist/chunk-BUMPRH7R.js.map +0 -1
  195. package/dist/chunk-D32MNBNS.js +0 -17597
  196. package/dist/chunk-D32MNBNS.js.map +0 -1
  197. package/dist/chunk-ID37OH5Z.js.map +0 -1
  198. package/dist/chunk-JGD42NME.cjs +0 -150
  199. package/dist/chunk-JGD42NME.cjs.map +0 -1
  200. package/dist/chunk-JPY7GWFC.cjs +0 -17614
  201. package/dist/chunk-JPY7GWFC.cjs.map +0 -1
  202. package/dist/chunk-KLCYAQBL.cjs.map +0 -1
  203. package/dist/chunk-OW4FX5TS.js.map +0 -1
  204. package/dist/chunk-PHZHWQZP.js.map +0 -1
  205. package/dist/chunk-QBWF6U7Z.js.map +0 -1
  206. package/dist/chunk-V5EWBGBF.cjs.map +0 -1
  207. package/dist/server/handlers/network.cjs +0 -24
  208. package/dist/server/handlers/network.cjs.map +0 -1
  209. package/dist/server/handlers/network.d.ts +0 -50
  210. package/dist/server/handlers/network.d.ts.map +0 -1
  211. package/dist/server/handlers/network.js +0 -3
  212. package/dist/server/handlers/network.js.map +0 -1
@@ -1,11 +1,10 @@
1
1
  'use strict';
2
2
 
3
- var chunkGU4EWMZB_cjs = require('./chunk-GU4EWMZB.cjs');
3
+ var chunkGDWMF6SB_cjs = require('./chunk-GDWMF6SB.cjs');
4
4
  var chunkRE4RPXT2_cjs = require('./chunk-RE4RPXT2.cjs');
5
5
  var chunk7NADHFD2_cjs = require('./chunk-7NADHFD2.cjs');
6
6
  var chunkEMMSS5I5_cjs = require('./chunk-EMMSS5I5.cjs');
7
7
  var web = require('stream/web');
8
- var zodToJson = require('@mastra/core/utils/zod-to-json');
9
8
 
10
9
  // src/server/handlers/workflows.ts
11
10
  var workflows_exports = {};
@@ -17,7 +16,9 @@ chunkEMMSS5I5_cjs.__export(workflows_exports, {
17
16
  getWorkflowRunExecutionResultHandler: () => getWorkflowRunExecutionResultHandler,
18
17
  getWorkflowRunsHandler: () => getWorkflowRunsHandler,
19
18
  getWorkflowsHandler: () => getWorkflowsHandler,
19
+ observeStreamWorkflowHandler: () => observeStreamWorkflowHandler,
20
20
  resumeAsyncWorkflowHandler: () => resumeAsyncWorkflowHandler,
21
+ resumeStreamWorkflowHandler: () => resumeStreamWorkflowHandler,
21
22
  resumeWorkflowHandler: () => resumeWorkflowHandler,
22
23
  sendWorkflowRunEventHandler: () => sendWorkflowRunEventHandler,
23
24
  startAsyncWorkflowHandler: () => startAsyncWorkflowHandler,
@@ -26,53 +27,11 @@ chunkEMMSS5I5_cjs.__export(workflows_exports, {
26
27
  streamWorkflowHandler: () => streamWorkflowHandler,
27
28
  watchWorkflowHandler: () => watchWorkflowHandler
28
29
  });
29
- function getSteps(steps, path) {
30
- return Object.entries(steps).reduce((acc, [key, step]) => {
31
- const fullKey = path ? `${path}.${key}` : key;
32
- acc[fullKey] = {
33
- id: step.id,
34
- description: step.description,
35
- inputSchema: step.inputSchema ? chunkGU4EWMZB_cjs.stringify(zodToJson.zodToJsonSchema(step.inputSchema)) : void 0,
36
- outputSchema: step.outputSchema ? chunkGU4EWMZB_cjs.stringify(zodToJson.zodToJsonSchema(step.outputSchema)) : void 0,
37
- resumeSchema: step.resumeSchema ? chunkGU4EWMZB_cjs.stringify(zodToJson.zodToJsonSchema(step.resumeSchema)) : void 0,
38
- suspendSchema: step.suspendSchema ? chunkGU4EWMZB_cjs.stringify(zodToJson.zodToJsonSchema(step.suspendSchema)) : void 0,
39
- isWorkflow: step.component === "WORKFLOW"
40
- };
41
- if (step.component === "WORKFLOW" && step.steps) {
42
- const nestedSteps = getSteps(step.steps, fullKey) || {};
43
- acc = { ...acc, ...nestedSteps };
44
- }
45
- return acc;
46
- }, {});
47
- }
48
- function getWorkflowInfo(workflow) {
49
- return {
50
- name: workflow.name,
51
- description: workflow.description,
52
- steps: Object.entries(workflow.steps).reduce((acc, [key, step]) => {
53
- acc[key] = {
54
- id: step.id,
55
- description: step.description,
56
- inputSchema: step.inputSchema ? chunkGU4EWMZB_cjs.stringify(zodToJson.zodToJsonSchema(step.inputSchema)) : void 0,
57
- outputSchema: step.outputSchema ? chunkGU4EWMZB_cjs.stringify(zodToJson.zodToJsonSchema(step.outputSchema)) : void 0,
58
- resumeSchema: step.resumeSchema ? chunkGU4EWMZB_cjs.stringify(zodToJson.zodToJsonSchema(step.resumeSchema)) : void 0,
59
- suspendSchema: step.suspendSchema ? chunkGU4EWMZB_cjs.stringify(zodToJson.zodToJsonSchema(step.suspendSchema)) : void 0
60
- };
61
- return acc;
62
- }, {}),
63
- allSteps: getSteps(workflow.steps) || {},
64
- stepGraph: workflow.serializedStepGraph,
65
- inputSchema: workflow.inputSchema ? chunkGU4EWMZB_cjs.stringify(zodToJson.zodToJsonSchema(workflow.inputSchema)) : void 0,
66
- outputSchema: workflow.outputSchema ? chunkGU4EWMZB_cjs.stringify(zodToJson.zodToJsonSchema(workflow.outputSchema)) : void 0
67
- };
68
- }
69
-
70
- // src/server/handlers/workflows.ts
71
30
  async function getWorkflowsHandler({ mastra }) {
72
31
  try {
73
32
  const workflows = mastra.getWorkflows({ serialized: false });
74
33
  const _workflows = Object.entries(workflows).reduce((acc, [key, workflow]) => {
75
- acc[key] = getWorkflowInfo(workflow);
34
+ acc[key] = chunkGDWMF6SB_cjs.getWorkflowInfo(workflow);
76
35
  return acc;
77
36
  }, {});
78
37
  return _workflows;
@@ -86,10 +45,13 @@ async function getWorkflowsFromSystem({ mastra, workflowId }) {
86
45
  throw new chunk7NADHFD2_cjs.HTTPException(400, { message: "Workflow ID is required" });
87
46
  }
88
47
  let workflow;
89
- try {
90
- workflow = mastra.getWorkflow(workflowId);
91
- } catch (error) {
92
- logger.debug("Error getting workflow, searching agents for workflow", error);
48
+ workflow = chunkGDWMF6SB_cjs.WorkflowRegistry.getWorkflow(workflowId);
49
+ if (!workflow) {
50
+ try {
51
+ workflow = mastra.getWorkflow(workflowId);
52
+ } catch (error) {
53
+ logger.debug("Error getting workflow, searching agents for workflow", error);
54
+ }
93
55
  }
94
56
  if (!workflow) {
95
57
  logger.debug("Workflow not found, searching agents for workflow", { workflowId });
@@ -123,7 +85,7 @@ async function getWorkflowByIdHandler({ mastra, workflowId }) {
123
85
  if (!workflow) {
124
86
  throw new chunk7NADHFD2_cjs.HTTPException(404, { message: "Workflow not found" });
125
87
  }
126
- return getWorkflowInfo(workflow);
88
+ return chunkGDWMF6SB_cjs.getWorkflowInfo(workflow);
127
89
  } catch (error) {
128
90
  return chunkRE4RPXT2_cjs.handleError(error, "Error getting workflow");
129
91
  }
@@ -257,7 +219,8 @@ async function startWorkflowRunHandler({
257
219
  async function watchWorkflowHandler({
258
220
  mastra,
259
221
  workflowId,
260
- runId
222
+ runId,
223
+ eventType = "watch"
261
224
  }) {
262
225
  try {
263
226
  if (!workflowId) {
@@ -279,22 +242,27 @@ async function watchWorkflowHandler({
279
242
  let asyncRef = null;
280
243
  const stream = new web.ReadableStream({
281
244
  start(controller) {
282
- unwatch = _run.watch(({ type, payload, eventTimestamp }) => {
245
+ unwatch = _run.watch((event) => {
246
+ const { type, payload, eventTimestamp } = event;
283
247
  controller.enqueue(JSON.stringify({ type, payload, eventTimestamp, runId }));
284
248
  if (asyncRef) {
285
249
  clearImmediate(asyncRef);
286
250
  asyncRef = null;
287
251
  }
288
252
  asyncRef = setImmediate(async () => {
289
- const runDone = payload.workflowState.status !== "running";
253
+ const runDone = eventType === "watch" ? payload.workflowState.status !== "running" : type === "finish";
290
254
  if (runDone) {
291
255
  controller.close();
292
256
  unwatch?.();
293
257
  }
294
258
  });
295
- });
259
+ }, eventType);
296
260
  },
297
261
  cancel() {
262
+ if (asyncRef) {
263
+ clearImmediate(asyncRef);
264
+ asyncRef = null;
265
+ }
298
266
  unwatch?.();
299
267
  }
300
268
  });
@@ -321,22 +289,68 @@ async function streamWorkflowHandler({
321
289
  if (!workflow) {
322
290
  throw new chunk7NADHFD2_cjs.HTTPException(404, { message: "Workflow not found" });
323
291
  }
292
+ const serverCache = mastra.getServerCache();
324
293
  const run = await workflow.createRunAsync({ runId });
325
294
  const result = run.stream({
326
295
  inputData,
327
- runtimeContext
296
+ runtimeContext,
297
+ onChunk: async (chunk) => {
298
+ if (serverCache) {
299
+ const cacheKey = runId;
300
+ await serverCache.listPush(cacheKey, chunk);
301
+ }
302
+ }
328
303
  });
329
304
  return result;
330
305
  } catch (error) {
331
306
  return chunkRE4RPXT2_cjs.handleError(error, "Error executing workflow");
332
307
  }
333
308
  }
309
+ async function observeStreamWorkflowHandler({
310
+ mastra,
311
+ workflowId,
312
+ runId
313
+ }) {
314
+ try {
315
+ if (!workflowId) {
316
+ throw new chunk7NADHFD2_cjs.HTTPException(400, { message: "Workflow ID is required" });
317
+ }
318
+ if (!runId) {
319
+ throw new chunk7NADHFD2_cjs.HTTPException(400, { message: "runId required to observe workflow stream" });
320
+ }
321
+ const { workflow } = await getWorkflowsFromSystem({ mastra, workflowId });
322
+ if (!workflow) {
323
+ throw new chunk7NADHFD2_cjs.HTTPException(404, { message: "Workflow not found" });
324
+ }
325
+ const run = await workflow.getWorkflowRunById(runId);
326
+ if (!run) {
327
+ throw new chunk7NADHFD2_cjs.HTTPException(404, { message: "Workflow run not found" });
328
+ }
329
+ const _run = await workflow.createRunAsync({ runId });
330
+ const serverCache = mastra.getServerCache();
331
+ if (!serverCache) {
332
+ throw new chunk7NADHFD2_cjs.HTTPException(500, { message: "Server cache not found" });
333
+ }
334
+ const transformStream = new web.TransformStream();
335
+ const writer = transformStream.writable.getWriter();
336
+ const cachedRunChunks = await serverCache.listFromTo(runId, 0);
337
+ for (const chunk of cachedRunChunks) {
338
+ await writer.write(chunk);
339
+ }
340
+ writer.releaseLock();
341
+ const result = _run.observeStream();
342
+ return result.stream?.pipeThrough(transformStream);
343
+ } catch (error) {
344
+ return chunkRE4RPXT2_cjs.handleError(error, "Error observing workflow stream");
345
+ }
346
+ }
334
347
  async function streamVNextWorkflowHandler({
335
348
  mastra,
336
349
  runtimeContext,
337
350
  workflowId,
338
351
  runId,
339
- inputData
352
+ inputData,
353
+ closeOnSuspend
340
354
  }) {
341
355
  try {
342
356
  if (!workflowId) {
@@ -352,7 +366,8 @@ async function streamVNextWorkflowHandler({
352
366
  const run = await workflow.createRunAsync({ runId });
353
367
  const result = run.streamVNext({
354
368
  inputData,
355
- runtimeContext
369
+ runtimeContext,
370
+ closeOnSuspend
356
371
  });
357
372
  return result;
358
373
  } catch (error) {
@@ -431,6 +446,42 @@ async function resumeWorkflowHandler({
431
446
  return chunkRE4RPXT2_cjs.handleError(error, "Error resuming workflow");
432
447
  }
433
448
  }
449
+ async function resumeStreamWorkflowHandler({
450
+ mastra,
451
+ workflowId,
452
+ runId,
453
+ body,
454
+ runtimeContext
455
+ }) {
456
+ try {
457
+ if (!workflowId) {
458
+ throw new chunk7NADHFD2_cjs.HTTPException(400, { message: "Workflow ID is required" });
459
+ }
460
+ if (!runId) {
461
+ throw new chunk7NADHFD2_cjs.HTTPException(400, { message: "runId required to resume workflow" });
462
+ }
463
+ if (!body.step) {
464
+ throw new chunk7NADHFD2_cjs.HTTPException(400, { message: "step required to resume workflow" });
465
+ }
466
+ const { workflow } = await getWorkflowsFromSystem({ mastra, workflowId });
467
+ if (!workflow) {
468
+ throw new chunk7NADHFD2_cjs.HTTPException(404, { message: "Workflow not found" });
469
+ }
470
+ const run = await workflow.getWorkflowRunById(runId);
471
+ if (!run) {
472
+ throw new chunk7NADHFD2_cjs.HTTPException(404, { message: "Workflow run not found" });
473
+ }
474
+ const _run = await workflow.createRunAsync({ runId });
475
+ const stream = await _run.resumeStreamVNext({
476
+ step: body.step,
477
+ resumeData: body.resumeData,
478
+ runtimeContext
479
+ });
480
+ return stream;
481
+ } catch (error) {
482
+ return chunkRE4RPXT2_cjs.handleError(error, "Error resuming workflow");
483
+ }
484
+ }
434
485
  async function getWorkflowRunsHandler({
435
486
  mastra,
436
487
  workflowId,
@@ -521,7 +572,9 @@ exports.getWorkflowRunByIdHandler = getWorkflowRunByIdHandler;
521
572
  exports.getWorkflowRunExecutionResultHandler = getWorkflowRunExecutionResultHandler;
522
573
  exports.getWorkflowRunsHandler = getWorkflowRunsHandler;
523
574
  exports.getWorkflowsHandler = getWorkflowsHandler;
575
+ exports.observeStreamWorkflowHandler = observeStreamWorkflowHandler;
524
576
  exports.resumeAsyncWorkflowHandler = resumeAsyncWorkflowHandler;
577
+ exports.resumeStreamWorkflowHandler = resumeStreamWorkflowHandler;
525
578
  exports.resumeWorkflowHandler = resumeWorkflowHandler;
526
579
  exports.sendWorkflowRunEventHandler = sendWorkflowRunEventHandler;
527
580
  exports.startAsyncWorkflowHandler = startAsyncWorkflowHandler;
@@ -530,5 +583,5 @@ exports.streamVNextWorkflowHandler = streamVNextWorkflowHandler;
530
583
  exports.streamWorkflowHandler = streamWorkflowHandler;
531
584
  exports.watchWorkflowHandler = watchWorkflowHandler;
532
585
  exports.workflows_exports = workflows_exports;
533
- //# sourceMappingURL=chunk-V5EWBGBF.cjs.map
534
- //# sourceMappingURL=chunk-V5EWBGBF.cjs.map
586
+ //# sourceMappingURL=chunk-57HWW2TY.cjs.map
587
+ //# sourceMappingURL=chunk-57HWW2TY.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/server/handlers/workflows.ts"],"names":["__export","getWorkflowInfo","handleError","HTTPException","WorkflowRegistry","ReadableStream","TransformStream"],"mappings":"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","file":"chunk-57HWW2TY.cjs","sourcesContent":["import { ReadableStream, TransformStream } from 'node:stream/web';\nimport type { RuntimeContext } from '@mastra/core/di';\nimport type { WorkflowRuns } from '@mastra/core/storage';\nimport type { Workflow, WatchEvent, WorkflowInfo, StreamEvent } from '@mastra/core/workflows';\nimport { HTTPException } from '../http-exception';\nimport type { Context } from '../types';\nimport { getWorkflowInfo, WorkflowRegistry } from '../utils';\nimport { handleError } from './error';\n\nexport interface WorkflowContext extends Context {\n workflowId?: string;\n runId?: string;\n}\n\nexport async function getWorkflowsHandler({ mastra }: WorkflowContext) {\n try {\n const workflows = mastra.getWorkflows({ serialized: false });\n const _workflows = Object.entries(workflows).reduce<Record<string, WorkflowInfo>>((acc, [key, workflow]) => {\n acc[key] = getWorkflowInfo(workflow);\n return acc;\n }, {});\n return _workflows;\n } catch (error) {\n return handleError(error, 'Error getting workflows');\n }\n}\n\nasync function getWorkflowsFromSystem({ mastra, workflowId }: WorkflowContext) {\n const logger = mastra.getLogger();\n\n if (!workflowId) {\n throw new HTTPException(400, { message: 'Workflow ID is required' });\n }\n\n let workflow;\n\n // First check registry for temporary workflows\n workflow = WorkflowRegistry.getWorkflow(workflowId);\n\n if (!workflow) {\n try {\n workflow = mastra.getWorkflow(workflowId);\n } catch (error) {\n logger.debug('Error getting workflow, searching agents for workflow', error);\n }\n }\n\n if (!workflow) {\n logger.debug('Workflow not found, searching agents for workflow', { workflowId });\n const agents = mastra.getAgents();\n\n if (Object.keys(agents || {}).length) {\n for (const [_, agent] of Object.entries(agents)) {\n try {\n const workflows = await agent.getWorkflows();\n\n if (workflows[workflowId]) {\n workflow = workflows[workflowId];\n break;\n }\n break;\n } catch (error) {\n logger.debug('Error getting workflow from agent', error);\n }\n }\n }\n }\n\n if (!workflow) {\n throw new HTTPException(404, { message: 'Workflow not found' });\n }\n\n return { workflow };\n}\n\nexport async function getWorkflowByIdHandler({ mastra, workflowId }: WorkflowContext): Promise<WorkflowInfo> {\n try {\n if (!workflowId) {\n throw new HTTPException(400, { message: 'Workflow ID is required' });\n }\n\n const { workflow } = await getWorkflowsFromSystem({ mastra, workflowId });\n\n if (!workflow) {\n throw new HTTPException(404, { message: 'Workflow not found' });\n }\n\n return getWorkflowInfo(workflow);\n } catch (error) {\n return handleError(error, 'Error getting workflow');\n }\n}\n\nexport async function getWorkflowRunByIdHandler({\n mastra,\n workflowId,\n runId,\n}: Pick<WorkflowContext, 'mastra' | 'workflowId' | 'runId'>): Promise<ReturnType<Workflow['getWorkflowRunById']>> {\n try {\n if (!workflowId) {\n throw new HTTPException(400, { message: 'Workflow ID is required' });\n }\n\n if (!runId) {\n throw new HTTPException(400, { message: 'Run ID is required' });\n }\n\n const { workflow } = await getWorkflowsFromSystem({ mastra, workflowId });\n\n if (!workflow) {\n throw new HTTPException(404, { message: 'Workflow not found' });\n }\n\n const run = await workflow.getWorkflowRunById(runId);\n\n if (!run) {\n throw new HTTPException(404, { message: 'Workflow run not found' });\n }\n\n return run;\n } catch (error) {\n return handleError(error, 'Error getting workflow run');\n }\n}\n\nexport async function getWorkflowRunExecutionResultHandler({\n mastra,\n workflowId,\n runId,\n}: Pick<WorkflowContext, 'mastra' | 'workflowId' | 'runId'>): Promise<WatchEvent['payload']['workflowState']> {\n try {\n if (!workflowId) {\n throw new HTTPException(400, { message: 'Workflow ID is required' });\n }\n\n if (!runId) {\n throw new HTTPException(400, { message: 'Run ID is required' });\n }\n\n const workflow = mastra.getWorkflow(workflowId);\n\n if (!workflow) {\n throw new HTTPException(404, { message: 'Workflow not found' });\n }\n\n const executionResult = await workflow.getWorkflowRunExecutionResult(runId);\n\n if (!executionResult) {\n throw new HTTPException(404, { message: 'Workflow run execution result not found' });\n }\n\n return executionResult;\n } catch (error) {\n return handleError(error, 'Error getting workflow run execution result');\n }\n}\n\nexport async function createWorkflowRunHandler({\n mastra,\n workflowId,\n runId: prevRunId,\n}: Pick<WorkflowContext, 'mastra' | 'workflowId' | 'runId'>) {\n try {\n if (!workflowId) {\n throw new HTTPException(400, { message: 'Workflow ID is required' });\n }\n\n const { workflow } = await getWorkflowsFromSystem({ mastra, workflowId });\n\n if (!workflow) {\n throw new HTTPException(404, { message: 'Workflow not found' });\n }\n\n const run = await workflow.createRunAsync({ runId: prevRunId });\n\n return { runId: run.runId };\n } catch (error) {\n return handleError(error, 'Error creating workflow run');\n }\n}\n\nexport async function startAsyncWorkflowHandler({\n mastra,\n runtimeContext,\n workflowId,\n runId,\n inputData,\n}: Pick<WorkflowContext, 'mastra' | 'workflowId' | 'runId'> & {\n inputData?: unknown;\n runtimeContext?: RuntimeContext;\n}) {\n try {\n if (!workflowId) {\n throw new HTTPException(400, { message: 'Workflow ID is required' });\n }\n\n const { workflow } = await getWorkflowsFromSystem({ mastra, workflowId });\n\n if (!workflow) {\n throw new HTTPException(404, { message: 'Workflow not found' });\n }\n\n const _run = await workflow.createRunAsync({ runId });\n const result = await _run.start({\n inputData,\n runtimeContext,\n });\n return result;\n } catch (error) {\n return handleError(error, 'Error starting async workflow');\n }\n}\n\nexport async function startWorkflowRunHandler({\n mastra,\n runtimeContext,\n workflowId,\n runId,\n inputData,\n}: Pick<WorkflowContext, 'mastra' | 'workflowId' | 'runId'> & {\n inputData?: unknown;\n runtimeContext?: RuntimeContext;\n}) {\n try {\n if (!workflowId) {\n throw new HTTPException(400, { message: 'Workflow ID is required' });\n }\n\n if (!runId) {\n throw new HTTPException(400, { message: 'runId required to start run' });\n }\n\n const { workflow } = await getWorkflowsFromSystem({ mastra, workflowId });\n\n if (!workflow) {\n throw new HTTPException(404, { message: 'Workflow not found' });\n }\n\n const run = await workflow.getWorkflowRunById(runId);\n\n if (!run) {\n throw new HTTPException(404, { message: 'Workflow run not found' });\n }\n\n const _run = await workflow.createRunAsync({ runId });\n void _run.start({\n inputData,\n runtimeContext,\n });\n\n return { message: 'Workflow run started' };\n } catch (e) {\n return handleError(e, 'Error starting workflow run');\n }\n}\n\nexport async function watchWorkflowHandler({\n mastra,\n workflowId,\n runId,\n eventType = 'watch',\n}: Pick<WorkflowContext, 'mastra' | 'workflowId' | 'runId'> & {\n eventType?: 'watch' | 'watch-v2';\n}): Promise<ReadableStream<string>> {\n try {\n if (!workflowId) {\n throw new HTTPException(400, { message: 'Workflow ID is required' });\n }\n\n if (!runId) {\n throw new HTTPException(400, { message: 'runId required to watch workflow' });\n }\n\n const { workflow } = await getWorkflowsFromSystem({ mastra, workflowId });\n\n if (!workflow) {\n throw new HTTPException(404, { message: 'Workflow not found' });\n }\n\n const run = await workflow.getWorkflowRunById(runId);\n\n if (!run) {\n throw new HTTPException(404, { message: 'Workflow run not found' });\n }\n\n const _run = await workflow.createRunAsync({ runId });\n let unwatch: () => void;\n let asyncRef: NodeJS.Immediate | null = null;\n const stream = new ReadableStream<string>({\n start(controller) {\n unwatch = _run.watch((event: any) => {\n const { type, payload, eventTimestamp } = event;\n controller.enqueue(JSON.stringify({ type, payload, eventTimestamp, runId }));\n\n if (asyncRef) {\n clearImmediate(asyncRef);\n asyncRef = null;\n }\n\n // a run is finished if the status is not running\n asyncRef = setImmediate(async () => {\n const runDone = eventType === 'watch' ? payload.workflowState.status !== 'running' : type === 'finish';\n if (runDone) {\n controller.close();\n unwatch?.();\n }\n });\n }, eventType);\n },\n cancel() {\n if (asyncRef) {\n clearImmediate(asyncRef);\n asyncRef = null;\n }\n unwatch?.();\n },\n });\n\n return stream;\n } catch (error) {\n return handleError(error, 'Error watching workflow');\n }\n}\n\nexport async function streamWorkflowHandler({\n mastra,\n runtimeContext,\n workflowId,\n runId,\n inputData,\n}: Pick<WorkflowContext, 'mastra' | 'workflowId' | 'runId'> & {\n inputData?: unknown;\n runtimeContext?: RuntimeContext;\n}) {\n try {\n if (!workflowId) {\n throw new HTTPException(400, { message: 'Workflow ID is required' });\n }\n\n if (!runId) {\n throw new HTTPException(400, { message: 'runId required to resume workflow' });\n }\n\n const { workflow } = await getWorkflowsFromSystem({ mastra, workflowId });\n\n if (!workflow) {\n throw new HTTPException(404, { message: 'Workflow not found' });\n }\n\n const serverCache = mastra.getServerCache();\n\n const run = await workflow.createRunAsync({ runId });\n const result = run.stream({\n inputData,\n runtimeContext,\n onChunk: async chunk => {\n if (serverCache) {\n const cacheKey = runId;\n await serverCache.listPush(cacheKey, chunk);\n }\n },\n });\n\n return result;\n } catch (error) {\n return handleError(error, 'Error executing workflow');\n }\n}\n\nexport async function observeStreamWorkflowHandler({\n mastra,\n workflowId,\n runId,\n}: Pick<WorkflowContext, 'mastra' | 'workflowId' | 'runId'>) {\n try {\n if (!workflowId) {\n throw new HTTPException(400, { message: 'Workflow ID is required' });\n }\n\n if (!runId) {\n throw new HTTPException(400, { message: 'runId required to observe workflow stream' });\n }\n\n const { workflow } = await getWorkflowsFromSystem({ mastra, workflowId });\n\n if (!workflow) {\n throw new HTTPException(404, { message: 'Workflow not found' });\n }\n\n const run = await workflow.getWorkflowRunById(runId);\n\n if (!run) {\n throw new HTTPException(404, { message: 'Workflow run not found' });\n }\n\n const _run = await workflow.createRunAsync({ runId });\n const serverCache = mastra.getServerCache();\n if (!serverCache) {\n throw new HTTPException(500, { message: 'Server cache not found' });\n }\n\n const transformStream = new TransformStream<StreamEvent, StreamEvent>();\n\n const writer = transformStream.writable.getWriter();\n\n const cachedRunChunks = await serverCache.listFromTo(runId, 0);\n\n for (const chunk of cachedRunChunks) {\n await writer.write(chunk as any);\n }\n\n writer.releaseLock();\n\n const result = _run.observeStream();\n return result.stream?.pipeThrough(transformStream);\n } catch (error) {\n return handleError(error, 'Error observing workflow stream');\n }\n}\n\nexport async function streamVNextWorkflowHandler({\n mastra,\n runtimeContext,\n workflowId,\n runId,\n inputData,\n closeOnSuspend,\n}: Pick<WorkflowContext, 'mastra' | 'workflowId' | 'runId'> & {\n inputData?: unknown;\n runtimeContext?: RuntimeContext;\n closeOnSuspend?: boolean;\n}) {\n try {\n if (!workflowId) {\n throw new HTTPException(400, { message: 'Workflow ID is required' });\n }\n\n if (!runId) {\n throw new HTTPException(400, { message: 'runId required to stream workflow' });\n }\n\n const { workflow } = await getWorkflowsFromSystem({ mastra, workflowId });\n\n if (!workflow) {\n throw new HTTPException(404, { message: 'Workflow not found' });\n }\n\n const run = await workflow.createRunAsync({ runId });\n const result = run.streamVNext({\n inputData,\n runtimeContext,\n closeOnSuspend,\n });\n return result;\n } catch (error) {\n return handleError(error, 'Error streaming workflow');\n }\n}\n\nexport async function resumeAsyncWorkflowHandler({\n mastra,\n workflowId,\n runId,\n body,\n runtimeContext,\n}: WorkflowContext & {\n body: { step: string | string[]; resumeData?: unknown };\n runtimeContext?: RuntimeContext;\n}) {\n try {\n if (!workflowId) {\n throw new HTTPException(400, { message: 'Workflow ID is required' });\n }\n\n if (!runId) {\n throw new HTTPException(400, { message: 'runId required to resume workflow' });\n }\n\n if (!body.step) {\n throw new HTTPException(400, { message: 'step required to resume workflow' });\n }\n\n const { workflow } = await getWorkflowsFromSystem({ mastra, workflowId });\n\n if (!workflow) {\n throw new HTTPException(404, { message: 'Workflow not found' });\n }\n\n const run = await workflow.getWorkflowRunById(runId);\n\n if (!run) {\n throw new HTTPException(404, { message: 'Workflow run not found' });\n }\n\n const _run = await workflow.createRunAsync({ runId });\n const result = await _run.resume({\n step: body.step,\n resumeData: body.resumeData,\n runtimeContext,\n });\n\n return result;\n } catch (error) {\n return handleError(error, 'Error resuming workflow step');\n }\n}\n\nexport async function resumeWorkflowHandler({\n mastra,\n workflowId,\n runId,\n body,\n runtimeContext,\n}: WorkflowContext & {\n body: { step: string | string[]; resumeData?: unknown };\n runtimeContext?: RuntimeContext;\n}) {\n try {\n if (!workflowId) {\n throw new HTTPException(400, { message: 'Workflow ID is required' });\n }\n\n if (!runId) {\n throw new HTTPException(400, { message: 'runId required to resume workflow' });\n }\n\n if (!body.step) {\n throw new HTTPException(400, { message: 'step required to resume workflow' });\n }\n\n const { workflow } = await getWorkflowsFromSystem({ mastra, workflowId });\n\n if (!workflow) {\n throw new HTTPException(404, { message: 'Workflow not found' });\n }\n\n const run = await workflow.getWorkflowRunById(runId);\n\n if (!run) {\n throw new HTTPException(404, { message: 'Workflow run not found' });\n }\n\n const _run = await workflow.createRunAsync({ runId });\n\n void _run.resume({\n step: body.step,\n resumeData: body.resumeData,\n runtimeContext,\n });\n\n return { message: 'Workflow run resumed' };\n } catch (error) {\n return handleError(error, 'Error resuming workflow');\n }\n}\n\nexport async function resumeStreamWorkflowHandler({\n mastra,\n workflowId,\n runId,\n body,\n runtimeContext,\n}: WorkflowContext & {\n body: { step: string | string[]; resumeData?: unknown };\n runtimeContext?: RuntimeContext;\n}) {\n try {\n if (!workflowId) {\n throw new HTTPException(400, { message: 'Workflow ID is required' });\n }\n\n if (!runId) {\n throw new HTTPException(400, { message: 'runId required to resume workflow' });\n }\n\n if (!body.step) {\n throw new HTTPException(400, { message: 'step required to resume workflow' });\n }\n\n const { workflow } = await getWorkflowsFromSystem({ mastra, workflowId });\n\n if (!workflow) {\n throw new HTTPException(404, { message: 'Workflow not found' });\n }\n\n const run = await workflow.getWorkflowRunById(runId);\n\n if (!run) {\n throw new HTTPException(404, { message: 'Workflow run not found' });\n }\n\n const _run = await workflow.createRunAsync({ runId });\n\n const stream = await _run.resumeStreamVNext({\n step: body.step,\n resumeData: body.resumeData,\n runtimeContext,\n });\n\n return stream;\n } catch (error) {\n return handleError(error, 'Error resuming workflow');\n }\n}\n\nexport async function getWorkflowRunsHandler({\n mastra,\n workflowId,\n fromDate,\n toDate,\n limit,\n offset,\n resourceId,\n}: WorkflowContext & {\n fromDate?: Date;\n toDate?: Date;\n limit?: number;\n offset?: number;\n resourceId?: string;\n}): Promise<WorkflowRuns> {\n try {\n if (!workflowId) {\n throw new HTTPException(400, { message: 'Workflow ID is required' });\n }\n\n const { workflow } = await getWorkflowsFromSystem({ mastra, workflowId });\n\n if (!workflow) {\n throw new HTTPException(404, { message: 'Workflow not found' });\n }\n\n const workflowRuns = (await workflow.getWorkflowRuns({ fromDate, toDate, limit, offset, resourceId })) || {\n runs: [],\n total: 0,\n };\n return workflowRuns;\n } catch (error) {\n return handleError(error, 'Error getting workflow runs');\n }\n}\n\nexport async function cancelWorkflowRunHandler({\n mastra,\n workflowId,\n runId,\n}: Pick<WorkflowContext, 'mastra' | 'workflowId' | 'runId'>) {\n try {\n if (!workflowId) {\n throw new HTTPException(400, { message: 'Workflow ID is required' });\n }\n\n if (!runId) {\n throw new HTTPException(400, { message: 'runId required to cancel workflow run' });\n }\n\n const { workflow } = await getWorkflowsFromSystem({ mastra, workflowId });\n\n if (!workflow) {\n throw new HTTPException(404, { message: 'Workflow not found' });\n }\n\n const run = await workflow.getWorkflowRunById(runId);\n\n if (!run) {\n throw new HTTPException(404, { message: 'Workflow run not found' });\n }\n\n const _run = await workflow.createRunAsync({ runId });\n\n await _run.cancel();\n\n return { message: 'Workflow run cancelled' };\n } catch (error) {\n return handleError(error, 'Error canceling workflow run');\n }\n}\n\nexport async function sendWorkflowRunEventHandler({\n mastra,\n workflowId,\n runId,\n event,\n data,\n}: Pick<WorkflowContext, 'mastra' | 'workflowId' | 'runId'> & {\n event: string;\n data: unknown;\n}) {\n try {\n if (!workflowId) {\n throw new HTTPException(400, { message: 'Workflow ID is required' });\n }\n\n if (!runId) {\n throw new HTTPException(400, { message: 'runId required to send workflow run event' });\n }\n\n const { workflow } = await getWorkflowsFromSystem({ mastra, workflowId });\n\n if (!workflow) {\n throw new HTTPException(404, { message: 'Workflow not found' });\n }\n\n const run = await workflow.getWorkflowRunById(runId);\n\n if (!run) {\n throw new HTTPException(404, { message: 'Workflow run not found' });\n }\n\n const _run = await workflow.createRunAsync({ runId });\n\n await _run.sendEvent(event, data);\n\n return { message: 'Workflow run event sent' };\n } catch (error) {\n return handleError(error, 'Error sending workflow run event');\n }\n}\n"]}