@mastra/server 0.0.0-fix-message-embedding-20250506021742 → 0.0.0-fix-generate-title-20250616171351

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 (85) hide show
  1. package/README.md +48 -135
  2. package/dist/_tsup-dts-rollup.d.cts +296 -100
  3. package/dist/_tsup-dts-rollup.d.ts +296 -100
  4. package/dist/{chunk-5JNVY6DU.js → chunk-2HXKRRNS.js} +7 -5
  5. package/dist/{chunk-Y3SV5XK4.js → chunk-4O23XCE5.js} +94 -13
  6. package/dist/{chunk-4JINXASC.js → chunk-55DOQLP6.js} +5 -4
  7. package/dist/{chunk-QN4KF3BH.cjs → chunk-57CJTIPW.cjs} +2 -2
  8. package/dist/{chunk-ZLBRQFDD.cjs → chunk-64U3UDTH.cjs} +2 -2
  9. package/dist/{chunk-2FJURXCL.cjs → chunk-6TJSHFCJ.cjs} +44 -36
  10. package/dist/chunk-75ZPJI57.cjs +9 -0
  11. package/dist/chunk-ASKESBJW.cjs +2004 -0
  12. package/dist/{chunk-AMVOS7YB.cjs → chunk-B4MQFJ7G.cjs} +12 -8
  13. package/dist/{chunk-BPL2CBLV.js → chunk-BFOA2QQY.js} +8 -4
  14. package/dist/{chunk-M56ECCHK.cjs → chunk-BNEY4P4P.cjs} +20 -19
  15. package/dist/{chunk-QJ3AHN64.js → chunk-C7564HUT.js} +4 -3
  16. package/dist/chunk-C75ZRJKD.cjs +270 -0
  17. package/dist/{chunk-3XTEV33Q.js → chunk-CLYX4KLH.js} +54 -51
  18. package/dist/{chunk-55HTWX4C.cjs → chunk-CMMOIUFC.cjs} +40 -19
  19. package/dist/{chunk-Q6SHQECN.js → chunk-CP55EVBK.js} +24 -4
  20. package/dist/chunk-FRXZL32L.cjs +471 -0
  21. package/dist/chunk-GHC4YV6R.js +504 -0
  22. package/dist/{chunk-L7XE5QTW.js → chunk-H5PTF3Y4.js} +1 -1
  23. package/dist/{chunk-RBQASTUP.js → chunk-I7KJZNX5.js} +14 -6
  24. package/dist/chunk-IMBY5XUG.cjs +86 -0
  25. package/dist/{chunk-IQTNZSFP.js → chunk-JKTNRUKY.js} +194 -49
  26. package/dist/{chunk-3AHQ5RGN.js → chunk-M5ABIP7D.js} +1 -1
  27. package/dist/chunk-MLKGABMK.js +7 -0
  28. package/dist/{chunk-D3G23FP3.cjs → chunk-NGURCFEJ.cjs} +24 -22
  29. package/dist/{chunk-TRDNDNGQ.js → chunk-NYN7KFXL.js} +1 -7
  30. package/dist/{chunk-FV45V6WC.cjs → chunk-OCWPVYNI.cjs} +0 -7
  31. package/dist/chunk-QLG2PFHE.js +81 -0
  32. package/dist/chunk-SDPGVWQJ.cjs +512 -0
  33. package/dist/chunk-TGJMNUYJ.js +2001 -0
  34. package/dist/{chunk-5YGDYMRB.cjs → chunk-VPNDC2DI.cjs} +14 -13
  35. package/dist/chunk-WE32JG64.cjs +332 -0
  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/legacyWorkflows.cjs +46 -0
  45. package/dist/server/handlers/legacyWorkflows.d.cts +10 -0
  46. package/dist/server/handlers/legacyWorkflows.d.ts +10 -0
  47. package/dist/server/handlers/legacyWorkflows.js +1 -0
  48. package/dist/server/handlers/logs.cjs +4 -4
  49. package/dist/server/handlers/logs.js +1 -1
  50. package/dist/server/handlers/memory.cjs +9 -9
  51. package/dist/server/handlers/memory.js +1 -1
  52. package/dist/server/handlers/network.cjs +5 -5
  53. package/dist/server/handlers/network.js +1 -1
  54. package/dist/server/handlers/telemetry.cjs +3 -3
  55. package/dist/server/handlers/telemetry.js +1 -1
  56. package/dist/server/handlers/tools.cjs +5 -5
  57. package/dist/server/handlers/tools.js +1 -1
  58. package/dist/server/handlers/utils.cjs +2 -2
  59. package/dist/server/handlers/utils.js +1 -1
  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 +8 -4
  63. package/dist/server/handlers/voice.d.cts +1 -0
  64. package/dist/server/handlers/voice.d.ts +1 -0
  65. package/dist/server/handlers/voice.js +1 -1
  66. package/dist/server/handlers/workflows.cjs +21 -13
  67. package/dist/server/handlers/workflows.d.cts +4 -2
  68. package/dist/server/handlers/workflows.d.ts +4 -2
  69. package/dist/server/handlers/workflows.js +1 -1
  70. package/dist/server/handlers.cjs +32 -27
  71. package/dist/server/handlers.d.cts +2 -1
  72. package/dist/server/handlers.d.ts +2 -1
  73. package/dist/server/handlers.js +11 -10
  74. package/package.json +13 -12
  75. package/dist/chunk-3EJZQ6TQ.js +0 -49
  76. package/dist/chunk-4BIX6GMY.cjs +0 -189
  77. package/dist/chunk-5SWCVTNL.cjs +0 -5579
  78. package/dist/chunk-CHFORQ7J.cjs +0 -329
  79. package/dist/chunk-FOXHTOQZ.cjs +0 -324
  80. package/dist/chunk-OMN3UI6X.js +0 -5576
  81. package/dist/chunk-SKBVVI24.cjs +0 -54
  82. package/dist/server/handlers/vNextWorkflows.cjs +0 -46
  83. package/dist/server/handlers/vNextWorkflows.d.cts +0 -10
  84. package/dist/server/handlers/vNextWorkflows.d.ts +0 -10
  85. package/dist/server/handlers/vNextWorkflows.js +0 -1
@@ -1,25 +1,26 @@
1
- import { stringify, esm_default } from './chunk-OMN3UI6X.js';
2
- import { handleError } from './chunk-3AHQ5RGN.js';
3
- import { __export, HTTPException } from './chunk-TRDNDNGQ.js';
4
- import { ReadableStream } from 'node:stream/web';
1
+ import { stringify, esm_default } from './chunk-TGJMNUYJ.js';
2
+ import { handleError } from './chunk-M5ABIP7D.js';
3
+ import { HTTPException } from './chunk-NYN7KFXL.js';
4
+ import { __export } from './chunk-MLKGABMK.js';
5
+ import { ReadableStream } from 'stream/web';
5
6
 
6
- // src/server/handlers/workflows.ts
7
- var workflows_exports = {};
8
- __export(workflows_exports, {
9
- createRunHandler: () => createRunHandler,
10
- getWorkflowByIdHandler: () => getWorkflowByIdHandler,
11
- getWorkflowRunHandler: () => getWorkflowRunHandler,
12
- getWorkflowRunsHandler: () => getWorkflowRunsHandler,
13
- getWorkflowsHandler: () => getWorkflowsHandler,
14
- resumeAsyncWorkflowHandler: () => resumeAsyncWorkflowHandler,
15
- resumeWorkflowHandler: () => resumeWorkflowHandler,
16
- startAsyncWorkflowHandler: () => startAsyncWorkflowHandler,
17
- startWorkflowRunHandler: () => startWorkflowRunHandler,
18
- watchWorkflowHandler: () => watchWorkflowHandler
7
+ // src/server/handlers/legacyWorkflows.ts
8
+ var legacyWorkflows_exports = {};
9
+ __export(legacyWorkflows_exports, {
10
+ createLegacyWorkflowRunHandler: () => createLegacyWorkflowRunHandler,
11
+ getLegacyWorkflowByIdHandler: () => getLegacyWorkflowByIdHandler,
12
+ getLegacyWorkflowRunHandler: () => getLegacyWorkflowRunHandler,
13
+ getLegacyWorkflowRunsHandler: () => getLegacyWorkflowRunsHandler,
14
+ getLegacyWorkflowsHandler: () => getLegacyWorkflowsHandler,
15
+ resumeAsyncLegacyWorkflowHandler: () => resumeAsyncLegacyWorkflowHandler,
16
+ resumeLegacyWorkflowHandler: () => resumeLegacyWorkflowHandler,
17
+ startAsyncLegacyWorkflowHandler: () => startAsyncLegacyWorkflowHandler,
18
+ startLegacyWorkflowRunHandler: () => startLegacyWorkflowRunHandler,
19
+ watchLegacyWorkflowHandler: () => watchLegacyWorkflowHandler
19
20
  });
20
- async function getWorkflowsHandler({ mastra }) {
21
+ async function getLegacyWorkflowsHandler({ mastra }) {
21
22
  try {
22
- const workflows = mastra.getWorkflows({ serialized: false });
23
+ const workflows = mastra.legacy_getWorkflows({ serialized: false });
23
24
  const _workflows = Object.entries(workflows).reduce((acc, [key, workflow]) => {
24
25
  if (workflow.isNested) return acc;
25
26
  acc[key] = {
@@ -48,12 +49,12 @@ async function getWorkflowsHandler({ mastra }) {
48
49
  throw new HTTPException(500, { message: error?.message || "Error getting workflows" });
49
50
  }
50
51
  }
51
- async function getWorkflowByIdHandler({ mastra, workflowId }) {
52
+ async function getLegacyWorkflowByIdHandler({ mastra, workflowId }) {
52
53
  try {
53
54
  if (!workflowId) {
54
55
  throw new HTTPException(400, { message: "Workflow ID is required" });
55
56
  }
56
- const workflow = mastra.getWorkflow(workflowId);
57
+ const workflow = mastra.legacy_getWorkflow(workflowId);
57
58
  if (!workflow) {
58
59
  throw new HTTPException(404, { message: "Workflow not found" });
59
60
  }
@@ -80,7 +81,7 @@ async function getWorkflowByIdHandler({ mastra, workflowId }) {
80
81
  throw new HTTPException(500, { message: error?.message || "Error getting workflow" });
81
82
  }
82
83
  }
83
- async function startAsyncWorkflowHandler({
84
+ async function startAsyncLegacyWorkflowHandler({
84
85
  mastra,
85
86
  runtimeContext,
86
87
  workflowId,
@@ -91,19 +92,19 @@ async function startAsyncWorkflowHandler({
91
92
  if (!workflowId) {
92
93
  throw new HTTPException(400, { message: "Workflow ID is required" });
93
94
  }
94
- const workflow = mastra.getWorkflow(workflowId);
95
+ const workflow = mastra.legacy_getWorkflow(workflowId);
95
96
  if (!workflow) {
96
97
  throw new HTTPException(404, { message: "Workflow not found" });
97
98
  }
98
99
  if (!runId) {
99
- const { start } = workflow.createRun();
100
- const result2 = await start({
100
+ const newRun = workflow.createRun();
101
+ const result2 = await newRun.start({
101
102
  triggerData,
102
103
  runtimeContext
103
104
  });
104
105
  return result2;
105
106
  }
106
- const run = workflow.getRun(runId);
107
+ const run = workflow.getMemoryRun(runId);
107
108
  if (!run) {
108
109
  throw new HTTPException(404, { message: "Workflow run not found" });
109
110
  }
@@ -116,7 +117,7 @@ async function startAsyncWorkflowHandler({
116
117
  throw new HTTPException(500, { message: error?.message || "Error executing workflow" });
117
118
  }
118
119
  }
119
- async function getWorkflowRunHandler({
120
+ async function getLegacyWorkflowRunHandler({
120
121
  mastra,
121
122
  workflowId,
122
123
  runId
@@ -128,11 +129,11 @@ async function getWorkflowRunHandler({
128
129
  if (!runId) {
129
130
  throw new HTTPException(400, { message: "Run ID is required" });
130
131
  }
131
- const workflow = mastra.getWorkflow(workflowId);
132
+ const workflow = mastra.legacy_getWorkflow(workflowId);
132
133
  if (!workflow) {
133
134
  throw new HTTPException(404, { message: "Workflow not found" });
134
135
  }
135
- const run = workflow.getRun(runId);
136
+ const run = await workflow.getRun(runId);
136
137
  if (!run) {
137
138
  throw new HTTPException(404, { message: "Workflow run not found" });
138
139
  }
@@ -141,7 +142,7 @@ async function getWorkflowRunHandler({
141
142
  throw new HTTPException(500, { message: error?.message || "Error getting workflow run" });
142
143
  }
143
144
  }
144
- async function createRunHandler({
145
+ async function createLegacyWorkflowRunHandler({
145
146
  mastra,
146
147
  workflowId,
147
148
  runId: prevRunId
@@ -150,17 +151,17 @@ async function createRunHandler({
150
151
  if (!workflowId) {
151
152
  throw new HTTPException(400, { message: "Workflow ID is required" });
152
153
  }
153
- const workflow = mastra.getWorkflow(workflowId);
154
+ const workflow = mastra.legacy_getWorkflow(workflowId);
154
155
  if (!workflow) {
155
156
  throw new HTTPException(404, { message: "Workflow not found" });
156
157
  }
157
- const { runId } = workflow.createRun({ runId: prevRunId });
158
- return { runId };
158
+ const newRun = workflow.createRun({ runId: prevRunId });
159
+ return { runId: newRun.runId };
159
160
  } catch (error) {
160
161
  throw new HTTPException(500, { message: error?.message || "Error creating workflow run" });
161
162
  }
162
163
  }
163
- async function startWorkflowRunHandler({
164
+ async function startLegacyWorkflowRunHandler({
164
165
  mastra,
165
166
  runtimeContext,
166
167
  workflowId,
@@ -174,12 +175,12 @@ async function startWorkflowRunHandler({
174
175
  if (!runId) {
175
176
  throw new HTTPException(400, { message: "runId required to start run" });
176
177
  }
177
- const workflow = mastra.getWorkflow(workflowId);
178
- const run = workflow.getRun(runId);
178
+ const workflow = mastra.legacy_getWorkflow(workflowId);
179
+ const run = workflow.getMemoryRun(runId);
179
180
  if (!run) {
180
181
  throw new HTTPException(404, { message: "Workflow run not found" });
181
182
  }
182
- await run.start({
183
+ void run.start({
183
184
  triggerData,
184
185
  runtimeContext
185
186
  });
@@ -188,7 +189,7 @@ async function startWorkflowRunHandler({
188
189
  return handleError(e, "Error starting workflow run");
189
190
  }
190
191
  }
191
- async function watchWorkflowHandler({
192
+ async function watchLegacyWorkflowHandler({
192
193
  mastra,
193
194
  workflowId,
194
195
  runId
@@ -200,8 +201,8 @@ async function watchWorkflowHandler({
200
201
  if (!runId) {
201
202
  throw new HTTPException(400, { message: "runId required to watch workflow" });
202
203
  }
203
- const workflow = mastra.getWorkflow(workflowId);
204
- const run = workflow.getRun(runId);
204
+ const workflow = mastra.legacy_getWorkflow(workflowId);
205
+ const run = workflow.getMemoryRun(runId);
205
206
  if (!run) {
206
207
  throw new HTTPException(404, { message: "Workflow run not found" });
207
208
  }
@@ -217,8 +218,10 @@ async function watchWorkflowHandler({
217
218
  asyncRef = null;
218
219
  }
219
220
  asyncRef = setImmediate(() => {
220
- if (!workflow.getRun(runId2)) {
221
+ const runDone = Object.values(activePathsObj).every((value) => value.status !== "executing");
222
+ if (runDone) {
221
223
  controller.close();
224
+ unwatch?.();
222
225
  }
223
226
  });
224
227
  });
@@ -232,7 +235,7 @@ async function watchWorkflowHandler({
232
235
  return handleError(error, "Error watching workflow");
233
236
  }
234
237
  }
235
- async function resumeAsyncWorkflowHandler({
238
+ async function resumeAsyncLegacyWorkflowHandler({
236
239
  mastra,
237
240
  workflowId,
238
241
  runId,
@@ -246,8 +249,8 @@ async function resumeAsyncWorkflowHandler({
246
249
  if (!runId) {
247
250
  throw new HTTPException(400, { message: "runId required to resume workflow" });
248
251
  }
249
- const workflow = mastra.getWorkflow(workflowId);
250
- const run = workflow.getRun(runId);
252
+ const workflow = mastra.legacy_getWorkflow(workflowId);
253
+ const run = workflow.getMemoryRun(runId);
251
254
  if (!run) {
252
255
  throw new HTTPException(404, { message: "Workflow run not found" });
253
256
  }
@@ -261,7 +264,7 @@ async function resumeAsyncWorkflowHandler({
261
264
  return handleError(error, "Error resuming workflow step");
262
265
  }
263
266
  }
264
- async function resumeWorkflowHandler({
267
+ async function resumeLegacyWorkflowHandler({
265
268
  mastra,
266
269
  workflowId,
267
270
  runId,
@@ -275,12 +278,12 @@ async function resumeWorkflowHandler({
275
278
  if (!runId) {
276
279
  throw new HTTPException(400, { message: "runId required to resume workflow" });
277
280
  }
278
- const workflow = mastra.getWorkflow(workflowId);
279
- const run = workflow.getRun(runId);
281
+ const workflow = mastra.legacy_getWorkflow(workflowId);
282
+ const run = workflow.getMemoryRun(runId);
280
283
  if (!run) {
281
284
  throw new HTTPException(404, { message: "Workflow run not found" });
282
285
  }
283
- await run.resume({
286
+ void run.resume({
284
287
  stepId: body.stepId,
285
288
  context: body.context,
286
289
  runtimeContext
@@ -290,7 +293,7 @@ async function resumeWorkflowHandler({
290
293
  return handleError(error, "Error resuming workflow");
291
294
  }
292
295
  }
293
- async function getWorkflowRunsHandler({
296
+ async function getLegacyWorkflowRunsHandler({
294
297
  mastra,
295
298
  workflowId,
296
299
  fromDate,
@@ -303,7 +306,7 @@ async function getWorkflowRunsHandler({
303
306
  if (!workflowId) {
304
307
  throw new HTTPException(400, { message: "Workflow ID is required" });
305
308
  }
306
- const workflow = mastra.getWorkflow(workflowId);
309
+ const workflow = mastra.legacy_getWorkflow(workflowId);
307
310
  const workflowRuns = await workflow.getWorkflowRuns({ fromDate, toDate, limit, offset, resourceId }) || {
308
311
  runs: [],
309
312
  total: 0
@@ -314,4 +317,4 @@ async function getWorkflowRunsHandler({
314
317
  }
315
318
  }
316
319
 
317
- export { createRunHandler, getWorkflowByIdHandler, getWorkflowRunHandler, getWorkflowRunsHandler, getWorkflowsHandler, resumeAsyncWorkflowHandler, resumeWorkflowHandler, startAsyncWorkflowHandler, startWorkflowRunHandler, watchWorkflowHandler, workflows_exports };
320
+ export { createLegacyWorkflowRunHandler, getLegacyWorkflowByIdHandler, getLegacyWorkflowRunHandler, getLegacyWorkflowRunsHandler, getLegacyWorkflowsHandler, legacyWorkflows_exports, resumeAsyncLegacyWorkflowHandler, resumeLegacyWorkflowHandler, startAsyncLegacyWorkflowHandler, startLegacyWorkflowRunHandler, watchLegacyWorkflowHandler };
@@ -1,33 +1,35 @@
1
1
  'use strict';
2
2
 
3
- var chunkQN4KF3BH_cjs = require('./chunk-QN4KF3BH.cjs');
4
- var chunkZLBRQFDD_cjs = require('./chunk-ZLBRQFDD.cjs');
5
- var chunkFV45V6WC_cjs = require('./chunk-FV45V6WC.cjs');
3
+ var chunk57CJTIPW_cjs = require('./chunk-57CJTIPW.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');
6
7
  var stream = require('stream');
7
8
 
8
9
  // src/server/handlers/voice.ts
9
10
  var voice_exports = {};
10
- chunkFV45V6WC_cjs.__export(voice_exports, {
11
+ chunk75ZPJI57_cjs.__export(voice_exports, {
11
12
  generateSpeechHandler: () => generateSpeechHandler,
13
+ getListenerHandler: () => getListenerHandler,
12
14
  getSpeakersHandler: () => getSpeakersHandler,
13
15
  transcribeSpeechHandler: () => transcribeSpeechHandler
14
16
  });
15
17
  async function getSpeakersHandler({ mastra, agentId }) {
16
18
  try {
17
19
  if (!agentId) {
18
- throw new chunkFV45V6WC_cjs.HTTPException(400, { message: "Agent ID is required" });
20
+ throw new chunkOCWPVYNI_cjs.HTTPException(400, { message: "Agent ID is required" });
19
21
  }
20
22
  const agent = mastra.getAgent(agentId);
21
23
  if (!agent) {
22
- throw new chunkFV45V6WC_cjs.HTTPException(404, { message: "Agent not found" });
24
+ throw new chunkOCWPVYNI_cjs.HTTPException(404, { message: "Agent not found" });
23
25
  }
24
26
  if (!agent.voice) {
25
- throw new chunkFV45V6WC_cjs.HTTPException(400, { message: "Agent does not have voice capabilities" });
27
+ throw new chunkOCWPVYNI_cjs.HTTPException(400, { message: "Agent does not have voice capabilities" });
26
28
  }
27
29
  const speakers = await agent.voice.getSpeakers();
28
30
  return speakers;
29
31
  } catch (error) {
30
- return chunkZLBRQFDD_cjs.handleError(error, "Error getting speakers");
32
+ return chunk64U3UDTH_cjs.handleError(error, "Error getting speakers");
31
33
  }
32
34
  }
33
35
  async function generateSpeechHandler({
@@ -37,25 +39,25 @@ async function generateSpeechHandler({
37
39
  }) {
38
40
  try {
39
41
  if (!agentId) {
40
- throw new chunkFV45V6WC_cjs.HTTPException(400, { message: "Agent ID is required" });
42
+ throw new chunkOCWPVYNI_cjs.HTTPException(400, { message: "Agent ID is required" });
41
43
  }
42
- chunkQN4KF3BH_cjs.validateBody({
44
+ chunk57CJTIPW_cjs.validateBody({
43
45
  text: body?.text
44
46
  });
45
47
  const agent = mastra.getAgent(agentId);
46
48
  if (!agent) {
47
- throw new chunkFV45V6WC_cjs.HTTPException(404, { message: "Agent not found" });
49
+ throw new chunkOCWPVYNI_cjs.HTTPException(404, { message: "Agent not found" });
48
50
  }
49
51
  if (!agent.voice) {
50
- throw new chunkFV45V6WC_cjs.HTTPException(400, { message: "Agent does not have voice capabilities" });
52
+ throw new chunkOCWPVYNI_cjs.HTTPException(400, { message: "Agent does not have voice capabilities" });
51
53
  }
52
54
  const audioStream = await agent.voice.speak(body.text, { speaker: body.speakerId });
53
55
  if (!audioStream) {
54
- throw new chunkFV45V6WC_cjs.HTTPException(500, { message: "Failed to generate speech" });
56
+ throw new chunkOCWPVYNI_cjs.HTTPException(500, { message: "Failed to generate speech" });
55
57
  }
56
58
  return audioStream;
57
59
  } catch (error) {
58
- return chunkZLBRQFDD_cjs.handleError(error, "Error generating speech");
60
+ return chunk64U3UDTH_cjs.handleError(error, "Error generating speech");
59
61
  }
60
62
  }
61
63
  async function transcribeSpeechHandler({
@@ -65,17 +67,17 @@ async function transcribeSpeechHandler({
65
67
  }) {
66
68
  try {
67
69
  if (!agentId) {
68
- throw new chunkFV45V6WC_cjs.HTTPException(400, { message: "Agent ID is required" });
70
+ throw new chunkOCWPVYNI_cjs.HTTPException(400, { message: "Agent ID is required" });
69
71
  }
70
72
  if (!body?.audioData) {
71
- throw new chunkFV45V6WC_cjs.HTTPException(400, { message: "Audio data is required" });
73
+ throw new chunkOCWPVYNI_cjs.HTTPException(400, { message: "Audio data is required" });
72
74
  }
73
75
  const agent = mastra.getAgent(agentId);
74
76
  if (!agent) {
75
- throw new chunkFV45V6WC_cjs.HTTPException(404, { message: "Agent not found" });
77
+ throw new chunkOCWPVYNI_cjs.HTTPException(404, { message: "Agent not found" });
76
78
  }
77
79
  if (!agent.voice) {
78
- throw new chunkFV45V6WC_cjs.HTTPException(400, { message: "Agent does not have voice capabilities" });
80
+ throw new chunkOCWPVYNI_cjs.HTTPException(400, { message: "Agent does not have voice capabilities" });
79
81
  }
80
82
  const audioStream = new stream.Readable();
81
83
  audioStream.push(body.audioData);
@@ -83,11 +85,30 @@ async function transcribeSpeechHandler({
83
85
  const text = await agent.voice.listen(audioStream, body.options);
84
86
  return { text };
85
87
  } catch (error) {
86
- return chunkZLBRQFDD_cjs.handleError(error, "Error transcribing speech");
88
+ return chunk64U3UDTH_cjs.handleError(error, "Error transcribing speech");
89
+ }
90
+ }
91
+ async function getListenerHandler({ mastra, agentId }) {
92
+ try {
93
+ if (!agentId) {
94
+ throw new chunkOCWPVYNI_cjs.HTTPException(400, { message: "Agent ID is required" });
95
+ }
96
+ const agent = mastra.getAgent(agentId);
97
+ if (!agent) {
98
+ throw new chunkOCWPVYNI_cjs.HTTPException(404, { message: "Agent not found" });
99
+ }
100
+ if (!agent.voice) {
101
+ throw new chunkOCWPVYNI_cjs.HTTPException(400, { message: "Agent does not have voice capabilities" });
102
+ }
103
+ const listeners = await agent.voice.getListener();
104
+ return listeners;
105
+ } catch (error) {
106
+ return chunk64U3UDTH_cjs.handleError(error, "Error getting listeners");
87
107
  }
88
108
  }
89
109
 
90
110
  exports.generateSpeechHandler = generateSpeechHandler;
111
+ exports.getListenerHandler = getListenerHandler;
91
112
  exports.getSpeakersHandler = getSpeakersHandler;
92
113
  exports.transcribeSpeechHandler = transcribeSpeechHandler;
93
114
  exports.voice_exports = voice_exports;
@@ -1,12 +1,14 @@
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
7
8
  var voice_exports = {};
8
9
  __export(voice_exports, {
9
10
  generateSpeechHandler: () => generateSpeechHandler,
11
+ getListenerHandler: () => getListenerHandler,
10
12
  getSpeakersHandler: () => getSpeakersHandler,
11
13
  transcribeSpeechHandler: () => transcribeSpeechHandler
12
14
  });
@@ -84,5 +86,23 @@ async function transcribeSpeechHandler({
84
86
  return handleError(error, "Error transcribing speech");
85
87
  }
86
88
  }
89
+ async function getListenerHandler({ mastra, agentId }) {
90
+ try {
91
+ if (!agentId) {
92
+ throw new HTTPException(400, { message: "Agent ID is required" });
93
+ }
94
+ const agent = mastra.getAgent(agentId);
95
+ if (!agent) {
96
+ throw new HTTPException(404, { message: "Agent not found" });
97
+ }
98
+ if (!agent.voice) {
99
+ throw new HTTPException(400, { message: "Agent does not have voice capabilities" });
100
+ }
101
+ const listeners = await agent.voice.getListener();
102
+ return listeners;
103
+ } catch (error) {
104
+ return handleError(error, "Error getting listeners");
105
+ }
106
+ }
87
107
 
88
- export { generateSpeechHandler, getSpeakersHandler, transcribeSpeechHandler, voice_exports };
108
+ export { generateSpeechHandler, getListenerHandler, getSpeakersHandler, transcribeSpeechHandler, voice_exports };