@mastra/server 0.0.0-expose-more-playground-ui-20250502141824 → 0.0.0-extract-tool-ui-inp-playground-ui-20251023135343

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 (282) hide show
  1. package/CHANGELOG.md +4165 -0
  2. package/LICENSE.md +11 -42
  3. package/README.md +45 -137
  4. package/dist/chunk-2PLXW4ZX.cjs +2777 -0
  5. package/dist/chunk-2PLXW4ZX.cjs.map +1 -0
  6. package/dist/chunk-2S4IMB6E.cjs +130 -0
  7. package/dist/chunk-2S4IMB6E.cjs.map +1 -0
  8. package/dist/chunk-2V3K6DKN.js +692 -0
  9. package/dist/chunk-2V3K6DKN.js.map +1 -0
  10. package/dist/chunk-3SNGNFUJ.cjs +128 -0
  11. package/dist/chunk-3SNGNFUJ.cjs.map +1 -0
  12. package/dist/{chunk-L7XE5QTW.js → chunk-4QCXUEAT.js} +11 -2
  13. package/dist/chunk-4QCXUEAT.js.map +1 -0
  14. package/dist/chunk-5OR5IUUV.cjs +713 -0
  15. package/dist/chunk-5OR5IUUV.cjs.map +1 -0
  16. package/dist/{chunk-WTHDCRMY.js → chunk-67GYDFSB.js} +33 -8
  17. package/dist/chunk-67GYDFSB.js.map +1 -0
  18. package/dist/{chunk-7IWQE76Z.cjs → chunk-6ZR275MD.cjs} +37 -11
  19. package/dist/chunk-6ZR275MD.cjs.map +1 -0
  20. package/dist/{chunk-FV45V6WC.cjs → chunk-7NADHFD2.cjs} +3 -7
  21. package/dist/chunk-7NADHFD2.cjs.map +1 -0
  22. package/dist/chunk-ABRFV4XP.js +83 -0
  23. package/dist/chunk-ABRFV4XP.js.map +1 -0
  24. package/dist/{chunk-5JNVY6DU.js → chunk-AHB4JCIQ.js} +52 -12
  25. package/dist/chunk-AHB4JCIQ.js.map +1 -0
  26. package/dist/chunk-AW5BU3RQ.js +192 -0
  27. package/dist/chunk-AW5BU3RQ.js.map +1 -0
  28. package/dist/chunk-BATEJLED.js +124 -0
  29. package/dist/chunk-BATEJLED.js.map +1 -0
  30. package/dist/chunk-CVOGYUL7.js +19480 -0
  31. package/dist/chunk-CVOGYUL7.js.map +1 -0
  32. package/dist/chunk-CY4TP3FK.js +16 -0
  33. package/dist/chunk-CY4TP3FK.js.map +1 -0
  34. package/dist/{chunk-M56ECCHK.cjs → chunk-EP3JQDPD.cjs} +22 -19
  35. package/dist/chunk-EP3JQDPD.cjs.map +1 -0
  36. package/dist/chunk-G4PUALCE.cjs +28 -0
  37. package/dist/chunk-G4PUALCE.cjs.map +1 -0
  38. package/dist/chunk-GU4EWMZB.cjs +769 -0
  39. package/dist/chunk-GU4EWMZB.cjs.map +1 -0
  40. package/dist/chunk-HPXAM2PG.js +477 -0
  41. package/dist/chunk-HPXAM2PG.js.map +1 -0
  42. package/dist/chunk-I3C4ODGV.cjs +335 -0
  43. package/dist/chunk-I3C4ODGV.cjs.map +1 -0
  44. package/dist/chunk-JTXOSCJQ.cjs +595 -0
  45. package/dist/chunk-JTXOSCJQ.cjs.map +1 -0
  46. package/dist/chunk-LF2ZLOFP.js +767 -0
  47. package/dist/chunk-LF2ZLOFP.js.map +1 -0
  48. package/dist/{chunk-M3YJLWTU.js → chunk-LLUOPR3J.js} +77 -63
  49. package/dist/chunk-LLUOPR3J.js.map +1 -0
  50. package/dist/chunk-LPM6BBAX.cjs +1043 -0
  51. package/dist/chunk-LPM6BBAX.cjs.map +1 -0
  52. package/dist/chunk-MH2EOSRX.js +578 -0
  53. package/dist/chunk-MH2EOSRX.js.map +1 -0
  54. package/dist/{chunk-TRDNDNGQ.js → chunk-MMROOK5J.js} +4 -7
  55. package/dist/chunk-MMROOK5J.js.map +1 -0
  56. package/dist/{chunk-4JINXASC.js → chunk-MYR4PVGN.js} +7 -4
  57. package/dist/chunk-MYR4PVGN.js.map +1 -0
  58. package/dist/chunk-O7I5CWRX.cjs +44 -0
  59. package/dist/chunk-O7I5CWRX.cjs.map +1 -0
  60. package/dist/chunk-PR4QN5HX.js +39 -0
  61. package/dist/chunk-PR4QN5HX.js.map +1 -0
  62. package/dist/{chunk-Q6SHQECN.js → chunk-QQXMIP6C.js} +47 -13
  63. package/dist/chunk-QQXMIP6C.js.map +1 -0
  64. package/dist/chunk-QU6N55W6.cjs +256 -0
  65. package/dist/chunk-QU6N55W6.cjs.map +1 -0
  66. package/dist/chunk-RE4RPXT2.cjs +18 -0
  67. package/dist/chunk-RE4RPXT2.cjs.map +1 -0
  68. package/dist/chunk-RJX63KSA.cjs +729 -0
  69. package/dist/chunk-RJX63KSA.cjs.map +1 -0
  70. package/dist/chunk-RQK4FQUD.js +1012 -0
  71. package/dist/chunk-RQK4FQUD.js.map +1 -0
  72. package/dist/chunk-SHWNNZBL.js +254 -0
  73. package/dist/chunk-SHWNNZBL.js.map +1 -0
  74. package/dist/chunk-SPRRK3P7.cjs +200 -0
  75. package/dist/chunk-SPRRK3P7.cjs.map +1 -0
  76. package/dist/chunk-TOCYBDP2.js +46 -0
  77. package/dist/chunk-TOCYBDP2.js.map +1 -0
  78. package/dist/chunk-TOP25AIO.cjs +485 -0
  79. package/dist/chunk-TOP25AIO.cjs.map +1 -0
  80. package/dist/chunk-TRGAMKHX.cjs +167 -0
  81. package/dist/chunk-TRGAMKHX.cjs.map +1 -0
  82. package/dist/chunk-VY4ENABS.cjs +135 -0
  83. package/dist/chunk-VY4ENABS.cjs.map +1 -0
  84. package/dist/chunk-X6C7BUWN.cjs +48 -0
  85. package/dist/chunk-X6C7BUWN.cjs.map +1 -0
  86. package/dist/chunk-XN74I6VW.cjs +88 -0
  87. package/dist/chunk-XN74I6VW.cjs.map +1 -0
  88. package/dist/chunk-XXPCYVTH.js +707 -0
  89. package/dist/chunk-XXPCYVTH.js.map +1 -0
  90. package/dist/chunk-YKENCZQ2.cjs +19516 -0
  91. package/dist/chunk-YKENCZQ2.cjs.map +1 -0
  92. package/dist/chunk-YWOK4F5A.js +131 -0
  93. package/dist/chunk-YWOK4F5A.js.map +1 -0
  94. package/dist/chunk-ZULZ2752.js +2774 -0
  95. package/dist/chunk-ZULZ2752.js.map +1 -0
  96. package/dist/dist-4MVGNSRL.cjs +1150 -0
  97. package/dist/dist-4MVGNSRL.cjs.map +1 -0
  98. package/dist/dist-FZYCV3VB.cjs +940 -0
  99. package/dist/dist-FZYCV3VB.cjs.map +1 -0
  100. package/dist/dist-G2BYZJOC.cjs +928 -0
  101. package/dist/dist-G2BYZJOC.cjs.map +1 -0
  102. package/dist/dist-P4MXBQ3U.cjs +16 -0
  103. package/dist/dist-P4MXBQ3U.cjs.map +1 -0
  104. package/dist/dist-PQZUVLPC.js +937 -0
  105. package/dist/dist-PQZUVLPC.js.map +1 -0
  106. package/dist/dist-R7WYX6LC.js +925 -0
  107. package/dist/dist-R7WYX6LC.js.map +1 -0
  108. package/dist/dist-RFMYFILX.cjs +764 -0
  109. package/dist/dist-RFMYFILX.cjs.map +1 -0
  110. package/dist/dist-X7XR3M3Z.js +1147 -0
  111. package/dist/dist-X7XR3M3Z.js.map +1 -0
  112. package/dist/dist-XVBSOGFK.js +761 -0
  113. package/dist/dist-XVBSOGFK.js.map +1 -0
  114. package/dist/dist-YREX2TJT.js +3 -0
  115. package/dist/dist-YREX2TJT.js.map +1 -0
  116. package/dist/index.cjs +6 -0
  117. package/dist/index.cjs.map +1 -0
  118. package/dist/index.d.ts +1 -0
  119. package/dist/index.d.ts.map +1 -0
  120. package/dist/index.js +5 -0
  121. package/dist/index.js.map +1 -0
  122. package/dist/server/a2a/protocol.d.ts +8 -0
  123. package/dist/server/a2a/protocol.d.ts.map +1 -0
  124. package/dist/server/a2a/store.cjs +25 -0
  125. package/dist/server/a2a/store.cjs.map +1 -0
  126. package/dist/server/a2a/store.d.ts +14 -0
  127. package/dist/server/a2a/store.d.ts.map +1 -0
  128. package/dist/server/a2a/store.js +23 -0
  129. package/dist/server/a2a/store.js.map +1 -0
  130. package/dist/server/a2a/tasks.d.ts +20 -0
  131. package/dist/server/a2a/tasks.d.ts.map +1 -0
  132. package/dist/server/handlers/a2a.cjs +32 -0
  133. package/dist/server/handlers/a2a.cjs.map +1 -0
  134. package/dist/server/handlers/a2a.d.ts +68 -0
  135. package/dist/server/handlers/a2a.d.ts.map +1 -0
  136. package/dist/server/handlers/a2a.js +3 -0
  137. package/dist/server/handlers/a2a.js.map +1 -0
  138. package/dist/server/handlers/agent-builder.cjs +68 -0
  139. package/dist/server/handlers/agent-builder.cjs.map +1 -0
  140. package/dist/server/handlers/agent-builder.d.ts +94 -0
  141. package/dist/server/handlers/agent-builder.d.ts.map +1 -0
  142. package/dist/server/handlers/agent-builder.js +3 -0
  143. package/dist/server/handlers/agent-builder.js.map +1 -0
  144. package/dist/server/handlers/agents.cjs +61 -7
  145. package/dist/server/handlers/agents.cjs.map +1 -0
  146. package/dist/server/handlers/agents.d.ts +208 -6
  147. package/dist/server/handlers/agents.d.ts.map +1 -0
  148. package/dist/server/handlers/agents.js +3 -1
  149. package/dist/server/handlers/agents.js.map +1 -0
  150. package/dist/server/handlers/error.cjs +4 -2
  151. package/dist/server/handlers/error.cjs.map +1 -0
  152. package/dist/server/handlers/error.d.ts +2 -1
  153. package/dist/server/handlers/error.d.ts.map +1 -0
  154. package/dist/server/handlers/error.js +3 -1
  155. package/dist/server/handlers/error.js.map +1 -0
  156. package/dist/server/handlers/legacyWorkflows.cjs +48 -0
  157. package/dist/server/handlers/legacyWorkflows.cjs.map +1 -0
  158. package/dist/server/handlers/legacyWorkflows.d.ts +59 -0
  159. package/dist/server/handlers/legacyWorkflows.d.ts.map +1 -0
  160. package/dist/server/handlers/legacyWorkflows.js +3 -0
  161. package/dist/server/handlers/legacyWorkflows.js.map +1 -0
  162. package/dist/server/handlers/logs.cjs +6 -4
  163. package/dist/server/handlers/logs.cjs.map +1 -0
  164. package/dist/server/handlers/logs.d.ts +34 -3
  165. package/dist/server/handlers/logs.d.ts.map +1 -0
  166. package/dist/server/handlers/logs.js +3 -1
  167. package/dist/server/handlers/logs.js.map +1 -0
  168. package/dist/server/handlers/memory.cjs +39 -9
  169. package/dist/server/handlers/memory.cjs.map +1 -0
  170. package/dist/server/handlers/memory.d.ts +118 -8
  171. package/dist/server/handlers/memory.d.ts.map +1 -0
  172. package/dist/server/handlers/memory.js +3 -1
  173. package/dist/server/handlers/memory.js.map +1 -0
  174. package/dist/server/handlers/observability.cjs +24 -0
  175. package/dist/server/handlers/observability.cjs.map +1 -0
  176. package/dist/server/handlers/observability.d.ts +49 -0
  177. package/dist/server/handlers/observability.d.ts.map +1 -0
  178. package/dist/server/handlers/observability.js +3 -0
  179. package/dist/server/handlers/observability.js.map +1 -0
  180. package/dist/server/handlers/scores.cjs +32 -0
  181. package/dist/server/handlers/scores.cjs.map +1 -0
  182. package/dist/server/handlers/scores.d.ts +152 -0
  183. package/dist/server/handlers/scores.d.ts.map +1 -0
  184. package/dist/server/handlers/scores.js +3 -0
  185. package/dist/server/handlers/scores.js.map +1 -0
  186. package/dist/server/handlers/telemetry.cjs +9 -3
  187. package/dist/server/handlers/telemetry.cjs.map +1 -0
  188. package/dist/server/handlers/telemetry.d.ts +33 -2
  189. package/dist/server/handlers/telemetry.d.ts.map +1 -0
  190. package/dist/server/handlers/telemetry.js +3 -1
  191. package/dist/server/handlers/telemetry.js.map +1 -0
  192. package/dist/server/handlers/tools.cjs +11 -5
  193. package/dist/server/handlers/tools.cjs.map +1 -0
  194. package/dist/server/handlers/tools.d.ts +25 -4
  195. package/dist/server/handlers/tools.d.ts.map +1 -0
  196. package/dist/server/handlers/tools.js +3 -1
  197. package/dist/server/handlers/tools.js.map +1 -0
  198. package/dist/server/handlers/utils.cjs +8 -2
  199. package/dist/server/handlers/utils.cjs.map +1 -0
  200. package/dist/server/handlers/utils.d.ts +8 -1
  201. package/dist/server/handlers/utils.d.ts.map +1 -0
  202. package/dist/server/handlers/utils.js +3 -1
  203. package/dist/server/handlers/utils.js.map +1 -0
  204. package/dist/server/handlers/vector.cjs +9 -7
  205. package/dist/server/handlers/vector.cjs.map +1 -0
  206. package/dist/server/handlers/vector.d.ts +51 -6
  207. package/dist/server/handlers/vector.d.ts.map +1 -0
  208. package/dist/server/handlers/vector.js +3 -1
  209. package/dist/server/handlers/vector.js.map +1 -0
  210. package/dist/server/handlers/voice.cjs +10 -4
  211. package/dist/server/handlers/voice.cjs.map +1 -0
  212. package/dist/server/handlers/voice.d.ts +41 -3
  213. package/dist/server/handlers/voice.d.ts.map +1 -0
  214. package/dist/server/handlers/voice.js +3 -1
  215. package/dist/server/handlers/voice.js.map +1 -0
  216. package/dist/server/handlers/workflows.cjs +55 -13
  217. package/dist/server/handlers/workflows.cjs.map +1 -0
  218. package/dist/server/handlers/workflows.d.ts +97 -10
  219. package/dist/server/handlers/workflows.d.ts.map +1 -0
  220. package/dist/server/handlers/workflows.js +3 -1
  221. package/dist/server/handlers/workflows.js.map +1 -0
  222. package/dist/server/handlers.cjs +47 -30
  223. package/dist/server/handlers.cjs.map +1 -0
  224. package/dist/server/handlers.d.ts +14 -10
  225. package/dist/server/handlers.d.ts.map +1 -0
  226. package/dist/server/handlers.js +15 -10
  227. package/dist/server/handlers.js.map +1 -0
  228. package/dist/server/http-exception.d.ts +87 -0
  229. package/dist/server/http-exception.d.ts.map +1 -0
  230. package/dist/server/types.d.ts +10 -0
  231. package/dist/server/types.d.ts.map +1 -0
  232. package/dist/server/utils.d.ts +44 -0
  233. package/dist/server/utils.d.ts.map +1 -0
  234. package/dist/token-375W3LEI.cjs +64 -0
  235. package/dist/token-375W3LEI.cjs.map +1 -0
  236. package/dist/token-C3IMNCC4.js +62 -0
  237. package/dist/token-C3IMNCC4.js.map +1 -0
  238. package/dist/token-util-CV3RRG6K.cjs +9 -0
  239. package/dist/token-util-CV3RRG6K.cjs.map +1 -0
  240. package/dist/token-util-E5QO2RCL.js +7 -0
  241. package/dist/token-util-E5QO2RCL.js.map +1 -0
  242. package/package.json +43 -19
  243. package/dist/_tsup-dts-rollup.d.cts +0 -654
  244. package/dist/_tsup-dts-rollup.d.ts +0 -654
  245. package/dist/chunk-2FJURXCL.cjs +0 -213
  246. package/dist/chunk-3AHQ5RGN.js +0 -11
  247. package/dist/chunk-3EJZQ6TQ.js +0 -49
  248. package/dist/chunk-4BIX6GMY.cjs +0 -189
  249. package/dist/chunk-55HTWX4C.cjs +0 -93
  250. package/dist/chunk-5SWCVTNL.cjs +0 -5579
  251. package/dist/chunk-5YGDYMRB.cjs +0 -147
  252. package/dist/chunk-AELYAUEE.cjs +0 -316
  253. package/dist/chunk-D3G23FP3.cjs +0 -126
  254. package/dist/chunk-EVCC233P.cjs +0 -321
  255. package/dist/chunk-JPB6RPGB.js +0 -304
  256. package/dist/chunk-OMN3UI6X.js +0 -5576
  257. package/dist/chunk-QJ3AHN64.js +0 -141
  258. package/dist/chunk-QN4KF3BH.cjs +0 -18
  259. package/dist/chunk-RBQASTUP.js +0 -203
  260. package/dist/chunk-SKBVVI24.cjs +0 -54
  261. package/dist/chunk-Y3SV5XK4.js +0 -181
  262. package/dist/chunk-ZLBRQFDD.cjs +0 -13
  263. package/dist/index.d.cts +0 -1
  264. package/dist/server/handlers/agents.d.cts +0 -6
  265. package/dist/server/handlers/error.d.cts +0 -1
  266. package/dist/server/handlers/logs.d.cts +0 -3
  267. package/dist/server/handlers/memory.d.cts +0 -8
  268. package/dist/server/handlers/network.cjs +0 -22
  269. package/dist/server/handlers/network.d.cts +0 -4
  270. package/dist/server/handlers/network.d.ts +0 -4
  271. package/dist/server/handlers/network.js +0 -1
  272. package/dist/server/handlers/telemetry.d.cts +0 -2
  273. package/dist/server/handlers/tools.d.cts +0 -4
  274. package/dist/server/handlers/utils.d.cts +0 -1
  275. package/dist/server/handlers/vNextWorkflows.cjs +0 -46
  276. package/dist/server/handlers/vNextWorkflows.d.cts +0 -10
  277. package/dist/server/handlers/vNextWorkflows.d.ts +0 -10
  278. package/dist/server/handlers/vNextWorkflows.js +0 -1
  279. package/dist/server/handlers/vector.d.cts +0 -6
  280. package/dist/server/handlers/voice.d.cts +0 -3
  281. package/dist/server/handlers/workflows.d.cts +0 -10
  282. package/dist/server/handlers.d.cts +0 -10
@@ -0,0 +1,595 @@
1
+ 'use strict';
2
+
3
+ var chunkG4PUALCE_cjs = require('./chunk-G4PUALCE.cjs');
4
+ var chunkRE4RPXT2_cjs = require('./chunk-RE4RPXT2.cjs');
5
+ var chunk7NADHFD2_cjs = require('./chunk-7NADHFD2.cjs');
6
+ var chunkO7I5CWRX_cjs = require('./chunk-O7I5CWRX.cjs');
7
+ var agent = require('@mastra/core/agent');
8
+ var utils = require('@mastra/core/utils');
9
+
10
+ // src/server/handlers/memory.ts
11
+ var memory_exports = {};
12
+ chunkO7I5CWRX_cjs.__export(memory_exports, {
13
+ createThreadHandler: () => createThreadHandler,
14
+ deleteMessagesHandler: () => deleteMessagesHandler,
15
+ deleteThreadHandler: () => deleteThreadHandler,
16
+ getMemoryConfigHandler: () => getMemoryConfigHandler,
17
+ getMemoryStatusHandler: () => getMemoryStatusHandler,
18
+ getMessagesHandler: () => getMessagesHandler,
19
+ getMessagesPaginatedHandler: () => getMessagesPaginatedHandler,
20
+ getThreadByIdHandler: () => getThreadByIdHandler,
21
+ getThreadsHandler: () => getThreadsHandler,
22
+ getThreadsPaginatedHandler: () => getThreadsPaginatedHandler,
23
+ getWorkingMemoryHandler: () => getWorkingMemoryHandler,
24
+ saveMessagesHandler: () => saveMessagesHandler,
25
+ searchMemoryHandler: () => searchMemoryHandler,
26
+ updateThreadHandler: () => updateThreadHandler,
27
+ updateWorkingMemoryHandler: () => updateWorkingMemoryHandler
28
+ });
29
+ async function getMemoryFromContext({
30
+ mastra,
31
+ agentId,
32
+ runtimeContext
33
+ }) {
34
+ const logger = mastra.getLogger();
35
+ let agent;
36
+ if (agentId) {
37
+ try {
38
+ agent = mastra.getAgent(agentId);
39
+ } catch (error) {
40
+ logger.debug("Error getting agent from mastra, searching agents for agent", error);
41
+ }
42
+ }
43
+ if (agentId && !agent) {
44
+ logger.debug("Agent not found, searching agents for agent", { agentId });
45
+ const agents = mastra.getAgents();
46
+ if (Object.keys(agents || {}).length) {
47
+ for (const [_, ag] of Object.entries(agents)) {
48
+ try {
49
+ const agents2 = await ag.listAgents();
50
+ if (agents2[agentId]) {
51
+ agent = agents2[agentId];
52
+ break;
53
+ }
54
+ } catch (error) {
55
+ logger.debug("Error getting agent from agent", error);
56
+ }
57
+ }
58
+ }
59
+ if (!agent) {
60
+ throw new chunk7NADHFD2_cjs.HTTPException(404, { message: "Agent not found" });
61
+ }
62
+ }
63
+ if (agent) {
64
+ return await agent?.getMemory({
65
+ runtimeContext
66
+ }) || mastra.getMemory();
67
+ }
68
+ return mastra.getMemory();
69
+ }
70
+ async function getMemoryStatusHandler({
71
+ mastra,
72
+ agentId,
73
+ runtimeContext
74
+ }) {
75
+ try {
76
+ const memory = await getMemoryFromContext({ mastra, agentId, runtimeContext });
77
+ if (!memory) {
78
+ return { result: false };
79
+ }
80
+ return { result: true };
81
+ } catch (error) {
82
+ return chunkRE4RPXT2_cjs.handleError(error, "Error getting memory status");
83
+ }
84
+ }
85
+ async function getMemoryConfigHandler({
86
+ mastra,
87
+ agentId,
88
+ runtimeContext
89
+ }) {
90
+ try {
91
+ const memory = await getMemoryFromContext({ mastra, agentId, runtimeContext });
92
+ if (!memory) {
93
+ throw new chunk7NADHFD2_cjs.HTTPException(400, { message: "Memory is not initialized" });
94
+ }
95
+ const config = memory.getMergedThreadConfig({});
96
+ return { config };
97
+ } catch (error) {
98
+ return chunkRE4RPXT2_cjs.handleError(error, "Error getting memory configuration");
99
+ }
100
+ }
101
+ async function getThreadsHandler({
102
+ mastra,
103
+ agentId,
104
+ resourceId,
105
+ runtimeContext,
106
+ orderBy,
107
+ sortDirection
108
+ }) {
109
+ try {
110
+ const memory = await getMemoryFromContext({ mastra, agentId, runtimeContext });
111
+ if (!memory) {
112
+ throw new chunk7NADHFD2_cjs.HTTPException(400, { message: "Memory is not initialized" });
113
+ }
114
+ chunkG4PUALCE_cjs.validateBody({ resourceId });
115
+ const threads = await memory.getThreadsByResourceId({
116
+ resourceId,
117
+ orderBy,
118
+ sortDirection
119
+ });
120
+ return threads;
121
+ } catch (error) {
122
+ return chunkRE4RPXT2_cjs.handleError(error, "Error getting threads");
123
+ }
124
+ }
125
+ async function getThreadsPaginatedHandler({
126
+ mastra,
127
+ agentId,
128
+ resourceId,
129
+ runtimeContext,
130
+ page,
131
+ perPage,
132
+ orderBy,
133
+ sortDirection
134
+ }) {
135
+ try {
136
+ const memory = await getMemoryFromContext({ mastra, agentId, runtimeContext });
137
+ if (!memory) {
138
+ throw new chunk7NADHFD2_cjs.HTTPException(400, { message: "Memory is not initialized" });
139
+ }
140
+ chunkG4PUALCE_cjs.validateBody({ resourceId });
141
+ const result = await memory.getThreadsByResourceIdPaginated({
142
+ resourceId,
143
+ page,
144
+ perPage,
145
+ orderBy,
146
+ sortDirection
147
+ });
148
+ return result;
149
+ } catch (error) {
150
+ return chunkRE4RPXT2_cjs.handleError(error, "Error getting paginated threads");
151
+ }
152
+ }
153
+ async function getThreadByIdHandler({
154
+ mastra,
155
+ agentId,
156
+ threadId,
157
+ runtimeContext
158
+ }) {
159
+ try {
160
+ chunkG4PUALCE_cjs.validateBody({ threadId });
161
+ const memory = await getMemoryFromContext({ mastra, agentId, runtimeContext });
162
+ if (!memory) {
163
+ throw new chunk7NADHFD2_cjs.HTTPException(400, { message: "Memory is not initialized" });
164
+ }
165
+ const thread = await memory.getThreadById({ threadId });
166
+ if (!thread) {
167
+ throw new chunk7NADHFD2_cjs.HTTPException(404, { message: "Thread not found" });
168
+ }
169
+ return thread;
170
+ } catch (error) {
171
+ return chunkRE4RPXT2_cjs.handleError(error, "Error getting thread");
172
+ }
173
+ }
174
+ async function saveMessagesHandler({
175
+ mastra,
176
+ agentId,
177
+ body,
178
+ runtimeContext
179
+ }) {
180
+ try {
181
+ const memory = await getMemoryFromContext({ mastra, agentId, runtimeContext });
182
+ if (!memory) {
183
+ throw new chunk7NADHFD2_cjs.HTTPException(400, { message: "Memory is not initialized" });
184
+ }
185
+ if (!body?.messages) {
186
+ throw new chunk7NADHFD2_cjs.HTTPException(400, { message: "Messages are required" });
187
+ }
188
+ if (!Array.isArray(body.messages)) {
189
+ throw new chunk7NADHFD2_cjs.HTTPException(400, { message: "Messages should be an array" });
190
+ }
191
+ const invalidMessages = body.messages.filter((message) => !message.threadId || !message.resourceId);
192
+ if (invalidMessages.length > 0) {
193
+ throw new chunk7NADHFD2_cjs.HTTPException(400, {
194
+ message: `All messages must have threadId and resourceId fields. Found ${invalidMessages.length} invalid message(s).`
195
+ });
196
+ }
197
+ const processedMessages = body.messages.map((message) => ({
198
+ ...message,
199
+ id: message.id || memory.generateId(),
200
+ createdAt: message.createdAt ? new Date(message.createdAt) : /* @__PURE__ */ new Date()
201
+ }));
202
+ const result = await memory.saveMessages({ messages: processedMessages, memoryConfig: {} });
203
+ return result;
204
+ } catch (error) {
205
+ return chunkRE4RPXT2_cjs.handleError(error, "Error saving messages");
206
+ }
207
+ }
208
+ async function createThreadHandler({
209
+ mastra,
210
+ agentId,
211
+ body,
212
+ runtimeContext
213
+ }) {
214
+ try {
215
+ const memory = await getMemoryFromContext({ mastra, agentId, runtimeContext });
216
+ if (!memory) {
217
+ throw new chunk7NADHFD2_cjs.HTTPException(400, { message: "Memory is not initialized" });
218
+ }
219
+ chunkG4PUALCE_cjs.validateBody({ resourceId: body?.resourceId });
220
+ const result = await memory.createThread({
221
+ resourceId: body?.resourceId,
222
+ title: body?.title,
223
+ metadata: body?.metadata,
224
+ threadId: body?.threadId
225
+ });
226
+ return result;
227
+ } catch (error) {
228
+ return chunkRE4RPXT2_cjs.handleError(error, "Error saving thread to memory");
229
+ }
230
+ }
231
+ async function updateThreadHandler({
232
+ mastra,
233
+ agentId,
234
+ threadId,
235
+ body,
236
+ runtimeContext
237
+ }) {
238
+ try {
239
+ const memory = await getMemoryFromContext({ mastra, agentId, runtimeContext });
240
+ if (!body) {
241
+ throw new chunk7NADHFD2_cjs.HTTPException(400, { message: "Body is required" });
242
+ }
243
+ const { title, metadata, resourceId } = body;
244
+ const updatedAt = /* @__PURE__ */ new Date();
245
+ chunkG4PUALCE_cjs.validateBody({ threadId });
246
+ if (!memory) {
247
+ throw new chunk7NADHFD2_cjs.HTTPException(400, { message: "Memory is not initialized" });
248
+ }
249
+ const thread = await memory.getThreadById({ threadId });
250
+ if (!thread) {
251
+ throw new chunk7NADHFD2_cjs.HTTPException(404, { message: "Thread not found" });
252
+ }
253
+ const updatedThread = {
254
+ ...thread,
255
+ title: title || thread.title,
256
+ metadata: metadata || thread.metadata,
257
+ resourceId: resourceId || thread.resourceId,
258
+ createdAt: thread.createdAt,
259
+ updatedAt
260
+ };
261
+ const result = await memory.saveThread({ thread: updatedThread });
262
+ return result;
263
+ } catch (error) {
264
+ return chunkRE4RPXT2_cjs.handleError(error, "Error updating thread");
265
+ }
266
+ }
267
+ async function deleteThreadHandler({
268
+ mastra,
269
+ agentId,
270
+ threadId,
271
+ runtimeContext
272
+ }) {
273
+ try {
274
+ chunkG4PUALCE_cjs.validateBody({ threadId });
275
+ const memory = await getMemoryFromContext({ mastra, agentId, runtimeContext });
276
+ if (!memory) {
277
+ throw new chunk7NADHFD2_cjs.HTTPException(400, { message: "Memory is not initialized" });
278
+ }
279
+ const thread = await memory.getThreadById({ threadId });
280
+ if (!thread) {
281
+ throw new chunk7NADHFD2_cjs.HTTPException(404, { message: "Thread not found" });
282
+ }
283
+ await memory.deleteThread(threadId);
284
+ return { result: "Thread deleted" };
285
+ } catch (error) {
286
+ return chunkRE4RPXT2_cjs.handleError(error, "Error deleting thread");
287
+ }
288
+ }
289
+ async function getMessagesPaginatedHandler({
290
+ mastra,
291
+ threadId,
292
+ resourceId,
293
+ selectBy,
294
+ format
295
+ }) {
296
+ try {
297
+ chunkG4PUALCE_cjs.validateBody({ threadId });
298
+ const storage = mastra.getStorage();
299
+ if (!storage) {
300
+ throw new chunk7NADHFD2_cjs.HTTPException(400, { message: "Storage is not initialized" });
301
+ }
302
+ const thread = await storage.getThreadById({ threadId });
303
+ if (!thread) {
304
+ throw new chunk7NADHFD2_cjs.HTTPException(404, { message: "Thread not found" });
305
+ }
306
+ const result = await storage.getMessagesPaginated({ threadId, resourceId, selectBy, format });
307
+ return result;
308
+ } catch (error) {
309
+ return chunkRE4RPXT2_cjs.handleError(error, "Error getting messages");
310
+ }
311
+ }
312
+ async function getMessagesHandler({
313
+ mastra,
314
+ agentId,
315
+ threadId,
316
+ limit,
317
+ runtimeContext
318
+ }) {
319
+ if (limit !== void 0 && (!Number.isInteger(limit) || limit <= 0)) {
320
+ throw new chunk7NADHFD2_cjs.HTTPException(400, { message: "Invalid limit: must be a positive integer" });
321
+ }
322
+ try {
323
+ chunkG4PUALCE_cjs.validateBody({ threadId });
324
+ const memory = await getMemoryFromContext({ mastra, agentId, runtimeContext });
325
+ if (!memory) {
326
+ throw new chunk7NADHFD2_cjs.HTTPException(400, { message: "Memory is not initialized" });
327
+ }
328
+ const thread = await memory.getThreadById({ threadId });
329
+ if (!thread) {
330
+ throw new chunk7NADHFD2_cjs.HTTPException(404, { message: "Thread not found" });
331
+ }
332
+ const result = await memory.query({
333
+ threadId,
334
+ ...limit && { selectBy: { last: limit } }
335
+ });
336
+ const uiMessages = agent.convertMessages(result.messagesV2).to("AIV5.UI");
337
+ return { messages: result.messages, uiMessages, legacyMessages: result.uiMessages };
338
+ } catch (error) {
339
+ return chunkRE4RPXT2_cjs.handleError(error, "Error getting messages");
340
+ }
341
+ }
342
+ async function getWorkingMemoryHandler({
343
+ mastra,
344
+ agentId,
345
+ threadId,
346
+ resourceId,
347
+ runtimeContext,
348
+ memoryConfig
349
+ }) {
350
+ try {
351
+ const memory = await getMemoryFromContext({ mastra, agentId, runtimeContext });
352
+ chunkG4PUALCE_cjs.validateBody({ threadId });
353
+ if (!memory) {
354
+ throw new chunk7NADHFD2_cjs.HTTPException(400, { message: "Memory is not initialized" });
355
+ }
356
+ const thread = await memory.getThreadById({ threadId });
357
+ const threadExists = !!thread;
358
+ const template = await memory.getWorkingMemoryTemplate({ memoryConfig });
359
+ const workingMemoryTemplate = template?.format === "json" ? { ...template, content: JSON.stringify(utils.generateEmptyFromSchema(template.content)) } : template;
360
+ const workingMemory = await memory.getWorkingMemory({ threadId, resourceId, memoryConfig });
361
+ const config = memory.getMergedThreadConfig(memoryConfig || {});
362
+ const source = config.workingMemory?.scope === "resource" && resourceId ? "resource" : "thread";
363
+ return { workingMemory, source, workingMemoryTemplate, threadExists };
364
+ } catch (error) {
365
+ return chunkRE4RPXT2_cjs.handleError(error, "Error getting working memory");
366
+ }
367
+ }
368
+ async function updateWorkingMemoryHandler({
369
+ mastra,
370
+ agentId,
371
+ threadId,
372
+ body,
373
+ runtimeContext
374
+ }) {
375
+ try {
376
+ chunkG4PUALCE_cjs.validateBody({ threadId });
377
+ const memory = await getMemoryFromContext({ mastra, agentId, runtimeContext });
378
+ const { resourceId, memoryConfig, workingMemory } = body;
379
+ if (!memory) {
380
+ throw new chunk7NADHFD2_cjs.HTTPException(400, { message: "Memory is not initialized" });
381
+ }
382
+ const thread = await memory.getThreadById({ threadId });
383
+ if (!thread) {
384
+ throw new chunk7NADHFD2_cjs.HTTPException(404, { message: "Thread not found" });
385
+ }
386
+ await memory.updateWorkingMemory({ threadId, resourceId, workingMemory, memoryConfig });
387
+ return { success: true };
388
+ } catch (error) {
389
+ return chunkRE4RPXT2_cjs.handleError(error, "Error updating working memory");
390
+ }
391
+ }
392
+ async function deleteMessagesHandler({
393
+ mastra,
394
+ agentId,
395
+ messageIds,
396
+ runtimeContext
397
+ }) {
398
+ try {
399
+ if (messageIds === void 0 || messageIds === null) {
400
+ throw new chunk7NADHFD2_cjs.HTTPException(400, { message: "messageIds is required" });
401
+ }
402
+ const memory = await getMemoryFromContext({ mastra, agentId, runtimeContext });
403
+ if (!memory) {
404
+ throw new chunk7NADHFD2_cjs.HTTPException(400, { message: "Memory is not initialized" });
405
+ }
406
+ await memory.deleteMessages(messageIds);
407
+ let count = 1;
408
+ if (Array.isArray(messageIds)) {
409
+ count = messageIds.length;
410
+ }
411
+ return { success: true, message: `${count} message${count === 1 ? "" : "s"} deleted successfully` };
412
+ } catch (error) {
413
+ return chunkRE4RPXT2_cjs.handleError(error, "Error deleting messages");
414
+ }
415
+ }
416
+ async function searchMemoryHandler({
417
+ mastra,
418
+ agentId,
419
+ searchQuery,
420
+ resourceId,
421
+ threadId,
422
+ limit = 20,
423
+ runtimeContext,
424
+ memoryConfig
425
+ }) {
426
+ try {
427
+ chunkG4PUALCE_cjs.validateBody({ searchQuery, resourceId });
428
+ const memory = await getMemoryFromContext({ mastra, agentId, runtimeContext });
429
+ if (!memory) {
430
+ throw new chunk7NADHFD2_cjs.HTTPException(400, { message: "Memory is not initialized" });
431
+ }
432
+ const config = memory.getMergedThreadConfig(memoryConfig || {});
433
+ const hasSemanticRecall = !!config?.semanticRecall;
434
+ const resourceScope = typeof config?.semanticRecall === "object" && config?.semanticRecall?.scope === "resource";
435
+ if (threadId && !resourceScope) {
436
+ const thread = await memory.getThreadById({ threadId });
437
+ if (!thread) {
438
+ throw new chunk7NADHFD2_cjs.HTTPException(404, { message: "Thread not found" });
439
+ }
440
+ if (thread.resourceId !== resourceId) {
441
+ throw new chunk7NADHFD2_cjs.HTTPException(403, { message: "Thread does not belong to the specified resource" });
442
+ }
443
+ }
444
+ const searchResults = [];
445
+ const messageMap = /* @__PURE__ */ new Map();
446
+ if (threadId && !resourceScope) {
447
+ const thread = await memory.getThreadById({ threadId });
448
+ if (!thread) {
449
+ return {
450
+ results: [],
451
+ count: 0,
452
+ query: searchQuery,
453
+ searchScope: "thread",
454
+ searchType: hasSemanticRecall ? "semantic" : "text"
455
+ };
456
+ }
457
+ }
458
+ if (!threadId || resourceScope) {
459
+ const threads = await memory.getThreadsByResourceId({ resourceId });
460
+ if (threads.length === 0) {
461
+ return {
462
+ results: [],
463
+ count: 0,
464
+ query: searchQuery,
465
+ searchScope: "resource",
466
+ searchType: hasSemanticRecall ? "semantic" : "text"
467
+ };
468
+ }
469
+ for (const thread of threads) {
470
+ const result = await memory.rememberMessages({
471
+ threadId: thread.id,
472
+ resourceId,
473
+ vectorMessageSearch: searchQuery,
474
+ config
475
+ });
476
+ const threadMessages = (await memory.query({ threadId: thread.id })).uiMessages;
477
+ result.messagesV2.forEach((msg) => {
478
+ if (messageMap.has(msg.id)) return;
479
+ messageMap.set(msg.id, true);
480
+ const content = msg.content.content || msg.content.parts?.map((p) => p.type === "text" ? p.text : "").join(" ") || "";
481
+ if (!hasSemanticRecall && !content.toLowerCase().includes(searchQuery.toLowerCase())) {
482
+ return;
483
+ }
484
+ const messageIndex = threadMessages.findIndex((m) => m.id === msg.id);
485
+ const searchResult = {
486
+ id: msg.id,
487
+ role: msg.role,
488
+ content,
489
+ createdAt: msg.createdAt,
490
+ threadId: msg.threadId || thread.id,
491
+ threadTitle: thread.title || msg.threadId || thread.id
492
+ };
493
+ if (messageIndex !== -1) {
494
+ searchResult.context = {
495
+ before: threadMessages.slice(Math.max(0, messageIndex - 2), messageIndex).map((m) => ({
496
+ id: m.id,
497
+ role: m.role,
498
+ content: m.content,
499
+ createdAt: m.createdAt || /* @__PURE__ */ new Date()
500
+ })),
501
+ after: threadMessages.slice(messageIndex + 1, messageIndex + 3).map((m) => ({
502
+ id: m.id,
503
+ role: m.role,
504
+ content: m.content,
505
+ createdAt: m.createdAt || /* @__PURE__ */ new Date()
506
+ }))
507
+ };
508
+ }
509
+ searchResults.push(searchResult);
510
+ });
511
+ }
512
+ } else if (threadId) {
513
+ const thread = await memory.getThreadById({ threadId });
514
+ if (!thread) {
515
+ return {
516
+ results: [],
517
+ count: 0,
518
+ query: searchQuery,
519
+ searchScope: "thread",
520
+ searchType: hasSemanticRecall ? "semantic" : "text"
521
+ };
522
+ }
523
+ const result = await memory.rememberMessages({
524
+ threadId,
525
+ resourceId,
526
+ vectorMessageSearch: searchQuery,
527
+ config
528
+ });
529
+ const threadMessages = (await memory.query({ threadId })).uiMessages;
530
+ result.messagesV2.forEach((msg) => {
531
+ if (messageMap.has(msg.id)) return;
532
+ messageMap.set(msg.id, true);
533
+ const content = msg.content.content || msg.content.parts?.map((p) => p.type === "text" ? p.text : "").join(" ") || "";
534
+ if (!hasSemanticRecall && !content.toLowerCase().includes(searchQuery.toLowerCase())) {
535
+ return;
536
+ }
537
+ const messageIndex = threadMessages.findIndex((m) => m.id === msg.id);
538
+ const searchResult = {
539
+ id: msg.id,
540
+ role: msg.role,
541
+ content,
542
+ createdAt: msg.createdAt,
543
+ threadId,
544
+ threadTitle: thread?.title || threadId
545
+ };
546
+ if (messageIndex !== -1) {
547
+ searchResult.context = {
548
+ before: threadMessages.slice(Math.max(0, messageIndex - 2), messageIndex).map((m) => ({
549
+ id: m.id,
550
+ role: m.role,
551
+ content: m.content,
552
+ createdAt: m.createdAt || /* @__PURE__ */ new Date()
553
+ })),
554
+ after: threadMessages.slice(messageIndex + 1, messageIndex + 3).map((m) => ({
555
+ id: m.id,
556
+ role: m.role,
557
+ content: m.content,
558
+ createdAt: m.createdAt || /* @__PURE__ */ new Date()
559
+ }))
560
+ };
561
+ }
562
+ searchResults.push(searchResult);
563
+ });
564
+ }
565
+ const sortedResults = searchResults.sort((a, b) => new Date(b.createdAt).getTime() - new Date(a.createdAt).getTime()).slice(0, limit);
566
+ return {
567
+ results: sortedResults,
568
+ count: sortedResults.length,
569
+ query: searchQuery,
570
+ searchScope: resourceScope ? "resource" : "thread",
571
+ searchType: hasSemanticRecall ? "semantic" : "text"
572
+ };
573
+ } catch (error) {
574
+ return chunkRE4RPXT2_cjs.handleError(error, "Error searching memory");
575
+ }
576
+ }
577
+
578
+ exports.createThreadHandler = createThreadHandler;
579
+ exports.deleteMessagesHandler = deleteMessagesHandler;
580
+ exports.deleteThreadHandler = deleteThreadHandler;
581
+ exports.getMemoryConfigHandler = getMemoryConfigHandler;
582
+ exports.getMemoryStatusHandler = getMemoryStatusHandler;
583
+ exports.getMessagesHandler = getMessagesHandler;
584
+ exports.getMessagesPaginatedHandler = getMessagesPaginatedHandler;
585
+ exports.getThreadByIdHandler = getThreadByIdHandler;
586
+ exports.getThreadsHandler = getThreadsHandler;
587
+ exports.getThreadsPaginatedHandler = getThreadsPaginatedHandler;
588
+ exports.getWorkingMemoryHandler = getWorkingMemoryHandler;
589
+ exports.memory_exports = memory_exports;
590
+ exports.saveMessagesHandler = saveMessagesHandler;
591
+ exports.searchMemoryHandler = searchMemoryHandler;
592
+ exports.updateThreadHandler = updateThreadHandler;
593
+ exports.updateWorkingMemoryHandler = updateWorkingMemoryHandler;
594
+ //# sourceMappingURL=chunk-JTXOSCJQ.cjs.map
595
+ //# sourceMappingURL=chunk-JTXOSCJQ.cjs.map