@mastra/server 1.0.0-beta.4 → 1.0.0-beta.5

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