@mastra/server 0.0.0-bundle-dynamic-imports-20250424001248 → 0.0.0-cli-debug-2-20250611100354
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.
- package/README.md +48 -135
- package/dist/_tsup-dts-rollup.d.cts +331 -42
- package/dist/_tsup-dts-rollup.d.ts +331 -42
- package/dist/{chunk-4JINXASC.js → chunk-55DOQLP6.js} +5 -4
- package/dist/{chunk-QN4KF3BH.cjs → chunk-57CJTIPW.cjs} +2 -2
- package/dist/{chunk-ZLBRQFDD.cjs → chunk-64U3UDTH.cjs} +2 -2
- package/dist/chunk-6F2H7Y45.js +255 -0
- package/dist/{chunk-2FJURXCL.cjs → chunk-6TJSHFCJ.cjs} +44 -36
- package/dist/chunk-75ZPJI57.cjs +9 -0
- package/dist/chunk-7IBZ4L35.js +344 -0
- package/dist/{chunk-7IWQE76Z.cjs → chunk-B4MQFJ7G.cjs} +16 -10
- package/dist/{chunk-WTHDCRMY.js → chunk-BFOA2QQY.js} +12 -6
- package/dist/{chunk-M56ECCHK.cjs → chunk-BNEY4P4P.cjs} +20 -19
- package/dist/{chunk-RE6YL32K.js → chunk-C7564HUT.js} +52 -30
- package/dist/{chunk-55HTWX4C.cjs → chunk-CMMOIUFC.cjs} +40 -19
- package/dist/{chunk-Q6SHQECN.js → chunk-CP55EVBK.js} +24 -4
- package/dist/chunk-GHC4YV6R.js +504 -0
- package/dist/{chunk-L7XE5QTW.js → chunk-H5PTF3Y4.js} +1 -1
- package/dist/{chunk-5JNVY6DU.js → chunk-HYP7B2TL.js} +7 -5
- package/dist/{chunk-RBQASTUP.js → chunk-I7KJZNX5.js} +14 -6
- package/dist/chunk-IMBY5XUG.cjs +86 -0
- package/dist/chunk-JEWNMAYQ.cjs +263 -0
- package/dist/chunk-JKF6PRPU.cjs +357 -0
- package/dist/{chunk-3AHQ5RGN.js → chunk-M5ABIP7D.js} +1 -1
- package/dist/chunk-MLKGABMK.js +7 -0
- package/dist/{chunk-TRDNDNGQ.js → chunk-NYN7KFXL.js} +1 -7
- package/dist/{chunk-FV45V6WC.cjs → chunk-OCWPVYNI.cjs} +0 -7
- package/dist/chunk-QLG2PFHE.js +81 -0
- package/dist/chunk-SDPGVWQJ.cjs +512 -0
- package/dist/{chunk-LFOBHRFO.js → chunk-TEZOEGR4.js} +69 -54
- package/dist/{chunk-D3G23FP3.cjs → chunk-TJO277H7.cjs} +24 -22
- package/dist/chunk-UZ7FJ66C.cjs +332 -0
- package/dist/{chunk-FPIWDH5Y.cjs → chunk-VPNDC2DI.cjs} +62 -40
- package/dist/chunk-WKWHYFX4.js +2001 -0
- package/dist/chunk-XUGQSVZ4.cjs +2004 -0
- package/dist/server/handlers/a2a.cjs +30 -0
- package/dist/server/handlers/a2a.d.cts +6 -0
- package/dist/server/handlers/a2a.d.ts +6 -0
- package/dist/server/handlers/a2a.js +1 -0
- package/dist/server/handlers/agents.cjs +7 -7
- package/dist/server/handlers/agents.js +1 -1
- package/dist/server/handlers/error.cjs +2 -2
- package/dist/server/handlers/error.js +1 -1
- package/dist/server/handlers/legacyWorkflows.cjs +46 -0
- package/dist/server/handlers/legacyWorkflows.d.cts +10 -0
- package/dist/server/handlers/legacyWorkflows.d.ts +10 -0
- package/dist/server/handlers/legacyWorkflows.js +1 -0
- package/dist/server/handlers/logs.cjs +4 -4
- package/dist/server/handlers/logs.js +1 -1
- package/dist/server/handlers/memory.cjs +9 -9
- package/dist/server/handlers/memory.js +1 -1
- package/dist/server/handlers/network.cjs +5 -5
- package/dist/server/handlers/network.js +1 -1
- package/dist/server/handlers/telemetry.cjs +3 -3
- package/dist/server/handlers/telemetry.js +1 -1
- package/dist/server/handlers/tools.cjs +5 -5
- package/dist/server/handlers/tools.js +1 -1
- package/dist/server/handlers/utils.cjs +2 -2
- package/dist/server/handlers/utils.js +1 -1
- package/dist/server/handlers/vector.cjs +7 -7
- package/dist/server/handlers/vector.js +1 -1
- package/dist/server/handlers/voice.cjs +8 -4
- package/dist/server/handlers/voice.d.cts +1 -0
- package/dist/server/handlers/voice.d.ts +1 -0
- package/dist/server/handlers/voice.js +1 -1
- package/dist/server/handlers/workflows.cjs +17 -13
- package/dist/server/handlers/workflows.d.cts +3 -2
- package/dist/server/handlers/workflows.d.ts +3 -2
- package/dist/server/handlers/workflows.js +1 -1
- package/dist/server/handlers.cjs +33 -23
- package/dist/server/handlers.d.cts +2 -0
- package/dist/server/handlers.d.ts +2 -0
- package/dist/server/handlers.js +11 -9
- package/package.json +12 -10
- package/dist/chunk-3EJZQ6TQ.js +0 -49
- package/dist/chunk-5SWCVTNL.cjs +0 -5579
- package/dist/chunk-HCOPJZ4A.cjs +0 -164
- package/dist/chunk-OMN3UI6X.js +0 -5576
- package/dist/chunk-R4J7XQYU.js +0 -156
- package/dist/chunk-SKBVVI24.cjs +0 -54
- package/dist/chunk-TZK63M5N.cjs +0 -317
|
@@ -0,0 +1,263 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var chunkXUGQSVZ4_cjs = require('./chunk-XUGQSVZ4.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 ? chunkXUGQSVZ4_cjs.stringify(chunkXUGQSVZ4_cjs.esm_default(_tool.inputSchema)) : void 0,
|
|
33
|
+
outputSchema: _tool.outputSchema ? chunkXUGQSVZ4_cjs.stringify(chunkXUGQSVZ4_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
|
+
defaultGenerateOptions: agent.getDefaultGenerateOptions(),
|
|
63
|
+
defaultStreamOptions: agent.getDefaultStreamOptions()
|
|
64
|
+
};
|
|
65
|
+
})
|
|
66
|
+
);
|
|
67
|
+
const serializedAgents = serializedAgentsMap.reduce((acc, { id, ...rest }) => {
|
|
68
|
+
acc[id] = rest;
|
|
69
|
+
return acc;
|
|
70
|
+
}, {});
|
|
71
|
+
return serializedAgents;
|
|
72
|
+
} catch (error) {
|
|
73
|
+
return chunk64U3UDTH_cjs.handleError(error, "Error getting agents");
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
async function getAgentByIdHandler({
|
|
77
|
+
mastra,
|
|
78
|
+
runtimeContext,
|
|
79
|
+
agentId,
|
|
80
|
+
isPlayground = false
|
|
81
|
+
}) {
|
|
82
|
+
try {
|
|
83
|
+
const agent = mastra.getAgent(agentId);
|
|
84
|
+
if (!agent) {
|
|
85
|
+
throw new chunkOCWPVYNI_cjs.HTTPException(404, { message: "Agent not found" });
|
|
86
|
+
}
|
|
87
|
+
const tools = await agent.getTools({ runtimeContext });
|
|
88
|
+
const serializedAgentTools = Object.entries(tools || {}).reduce((acc, [key, tool]) => {
|
|
89
|
+
const _tool = tool;
|
|
90
|
+
acc[key] = {
|
|
91
|
+
..._tool,
|
|
92
|
+
inputSchema: _tool.inputSchema ? chunkXUGQSVZ4_cjs.stringify(chunkXUGQSVZ4_cjs.esm_default(_tool.inputSchema)) : void 0,
|
|
93
|
+
outputSchema: _tool.outputSchema ? chunkXUGQSVZ4_cjs.stringify(chunkXUGQSVZ4_cjs.esm_default(_tool.outputSchema)) : void 0
|
|
94
|
+
};
|
|
95
|
+
return acc;
|
|
96
|
+
}, {});
|
|
97
|
+
let serializedAgentWorkflows = {};
|
|
98
|
+
if ("getWorkflows" in agent) {
|
|
99
|
+
const logger = mastra.getLogger();
|
|
100
|
+
try {
|
|
101
|
+
const workflows = await agent.getWorkflows({ runtimeContext });
|
|
102
|
+
serializedAgentWorkflows = Object.entries(workflows || {}).reduce((acc, [key, workflow]) => {
|
|
103
|
+
return {
|
|
104
|
+
...acc,
|
|
105
|
+
[key]: {
|
|
106
|
+
name: workflow.name,
|
|
107
|
+
steps: Object.entries(workflow.steps).reduce((acc2, [key2, step]) => {
|
|
108
|
+
return {
|
|
109
|
+
...acc2,
|
|
110
|
+
[key2]: {
|
|
111
|
+
id: step.id,
|
|
112
|
+
description: step.description
|
|
113
|
+
}
|
|
114
|
+
};
|
|
115
|
+
}, {})
|
|
116
|
+
}
|
|
117
|
+
};
|
|
118
|
+
}, {});
|
|
119
|
+
} catch (error) {
|
|
120
|
+
logger.error("Error getting workflows for agent", { agentName: agent.name, error });
|
|
121
|
+
}
|
|
122
|
+
}
|
|
123
|
+
let proxyRuntimeContext = runtimeContext;
|
|
124
|
+
if (isPlayground) {
|
|
125
|
+
proxyRuntimeContext = new Proxy(runtimeContext, {
|
|
126
|
+
get(target, prop) {
|
|
127
|
+
if (prop === "get") {
|
|
128
|
+
return function(key) {
|
|
129
|
+
const value = target.get(key);
|
|
130
|
+
return value ?? `<${key}>`;
|
|
131
|
+
};
|
|
132
|
+
}
|
|
133
|
+
return Reflect.get(target, prop);
|
|
134
|
+
}
|
|
135
|
+
});
|
|
136
|
+
}
|
|
137
|
+
const instructions = await agent.getInstructions({ runtimeContext: proxyRuntimeContext });
|
|
138
|
+
const llm = await agent.getLLM({ runtimeContext });
|
|
139
|
+
return {
|
|
140
|
+
name: agent.name,
|
|
141
|
+
instructions,
|
|
142
|
+
tools: serializedAgentTools,
|
|
143
|
+
workflows: serializedAgentWorkflows,
|
|
144
|
+
provider: llm?.getProvider(),
|
|
145
|
+
modelId: llm?.getModelId(),
|
|
146
|
+
defaultGenerateOptions: agent.getDefaultGenerateOptions(),
|
|
147
|
+
defaultStreamOptions: agent.getDefaultStreamOptions()
|
|
148
|
+
};
|
|
149
|
+
} catch (error) {
|
|
150
|
+
return chunk64U3UDTH_cjs.handleError(error, "Error getting agent");
|
|
151
|
+
}
|
|
152
|
+
}
|
|
153
|
+
async function getEvalsByAgentIdHandler({
|
|
154
|
+
mastra,
|
|
155
|
+
runtimeContext,
|
|
156
|
+
agentId
|
|
157
|
+
}) {
|
|
158
|
+
try {
|
|
159
|
+
const agent = mastra.getAgent(agentId);
|
|
160
|
+
const evals = await mastra.getStorage()?.getEvalsByAgentName?.(agent.name, "test") || [];
|
|
161
|
+
const instructions = await agent.getInstructions({ runtimeContext });
|
|
162
|
+
return {
|
|
163
|
+
id: agentId,
|
|
164
|
+
name: agent.name,
|
|
165
|
+
instructions,
|
|
166
|
+
evals
|
|
167
|
+
};
|
|
168
|
+
} catch (error) {
|
|
169
|
+
return chunk64U3UDTH_cjs.handleError(error, "Error getting test evals");
|
|
170
|
+
}
|
|
171
|
+
}
|
|
172
|
+
async function getLiveEvalsByAgentIdHandler({
|
|
173
|
+
mastra,
|
|
174
|
+
runtimeContext,
|
|
175
|
+
agentId
|
|
176
|
+
}) {
|
|
177
|
+
try {
|
|
178
|
+
const agent = mastra.getAgent(agentId);
|
|
179
|
+
const evals = await mastra.getStorage()?.getEvalsByAgentName?.(agent.name, "live") || [];
|
|
180
|
+
const instructions = await agent.getInstructions({ runtimeContext });
|
|
181
|
+
return {
|
|
182
|
+
id: agentId,
|
|
183
|
+
name: agent.name,
|
|
184
|
+
instructions,
|
|
185
|
+
evals
|
|
186
|
+
};
|
|
187
|
+
} catch (error) {
|
|
188
|
+
return chunk64U3UDTH_cjs.handleError(error, "Error getting live evals");
|
|
189
|
+
}
|
|
190
|
+
}
|
|
191
|
+
async function generateHandler({
|
|
192
|
+
mastra,
|
|
193
|
+
runtimeContext: runtimeContext$1,
|
|
194
|
+
agentId,
|
|
195
|
+
body
|
|
196
|
+
}) {
|
|
197
|
+
try {
|
|
198
|
+
const agent = mastra.getAgent(agentId);
|
|
199
|
+
if (!agent) {
|
|
200
|
+
throw new chunkOCWPVYNI_cjs.HTTPException(404, { message: "Agent not found" });
|
|
201
|
+
}
|
|
202
|
+
const { messages, resourceId, resourceid, runtimeContext: agentRuntimeContext, ...rest } = body;
|
|
203
|
+
const finalResourceId = resourceId ?? resourceid;
|
|
204
|
+
const finalRuntimeContext = new runtimeContext.RuntimeContext([
|
|
205
|
+
...Array.from(runtimeContext$1.entries()),
|
|
206
|
+
...Array.from(Object.entries(agentRuntimeContext ?? {}))
|
|
207
|
+
]);
|
|
208
|
+
chunk57CJTIPW_cjs.validateBody({ messages });
|
|
209
|
+
const result = await agent.generate(messages, {
|
|
210
|
+
...rest,
|
|
211
|
+
// @ts-expect-error TODO fix types
|
|
212
|
+
resourceId: finalResourceId,
|
|
213
|
+
runtimeContext: finalRuntimeContext
|
|
214
|
+
});
|
|
215
|
+
return result;
|
|
216
|
+
} catch (error) {
|
|
217
|
+
return chunk64U3UDTH_cjs.handleError(error, "Error generating from agent");
|
|
218
|
+
}
|
|
219
|
+
}
|
|
220
|
+
async function streamGenerateHandler({
|
|
221
|
+
mastra,
|
|
222
|
+
runtimeContext: runtimeContext$1,
|
|
223
|
+
agentId,
|
|
224
|
+
body
|
|
225
|
+
}) {
|
|
226
|
+
try {
|
|
227
|
+
const agent = mastra.getAgent(agentId);
|
|
228
|
+
if (!agent) {
|
|
229
|
+
throw new chunkOCWPVYNI_cjs.HTTPException(404, { message: "Agent not found" });
|
|
230
|
+
}
|
|
231
|
+
const { messages, resourceId, resourceid, runtimeContext: agentRuntimeContext, ...rest } = body;
|
|
232
|
+
const finalResourceId = resourceId ?? resourceid;
|
|
233
|
+
const finalRuntimeContext = new runtimeContext.RuntimeContext([
|
|
234
|
+
...Array.from(runtimeContext$1.entries()),
|
|
235
|
+
...Array.from(Object.entries(agentRuntimeContext ?? {}))
|
|
236
|
+
]);
|
|
237
|
+
chunk57CJTIPW_cjs.validateBody({ messages });
|
|
238
|
+
const streamResult = await agent.stream(messages, {
|
|
239
|
+
...rest,
|
|
240
|
+
// @ts-expect-error TODO fix types
|
|
241
|
+
resourceId: finalResourceId,
|
|
242
|
+
runtimeContext: finalRuntimeContext
|
|
243
|
+
});
|
|
244
|
+
const streamResponse = rest.output ? streamResult.toTextStreamResponse() : streamResult.toDataStreamResponse({
|
|
245
|
+
sendUsage: true,
|
|
246
|
+
sendReasoning: true,
|
|
247
|
+
getErrorMessage: (error) => {
|
|
248
|
+
return `An error occurred while processing your request. ${error instanceof Error ? error.message : JSON.stringify(error)}`;
|
|
249
|
+
}
|
|
250
|
+
});
|
|
251
|
+
return streamResponse;
|
|
252
|
+
} catch (error) {
|
|
253
|
+
throw new chunkOCWPVYNI_cjs.HTTPException(error?.status ?? 500, { message: error?.message ?? "Error streaming from agent" });
|
|
254
|
+
}
|
|
255
|
+
}
|
|
256
|
+
|
|
257
|
+
exports.agents_exports = agents_exports;
|
|
258
|
+
exports.generateHandler = generateHandler;
|
|
259
|
+
exports.getAgentByIdHandler = getAgentByIdHandler;
|
|
260
|
+
exports.getAgentsHandler = getAgentsHandler;
|
|
261
|
+
exports.getEvalsByAgentIdHandler = getEvalsByAgentIdHandler;
|
|
262
|
+
exports.getLiveEvalsByAgentIdHandler = getLiveEvalsByAgentIdHandler;
|
|
263
|
+
exports.streamGenerateHandler = streamGenerateHandler;
|
|
@@ -0,0 +1,357 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var chunkXUGQSVZ4_cjs = require('./chunk-XUGQSVZ4.cjs');
|
|
4
|
+
var chunk64U3UDTH_cjs = require('./chunk-64U3UDTH.cjs');
|
|
5
|
+
var chunkOCWPVYNI_cjs = require('./chunk-OCWPVYNI.cjs');
|
|
6
|
+
var chunk75ZPJI57_cjs = require('./chunk-75ZPJI57.cjs');
|
|
7
|
+
var web = require('stream/web');
|
|
8
|
+
|
|
9
|
+
// src/server/handlers/workflows.ts
|
|
10
|
+
var workflows_exports = {};
|
|
11
|
+
chunk75ZPJI57_cjs.__export(workflows_exports, {
|
|
12
|
+
createWorkflowRunHandler: () => createWorkflowRunHandler,
|
|
13
|
+
getWorkflowByIdHandler: () => getWorkflowByIdHandler,
|
|
14
|
+
getWorkflowRunByIdHandler: () => getWorkflowRunByIdHandler,
|
|
15
|
+
getWorkflowRunsHandler: () => getWorkflowRunsHandler,
|
|
16
|
+
getWorkflowsHandler: () => getWorkflowsHandler,
|
|
17
|
+
resumeAsyncWorkflowHandler: () => resumeAsyncWorkflowHandler,
|
|
18
|
+
resumeWorkflowHandler: () => resumeWorkflowHandler,
|
|
19
|
+
startAsyncWorkflowHandler: () => startAsyncWorkflowHandler,
|
|
20
|
+
startWorkflowRunHandler: () => startWorkflowRunHandler,
|
|
21
|
+
streamWorkflowHandler: () => streamWorkflowHandler,
|
|
22
|
+
watchWorkflowHandler: () => watchWorkflowHandler
|
|
23
|
+
});
|
|
24
|
+
async function getWorkflowsHandler({ mastra }) {
|
|
25
|
+
try {
|
|
26
|
+
const workflows = mastra.getWorkflows({ serialized: false });
|
|
27
|
+
const _workflows = Object.entries(workflows).reduce((acc, [key, workflow]) => {
|
|
28
|
+
acc[key] = {
|
|
29
|
+
name: workflow.name,
|
|
30
|
+
description: workflow.description,
|
|
31
|
+
steps: Object.entries(workflow.steps).reduce((acc2, [key2, step]) => {
|
|
32
|
+
acc2[key2] = {
|
|
33
|
+
id: step.id,
|
|
34
|
+
description: step.description,
|
|
35
|
+
inputSchema: step.inputSchema ? chunkXUGQSVZ4_cjs.stringify(chunkXUGQSVZ4_cjs.esm_default(step.inputSchema)) : void 0,
|
|
36
|
+
outputSchema: step.outputSchema ? chunkXUGQSVZ4_cjs.stringify(chunkXUGQSVZ4_cjs.esm_default(step.outputSchema)) : void 0,
|
|
37
|
+
resumeSchema: step.resumeSchema ? chunkXUGQSVZ4_cjs.stringify(chunkXUGQSVZ4_cjs.esm_default(step.resumeSchema)) : void 0,
|
|
38
|
+
suspendSchema: step.suspendSchema ? chunkXUGQSVZ4_cjs.stringify(chunkXUGQSVZ4_cjs.esm_default(step.suspendSchema)) : void 0
|
|
39
|
+
};
|
|
40
|
+
return acc2;
|
|
41
|
+
}, {}),
|
|
42
|
+
stepGraph: workflow.serializedStepGraph,
|
|
43
|
+
inputSchema: workflow.inputSchema ? chunkXUGQSVZ4_cjs.stringify(chunkXUGQSVZ4_cjs.esm_default(workflow.inputSchema)) : void 0,
|
|
44
|
+
outputSchema: workflow.outputSchema ? chunkXUGQSVZ4_cjs.stringify(chunkXUGQSVZ4_cjs.esm_default(workflow.outputSchema)) : void 0
|
|
45
|
+
};
|
|
46
|
+
return acc;
|
|
47
|
+
}, {});
|
|
48
|
+
return _workflows;
|
|
49
|
+
} catch (error) {
|
|
50
|
+
throw new chunkOCWPVYNI_cjs.HTTPException(500, { message: error?.message || "Error getting workflows" });
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
async function getWorkflowByIdHandler({ mastra, workflowId }) {
|
|
54
|
+
try {
|
|
55
|
+
if (!workflowId) {
|
|
56
|
+
throw new chunkOCWPVYNI_cjs.HTTPException(400, { message: "Workflow ID is required" });
|
|
57
|
+
}
|
|
58
|
+
const workflow = mastra.getWorkflow(workflowId);
|
|
59
|
+
if (!workflow) {
|
|
60
|
+
throw new chunkOCWPVYNI_cjs.HTTPException(404, { message: "Workflow not found" });
|
|
61
|
+
}
|
|
62
|
+
return {
|
|
63
|
+
steps: Object.entries(workflow.steps).reduce((acc, [key, step]) => {
|
|
64
|
+
acc[key] = {
|
|
65
|
+
id: step.id,
|
|
66
|
+
description: step.description,
|
|
67
|
+
inputSchema: step.inputSchema ? chunkXUGQSVZ4_cjs.stringify(chunkXUGQSVZ4_cjs.esm_default(step.inputSchema)) : void 0,
|
|
68
|
+
outputSchema: step.outputSchema ? chunkXUGQSVZ4_cjs.stringify(chunkXUGQSVZ4_cjs.esm_default(step.outputSchema)) : void 0,
|
|
69
|
+
resumeSchema: step.resumeSchema ? chunkXUGQSVZ4_cjs.stringify(chunkXUGQSVZ4_cjs.esm_default(step.resumeSchema)) : void 0,
|
|
70
|
+
suspendSchema: step.suspendSchema ? chunkXUGQSVZ4_cjs.stringify(chunkXUGQSVZ4_cjs.esm_default(step.suspendSchema)) : void 0
|
|
71
|
+
};
|
|
72
|
+
return acc;
|
|
73
|
+
}, {}),
|
|
74
|
+
name: workflow.name,
|
|
75
|
+
description: workflow.description,
|
|
76
|
+
stepGraph: workflow.serializedStepGraph,
|
|
77
|
+
inputSchema: workflow.inputSchema ? chunkXUGQSVZ4_cjs.stringify(chunkXUGQSVZ4_cjs.esm_default(workflow.inputSchema)) : void 0,
|
|
78
|
+
outputSchema: workflow.outputSchema ? chunkXUGQSVZ4_cjs.stringify(chunkXUGQSVZ4_cjs.esm_default(workflow.outputSchema)) : void 0
|
|
79
|
+
};
|
|
80
|
+
} catch (error) {
|
|
81
|
+
throw new chunkOCWPVYNI_cjs.HTTPException(500, { message: error?.message || "Error getting workflow" });
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
async function getWorkflowRunByIdHandler({
|
|
85
|
+
mastra,
|
|
86
|
+
workflowId,
|
|
87
|
+
runId
|
|
88
|
+
}) {
|
|
89
|
+
try {
|
|
90
|
+
if (!workflowId) {
|
|
91
|
+
throw new chunkOCWPVYNI_cjs.HTTPException(400, { message: "Workflow ID is required" });
|
|
92
|
+
}
|
|
93
|
+
if (!runId) {
|
|
94
|
+
throw new chunkOCWPVYNI_cjs.HTTPException(400, { message: "Run ID is required" });
|
|
95
|
+
}
|
|
96
|
+
const workflow = mastra.getWorkflow(workflowId);
|
|
97
|
+
if (!workflow) {
|
|
98
|
+
throw new chunkOCWPVYNI_cjs.HTTPException(404, { message: "Workflow not found" });
|
|
99
|
+
}
|
|
100
|
+
const run = await workflow.getWorkflowRunById(runId);
|
|
101
|
+
if (!run) {
|
|
102
|
+
throw new chunkOCWPVYNI_cjs.HTTPException(404, { message: "Workflow run not found" });
|
|
103
|
+
}
|
|
104
|
+
return run;
|
|
105
|
+
} catch (error) {
|
|
106
|
+
throw new chunkOCWPVYNI_cjs.HTTPException(500, { message: error?.message || "Error getting workflow run" });
|
|
107
|
+
}
|
|
108
|
+
}
|
|
109
|
+
async function createWorkflowRunHandler({
|
|
110
|
+
mastra,
|
|
111
|
+
workflowId,
|
|
112
|
+
runId: prevRunId
|
|
113
|
+
}) {
|
|
114
|
+
try {
|
|
115
|
+
if (!workflowId) {
|
|
116
|
+
throw new chunkOCWPVYNI_cjs.HTTPException(400, { message: "Workflow ID is required" });
|
|
117
|
+
}
|
|
118
|
+
const workflow = mastra.getWorkflow(workflowId);
|
|
119
|
+
if (!workflow) {
|
|
120
|
+
throw new chunkOCWPVYNI_cjs.HTTPException(404, { message: "Workflow not found" });
|
|
121
|
+
}
|
|
122
|
+
const run = workflow.createRun({ runId: prevRunId });
|
|
123
|
+
return { runId: run.runId };
|
|
124
|
+
} catch (error) {
|
|
125
|
+
throw new chunkOCWPVYNI_cjs.HTTPException(500, { message: error?.message || "Error creating workflow run" });
|
|
126
|
+
}
|
|
127
|
+
}
|
|
128
|
+
async function startAsyncWorkflowHandler({
|
|
129
|
+
mastra,
|
|
130
|
+
runtimeContext,
|
|
131
|
+
workflowId,
|
|
132
|
+
runId,
|
|
133
|
+
inputData
|
|
134
|
+
}) {
|
|
135
|
+
try {
|
|
136
|
+
if (!workflowId) {
|
|
137
|
+
throw new chunkOCWPVYNI_cjs.HTTPException(400, { message: "Workflow ID is required" });
|
|
138
|
+
}
|
|
139
|
+
const workflow = mastra.getWorkflow(workflowId);
|
|
140
|
+
if (!workflow) {
|
|
141
|
+
throw new chunkOCWPVYNI_cjs.HTTPException(404, { message: "Workflow not found" });
|
|
142
|
+
}
|
|
143
|
+
const _run = workflow.createRun({ runId });
|
|
144
|
+
const result = await _run.start({
|
|
145
|
+
inputData,
|
|
146
|
+
runtimeContext
|
|
147
|
+
});
|
|
148
|
+
return result;
|
|
149
|
+
} catch (error) {
|
|
150
|
+
throw new chunkOCWPVYNI_cjs.HTTPException(500, { message: error?.message || "Error executing workflow" });
|
|
151
|
+
}
|
|
152
|
+
}
|
|
153
|
+
async function startWorkflowRunHandler({
|
|
154
|
+
mastra,
|
|
155
|
+
runtimeContext,
|
|
156
|
+
workflowId,
|
|
157
|
+
runId,
|
|
158
|
+
inputData
|
|
159
|
+
}) {
|
|
160
|
+
try {
|
|
161
|
+
if (!workflowId) {
|
|
162
|
+
throw new chunkOCWPVYNI_cjs.HTTPException(400, { message: "Workflow ID is required" });
|
|
163
|
+
}
|
|
164
|
+
if (!runId) {
|
|
165
|
+
throw new chunkOCWPVYNI_cjs.HTTPException(400, { message: "runId required to start run" });
|
|
166
|
+
}
|
|
167
|
+
const workflow = mastra.getWorkflow(workflowId);
|
|
168
|
+
const run = await workflow.getWorkflowRunById(runId);
|
|
169
|
+
if (!run) {
|
|
170
|
+
throw new chunkOCWPVYNI_cjs.HTTPException(404, { message: "Workflow run not found" });
|
|
171
|
+
}
|
|
172
|
+
const _run = workflow.createRun({ runId });
|
|
173
|
+
void _run.start({
|
|
174
|
+
inputData,
|
|
175
|
+
runtimeContext
|
|
176
|
+
});
|
|
177
|
+
return { message: "Workflow run started" };
|
|
178
|
+
} catch (e) {
|
|
179
|
+
return chunk64U3UDTH_cjs.handleError(e, "Error starting workflow run");
|
|
180
|
+
}
|
|
181
|
+
}
|
|
182
|
+
async function watchWorkflowHandler({
|
|
183
|
+
mastra,
|
|
184
|
+
workflowId,
|
|
185
|
+
runId
|
|
186
|
+
}) {
|
|
187
|
+
try {
|
|
188
|
+
if (!workflowId) {
|
|
189
|
+
throw new chunkOCWPVYNI_cjs.HTTPException(400, { message: "Workflow ID is required" });
|
|
190
|
+
}
|
|
191
|
+
if (!runId) {
|
|
192
|
+
throw new chunkOCWPVYNI_cjs.HTTPException(400, { message: "runId required to watch workflow" });
|
|
193
|
+
}
|
|
194
|
+
const workflow = mastra.getWorkflow(workflowId);
|
|
195
|
+
const run = await workflow.getWorkflowRunById(runId);
|
|
196
|
+
if (!run) {
|
|
197
|
+
throw new chunkOCWPVYNI_cjs.HTTPException(404, { message: "Workflow run not found" });
|
|
198
|
+
}
|
|
199
|
+
const _run = workflow.createRun({ runId });
|
|
200
|
+
let unwatch;
|
|
201
|
+
let asyncRef = null;
|
|
202
|
+
const stream = new web.ReadableStream({
|
|
203
|
+
start(controller) {
|
|
204
|
+
unwatch = _run.watch(({ type, payload, eventTimestamp }) => {
|
|
205
|
+
controller.enqueue(JSON.stringify({ type, payload, eventTimestamp, runId }));
|
|
206
|
+
if (asyncRef) {
|
|
207
|
+
clearImmediate(asyncRef);
|
|
208
|
+
asyncRef = null;
|
|
209
|
+
}
|
|
210
|
+
asyncRef = setImmediate(async () => {
|
|
211
|
+
const runDone = payload.workflowState.status !== "running";
|
|
212
|
+
if (runDone) {
|
|
213
|
+
controller.close();
|
|
214
|
+
unwatch?.();
|
|
215
|
+
}
|
|
216
|
+
});
|
|
217
|
+
});
|
|
218
|
+
},
|
|
219
|
+
cancel() {
|
|
220
|
+
unwatch?.();
|
|
221
|
+
}
|
|
222
|
+
});
|
|
223
|
+
return stream;
|
|
224
|
+
} catch (error) {
|
|
225
|
+
return chunk64U3UDTH_cjs.handleError(error, "Error watching workflow");
|
|
226
|
+
}
|
|
227
|
+
}
|
|
228
|
+
function streamWorkflowHandler({
|
|
229
|
+
mastra,
|
|
230
|
+
runtimeContext,
|
|
231
|
+
workflowId,
|
|
232
|
+
runId,
|
|
233
|
+
inputData
|
|
234
|
+
}) {
|
|
235
|
+
try {
|
|
236
|
+
if (!workflowId) {
|
|
237
|
+
throw new chunkOCWPVYNI_cjs.HTTPException(400, { message: "Workflow ID is required" });
|
|
238
|
+
}
|
|
239
|
+
if (!runId) {
|
|
240
|
+
throw new chunkOCWPVYNI_cjs.HTTPException(400, { message: "runId required to resume workflow" });
|
|
241
|
+
}
|
|
242
|
+
const workflow = mastra.getWorkflow(workflowId);
|
|
243
|
+
if (!workflow) {
|
|
244
|
+
throw new chunkOCWPVYNI_cjs.HTTPException(404, { message: "Workflow not found" });
|
|
245
|
+
}
|
|
246
|
+
const run = workflow.createRun({ runId });
|
|
247
|
+
const result = run.stream({
|
|
248
|
+
inputData,
|
|
249
|
+
runtimeContext
|
|
250
|
+
});
|
|
251
|
+
return result;
|
|
252
|
+
} catch (error) {
|
|
253
|
+
return chunk64U3UDTH_cjs.handleError(error, "Error executing workflow");
|
|
254
|
+
}
|
|
255
|
+
}
|
|
256
|
+
async function resumeAsyncWorkflowHandler({
|
|
257
|
+
mastra,
|
|
258
|
+
workflowId,
|
|
259
|
+
runId,
|
|
260
|
+
body,
|
|
261
|
+
runtimeContext
|
|
262
|
+
}) {
|
|
263
|
+
try {
|
|
264
|
+
if (!workflowId) {
|
|
265
|
+
throw new chunkOCWPVYNI_cjs.HTTPException(400, { message: "Workflow ID is required" });
|
|
266
|
+
}
|
|
267
|
+
if (!runId) {
|
|
268
|
+
throw new chunkOCWPVYNI_cjs.HTTPException(400, { message: "runId required to resume workflow" });
|
|
269
|
+
}
|
|
270
|
+
if (!body.step) {
|
|
271
|
+
throw new chunkOCWPVYNI_cjs.HTTPException(400, { message: "step required to resume workflow" });
|
|
272
|
+
}
|
|
273
|
+
const workflow = mastra.getWorkflow(workflowId);
|
|
274
|
+
const run = await workflow.getWorkflowRunById(runId);
|
|
275
|
+
if (!run) {
|
|
276
|
+
throw new chunkOCWPVYNI_cjs.HTTPException(404, { message: "Workflow run not found" });
|
|
277
|
+
}
|
|
278
|
+
const _run = workflow.createRun({ runId });
|
|
279
|
+
const result = await _run.resume({
|
|
280
|
+
step: body.step,
|
|
281
|
+
resumeData: body.resumeData,
|
|
282
|
+
runtimeContext
|
|
283
|
+
});
|
|
284
|
+
return result;
|
|
285
|
+
} catch (error) {
|
|
286
|
+
return chunk64U3UDTH_cjs.handleError(error, "Error resuming workflow step");
|
|
287
|
+
}
|
|
288
|
+
}
|
|
289
|
+
async function resumeWorkflowHandler({
|
|
290
|
+
mastra,
|
|
291
|
+
workflowId,
|
|
292
|
+
runId,
|
|
293
|
+
body,
|
|
294
|
+
runtimeContext
|
|
295
|
+
}) {
|
|
296
|
+
try {
|
|
297
|
+
if (!workflowId) {
|
|
298
|
+
throw new chunkOCWPVYNI_cjs.HTTPException(400, { message: "Workflow ID is required" });
|
|
299
|
+
}
|
|
300
|
+
if (!runId) {
|
|
301
|
+
throw new chunkOCWPVYNI_cjs.HTTPException(400, { message: "runId required to resume workflow" });
|
|
302
|
+
}
|
|
303
|
+
if (!body.step) {
|
|
304
|
+
throw new chunkOCWPVYNI_cjs.HTTPException(400, { message: "step required to resume workflow" });
|
|
305
|
+
}
|
|
306
|
+
const workflow = mastra.getWorkflow(workflowId);
|
|
307
|
+
const run = await workflow.getWorkflowRunById(runId);
|
|
308
|
+
if (!run) {
|
|
309
|
+
throw new chunkOCWPVYNI_cjs.HTTPException(404, { message: "Workflow run not found" });
|
|
310
|
+
}
|
|
311
|
+
const _run = workflow.createRun({ runId });
|
|
312
|
+
void _run.resume({
|
|
313
|
+
step: body.step,
|
|
314
|
+
resumeData: body.resumeData,
|
|
315
|
+
runtimeContext
|
|
316
|
+
});
|
|
317
|
+
return { message: "Workflow run resumed" };
|
|
318
|
+
} catch (error) {
|
|
319
|
+
return chunk64U3UDTH_cjs.handleError(error, "Error resuming workflow");
|
|
320
|
+
}
|
|
321
|
+
}
|
|
322
|
+
async function getWorkflowRunsHandler({
|
|
323
|
+
mastra,
|
|
324
|
+
workflowId,
|
|
325
|
+
fromDate,
|
|
326
|
+
toDate,
|
|
327
|
+
limit,
|
|
328
|
+
offset,
|
|
329
|
+
resourceId
|
|
330
|
+
}) {
|
|
331
|
+
try {
|
|
332
|
+
if (!workflowId) {
|
|
333
|
+
throw new chunkOCWPVYNI_cjs.HTTPException(400, { message: "Workflow ID is required" });
|
|
334
|
+
}
|
|
335
|
+
const workflow = mastra.getWorkflow(workflowId);
|
|
336
|
+
const workflowRuns = await workflow.getWorkflowRuns({ fromDate, toDate, limit, offset, resourceId }) || {
|
|
337
|
+
runs: [],
|
|
338
|
+
total: 0
|
|
339
|
+
};
|
|
340
|
+
return workflowRuns;
|
|
341
|
+
} catch (error) {
|
|
342
|
+
return chunk64U3UDTH_cjs.handleError(error, "Error getting workflow runs");
|
|
343
|
+
}
|
|
344
|
+
}
|
|
345
|
+
|
|
346
|
+
exports.createWorkflowRunHandler = createWorkflowRunHandler;
|
|
347
|
+
exports.getWorkflowByIdHandler = getWorkflowByIdHandler;
|
|
348
|
+
exports.getWorkflowRunByIdHandler = getWorkflowRunByIdHandler;
|
|
349
|
+
exports.getWorkflowRunsHandler = getWorkflowRunsHandler;
|
|
350
|
+
exports.getWorkflowsHandler = getWorkflowsHandler;
|
|
351
|
+
exports.resumeAsyncWorkflowHandler = resumeAsyncWorkflowHandler;
|
|
352
|
+
exports.resumeWorkflowHandler = resumeWorkflowHandler;
|
|
353
|
+
exports.startAsyncWorkflowHandler = startAsyncWorkflowHandler;
|
|
354
|
+
exports.startWorkflowRunHandler = startWorkflowRunHandler;
|
|
355
|
+
exports.streamWorkflowHandler = streamWorkflowHandler;
|
|
356
|
+
exports.watchWorkflowHandler = watchWorkflowHandler;
|
|
357
|
+
exports.workflows_exports = workflows_exports;
|
|
@@ -1,9 +1,3 @@
|
|
|
1
|
-
var __defProp = Object.defineProperty;
|
|
2
|
-
var __export = (target, all) => {
|
|
3
|
-
for (var name in all)
|
|
4
|
-
__defProp(target, name, { get: all[name], enumerable: true });
|
|
5
|
-
};
|
|
6
|
-
|
|
7
1
|
// src/server/http-exception.ts
|
|
8
2
|
var HTTPException = class extends Error {
|
|
9
3
|
res;
|
|
@@ -37,4 +31,4 @@ var HTTPException = class extends Error {
|
|
|
37
31
|
}
|
|
38
32
|
};
|
|
39
33
|
|
|
40
|
-
export { HTTPException
|
|
34
|
+
export { HTTPException };
|
|
@@ -1,11 +1,5 @@
|
|
|
1
1
|
'use strict';
|
|
2
2
|
|
|
3
|
-
var __defProp = Object.defineProperty;
|
|
4
|
-
var __export = (target, all) => {
|
|
5
|
-
for (var name in all)
|
|
6
|
-
__defProp(target, name, { get: all[name], enumerable: true });
|
|
7
|
-
};
|
|
8
|
-
|
|
9
3
|
// src/server/http-exception.ts
|
|
10
4
|
var HTTPException = class extends Error {
|
|
11
5
|
res;
|
|
@@ -40,4 +34,3 @@ var HTTPException = class extends Error {
|
|
|
40
34
|
};
|
|
41
35
|
|
|
42
36
|
exports.HTTPException = HTTPException;
|
|
43
|
-
exports.__export = __export;
|