@mastra/server 0.0.0-main-test-05-11-2025-2-20251106053353 → 0.0.0-main-test-2-20251127211532

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 (259) hide show
  1. package/CHANGELOG.md +428 -3
  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-6GHJDY7R.js +23157 -0
  13. package/dist/chunk-6GHJDY7R.js.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-TOCYBDP2.js → chunk-ER3QM7DD.js} +4 -4
  23. package/dist/{chunk-TOCYBDP2.js.map → chunk-ER3QM7DD.js.map} +1 -1
  24. package/dist/chunk-FPCGLPLJ.cjs +297 -0
  25. package/dist/chunk-FPCGLPLJ.cjs.map +1 -0
  26. package/dist/{chunk-D7T74TVR.js → chunk-G7BPNX2V.js} +4 -3
  27. package/dist/chunk-G7BPNX2V.js.map +1 -0
  28. package/dist/chunk-IMK7366C.cjs +346 -0
  29. package/dist/chunk-IMK7366C.cjs.map +1 -0
  30. package/dist/chunk-LGG3N3AV.js +116 -0
  31. package/dist/chunk-LGG3N3AV.js.map +1 -0
  32. package/dist/chunk-LIDPFFPK.cjs +23199 -0
  33. package/dist/chunk-LIDPFFPK.cjs.map +1 -0
  34. package/dist/chunk-LZDCXQMX.js +164 -0
  35. package/dist/chunk-LZDCXQMX.js.map +1 -0
  36. package/dist/chunk-MH3A7RDQ.cjs +1064 -0
  37. package/dist/chunk-MH3A7RDQ.cjs.map +1 -0
  38. package/dist/chunk-MWQQRVQC.cjs +259 -0
  39. package/dist/chunk-MWQQRVQC.cjs.map +1 -0
  40. package/dist/{chunk-KJIDZQRA.cjs → chunk-PDVJ2TTM.cjs} +216 -23
  41. package/dist/chunk-PDVJ2TTM.cjs.map +1 -0
  42. package/dist/chunk-PKRHEXX7.js +74 -0
  43. package/dist/chunk-PKRHEXX7.js.map +1 -0
  44. package/dist/chunk-QDOIM3G5.cjs +916 -0
  45. package/dist/chunk-QDOIM3G5.cjs.map +1 -0
  46. package/dist/chunk-QVHQZUGJ.cjs +368 -0
  47. package/dist/chunk-QVHQZUGJ.cjs.map +1 -0
  48. package/dist/chunk-R4M3BSUG.js +226 -0
  49. package/dist/chunk-R4M3BSUG.js.map +1 -0
  50. package/dist/chunk-R6ZTXNN2.cjs +797 -0
  51. package/dist/chunk-R6ZTXNN2.cjs.map +1 -0
  52. package/dist/{chunk-FPBYKMIS.js → chunk-RCCWKKI3.js} +210 -23
  53. package/dist/chunk-RCCWKKI3.js.map +1 -0
  54. package/dist/chunk-RIYA7ZCE.js +887 -0
  55. package/dist/chunk-RIYA7ZCE.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 +67 -27
  95. package/dist/server/handlers/memory.d.ts +933 -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 +23 -8
  208. package/dist/chunk-2IS5WICF.js +0 -23036
  209. package/dist/chunk-2IS5WICF.js.map +0 -1
  210. package/dist/chunk-3AMNUUZF.js +0 -124
  211. package/dist/chunk-3AMNUUZF.js.map +0 -1
  212. package/dist/chunk-4JF5WXPL.js +0 -502
  213. package/dist/chunk-4JF5WXPL.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-A24TSVEZ.cjs +0 -130
  217. package/dist/chunk-A24TSVEZ.cjs.map +0 -1
  218. package/dist/chunk-A2NPD5N6.cjs +0 -517
  219. package/dist/chunk-A2NPD5N6.cjs.map +0 -1
  220. package/dist/chunk-B3Z6J745.js +0 -122
  221. package/dist/chunk-B3Z6J745.js.map +0 -1
  222. package/dist/chunk-BANGX6SC.cjs +0 -200
  223. package/dist/chunk-BANGX6SC.cjs.map +0 -1
  224. package/dist/chunk-BTWIR2B7.cjs +0 -28
  225. package/dist/chunk-BTWIR2B7.cjs.map +0 -1
  226. package/dist/chunk-D7T74TVR.js.map +0 -1
  227. package/dist/chunk-EHACNWDL.cjs +0 -681
  228. package/dist/chunk-EHACNWDL.cjs.map +0 -1
  229. package/dist/chunk-FPBYKMIS.js.map +0 -1
  230. package/dist/chunk-GLAZTMX3.cjs +0 -128
  231. package/dist/chunk-GLAZTMX3.cjs.map +0 -1
  232. package/dist/chunk-ID6JYDNL.cjs +0 -23075
  233. package/dist/chunk-ID6JYDNL.cjs.map +0 -1
  234. package/dist/chunk-IGOWG5V5.js +0 -192
  235. package/dist/chunk-IGOWG5V5.js.map +0 -1
  236. package/dist/chunk-KF3RI45U.cjs +0 -172
  237. package/dist/chunk-KF3RI45U.cjs.map +0 -1
  238. package/dist/chunk-KJIDZQRA.cjs.map +0 -1
  239. package/dist/chunk-KWH5QBXP.js +0 -123
  240. package/dist/chunk-KWH5QBXP.js.map +0 -1
  241. package/dist/chunk-ND5OKOMT.js +0 -165
  242. package/dist/chunk-ND5OKOMT.js.map +0 -1
  243. package/dist/chunk-PPMIB3FQ.cjs +0 -88
  244. package/dist/chunk-PPMIB3FQ.cjs.map +0 -1
  245. package/dist/chunk-QU6N55W6.cjs.map +0 -1
  246. package/dist/chunk-S54HNARD.cjs +0 -131
  247. package/dist/chunk-S54HNARD.cjs.map +0 -1
  248. package/dist/chunk-SHWNNZBL.js.map +0 -1
  249. package/dist/chunk-SZIFSF4T.js +0 -25
  250. package/dist/chunk-SZIFSF4T.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-Z2O5YVHY.js +0 -661
  255. package/dist/chunk-Z2O5YVHY.js.map +0 -1
  256. package/dist/chunk-ZJ6KEY6H.js +0 -600
  257. package/dist/chunk-ZJ6KEY6H.js.map +0 -1
  258. package/dist/token-util-CV3RRG6K.cjs +0 -9
  259. package/dist/token-util-E5QO2RCL.js +0 -7
@@ -1,124 +0,0 @@
1
- import { handleError } from './chunk-UXGQZUYZ.js';
2
- import { HTTPException } from './chunk-6QWQZI4Q.js';
3
- import { __export } from './chunk-PR4QN5HX.js';
4
- import { scoreTraces } from '@mastra/core/evals/scoreTraces';
5
-
6
- // src/server/handlers/observability.ts
7
- var observability_exports = {};
8
- __export(observability_exports, {
9
- getTraceHandler: () => getTraceHandler,
10
- getTracesPaginatedHandler: () => getTracesPaginatedHandler,
11
- listScoresBySpan: () => listScoresBySpan,
12
- scoreTracesHandler: () => scoreTracesHandler
13
- });
14
- async function getTraceHandler({ mastra, traceId }) {
15
- try {
16
- if (!traceId) {
17
- throw new HTTPException(400, { message: "Trace ID is required" });
18
- }
19
- const storage = mastra.getStorage();
20
- if (!storage) {
21
- throw new HTTPException(500, { message: "Storage is not available" });
22
- }
23
- const trace = await storage.getTrace(traceId);
24
- if (!trace) {
25
- throw new HTTPException(404, { message: `Trace with ID '${traceId}' not found` });
26
- }
27
- return trace;
28
- } catch (error) {
29
- handleError(error, "Error getting trace");
30
- }
31
- }
32
- async function getTracesPaginatedHandler({ mastra, body }) {
33
- try {
34
- const storage = mastra.getStorage();
35
- if (!storage) {
36
- throw new HTTPException(500, { message: "Storage is not available" });
37
- }
38
- if (!body) {
39
- throw new HTTPException(400, { message: "Request body is required" });
40
- }
41
- const { filters, pagination } = body;
42
- if (pagination?.page && pagination.page < 0) {
43
- throw new HTTPException(400, { message: "Page must be a non-negative integer" });
44
- }
45
- if (pagination?.perPage && pagination.perPage < 0) {
46
- throw new HTTPException(400, { message: "Per page must be a non-negative integer" });
47
- }
48
- if (pagination?.dateRange) {
49
- const { start, end } = pagination.dateRange;
50
- if (start && !(start instanceof Date)) {
51
- throw new HTTPException(400, { message: "Invalid date format in date range" });
52
- }
53
- if (end && !(end instanceof Date)) {
54
- throw new HTTPException(400, { message: "Invalid date format in date range" });
55
- }
56
- }
57
- return storage.getTracesPaginated({
58
- pagination,
59
- filters
60
- });
61
- } catch (error) {
62
- handleError(error, "Error getting traces paginated");
63
- }
64
- }
65
- async function scoreTracesHandler({ mastra, body }) {
66
- try {
67
- if (!body) {
68
- throw new HTTPException(400, { message: "Request body is required" });
69
- }
70
- const { scorerName, targets } = body;
71
- if (!scorerName) {
72
- throw new HTTPException(400, { message: "Scorer ID is required" });
73
- }
74
- if (!targets || targets.length === 0) {
75
- throw new HTTPException(400, { message: "At least one target is required" });
76
- }
77
- const storage = mastra.getStorage();
78
- if (!storage) {
79
- throw new HTTPException(500, { message: "Storage is not available" });
80
- }
81
- const scorer = mastra.getScorerById(scorerName);
82
- if (!scorer) {
83
- throw new HTTPException(404, { message: `Scorer '${scorerName}' not found` });
84
- }
85
- const logger = mastra.getLogger();
86
- scoreTraces({
87
- scorerId: scorer.config.id || scorer.config.name,
88
- targets,
89
- mastra
90
- }).catch((error) => {
91
- logger?.error(`Background trace scoring failed: ${error.message}`, error);
92
- });
93
- return {
94
- status: "success",
95
- message: `Scoring started for ${targets.length} ${targets.length === 1 ? "trace" : "traces"}`,
96
- traceCount: targets.length
97
- };
98
- } catch (error) {
99
- handleError(error, "Error processing trace scoring");
100
- }
101
- }
102
- async function listScoresBySpan({
103
- mastra,
104
- traceId,
105
- spanId,
106
- pagination
107
- }) {
108
- try {
109
- const storage = mastra.getStorage();
110
- if (!storage) {
111
- throw new HTTPException(500, { message: "Storage is not available" });
112
- }
113
- if (!traceId || !spanId) {
114
- throw new HTTPException(400, { message: "Trace ID and span ID are required" });
115
- }
116
- return await storage.listScoresBySpan({ traceId, spanId, pagination });
117
- } catch (error) {
118
- return handleError(error, "Error getting scores by span");
119
- }
120
- }
121
-
122
- export { getTraceHandler, getTracesPaginatedHandler, listScoresBySpan, observability_exports, scoreTracesHandler };
123
- //# sourceMappingURL=chunk-3AMNUUZF.js.map
124
- //# sourceMappingURL=chunk-3AMNUUZF.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../src/server/handlers/observability.ts"],"names":[],"mappings":"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","file":"chunk-3AMNUUZF.js","sourcesContent":["import { scoreTraces } from '@mastra/core/evals/scoreTraces';\nimport type { TracesPaginatedArg, StoragePagination } from '@mastra/core/storage';\nimport { HTTPException } from '../http-exception';\nimport type { Context } from '../types';\nimport { handleError } from './error';\n\ninterface ObservabilityContext extends Context {\n traceId?: string;\n body?: TracesPaginatedArg;\n}\n\ninterface ScoreTracesContext extends Context {\n body?: {\n // scorer.id\n scorerName: string;\n targets: Array<{\n traceId: string;\n spanId?: string;\n }>;\n };\n}\n\n/**\n * Get a complete trace by trace ID\n * Returns all spans in the trace with their parent-child relationships\n */\nexport async function getTraceHandler({ mastra, traceId }: ObservabilityContext & { traceId: string }) {\n try {\n if (!traceId) {\n throw new HTTPException(400, { message: 'Trace ID is required' });\n }\n\n const storage = mastra.getStorage();\n if (!storage) {\n throw new HTTPException(500, { message: 'Storage is not available' });\n }\n\n const trace = await storage.getTrace(traceId);\n\n if (!trace) {\n throw new HTTPException(404, { message: `Trace with ID '${traceId}' not found` });\n }\n\n return trace;\n } catch (error) {\n handleError(error, 'Error getting trace');\n }\n}\n\n/**\n * Get paginated traces with filtering and pagination\n * Returns only root spans (parent spans) for pagination, not child spans\n */\nexport async function getTracesPaginatedHandler({ mastra, body }: ObservabilityContext) {\n try {\n const storage = mastra.getStorage();\n if (!storage) {\n throw new HTTPException(500, { message: 'Storage is not available' });\n }\n\n if (!body) {\n throw new HTTPException(400, { message: 'Request body is required' });\n }\n\n const { filters, pagination } = body;\n\n if (pagination?.page && pagination.page < 0) {\n throw new HTTPException(400, { message: 'Page must be a non-negative integer' });\n }\n\n if (pagination?.perPage && pagination.perPage < 0) {\n throw new HTTPException(400, { message: 'Per page must be a non-negative integer' });\n }\n\n if (pagination?.dateRange) {\n const { start, end } = pagination.dateRange;\n\n if (start && !(start instanceof Date)) {\n throw new HTTPException(400, { message: 'Invalid date format in date range' });\n }\n\n if (end && !(end instanceof Date)) {\n throw new HTTPException(400, { message: 'Invalid date format in date range' });\n }\n }\n\n return storage.getTracesPaginated({\n pagination,\n filters,\n });\n } catch (error) {\n handleError(error, 'Error getting traces paginated');\n }\n}\n\n/**\n * Score traces using a specified scorer\n * Fire-and-forget approach - returns immediately while scoring runs in background\n */\nexport async function scoreTracesHandler({ mastra, body }: ScoreTracesContext) {\n try {\n if (!body) {\n throw new HTTPException(400, { message: 'Request body is required' });\n }\n\n const { scorerName, targets } = body;\n\n if (!scorerName) {\n throw new HTTPException(400, { message: 'Scorer ID is required' });\n }\n\n if (!targets || targets.length === 0) {\n throw new HTTPException(400, { message: 'At least one target is required' });\n }\n\n const storage = mastra.getStorage();\n if (!storage) {\n throw new HTTPException(500, { message: 'Storage is not available' });\n }\n\n const scorer = mastra.getScorerById(scorerName);\n if (!scorer) {\n throw new HTTPException(404, { message: `Scorer '${scorerName}' not found` });\n }\n\n const logger = mastra.getLogger();\n\n scoreTraces({\n scorerId: scorer.config.id || scorer.config.name,\n targets,\n mastra,\n }).catch(error => {\n logger?.error(`Background trace scoring failed: ${error.message}`, error);\n });\n\n // Return immediate response\n return {\n status: 'success',\n message: `Scoring started for ${targets.length} ${targets.length === 1 ? 'trace' : 'traces'}`,\n traceCount: targets.length,\n };\n } catch (error) {\n handleError(error, 'Error processing trace scoring');\n }\n}\n\nexport async function listScoresBySpan({\n mastra,\n traceId,\n spanId,\n pagination,\n}: Context & { traceId: string; spanId: string; pagination: StoragePagination }) {\n try {\n const storage = mastra.getStorage();\n if (!storage) {\n throw new HTTPException(500, { message: 'Storage is not available' });\n }\n\n if (!traceId || !spanId) {\n throw new HTTPException(400, { message: 'Trace ID and span ID are required' });\n }\n\n return await storage.listScoresBySpan({ traceId, spanId, pagination });\n } catch (error) {\n return handleError(error, 'Error getting scores by span');\n }\n}\n"]}
@@ -1,502 +0,0 @@
1
- import { validateBody } from './chunk-SZIFSF4T.js';
2
- import { handleError } from './chunk-UXGQZUYZ.js';
3
- import { HTTPException } from './chunk-6QWQZI4Q.js';
4
- import { __export } from './chunk-PR4QN5HX.js';
5
- import { RequestContext } from '@mastra/core/di';
6
- import { generateEmptyFromSchema } from '@mastra/core/utils';
7
-
8
- // src/server/handlers/memory.ts
9
- var memory_exports = {};
10
- __export(memory_exports, {
11
- createThreadHandler: () => createThreadHandler,
12
- deleteMessagesHandler: () => deleteMessagesHandler,
13
- deleteThreadHandler: () => deleteThreadHandler,
14
- getMemoryConfigHandler: () => getMemoryConfigHandler,
15
- getMemoryStatusHandler: () => getMemoryStatusHandler,
16
- getThreadByIdHandler: () => getThreadByIdHandler,
17
- getWorkingMemoryHandler: () => getWorkingMemoryHandler,
18
- listMessagesHandler: () => listMessagesHandler,
19
- listThreadsHandler: () => listThreadsHandler,
20
- saveMessagesHandler: () => saveMessagesHandler,
21
- searchMemoryHandler: () => searchMemoryHandler,
22
- updateThreadHandler: () => updateThreadHandler,
23
- updateWorkingMemoryHandler: () => updateWorkingMemoryHandler
24
- });
25
- async function getMemoryFromContext({
26
- mastra,
27
- agentId,
28
- requestContext
29
- }) {
30
- const logger = mastra.getLogger();
31
- let agent;
32
- if (agentId) {
33
- try {
34
- agent = mastra.getAgentById(agentId);
35
- } catch (error) {
36
- logger.debug("Error getting agent from mastra, searching agents for agent", error);
37
- }
38
- }
39
- if (agentId && !agent) {
40
- logger.debug("Agent not found, searching agents for agent", { agentId });
41
- const agents = mastra.listAgents();
42
- if (Object.keys(agents || {}).length) {
43
- for (const [_, ag] of Object.entries(agents)) {
44
- try {
45
- const agents2 = await ag.listAgents();
46
- if (agents2[agentId]) {
47
- agent = agents2[agentId];
48
- break;
49
- }
50
- } catch (error) {
51
- logger.debug("Error getting agent from agent", error);
52
- }
53
- }
54
- }
55
- if (!agent) {
56
- throw new HTTPException(404, { message: "Agent not found" });
57
- }
58
- }
59
- if (agent) {
60
- return await agent?.getMemory({
61
- requestContext: requestContext ?? new RequestContext()
62
- });
63
- }
64
- }
65
- async function getMemoryStatusHandler({
66
- mastra,
67
- agentId,
68
- requestContext
69
- }) {
70
- try {
71
- const memory = await getMemoryFromContext({ mastra, agentId, requestContext });
72
- if (!memory) {
73
- return { result: false };
74
- }
75
- return { result: true };
76
- } catch (error) {
77
- return handleError(error, "Error getting memory status");
78
- }
79
- }
80
- async function getMemoryConfigHandler({
81
- mastra,
82
- agentId,
83
- requestContext
84
- }) {
85
- try {
86
- const memory = await getMemoryFromContext({ mastra, agentId, requestContext });
87
- if (!memory) {
88
- throw new HTTPException(400, { message: "Memory is not initialized" });
89
- }
90
- const config = memory.getMergedThreadConfig({});
91
- return { config };
92
- } catch (error) {
93
- return handleError(error, "Error getting memory configuration");
94
- }
95
- }
96
- async function listThreadsHandler({
97
- mastra,
98
- agentId,
99
- resourceId,
100
- requestContext,
101
- page,
102
- perPage,
103
- orderBy
104
- }) {
105
- try {
106
- const memory = await getMemoryFromContext({ mastra, agentId, requestContext });
107
- if (!memory) {
108
- throw new HTTPException(400, { message: "Memory is not initialized" });
109
- }
110
- validateBody({ resourceId });
111
- const result = await memory.listThreadsByResourceId({
112
- resourceId,
113
- page,
114
- perPage,
115
- orderBy
116
- });
117
- return result;
118
- } catch (error) {
119
- return handleError(error, "Error listing threads");
120
- }
121
- }
122
- async function getThreadByIdHandler({
123
- mastra,
124
- agentId,
125
- threadId,
126
- requestContext
127
- }) {
128
- try {
129
- validateBody({ threadId });
130
- const memory = await getMemoryFromContext({ mastra, agentId, requestContext });
131
- if (!memory) {
132
- throw new HTTPException(400, { message: "Memory is not initialized" });
133
- }
134
- const thread = await memory.getThreadById({ threadId });
135
- if (!thread) {
136
- throw new HTTPException(404, { message: "Thread not found" });
137
- }
138
- return thread;
139
- } catch (error) {
140
- return handleError(error, "Error getting thread");
141
- }
142
- }
143
- async function saveMessagesHandler({
144
- mastra,
145
- agentId,
146
- body,
147
- requestContext
148
- }) {
149
- try {
150
- const memory = await getMemoryFromContext({ mastra, agentId, requestContext });
151
- if (!memory) {
152
- throw new HTTPException(400, { message: "Memory is not initialized" });
153
- }
154
- if (!body?.messages) {
155
- throw new HTTPException(400, { message: "Messages are required" });
156
- }
157
- if (!Array.isArray(body.messages)) {
158
- throw new HTTPException(400, { message: "Messages should be an array" });
159
- }
160
- const invalidMessages = body.messages.filter((message) => !message.threadId || !message.resourceId);
161
- if (invalidMessages.length > 0) {
162
- throw new HTTPException(400, {
163
- message: `All messages must have threadId and resourceId fields. Found ${invalidMessages.length} invalid message(s).`
164
- });
165
- }
166
- const processedMessages = body.messages.map((message) => ({
167
- ...message,
168
- id: message.id || memory.generateId(),
169
- createdAt: message.createdAt ? new Date(message.createdAt) : /* @__PURE__ */ new Date()
170
- }));
171
- const result = await memory.saveMessages({ messages: processedMessages, memoryConfig: {} });
172
- return result;
173
- } catch (error) {
174
- return handleError(error, "Error saving messages");
175
- }
176
- }
177
- async function createThreadHandler({
178
- mastra,
179
- agentId,
180
- body,
181
- requestContext
182
- }) {
183
- try {
184
- const memory = await getMemoryFromContext({ mastra, agentId, requestContext });
185
- if (!memory) {
186
- throw new HTTPException(400, { message: "Memory is not initialized" });
187
- }
188
- validateBody({ resourceId: body?.resourceId });
189
- const result = await memory.createThread({
190
- resourceId: body?.resourceId,
191
- title: body?.title,
192
- metadata: body?.metadata,
193
- threadId: body?.threadId
194
- });
195
- return result;
196
- } catch (error) {
197
- return handleError(error, "Error saving thread to memory");
198
- }
199
- }
200
- async function updateThreadHandler({
201
- mastra,
202
- agentId,
203
- threadId,
204
- body,
205
- requestContext
206
- }) {
207
- try {
208
- const memory = await getMemoryFromContext({ mastra, agentId, requestContext });
209
- if (!body) {
210
- throw new HTTPException(400, { message: "Body is required" });
211
- }
212
- const { title, metadata, resourceId } = body;
213
- const updatedAt = /* @__PURE__ */ new Date();
214
- validateBody({ threadId });
215
- if (!memory) {
216
- throw new HTTPException(400, { message: "Memory is not initialized" });
217
- }
218
- const thread = await memory.getThreadById({ threadId });
219
- if (!thread) {
220
- throw new HTTPException(404, { message: "Thread not found" });
221
- }
222
- const updatedThread = {
223
- ...thread,
224
- title: title || thread.title,
225
- metadata: metadata || thread.metadata,
226
- resourceId: resourceId || thread.resourceId,
227
- createdAt: thread.createdAt,
228
- updatedAt
229
- };
230
- const result = await memory.saveThread({ thread: updatedThread });
231
- return result;
232
- } catch (error) {
233
- return handleError(error, "Error updating thread");
234
- }
235
- }
236
- async function deleteThreadHandler({
237
- mastra,
238
- agentId,
239
- threadId,
240
- requestContext
241
- }) {
242
- try {
243
- validateBody({ threadId });
244
- const memory = await getMemoryFromContext({ mastra, agentId, requestContext });
245
- if (!memory) {
246
- throw new HTTPException(400, { message: "Memory is not initialized" });
247
- }
248
- const thread = await memory.getThreadById({ threadId });
249
- if (!thread) {
250
- throw new HTTPException(404, { message: "Thread not found" });
251
- }
252
- await memory.deleteThread(threadId);
253
- return { result: "Thread deleted" };
254
- } catch (error) {
255
- return handleError(error, "Error deleting thread");
256
- }
257
- }
258
- async function listMessagesHandler({
259
- mastra,
260
- agentId,
261
- threadId,
262
- resourceId,
263
- perPage,
264
- page,
265
- orderBy,
266
- include,
267
- filter,
268
- requestContext
269
- }) {
270
- try {
271
- validateBody({ threadId });
272
- const memory = await getMemoryFromContext({ mastra, agentId, requestContext });
273
- if (!memory) {
274
- throw new HTTPException(400, { message: "Memory is not initialized" });
275
- }
276
- if (!threadId) {
277
- throw new HTTPException(400, { message: "No threadId found" });
278
- }
279
- const thread = await memory.getThreadById({ threadId });
280
- if (!thread) {
281
- throw new HTTPException(404, { message: "Thread not found" });
282
- }
283
- const result = await memory.recall({
284
- threadId,
285
- resourceId,
286
- perPage,
287
- page,
288
- orderBy,
289
- include,
290
- filter
291
- });
292
- return result;
293
- } catch (error) {
294
- return handleError(error, "Error getting messages");
295
- }
296
- }
297
- async function getWorkingMemoryHandler({
298
- mastra,
299
- agentId,
300
- threadId,
301
- resourceId,
302
- requestContext,
303
- memoryConfig
304
- }) {
305
- try {
306
- const memory = await getMemoryFromContext({ mastra, agentId, requestContext });
307
- validateBody({ threadId });
308
- if (!memory) {
309
- throw new HTTPException(400, { message: "Memory is not initialized" });
310
- }
311
- const thread = await memory.getThreadById({ threadId });
312
- const threadExists = !!thread;
313
- const template = await memory.getWorkingMemoryTemplate({ memoryConfig });
314
- const workingMemoryTemplate = template?.format === "json" ? { ...template, content: JSON.stringify(generateEmptyFromSchema(template.content)) } : template;
315
- const workingMemory = await memory.getWorkingMemory({ threadId, resourceId, memoryConfig });
316
- const config = memory.getMergedThreadConfig(memoryConfig || {});
317
- const source = config.workingMemory?.scope !== "thread" && resourceId ? "resource" : "thread";
318
- return { workingMemory, source, workingMemoryTemplate, threadExists };
319
- } catch (error) {
320
- return handleError(error, "Error getting working memory");
321
- }
322
- }
323
- async function updateWorkingMemoryHandler({
324
- mastra,
325
- agentId,
326
- threadId,
327
- body,
328
- requestContext
329
- }) {
330
- try {
331
- validateBody({ threadId });
332
- const memory = await getMemoryFromContext({ mastra, agentId, requestContext });
333
- const { resourceId, memoryConfig, workingMemory } = body;
334
- if (!memory) {
335
- throw new HTTPException(400, { message: "Memory is not initialized" });
336
- }
337
- const thread = await memory.getThreadById({ threadId });
338
- if (!thread) {
339
- throw new HTTPException(404, { message: "Thread not found" });
340
- }
341
- await memory.updateWorkingMemory({ threadId, resourceId, workingMemory, memoryConfig });
342
- return { success: true };
343
- } catch (error) {
344
- return handleError(error, "Error updating working memory");
345
- }
346
- }
347
- async function deleteMessagesHandler({
348
- mastra,
349
- agentId,
350
- messageIds,
351
- requestContext
352
- }) {
353
- try {
354
- if (messageIds === void 0 || messageIds === null) {
355
- throw new HTTPException(400, { message: "messageIds is required" });
356
- }
357
- const memory = await getMemoryFromContext({ mastra, agentId, requestContext });
358
- if (!memory) {
359
- throw new HTTPException(400, { message: "Memory is not initialized" });
360
- }
361
- await memory.deleteMessages(messageIds);
362
- let count = 1;
363
- if (Array.isArray(messageIds)) {
364
- count = messageIds.length;
365
- }
366
- return { success: true, message: `${count} message${count === 1 ? "" : "s"} deleted successfully` };
367
- } catch (error) {
368
- return handleError(error, "Error deleting messages");
369
- }
370
- }
371
- async function searchMemoryHandler({
372
- mastra,
373
- agentId,
374
- searchQuery,
375
- resourceId,
376
- threadId,
377
- limit = 20,
378
- requestContext,
379
- memoryConfig
380
- }) {
381
- try {
382
- validateBody({ searchQuery, resourceId });
383
- const memory = await getMemoryFromContext({ mastra, agentId, requestContext });
384
- if (!memory) {
385
- throw new HTTPException(400, { message: "Memory is not initialized" });
386
- }
387
- const config = memory.getMergedThreadConfig(memoryConfig || {});
388
- const hasSemanticRecall = !!config?.semanticRecall;
389
- const resourceScope = typeof config?.semanticRecall === "object" ? config?.semanticRecall?.scope !== "thread" : true;
390
- if (threadId && !resourceScope) {
391
- const thread = await memory.getThreadById({ threadId });
392
- if (!thread) {
393
- throw new HTTPException(404, { message: "Thread not found" });
394
- }
395
- if (thread.resourceId !== resourceId) {
396
- throw new HTTPException(403, { message: "Thread does not belong to the specified resource" });
397
- }
398
- }
399
- const searchResults = [];
400
- if (threadId && !resourceScope) {
401
- const thread = await memory.getThreadById({ threadId });
402
- if (!thread) {
403
- return {
404
- results: [],
405
- count: 0,
406
- query: searchQuery,
407
- searchScope: resourceScope ? "resource" : "thread",
408
- searchType: hasSemanticRecall ? "semantic" : "text"
409
- };
410
- }
411
- }
412
- if (!threadId) {
413
- const { threads } = await memory.listThreadsByResourceId({
414
- resourceId,
415
- page: 0,
416
- perPage: 1,
417
- orderBy: { field: "updatedAt", direction: "DESC" }
418
- });
419
- if (threads.length === 0) {
420
- return {
421
- results: [],
422
- count: 0,
423
- query: searchQuery,
424
- searchScope: resourceScope ? "resource" : "thread",
425
- searchType: hasSemanticRecall ? "semantic" : "text"
426
- };
427
- }
428
- threadId = threads[0].id;
429
- }
430
- const beforeRange = typeof config.semanticRecall === `boolean` ? 2 : typeof config.semanticRecall?.messageRange === `number` ? config.semanticRecall.messageRange : config.semanticRecall?.messageRange.before || 2;
431
- const afterRange = typeof config.semanticRecall === `boolean` ? 2 : typeof config.semanticRecall?.messageRange === `number` ? config.semanticRecall.messageRange : config.semanticRecall?.messageRange.after || 2;
432
- if (resourceScope && config.semanticRecall) {
433
- config.semanticRecall = typeof config.semanticRecall === `boolean` ? (
434
- // make message range 0 so we can highlight the matches in search, message range will include other messages, not the matching ones
435
- // and we add prev/next messages in a special section on each message anyway
436
- { messageRange: 0, topK: 2, scope: "resource" }
437
- ) : { ...config.semanticRecall, messageRange: 0 };
438
- }
439
- const threadConfig = memory.getMergedThreadConfig(config || {});
440
- if (!threadConfig.lastMessages && !threadConfig.semanticRecall) {
441
- return { results: [], count: 0, query: searchQuery };
442
- }
443
- const result = await memory.recall({
444
- threadId,
445
- resourceId,
446
- perPage: threadConfig.lastMessages,
447
- threadConfig: config,
448
- vectorSearchString: threadConfig.semanticRecall && searchQuery ? searchQuery : void 0
449
- });
450
- const threadIds = Array.from(
451
- new Set(result.messages.map((m) => m.threadId || threadId).filter(Boolean))
452
- );
453
- const fetched = await Promise.all(threadIds.map((id) => memory.getThreadById({ threadId: id })));
454
- const threadMap = new Map(fetched.filter(Boolean).map((t) => [t.id, t]));
455
- for (const msg of result.messages) {
456
- const content = typeof msg.content.content === `string` ? msg.content.content : msg.content.parts?.map((p) => p.type === "text" ? p.text : "").join(" ") || "";
457
- const msgThreadId = msg.threadId || threadId;
458
- const thread = threadMap.get(msgThreadId);
459
- const threadMessages = (await memory.recall({ threadId: msgThreadId })).messages;
460
- const messageIndex = threadMessages.findIndex((m) => m.id === msg.id);
461
- const searchResult = {
462
- id: msg.id,
463
- role: msg.role,
464
- content,
465
- createdAt: msg.createdAt,
466
- threadId: msgThreadId,
467
- threadTitle: thread?.title || msgThreadId
468
- };
469
- if (messageIndex !== -1) {
470
- searchResult.context = {
471
- before: threadMessages.slice(Math.max(0, messageIndex - beforeRange), messageIndex).map((m) => ({
472
- id: m.id,
473
- role: m.role,
474
- content: m.content,
475
- createdAt: m.createdAt || /* @__PURE__ */ new Date()
476
- })),
477
- after: threadMessages.slice(messageIndex + 1, messageIndex + afterRange + 1).map((m) => ({
478
- id: m.id,
479
- role: m.role,
480
- content: m.content,
481
- createdAt: m.createdAt || /* @__PURE__ */ new Date()
482
- }))
483
- };
484
- }
485
- searchResults.push(searchResult);
486
- }
487
- const sortedResults = searchResults.sort((a, b) => new Date(b.createdAt).getTime() - new Date(a.createdAt).getTime()).slice(0, limit);
488
- return {
489
- results: sortedResults,
490
- count: sortedResults.length,
491
- query: searchQuery,
492
- searchScope: resourceScope ? "resource" : "thread",
493
- searchType: hasSemanticRecall ? "semantic" : "text"
494
- };
495
- } catch (error) {
496
- return handleError(error, "Error searching memory");
497
- }
498
- }
499
-
500
- export { createThreadHandler, deleteMessagesHandler, deleteThreadHandler, getMemoryConfigHandler, getMemoryStatusHandler, getThreadByIdHandler, getWorkingMemoryHandler, listMessagesHandler, listThreadsHandler, memory_exports, saveMessagesHandler, searchMemoryHandler, updateThreadHandler, updateWorkingMemoryHandler };
501
- //# sourceMappingURL=chunk-4JF5WXPL.js.map
502
- //# sourceMappingURL=chunk-4JF5WXPL.js.map