@mastra/server 1.18.0-alpha.4 → 1.18.0-alpha.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 (154) hide show
  1. package/CHANGELOG.md +22 -0
  2. package/dist/_types/@internal_core/dist/index.d.ts +502 -29
  3. package/dist/{chunk-IOCKHUAA.cjs → chunk-2QCTUEHS.cjs} +3 -3
  4. package/dist/{chunk-IOCKHUAA.cjs.map → chunk-2QCTUEHS.cjs.map} +1 -1
  5. package/dist/{chunk-SUZOB46P.cjs → chunk-3W54ZNYP.cjs} +4 -4
  6. package/dist/{chunk-SUZOB46P.cjs.map → chunk-3W54ZNYP.cjs.map} +1 -1
  7. package/dist/{chunk-ZL4KCUCN.js → chunk-4D7KSU4X.js} +4 -4
  8. package/dist/{chunk-ZL4KCUCN.js.map → chunk-4D7KSU4X.js.map} +1 -1
  9. package/dist/{chunk-AUSQGJ52.js → chunk-4NRXB7VI.js} +3 -3
  10. package/dist/{chunk-AUSQGJ52.js.map → chunk-4NRXB7VI.js.map} +1 -1
  11. package/dist/{chunk-6M5HZQQV.js → chunk-4WCXXTKX.js} +4 -4
  12. package/dist/{chunk-6M5HZQQV.js.map → chunk-4WCXXTKX.js.map} +1 -1
  13. package/dist/{chunk-RSIZIEPW.js → chunk-53YFG5AY.js} +58 -2
  14. package/dist/chunk-53YFG5AY.js.map +1 -0
  15. package/dist/{chunk-SECEXHY4.js → chunk-5YMAXL54.js} +3 -3
  16. package/dist/{chunk-SECEXHY4.js.map → chunk-5YMAXL54.js.map} +1 -1
  17. package/dist/{chunk-4NTRDFFE.cjs → chunk-6FF7Q5D7.cjs} +6 -6
  18. package/dist/{chunk-4NTRDFFE.cjs.map → chunk-6FF7Q5D7.cjs.map} +1 -1
  19. package/dist/{chunk-U4GMLJ6B.cjs → chunk-A5J2TY2W.cjs} +3 -3
  20. package/dist/{chunk-U4GMLJ6B.cjs.map → chunk-A5J2TY2W.cjs.map} +1 -1
  21. package/dist/{chunk-3XXKCBEU.js → chunk-B32EWUTE.js} +83 -27
  22. package/dist/chunk-B32EWUTE.js.map +1 -0
  23. package/dist/{chunk-IFSINB5S.js → chunk-B5FSBQV5.js} +3 -3
  24. package/dist/{chunk-IFSINB5S.js.map → chunk-B5FSBQV5.js.map} +1 -1
  25. package/dist/{chunk-3PYG4YYL.js → chunk-E56FRMZY.js} +3 -3
  26. package/dist/{chunk-3PYG4YYL.js.map → chunk-E56FRMZY.js.map} +1 -1
  27. package/dist/{chunk-NS5TM6YM.js → chunk-FB5NRM2M.js} +3 -3
  28. package/dist/{chunk-NS5TM6YM.js.map → chunk-FB5NRM2M.js.map} +1 -1
  29. package/dist/{chunk-HEJ53V64.js → chunk-FWNRIUEW.js} +4 -4
  30. package/dist/{chunk-HEJ53V64.js.map → chunk-FWNRIUEW.js.map} +1 -1
  31. package/dist/{chunk-B5DA5QVZ.js → chunk-G2ZZKKQI.js} +4 -4
  32. package/dist/{chunk-B5DA5QVZ.js.map → chunk-G2ZZKKQI.js.map} +1 -1
  33. package/dist/{chunk-DTJJFVTS.js → chunk-GCHFLKRG.js} +24 -18
  34. package/dist/chunk-GCHFLKRG.js.map +1 -0
  35. package/dist/{chunk-7EOHGXMP.cjs → chunk-GDWCOWNR.cjs} +21 -21
  36. package/dist/{chunk-7EOHGXMP.cjs.map → chunk-GDWCOWNR.cjs.map} +1 -1
  37. package/dist/{chunk-JD5ZGRBN.cjs → chunk-HBMIUVV4.cjs} +3 -3
  38. package/dist/{chunk-JD5ZGRBN.cjs.map → chunk-HBMIUVV4.cjs.map} +1 -1
  39. package/dist/{chunk-NCHR6DGR.js → chunk-HI5EDX3F.js} +3 -3
  40. package/dist/{chunk-NCHR6DGR.js.map → chunk-HI5EDX3F.js.map} +1 -1
  41. package/dist/{chunk-SIPQHHIE.cjs → chunk-HSCQPKAF.cjs} +25 -19
  42. package/dist/chunk-HSCQPKAF.cjs.map +1 -0
  43. package/dist/{chunk-NEB3TPME.cjs → chunk-JH576GTI.cjs} +3 -3
  44. package/dist/{chunk-NEB3TPME.cjs.map → chunk-JH576GTI.cjs.map} +1 -1
  45. package/dist/{chunk-VOCUA2P2.js → chunk-K6RNBFGH.js} +4 -4
  46. package/dist/{chunk-VOCUA2P2.js.map → chunk-K6RNBFGH.js.map} +1 -1
  47. package/dist/{chunk-VDAG64VF.cjs → chunk-KOKKZIYI.cjs} +5 -5
  48. package/dist/{chunk-VDAG64VF.cjs.map → chunk-KOKKZIYI.cjs.map} +1 -1
  49. package/dist/{chunk-LDIPV66L.js → chunk-M6AQTASN.js} +3 -3
  50. package/dist/{chunk-LDIPV66L.js.map → chunk-M6AQTASN.js.map} +1 -1
  51. package/dist/{chunk-SEPFGGZQ.js → chunk-MH2WUZWZ.js} +4 -4
  52. package/dist/{chunk-SEPFGGZQ.js.map → chunk-MH2WUZWZ.js.map} +1 -1
  53. package/dist/{chunk-TWILU7Q5.js → chunk-MKW43AJ3.js} +4 -4
  54. package/dist/{chunk-TWILU7Q5.js.map → chunk-MKW43AJ3.js.map} +1 -1
  55. package/dist/{chunk-ZEQ3ZL2T.cjs → chunk-MUNMS4IN.cjs} +83 -26
  56. package/dist/chunk-MUNMS4IN.cjs.map +1 -0
  57. package/dist/{chunk-GIRVVQTS.js → chunk-MYFV2L3T.js} +12 -4
  58. package/dist/{chunk-GIRVVQTS.js.map → chunk-MYFV2L3T.js.map} +1 -1
  59. package/dist/{chunk-2HOVE4YF.cjs → chunk-NCCK5NVX.cjs} +4 -4
  60. package/dist/{chunk-2HOVE4YF.cjs.map → chunk-NCCK5NVX.cjs.map} +1 -1
  61. package/dist/{chunk-4LOHS62D.cjs → chunk-NOBDUHIG.cjs} +3 -3
  62. package/dist/{chunk-4LOHS62D.cjs.map → chunk-NOBDUHIG.cjs.map} +1 -1
  63. package/dist/{chunk-TEAYHLYJ.cjs → chunk-OSMI5XLT.cjs} +297 -71
  64. package/dist/chunk-OSMI5XLT.cjs.map +1 -0
  65. package/dist/{chunk-PV7IUA6N.js → chunk-QJZOWORS.js} +3 -3
  66. package/dist/{chunk-PV7IUA6N.js.map → chunk-QJZOWORS.js.map} +1 -1
  67. package/dist/{chunk-42OVSPQK.js → chunk-SDKSW2BQ.js} +6 -6
  68. package/dist/{chunk-42OVSPQK.js.map → chunk-SDKSW2BQ.js.map} +1 -1
  69. package/dist/{chunk-2UVJD67W.cjs → chunk-TU7U5XUE.cjs} +58 -2
  70. package/dist/chunk-TU7U5XUE.cjs.map +1 -0
  71. package/dist/{chunk-OFI7WQSK.cjs → chunk-TYYGY4H4.cjs} +4 -4
  72. package/dist/{chunk-OFI7WQSK.cjs.map → chunk-TYYGY4H4.cjs.map} +1 -1
  73. package/dist/{chunk-PGPTFBZ3.cjs → chunk-U6YSBD3M.cjs} +7 -7
  74. package/dist/{chunk-PGPTFBZ3.cjs.map → chunk-U6YSBD3M.cjs.map} +1 -1
  75. package/dist/{chunk-N4PIAZEA.cjs → chunk-UFK5THVP.cjs} +4 -4
  76. package/dist/{chunk-N4PIAZEA.cjs.map → chunk-UFK5THVP.cjs.map} +1 -1
  77. package/dist/{chunk-42UIDILO.cjs → chunk-ULLR3RN3.cjs} +4 -4
  78. package/dist/{chunk-42UIDILO.cjs.map → chunk-ULLR3RN3.cjs.map} +1 -1
  79. package/dist/{chunk-LCA2MLVR.cjs → chunk-WUCJRGTK.cjs} +3 -3
  80. package/dist/{chunk-LCA2MLVR.cjs.map → chunk-WUCJRGTK.cjs.map} +1 -1
  81. package/dist/{chunk-FQHTXKF6.cjs → chunk-XINNAPVH.cjs} +34 -26
  82. package/dist/chunk-XINNAPVH.cjs.map +1 -0
  83. package/dist/{chunk-BX372Y6T.js → chunk-YFQ5JIUD.js} +256 -38
  84. package/dist/chunk-YFQ5JIUD.js.map +1 -0
  85. package/dist/{chunk-S5PRNKVT.cjs → chunk-YV7FX2SA.cjs} +3 -3
  86. package/dist/{chunk-S5PRNKVT.cjs.map → chunk-YV7FX2SA.cjs.map} +1 -1
  87. package/dist/docs/SKILL.md +1 -1
  88. package/dist/docs/assets/SOURCE_MAP.json +1 -1
  89. package/dist/server/handlers/a2a.cjs +9 -9
  90. package/dist/server/handlers/a2a.js +1 -1
  91. package/dist/server/handlers/agent-builder.cjs +16 -16
  92. package/dist/server/handlers/agent-builder.js +1 -1
  93. package/dist/server/handlers/agent-versions.cjs +8 -8
  94. package/dist/server/handlers/agent-versions.js +1 -1
  95. package/dist/server/handlers/agents.cjs +37 -33
  96. package/dist/server/handlers/agents.d.ts +3 -0
  97. package/dist/server/handlers/agents.d.ts.map +1 -1
  98. package/dist/server/handlers/agents.js +1 -1
  99. package/dist/server/handlers/datasets.cjs +26 -26
  100. package/dist/server/handlers/datasets.js +1 -1
  101. package/dist/server/handlers/logs.cjs +4 -4
  102. package/dist/server/handlers/logs.js +1 -1
  103. package/dist/server/handlers/mcp-client-versions.cjs +8 -8
  104. package/dist/server/handlers/mcp-client-versions.js +1 -1
  105. package/dist/server/handlers/observability-new-endpoints.cjs +51 -19
  106. package/dist/server/handlers/observability-new-endpoints.d.ts +1998 -458
  107. package/dist/server/handlers/observability-new-endpoints.d.ts.map +1 -1
  108. package/dist/server/handlers/observability-new-endpoints.js +1 -1
  109. package/dist/server/handlers/observability-shared.cjs +5 -5
  110. package/dist/server/handlers/observability-shared.d.ts +56 -0
  111. package/dist/server/handlers/observability-shared.d.ts.map +1 -1
  112. package/dist/server/handlers/observability-shared.js +1 -1
  113. package/dist/server/handlers/observability.cjs +56 -24
  114. package/dist/server/handlers/observability.js +2 -2
  115. package/dist/server/handlers/prompt-block-versions.cjs +8 -8
  116. package/dist/server/handlers/prompt-block-versions.js +1 -1
  117. package/dist/server/handlers/scorer-versions.cjs +8 -8
  118. package/dist/server/handlers/scorer-versions.js +1 -1
  119. package/dist/server/handlers/scores.cjs +7 -7
  120. package/dist/server/handlers/scores.js +1 -1
  121. package/dist/server/handlers/stored-agents.cjs +7 -7
  122. package/dist/server/handlers/stored-agents.js +1 -1
  123. package/dist/server/handlers/stored-mcp-clients.cjs +6 -6
  124. package/dist/server/handlers/stored-mcp-clients.js +1 -1
  125. package/dist/server/handlers/stored-prompt-blocks.cjs +6 -6
  126. package/dist/server/handlers/stored-prompt-blocks.js +1 -1
  127. package/dist/server/handlers/stored-scorers.cjs +6 -6
  128. package/dist/server/handlers/stored-scorers.js +1 -1
  129. package/dist/server/handlers/stored-workspaces.cjs +6 -6
  130. package/dist/server/handlers/stored-workspaces.js +1 -1
  131. package/dist/server/handlers/tools.cjs +6 -6
  132. package/dist/server/handlers/tools.d.ts.map +1 -1
  133. package/dist/server/handlers/tools.js +1 -1
  134. package/dist/server/handlers/voice.cjs +8 -8
  135. package/dist/server/handlers/voice.js +1 -1
  136. package/dist/server/handlers/workflows.cjs +24 -24
  137. package/dist/server/handlers/workflows.js +1 -1
  138. package/dist/server/handlers.cjs +30 -30
  139. package/dist/server/handlers.js +11 -11
  140. package/dist/server/schemas/index.cjs +377 -377
  141. package/dist/server/schemas/index.js +7 -7
  142. package/dist/server/server-adapter/index.cjs +205 -205
  143. package/dist/server/server-adapter/index.js +23 -23
  144. package/dist/server/server-adapter/routes/observability.d.ts +5 -5
  145. package/package.json +6 -6
  146. package/dist/chunk-2UVJD67W.cjs.map +0 -1
  147. package/dist/chunk-3XXKCBEU.js.map +0 -1
  148. package/dist/chunk-BX372Y6T.js.map +0 -1
  149. package/dist/chunk-DTJJFVTS.js.map +0 -1
  150. package/dist/chunk-FQHTXKF6.cjs.map +0 -1
  151. package/dist/chunk-RSIZIEPW.js.map +0 -1
  152. package/dist/chunk-SIPQHHIE.cjs.map +0 -1
  153. package/dist/chunk-TEAYHLYJ.cjs.map +0 -1
  154. package/dist/chunk-ZEQ3ZL2T.cjs.map +0 -1
@@ -1,4 +1,4 @@
1
- import { NEW_ROUTE_DEFS, getObservabilityStore } from './chunk-RSIZIEPW.js';
1
+ import { NEW_ROUTE_DEFS, getObservabilityStore } from './chunk-53YFG5AY.js';
2
2
  import { handleError } from './chunk-P23KBWKB.js';
3
3
  import { wrapSchemaForQueryParams, createRoute, pickParams } from './chunk-NMS2SC2B.js';
4
4
  import { HTTPException } from './chunk-6QWQZI4Q.js';
@@ -39,6 +39,21 @@ var dateRangeSchema = z.object({
39
39
  endExclusive: z.boolean().optional().describe("When true, excludes the end date from results (uses < instead of <=)")
40
40
  }).describe("Date range filter for timestamps");
41
41
  var sortDirectionSchema = z.enum(["ASC", "DESC"]).describe("Sort direction: 'ASC' | 'DESC'");
42
+ var aggregationTypeSchema = z.enum(["sum", "avg", "min", "max", "count", "last"]).describe("Aggregation function");
43
+ var aggregationIntervalSchema = z.enum(["1m", "5m", "15m", "1h", "1d"]).describe("Time bucket interval");
44
+ var comparePeriodSchema = z.enum(["previous_period", "previous_day", "previous_week"]).describe("Comparison period for aggregate queries");
45
+ var groupBySchema = z.array(z.string()).min(1).describe("Fields to group by");
46
+ var percentilesSchema = z.array(z.number().min(0).max(1)).min(1).describe("Percentile values (0-1)");
47
+ var aggregateResponseFields = {
48
+ value: z.number().nullable().describe("Aggregated value"),
49
+ previousValue: z.number().nullable().optional().describe("Value from comparison period"),
50
+ changePercent: z.number().nullable().optional().describe("Percentage change from comparison period")
51
+ };
52
+ var dimensionsField = z.record(z.string(), z.string().nullable()).describe("Dimension values for this group");
53
+ var aggregatedValueField = z.number().describe("Aggregated value");
54
+ var bucketTimestampField = z.date().describe("Bucket timestamp");
55
+ var percentileField = z.number().describe("Percentile value");
56
+ var percentileBucketValueField = z.number().describe("Percentile value at this bucket");
42
57
  var entityTypeField = z.nativeEnum(EntityType).describe(`Entity type (e.g., 'agent' | 'processor' | 'tool' | 'workflow')`);
43
58
  var entityIdField = z.string().describe('ID of the entity (e.g., "weatherAgent", "orderWorkflow")');
44
59
  var entityNameField = z.string().describe("Name of the entity");
@@ -245,7 +260,7 @@ var scoresOrderBySchema = z.object({
245
260
  direction: sortDirectionSchema.default("DESC").describe("Sort direction")
246
261
  }).describe("Order by configuration");
247
262
  z.object({
248
- filters: scoresFilterSchema.optional().describe("Optional filters to apply"),
263
+ filters: scoresFilterSchema.optional(),
249
264
  pagination: paginationArgsSchema.default({ page: 0, perPage: 10 }).describe("Pagination settings"),
250
265
  orderBy: scoresOrderBySchema.default({ field: "timestamp", direction: "DESC" }).describe("Ordering configuration (defaults to timestamp desc)")
251
266
  }).describe("Arguments for listing scores");
@@ -253,6 +268,70 @@ var listScoresResponseSchema = z.object({
253
268
  pagination: paginationInfoSchema,
254
269
  scores: z.array(scoreRecordSchema)
255
270
  });
271
+ var getScoreAggregateArgsSchema = z.object({
272
+ scorerId: scorerIdField,
273
+ scoreSource: scoreSourceField.optional(),
274
+ aggregation: aggregationTypeSchema,
275
+ filters: scoresFilterSchema.optional(),
276
+ comparePeriod: comparePeriodSchema.optional()
277
+ }).describe("Arguments for getting a score aggregate");
278
+ var getScoreAggregateResponseSchema = z.object(aggregateResponseFields);
279
+ var getScoreBreakdownArgsSchema = z.object({
280
+ scorerId: scorerIdField,
281
+ scoreSource: scoreSourceField.optional(),
282
+ groupBy: groupBySchema,
283
+ aggregation: aggregationTypeSchema,
284
+ filters: scoresFilterSchema.optional()
285
+ }).describe("Arguments for getting a score breakdown");
286
+ var getScoreBreakdownResponseSchema = z.object({
287
+ groups: z.array(
288
+ z.object({
289
+ dimensions: dimensionsField,
290
+ value: aggregatedValueField
291
+ })
292
+ )
293
+ });
294
+ var getScoreTimeSeriesArgsSchema = z.object({
295
+ scorerId: scorerIdField,
296
+ scoreSource: scoreSourceField.optional(),
297
+ interval: aggregationIntervalSchema,
298
+ aggregation: aggregationTypeSchema,
299
+ filters: scoresFilterSchema.optional(),
300
+ groupBy: groupBySchema.optional()
301
+ }).describe("Arguments for getting score time series");
302
+ var getScoreTimeSeriesResponseSchema = z.object({
303
+ series: z.array(
304
+ z.object({
305
+ name: z.string().describe("Series name (scorer ID or group key)"),
306
+ points: z.array(
307
+ z.object({
308
+ timestamp: bucketTimestampField,
309
+ value: aggregatedValueField
310
+ })
311
+ )
312
+ })
313
+ )
314
+ });
315
+ var getScorePercentilesArgsSchema = z.object({
316
+ scorerId: scorerIdField,
317
+ scoreSource: scoreSourceField.optional(),
318
+ percentiles: percentilesSchema,
319
+ interval: aggregationIntervalSchema,
320
+ filters: scoresFilterSchema.optional()
321
+ }).describe("Arguments for getting score percentiles");
322
+ var getScorePercentilesResponseSchema = z.object({
323
+ series: z.array(
324
+ z.object({
325
+ percentile: percentileField,
326
+ points: z.array(
327
+ z.object({
328
+ timestamp: bucketTimestampField,
329
+ value: percentileBucketValueField
330
+ })
331
+ )
332
+ })
333
+ )
334
+ });
256
335
  var feedbackSourceField = z.string().describe("Source of feedback (e.g., 'user', 'system', 'manual')");
257
336
  var feedbackTypeField = z.string().describe("Type of feedback (e.g., 'thumbs', 'rating', 'correction')");
258
337
  var feedbackValueField = z.union([z.number(), z.string()]).describe("Feedback value (rating number or correction text)");
@@ -326,11 +405,11 @@ var feedbackFilterObjectSchema = z.object({
326
405
  ...commonFilterFields,
327
406
  // Feedback-specific filters
328
407
  feedbackType: z.union([z.string(), z.array(z.string())]).optional().describe("Filter by feedback type(s)"),
329
- feedbackSource: feedbackSourceField.optional().describe("Filter by feedback source (e.g., user, system, manual)"),
408
+ feedbackSource: feedbackSourceField.optional(),
330
409
  /**
331
410
  * @deprecated Use `feedbackSource` instead.
332
411
  */
333
- source: feedbackSourceField.optional().describe("Filter by feedback source (e.g., user, system, manual)"),
412
+ source: feedbackSourceField.optional(),
334
413
  feedbackUserId: feedbackUserIdField.optional()
335
414
  });
336
415
  var feedbackFilterSchema = z.object(feedbackFilterObjectSchema.shape).describe("Filters for querying feedback");
@@ -348,6 +427,70 @@ var listFeedbackResponseSchema = z.object({
348
427
  pagination: paginationInfoSchema,
349
428
  feedback: z.array(feedbackRecordSchema)
350
429
  });
430
+ var getFeedbackAggregateArgsSchema = z.object({
431
+ feedbackType: feedbackTypeField,
432
+ feedbackSource: feedbackSourceField.optional(),
433
+ aggregation: aggregationTypeSchema,
434
+ filters: feedbackFilterSchema.optional(),
435
+ comparePeriod: comparePeriodSchema.optional()
436
+ }).describe("Arguments for getting a feedback aggregate over numeric values");
437
+ var getFeedbackAggregateResponseSchema = z.object(aggregateResponseFields);
438
+ var getFeedbackBreakdownArgsSchema = z.object({
439
+ feedbackType: feedbackTypeField,
440
+ feedbackSource: feedbackSourceField.optional(),
441
+ groupBy: groupBySchema,
442
+ aggregation: aggregationTypeSchema,
443
+ filters: feedbackFilterSchema.optional()
444
+ }).describe("Arguments for getting a feedback breakdown over numeric values");
445
+ var getFeedbackBreakdownResponseSchema = z.object({
446
+ groups: z.array(
447
+ z.object({
448
+ dimensions: dimensionsField,
449
+ value: aggregatedValueField
450
+ })
451
+ )
452
+ });
453
+ var getFeedbackTimeSeriesArgsSchema = z.object({
454
+ feedbackType: feedbackTypeField,
455
+ feedbackSource: feedbackSourceField.optional(),
456
+ interval: aggregationIntervalSchema,
457
+ aggregation: aggregationTypeSchema,
458
+ filters: feedbackFilterSchema.optional(),
459
+ groupBy: groupBySchema.optional()
460
+ }).describe("Arguments for getting feedback time series over numeric values");
461
+ var getFeedbackTimeSeriesResponseSchema = z.object({
462
+ series: z.array(
463
+ z.object({
464
+ name: z.string().describe("Series name (feedback type or group key)"),
465
+ points: z.array(
466
+ z.object({
467
+ timestamp: bucketTimestampField,
468
+ value: aggregatedValueField
469
+ })
470
+ )
471
+ })
472
+ )
473
+ });
474
+ var getFeedbackPercentilesArgsSchema = z.object({
475
+ feedbackType: feedbackTypeField,
476
+ feedbackSource: feedbackSourceField.optional(),
477
+ percentiles: percentilesSchema,
478
+ interval: aggregationIntervalSchema,
479
+ filters: feedbackFilterSchema.optional()
480
+ }).describe("Arguments for getting feedback percentiles over numeric values");
481
+ var getFeedbackPercentilesResponseSchema = z.object({
482
+ series: z.array(
483
+ z.object({
484
+ percentile: percentileField,
485
+ points: z.array(
486
+ z.object({
487
+ timestamp: bucketTimestampField,
488
+ value: percentileBucketValueField
489
+ })
490
+ )
491
+ })
492
+ )
493
+ });
351
494
  z.enum(["counter", "gauge", "histogram"]);
352
495
  var metricNameField = z.string().describe("Metric name (e.g., mastra_agent_duration_ms)");
353
496
  var metricValueField = z.number().describe("Metric value");
@@ -391,12 +534,10 @@ var createMetricRecordSchema = metricRecordSchema;
391
534
  z.object({
392
535
  metrics: z.array(createMetricRecordSchema)
393
536
  }).describe("Arguments for batch recording metrics");
394
- var aggregationTypeSchema = z.enum(["sum", "avg", "min", "max", "count", "last"]);
395
- var aggregationIntervalSchema = z.enum(["1m", "5m", "15m", "1h", "1d"]);
396
537
  z.object({
397
- type: aggregationTypeSchema.describe("Aggregation function"),
398
- interval: aggregationIntervalSchema.optional().describe("Time bucket interval"),
399
- groupBy: z.array(z.string()).optional().describe("Label keys to group by")
538
+ type: aggregationTypeSchema,
539
+ interval: aggregationIntervalSchema.optional(),
540
+ groupBy: groupBySchema.optional()
400
541
  }).describe("Metrics aggregation configuration");
401
542
  var metricsFilterSchema = z.object({
402
543
  ...commonFilterFields,
@@ -419,7 +560,7 @@ var metricsOrderBySchema = z.object({
419
560
  direction: sortDirectionSchema.default("DESC").describe("Sort direction")
420
561
  }).describe("Order by configuration");
421
562
  z.object({
422
- filters: metricsFilterSchema.optional().describe("Optional filters to apply"),
563
+ filters: metricsFilterSchema.optional(),
423
564
  pagination: paginationArgsSchema.default({ page: 0, perPage: 10 }).describe("Pagination settings"),
424
565
  orderBy: metricsOrderBySchema.default({ field: "timestamp", direction: "DESC" }).describe("Ordering configuration (defaults to timestamp desc)")
425
566
  }).describe("Arguments for listing metrics");
@@ -427,33 +568,30 @@ z.object({
427
568
  pagination: paginationInfoSchema,
428
569
  metrics: z.array(metricRecordSchema)
429
570
  });
430
- var comparePeriodSchema = z.enum(["previous_period", "previous_day", "previous_week"]).describe("Comparison period for aggregate queries");
431
571
  var getMetricAggregateArgsSchema = z.object({
432
572
  name: z.array(z.string()).nonempty().describe("Metric name(s) to aggregate"),
433
- aggregation: aggregationTypeSchema.describe("Aggregation function"),
434
- filters: metricsFilterSchema.optional().describe("Optional filters"),
435
- comparePeriod: comparePeriodSchema.optional().describe("Optional comparison period")
573
+ aggregation: aggregationTypeSchema,
574
+ filters: metricsFilterSchema.optional(),
575
+ comparePeriod: comparePeriodSchema.optional()
436
576
  }).describe("Arguments for getting a metric aggregate");
437
577
  var getMetricAggregateResponseSchema = z.object({
438
- value: z.number().nullable().describe("Aggregated value"),
578
+ ...aggregateResponseFields,
439
579
  estimatedCost: z.number().nullable().optional().describe("Aggregated estimated cost from the same filtered row set"),
440
580
  costUnit: z.string().nullable().optional().describe("Shared cost unit for the aggregated rows, or null when mixed/unknown"),
441
- previousValue: z.number().nullable().optional().describe("Value from comparison period"),
442
581
  previousEstimatedCost: z.number().nullable().optional().describe("Aggregated estimated cost from the comparison period"),
443
- changePercent: z.number().nullable().optional().describe("Percentage change from comparison period"),
444
582
  costChangePercent: z.number().nullable().optional().describe("Percentage change in estimated cost from comparison period")
445
583
  });
446
584
  var getMetricBreakdownArgsSchema = z.object({
447
585
  name: z.array(z.string()).nonempty().describe("Metric name(s) to break down"),
448
- groupBy: z.array(z.string()).min(1).describe("Fields to group by"),
449
- aggregation: aggregationTypeSchema.describe("Aggregation function"),
450
- filters: metricsFilterSchema.optional().describe("Optional filters")
586
+ groupBy: groupBySchema,
587
+ aggregation: aggregationTypeSchema,
588
+ filters: metricsFilterSchema.optional()
451
589
  }).describe("Arguments for getting a metric breakdown");
452
590
  var getMetricBreakdownResponseSchema = z.object({
453
591
  groups: z.array(
454
592
  z.object({
455
- dimensions: z.record(z.string(), z.string().nullable()).describe("Dimension values for this group"),
456
- value: z.number().describe("Aggregated value for this group"),
593
+ dimensions: dimensionsField,
594
+ value: aggregatedValueField,
457
595
  estimatedCost: z.number().nullable().optional().describe("Summed estimated cost for this group"),
458
596
  costUnit: z.string().nullable().optional().describe("Shared cost unit for this group, or null when mixed/unknown")
459
597
  })
@@ -461,10 +599,10 @@ var getMetricBreakdownResponseSchema = z.object({
461
599
  });
462
600
  var getMetricTimeSeriesArgsSchema = z.object({
463
601
  name: z.array(z.string()).nonempty().describe("Metric name(s)"),
464
- interval: aggregationIntervalSchema.describe("Time bucket interval"),
465
- aggregation: aggregationTypeSchema.describe("Aggregation function"),
466
- filters: metricsFilterSchema.optional().describe("Optional filters"),
467
- groupBy: z.array(z.string()).optional().describe("Optional fields to group by")
602
+ interval: aggregationIntervalSchema,
603
+ aggregation: aggregationTypeSchema,
604
+ filters: metricsFilterSchema.optional(),
605
+ groupBy: groupBySchema.optional()
468
606
  }).describe("Arguments for getting metric time series");
469
607
  var getMetricTimeSeriesResponseSchema = z.object({
470
608
  series: z.array(
@@ -473,8 +611,8 @@ var getMetricTimeSeriesResponseSchema = z.object({
473
611
  costUnit: z.string().nullable().optional().describe("Shared cost unit for this series, or null when mixed/unknown"),
474
612
  points: z.array(
475
613
  z.object({
476
- timestamp: z.date().describe("Bucket timestamp"),
477
- value: z.number().describe("Aggregated value"),
614
+ timestamp: bucketTimestampField,
615
+ value: aggregatedValueField,
478
616
  estimatedCost: z.number().nullable().optional().describe("Summed estimated cost in this bucket")
479
617
  })
480
618
  )
@@ -483,18 +621,18 @@ var getMetricTimeSeriesResponseSchema = z.object({
483
621
  });
484
622
  var getMetricPercentilesArgsSchema = z.object({
485
623
  name: z.string().describe("Metric name"),
486
- percentiles: z.array(z.number().min(0).max(1)).describe("Percentile values (0-1)"),
487
- interval: aggregationIntervalSchema.describe("Time bucket interval"),
488
- filters: metricsFilterSchema.optional().describe("Optional filters")
624
+ percentiles: percentilesSchema,
625
+ interval: aggregationIntervalSchema,
626
+ filters: metricsFilterSchema.optional()
489
627
  }).describe("Arguments for getting metric percentiles");
490
628
  var getMetricPercentilesResponseSchema = z.object({
491
629
  series: z.array(
492
630
  z.object({
493
- percentile: z.number().describe("Percentile value"),
631
+ percentile: percentileField,
494
632
  points: z.array(
495
633
  z.object({
496
- timestamp: z.date().describe("Bucket timestamp"),
497
- value: z.number().describe("Percentile value at this bucket")
634
+ timestamp: bucketTimestampField,
635
+ value: percentileBucketValueField
498
636
  })
499
637
  )
500
638
  })
@@ -557,7 +695,7 @@ function createNewRoute(def, config) {
557
695
  handler: (async (params) => {
558
696
  if (!coreFeatures.has("observability:v1.13.2")) {
559
697
  throw new HTTPException(501, {
560
- message: "New observability endpoints require @mastra/core >= 1.13.3, please upgrade."
698
+ message: "New observability endpoints require @mastra/core >= 1.13.2, please upgrade."
561
699
  });
562
700
  }
563
701
  try {
@@ -603,6 +741,42 @@ var CREATE_SCORE = createNewRoute(NEW_ROUTE_DEFS.CREATE_SCORE, {
603
741
  return { success: true };
604
742
  }
605
743
  });
744
+ var GET_SCORE_AGGREGATE = createNewRoute(NEW_ROUTE_DEFS.GET_SCORE_AGGREGATE, {
745
+ bodySchema: getScoreAggregateArgsSchema,
746
+ responseSchema: getScoreAggregateResponseSchema,
747
+ handler: async ({ mastra, ...params }) => {
748
+ const args = pickParams(getScoreAggregateArgsSchema, params);
749
+ const observabilityStore = await getObservabilityStore(mastra);
750
+ return await observabilityStore.getScoreAggregate(args);
751
+ }
752
+ });
753
+ var GET_SCORE_BREAKDOWN = createNewRoute(NEW_ROUTE_DEFS.GET_SCORE_BREAKDOWN, {
754
+ bodySchema: getScoreBreakdownArgsSchema,
755
+ responseSchema: getScoreBreakdownResponseSchema,
756
+ handler: async ({ mastra, ...params }) => {
757
+ const args = pickParams(getScoreBreakdownArgsSchema, params);
758
+ const observabilityStore = await getObservabilityStore(mastra);
759
+ return await observabilityStore.getScoreBreakdown(args);
760
+ }
761
+ });
762
+ var GET_SCORE_TIME_SERIES = createNewRoute(NEW_ROUTE_DEFS.GET_SCORE_TIME_SERIES, {
763
+ bodySchema: getScoreTimeSeriesArgsSchema,
764
+ responseSchema: getScoreTimeSeriesResponseSchema,
765
+ handler: async ({ mastra, ...params }) => {
766
+ const args = pickParams(getScoreTimeSeriesArgsSchema, params);
767
+ const observabilityStore = await getObservabilityStore(mastra);
768
+ return await observabilityStore.getScoreTimeSeries(args);
769
+ }
770
+ });
771
+ var GET_SCORE_PERCENTILES = createNewRoute(NEW_ROUTE_DEFS.GET_SCORE_PERCENTILES, {
772
+ bodySchema: getScorePercentilesArgsSchema,
773
+ responseSchema: getScorePercentilesResponseSchema,
774
+ handler: async ({ mastra, ...params }) => {
775
+ const args = pickParams(getScorePercentilesArgsSchema, params);
776
+ const observabilityStore = await getObservabilityStore(mastra);
777
+ return await observabilityStore.getScorePercentiles(args);
778
+ }
779
+ });
606
780
  var LIST_FEEDBACK = createNewRoute(NEW_ROUTE_DEFS.LIST_FEEDBACK, {
607
781
  queryParamSchema: wrapSchemaForQueryParams(
608
782
  feedbackFilterSchema.extend(paginationArgsSchema.shape).extend(feedbackOrderBySchema.shape).partial()
@@ -625,6 +799,42 @@ var CREATE_FEEDBACK = createNewRoute(NEW_ROUTE_DEFS.CREATE_FEEDBACK, {
625
799
  return { success: true };
626
800
  }
627
801
  });
802
+ var GET_FEEDBACK_AGGREGATE = createNewRoute(NEW_ROUTE_DEFS.GET_FEEDBACK_AGGREGATE, {
803
+ bodySchema: getFeedbackAggregateArgsSchema,
804
+ responseSchema: getFeedbackAggregateResponseSchema,
805
+ handler: async ({ mastra, ...params }) => {
806
+ const args = pickParams(getFeedbackAggregateArgsSchema, params);
807
+ const observabilityStore = await getObservabilityStore(mastra);
808
+ return await observabilityStore.getFeedbackAggregate(args);
809
+ }
810
+ });
811
+ var GET_FEEDBACK_BREAKDOWN = createNewRoute(NEW_ROUTE_DEFS.GET_FEEDBACK_BREAKDOWN, {
812
+ bodySchema: getFeedbackBreakdownArgsSchema,
813
+ responseSchema: getFeedbackBreakdownResponseSchema,
814
+ handler: async ({ mastra, ...params }) => {
815
+ const args = pickParams(getFeedbackBreakdownArgsSchema, params);
816
+ const observabilityStore = await getObservabilityStore(mastra);
817
+ return await observabilityStore.getFeedbackBreakdown(args);
818
+ }
819
+ });
820
+ var GET_FEEDBACK_TIME_SERIES = createNewRoute(NEW_ROUTE_DEFS.GET_FEEDBACK_TIME_SERIES, {
821
+ bodySchema: getFeedbackTimeSeriesArgsSchema,
822
+ responseSchema: getFeedbackTimeSeriesResponseSchema,
823
+ handler: async ({ mastra, ...params }) => {
824
+ const args = pickParams(getFeedbackTimeSeriesArgsSchema, params);
825
+ const observabilityStore = await getObservabilityStore(mastra);
826
+ return await observabilityStore.getFeedbackTimeSeries(args);
827
+ }
828
+ });
829
+ var GET_FEEDBACK_PERCENTILES = createNewRoute(NEW_ROUTE_DEFS.GET_FEEDBACK_PERCENTILES, {
830
+ bodySchema: getFeedbackPercentilesArgsSchema,
831
+ responseSchema: getFeedbackPercentilesResponseSchema,
832
+ handler: async ({ mastra, ...params }) => {
833
+ const args = pickParams(getFeedbackPercentilesArgsSchema, params);
834
+ const observabilityStore = await getObservabilityStore(mastra);
835
+ return await observabilityStore.getFeedbackPercentiles(args);
836
+ }
837
+ });
628
838
  var GET_METRIC_AGGREGATE = createNewRoute(NEW_ROUTE_DEFS.GET_METRIC_AGGREGATE, {
629
839
  bodySchema: getMetricAggregateArgsSchema,
630
840
  responseSchema: getMetricAggregateResponseSchema,
@@ -738,8 +948,16 @@ var NEW_ROUTES = {
738
948
  LIST_LOGS,
739
949
  LIST_SCORES,
740
950
  CREATE_SCORE,
951
+ GET_SCORE_AGGREGATE,
952
+ GET_SCORE_BREAKDOWN,
953
+ GET_SCORE_TIME_SERIES,
954
+ GET_SCORE_PERCENTILES,
741
955
  LIST_FEEDBACK,
742
956
  CREATE_FEEDBACK,
957
+ GET_FEEDBACK_AGGREGATE,
958
+ GET_FEEDBACK_BREAKDOWN,
959
+ GET_FEEDBACK_TIME_SERIES,
960
+ GET_FEEDBACK_PERCENTILES,
743
961
  GET_METRIC_AGGREGATE,
744
962
  GET_METRIC_BREAKDOWN,
745
963
  GET_METRIC_TIME_SERIES,
@@ -754,6 +972,6 @@ var NEW_ROUTES = {
754
972
  GET_TAGS
755
973
  };
756
974
 
757
- export { CREATE_FEEDBACK, CREATE_SCORE, GET_ENTITY_NAMES, GET_ENTITY_TYPES, GET_ENVIRONMENTS, GET_METRIC_AGGREGATE, GET_METRIC_BREAKDOWN, GET_METRIC_LABEL_KEYS, GET_METRIC_LABEL_VALUES, GET_METRIC_NAMES, GET_METRIC_PERCENTILES, GET_METRIC_TIME_SERIES, GET_SERVICE_NAMES, GET_TAGS, LIST_FEEDBACK, LIST_LOGS, LIST_SCORES, NEW_ROUTES };
758
- //# sourceMappingURL=chunk-BX372Y6T.js.map
759
- //# sourceMappingURL=chunk-BX372Y6T.js.map
975
+ export { CREATE_FEEDBACK, CREATE_SCORE, GET_ENTITY_NAMES, GET_ENTITY_TYPES, GET_ENVIRONMENTS, GET_FEEDBACK_AGGREGATE, GET_FEEDBACK_BREAKDOWN, GET_FEEDBACK_PERCENTILES, GET_FEEDBACK_TIME_SERIES, GET_METRIC_AGGREGATE, GET_METRIC_BREAKDOWN, GET_METRIC_LABEL_KEYS, GET_METRIC_LABEL_VALUES, GET_METRIC_NAMES, GET_METRIC_PERCENTILES, GET_METRIC_TIME_SERIES, GET_SCORE_AGGREGATE, GET_SCORE_BREAKDOWN, GET_SCORE_PERCENTILES, GET_SCORE_TIME_SERIES, GET_SERVICE_NAMES, GET_TAGS, LIST_FEEDBACK, LIST_LOGS, LIST_SCORES, NEW_ROUTES };
976
+ //# sourceMappingURL=chunk-YFQ5JIUD.js.map
977
+ //# sourceMappingURL=chunk-YFQ5JIUD.js.map