@mastra/server 0.0.0-default-storage-virtual-file-20250410035748 → 0.0.0-experimental-agent-builder-20250815195917

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 (216) hide show
  1. package/LICENSE.md +15 -0
  2. package/README.md +48 -135
  3. package/dist/chunk-4CEZIJWJ.cjs +150 -0
  4. package/dist/chunk-4CEZIJWJ.cjs.map +1 -0
  5. package/dist/chunk-4MQU6AJN.js +83 -0
  6. package/dist/chunk-4MQU6AJN.js.map +1 -0
  7. package/dist/{chunk-QN4KF3BH.cjs → chunk-4QSNRCOT.cjs} +4 -2
  8. package/dist/chunk-4QSNRCOT.cjs.map +1 -0
  9. package/dist/chunk-4US5W7PH.cjs +120 -0
  10. package/dist/chunk-4US5W7PH.cjs.map +1 -0
  11. package/dist/chunk-5AKR33BI.js +333 -0
  12. package/dist/chunk-5AKR33BI.js.map +1 -0
  13. package/dist/chunk-7FHF55WA.js +2041 -0
  14. package/dist/chunk-7FHF55WA.js.map +1 -0
  15. package/dist/{chunk-FV45V6WC.cjs → chunk-7NADHFD2.cjs} +3 -7
  16. package/dist/chunk-7NADHFD2.cjs.map +1 -0
  17. package/dist/chunk-BED2O446.cjs +88 -0
  18. package/dist/chunk-BED2O446.cjs.map +1 -0
  19. package/dist/chunk-BUOJL3MN.js +529 -0
  20. package/dist/chunk-BUOJL3MN.js.map +1 -0
  21. package/dist/chunk-CY4TP3FK.js +16 -0
  22. package/dist/chunk-CY4TP3FK.js.map +1 -0
  23. package/dist/chunk-EBNIUZRY.cjs +344 -0
  24. package/dist/chunk-EBNIUZRY.cjs.map +1 -0
  25. package/dist/{chunk-4JINXASC.js → chunk-G7NVCO5M.js} +7 -4
  26. package/dist/chunk-G7NVCO5M.js.map +1 -0
  27. package/dist/chunk-GX25CWC7.cjs +588 -0
  28. package/dist/chunk-GX25CWC7.cjs.map +1 -0
  29. package/dist/{chunk-3RVHWGWO.js → chunk-HWHKM67I.js} +38 -19
  30. package/dist/chunk-HWHKM67I.js.map +1 -0
  31. package/dist/{chunk-CWSDZEZG.cjs → chunk-ILCWPBYQ.cjs} +20 -12
  32. package/dist/chunk-ILCWPBYQ.cjs.map +1 -0
  33. package/dist/chunk-JGVY3KWV.cjs +334 -0
  34. package/dist/chunk-JGVY3KWV.cjs.map +1 -0
  35. package/dist/chunk-JNWFG7JP.js +476 -0
  36. package/dist/chunk-JNWFG7JP.js.map +1 -0
  37. package/dist/chunk-KXNFZXLG.cjs +484 -0
  38. package/dist/chunk-KXNFZXLG.cjs.map +1 -0
  39. package/dist/chunk-L7YG7WQH.js +151 -0
  40. package/dist/chunk-L7YG7WQH.js.map +1 -0
  41. package/dist/chunk-LRUH33B4.cjs +2044 -0
  42. package/dist/chunk-LRUH33B4.cjs.map +1 -0
  43. package/dist/{chunk-TRDNDNGQ.js → chunk-MMROOK5J.js} +4 -7
  44. package/dist/chunk-MMROOK5J.js.map +1 -0
  45. package/dist/{chunk-M56ECCHK.cjs → chunk-NCS2OXX6.cjs} +22 -19
  46. package/dist/chunk-NCS2OXX6.cjs.map +1 -0
  47. package/dist/{chunk-4C3EPMMF.cjs → chunk-O4I563YW.cjs} +33 -25
  48. package/dist/chunk-O4I563YW.cjs.map +1 -0
  49. package/dist/{chunk-L7XE5QTW.js → chunk-OW4FX5TS.js} +3 -1
  50. package/dist/chunk-OW4FX5TS.js.map +1 -0
  51. package/dist/chunk-PZ5AY32C.js +9 -0
  52. package/dist/chunk-PZ5AY32C.js.map +1 -0
  53. package/dist/chunk-Q7SFCCGT.cjs +11 -0
  54. package/dist/chunk-Q7SFCCGT.cjs.map +1 -0
  55. package/dist/chunk-RE4RPXT2.cjs +18 -0
  56. package/dist/chunk-RE4RPXT2.cjs.map +1 -0
  57. package/dist/chunk-RQQNZZAI.cjs +159 -0
  58. package/dist/chunk-RQQNZZAI.cjs.map +1 -0
  59. package/dist/chunk-S37KCGOR.cjs +546 -0
  60. package/dist/chunk-S37KCGOR.cjs.map +1 -0
  61. package/dist/{chunk-DVPP5S6I.js → chunk-SQ7KKIH3.js} +16 -8
  62. package/dist/chunk-SQ7KKIH3.js.map +1 -0
  63. package/dist/{chunk-ILW7XYNJ.js → chunk-UVOSITKU.js} +92 -66
  64. package/dist/chunk-UVOSITKU.js.map +1 -0
  65. package/dist/{chunk-2YONKUWB.js → chunk-Y3J45CVZ.js} +60 -33
  66. package/dist/chunk-Y3J45CVZ.js.map +1 -0
  67. package/dist/{chunk-YNSGUC2O.js → chunk-YS66MFDY.js} +16 -8
  68. package/dist/chunk-YS66MFDY.js.map +1 -0
  69. package/dist/chunk-ZKJZQN24.js +571 -0
  70. package/dist/chunk-ZKJZQN24.js.map +1 -0
  71. package/dist/index.cjs +2 -0
  72. package/dist/index.cjs.map +1 -0
  73. package/dist/index.d.ts +1 -0
  74. package/dist/index.d.ts.map +1 -0
  75. package/dist/index.js +2 -0
  76. package/dist/index.js.map +1 -0
  77. package/dist/server/a2a/protocol.d.ts +8 -0
  78. package/dist/server/a2a/protocol.d.ts.map +1 -0
  79. package/dist/server/a2a/store.cjs +25 -0
  80. package/dist/server/a2a/store.cjs.map +1 -0
  81. package/dist/server/a2a/store.d.ts +14 -0
  82. package/dist/server/a2a/store.d.ts.map +1 -0
  83. package/dist/server/a2a/store.js +23 -0
  84. package/dist/server/a2a/store.js.map +1 -0
  85. package/dist/server/a2a/tasks.d.ts +20 -0
  86. package/dist/server/a2a/tasks.d.ts.map +1 -0
  87. package/dist/server/handlers/a2a.cjs +32 -0
  88. package/dist/server/handlers/a2a.cjs.map +1 -0
  89. package/dist/server/handlers/a2a.d.ts +68 -0
  90. package/dist/server/handlers/a2a.d.ts.map +1 -0
  91. package/dist/server/handlers/a2a.js +3 -0
  92. package/dist/server/handlers/a2a.js.map +1 -0
  93. package/dist/server/handlers/agents.cjs +21 -7
  94. package/dist/server/handlers/agents.cjs.map +1 -0
  95. package/dist/server/handlers/agents.d.ts +90 -6
  96. package/dist/server/handlers/agents.d.ts.map +1 -0
  97. package/dist/server/handlers/agents.js +3 -1
  98. package/dist/server/handlers/agents.js.map +1 -0
  99. package/dist/server/handlers/error.cjs +4 -2
  100. package/dist/server/handlers/error.cjs.map +1 -0
  101. package/dist/server/handlers/error.d.ts +2 -1
  102. package/dist/server/handlers/error.d.ts.map +1 -0
  103. package/dist/server/handlers/error.js +3 -1
  104. package/dist/server/handlers/error.js.map +1 -0
  105. package/dist/server/handlers/legacyWorkflows.cjs +48 -0
  106. package/dist/server/handlers/legacyWorkflows.cjs.map +1 -0
  107. package/dist/server/handlers/legacyWorkflows.d.ts +59 -0
  108. package/dist/server/handlers/legacyWorkflows.d.ts.map +1 -0
  109. package/dist/server/handlers/legacyWorkflows.js +3 -0
  110. package/dist/server/handlers/legacyWorkflows.js.map +1 -0
  111. package/dist/server/handlers/logs.cjs +6 -4
  112. package/dist/server/handlers/logs.cjs.map +1 -0
  113. package/dist/server/handlers/logs.d.ts +34 -3
  114. package/dist/server/handlers/logs.d.ts.map +1 -0
  115. package/dist/server/handlers/logs.js +3 -1
  116. package/dist/server/handlers/logs.js.map +1 -0
  117. package/dist/server/handlers/memory.cjs +39 -9
  118. package/dist/server/handlers/memory.cjs.map +1 -0
  119. package/dist/server/handlers/memory.d.ts +119 -8
  120. package/dist/server/handlers/memory.d.ts.map +1 -0
  121. package/dist/server/handlers/memory.js +3 -1
  122. package/dist/server/handlers/memory.js.map +1 -0
  123. package/dist/server/handlers/network.cjs +7 -5
  124. package/dist/server/handlers/network.cjs.map +1 -0
  125. package/dist/server/handlers/network.d.ts +50 -4
  126. package/dist/server/handlers/network.d.ts.map +1 -0
  127. package/dist/server/handlers/network.js +3 -1
  128. package/dist/server/handlers/network.js.map +1 -0
  129. package/dist/server/handlers/scores.cjs +32 -0
  130. package/dist/server/handlers/scores.cjs.map +1 -0
  131. package/dist/server/handlers/scores.d.ts +49 -0
  132. package/dist/server/handlers/scores.d.ts.map +1 -0
  133. package/dist/server/handlers/scores.js +3 -0
  134. package/dist/server/handlers/scores.js.map +1 -0
  135. package/dist/server/handlers/telemetry.cjs +5 -3
  136. package/dist/server/handlers/telemetry.cjs.map +1 -0
  137. package/dist/server/handlers/telemetry.d.ts +32 -2
  138. package/dist/server/handlers/telemetry.d.ts.map +1 -0
  139. package/dist/server/handlers/telemetry.js +3 -1
  140. package/dist/server/handlers/telemetry.js.map +1 -0
  141. package/dist/server/handlers/tools.cjs +7 -5
  142. package/dist/server/handlers/tools.cjs.map +1 -0
  143. package/dist/server/handlers/tools.d.ts +21 -4
  144. package/dist/server/handlers/tools.d.ts.map +1 -0
  145. package/dist/server/handlers/tools.js +3 -1
  146. package/dist/server/handlers/tools.js.map +1 -0
  147. package/dist/server/handlers/utils.cjs +4 -2
  148. package/dist/server/handlers/utils.cjs.map +1 -0
  149. package/dist/server/handlers/utils.d.ts +2 -1
  150. package/dist/server/handlers/utils.d.ts.map +1 -0
  151. package/dist/server/handlers/utils.js +3 -1
  152. package/dist/server/handlers/utils.js.map +1 -0
  153. package/dist/server/handlers/vNextNetwork.cjs +220 -0
  154. package/dist/server/handlers/vNextNetwork.cjs.map +1 -0
  155. package/dist/server/handlers/vNextNetwork.d.ts +179 -0
  156. package/dist/server/handlers/vNextNetwork.d.ts.map +1 -0
  157. package/dist/server/handlers/vNextNetwork.js +213 -0
  158. package/dist/server/handlers/vNextNetwork.js.map +1 -0
  159. package/dist/server/handlers/vector.cjs +9 -7
  160. package/dist/server/handlers/vector.cjs.map +1 -0
  161. package/dist/server/handlers/vector.d.ts +51 -6
  162. package/dist/server/handlers/vector.d.ts.map +1 -0
  163. package/dist/server/handlers/vector.js +3 -1
  164. package/dist/server/handlers/vector.js.map +1 -0
  165. package/dist/server/handlers/voice.cjs +10 -4
  166. package/dist/server/handlers/voice.cjs.map +1 -0
  167. package/dist/server/handlers/voice.d.ts +39 -3
  168. package/dist/server/handlers/voice.d.ts.map +1 -0
  169. package/dist/server/handlers/voice.js +3 -1
  170. package/dist/server/handlers/voice.js.map +1 -0
  171. package/dist/server/handlers/workflows.cjs +35 -13
  172. package/dist/server/handlers/workflows.cjs.map +1 -0
  173. package/dist/server/handlers/workflows.d.ts +88 -10
  174. package/dist/server/handlers/workflows.d.ts.map +1 -0
  175. package/dist/server/handlers/workflows.js +3 -1
  176. package/dist/server/handlers/workflows.js.map +1 -0
  177. package/dist/server/handlers.cjs +44 -27
  178. package/dist/server/handlers.cjs.map +1 -0
  179. package/dist/server/handlers.d.ts +13 -9
  180. package/dist/server/handlers.d.ts.map +1 -0
  181. package/dist/server/handlers.js +14 -9
  182. package/dist/server/handlers.js.map +1 -0
  183. package/dist/server/http-exception.d.ts +87 -0
  184. package/dist/server/http-exception.d.ts.map +1 -0
  185. package/dist/server/types.d.ts +10 -0
  186. package/dist/server/types.d.ts.map +1 -0
  187. package/package.json +31 -18
  188. package/LICENSE +0 -44
  189. package/dist/_tsup-dts-rollup.d.cts +0 -564
  190. package/dist/_tsup-dts-rollup.d.ts +0 -564
  191. package/dist/chunk-2FJURXCL.cjs +0 -213
  192. package/dist/chunk-2JQC6JWP.js +0 -46
  193. package/dist/chunk-3AHQ5RGN.js +0 -11
  194. package/dist/chunk-5JOF627H.cjs +0 -123
  195. package/dist/chunk-A7DF4ETD.cjs +0 -100
  196. package/dist/chunk-BMA2ORRT.js +0 -152
  197. package/dist/chunk-GV52BII2.cjs +0 -160
  198. package/dist/chunk-QH6XWSXP.cjs +0 -5579
  199. package/dist/chunk-RBQASTUP.js +0 -203
  200. package/dist/chunk-VB7KH62D.cjs +0 -51
  201. package/dist/chunk-VK6FX47H.js +0 -5576
  202. package/dist/chunk-X37I6GZT.cjs +0 -308
  203. package/dist/chunk-ZLBRQFDD.cjs +0 -13
  204. package/dist/index.d.cts +0 -1
  205. package/dist/server/handlers/agents.d.cts +0 -6
  206. package/dist/server/handlers/error.d.cts +0 -1
  207. package/dist/server/handlers/logs.d.cts +0 -3
  208. package/dist/server/handlers/memory.d.cts +0 -8
  209. package/dist/server/handlers/network.d.cts +0 -4
  210. package/dist/server/handlers/telemetry.d.cts +0 -2
  211. package/dist/server/handlers/tools.d.cts +0 -4
  212. package/dist/server/handlers/utils.d.cts +0 -1
  213. package/dist/server/handlers/vector.d.cts +0 -6
  214. package/dist/server/handlers/voice.d.cts +0 -3
  215. package/dist/server/handlers/workflows.d.cts +0 -10
  216. package/dist/server/handlers.d.cts +0 -9
@@ -1,7 +1,8 @@
1
- import { stringify, esm_default } from './chunk-VK6FX47H.js';
2
- import { validateBody } from './chunk-L7XE5QTW.js';
3
- import { handleError } from './chunk-3AHQ5RGN.js';
4
- import { __export, HTTPException } from './chunk-TRDNDNGQ.js';
1
+ import { stringify, esm_default } from './chunk-7FHF55WA.js';
2
+ import { validateBody } from './chunk-OW4FX5TS.js';
3
+ import { handleError } from './chunk-CY4TP3FK.js';
4
+ import { HTTPException } from './chunk-MMROOK5J.js';
5
+ import { __export } from './chunk-PZ5AY32C.js';
5
6
  import { isVercelTool } from '@mastra/core/tools';
6
7
 
7
8
  // src/server/handlers/tools.ts
@@ -55,7 +56,8 @@ function executeToolHandler(tools) {
55
56
  mastra,
56
57
  runId,
57
58
  toolId,
58
- data
59
+ data,
60
+ runtimeContext
59
61
  }) => {
60
62
  try {
61
63
  if (!toolId) {
@@ -76,7 +78,8 @@ function executeToolHandler(tools) {
76
78
  const result = await tool.execute({
77
79
  context: data,
78
80
  mastra,
79
- runId
81
+ runId,
82
+ runtimeContext
80
83
  });
81
84
  return result;
82
85
  } catch (error) {
@@ -88,14 +91,16 @@ async function executeAgentToolHandler({
88
91
  mastra,
89
92
  agentId,
90
93
  toolId,
91
- data
94
+ data,
95
+ runtimeContext
92
96
  }) {
93
97
  try {
94
98
  const agent = agentId ? mastra.getAgent(agentId) : null;
95
99
  if (!agent) {
96
100
  throw new HTTPException(404, { message: "Tool not found" });
97
101
  }
98
- const tool = Object.values(agent?.tools || {}).find((tool2) => tool2.id === toolId);
102
+ const agentTools = await agent.getTools({ runtimeContext });
103
+ const tool = Object.values(agentTools || {}).find((tool2) => tool2.id === toolId);
99
104
  if (!tool) {
100
105
  throw new HTTPException(404, { message: "Tool not found" });
101
106
  }
@@ -104,6 +109,7 @@ async function executeAgentToolHandler({
104
109
  }
105
110
  const result = await tool.execute({
106
111
  context: data,
112
+ runtimeContext,
107
113
  mastra,
108
114
  runId: agentId
109
115
  });
@@ -114,3 +120,5 @@ async function executeAgentToolHandler({
114
120
  }
115
121
 
116
122
  export { executeAgentToolHandler, executeToolHandler, getToolByIdHandler, getToolsHandler, tools_exports };
123
+ //# sourceMappingURL=chunk-YS66MFDY.js.map
124
+ //# sourceMappingURL=chunk-YS66MFDY.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/server/handlers/tools.ts"],"names":["tool","result"],"mappings":"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","file":"chunk-YS66MFDY.js","sourcesContent":["import type { RuntimeContext } from '@mastra/core/di';\nimport type { ToolAction, VercelTool } from '@mastra/core/tools';\nimport { isVercelTool } from '@mastra/core/tools';\nimport { stringify } from 'superjson';\nimport zodToJsonSchema from 'zod-to-json-schema';\nimport { HTTPException } from '../http-exception';\nimport type { Context } from '../types';\n\nimport { handleError } from './error';\nimport { validateBody } from './utils';\n\ninterface ToolsContext extends Context {\n tools?: Record<string, ToolAction | VercelTool>;\n toolId?: string;\n runId?: string;\n}\n\n// Tool handlers\nexport async function getToolsHandler({ tools }: Pick<ToolsContext, 'tools'>) {\n try {\n if (!tools) {\n return {};\n }\n\n const serializedTools = Object.entries(tools).reduce(\n (acc, [id, _tool]) => {\n const tool = _tool as any;\n acc[id] = {\n ...tool,\n inputSchema: tool.inputSchema ? stringify(zodToJsonSchema(tool.inputSchema)) : undefined,\n outputSchema: tool.outputSchema ? stringify(zodToJsonSchema(tool.outputSchema)) : undefined,\n };\n return acc;\n },\n {} as Record<string, any>,\n );\n\n return serializedTools;\n } catch (error) {\n return handleError(error, 'Error getting tools');\n }\n}\n\nexport async function getToolByIdHandler({ tools, toolId }: Pick<ToolsContext, 'tools' | 'toolId'>) {\n try {\n const tool = Object.values(tools || {}).find((tool: any) => tool.id === toolId) as any;\n\n if (!tool) {\n throw new HTTPException(404, { message: 'Tool not found' });\n }\n\n const serializedTool = {\n ...tool,\n inputSchema: tool.inputSchema ? stringify(zodToJsonSchema(tool.inputSchema)) : undefined,\n outputSchema: tool.outputSchema ? stringify(zodToJsonSchema(tool.outputSchema)) : undefined,\n };\n\n return serializedTool;\n } catch (error) {\n return handleError(error, 'Error getting tool');\n }\n}\n\nexport function executeToolHandler(tools: ToolsContext['tools']) {\n return async ({\n mastra,\n runId,\n toolId,\n data,\n runtimeContext,\n }: Pick<ToolsContext, 'mastra' | 'toolId' | 'runId'> & {\n data?: unknown;\n runtimeContext: RuntimeContext;\n }) => {\n try {\n if (!toolId) {\n throw new HTTPException(400, { message: 'Tool ID is required' });\n }\n\n const tool = Object.values(tools || {}).find((tool: any) => tool.id === toolId) as any;\n\n if (!tool) {\n throw new HTTPException(404, { message: 'Tool not found' });\n }\n\n if (!tool?.execute) {\n throw new HTTPException(400, { message: 'Tool is not executable' });\n }\n\n validateBody({ data });\n\n if (isVercelTool(tool)) {\n const result = await (tool as any).execute(data);\n return result;\n }\n\n const result = await tool.execute({\n context: data!,\n mastra,\n runId,\n runtimeContext,\n });\n return result;\n } catch (error) {\n return handleError(error, 'Error executing tool');\n }\n };\n}\n\nexport async function executeAgentToolHandler({\n mastra,\n agentId,\n toolId,\n data,\n runtimeContext,\n}: Pick<ToolsContext, 'mastra' | 'toolId'> & {\n agentId?: string;\n data: any;\n runtimeContext: RuntimeContext;\n}) {\n try {\n const agent = agentId ? mastra.getAgent(agentId) : null;\n if (!agent) {\n throw new HTTPException(404, { message: 'Tool not found' });\n }\n\n const agentTools = await agent.getTools({ runtimeContext });\n\n const tool = Object.values(agentTools || {}).find((tool: any) => tool.id === toolId) as any;\n\n if (!tool) {\n throw new HTTPException(404, { message: 'Tool not found' });\n }\n\n if (!tool?.execute) {\n throw new HTTPException(400, { message: 'Tool is not executable' });\n }\n\n // if (isVercelTool(tool)) {\n // const result = await (tool as any).execute(data);\n // return result;\n // }\n\n const result = await tool.execute({\n context: data,\n runtimeContext,\n mastra,\n runId: agentId,\n });\n\n return result;\n } catch (error) {\n return handleError(error, 'Error executing tool');\n }\n}\n"]}
@@ -0,0 +1,571 @@
1
+ import { validateBody } from './chunk-OW4FX5TS.js';
2
+ import { handleError } from './chunk-CY4TP3FK.js';
3
+ import { HTTPException } from './chunk-MMROOK5J.js';
4
+ import { __export } from './chunk-PZ5AY32C.js';
5
+ import { generateEmptyFromSchema } from '@mastra/core';
6
+
7
+ // src/server/handlers/memory.ts
8
+ var memory_exports = {};
9
+ __export(memory_exports, {
10
+ createThreadHandler: () => createThreadHandler,
11
+ deleteMessagesHandler: () => deleteMessagesHandler,
12
+ deleteThreadHandler: () => deleteThreadHandler,
13
+ getMemoryConfigHandler: () => getMemoryConfigHandler,
14
+ getMemoryStatusHandler: () => getMemoryStatusHandler,
15
+ getMessagesHandler: () => getMessagesHandler,
16
+ getMessagesPaginatedHandler: () => getMessagesPaginatedHandler,
17
+ getThreadByIdHandler: () => getThreadByIdHandler,
18
+ getThreadsHandler: () => getThreadsHandler,
19
+ getThreadsPaginatedHandler: () => getThreadsPaginatedHandler,
20
+ getWorkingMemoryHandler: () => getWorkingMemoryHandler,
21
+ saveMessagesHandler: () => saveMessagesHandler,
22
+ searchMemoryHandler: () => searchMemoryHandler,
23
+ updateThreadHandler: () => updateThreadHandler,
24
+ updateWorkingMemoryHandler: () => updateWorkingMemoryHandler
25
+ });
26
+ async function getMemoryFromContext({
27
+ mastra,
28
+ agentId,
29
+ networkId,
30
+ runtimeContext
31
+ }) {
32
+ const agent = agentId ? mastra.getAgent(agentId) : null;
33
+ if (agentId && !agent) {
34
+ throw new HTTPException(404, { message: "Agent not found" });
35
+ }
36
+ const network = networkId ? mastra.vnext_getNetwork(networkId) : null;
37
+ if (networkId && !network) {
38
+ throw new HTTPException(404, { message: "Network not found" });
39
+ }
40
+ if (agent) {
41
+ return await agent?.getMemory() || mastra.getMemory();
42
+ }
43
+ if (network) {
44
+ return await network?.getMemory({ runtimeContext }) || mastra.getMemory();
45
+ }
46
+ return mastra.getMemory();
47
+ }
48
+ async function getMemoryStatusHandler({
49
+ mastra,
50
+ agentId,
51
+ networkId,
52
+ runtimeContext
53
+ }) {
54
+ try {
55
+ const memory = await getMemoryFromContext({ mastra, agentId, networkId, runtimeContext });
56
+ if (!memory) {
57
+ return { result: false };
58
+ }
59
+ return { result: true };
60
+ } catch (error) {
61
+ return handleError(error, "Error getting memory status");
62
+ }
63
+ }
64
+ async function getMemoryConfigHandler({
65
+ mastra,
66
+ agentId,
67
+ networkId,
68
+ runtimeContext
69
+ }) {
70
+ try {
71
+ const memory = await getMemoryFromContext({ mastra, agentId, networkId, runtimeContext });
72
+ if (!memory) {
73
+ throw new HTTPException(400, { message: "Memory is not initialized" });
74
+ }
75
+ const config = memory.getMergedThreadConfig({});
76
+ return { config };
77
+ } catch (error) {
78
+ return handleError(error, "Error getting memory configuration");
79
+ }
80
+ }
81
+ async function getThreadsHandler({
82
+ mastra,
83
+ agentId,
84
+ resourceId,
85
+ networkId,
86
+ runtimeContext,
87
+ orderBy,
88
+ sortDirection
89
+ }) {
90
+ try {
91
+ const memory = await getMemoryFromContext({ mastra, agentId, networkId, runtimeContext });
92
+ if (!memory) {
93
+ throw new HTTPException(400, { message: "Memory is not initialized" });
94
+ }
95
+ validateBody({ resourceId });
96
+ const threads = await memory.getThreadsByResourceId({
97
+ resourceId,
98
+ orderBy,
99
+ sortDirection
100
+ });
101
+ return threads;
102
+ } catch (error) {
103
+ return handleError(error, "Error getting threads");
104
+ }
105
+ }
106
+ async function getThreadsPaginatedHandler({
107
+ mastra,
108
+ agentId,
109
+ resourceId,
110
+ networkId,
111
+ runtimeContext,
112
+ page,
113
+ perPage,
114
+ orderBy,
115
+ sortDirection
116
+ }) {
117
+ try {
118
+ const memory = await getMemoryFromContext({ mastra, agentId, networkId, runtimeContext });
119
+ if (!memory) {
120
+ throw new HTTPException(400, { message: "Memory is not initialized" });
121
+ }
122
+ validateBody({ resourceId });
123
+ const result = await memory.getThreadsByResourceIdPaginated({
124
+ resourceId,
125
+ page,
126
+ perPage,
127
+ orderBy,
128
+ sortDirection
129
+ });
130
+ return result;
131
+ } catch (error) {
132
+ return handleError(error, "Error getting paginated threads");
133
+ }
134
+ }
135
+ async function getThreadByIdHandler({
136
+ mastra,
137
+ agentId,
138
+ threadId,
139
+ networkId,
140
+ runtimeContext
141
+ }) {
142
+ try {
143
+ validateBody({ threadId });
144
+ const memory = await getMemoryFromContext({ mastra, agentId, networkId, runtimeContext });
145
+ if (!memory) {
146
+ throw new HTTPException(400, { message: "Memory is not initialized" });
147
+ }
148
+ const thread = await memory.getThreadById({ threadId });
149
+ if (!thread) {
150
+ throw new HTTPException(404, { message: "Thread not found" });
151
+ }
152
+ return thread;
153
+ } catch (error) {
154
+ return handleError(error, "Error getting thread");
155
+ }
156
+ }
157
+ async function saveMessagesHandler({
158
+ mastra,
159
+ agentId,
160
+ body,
161
+ networkId,
162
+ runtimeContext
163
+ }) {
164
+ try {
165
+ const memory = await getMemoryFromContext({ mastra, agentId, networkId, runtimeContext });
166
+ if (!memory) {
167
+ throw new HTTPException(400, { message: "Memory is not initialized" });
168
+ }
169
+ if (!body?.messages) {
170
+ throw new HTTPException(400, { message: "Messages are required" });
171
+ }
172
+ if (!Array.isArray(body.messages)) {
173
+ throw new HTTPException(400, { message: "Messages should be an array" });
174
+ }
175
+ const invalidMessages = body.messages.filter((message) => !message.threadId || !message.resourceId);
176
+ if (invalidMessages.length > 0) {
177
+ throw new HTTPException(400, {
178
+ message: `All messages must have threadId and resourceId fields. Found ${invalidMessages.length} invalid message(s).`
179
+ });
180
+ }
181
+ const processedMessages = body.messages.map((message) => ({
182
+ ...message,
183
+ id: message.id || memory.generateId(),
184
+ createdAt: message.createdAt ? new Date(message.createdAt) : /* @__PURE__ */ new Date()
185
+ }));
186
+ const result = await memory.saveMessages({ messages: processedMessages, memoryConfig: {} });
187
+ return result;
188
+ } catch (error) {
189
+ return handleError(error, "Error saving messages");
190
+ }
191
+ }
192
+ async function createThreadHandler({
193
+ mastra,
194
+ agentId,
195
+ body,
196
+ networkId,
197
+ runtimeContext
198
+ }) {
199
+ try {
200
+ const memory = await getMemoryFromContext({ mastra, agentId, networkId, runtimeContext });
201
+ if (!memory) {
202
+ throw new HTTPException(400, { message: "Memory is not initialized" });
203
+ }
204
+ validateBody({ resourceId: body?.resourceId });
205
+ const result = await memory.createThread({
206
+ resourceId: body?.resourceId,
207
+ title: body?.title,
208
+ metadata: body?.metadata,
209
+ threadId: body?.threadId
210
+ });
211
+ return result;
212
+ } catch (error) {
213
+ return handleError(error, "Error saving thread to memory");
214
+ }
215
+ }
216
+ async function updateThreadHandler({
217
+ mastra,
218
+ agentId,
219
+ threadId,
220
+ body,
221
+ networkId,
222
+ runtimeContext
223
+ }) {
224
+ try {
225
+ const memory = await getMemoryFromContext({ mastra, agentId, networkId, runtimeContext });
226
+ if (!body) {
227
+ throw new HTTPException(400, { message: "Body is required" });
228
+ }
229
+ const { title, metadata, resourceId } = body;
230
+ const updatedAt = /* @__PURE__ */ new Date();
231
+ validateBody({ threadId });
232
+ if (!memory) {
233
+ throw new HTTPException(400, { message: "Memory is not initialized" });
234
+ }
235
+ const thread = await memory.getThreadById({ threadId });
236
+ if (!thread) {
237
+ throw new HTTPException(404, { message: "Thread not found" });
238
+ }
239
+ const updatedThread = {
240
+ ...thread,
241
+ title: title || thread.title,
242
+ metadata: metadata || thread.metadata,
243
+ resourceId: resourceId || thread.resourceId,
244
+ createdAt: thread.createdAt,
245
+ updatedAt
246
+ };
247
+ const result = await memory.saveThread({ thread: updatedThread });
248
+ return result;
249
+ } catch (error) {
250
+ return handleError(error, "Error updating thread");
251
+ }
252
+ }
253
+ async function deleteThreadHandler({
254
+ mastra,
255
+ agentId,
256
+ threadId,
257
+ networkId,
258
+ runtimeContext
259
+ }) {
260
+ try {
261
+ validateBody({ threadId });
262
+ const memory = await getMemoryFromContext({ mastra, agentId, networkId, runtimeContext });
263
+ if (!memory) {
264
+ throw new HTTPException(400, { message: "Memory is not initialized" });
265
+ }
266
+ const thread = await memory.getThreadById({ threadId });
267
+ if (!thread) {
268
+ throw new HTTPException(404, { message: "Thread not found" });
269
+ }
270
+ await memory.deleteThread(threadId);
271
+ return { result: "Thread deleted" };
272
+ } catch (error) {
273
+ return handleError(error, "Error deleting thread");
274
+ }
275
+ }
276
+ async function getMessagesPaginatedHandler({
277
+ mastra,
278
+ threadId,
279
+ resourceId,
280
+ selectBy,
281
+ format
282
+ }) {
283
+ try {
284
+ validateBody({ threadId });
285
+ const storage = mastra.getStorage();
286
+ if (!storage) {
287
+ throw new HTTPException(400, { message: "Storage is not initialized" });
288
+ }
289
+ const thread = await storage.getThreadById({ threadId });
290
+ if (!thread) {
291
+ throw new HTTPException(404, { message: "Thread not found" });
292
+ }
293
+ const result = await storage.getMessagesPaginated({ threadId, resourceId, selectBy, format });
294
+ return result;
295
+ } catch (error) {
296
+ return handleError(error, "Error getting messages");
297
+ }
298
+ }
299
+ async function getMessagesHandler({
300
+ mastra,
301
+ agentId,
302
+ threadId,
303
+ limit,
304
+ networkId,
305
+ runtimeContext
306
+ }) {
307
+ if (limit !== void 0 && (!Number.isInteger(limit) || limit <= 0)) {
308
+ throw new HTTPException(400, { message: "Invalid limit: must be a positive integer" });
309
+ }
310
+ try {
311
+ validateBody({ threadId });
312
+ const memory = await getMemoryFromContext({ mastra, agentId, networkId, runtimeContext });
313
+ if (!memory) {
314
+ throw new HTTPException(400, { message: "Memory is not initialized" });
315
+ }
316
+ const thread = await memory.getThreadById({ threadId });
317
+ if (!thread) {
318
+ throw new HTTPException(404, { message: "Thread not found" });
319
+ }
320
+ const result = await memory.query({
321
+ threadId,
322
+ ...limit && { selectBy: { last: limit } }
323
+ });
324
+ return { messages: result.messages, uiMessages: result.uiMessages };
325
+ } catch (error) {
326
+ return handleError(error, "Error getting messages");
327
+ }
328
+ }
329
+ async function getWorkingMemoryHandler({
330
+ mastra,
331
+ agentId,
332
+ threadId,
333
+ resourceId,
334
+ networkId,
335
+ runtimeContext,
336
+ memoryConfig
337
+ }) {
338
+ try {
339
+ const memory = await getMemoryFromContext({ mastra, agentId, networkId, runtimeContext });
340
+ validateBody({ threadId });
341
+ if (!memory) {
342
+ throw new HTTPException(400, { message: "Memory is not initialized" });
343
+ }
344
+ const thread = await memory.getThreadById({ threadId });
345
+ const threadExists = !!thread;
346
+ const template = await memory.getWorkingMemoryTemplate({ memoryConfig });
347
+ const workingMemoryTemplate = template?.format === "json" ? { ...template, content: JSON.stringify(generateEmptyFromSchema(template.content)) } : template;
348
+ const workingMemory = await memory.getWorkingMemory({ threadId, resourceId, memoryConfig });
349
+ const config = memory.getMergedThreadConfig(memoryConfig || {});
350
+ const source = config.workingMemory?.scope === "resource" && resourceId ? "resource" : "thread";
351
+ return { workingMemory, source, workingMemoryTemplate, threadExists };
352
+ } catch (error) {
353
+ return handleError(error, "Error getting working memory");
354
+ }
355
+ }
356
+ async function updateWorkingMemoryHandler({
357
+ mastra,
358
+ agentId,
359
+ threadId,
360
+ body,
361
+ networkId,
362
+ runtimeContext
363
+ }) {
364
+ try {
365
+ validateBody({ threadId });
366
+ const memory = await getMemoryFromContext({ mastra, agentId, networkId, runtimeContext });
367
+ const { resourceId, memoryConfig, workingMemory } = body;
368
+ if (!memory) {
369
+ throw new HTTPException(400, { message: "Memory is not initialized" });
370
+ }
371
+ const thread = await memory.getThreadById({ threadId });
372
+ if (!thread) {
373
+ throw new HTTPException(404, { message: "Thread not found" });
374
+ }
375
+ await memory.updateWorkingMemory({ threadId, resourceId, workingMemory, memoryConfig });
376
+ return { success: true };
377
+ } catch (error) {
378
+ return handleError(error, "Error updating working memory");
379
+ }
380
+ }
381
+ async function deleteMessagesHandler({
382
+ mastra,
383
+ agentId,
384
+ messageIds,
385
+ networkId,
386
+ runtimeContext
387
+ }) {
388
+ try {
389
+ if (messageIds === void 0 || messageIds === null) {
390
+ throw new HTTPException(400, { message: "messageIds is required" });
391
+ }
392
+ const memory = await getMemoryFromContext({ mastra, agentId, networkId, runtimeContext });
393
+ if (!memory) {
394
+ throw new HTTPException(400, { message: "Memory is not initialized" });
395
+ }
396
+ await memory.deleteMessages(messageIds);
397
+ let count = 1;
398
+ if (Array.isArray(messageIds)) {
399
+ count = messageIds.length;
400
+ }
401
+ return { success: true, message: `${count} message${count === 1 ? "" : "s"} deleted successfully` };
402
+ } catch (error) {
403
+ return handleError(error, "Error deleting messages");
404
+ }
405
+ }
406
+ async function searchMemoryHandler({
407
+ mastra,
408
+ agentId,
409
+ searchQuery,
410
+ resourceId,
411
+ threadId,
412
+ limit = 20,
413
+ networkId,
414
+ runtimeContext,
415
+ memoryConfig
416
+ }) {
417
+ try {
418
+ validateBody({ searchQuery, resourceId });
419
+ const memory = await getMemoryFromContext({ mastra, agentId, networkId, runtimeContext });
420
+ if (!memory) {
421
+ throw new HTTPException(400, { message: "Memory is not initialized" });
422
+ }
423
+ const config = memory.getMergedThreadConfig(memoryConfig || {});
424
+ const hasSemanticRecall = !!config?.semanticRecall;
425
+ const resourceScope = typeof config?.semanticRecall === "object" && config?.semanticRecall?.scope === "resource";
426
+ if (threadId && !resourceScope) {
427
+ const thread = await memory.getThreadById({ threadId });
428
+ if (!thread) {
429
+ throw new HTTPException(404, { message: "Thread not found" });
430
+ }
431
+ if (thread.resourceId !== resourceId) {
432
+ throw new HTTPException(403, { message: "Thread does not belong to the specified resource" });
433
+ }
434
+ }
435
+ const searchResults = [];
436
+ const messageMap = /* @__PURE__ */ new Map();
437
+ if (threadId && !resourceScope) {
438
+ const thread = await memory.getThreadById({ threadId });
439
+ if (!thread) {
440
+ return {
441
+ results: [],
442
+ count: 0,
443
+ query: searchQuery,
444
+ searchScope: "thread",
445
+ searchType: hasSemanticRecall ? "semantic" : "text"
446
+ };
447
+ }
448
+ }
449
+ if (!threadId || resourceScope) {
450
+ const threads = await memory.getThreadsByResourceId({ resourceId });
451
+ if (threads.length === 0) {
452
+ return {
453
+ results: [],
454
+ count: 0,
455
+ query: searchQuery,
456
+ searchScope: "resource",
457
+ searchType: hasSemanticRecall ? "semantic" : "text"
458
+ };
459
+ }
460
+ for (const thread of threads) {
461
+ const result = await memory.rememberMessages({
462
+ threadId: thread.id,
463
+ resourceId,
464
+ vectorMessageSearch: searchQuery,
465
+ config
466
+ });
467
+ const threadMessages = (await memory.query({ threadId: thread.id })).uiMessages;
468
+ result.messagesV2.forEach((msg) => {
469
+ if (messageMap.has(msg.id)) return;
470
+ messageMap.set(msg.id, true);
471
+ const content = msg.content.content || msg.content.parts?.map((p) => p.type === "text" ? p.text : "").join(" ") || "";
472
+ if (!hasSemanticRecall && !content.toLowerCase().includes(searchQuery.toLowerCase())) {
473
+ return;
474
+ }
475
+ const messageIndex = threadMessages.findIndex((m) => m.id === msg.id);
476
+ const searchResult = {
477
+ id: msg.id,
478
+ role: msg.role,
479
+ content,
480
+ createdAt: msg.createdAt,
481
+ threadId: msg.threadId || thread.id,
482
+ threadTitle: thread.title || msg.threadId || thread.id
483
+ };
484
+ if (messageIndex !== -1) {
485
+ searchResult.context = {
486
+ before: threadMessages.slice(Math.max(0, messageIndex - 2), messageIndex).map((m) => ({
487
+ id: m.id,
488
+ role: m.role,
489
+ content: m.content,
490
+ createdAt: m.createdAt || /* @__PURE__ */ new Date()
491
+ })),
492
+ after: threadMessages.slice(messageIndex + 1, messageIndex + 3).map((m) => ({
493
+ id: m.id,
494
+ role: m.role,
495
+ content: m.content,
496
+ createdAt: m.createdAt || /* @__PURE__ */ new Date()
497
+ }))
498
+ };
499
+ }
500
+ searchResults.push(searchResult);
501
+ });
502
+ }
503
+ } else if (threadId) {
504
+ const thread = await memory.getThreadById({ threadId });
505
+ if (!thread) {
506
+ return {
507
+ results: [],
508
+ count: 0,
509
+ query: searchQuery,
510
+ searchScope: "thread",
511
+ searchType: hasSemanticRecall ? "semantic" : "text"
512
+ };
513
+ }
514
+ const result = await memory.rememberMessages({
515
+ threadId,
516
+ resourceId,
517
+ vectorMessageSearch: searchQuery,
518
+ config
519
+ });
520
+ const threadMessages = (await memory.query({ threadId })).uiMessages;
521
+ result.messagesV2.forEach((msg) => {
522
+ if (messageMap.has(msg.id)) return;
523
+ messageMap.set(msg.id, true);
524
+ const content = msg.content.content || msg.content.parts?.map((p) => p.type === "text" ? p.text : "").join(" ") || "";
525
+ if (!hasSemanticRecall && !content.toLowerCase().includes(searchQuery.toLowerCase())) {
526
+ return;
527
+ }
528
+ const messageIndex = threadMessages.findIndex((m) => m.id === msg.id);
529
+ const searchResult = {
530
+ id: msg.id,
531
+ role: msg.role,
532
+ content,
533
+ createdAt: msg.createdAt,
534
+ threadId,
535
+ threadTitle: thread?.title || threadId
536
+ };
537
+ if (messageIndex !== -1) {
538
+ searchResult.context = {
539
+ before: threadMessages.slice(Math.max(0, messageIndex - 2), messageIndex).map((m) => ({
540
+ id: m.id,
541
+ role: m.role,
542
+ content: m.content,
543
+ createdAt: m.createdAt || /* @__PURE__ */ new Date()
544
+ })),
545
+ after: threadMessages.slice(messageIndex + 1, messageIndex + 3).map((m) => ({
546
+ id: m.id,
547
+ role: m.role,
548
+ content: m.content,
549
+ createdAt: m.createdAt || /* @__PURE__ */ new Date()
550
+ }))
551
+ };
552
+ }
553
+ searchResults.push(searchResult);
554
+ });
555
+ }
556
+ const sortedResults = searchResults.sort((a, b) => new Date(b.createdAt).getTime() - new Date(a.createdAt).getTime()).slice(0, limit);
557
+ return {
558
+ results: sortedResults,
559
+ count: sortedResults.length,
560
+ query: searchQuery,
561
+ searchScope: resourceScope ? "resource" : "thread",
562
+ searchType: hasSemanticRecall ? "semantic" : "text"
563
+ };
564
+ } catch (error) {
565
+ return handleError(error, "Error searching memory");
566
+ }
567
+ }
568
+
569
+ export { createThreadHandler, deleteMessagesHandler, deleteThreadHandler, getMemoryConfigHandler, getMemoryStatusHandler, getMessagesHandler, getMessagesPaginatedHandler, getThreadByIdHandler, getThreadsHandler, getThreadsPaginatedHandler, getWorkingMemoryHandler, memory_exports, saveMessagesHandler, searchMemoryHandler, updateThreadHandler, updateWorkingMemoryHandler };
570
+ //# sourceMappingURL=chunk-ZKJZQN24.js.map
571
+ //# sourceMappingURL=chunk-ZKJZQN24.js.map