@mastra/server 0.0.0-switch-to-core-20250424015131 → 0.0.0-vector-query-sources-20250516172905

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 (74) hide show
  1. package/README.md +48 -135
  2. package/dist/_tsup-dts-rollup.d.cts +258 -13
  3. package/dist/_tsup-dts-rollup.d.ts +258 -13
  4. package/dist/{chunk-4JINXASC.js → chunk-55DOQLP6.js} +5 -4
  5. package/dist/{chunk-QN4KF3BH.cjs → chunk-57CJTIPW.cjs} +2 -2
  6. package/dist/chunk-5SN4U5AC.cjs +508 -0
  7. package/dist/{chunk-ZLBRQFDD.cjs → chunk-64U3UDTH.cjs} +2 -2
  8. package/dist/chunk-75ZPJI57.cjs +9 -0
  9. package/dist/{chunk-M56ECCHK.cjs → chunk-BNEY4P4P.cjs} +20 -19
  10. package/dist/{chunk-RE6YL32K.js → chunk-C7564HUT.js} +52 -30
  11. package/dist/chunk-D4IRYCUI.cjs +235 -0
  12. package/dist/{chunk-RBQASTUP.js → chunk-DJJIUEL2.js} +13 -5
  13. package/dist/{chunk-LFOBHRFO.js → chunk-EJO45KYT.js} +35 -20
  14. package/dist/{chunk-L7XE5QTW.js → chunk-H5PTF3Y4.js} +1 -1
  15. package/dist/{chunk-Q6SHQECN.js → chunk-HFWCEP5S.js} +4 -3
  16. package/dist/{chunk-3EJZQ6TQ.js → chunk-HWZVAG3H.js} +3 -3
  17. package/dist/{chunk-TZK63M5N.cjs → chunk-I2B73Y4I.cjs} +76 -61
  18. package/dist/chunk-LIVAK2DM.js +2001 -0
  19. package/dist/{chunk-3AHQ5RGN.js → chunk-M5ABIP7D.js} +1 -1
  20. package/dist/{chunk-7IWQE76Z.cjs → chunk-MHKNLNAN.cjs} +13 -10
  21. package/dist/chunk-MIQYDLLM.js +329 -0
  22. package/dist/chunk-MLKGABMK.js +7 -0
  23. package/dist/{chunk-TRDNDNGQ.js → chunk-NYN7KFXL.js} +1 -7
  24. package/dist/{chunk-FV45V6WC.cjs → chunk-OCWPVYNI.cjs} +0 -7
  25. package/dist/{chunk-SKBVVI24.cjs → chunk-OGCNNUHF.cjs} +9 -9
  26. package/dist/{chunk-WTHDCRMY.js → chunk-OR3CIE2H.js} +7 -4
  27. package/dist/chunk-P6SCPDYW.js +500 -0
  28. package/dist/{chunk-5JNVY6DU.js → chunk-TJKLBTFB.js} +20 -8
  29. package/dist/chunk-UCTEMO2Q.cjs +341 -0
  30. package/dist/{chunk-FPIWDH5Y.cjs → chunk-VPNDC2DI.cjs} +62 -40
  31. package/dist/chunk-WUC6LSTW.js +227 -0
  32. package/dist/{chunk-2FJURXCL.cjs → chunk-Y7UWRW5X.cjs} +43 -35
  33. package/dist/{chunk-55HTWX4C.cjs → chunk-YBVOQN4M.cjs} +20 -19
  34. package/dist/chunk-YWLUOY3D.cjs +2004 -0
  35. package/dist/{chunk-D3G23FP3.cjs → chunk-ZE5AAC4I.cjs} +37 -25
  36. package/dist/server/handlers/a2a.cjs +30 -0
  37. package/dist/server/handlers/a2a.d.cts +6 -0
  38. package/dist/server/handlers/a2a.d.ts +6 -0
  39. package/dist/server/handlers/a2a.js +1 -0
  40. package/dist/server/handlers/agents.cjs +7 -7
  41. package/dist/server/handlers/agents.js +1 -1
  42. package/dist/server/handlers/error.cjs +2 -2
  43. package/dist/server/handlers/error.js +1 -1
  44. package/dist/server/handlers/logs.cjs +4 -4
  45. package/dist/server/handlers/logs.js +1 -1
  46. package/dist/server/handlers/memory.cjs +9 -9
  47. package/dist/server/handlers/memory.js +1 -1
  48. package/dist/server/handlers/network.cjs +5 -5
  49. package/dist/server/handlers/network.js +1 -1
  50. package/dist/server/handlers/telemetry.cjs +3 -3
  51. package/dist/server/handlers/telemetry.js +1 -1
  52. package/dist/server/handlers/tools.cjs +5 -5
  53. package/dist/server/handlers/tools.js +1 -1
  54. package/dist/server/handlers/utils.cjs +2 -2
  55. package/dist/server/handlers/utils.js +1 -1
  56. package/dist/server/handlers/vNextWorkflows.cjs +46 -0
  57. package/dist/server/handlers/vNextWorkflows.d.cts +10 -0
  58. package/dist/server/handlers/vNextWorkflows.d.ts +10 -0
  59. package/dist/server/handlers/vNextWorkflows.js +1 -0
  60. package/dist/server/handlers/vector.cjs +7 -7
  61. package/dist/server/handlers/vector.js +1 -1
  62. package/dist/server/handlers/voice.cjs +4 -4
  63. package/dist/server/handlers/voice.js +1 -1
  64. package/dist/server/handlers/workflows.cjs +11 -11
  65. package/dist/server/handlers/workflows.js +1 -1
  66. package/dist/server/handlers.cjs +31 -21
  67. package/dist/server/handlers.d.cts +2 -0
  68. package/dist/server/handlers.d.ts +2 -0
  69. package/dist/server/handlers.js +11 -9
  70. package/package.json +8 -6
  71. package/dist/chunk-5SWCVTNL.cjs +0 -5579
  72. package/dist/chunk-HCOPJZ4A.cjs +0 -164
  73. package/dist/chunk-OMN3UI6X.js +0 -5576
  74. package/dist/chunk-R4J7XQYU.js +0 -156
@@ -1,6 +1,7 @@
1
- import { validateBody } from './chunk-L7XE5QTW.js';
2
- import { handleError } from './chunk-3AHQ5RGN.js';
3
- import { __export, HTTPException } from './chunk-TRDNDNGQ.js';
1
+ import { validateBody } from './chunk-H5PTF3Y4.js';
2
+ import { handleError } from './chunk-M5ABIP7D.js';
3
+ import { HTTPException } from './chunk-NYN7KFXL.js';
4
+ import { __export } from './chunk-MLKGABMK.js';
4
5
 
5
6
  // src/server/handlers/network.ts
6
7
  var network_exports = {};
@@ -10,33 +11,48 @@ __export(network_exports, {
10
11
  getNetworksHandler: () => getNetworksHandler,
11
12
  streamGenerateHandler: () => streamGenerateHandler
12
13
  });
13
- async function getNetworksHandler({ mastra }) {
14
+ async function getNetworksHandler({
15
+ mastra,
16
+ runtimeContext
17
+ }) {
14
18
  try {
15
19
  const networks = mastra.getNetworks();
16
- const serializedNetworks = networks.map((network) => {
17
- const routingAgent = network.getRoutingAgent();
18
- const agents = network.getAgents();
19
- return {
20
- id: network.formatAgentId(routingAgent.name),
21
- name: routingAgent.name,
22
- instructions: routingAgent.instructions,
23
- agents: agents.map((agent) => ({
24
- name: agent.name,
25
- provider: agent.llm?.getProvider(),
26
- modelId: agent.llm?.getModelId()
27
- })),
28
- routingModel: {
29
- provider: routingAgent.llm?.getProvider(),
30
- modelId: routingAgent.llm?.getModelId()
31
- }
32
- };
33
- });
20
+ const serializedNetworks = await Promise.all(
21
+ networks.map(async (network) => {
22
+ const routingAgent = network.getRoutingAgent();
23
+ const routingLLM = await routingAgent.getLLM({ runtimeContext });
24
+ const agents = network.getAgents();
25
+ return {
26
+ id: network.formatAgentId(routingAgent.name),
27
+ name: routingAgent.name,
28
+ instructions: routingAgent.instructions,
29
+ agents: await Promise.all(
30
+ agents.map(async (agent) => {
31
+ const llm = await agent.getLLM({ runtimeContext });
32
+ return {
33
+ name: agent.name,
34
+ provider: llm?.getProvider(),
35
+ modelId: llm?.getModelId()
36
+ };
37
+ })
38
+ ),
39
+ routingModel: {
40
+ provider: routingLLM?.getProvider(),
41
+ modelId: routingLLM?.getModelId()
42
+ }
43
+ };
44
+ })
45
+ );
34
46
  return serializedNetworks;
35
47
  } catch (error) {
36
48
  return handleError(error, "Error getting networks");
37
49
  }
38
50
  }
39
- async function getNetworkByIdHandler({ mastra, networkId }) {
51
+ async function getNetworkByIdHandler({
52
+ mastra,
53
+ networkId,
54
+ runtimeContext
55
+ }) {
40
56
  try {
41
57
  const networks = mastra.getNetworks();
42
58
  const network = networks.find((network2) => {
@@ -47,19 +63,25 @@ async function getNetworkByIdHandler({ mastra, networkId }) {
47
63
  throw new HTTPException(404, { message: "Network not found" });
48
64
  }
49
65
  const routingAgent = network.getRoutingAgent();
66
+ const routingLLM = await routingAgent.getLLM({ runtimeContext });
50
67
  const agents = network.getAgents();
51
68
  const serializedNetwork = {
52
69
  id: network.formatAgentId(routingAgent.name),
53
70
  name: routingAgent.name,
54
71
  instructions: routingAgent.instructions,
55
- agents: agents.map((agent) => ({
56
- name: agent.name,
57
- provider: agent.llm?.getProvider(),
58
- modelId: agent.llm?.getModelId()
59
- })),
72
+ agents: await Promise.all(
73
+ agents.map(async (agent) => {
74
+ const llm = await agent.getLLM({ runtimeContext });
75
+ return {
76
+ name: agent.name,
77
+ provider: llm?.getProvider(),
78
+ modelId: llm?.getModelId()
79
+ };
80
+ })
81
+ ),
60
82
  routingModel: {
61
- provider: routingAgent.llm?.getProvider(),
62
- modelId: routingAgent.llm?.getModelId()
83
+ provider: routingLLM?.getProvider(),
84
+ modelId: routingLLM?.getModelId()
63
85
  }
64
86
  };
65
87
  return serializedNetwork;
@@ -0,0 +1,235 @@
1
+ 'use strict';
2
+
3
+ var chunkYWLUOY3D_cjs = require('./chunk-YWLUOY3D.cjs');
4
+ var chunk57CJTIPW_cjs = require('./chunk-57CJTIPW.cjs');
5
+ var chunk64U3UDTH_cjs = require('./chunk-64U3UDTH.cjs');
6
+ var chunkOCWPVYNI_cjs = require('./chunk-OCWPVYNI.cjs');
7
+ var chunk75ZPJI57_cjs = require('./chunk-75ZPJI57.cjs');
8
+ var runtimeContext = require('@mastra/core/runtime-context');
9
+
10
+ // src/server/handlers/agents.ts
11
+ var agents_exports = {};
12
+ chunk75ZPJI57_cjs.__export(agents_exports, {
13
+ generateHandler: () => generateHandler,
14
+ getAgentByIdHandler: () => getAgentByIdHandler,
15
+ getAgentsHandler: () => getAgentsHandler,
16
+ getEvalsByAgentIdHandler: () => getEvalsByAgentIdHandler,
17
+ getLiveEvalsByAgentIdHandler: () => getLiveEvalsByAgentIdHandler,
18
+ streamGenerateHandler: () => streamGenerateHandler
19
+ });
20
+ async function getAgentsHandler({ mastra, runtimeContext }) {
21
+ try {
22
+ const agents = mastra.getAgents();
23
+ const serializedAgentsMap = await Promise.all(
24
+ Object.entries(agents).map(async ([id, agent]) => {
25
+ const instructions = await agent.getInstructions({ runtimeContext });
26
+ const tools = await agent.getTools({ runtimeContext });
27
+ const llm = await agent.getLLM({ runtimeContext });
28
+ const serializedAgentTools = Object.entries(tools || {}).reduce((acc, [key, tool]) => {
29
+ const _tool = tool;
30
+ acc[key] = {
31
+ ..._tool,
32
+ inputSchema: _tool.inputSchema ? chunkYWLUOY3D_cjs.stringify(chunkYWLUOY3D_cjs.esm_default(_tool.inputSchema)) : void 0,
33
+ outputSchema: _tool.outputSchema ? chunkYWLUOY3D_cjs.stringify(chunkYWLUOY3D_cjs.esm_default(_tool.outputSchema)) : void 0
34
+ };
35
+ return acc;
36
+ }, {});
37
+ let serializedAgentWorkflows = {};
38
+ if ("getWorkflows" in agent) {
39
+ const logger = mastra.getLogger();
40
+ try {
41
+ const workflows = await agent.getWorkflows({ runtimeContext });
42
+ serializedAgentWorkflows = Object.entries(workflows || {}).reduce((acc, [key, workflow]) => {
43
+ return {
44
+ ...acc,
45
+ [key]: {
46
+ name: workflow.name
47
+ }
48
+ };
49
+ }, {});
50
+ } catch (error) {
51
+ logger.error("Error getting workflows for agent", { agentName: agent.name, error });
52
+ }
53
+ }
54
+ return {
55
+ id,
56
+ name: agent.name,
57
+ instructions,
58
+ tools: serializedAgentTools,
59
+ workflows: serializedAgentWorkflows,
60
+ provider: llm?.getProvider(),
61
+ modelId: llm?.getModelId()
62
+ };
63
+ })
64
+ );
65
+ const serializedAgents = serializedAgentsMap.reduce((acc, { id, ...rest }) => {
66
+ acc[id] = rest;
67
+ return acc;
68
+ }, {});
69
+ return serializedAgents;
70
+ } catch (error) {
71
+ return chunk64U3UDTH_cjs.handleError(error, "Error getting agents");
72
+ }
73
+ }
74
+ async function getAgentByIdHandler({
75
+ mastra,
76
+ runtimeContext,
77
+ agentId
78
+ }) {
79
+ try {
80
+ const agent = mastra.getAgent(agentId);
81
+ if (!agent) {
82
+ throw new chunkOCWPVYNI_cjs.HTTPException(404, { message: "Agent not found" });
83
+ }
84
+ const tools = await agent.getTools({ runtimeContext });
85
+ const serializedAgentTools = Object.entries(tools || {}).reduce((acc, [key, tool]) => {
86
+ const _tool = tool;
87
+ acc[key] = {
88
+ ..._tool,
89
+ inputSchema: _tool.inputSchema ? chunkYWLUOY3D_cjs.stringify(chunkYWLUOY3D_cjs.esm_default(_tool.inputSchema)) : void 0,
90
+ outputSchema: _tool.outputSchema ? chunkYWLUOY3D_cjs.stringify(chunkYWLUOY3D_cjs.esm_default(_tool.outputSchema)) : void 0
91
+ };
92
+ return acc;
93
+ }, {});
94
+ let serializedAgentWorkflows = {};
95
+ if ("getWorkflows" in agent) {
96
+ const logger = mastra.getLogger();
97
+ try {
98
+ const workflows = await agent.getWorkflows({ runtimeContext });
99
+ serializedAgentWorkflows = Object.entries(workflows || {}).reduce((acc, [key, workflow]) => {
100
+ return {
101
+ ...acc,
102
+ [key]: {
103
+ name: workflow.name
104
+ }
105
+ };
106
+ }, {});
107
+ } catch (error) {
108
+ logger.error("Error getting workflows for agent", { agentName: agent.name, error });
109
+ }
110
+ }
111
+ const instructions = await agent.getInstructions({ runtimeContext });
112
+ const llm = await agent.getLLM({ runtimeContext });
113
+ return {
114
+ name: agent.name,
115
+ instructions,
116
+ tools: serializedAgentTools,
117
+ workflows: serializedAgentWorkflows,
118
+ provider: llm?.getProvider(),
119
+ modelId: llm?.getModelId()
120
+ };
121
+ } catch (error) {
122
+ return chunk64U3UDTH_cjs.handleError(error, "Error getting agent");
123
+ }
124
+ }
125
+ async function getEvalsByAgentIdHandler({
126
+ mastra,
127
+ runtimeContext,
128
+ agentId
129
+ }) {
130
+ try {
131
+ const agent = mastra.getAgent(agentId);
132
+ const evals = await mastra.getStorage()?.getEvalsByAgentName?.(agent.name, "test") || [];
133
+ const instructions = await agent.getInstructions({ runtimeContext });
134
+ return {
135
+ id: agentId,
136
+ name: agent.name,
137
+ instructions,
138
+ evals
139
+ };
140
+ } catch (error) {
141
+ return chunk64U3UDTH_cjs.handleError(error, "Error getting test evals");
142
+ }
143
+ }
144
+ async function getLiveEvalsByAgentIdHandler({
145
+ mastra,
146
+ runtimeContext,
147
+ agentId
148
+ }) {
149
+ try {
150
+ const agent = mastra.getAgent(agentId);
151
+ const evals = await mastra.getStorage()?.getEvalsByAgentName?.(agent.name, "live") || [];
152
+ const instructions = await agent.getInstructions({ runtimeContext });
153
+ return {
154
+ id: agentId,
155
+ name: agent.name,
156
+ instructions,
157
+ evals
158
+ };
159
+ } catch (error) {
160
+ return chunk64U3UDTH_cjs.handleError(error, "Error getting live evals");
161
+ }
162
+ }
163
+ async function generateHandler({
164
+ mastra,
165
+ runtimeContext: runtimeContext$1,
166
+ agentId,
167
+ body
168
+ }) {
169
+ try {
170
+ const agent = mastra.getAgent(agentId);
171
+ if (!agent) {
172
+ throw new chunkOCWPVYNI_cjs.HTTPException(404, { message: "Agent not found" });
173
+ }
174
+ const { messages, resourceId, resourceid, runtimeContext: agentRuntimeContext, ...rest } = body;
175
+ const finalResourceId = resourceId ?? resourceid;
176
+ const finalRuntimeContext = new runtimeContext.RuntimeContext([
177
+ ...Array.from(runtimeContext$1.entries()),
178
+ ...Array.from(Object.entries(agentRuntimeContext ?? {}))
179
+ ]);
180
+ chunk57CJTIPW_cjs.validateBody({ messages });
181
+ const result = await agent.generate(messages, {
182
+ ...rest,
183
+ // @ts-expect-error TODO fix types
184
+ resourceId: finalResourceId,
185
+ runtimeContext: finalRuntimeContext
186
+ });
187
+ return result;
188
+ } catch (error) {
189
+ return chunk64U3UDTH_cjs.handleError(error, "Error generating from agent");
190
+ }
191
+ }
192
+ async function streamGenerateHandler({
193
+ mastra,
194
+ runtimeContext: runtimeContext$1,
195
+ agentId,
196
+ body
197
+ }) {
198
+ try {
199
+ const agent = mastra.getAgent(agentId);
200
+ if (!agent) {
201
+ throw new chunkOCWPVYNI_cjs.HTTPException(404, { message: "Agent not found" });
202
+ }
203
+ const { messages, resourceId, resourceid, runtimeContext: agentRuntimeContext, ...rest } = body;
204
+ const finalResourceId = resourceId ?? resourceid;
205
+ const finalRuntimeContext = new runtimeContext.RuntimeContext([
206
+ ...Array.from(runtimeContext$1.entries()),
207
+ ...Array.from(Object.entries(agentRuntimeContext ?? {}))
208
+ ]);
209
+ chunk57CJTIPW_cjs.validateBody({ messages });
210
+ const streamResult = await agent.stream(messages, {
211
+ ...rest,
212
+ // @ts-expect-error TODO fix types
213
+ resourceId: finalResourceId,
214
+ runtimeContext: finalRuntimeContext
215
+ });
216
+ const streamResponse = rest.output ? streamResult.toTextStreamResponse() : streamResult.toDataStreamResponse({
217
+ sendUsage: true,
218
+ sendReasoning: true,
219
+ getErrorMessage: (error) => {
220
+ return `An error occurred while processing your request. ${error instanceof Error ? error.message : JSON.stringify(error)}`;
221
+ }
222
+ });
223
+ return streamResponse;
224
+ } catch (error) {
225
+ throw new chunkOCWPVYNI_cjs.HTTPException(error?.status ?? 500, { message: error?.message ?? "Error streaming from agent" });
226
+ }
227
+ }
228
+
229
+ exports.agents_exports = agents_exports;
230
+ exports.generateHandler = generateHandler;
231
+ exports.getAgentByIdHandler = getAgentByIdHandler;
232
+ exports.getAgentsHandler = getAgentsHandler;
233
+ exports.getEvalsByAgentIdHandler = getEvalsByAgentIdHandler;
234
+ exports.getLiveEvalsByAgentIdHandler = getLiveEvalsByAgentIdHandler;
235
+ exports.streamGenerateHandler = streamGenerateHandler;
@@ -1,6 +1,7 @@
1
- import { validateBody } from './chunk-L7XE5QTW.js';
2
- import { handleError } from './chunk-3AHQ5RGN.js';
3
- import { __export, HTTPException } from './chunk-TRDNDNGQ.js';
1
+ import { validateBody } from './chunk-H5PTF3Y4.js';
2
+ import { handleError } from './chunk-M5ABIP7D.js';
3
+ import { HTTPException } from './chunk-NYN7KFXL.js';
4
+ import { __export } from './chunk-MLKGABMK.js';
4
5
 
5
6
  // src/server/handlers/memory.ts
6
7
  var memory_exports = {};
@@ -181,8 +182,12 @@ async function deleteThreadHandler({
181
182
  async function getMessagesHandler({
182
183
  mastra,
183
184
  agentId,
184
- threadId
185
+ threadId,
186
+ limit
185
187
  }) {
188
+ if (limit !== void 0 && (!Number.isInteger(limit) || limit <= 0)) {
189
+ throw new HTTPException(400, { message: "Invalid limit: must be a positive integer" });
190
+ }
186
191
  try {
187
192
  validateBody({ threadId });
188
193
  const memory = getMemoryFromContext({ mastra, agentId });
@@ -193,7 +198,10 @@ async function getMessagesHandler({
193
198
  if (!thread) {
194
199
  throw new HTTPException(404, { message: "Thread not found" });
195
200
  }
196
- const result = await memory.query({ threadId });
201
+ const result = await memory.query({
202
+ threadId,
203
+ ...limit && { selectBy: { last: limit } }
204
+ });
197
205
  return result;
198
206
  } catch (error) {
199
207
  return handleError(error, "Error getting messages");
@@ -1,6 +1,7 @@
1
- import { stringify, esm_default } from './chunk-OMN3UI6X.js';
2
- import { handleError } from './chunk-3AHQ5RGN.js';
3
- import { __export, HTTPException } from './chunk-TRDNDNGQ.js';
1
+ import { stringify, esm_default } from './chunk-LIVAK2DM.js';
2
+ import { handleError } from './chunk-M5ABIP7D.js';
3
+ import { HTTPException } from './chunk-NYN7KFXL.js';
4
+ import { __export } from './chunk-MLKGABMK.js';
4
5
  import { ReadableStream } from 'node:stream/web';
5
6
 
6
7
  // src/server/handlers/workflows.ts
@@ -32,7 +33,9 @@ async function getWorkflowsHandler({ mastra }) {
32
33
  steps: Object.entries(workflow.steps).reduce((acc2, [key2, step]) => {
33
34
  const _step = step;
34
35
  acc2[key2] = {
35
- ..._step,
36
+ id: _step.id,
37
+ description: _step.description,
38
+ workflowId: _step.workflowId,
36
39
  inputSchema: _step.inputSchema ? stringify(esm_default(_step.inputSchema)) : void 0,
37
40
  outputSchema: _step.outputSchema ? stringify(esm_default(_step.outputSchema)) : void 0
38
41
  };
@@ -65,7 +68,9 @@ async function getWorkflowByIdHandler({ mastra, workflowId }) {
65
68
  steps: Object.entries(workflow.steps).reduce((acc, [key, step]) => {
66
69
  const _step = step;
67
70
  acc[key] = {
68
- ..._step,
71
+ id: _step.id,
72
+ description: _step.description,
73
+ workflowId: _step.workflowId,
69
74
  inputSchema: _step.inputSchema ? stringify(esm_default(_step.inputSchema)) : void 0,
70
75
  outputSchema: _step.outputSchema ? stringify(esm_default(_step.outputSchema)) : void 0
71
76
  };
@@ -92,14 +97,14 @@ async function startAsyncWorkflowHandler({
92
97
  throw new HTTPException(404, { message: "Workflow not found" });
93
98
  }
94
99
  if (!runId) {
95
- const { start } = workflow.createRun();
96
- const result2 = await start({
100
+ const newRun = workflow.createRun();
101
+ const result2 = await newRun.start({
97
102
  triggerData,
98
103
  runtimeContext
99
104
  });
100
105
  return result2;
101
106
  }
102
- const run = workflow.getRun(runId);
107
+ const run = workflow.getMemoryRun(runId);
103
108
  if (!run) {
104
109
  throw new HTTPException(404, { message: "Workflow run not found" });
105
110
  }
@@ -128,7 +133,7 @@ async function getWorkflowRunHandler({
128
133
  if (!workflow) {
129
134
  throw new HTTPException(404, { message: "Workflow not found" });
130
135
  }
131
- const run = workflow.getRun(runId);
136
+ const run = await workflow.getRun(runId);
132
137
  if (!run) {
133
138
  throw new HTTPException(404, { message: "Workflow run not found" });
134
139
  }
@@ -150,8 +155,8 @@ async function createRunHandler({
150
155
  if (!workflow) {
151
156
  throw new HTTPException(404, { message: "Workflow not found" });
152
157
  }
153
- const { runId } = workflow.createRun({ runId: prevRunId });
154
- return { runId };
158
+ const newRun = workflow.createRun({ runId: prevRunId });
159
+ return { runId: newRun.runId };
155
160
  } catch (error) {
156
161
  throw new HTTPException(500, { message: error?.message || "Error creating workflow run" });
157
162
  }
@@ -171,11 +176,11 @@ async function startWorkflowRunHandler({
171
176
  throw new HTTPException(400, { message: "runId required to start run" });
172
177
  }
173
178
  const workflow = mastra.getWorkflow(workflowId);
174
- const run = workflow.getRun(runId);
179
+ const run = workflow.getMemoryRun(runId);
175
180
  if (!run) {
176
181
  throw new HTTPException(404, { message: "Workflow run not found" });
177
182
  }
178
- await run.start({
183
+ void run.start({
179
184
  triggerData,
180
185
  runtimeContext
181
186
  });
@@ -197,7 +202,7 @@ async function watchWorkflowHandler({
197
202
  throw new HTTPException(400, { message: "runId required to watch workflow" });
198
203
  }
199
204
  const workflow = mastra.getWorkflow(workflowId);
200
- const run = workflow.getRun(runId);
205
+ const run = workflow.getMemoryRun(runId);
201
206
  if (!run) {
202
207
  throw new HTTPException(404, { message: "Workflow run not found" });
203
208
  }
@@ -213,8 +218,10 @@ async function watchWorkflowHandler({
213
218
  asyncRef = null;
214
219
  }
215
220
  asyncRef = setImmediate(() => {
216
- if (!workflow.getRun(runId2)) {
221
+ const runDone = Object.values(activePathsObj).every((value) => value.status !== "executing");
222
+ if (runDone) {
217
223
  controller.close();
224
+ unwatch?.();
218
225
  }
219
226
  });
220
227
  });
@@ -243,7 +250,7 @@ async function resumeAsyncWorkflowHandler({
243
250
  throw new HTTPException(400, { message: "runId required to resume workflow" });
244
251
  }
245
252
  const workflow = mastra.getWorkflow(workflowId);
246
- const run = workflow.getRun(runId);
253
+ const run = workflow.getMemoryRun(runId);
247
254
  if (!run) {
248
255
  throw new HTTPException(404, { message: "Workflow run not found" });
249
256
  }
@@ -272,11 +279,11 @@ async function resumeWorkflowHandler({
272
279
  throw new HTTPException(400, { message: "runId required to resume workflow" });
273
280
  }
274
281
  const workflow = mastra.getWorkflow(workflowId);
275
- const run = workflow.getRun(runId);
282
+ const run = workflow.getMemoryRun(runId);
276
283
  if (!run) {
277
284
  throw new HTTPException(404, { message: "Workflow run not found" });
278
285
  }
279
- await run.resume({
286
+ void run.resume({
280
287
  stepId: body.stepId,
281
288
  context: body.context,
282
289
  runtimeContext
@@ -286,13 +293,21 @@ async function resumeWorkflowHandler({
286
293
  return handleError(error, "Error resuming workflow");
287
294
  }
288
295
  }
289
- async function getWorkflowRunsHandler({ mastra, workflowId }) {
296
+ async function getWorkflowRunsHandler({
297
+ mastra,
298
+ workflowId,
299
+ fromDate,
300
+ toDate,
301
+ limit,
302
+ offset,
303
+ resourceId
304
+ }) {
290
305
  try {
291
306
  if (!workflowId) {
292
307
  throw new HTTPException(400, { message: "Workflow ID is required" });
293
308
  }
294
309
  const workflow = mastra.getWorkflow(workflowId);
295
- const workflowRuns = await workflow.getWorkflowRuns() || {
310
+ const workflowRuns = await workflow.getWorkflowRuns({ fromDate, toDate, limit, offset, resourceId }) || {
296
311
  runs: [],
297
312
  total: 0
298
313
  };
@@ -1,4 +1,4 @@
1
- import { HTTPException } from './chunk-TRDNDNGQ.js';
1
+ import { HTTPException } from './chunk-NYN7KFXL.js';
2
2
 
3
3
  // src/server/handlers/utils.ts
4
4
  function validateBody(body) {
@@ -1,6 +1,7 @@
1
- import { validateBody } from './chunk-L7XE5QTW.js';
2
- import { handleError } from './chunk-3AHQ5RGN.js';
3
- import { __export, HTTPException } from './chunk-TRDNDNGQ.js';
1
+ import { validateBody } from './chunk-H5PTF3Y4.js';
2
+ import { handleError } from './chunk-M5ABIP7D.js';
3
+ import { HTTPException } from './chunk-NYN7KFXL.js';
4
+ import { __export } from './chunk-MLKGABMK.js';
4
5
  import { Readable } from 'stream';
5
6
 
6
7
  // src/server/handlers/voice.ts
@@ -1,6 +1,6 @@
1
- import { validateBody } from './chunk-L7XE5QTW.js';
2
- import { handleError } from './chunk-3AHQ5RGN.js';
3
- import { __export } from './chunk-TRDNDNGQ.js';
1
+ import { validateBody } from './chunk-H5PTF3Y4.js';
2
+ import { handleError } from './chunk-M5ABIP7D.js';
3
+ import { __export } from './chunk-MLKGABMK.js';
4
4
 
5
5
  // src/server/handlers/logs.ts
6
6
  var logs_exports = {};