@mastra/server 0.0.0-fix-memory-xxhash-20250409202110 → 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 (84) hide show
  1. package/{LICENSE → LICENSE.md} +3 -1
  2. package/README.md +48 -135
  3. package/dist/_tsup-dts-rollup.d.cts +357 -57
  4. package/dist/_tsup-dts-rollup.d.ts +357 -57
  5. package/dist/{chunk-YNSGUC2O.js → chunk-2HXKRRNS.js} +14 -8
  6. package/dist/chunk-4O23XCE5.js +262 -0
  7. package/dist/{chunk-4JINXASC.js → chunk-55DOQLP6.js} +5 -4
  8. package/dist/{chunk-QN4KF3BH.cjs → chunk-57CJTIPW.cjs} +2 -2
  9. package/dist/{chunk-ZLBRQFDD.cjs → chunk-64U3UDTH.cjs} +2 -2
  10. package/dist/{chunk-2FJURXCL.cjs → chunk-6TJSHFCJ.cjs} +44 -36
  11. package/dist/chunk-75ZPJI57.cjs +9 -0
  12. package/dist/chunk-ASKESBJW.cjs +2004 -0
  13. package/dist/{chunk-CWSDZEZG.cjs → chunk-B4MQFJ7G.cjs} +18 -12
  14. package/dist/{chunk-DVPP5S6I.js → chunk-BFOA2QQY.js} +14 -8
  15. package/dist/{chunk-M56ECCHK.cjs → chunk-BNEY4P4P.cjs} +20 -19
  16. package/dist/{chunk-2YONKUWB.js → chunk-C7564HUT.js} +58 -33
  17. package/dist/chunk-C75ZRJKD.cjs +270 -0
  18. package/dist/{chunk-ILW7XYNJ.js → chunk-CLYX4KLH.js} +85 -61
  19. package/dist/chunk-CMMOIUFC.cjs +114 -0
  20. package/dist/{chunk-3RVHWGWO.js → chunk-CP55EVBK.js} +26 -13
  21. package/dist/chunk-FRXZL32L.cjs +471 -0
  22. package/dist/chunk-GHC4YV6R.js +504 -0
  23. package/dist/{chunk-L7XE5QTW.js → chunk-H5PTF3Y4.js} +1 -1
  24. package/dist/{chunk-RBQASTUP.js → chunk-I7KJZNX5.js} +14 -6
  25. package/dist/chunk-IMBY5XUG.cjs +86 -0
  26. package/dist/chunk-JKTNRUKY.js +457 -0
  27. package/dist/{chunk-3AHQ5RGN.js → chunk-M5ABIP7D.js} +1 -1
  28. package/dist/chunk-MLKGABMK.js +7 -0
  29. package/dist/{chunk-4C3EPMMF.cjs → chunk-NGURCFEJ.cjs} +31 -25
  30. package/dist/{chunk-TRDNDNGQ.js → chunk-NYN7KFXL.js} +1 -7
  31. package/dist/{chunk-FV45V6WC.cjs → chunk-OCWPVYNI.cjs} +0 -7
  32. package/dist/chunk-QLG2PFHE.js +81 -0
  33. package/dist/chunk-SDPGVWQJ.cjs +512 -0
  34. package/dist/chunk-TGJMNUYJ.js +2001 -0
  35. package/dist/chunk-VPNDC2DI.cjs +148 -0
  36. package/dist/chunk-WE32JG64.cjs +332 -0
  37. package/dist/server/handlers/a2a.cjs +30 -0
  38. package/dist/server/handlers/a2a.d.cts +6 -0
  39. package/dist/server/handlers/a2a.d.ts +6 -0
  40. package/dist/server/handlers/a2a.js +1 -0
  41. package/dist/server/handlers/agents.cjs +7 -7
  42. package/dist/server/handlers/agents.js +1 -1
  43. package/dist/server/handlers/error.cjs +2 -2
  44. package/dist/server/handlers/error.js +1 -1
  45. package/dist/server/handlers/legacyWorkflows.cjs +46 -0
  46. package/dist/server/handlers/legacyWorkflows.d.cts +10 -0
  47. package/dist/server/handlers/legacyWorkflows.d.ts +10 -0
  48. package/dist/server/handlers/legacyWorkflows.js +1 -0
  49. package/dist/server/handlers/logs.cjs +4 -4
  50. package/dist/server/handlers/logs.js +1 -1
  51. package/dist/server/handlers/memory.cjs +9 -9
  52. package/dist/server/handlers/memory.js +1 -1
  53. package/dist/server/handlers/network.cjs +5 -5
  54. package/dist/server/handlers/network.js +1 -1
  55. package/dist/server/handlers/telemetry.cjs +3 -3
  56. package/dist/server/handlers/telemetry.js +1 -1
  57. package/dist/server/handlers/tools.cjs +5 -5
  58. package/dist/server/handlers/tools.js +1 -1
  59. package/dist/server/handlers/utils.cjs +2 -2
  60. package/dist/server/handlers/utils.js +1 -1
  61. package/dist/server/handlers/vector.cjs +7 -7
  62. package/dist/server/handlers/vector.js +1 -1
  63. package/dist/server/handlers/voice.cjs +8 -4
  64. package/dist/server/handlers/voice.d.cts +1 -0
  65. package/dist/server/handlers/voice.d.ts +1 -0
  66. package/dist/server/handlers/voice.js +1 -1
  67. package/dist/server/handlers/workflows.cjs +21 -13
  68. package/dist/server/handlers/workflows.d.cts +4 -2
  69. package/dist/server/handlers/workflows.d.ts +4 -2
  70. package/dist/server/handlers/workflows.js +1 -1
  71. package/dist/server/handlers.cjs +33 -23
  72. package/dist/server/handlers.d.cts +2 -0
  73. package/dist/server/handlers.d.ts +2 -0
  74. package/dist/server/handlers.js +11 -9
  75. package/package.json +14 -13
  76. package/dist/chunk-2JQC6JWP.js +0 -46
  77. package/dist/chunk-5JOF627H.cjs +0 -123
  78. package/dist/chunk-A7DF4ETD.cjs +0 -100
  79. package/dist/chunk-BMA2ORRT.js +0 -152
  80. package/dist/chunk-GV52BII2.cjs +0 -160
  81. package/dist/chunk-QH6XWSXP.cjs +0 -5579
  82. package/dist/chunk-VB7KH62D.cjs +0 -51
  83. package/dist/chunk-VK6FX47H.js +0 -5576
  84. package/dist/chunk-X37I6GZT.cjs +0 -308
@@ -1,11 +1,12 @@
1
1
  'use strict';
2
2
 
3
- var chunkZLBRQFDD_cjs = require('./chunk-ZLBRQFDD.cjs');
4
- var chunkFV45V6WC_cjs = require('./chunk-FV45V6WC.cjs');
3
+ var chunk64U3UDTH_cjs = require('./chunk-64U3UDTH.cjs');
4
+ var chunkOCWPVYNI_cjs = require('./chunk-OCWPVYNI.cjs');
5
+ var chunk75ZPJI57_cjs = require('./chunk-75ZPJI57.cjs');
5
6
 
6
7
  // src/server/handlers/telemetry.ts
7
8
  var telemetry_exports = {};
8
- chunkFV45V6WC_cjs.__export(telemetry_exports, {
9
+ chunk75ZPJI57_cjs.__export(telemetry_exports, {
9
10
  getTelemetryHandler: () => getTelemetryHandler,
10
11
  storeTelemetryHandler: () => storeTelemetryHandler
11
12
  });
@@ -14,31 +15,33 @@ async function getTelemetryHandler({ mastra, body }) {
14
15
  const telemetry = mastra.getTelemetry();
15
16
  const storage = mastra.getStorage();
16
17
  if (!telemetry) {
17
- throw new chunkFV45V6WC_cjs.HTTPException(400, { message: "Telemetry is not initialized" });
18
+ throw new chunkOCWPVYNI_cjs.HTTPException(400, { message: "Telemetry is not initialized" });
18
19
  }
19
20
  if (!storage) {
20
- throw new chunkFV45V6WC_cjs.HTTPException(400, { message: "Storage is not initialized" });
21
+ return [];
21
22
  }
22
23
  if (!body) {
23
- throw new chunkFV45V6WC_cjs.HTTPException(400, { message: "Body is required" });
24
+ throw new chunkOCWPVYNI_cjs.HTTPException(400, { message: "Body is required" });
24
25
  }
25
- const { name, scope, page, perPage, attribute } = body;
26
+ const { name, scope, page, perPage, attribute, fromDate, toDate } = body;
26
27
  const attributes = attribute ? Object.fromEntries(
27
28
  (Array.isArray(attribute) ? attribute : [attribute]).map((attr) => {
28
29
  const [key, value] = attr.split(":");
29
30
  return [key, value];
30
31
  })
31
32
  ) : void 0;
32
- const traces = await storage.__getTraces({
33
+ const traces = await storage.getTraces({
33
34
  name,
34
35
  scope,
35
36
  page: Number(page ?? 0),
36
37
  perPage: Number(perPage ?? 100),
37
- attributes
38
+ attributes,
39
+ fromDate: fromDate ? new Date(fromDate) : void 0,
40
+ toDate: toDate ? new Date(toDate) : void 0
38
41
  });
39
42
  return traces;
40
43
  } catch (error2) {
41
- return chunkZLBRQFDD_cjs.handleError(error2, "Error getting telemetry");
44
+ return chunk64U3UDTH_cjs.handleError(error2, "Error getting telemetry");
42
45
  }
43
46
  }
44
47
  async function storeTelemetryHandler({ mastra, body }) {
@@ -46,7 +49,10 @@ async function storeTelemetryHandler({ mastra, body }) {
46
49
  const storage = mastra.getStorage();
47
50
  const logger = mastra.getLogger();
48
51
  if (!storage) {
49
- throw new chunkFV45V6WC_cjs.HTTPException(400, { message: "Storage is not initialized" });
52
+ return {
53
+ status: "error",
54
+ message: "Storage is not initialized"
55
+ };
50
56
  }
51
57
  const now = /* @__PURE__ */ new Date();
52
58
  const items = body?.resourceSpans?.[0]?.scopeSpans;
@@ -107,7 +113,7 @@ async function storeTelemetryHandler({ mastra, body }) {
107
113
  }
108
114
  return acc;
109
115
  }, []);
110
- return storage.__batchTraceInsert({
116
+ return storage.batchTraceInsert({
111
117
  records: allSpans
112
118
  }).then(() => {
113
119
  return {
@@ -1,5 +1,6 @@
1
- import { handleError } from './chunk-3AHQ5RGN.js';
2
- import { __export, HTTPException } from './chunk-TRDNDNGQ.js';
1
+ import { handleError } from './chunk-M5ABIP7D.js';
2
+ import { HTTPException } from './chunk-NYN7KFXL.js';
3
+ import { __export } from './chunk-MLKGABMK.js';
3
4
 
4
5
  // src/server/handlers/telemetry.ts
5
6
  var telemetry_exports = {};
@@ -15,24 +16,26 @@ async function getTelemetryHandler({ mastra, body }) {
15
16
  throw new HTTPException(400, { message: "Telemetry is not initialized" });
16
17
  }
17
18
  if (!storage) {
18
- throw new HTTPException(400, { message: "Storage is not initialized" });
19
+ return [];
19
20
  }
20
21
  if (!body) {
21
22
  throw new HTTPException(400, { message: "Body is required" });
22
23
  }
23
- const { name, scope, page, perPage, attribute } = body;
24
+ const { name, scope, page, perPage, attribute, fromDate, toDate } = body;
24
25
  const attributes = attribute ? Object.fromEntries(
25
26
  (Array.isArray(attribute) ? attribute : [attribute]).map((attr) => {
26
27
  const [key, value] = attr.split(":");
27
28
  return [key, value];
28
29
  })
29
30
  ) : void 0;
30
- const traces = await storage.__getTraces({
31
+ const traces = await storage.getTraces({
31
32
  name,
32
33
  scope,
33
34
  page: Number(page ?? 0),
34
35
  perPage: Number(perPage ?? 100),
35
- attributes
36
+ attributes,
37
+ fromDate: fromDate ? new Date(fromDate) : void 0,
38
+ toDate: toDate ? new Date(toDate) : void 0
36
39
  });
37
40
  return traces;
38
41
  } catch (error2) {
@@ -44,7 +47,10 @@ async function storeTelemetryHandler({ mastra, body }) {
44
47
  const storage = mastra.getStorage();
45
48
  const logger = mastra.getLogger();
46
49
  if (!storage) {
47
- throw new HTTPException(400, { message: "Storage is not initialized" });
50
+ return {
51
+ status: "error",
52
+ message: "Storage is not initialized"
53
+ };
48
54
  }
49
55
  const now = /* @__PURE__ */ new Date();
50
56
  const items = body?.resourceSpans?.[0]?.scopeSpans;
@@ -105,7 +111,7 @@ async function storeTelemetryHandler({ mastra, body }) {
105
111
  }
106
112
  return acc;
107
113
  }, []);
108
- return storage.__batchTraceInsert({
114
+ return storage.batchTraceInsert({
109
115
  records: allSpans
110
116
  }).then(() => {
111
117
  return {
@@ -1,11 +1,12 @@
1
1
  'use strict';
2
2
 
3
- var chunkZLBRQFDD_cjs = require('./chunk-ZLBRQFDD.cjs');
4
- var chunkFV45V6WC_cjs = require('./chunk-FV45V6WC.cjs');
3
+ var chunk64U3UDTH_cjs = require('./chunk-64U3UDTH.cjs');
4
+ var chunkOCWPVYNI_cjs = require('./chunk-OCWPVYNI.cjs');
5
+ var chunk75ZPJI57_cjs = require('./chunk-75ZPJI57.cjs');
5
6
 
6
7
  // src/server/handlers/vector.ts
7
8
  var vector_exports = {};
8
- chunkFV45V6WC_cjs.__export(vector_exports, {
9
+ chunk75ZPJI57_cjs.__export(vector_exports, {
9
10
  createIndex: () => createIndex,
10
11
  deleteIndex: () => deleteIndex,
11
12
  describeIndex: () => describeIndex,
@@ -15,24 +16,24 @@ chunkFV45V6WC_cjs.__export(vector_exports, {
15
16
  });
16
17
  function getVector(mastra, vectorName) {
17
18
  if (!vectorName) {
18
- throw new chunkFV45V6WC_cjs.HTTPException(400, { message: "Vector name is required" });
19
+ throw new chunkOCWPVYNI_cjs.HTTPException(400, { message: "Vector name is required" });
19
20
  }
20
21
  const vector = mastra.getVector(vectorName);
21
22
  if (!vector) {
22
- throw new chunkFV45V6WC_cjs.HTTPException(404, { message: `Vector store ${vectorName} not found` });
23
+ throw new chunkOCWPVYNI_cjs.HTTPException(404, { message: `Vector store ${vectorName} not found` });
23
24
  }
24
25
  return vector;
25
26
  }
26
27
  async function upsertVectors({ mastra, vectorName, index }) {
27
28
  try {
28
29
  if (!index?.indexName || !index?.vectors || !Array.isArray(index.vectors)) {
29
- throw new chunkFV45V6WC_cjs.HTTPException(400, { message: "Invalid request index. indexName and vectors array are required." });
30
+ throw new chunkOCWPVYNI_cjs.HTTPException(400, { message: "Invalid request index. indexName and vectors array are required." });
30
31
  }
31
32
  const vector = getVector(mastra, vectorName);
32
33
  const result = await vector.upsert(index);
33
34
  return { ids: result };
34
35
  } catch (error) {
35
- return chunkZLBRQFDD_cjs.handleError(error, "Error upserting vectors");
36
+ return chunk64U3UDTH_cjs.handleError(error, "Error upserting vectors");
36
37
  }
37
38
  }
38
39
  async function createIndex({
@@ -43,18 +44,18 @@ async function createIndex({
43
44
  try {
44
45
  const { indexName, dimension, metric } = index;
45
46
  if (!indexName || typeof dimension !== "number" || dimension <= 0) {
46
- throw new chunkFV45V6WC_cjs.HTTPException(400, {
47
+ throw new chunkOCWPVYNI_cjs.HTTPException(400, {
47
48
  message: "Invalid request index, indexName and positive dimension number are required."
48
49
  });
49
50
  }
50
51
  if (metric && !["cosine", "euclidean", "dotproduct"].includes(metric)) {
51
- throw new chunkFV45V6WC_cjs.HTTPException(400, { message: "Invalid metric. Must be one of: cosine, euclidean, dotproduct" });
52
+ throw new chunkOCWPVYNI_cjs.HTTPException(400, { message: "Invalid metric. Must be one of: cosine, euclidean, dotproduct" });
52
53
  }
53
54
  const vector = getVector(mastra, vectorName);
54
55
  await vector.createIndex({ indexName, dimension, metric });
55
56
  return { success: true };
56
57
  } catch (error) {
57
- return chunkZLBRQFDD_cjs.handleError(error, "Error creating index");
58
+ return chunk64U3UDTH_cjs.handleError(error, "Error creating index");
58
59
  }
59
60
  }
60
61
  async function queryVectors({
@@ -64,13 +65,13 @@ async function queryVectors({
64
65
  }) {
65
66
  try {
66
67
  if (!query?.indexName || !query?.queryVector || !Array.isArray(query.queryVector)) {
67
- throw new chunkFV45V6WC_cjs.HTTPException(400, { message: "Invalid request query. indexName and queryVector array are required." });
68
+ throw new chunkOCWPVYNI_cjs.HTTPException(400, { message: "Invalid request query. indexName and queryVector array are required." });
68
69
  }
69
70
  const vector = getVector(mastra, vectorName);
70
71
  const results = await vector.query(query);
71
72
  return results;
72
73
  } catch (error) {
73
- return chunkZLBRQFDD_cjs.handleError(error, "Error querying vectors");
74
+ return chunk64U3UDTH_cjs.handleError(error, "Error querying vectors");
74
75
  }
75
76
  }
76
77
  async function listIndexes({ mastra, vectorName }) {
@@ -79,7 +80,7 @@ async function listIndexes({ mastra, vectorName }) {
79
80
  const indexes = await vector.listIndexes();
80
81
  return indexes.filter(Boolean);
81
82
  } catch (error) {
82
- return chunkZLBRQFDD_cjs.handleError(error, "Error listing indexes");
83
+ return chunk64U3UDTH_cjs.handleError(error, "Error listing indexes");
83
84
  }
84
85
  }
85
86
  async function describeIndex({
@@ -89,17 +90,17 @@ async function describeIndex({
89
90
  }) {
90
91
  try {
91
92
  if (!indexName) {
92
- throw new chunkFV45V6WC_cjs.HTTPException(400, { message: "Index name is required" });
93
+ throw new chunkOCWPVYNI_cjs.HTTPException(400, { message: "Index name is required" });
93
94
  }
94
95
  const vector = getVector(mastra, vectorName);
95
- const stats = await vector.describeIndex(indexName);
96
+ const stats = await vector.describeIndex({ indexName });
96
97
  return {
97
98
  dimension: stats.dimension,
98
99
  count: stats.count,
99
100
  metric: stats.metric?.toLowerCase()
100
101
  };
101
102
  } catch (error) {
102
- return chunkZLBRQFDD_cjs.handleError(error, "Error describing index");
103
+ return chunk64U3UDTH_cjs.handleError(error, "Error describing index");
103
104
  }
104
105
  }
105
106
  async function deleteIndex({
@@ -109,13 +110,13 @@ async function deleteIndex({
109
110
  }) {
110
111
  try {
111
112
  if (!indexName) {
112
- throw new chunkFV45V6WC_cjs.HTTPException(400, { message: "Index name is required" });
113
+ throw new chunkOCWPVYNI_cjs.HTTPException(400, { message: "Index name is required" });
113
114
  }
114
115
  const vector = getVector(mastra, vectorName);
115
- await vector.deleteIndex(indexName);
116
+ await vector.deleteIndex({ indexName });
116
117
  return { success: true };
117
118
  } catch (error) {
118
- return chunkZLBRQFDD_cjs.handleError(error, "Error deleting index");
119
+ return chunk64U3UDTH_cjs.handleError(error, "Error deleting index");
119
120
  }
120
121
  }
121
122
 
@@ -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;
@@ -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,270 @@
1
+ 'use strict';
2
+
3
+ var chunkASKESBJW_cjs = require('./chunk-ASKESBJW.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 ? chunkASKESBJW_cjs.stringify(chunkASKESBJW_cjs.esm_default(_tool.inputSchema)) : void 0,
33
+ outputSchema: _tool.outputSchema ? chunkASKESBJW_cjs.stringify(chunkASKESBJW_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 ? chunkASKESBJW_cjs.stringify(chunkASKESBJW_cjs.esm_default(_tool.inputSchema)) : void 0,
93
+ outputSchema: _tool.outputSchema ? chunkASKESBJW_cjs.stringify(chunkASKESBJW_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({
245
+ headers: {
246
+ "Transfer-Encoding": "chunked"
247
+ }
248
+ }) : streamResult.toDataStreamResponse({
249
+ sendUsage: true,
250
+ sendReasoning: true,
251
+ getErrorMessage: (error) => {
252
+ return `An error occurred while processing your request. ${error instanceof Error ? error.message : JSON.stringify(error)}`;
253
+ },
254
+ headers: {
255
+ "Transfer-Encoding": "chunked"
256
+ }
257
+ });
258
+ return streamResponse;
259
+ } catch (error) {
260
+ throw new chunkOCWPVYNI_cjs.HTTPException(error?.status ?? 500, { message: error?.message ?? "Error streaming from agent" });
261
+ }
262
+ }
263
+
264
+ exports.agents_exports = agents_exports;
265
+ exports.generateHandler = generateHandler;
266
+ exports.getAgentByIdHandler = getAgentByIdHandler;
267
+ exports.getAgentsHandler = getAgentsHandler;
268
+ exports.getEvalsByAgentIdHandler = getEvalsByAgentIdHandler;
269
+ exports.getLiveEvalsByAgentIdHandler = getLiveEvalsByAgentIdHandler;
270
+ exports.streamGenerateHandler = streamGenerateHandler;