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