@mastra/server 1.0.0-beta.1 → 1.0.0-beta.11

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 (303) hide show
  1. package/CHANGELOG.md +273 -0
  2. package/README.md +2 -2
  3. package/dist/chunk-3SFLFUKY.js +116 -0
  4. package/dist/chunk-3SFLFUKY.js.map +1 -0
  5. package/dist/{chunk-W2KMU354.cjs → chunk-3XI22UQR.cjs} +19 -4
  6. package/dist/chunk-3XI22UQR.cjs.map +1 -0
  7. package/dist/chunk-4W2SM6CG.js +294 -0
  8. package/dist/chunk-4W2SM6CG.js.map +1 -0
  9. package/dist/chunk-5W4RPVTK.cjs +49 -0
  10. package/dist/chunk-5W4RPVTK.cjs.map +1 -0
  11. package/dist/chunk-7N3PD4SV.js +196 -0
  12. package/dist/chunk-7N3PD4SV.js.map +1 -0
  13. package/dist/{chunk-KJIDZQRA.cjs → chunk-7O3KPUJ4.cjs} +219 -24
  14. package/dist/chunk-7O3KPUJ4.cjs.map +1 -0
  15. package/dist/chunk-C3UIIRAT.cjs +920 -0
  16. package/dist/chunk-C3UIIRAT.cjs.map +1 -0
  17. package/dist/chunk-CDRVS35Y.js +23226 -0
  18. package/dist/chunk-CDRVS35Y.js.map +1 -0
  19. package/dist/chunk-DHWPHLGF.cjs +211 -0
  20. package/dist/chunk-DHWPHLGF.cjs.map +1 -0
  21. package/dist/chunk-DRUNNM4C.js +328 -0
  22. package/dist/chunk-DRUNNM4C.js.map +1 -0
  23. package/dist/{chunk-TOCYBDP2.js → chunk-ER3QM7DD.js} +4 -4
  24. package/dist/{chunk-TOCYBDP2.js.map → chunk-ER3QM7DD.js.map} +1 -1
  25. package/dist/chunk-FPCGLPLJ.cjs +297 -0
  26. package/dist/chunk-FPCGLPLJ.cjs.map +1 -0
  27. package/dist/chunk-FYY54HZC.js +310 -0
  28. package/dist/chunk-FYY54HZC.js.map +1 -0
  29. package/dist/chunk-GFF2I6UD.js +354 -0
  30. package/dist/chunk-GFF2I6UD.js.map +1 -0
  31. package/dist/chunk-GN2LFMET.cjs +23268 -0
  32. package/dist/chunk-GN2LFMET.cjs.map +1 -0
  33. package/dist/chunk-H2RMXG2Q.cjs +167 -0
  34. package/dist/chunk-H2RMXG2Q.cjs.map +1 -0
  35. package/dist/chunk-HAJOEDNB.js +274 -0
  36. package/dist/chunk-HAJOEDNB.js.map +1 -0
  37. package/dist/chunk-HFQGXVIE.js +786 -0
  38. package/dist/chunk-HFQGXVIE.js.map +1 -0
  39. package/dist/chunk-HT4LP3BO.js +75 -0
  40. package/dist/chunk-HT4LP3BO.js.map +1 -0
  41. package/dist/chunk-I6LR6CPC.cjs +125 -0
  42. package/dist/chunk-I6LR6CPC.cjs.map +1 -0
  43. package/dist/chunk-IEYXQTUW.cjs +284 -0
  44. package/dist/chunk-IEYXQTUW.cjs.map +1 -0
  45. package/dist/chunk-K3ELPJS3.js +1063 -0
  46. package/dist/chunk-K3ELPJS3.js.map +1 -0
  47. package/dist/{chunk-FPBYKMIS.js → chunk-KEXR53KI.js} +213 -24
  48. package/dist/chunk-KEXR53KI.js.map +1 -0
  49. package/dist/chunk-MCYD5LW7.cjs +90 -0
  50. package/dist/chunk-MCYD5LW7.cjs.map +1 -0
  51. package/dist/chunk-MQLS6Z7A.js +891 -0
  52. package/dist/chunk-MQLS6Z7A.js.map +1 -0
  53. package/dist/chunk-PUFCKXFW.cjs +312 -0
  54. package/dist/chunk-PUFCKXFW.cjs.map +1 -0
  55. package/dist/chunk-QNVYGEJ4.js +204 -0
  56. package/dist/chunk-QNVYGEJ4.js.map +1 -0
  57. package/dist/chunk-S3TIWWQL.cjs +322 -0
  58. package/dist/chunk-S3TIWWQL.cjs.map +1 -0
  59. package/dist/chunk-SXVANU23.js +164 -0
  60. package/dist/chunk-SXVANU23.js.map +1 -0
  61. package/dist/chunk-TYZ6ZISQ.cjs +368 -0
  62. package/dist/chunk-TYZ6ZISQ.cjs.map +1 -0
  63. package/dist/chunk-US6Y5RLR.cjs +205 -0
  64. package/dist/chunk-US6Y5RLR.cjs.map +1 -0
  65. package/dist/{chunk-QU6N55W6.cjs → chunk-V272B7RM.cjs} +11 -12
  66. package/dist/chunk-V272B7RM.cjs.map +1 -0
  67. package/dist/{chunk-D7T74TVR.js → chunk-WBLT2HL3.js} +19 -4
  68. package/dist/chunk-WBLT2HL3.js.map +1 -0
  69. package/dist/chunk-WE4USCF3.js +226 -0
  70. package/dist/chunk-WE4USCF3.js.map +1 -0
  71. package/dist/chunk-WI3X62RJ.cjs +810 -0
  72. package/dist/chunk-WI3X62RJ.cjs.map +1 -0
  73. package/dist/chunk-X43DWDXB.cjs +346 -0
  74. package/dist/chunk-X43DWDXB.cjs.map +1 -0
  75. package/dist/chunk-X4QMPCTP.cjs +259 -0
  76. package/dist/chunk-X4QMPCTP.cjs.map +1 -0
  77. package/dist/{chunk-X6C7BUWN.cjs → chunk-XQPJ63ZD.cjs} +4 -4
  78. package/dist/{chunk-X6C7BUWN.cjs.map → chunk-XQPJ63ZD.cjs.map} +1 -1
  79. package/dist/chunk-XW2HXQDO.js +302 -0
  80. package/dist/chunk-XW2HXQDO.js.map +1 -0
  81. package/dist/chunk-XWGAT2DA.js +44 -0
  82. package/dist/chunk-XWGAT2DA.js.map +1 -0
  83. package/dist/{chunk-SHWNNZBL.js → chunk-YP34EWWK.js} +9 -10
  84. package/dist/chunk-YP34EWWK.js.map +1 -0
  85. package/dist/chunk-ZN5R6OZB.cjs +1107 -0
  86. package/dist/chunk-ZN5R6OZB.cjs.map +1 -0
  87. package/dist/server/auth/defaults.d.ts +3 -0
  88. package/dist/server/auth/defaults.d.ts.map +1 -0
  89. package/dist/server/auth/helpers.d.ts +14 -0
  90. package/dist/server/auth/helpers.d.ts.map +1 -0
  91. package/dist/server/auth/index.cjs +137 -0
  92. package/dist/server/auth/index.cjs.map +1 -0
  93. package/dist/server/auth/index.d.ts +3 -0
  94. package/dist/server/auth/index.d.ts.map +1 -0
  95. package/dist/server/auth/index.js +127 -0
  96. package/dist/server/auth/index.js.map +1 -0
  97. package/dist/server/handlers/a2a.cjs +15 -7
  98. package/dist/server/handlers/a2a.d.ts +482 -0
  99. package/dist/server/handlers/a2a.d.ts.map +1 -1
  100. package/dist/server/handlers/a2a.js +1 -1
  101. package/dist/server/handlers/agent-builder.cjs +37 -37
  102. package/dist/server/handlers/agent-builder.d.ts +601 -77
  103. package/dist/server/handlers/agent-builder.d.ts.map +1 -1
  104. package/dist/server/handlers/agent-builder.js +1 -1
  105. package/dist/server/handlers/agents.cjs +53 -37
  106. package/dist/server/handlers/agents.d.ts +3275 -130
  107. package/dist/server/handlers/agents.d.ts.map +1 -1
  108. package/dist/server/handlers/agents.js +1 -1
  109. package/dist/server/handlers/logs.cjs +7 -7
  110. package/dist/server/handlers/logs.d.ts +135 -27
  111. package/dist/server/handlers/logs.d.ts.map +1 -1
  112. package/dist/server/handlers/logs.js +1 -1
  113. package/dist/server/handlers/mcp.cjs +40 -0
  114. package/dist/server/handlers/mcp.cjs.map +1 -0
  115. package/dist/server/handlers/mcp.d.ts +110 -0
  116. package/dist/server/handlers/mcp.d.ts.map +1 -0
  117. package/dist/server/handlers/mcp.js +3 -0
  118. package/dist/server/handlers/mcp.js.map +1 -0
  119. package/dist/server/handlers/memory.cjs +67 -27
  120. package/dist/server/handlers/memory.d.ts +933 -96
  121. package/dist/server/handlers/memory.d.ts.map +1 -1
  122. package/dist/server/handlers/memory.js +1 -1
  123. package/dist/server/handlers/observability.cjs +21 -5
  124. package/dist/server/handlers/observability.d.ts +119 -12
  125. package/dist/server/handlers/observability.d.ts.map +1 -1
  126. package/dist/server/handlers/observability.js +1 -1
  127. package/dist/server/handlers/scores.cjs +13 -13
  128. package/dist/server/handlers/scores.d.ts +110 -141
  129. package/dist/server/handlers/scores.d.ts.map +1 -1
  130. package/dist/server/handlers/scores.js +1 -1
  131. package/dist/server/handlers/stored-agents.cjs +28 -0
  132. package/dist/server/handlers/stored-agents.cjs.map +1 -0
  133. package/dist/server/handlers/stored-agents.d.ts +289 -0
  134. package/dist/server/handlers/stored-agents.d.ts.map +1 -0
  135. package/dist/server/handlers/stored-agents.js +3 -0
  136. package/dist/server/handlers/stored-agents.js.map +1 -0
  137. package/dist/server/handlers/test-utils.cjs +15 -0
  138. package/dist/server/handlers/test-utils.cjs.map +1 -0
  139. package/dist/server/handlers/test-utils.d.ts +6 -0
  140. package/dist/server/handlers/test-utils.d.ts.map +1 -0
  141. package/dist/server/handlers/test-utils.js +13 -0
  142. package/dist/server/handlers/test-utils.js.map +1 -0
  143. package/dist/server/handlers/tools.cjs +11 -11
  144. package/dist/server/handlers/tools.d.ts +69 -23
  145. package/dist/server/handlers/tools.d.ts.map +1 -1
  146. package/dist/server/handlers/tools.js +1 -1
  147. package/dist/server/handlers/utils.cjs +11 -3
  148. package/dist/server/handlers/utils.d.ts +5 -0
  149. package/dist/server/handlers/utils.d.ts.map +1 -1
  150. package/dist/server/handlers/utils.js +1 -1
  151. package/dist/server/handlers/vector.cjs +31 -7
  152. package/dist/server/handlers/vector.d.ts +93 -9
  153. package/dist/server/handlers/vector.d.ts.map +1 -1
  154. package/dist/server/handlers/vector.js +1 -1
  155. package/dist/server/handlers/voice.cjs +21 -9
  156. package/dist/server/handlers/voice.d.ts +81 -40
  157. package/dist/server/handlers/voice.d.ts.map +1 -1
  158. package/dist/server/handlers/voice.js +1 -1
  159. package/dist/server/handlers/workflows.cjs +69 -37
  160. package/dist/server/handlers/workflows.d.ts +929 -79
  161. package/dist/server/handlers/workflows.d.ts.map +1 -1
  162. package/dist/server/handlers/workflows.js +1 -1
  163. package/dist/server/handlers.cjs +36 -31
  164. package/dist/server/handlers.d.ts +1 -0
  165. package/dist/server/handlers.d.ts.map +1 -1
  166. package/dist/server/handlers.js +12 -11
  167. package/dist/server/schemas/a2a.d.ts +786 -0
  168. package/dist/server/schemas/a2a.d.ts.map +1 -0
  169. package/dist/server/schemas/agent-builder.d.ts +204 -0
  170. package/dist/server/schemas/agent-builder.d.ts.map +1 -0
  171. package/dist/server/schemas/agents.d.ts +1375 -0
  172. package/dist/server/schemas/agents.d.ts.map +1 -0
  173. package/dist/server/schemas/common.d.ts +179 -0
  174. package/dist/server/schemas/common.d.ts.map +1 -0
  175. package/dist/server/schemas/logs.d.ts +124 -0
  176. package/dist/server/schemas/logs.d.ts.map +1 -0
  177. package/dist/server/schemas/mcp.d.ts +299 -0
  178. package/dist/server/schemas/mcp.d.ts.map +1 -0
  179. package/dist/server/schemas/memory.d.ts +998 -0
  180. package/dist/server/schemas/memory.d.ts.map +1 -0
  181. package/dist/server/schemas/observability.d.ts +402 -0
  182. package/dist/server/schemas/observability.d.ts.map +1 -0
  183. package/dist/server/schemas/scores.d.ts +259 -0
  184. package/dist/server/schemas/scores.d.ts.map +1 -0
  185. package/dist/server/schemas/stored-agents.d.ts +792 -0
  186. package/dist/server/schemas/stored-agents.d.ts.map +1 -0
  187. package/dist/server/schemas/vectors.d.ts +107 -0
  188. package/dist/server/schemas/vectors.d.ts.map +1 -0
  189. package/dist/server/schemas/workflows.d.ts +608 -0
  190. package/dist/server/schemas/workflows.d.ts.map +1 -0
  191. package/dist/server/server-adapter/index.cjs +481 -0
  192. package/dist/server/server-adapter/index.cjs.map +1 -0
  193. package/dist/server/server-adapter/index.d.ts +91 -0
  194. package/dist/server/server-adapter/index.d.ts.map +1 -0
  195. package/dist/server/server-adapter/index.js +466 -0
  196. package/dist/server/server-adapter/index.js.map +1 -0
  197. package/dist/server/server-adapter/openapi-utils.d.ts +59 -0
  198. package/dist/server/server-adapter/openapi-utils.d.ts.map +1 -0
  199. package/dist/server/server-adapter/redact.d.ts +26 -0
  200. package/dist/server/server-adapter/redact.d.ts.map +1 -0
  201. package/dist/server/server-adapter/routes/a2a.d.ts +3 -0
  202. package/dist/server/server-adapter/routes/a2a.d.ts.map +1 -0
  203. package/dist/server/server-adapter/routes/agent-builder.d.ts +3 -0
  204. package/dist/server/server-adapter/routes/agent-builder.d.ts.map +1 -0
  205. package/dist/server/server-adapter/routes/agents.d.ts +3 -0
  206. package/dist/server/server-adapter/routes/agents.d.ts.map +1 -0
  207. package/dist/server/server-adapter/routes/index.d.ts +50 -0
  208. package/dist/server/server-adapter/routes/index.d.ts.map +1 -0
  209. package/dist/server/server-adapter/routes/legacy.d.ts +7 -0
  210. package/dist/server/server-adapter/routes/legacy.d.ts.map +1 -0
  211. package/dist/server/server-adapter/routes/logs.d.ts +3 -0
  212. package/dist/server/server-adapter/routes/logs.d.ts.map +1 -0
  213. package/dist/server/server-adapter/routes/mcp.d.ts +9 -0
  214. package/dist/server/server-adapter/routes/mcp.d.ts.map +1 -0
  215. package/dist/server/server-adapter/routes/memory.d.ts +3 -0
  216. package/dist/server/server-adapter/routes/memory.d.ts.map +1 -0
  217. package/dist/server/server-adapter/routes/observability.d.ts +3 -0
  218. package/dist/server/server-adapter/routes/observability.d.ts.map +1 -0
  219. package/dist/server/server-adapter/routes/route-builder.d.ts +52 -0
  220. package/dist/server/server-adapter/routes/route-builder.d.ts.map +1 -0
  221. package/dist/server/server-adapter/routes/scorers.d.ts +3 -0
  222. package/dist/server/server-adapter/routes/scorers.d.ts.map +1 -0
  223. package/dist/server/server-adapter/routes/stored-agents.d.ts +8 -0
  224. package/dist/server/server-adapter/routes/stored-agents.d.ts.map +1 -0
  225. package/dist/server/server-adapter/routes/stream-types.d.ts +10 -0
  226. package/dist/server/server-adapter/routes/stream-types.d.ts.map +1 -0
  227. package/dist/server/server-adapter/routes/tools.d.ts +3 -0
  228. package/dist/server/server-adapter/routes/tools.d.ts.map +1 -0
  229. package/dist/server/server-adapter/routes/vectors.d.ts +3 -0
  230. package/dist/server/server-adapter/routes/vectors.d.ts.map +1 -0
  231. package/dist/server/server-adapter/routes/workflows.d.ts +3 -0
  232. package/dist/server/server-adapter/routes/workflows.d.ts.map +1 -0
  233. package/dist/server/utils.d.ts +1 -1
  234. package/dist/server/utils.d.ts.map +1 -1
  235. package/dist/token-GVZ7HRD7.js +62 -0
  236. package/dist/{token-C3IMNCC4.js.map → token-GVZ7HRD7.js.map} +1 -1
  237. package/dist/{token-C3IMNCC4.js → token-JGA3ZWAN.js} +5 -6
  238. package/dist/token-JGA3ZWAN.js.map +1 -0
  239. package/dist/token-VFONFWVS.cjs +64 -0
  240. package/dist/{token-375W3LEI.cjs.map → token-VFONFWVS.cjs.map} +1 -1
  241. package/dist/{token-375W3LEI.cjs → token-ZOD6YIQ3.cjs} +7 -8
  242. package/dist/token-ZOD6YIQ3.cjs.map +1 -0
  243. package/dist/token-util-7R2ZFIXO.js +7 -0
  244. package/dist/{token-util-E5QO2RCL.js.map → token-util-7R2ZFIXO.js.map} +1 -1
  245. package/dist/token-util-BLJZJDBZ.cjs +9 -0
  246. package/dist/{token-util-CV3RRG6K.cjs.map → token-util-BLJZJDBZ.cjs.map} +1 -1
  247. package/dist/token-util-VGZUWSNR.cjs +9 -0
  248. package/dist/token-util-VGZUWSNR.cjs.map +1 -0
  249. package/dist/token-util-VKTPZLSE.js +7 -0
  250. package/dist/token-util-VKTPZLSE.js.map +1 -0
  251. package/package.json +30 -5
  252. package/dist/chunk-2IS5WICF.js +0 -23036
  253. package/dist/chunk-2IS5WICF.js.map +0 -1
  254. package/dist/chunk-2YZH5PH6.cjs +0 -200
  255. package/dist/chunk-2YZH5PH6.cjs.map +0 -1
  256. package/dist/chunk-3AMNUUZF.js +0 -124
  257. package/dist/chunk-3AMNUUZF.js.map +0 -1
  258. package/dist/chunk-3F52QCI4.js +0 -192
  259. package/dist/chunk-3F52QCI4.js.map +0 -1
  260. package/dist/chunk-4JF5WXPL.js +0 -502
  261. package/dist/chunk-4JF5WXPL.js.map +0 -1
  262. package/dist/chunk-73PAWDM5.js +0 -83
  263. package/dist/chunk-73PAWDM5.js.map +0 -1
  264. package/dist/chunk-A24TSVEZ.cjs +0 -130
  265. package/dist/chunk-A24TSVEZ.cjs.map +0 -1
  266. package/dist/chunk-A2NPD5N6.cjs +0 -517
  267. package/dist/chunk-A2NPD5N6.cjs.map +0 -1
  268. package/dist/chunk-B3Z6J745.js +0 -122
  269. package/dist/chunk-B3Z6J745.js.map +0 -1
  270. package/dist/chunk-BTWIR2B7.cjs +0 -28
  271. package/dist/chunk-BTWIR2B7.cjs.map +0 -1
  272. package/dist/chunk-D7T74TVR.js.map +0 -1
  273. package/dist/chunk-EHACNWDL.cjs +0 -681
  274. package/dist/chunk-EHACNWDL.cjs.map +0 -1
  275. package/dist/chunk-FPBYKMIS.js.map +0 -1
  276. package/dist/chunk-GLAZTMX3.cjs +0 -128
  277. package/dist/chunk-GLAZTMX3.cjs.map +0 -1
  278. package/dist/chunk-ID6JYDNL.cjs +0 -23075
  279. package/dist/chunk-ID6JYDNL.cjs.map +0 -1
  280. package/dist/chunk-KF3RI45U.cjs +0 -172
  281. package/dist/chunk-KF3RI45U.cjs.map +0 -1
  282. package/dist/chunk-KJIDZQRA.cjs.map +0 -1
  283. package/dist/chunk-KWH5QBXP.js +0 -123
  284. package/dist/chunk-KWH5QBXP.js.map +0 -1
  285. package/dist/chunk-ND5OKOMT.js +0 -165
  286. package/dist/chunk-ND5OKOMT.js.map +0 -1
  287. package/dist/chunk-PPMIB3FQ.cjs +0 -88
  288. package/dist/chunk-PPMIB3FQ.cjs.map +0 -1
  289. package/dist/chunk-QU6N55W6.cjs.map +0 -1
  290. package/dist/chunk-S54HNARD.cjs +0 -131
  291. package/dist/chunk-S54HNARD.cjs.map +0 -1
  292. package/dist/chunk-SHWNNZBL.js.map +0 -1
  293. package/dist/chunk-SZIFSF4T.js +0 -25
  294. package/dist/chunk-SZIFSF4T.js.map +0 -1
  295. package/dist/chunk-W2KMU354.cjs.map +0 -1
  296. package/dist/chunk-X3MICMI2.cjs +0 -620
  297. package/dist/chunk-X3MICMI2.cjs.map +0 -1
  298. package/dist/chunk-Z2O5YVHY.js +0 -661
  299. package/dist/chunk-Z2O5YVHY.js.map +0 -1
  300. package/dist/chunk-ZJ6KEY6H.js +0 -600
  301. package/dist/chunk-ZJ6KEY6H.js.map +0 -1
  302. package/dist/token-util-CV3RRG6K.cjs +0 -9
  303. package/dist/token-util-E5QO2RCL.js +0 -7
@@ -0,0 +1,891 @@
1
+ import { validateBody } from './chunk-XWGAT2DA.js';
2
+ import { createPagePaginationSchema, paginationInfoSchema, successResponseSchema } from './chunk-HT4LP3BO.js';
3
+ import { createRoute } from './chunk-SXVANU23.js';
4
+ import { handleError } from './chunk-UXGQZUYZ.js';
5
+ import { HTTPException } from './chunk-6QWQZI4Q.js';
6
+ import { __export } from './chunk-PR4QN5HX.js';
7
+ import { generateEmptyFromSchema } from '@mastra/core/utils';
8
+ import z from 'zod';
9
+
10
+ // src/server/handlers/memory.ts
11
+ var memory_exports = {};
12
+ __export(memory_exports, {
13
+ CREATE_THREAD_NETWORK_ROUTE: () => CREATE_THREAD_NETWORK_ROUTE,
14
+ CREATE_THREAD_ROUTE: () => CREATE_THREAD_ROUTE,
15
+ DELETE_MESSAGES_NETWORK_ROUTE: () => DELETE_MESSAGES_NETWORK_ROUTE,
16
+ DELETE_MESSAGES_ROUTE: () => DELETE_MESSAGES_ROUTE,
17
+ DELETE_THREAD_NETWORK_ROUTE: () => DELETE_THREAD_NETWORK_ROUTE,
18
+ DELETE_THREAD_ROUTE: () => DELETE_THREAD_ROUTE,
19
+ GET_MEMORY_CONFIG_ROUTE: () => GET_MEMORY_CONFIG_ROUTE,
20
+ GET_MEMORY_STATUS_NETWORK_ROUTE: () => GET_MEMORY_STATUS_NETWORK_ROUTE,
21
+ GET_MEMORY_STATUS_ROUTE: () => GET_MEMORY_STATUS_ROUTE,
22
+ GET_THREAD_BY_ID_NETWORK_ROUTE: () => GET_THREAD_BY_ID_NETWORK_ROUTE,
23
+ GET_THREAD_BY_ID_ROUTE: () => GET_THREAD_BY_ID_ROUTE,
24
+ GET_WORKING_MEMORY_ROUTE: () => GET_WORKING_MEMORY_ROUTE,
25
+ LIST_MESSAGES_NETWORK_ROUTE: () => LIST_MESSAGES_NETWORK_ROUTE,
26
+ LIST_MESSAGES_ROUTE: () => LIST_MESSAGES_ROUTE,
27
+ LIST_THREADS_NETWORK_ROUTE: () => LIST_THREADS_NETWORK_ROUTE,
28
+ LIST_THREADS_ROUTE: () => LIST_THREADS_ROUTE,
29
+ SAVE_MESSAGES_NETWORK_ROUTE: () => SAVE_MESSAGES_NETWORK_ROUTE,
30
+ SAVE_MESSAGES_ROUTE: () => SAVE_MESSAGES_ROUTE,
31
+ SEARCH_MEMORY_ROUTE: () => SEARCH_MEMORY_ROUTE,
32
+ UPDATE_THREAD_NETWORK_ROUTE: () => UPDATE_THREAD_NETWORK_ROUTE,
33
+ UPDATE_THREAD_ROUTE: () => UPDATE_THREAD_ROUTE,
34
+ UPDATE_WORKING_MEMORY_ROUTE: () => UPDATE_WORKING_MEMORY_ROUTE,
35
+ getTextContent: () => getTextContent
36
+ });
37
+ var threadIdPathParams = z.object({
38
+ threadId: z.string().describe("Unique identifier for the conversation thread")
39
+ });
40
+ var agentIdQuerySchema = z.object({
41
+ agentId: z.string()
42
+ });
43
+ var storageOrderBySchema = z.object({
44
+ field: z.enum(["createdAt", "updatedAt"]).optional(),
45
+ direction: z.enum(["ASC", "DESC"]).optional()
46
+ });
47
+ var messageOrderBySchema = z.object({
48
+ field: z.enum(["createdAt"]).optional(),
49
+ direction: z.enum(["ASC", "DESC"]).optional()
50
+ });
51
+ var includeSchema = z.preprocess(
52
+ (val) => {
53
+ if (typeof val === "string") {
54
+ try {
55
+ return JSON.parse(val);
56
+ } catch {
57
+ return void 0;
58
+ }
59
+ }
60
+ return val;
61
+ },
62
+ z.array(
63
+ z.object({
64
+ id: z.string(),
65
+ threadId: z.string().optional(),
66
+ withPreviousMessages: z.number().optional(),
67
+ withNextMessages: z.number().optional()
68
+ })
69
+ ).optional()
70
+ );
71
+ var filterSchema = z.preprocess(
72
+ (val) => {
73
+ if (typeof val === "string") {
74
+ try {
75
+ return JSON.parse(val);
76
+ } catch {
77
+ return void 0;
78
+ }
79
+ }
80
+ return val;
81
+ },
82
+ z.object({
83
+ dateRange: z.object({
84
+ start: z.coerce.date().optional(),
85
+ end: z.coerce.date().optional()
86
+ }).optional()
87
+ }).optional()
88
+ );
89
+ var memoryConfigSchema = z.preprocess((val) => {
90
+ if (typeof val === "string") {
91
+ try {
92
+ return JSON.parse(val);
93
+ } catch {
94
+ return void 0;
95
+ }
96
+ }
97
+ return val;
98
+ }, z.record(z.string(), z.unknown()).optional());
99
+ var threadSchema = z.object({
100
+ id: z.string(),
101
+ title: z.string().optional(),
102
+ resourceId: z.string(),
103
+ createdAt: z.date(),
104
+ updatedAt: z.date(),
105
+ metadata: z.record(z.string(), z.unknown()).optional()
106
+ });
107
+ var messageSchema = z.any();
108
+ var getMemoryStatusQuerySchema = agentIdQuerySchema;
109
+ var getMemoryConfigQuerySchema = agentIdQuerySchema;
110
+ var listThreadsQuerySchema = createPagePaginationSchema(100).extend({
111
+ agentId: z.string(),
112
+ resourceId: z.string(),
113
+ orderBy: storageOrderBySchema.optional()
114
+ });
115
+ var getThreadByIdQuerySchema = agentIdQuerySchema;
116
+ var listMessagesQuerySchema = createPagePaginationSchema(40).extend({
117
+ agentId: z.string(),
118
+ resourceId: z.string().optional(),
119
+ orderBy: messageOrderBySchema.optional(),
120
+ include: includeSchema,
121
+ filter: filterSchema
122
+ });
123
+ var getWorkingMemoryQuerySchema = z.object({
124
+ agentId: z.string(),
125
+ resourceId: z.string().optional(),
126
+ memoryConfig: memoryConfigSchema
127
+ });
128
+ var getMemoryStatusNetworkQuerySchema = agentIdQuerySchema;
129
+ var listThreadsNetworkQuerySchema = createPagePaginationSchema(100).extend({
130
+ agentId: z.string(),
131
+ resourceId: z.string(),
132
+ orderBy: storageOrderBySchema.optional()
133
+ });
134
+ var getThreadByIdNetworkQuerySchema = agentIdQuerySchema;
135
+ var listMessagesNetworkQuerySchema = createPagePaginationSchema(40).extend({
136
+ agentId: z.string(),
137
+ resourceId: z.string().optional(),
138
+ orderBy: messageOrderBySchema.optional(),
139
+ include: includeSchema,
140
+ filter: filterSchema
141
+ });
142
+ var saveMessagesNetworkQuerySchema = agentIdQuerySchema;
143
+ var createThreadNetworkQuerySchema = agentIdQuerySchema;
144
+ var updateThreadNetworkQuerySchema = agentIdQuerySchema;
145
+ var deleteThreadNetworkQuerySchema = agentIdQuerySchema;
146
+ var deleteMessagesNetworkQuerySchema = agentIdQuerySchema;
147
+ var memoryStatusResponseSchema = z.object({
148
+ result: z.boolean()
149
+ });
150
+ var memoryConfigResponseSchema = z.object({
151
+ config: z.object({
152
+ lastMessages: z.union([z.number(), z.literal(false)]).optional(),
153
+ semanticRecall: z.union([z.boolean(), z.any()]).optional(),
154
+ workingMemory: z.any().optional()
155
+ })
156
+ });
157
+ var listThreadsResponseSchema = paginationInfoSchema.extend({
158
+ threads: z.array(threadSchema)
159
+ });
160
+ var getThreadByIdResponseSchema = threadSchema;
161
+ var listMessagesResponseSchema = z.object({
162
+ messages: z.array(messageSchema),
163
+ uiMessages: z.unknown()
164
+ // Converted messages in UI format
165
+ });
166
+ var getWorkingMemoryResponseSchema = z.object({
167
+ workingMemory: z.unknown(),
168
+ // Can be string or structured object depending on template
169
+ source: z.enum(["thread", "resource"]),
170
+ workingMemoryTemplate: z.unknown(),
171
+ // Template structure varies
172
+ threadExists: z.boolean()
173
+ });
174
+ var saveMessagesBodySchema = z.object({
175
+ messages: z.array(messageSchema)
176
+ });
177
+ var createThreadBodySchema = z.object({
178
+ resourceId: z.string(),
179
+ title: z.string().optional(),
180
+ metadata: z.record(z.string(), z.unknown()).optional(),
181
+ threadId: z.string().optional()
182
+ });
183
+ var updateThreadBodySchema = z.object({
184
+ title: z.string().optional(),
185
+ metadata: z.record(z.string(), z.unknown()).optional(),
186
+ resourceId: z.string().optional()
187
+ });
188
+ var updateWorkingMemoryBodySchema = z.object({
189
+ workingMemory: z.string(),
190
+ resourceId: z.string().optional(),
191
+ memoryConfig: z.record(z.string(), z.unknown()).optional()
192
+ });
193
+ var deleteMessagesBodySchema = z.object({
194
+ messageIds: z.union([
195
+ z.string(),
196
+ z.array(z.string()),
197
+ z.object({ id: z.string() }),
198
+ z.array(z.object({ id: z.string() }))
199
+ ])
200
+ });
201
+ var searchMemoryQuerySchema = z.object({
202
+ agentId: z.string(),
203
+ searchQuery: z.string(),
204
+ resourceId: z.string(),
205
+ threadId: z.string().optional(),
206
+ limit: z.coerce.number().optional().default(20),
207
+ memoryConfig: memoryConfigSchema
208
+ });
209
+ var saveMessagesResponseSchema = z.object({
210
+ messages: z.array(messageSchema)
211
+ });
212
+ var deleteThreadResponseSchema = z.object({
213
+ result: z.string()
214
+ });
215
+ var updateWorkingMemoryResponseSchema = successResponseSchema;
216
+ var deleteMessagesResponseSchema = successResponseSchema.extend({
217
+ message: z.string()
218
+ });
219
+ var searchMemoryResponseSchema = z.object({
220
+ results: z.array(z.unknown()),
221
+ count: z.number(),
222
+ query: z.string(),
223
+ searchScope: z.string().optional(),
224
+ searchType: z.string().optional()
225
+ });
226
+
227
+ // src/server/handlers/memory.ts
228
+ function getTextContent(message) {
229
+ if (typeof message.content === "string") {
230
+ return message.content;
231
+ }
232
+ if (message.content && typeof message.content === "object" && "parts" in message.content) {
233
+ const textPart = message.content.parts.find((p) => p.type === "text");
234
+ return textPart?.text || "";
235
+ }
236
+ return "";
237
+ }
238
+ async function getMemoryFromContext({
239
+ mastra,
240
+ agentId,
241
+ requestContext
242
+ }) {
243
+ const logger = mastra.getLogger();
244
+ let agent;
245
+ if (agentId) {
246
+ try {
247
+ agent = mastra.getAgentById(agentId);
248
+ } catch (error) {
249
+ logger.debug("Error getting agent from mastra, searching agents for agent", error);
250
+ }
251
+ }
252
+ if (agentId && !agent) {
253
+ logger.debug("Agent not found, searching agents for agent", { agentId });
254
+ const agents = mastra.listAgents();
255
+ if (Object.keys(agents || {}).length) {
256
+ for (const [_, ag] of Object.entries(agents)) {
257
+ try {
258
+ const agents2 = await ag.listAgents();
259
+ if (agents2[agentId]) {
260
+ agent = agents2[agentId];
261
+ break;
262
+ }
263
+ } catch (error) {
264
+ logger.debug("Error getting agent from agent", error);
265
+ }
266
+ }
267
+ }
268
+ if (!agent) {
269
+ throw new HTTPException(404, { message: "Agent not found" });
270
+ }
271
+ }
272
+ if (agent) {
273
+ return await agent?.getMemory({
274
+ requestContext
275
+ });
276
+ }
277
+ }
278
+ var GET_MEMORY_STATUS_ROUTE = createRoute({
279
+ method: "GET",
280
+ path: "/api/memory/status",
281
+ responseType: "json",
282
+ queryParamSchema: getMemoryStatusQuerySchema,
283
+ responseSchema: memoryStatusResponseSchema,
284
+ summary: "Get memory status",
285
+ description: "Returns the current status of the memory system including configuration and health information",
286
+ tags: ["Memory"],
287
+ handler: async ({ mastra, agentId, requestContext }) => {
288
+ try {
289
+ const memory = await getMemoryFromContext({ mastra, agentId, requestContext });
290
+ if (!memory) {
291
+ return { result: false };
292
+ }
293
+ return { result: true };
294
+ } catch (error) {
295
+ return handleError(error, "Error getting memory status");
296
+ }
297
+ }
298
+ });
299
+ var GET_MEMORY_CONFIG_ROUTE = createRoute({
300
+ method: "GET",
301
+ path: "/api/memory/config",
302
+ responseType: "json",
303
+ queryParamSchema: getMemoryConfigQuerySchema,
304
+ responseSchema: memoryConfigResponseSchema,
305
+ summary: "Get memory configuration",
306
+ description: "Returns the memory configuration for a specific agent or the system default",
307
+ tags: ["Memory"],
308
+ handler: async ({ mastra, agentId, requestContext }) => {
309
+ try {
310
+ const memory = await getMemoryFromContext({ mastra, agentId, requestContext });
311
+ if (!memory) {
312
+ throw new HTTPException(400, { message: "Memory is not initialized" });
313
+ }
314
+ const config = memory.getMergedThreadConfig({});
315
+ return { config };
316
+ } catch (error) {
317
+ return handleError(error, "Error getting memory configuration");
318
+ }
319
+ }
320
+ });
321
+ var LIST_THREADS_ROUTE = createRoute({
322
+ method: "GET",
323
+ path: "/api/memory/threads",
324
+ responseType: "json",
325
+ queryParamSchema: listThreadsQuerySchema,
326
+ responseSchema: listThreadsResponseSchema,
327
+ summary: "List memory threads",
328
+ description: "Returns a paginated list of conversation threads filtered by resource ID",
329
+ tags: ["Memory"],
330
+ handler: async ({ mastra, agentId, resourceId, requestContext, page, perPage, orderBy }) => {
331
+ try {
332
+ const memory = await getMemoryFromContext({ mastra, agentId, requestContext });
333
+ if (!memory) {
334
+ throw new HTTPException(400, { message: "Memory is not initialized" });
335
+ }
336
+ validateBody({ resourceId });
337
+ const result = await memory.listThreadsByResourceId({
338
+ resourceId,
339
+ page,
340
+ perPage,
341
+ orderBy
342
+ });
343
+ return result;
344
+ } catch (error) {
345
+ return handleError(error, "Error listing threads");
346
+ }
347
+ }
348
+ });
349
+ var GET_THREAD_BY_ID_ROUTE = createRoute({
350
+ method: "GET",
351
+ path: "/api/memory/threads/:threadId",
352
+ responseType: "json",
353
+ pathParamSchema: threadIdPathParams,
354
+ queryParamSchema: getThreadByIdQuerySchema,
355
+ responseSchema: getThreadByIdResponseSchema,
356
+ summary: "Get thread by ID",
357
+ description: "Returns details for a specific conversation thread",
358
+ tags: ["Memory"],
359
+ handler: async ({ mastra, agentId, threadId, requestContext }) => {
360
+ try {
361
+ validateBody({ threadId });
362
+ const memory = await getMemoryFromContext({ mastra, agentId, requestContext });
363
+ if (!memory) {
364
+ throw new HTTPException(400, { message: "Memory is not initialized" });
365
+ }
366
+ const thread = await memory.getThreadById({ threadId });
367
+ if (!thread) {
368
+ throw new HTTPException(404, { message: "Thread not found" });
369
+ }
370
+ return thread;
371
+ } catch (error) {
372
+ return handleError(error, "Error getting thread");
373
+ }
374
+ }
375
+ });
376
+ var LIST_MESSAGES_ROUTE = createRoute({
377
+ method: "GET",
378
+ path: "/api/memory/threads/:threadId/messages",
379
+ responseType: "json",
380
+ pathParamSchema: threadIdPathParams,
381
+ queryParamSchema: listMessagesQuerySchema,
382
+ responseSchema: listMessagesResponseSchema,
383
+ summary: "List thread messages",
384
+ description: "Returns a paginated list of messages in a conversation thread",
385
+ tags: ["Memory"],
386
+ handler: async ({
387
+ mastra,
388
+ agentId,
389
+ threadId,
390
+ resourceId,
391
+ perPage,
392
+ page,
393
+ orderBy,
394
+ include,
395
+ filter,
396
+ requestContext
397
+ }) => {
398
+ try {
399
+ validateBody({ threadId });
400
+ const memory = await getMemoryFromContext({ mastra, agentId, requestContext });
401
+ if (!memory) {
402
+ throw new HTTPException(400, { message: "Memory is not initialized" });
403
+ }
404
+ if (!threadId) {
405
+ throw new HTTPException(400, { message: "No threadId found" });
406
+ }
407
+ const thread = await memory.getThreadById({ threadId });
408
+ if (!thread) {
409
+ throw new HTTPException(404, { message: "Thread not found" });
410
+ }
411
+ const result = await memory.recall({
412
+ threadId,
413
+ resourceId,
414
+ perPage,
415
+ page,
416
+ orderBy,
417
+ include,
418
+ filter
419
+ });
420
+ return result;
421
+ } catch (error) {
422
+ return handleError(error, "Error getting messages");
423
+ }
424
+ }
425
+ });
426
+ var GET_WORKING_MEMORY_ROUTE = createRoute({
427
+ method: "GET",
428
+ path: "/api/memory/threads/:threadId/working-memory",
429
+ responseType: "json",
430
+ pathParamSchema: threadIdPathParams,
431
+ queryParamSchema: getWorkingMemoryQuerySchema,
432
+ responseSchema: getWorkingMemoryResponseSchema,
433
+ summary: "Get working memory",
434
+ description: "Returns the working memory state for a thread",
435
+ tags: ["Memory"],
436
+ handler: async ({ mastra, agentId, threadId, resourceId, requestContext, memoryConfig }) => {
437
+ try {
438
+ const memory = await getMemoryFromContext({ mastra, agentId, requestContext });
439
+ validateBody({ threadId });
440
+ if (!memory) {
441
+ throw new HTTPException(400, { message: "Memory is not initialized" });
442
+ }
443
+ const thread = await memory.getThreadById({ threadId });
444
+ const threadExists = !!thread;
445
+ const template = await memory.getWorkingMemoryTemplate({ memoryConfig });
446
+ const workingMemoryTemplate = template?.format === "json" ? { ...template, content: JSON.stringify(generateEmptyFromSchema(template.content)) } : template;
447
+ const workingMemory = await memory.getWorkingMemory({ threadId, resourceId, memoryConfig });
448
+ const config = memory.getMergedThreadConfig(memoryConfig || {});
449
+ const source = config.workingMemory?.scope !== "thread" && resourceId ? "resource" : "thread";
450
+ return { workingMemory, source, workingMemoryTemplate, threadExists };
451
+ } catch (error) {
452
+ return handleError(error, "Error getting working memory");
453
+ }
454
+ }
455
+ });
456
+ var SAVE_MESSAGES_ROUTE = createRoute({
457
+ method: "POST",
458
+ path: "/api/memory/save-messages",
459
+ responseType: "json",
460
+ queryParamSchema: agentIdQuerySchema,
461
+ bodySchema: saveMessagesBodySchema,
462
+ responseSchema: saveMessagesResponseSchema,
463
+ summary: "Save messages",
464
+ description: "Saves new messages to memory",
465
+ tags: ["Memory"],
466
+ handler: async ({ mastra, agentId, messages, requestContext }) => {
467
+ try {
468
+ const memory = await getMemoryFromContext({ mastra, agentId, requestContext });
469
+ if (!memory) {
470
+ throw new HTTPException(400, { message: "Memory is not initialized" });
471
+ }
472
+ if (!messages) {
473
+ throw new HTTPException(400, { message: "Messages are required" });
474
+ }
475
+ if (!Array.isArray(messages)) {
476
+ throw new HTTPException(400, { message: "Messages should be an array" });
477
+ }
478
+ const invalidMessages = messages.filter((message) => !message.threadId || !message.resourceId);
479
+ if (invalidMessages.length > 0) {
480
+ throw new HTTPException(400, {
481
+ message: `All messages must have threadId and resourceId fields. Found ${invalidMessages.length} invalid message(s).`
482
+ });
483
+ }
484
+ const processedMessages = messages.map((message) => ({
485
+ ...message,
486
+ id: message.id || memory.generateId(),
487
+ createdAt: message.createdAt ? new Date(message.createdAt) : /* @__PURE__ */ new Date()
488
+ }));
489
+ const result = await memory.saveMessages({ messages: processedMessages, memoryConfig: {} });
490
+ return result;
491
+ } catch (error) {
492
+ return handleError(error, "Error saving messages");
493
+ }
494
+ }
495
+ });
496
+ var CREATE_THREAD_ROUTE = createRoute({
497
+ method: "POST",
498
+ path: "/api/memory/threads",
499
+ responseType: "json",
500
+ queryParamSchema: agentIdQuerySchema,
501
+ bodySchema: createThreadBodySchema,
502
+ responseSchema: getThreadByIdResponseSchema,
503
+ summary: "Create thread",
504
+ description: "Creates a new conversation thread",
505
+ tags: ["Memory"],
506
+ handler: async ({ mastra, agentId, resourceId, title, metadata, threadId, requestContext }) => {
507
+ try {
508
+ const memory = await getMemoryFromContext({ mastra, agentId, requestContext });
509
+ if (!memory) {
510
+ throw new HTTPException(400, { message: "Memory is not initialized" });
511
+ }
512
+ validateBody({ resourceId });
513
+ const result = await memory.createThread({
514
+ resourceId,
515
+ title,
516
+ metadata,
517
+ threadId
518
+ });
519
+ return result;
520
+ } catch (error) {
521
+ return handleError(error, "Error saving thread to memory");
522
+ }
523
+ }
524
+ });
525
+ var UPDATE_THREAD_ROUTE = createRoute({
526
+ method: "PATCH",
527
+ path: "/api/memory/threads/:threadId",
528
+ responseType: "json",
529
+ pathParamSchema: threadIdPathParams,
530
+ queryParamSchema: agentIdQuerySchema,
531
+ bodySchema: updateThreadBodySchema,
532
+ responseSchema: getThreadByIdResponseSchema,
533
+ summary: "Update thread",
534
+ description: "Updates a conversation thread",
535
+ tags: ["Memory"],
536
+ handler: async ({ mastra, agentId, threadId, title, metadata, resourceId, requestContext }) => {
537
+ try {
538
+ const memory = await getMemoryFromContext({ mastra, agentId, requestContext });
539
+ const updatedAt = /* @__PURE__ */ new Date();
540
+ validateBody({ threadId });
541
+ if (!memory) {
542
+ throw new HTTPException(400, { message: "Memory is not initialized" });
543
+ }
544
+ const thread = await memory.getThreadById({ threadId });
545
+ if (!thread) {
546
+ throw new HTTPException(404, { message: "Thread not found" });
547
+ }
548
+ const updatedThread = {
549
+ ...thread,
550
+ title: title || thread.title,
551
+ metadata: metadata || thread.metadata,
552
+ resourceId: resourceId || thread.resourceId,
553
+ createdAt: thread.createdAt,
554
+ updatedAt
555
+ };
556
+ const result = await memory.saveThread({ thread: updatedThread });
557
+ return {
558
+ ...result,
559
+ resourceId: result.resourceId ?? null
560
+ };
561
+ } catch (error) {
562
+ return handleError(error, "Error updating thread");
563
+ }
564
+ }
565
+ });
566
+ var DELETE_THREAD_ROUTE = createRoute({
567
+ method: "DELETE",
568
+ path: "/api/memory/threads/:threadId",
569
+ responseType: "json",
570
+ pathParamSchema: threadIdPathParams,
571
+ queryParamSchema: agentIdQuerySchema,
572
+ responseSchema: deleteThreadResponseSchema,
573
+ summary: "Delete thread",
574
+ description: "Deletes a conversation thread",
575
+ tags: ["Memory"],
576
+ handler: async ({ mastra, agentId, threadId, requestContext }) => {
577
+ try {
578
+ validateBody({ threadId });
579
+ const memory = await getMemoryFromContext({ mastra, agentId, requestContext });
580
+ if (!memory) {
581
+ throw new HTTPException(400, { message: "Memory is not initialized" });
582
+ }
583
+ const thread = await memory.getThreadById({ threadId });
584
+ if (!thread) {
585
+ throw new HTTPException(404, { message: "Thread not found" });
586
+ }
587
+ await memory.deleteThread(threadId);
588
+ return { result: "Thread deleted" };
589
+ } catch (error) {
590
+ return handleError(error, "Error deleting thread");
591
+ }
592
+ }
593
+ });
594
+ var UPDATE_WORKING_MEMORY_ROUTE = createRoute({
595
+ method: "POST",
596
+ path: "/api/memory/threads/:threadId/working-memory",
597
+ responseType: "json",
598
+ pathParamSchema: threadIdPathParams,
599
+ queryParamSchema: agentIdQuerySchema,
600
+ bodySchema: updateWorkingMemoryBodySchema,
601
+ responseSchema: updateWorkingMemoryResponseSchema,
602
+ summary: "Update working memory",
603
+ description: "Updates the working memory state for a thread",
604
+ tags: ["Memory"],
605
+ handler: async ({ mastra, agentId, threadId, resourceId, memoryConfig, workingMemory, requestContext }) => {
606
+ try {
607
+ validateBody({ threadId, workingMemory });
608
+ const memory = await getMemoryFromContext({ mastra, agentId, requestContext });
609
+ if (!memory) {
610
+ throw new HTTPException(400, { message: "Memory is not initialized" });
611
+ }
612
+ const thread = await memory.getThreadById({ threadId });
613
+ if (!thread) {
614
+ throw new HTTPException(404, { message: "Thread not found" });
615
+ }
616
+ await memory.updateWorkingMemory({ threadId, resourceId, workingMemory, memoryConfig });
617
+ return { success: true };
618
+ } catch (error) {
619
+ return handleError(error, "Error updating working memory");
620
+ }
621
+ }
622
+ });
623
+ var DELETE_MESSAGES_ROUTE = createRoute({
624
+ method: "POST",
625
+ path: "/api/memory/messages/delete",
626
+ responseType: "json",
627
+ queryParamSchema: agentIdQuerySchema,
628
+ bodySchema: deleteMessagesBodySchema,
629
+ responseSchema: deleteMessagesResponseSchema,
630
+ summary: "Delete messages",
631
+ description: "Deletes specific messages from memory",
632
+ tags: ["Memory"],
633
+ handler: async ({ mastra, agentId, messageIds, requestContext }) => {
634
+ try {
635
+ if (messageIds === void 0 || messageIds === null) {
636
+ throw new HTTPException(400, { message: "messageIds is required" });
637
+ }
638
+ const memory = await getMemoryFromContext({ mastra, agentId, requestContext });
639
+ if (!memory) {
640
+ throw new HTTPException(400, { message: "Memory is not initialized" });
641
+ }
642
+ let normalizedIds;
643
+ if (Array.isArray(messageIds)) {
644
+ normalizedIds = messageIds;
645
+ } else if (typeof messageIds === "string") {
646
+ normalizedIds = [messageIds];
647
+ } else {
648
+ normalizedIds = [messageIds];
649
+ }
650
+ await memory.deleteMessages(normalizedIds);
651
+ const count = Array.isArray(messageIds) ? messageIds.length : 1;
652
+ return { success: true, message: `${count} message${count === 1 ? "" : "s"} deleted successfully` };
653
+ } catch (error) {
654
+ return handleError(error, "Error deleting messages");
655
+ }
656
+ }
657
+ });
658
+ var SEARCH_MEMORY_ROUTE = createRoute({
659
+ method: "GET",
660
+ path: "/api/memory/search",
661
+ responseType: "json",
662
+ queryParamSchema: searchMemoryQuerySchema,
663
+ responseSchema: searchMemoryResponseSchema,
664
+ summary: "Search memory",
665
+ description: "Searches across memory using semantic or text search",
666
+ tags: ["Memory"],
667
+ handler: async ({ mastra, agentId, searchQuery, resourceId, threadId, limit = 20, requestContext, memoryConfig }) => {
668
+ try {
669
+ validateBody({ searchQuery, resourceId });
670
+ const memory = await getMemoryFromContext({ mastra, agentId, requestContext });
671
+ if (!memory) {
672
+ throw new HTTPException(400, { message: "Memory is not initialized" });
673
+ }
674
+ const config = memory.getMergedThreadConfig(memoryConfig || {});
675
+ const hasSemanticRecall = !!config?.semanticRecall;
676
+ const resourceScope = typeof config?.semanticRecall === "object" ? config?.semanticRecall?.scope !== "thread" : true;
677
+ const searchResults = [];
678
+ if (threadId && !resourceScope) {
679
+ const thread = await memory.getThreadById({ threadId });
680
+ if (!thread) {
681
+ return {
682
+ results: [],
683
+ count: 0,
684
+ query: searchQuery,
685
+ searchScope: resourceScope ? "resource" : "thread",
686
+ searchType: hasSemanticRecall ? "semantic" : "text"
687
+ };
688
+ }
689
+ if (thread.resourceId !== resourceId) {
690
+ throw new HTTPException(403, { message: "Thread does not belong to the specified resource" });
691
+ }
692
+ }
693
+ if (!threadId) {
694
+ const { threads } = await memory.listThreadsByResourceId({
695
+ resourceId,
696
+ page: 0,
697
+ perPage: 1,
698
+ orderBy: { field: "updatedAt", direction: "DESC" }
699
+ });
700
+ if (threads.length === 0) {
701
+ return {
702
+ results: [],
703
+ count: 0,
704
+ query: searchQuery,
705
+ searchScope: resourceScope ? "resource" : "thread",
706
+ searchType: hasSemanticRecall ? "semantic" : "text"
707
+ };
708
+ }
709
+ threadId = threads[0].id;
710
+ }
711
+ const beforeRange = typeof config.semanticRecall === `boolean` ? 2 : typeof config.semanticRecall?.messageRange === `number` ? config.semanticRecall.messageRange : config.semanticRecall?.messageRange.before || 2;
712
+ const afterRange = typeof config.semanticRecall === `boolean` ? 2 : typeof config.semanticRecall?.messageRange === `number` ? config.semanticRecall.messageRange : config.semanticRecall?.messageRange.after || 2;
713
+ if (resourceScope && config.semanticRecall) {
714
+ config.semanticRecall = typeof config.semanticRecall === `boolean` ? (
715
+ // make message range 0 so we can highlight the matches in search, message range will include other messages, not the matching ones
716
+ // and we add prev/next messages in a special section on each message anyway
717
+ { messageRange: 0, topK: 2, scope: "resource" }
718
+ ) : { ...config.semanticRecall, messageRange: 0 };
719
+ }
720
+ const threadConfig = memory.getMergedThreadConfig(config || {});
721
+ if (!threadConfig.lastMessages && !threadConfig.semanticRecall) {
722
+ return { results: [], count: 0, query: searchQuery };
723
+ }
724
+ const result = await memory.recall({
725
+ threadId,
726
+ resourceId,
727
+ perPage: threadConfig.lastMessages,
728
+ threadConfig: config,
729
+ vectorSearchString: threadConfig.semanticRecall && searchQuery ? searchQuery : void 0
730
+ });
731
+ const threadIds = Array.from(
732
+ new Set(result.messages.map((m) => m.threadId || threadId).filter(Boolean))
733
+ );
734
+ const fetched = await Promise.all(threadIds.map((id) => memory.getThreadById({ threadId: id })));
735
+ const threadMap = new Map(fetched.filter(Boolean).map((t) => [t.id, t]));
736
+ for (const msg of result.messages) {
737
+ const content = getTextContent(msg);
738
+ const msgThreadId = msg.threadId || threadId;
739
+ const thread = threadMap.get(msgThreadId);
740
+ const threadMessages = (await memory.recall({ threadId: msgThreadId })).messages;
741
+ const messageIndex = threadMessages.findIndex((m) => m.id === msg.id);
742
+ const searchResult = {
743
+ id: msg.id,
744
+ role: msg.role,
745
+ content,
746
+ createdAt: msg.createdAt,
747
+ threadId: msgThreadId,
748
+ threadTitle: thread?.title || msgThreadId
749
+ };
750
+ if (messageIndex !== -1) {
751
+ searchResult.context = {
752
+ before: threadMessages.slice(Math.max(0, messageIndex - beforeRange), messageIndex).map((m) => ({
753
+ id: m.id,
754
+ role: m.role,
755
+ content: getTextContent(m),
756
+ createdAt: m.createdAt || /* @__PURE__ */ new Date()
757
+ })),
758
+ after: threadMessages.slice(messageIndex + 1, messageIndex + afterRange + 1).map((m) => ({
759
+ id: m.id,
760
+ role: m.role,
761
+ content: getTextContent(m),
762
+ createdAt: m.createdAt || /* @__PURE__ */ new Date()
763
+ }))
764
+ };
765
+ }
766
+ searchResults.push(searchResult);
767
+ }
768
+ const sortedResults = searchResults.sort((a, b) => new Date(b.createdAt).getTime() - new Date(a.createdAt).getTime()).slice(0, limit);
769
+ return {
770
+ results: sortedResults,
771
+ count: sortedResults.length,
772
+ query: searchQuery,
773
+ searchScope: resourceScope ? "resource" : "thread",
774
+ searchType: hasSemanticRecall ? "semantic" : "text"
775
+ };
776
+ } catch (error) {
777
+ return handleError(error, "Error searching memory");
778
+ }
779
+ }
780
+ });
781
+ var GET_MEMORY_STATUS_NETWORK_ROUTE = createRoute({
782
+ method: "GET",
783
+ path: "/api/memory/network/status",
784
+ responseType: "json",
785
+ queryParamSchema: getMemoryStatusNetworkQuerySchema,
786
+ responseSchema: memoryStatusResponseSchema,
787
+ summary: "Get memory status (network)",
788
+ description: "Returns the current status of the memory system (network route)",
789
+ tags: ["Memory - Network"],
790
+ handler: GET_MEMORY_STATUS_ROUTE.handler
791
+ });
792
+ var LIST_THREADS_NETWORK_ROUTE = createRoute({
793
+ method: "GET",
794
+ path: "/api/memory/network/threads",
795
+ responseType: "json",
796
+ queryParamSchema: listThreadsNetworkQuerySchema,
797
+ responseSchema: listThreadsResponseSchema,
798
+ summary: "List memory threads (network)",
799
+ description: "Returns a paginated list of conversation threads (network route)",
800
+ tags: ["Memory - Network"],
801
+ handler: LIST_THREADS_ROUTE.handler
802
+ });
803
+ var GET_THREAD_BY_ID_NETWORK_ROUTE = createRoute({
804
+ method: "GET",
805
+ path: "/api/memory/network/threads/:threadId",
806
+ responseType: "json",
807
+ pathParamSchema: threadIdPathParams,
808
+ queryParamSchema: getThreadByIdNetworkQuerySchema,
809
+ responseSchema: getThreadByIdResponseSchema,
810
+ summary: "Get thread by ID (network)",
811
+ description: "Returns details for a specific conversation thread (network route)",
812
+ tags: ["Memory - Network"],
813
+ handler: GET_THREAD_BY_ID_ROUTE.handler
814
+ });
815
+ var LIST_MESSAGES_NETWORK_ROUTE = createRoute({
816
+ method: "GET",
817
+ path: "/api/memory/network/threads/:threadId/messages",
818
+ responseType: "json",
819
+ pathParamSchema: threadIdPathParams,
820
+ queryParamSchema: listMessagesNetworkQuerySchema,
821
+ responseSchema: listMessagesResponseSchema,
822
+ summary: "List thread messages (network)",
823
+ description: "Returns a paginated list of messages in a conversation thread (network route)",
824
+ tags: ["Memory - Network"],
825
+ handler: LIST_MESSAGES_ROUTE.handler
826
+ });
827
+ var SAVE_MESSAGES_NETWORK_ROUTE = createRoute({
828
+ method: "POST",
829
+ path: "/api/memory/network/save-messages",
830
+ responseType: "json",
831
+ queryParamSchema: saveMessagesNetworkQuerySchema,
832
+ bodySchema: saveMessagesBodySchema,
833
+ responseSchema: saveMessagesResponseSchema,
834
+ summary: "Save messages (network)",
835
+ description: "Saves new messages to memory (network route)",
836
+ tags: ["Memory - Network"],
837
+ handler: SAVE_MESSAGES_ROUTE.handler
838
+ });
839
+ var CREATE_THREAD_NETWORK_ROUTE = createRoute({
840
+ method: "POST",
841
+ path: "/api/memory/network/threads",
842
+ responseType: "json",
843
+ queryParamSchema: createThreadNetworkQuerySchema,
844
+ bodySchema: createThreadBodySchema,
845
+ responseSchema: getThreadByIdResponseSchema,
846
+ summary: "Create thread (network)",
847
+ description: "Creates a new conversation thread (network route)",
848
+ tags: ["Memory - Network"],
849
+ handler: CREATE_THREAD_ROUTE.handler
850
+ });
851
+ var UPDATE_THREAD_NETWORK_ROUTE = createRoute({
852
+ method: "PATCH",
853
+ path: "/api/memory/network/threads/:threadId",
854
+ responseType: "json",
855
+ pathParamSchema: threadIdPathParams,
856
+ queryParamSchema: updateThreadNetworkQuerySchema,
857
+ bodySchema: updateThreadBodySchema,
858
+ responseSchema: getThreadByIdResponseSchema,
859
+ summary: "Update thread (network)",
860
+ description: "Updates a conversation thread (network route)",
861
+ tags: ["Memory - Network"],
862
+ handler: UPDATE_THREAD_ROUTE.handler
863
+ });
864
+ var DELETE_THREAD_NETWORK_ROUTE = createRoute({
865
+ method: "DELETE",
866
+ path: "/api/memory/network/threads/:threadId",
867
+ responseType: "json",
868
+ pathParamSchema: threadIdPathParams,
869
+ queryParamSchema: deleteThreadNetworkQuerySchema,
870
+ responseSchema: deleteThreadResponseSchema,
871
+ summary: "Delete thread (network)",
872
+ description: "Deletes a conversation thread (network route)",
873
+ tags: ["Memory - Network"],
874
+ handler: DELETE_THREAD_ROUTE.handler
875
+ });
876
+ var DELETE_MESSAGES_NETWORK_ROUTE = createRoute({
877
+ method: "POST",
878
+ path: "/api/memory/network/messages/delete",
879
+ responseType: "json",
880
+ queryParamSchema: deleteMessagesNetworkQuerySchema,
881
+ bodySchema: deleteMessagesBodySchema,
882
+ responseSchema: deleteMessagesResponseSchema,
883
+ summary: "Delete messages (network)",
884
+ description: "Deletes specific messages from memory (network route)",
885
+ tags: ["Memory - Network"],
886
+ handler: DELETE_MESSAGES_ROUTE.handler
887
+ });
888
+
889
+ export { CREATE_THREAD_NETWORK_ROUTE, CREATE_THREAD_ROUTE, DELETE_MESSAGES_NETWORK_ROUTE, DELETE_MESSAGES_ROUTE, DELETE_THREAD_NETWORK_ROUTE, DELETE_THREAD_ROUTE, GET_MEMORY_CONFIG_ROUTE, GET_MEMORY_STATUS_NETWORK_ROUTE, GET_MEMORY_STATUS_ROUTE, GET_THREAD_BY_ID_NETWORK_ROUTE, GET_THREAD_BY_ID_ROUTE, GET_WORKING_MEMORY_ROUTE, LIST_MESSAGES_NETWORK_ROUTE, LIST_MESSAGES_ROUTE, LIST_THREADS_NETWORK_ROUTE, LIST_THREADS_ROUTE, SAVE_MESSAGES_NETWORK_ROUTE, SAVE_MESSAGES_ROUTE, SEARCH_MEMORY_ROUTE, UPDATE_THREAD_NETWORK_ROUTE, UPDATE_THREAD_ROUTE, UPDATE_WORKING_MEMORY_ROUTE, getTextContent, memory_exports };
890
+ //# sourceMappingURL=chunk-MQLS6Z7A.js.map
891
+ //# sourceMappingURL=chunk-MQLS6Z7A.js.map