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

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