@mastra/server 0.0.1-alpha.6 → 0.10.0
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/{LICENSE → LICENSE.md} +3 -1
- package/README.md +48 -135
- package/dist/_tsup-dts-rollup.d.cts +305 -52
- package/dist/_tsup-dts-rollup.d.ts +305 -52
- package/dist/{chunk-4JINXASC.js → chunk-55DOQLP6.js} +5 -4
- package/dist/{chunk-QN4KF3BH.cjs → chunk-57CJTIPW.cjs} +2 -2
- package/dist/chunk-5SN4U5AC.cjs +508 -0
- package/dist/{chunk-ZLBRQFDD.cjs → chunk-64U3UDTH.cjs} +2 -2
- package/dist/chunk-6B4OMWT6.cjs +343 -0
- package/dist/chunk-75ZPJI57.cjs +9 -0
- package/dist/{chunk-VB7KH62D.cjs → chunk-7DLZLWJV.cjs} +16 -12
- package/dist/{chunk-M56ECCHK.cjs → chunk-BNEY4P4P.cjs} +20 -19
- package/dist/{chunk-2YONKUWB.js → chunk-C7564HUT.js} +58 -33
- package/dist/chunk-D4IRYCUI.cjs +235 -0
- package/dist/{chunk-RBQASTUP.js → chunk-DJJIUEL2.js} +13 -5
- package/dist/{chunk-L7XE5QTW.js → chunk-H5PTF3Y4.js} +1 -1
- package/dist/{chunk-3RVHWGWO.js → chunk-HFWCEP5S.js} +6 -12
- package/dist/chunk-LIVAK2DM.js +2001 -0
- package/dist/{chunk-3AHQ5RGN.js → chunk-M5ABIP7D.js} +1 -1
- package/dist/{chunk-CWSDZEZG.cjs → chunk-MHKNLNAN.cjs} +15 -12
- 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-DVPP5S6I.js → chunk-OR3CIE2H.js} +9 -6
- package/dist/chunk-P6SCPDYW.js +500 -0
- package/dist/chunk-QY36IPTP.js +331 -0
- package/dist/{chunk-YNSGUC2O.js → chunk-TJKLBTFB.js} +23 -7
- package/dist/chunk-VPNDC2DI.cjs +148 -0
- package/dist/{chunk-ILW7XYNJ.js → chunk-W7VCKPAD.js} +84 -60
- package/dist/{chunk-2JQC6JWP.js → chunk-WFBJJNCK.js} +10 -6
- package/dist/chunk-WUC6LSTW.js +227 -0
- package/dist/{chunk-2FJURXCL.cjs → chunk-Y7UWRW5X.cjs} +43 -35
- package/dist/{chunk-A7DF4ETD.cjs → chunk-YBVOQN4M.cjs} +22 -28
- package/dist/chunk-YIOVBYZH.cjs +332 -0
- package/dist/chunk-YWLUOY3D.cjs +2004 -0
- package/dist/{chunk-4C3EPMMF.cjs → chunk-ZE5AAC4I.cjs} +40 -24
- 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 +4 -4
- package/dist/server/handlers/voice.js +1 -1
- package/dist/server/handlers/workflows.cjs +13 -13
- package/dist/server/handlers/workflows.d.cts +2 -2
- package/dist/server/handlers/workflows.d.ts +2 -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 +9 -7
- package/dist/chunk-5JOF627H.cjs +0 -123
- package/dist/chunk-BMA2ORRT.js +0 -152
- package/dist/chunk-GV52BII2.cjs +0 -160
- package/dist/chunk-QH6XWSXP.cjs +0 -5579
- package/dist/chunk-VK6FX47H.js +0 -5576
- package/dist/chunk-X37I6GZT.cjs +0 -308
|
@@ -1,6 +1,7 @@
|
|
|
1
|
-
import { validateBody } from './chunk-
|
|
2
|
-
import { handleError } from './chunk-
|
|
3
|
-
import {
|
|
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({
|
|
14
|
+
async function getNetworksHandler({
|
|
15
|
+
mastra,
|
|
16
|
+
runtimeContext
|
|
17
|
+
}) {
|
|
14
18
|
try {
|
|
15
19
|
const networks = mastra.getNetworks();
|
|
16
|
-
const serializedNetworks =
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
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({
|
|
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:
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
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:
|
|
62
|
-
modelId:
|
|
83
|
+
provider: routingLLM?.getProvider(),
|
|
84
|
+
modelId: routingLLM?.getModelId()
|
|
63
85
|
}
|
|
64
86
|
};
|
|
65
87
|
return serializedNetwork;
|
|
@@ -69,6 +91,7 @@ async function getNetworkByIdHandler({ mastra, networkId }) {
|
|
|
69
91
|
}
|
|
70
92
|
async function generateHandler({
|
|
71
93
|
mastra,
|
|
94
|
+
runtimeContext,
|
|
72
95
|
networkId,
|
|
73
96
|
body
|
|
74
97
|
}) {
|
|
@@ -79,7 +102,7 @@ async function generateHandler({
|
|
|
79
102
|
}
|
|
80
103
|
validateBody({ messages: body.messages });
|
|
81
104
|
const { messages, ...rest } = body;
|
|
82
|
-
const result = await network.generate(messages, rest);
|
|
105
|
+
const result = await network.generate(messages, { ...rest, runtimeContext });
|
|
83
106
|
return result;
|
|
84
107
|
} catch (error) {
|
|
85
108
|
return handleError(error, "Error generating from network");
|
|
@@ -88,7 +111,8 @@ async function generateHandler({
|
|
|
88
111
|
async function streamGenerateHandler({
|
|
89
112
|
mastra,
|
|
90
113
|
networkId,
|
|
91
|
-
body
|
|
114
|
+
body,
|
|
115
|
+
runtimeContext
|
|
92
116
|
}) {
|
|
93
117
|
try {
|
|
94
118
|
const network = mastra.getNetwork(networkId);
|
|
@@ -99,7 +123,8 @@ async function streamGenerateHandler({
|
|
|
99
123
|
const { messages, output, ...rest } = body;
|
|
100
124
|
const streamResult = await network.stream(messages, {
|
|
101
125
|
output,
|
|
102
|
-
...rest
|
|
126
|
+
...rest,
|
|
127
|
+
runtimeContext
|
|
103
128
|
});
|
|
104
129
|
const streamResponse = output ? streamResult.toTextStreamResponse() : streamResult.toDataStreamResponse({
|
|
105
130
|
sendUsage: true,
|
|
@@ -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-
|
|
2
|
-
import { handleError } from './chunk-
|
|
3
|
-
import {
|
|
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({
|
|
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 { validateBody } from './chunk-
|
|
2
|
-
import { handleError } from './chunk-
|
|
3
|
-
import {
|
|
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
|
|
@@ -38,9 +39,7 @@ async function generateSpeechHandler({
|
|
|
38
39
|
throw new HTTPException(400, { message: "Agent ID is required" });
|
|
39
40
|
}
|
|
40
41
|
validateBody({
|
|
41
|
-
text:
|
|
42
|
-
speakerId: void 0,
|
|
43
|
-
...body
|
|
42
|
+
text: body?.text
|
|
44
43
|
});
|
|
45
44
|
const agent = mastra.getAgent(agentId);
|
|
46
45
|
if (!agent) {
|
|
@@ -53,12 +52,7 @@ async function generateSpeechHandler({
|
|
|
53
52
|
if (!audioStream) {
|
|
54
53
|
throw new HTTPException(500, { message: "Failed to generate speech" });
|
|
55
54
|
}
|
|
56
|
-
|
|
57
|
-
for await (const chunk of audioStream) {
|
|
58
|
-
chunks.push(Buffer.isBuffer(chunk) ? chunk : Buffer.from(chunk));
|
|
59
|
-
}
|
|
60
|
-
const audioData = Buffer.concat(chunks);
|
|
61
|
-
return { audioData };
|
|
55
|
+
return audioStream;
|
|
62
56
|
} catch (error) {
|
|
63
57
|
return handleError(error, "Error generating speech");
|
|
64
58
|
}
|