@mastra/duckdb 1.3.1-alpha.0 → 1.3.2-alpha.0

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.
package/CHANGELOG.md CHANGED
@@ -1,5 +1,23 @@
1
1
  # @mastra/duckdb
2
2
 
3
+ ## 1.3.2-alpha.0
4
+
5
+ ### Patch Changes
6
+
7
+ - Expose `GET /observability/traces/light` and storage support for fetching paginated trace-list rows without span payload data. ([#16608](https://github.com/mastra-ai/mastra/pull/16608))
8
+
9
+ - Updated dependencies [[`090a647`](https://github.com/mastra-ai/mastra/commit/090a647ba5a66d36f203f9f49457e03a1ff4e6fb), [`090a647`](https://github.com/mastra-ai/mastra/commit/090a647ba5a66d36f203f9f49457e03a1ff4e6fb), [`f84447d`](https://github.com/mastra-ai/mastra/commit/f84447d6c80f3471836a9b300d246b331fb47e0d), [`a1a5b3e`](https://github.com/mastra-ai/mastra/commit/a1a5b3e42ab2ca5161ea21db59ebf28442680fa7), [`af84f57`](https://github.com/mastra-ai/mastra/commit/af84f571ed762e92e8e61c5f9a72363520914274), [`8b3c6f9`](https://github.com/mastra-ai/mastra/commit/8b3c6f90f7879833ba7d1bc70937e1d8f69d0804)]:
10
+ - @mastra/core@1.34.0-alpha.3
11
+
12
+ ## 1.3.1
13
+
14
+ ### Patch Changes
15
+
16
+ - Improved DuckDB observability initialization by batching schema setup statements on one connection while preserving migration order. ([#16239](https://github.com/mastra-ai/mastra/pull/16239))
17
+
18
+ - Updated dependencies [[`9f17410`](https://github.com/mastra-ai/mastra/commit/9f1741080def23d42ee50b39887a385ae316a3c6), [`7ad5585`](https://github.com/mastra-ai/mastra/commit/7ad55856406f1de398dc713f6a9eaa78b2784bb6), [`ac47842`](https://github.com/mastra-ai/mastra/commit/ac478427aa7a5f5fdaed633a911218689b438c60), [`cc189cc`](https://github.com/mastra-ai/mastra/commit/cc189cc0128eb7af233476b5e421ec6888bffde7), [`d1fdbd0`](https://github.com/mastra-ai/mastra/commit/d1fdbd012add5623cb7e6b7f882b605ab358bbb4), [`210ea7a`](https://github.com/mastra-ai/mastra/commit/210ea7af559791b73a44fc9c12179908aaa3183f), [`7c275a8`](https://github.com/mastra-ai/mastra/commit/7c275a810595e1a6c41ccc39720531ab65734700), [`bae019e`](https://github.com/mastra-ai/mastra/commit/bae019ecb6694da96909f7ec7b9eb3a0a33aa887), [`890b24c`](https://github.com/mastra-ai/mastra/commit/890b24cc7d32ed6aa4dfe253e54dc6bf4099f690), [`f984b4d`](https://github.com/mastra-ai/mastra/commit/f984b4d6c60bf2ae2a9b156f0e8c35a66fe96c91), [`6742347`](https://github.com/mastra-ai/mastra/commit/6742347d71955d7639adc9ddf6ff8282de7ee3ba), [`b59316f`](https://github.com/mastra-ai/mastra/commit/b59316ffa0f7688165b0f9c81ccdf85da461e5b2), [`0f48ebf`](https://github.com/mastra-ai/mastra/commit/0f48ebfc7ac7897b2092a189f45751924cf56d1c), [`37c0dc5`](https://github.com/mastra-ai/mastra/commit/37c0dc5697d343db98628bf867bf71ce6deec6d7), [`087e413`](https://github.com/mastra-ai/mastra/commit/087e4133e5d6efa36619e9556c16750e4179c047), [`83218c8`](https://github.com/mastra-ai/mastra/commit/83218c88b37773c9424fbe733b37be556e55e94d), [`ef6b584`](https://github.com/mastra-ai/mastra/commit/ef6b5847ac33c0a7e80af3a86e8801e2933dd3ee), [`c6eb39e`](https://github.com/mastra-ai/mastra/commit/c6eb39ea6dca381c6563cb240237fbe608e02f93), [`7b0ad1f`](https://github.com/mastra-ai/mastra/commit/7b0ad1f5c53dc118c6da12ae82ae2587037dc2b8), [`d91ebe2`](https://github.com/mastra-ai/mastra/commit/d91ebe28ee065d8f2ed6df741c3c07f58d359529), [`62666c3`](https://github.com/mastra-ai/mastra/commit/62666c367eaeac3941ead454b1d38810cc855721), [`33f5061`](https://github.com/mastra-ai/mastra/commit/33f5061cd1c0335020c3faae61ce96de822854fa), [`4af2160`](https://github.com/mastra-ai/mastra/commit/4af2160322f4718cac421930cce85641e9512389), [`087e413`](https://github.com/mastra-ai/mastra/commit/087e4133e5d6efa36619e9556c16750e4179c047), [`265ec9f`](https://github.com/mastra-ai/mastra/commit/265ec9f887b5c81255c873a76ff7796f16e4f99b), [`ce01024`](https://github.com/mastra-ai/mastra/commit/ce010242eee9bdfc09e4c26725b9d37998679a8d), [`6ce80bf`](https://github.com/mastra-ai/mastra/commit/6ce80bf4872a891e0bddf8b80561a80584efb14b), [`f984b4d`](https://github.com/mastra-ai/mastra/commit/f984b4d6c60bf2ae2a9b156f0e8c35a66fe96c91), [`136c959`](https://github.com/mastra-ai/mastra/commit/136c9592fb0eeb0cd212f28629d8a29b7557a2fc), [`9268531`](https://github.com/mastra-ai/mastra/commit/9268531e7ec4be98beeba3b3ae8be0a7ea380662), [`13ead79`](https://github.com/mastra-ai/mastra/commit/13ead79149486b88144db7e11e6ff551caef5be1), [`dccd8f1`](https://github.com/mastra-ai/mastra/commit/dccd8f1f8b8f1ad203b77556207e5529567c616d), [`4df7cc7`](https://github.com/mastra-ai/mastra/commit/4df7cc79342fd065fe7fdeef93c094db14b12bcd), [`f180e49`](https://github.com/mastra-ai/mastra/commit/f180e4990e71b04c9a475b523584071712f0048f), [`9260e01`](https://github.com/mastra-ai/mastra/commit/9260e015276fb1b500f7878ee452b47476bf1583), [`2f6c54e`](https://github.com/mastra-ai/mastra/commit/2f6c54e17c041cac1def54baaa6b771647836414), [`aca3121`](https://github.com/mastra-ai/mastra/commit/aca31211233dac25459f140ea4fcfb3a5af64c18), [`e06a159`](https://github.com/mastra-ai/mastra/commit/e06a1598ca07a6c3778aefc2a2d288363c6294ff), [`4dd900d`](https://github.com/mastra-ai/mastra/commit/4dd900d75dfe9be89f8c15188b368a8622aa1e18), [`b560d6f`](https://github.com/mastra-ai/mastra/commit/b560d6f88b9b904b15c10f75c949eb145bc27684), [`99869ec`](https://github.com/mastra-ai/mastra/commit/99869ecb1f2aa6dfcc44fa4e843e5ee0344efa64), [`900d086`](https://github.com/mastra-ai/mastra/commit/900d086bb737b9cf2fcf68f11b0389b801a2738c), [`4c0e286`](https://github.com/mastra-ai/mastra/commit/4c0e28637c9cfb4f416549b55e97ebfa13319dfc), [`55f1e2d`](https://github.com/mastra-ai/mastra/commit/55f1e2d65425b95a49ae788053b266f256e38c96), [`4ff5bdf`](https://github.com/mastra-ai/mastra/commit/4ff5bdfe170cba6dfb5260c6af0f4ba668430772), [`9cdf38e`](https://github.com/mastra-ai/mastra/commit/9cdf38e58506e1109c8b38f97cd7770978a4218e), [`087e413`](https://github.com/mastra-ai/mastra/commit/087e4133e5d6efa36619e9556c16750e4179c047), [`db34bc6`](https://github.com/mastra-ai/mastra/commit/db34bc6fb36cf125bda0c46be4d3fdc774b70cc4), [`990851e`](https://github.com/mastra-ai/mastra/commit/990851edcb0e30be5c2c18b6532f1a876cc2d335), [`bbcd93c`](https://github.com/mastra-ai/mastra/commit/bbcd93cf7d8aa1007d6d84bfd033b8015c912087), [`8373ff4`](https://github.com/mastra-ai/mastra/commit/8373ff46745d77af79f183c4470f80fa2727a6b2), [`d48a705`](https://github.com/mastra-ai/mastra/commit/d48a705ff3dfbdc7a996e07ecd8293b5effd9a2a), [`308bd07`](https://github.com/mastra-ai/mastra/commit/308bd074f35cef0c75d82fc1eb19382fe04ecf6f), [`6068a6c`](https://github.com/mastra-ai/mastra/commit/6068a6c42950fad3ebfc92346417896ba60803d2), [`36b3bbf`](https://github.com/mastra-ai/mastra/commit/36b3bbf5a8d59f7e23d47e29340e76c681b4929c), [`d86f031`](https://github.com/mastra-ai/mastra/commit/d86f031eb6b0b2570145afafea664e59bf688962), [`b275631`](https://github.com/mastra-ai/mastra/commit/b275631dc10541a482b2e2d4a3e3cfa843bd5fa1), [`00106be`](https://github.com/mastra-ai/mastra/commit/00106bede59b81e5b0e9cd6aad8d3b5dbc336387), [`bd36d8e`](https://github.com/mastra-ai/mastra/commit/bd36d8eb6de8c9a0310352649dbd4b06703c2299), [`11c1528`](https://github.com/mastra-ai/mastra/commit/11c152848c5d0ef227184853b5040f5b41ee7b1e), [`4999667`](https://github.com/mastra-ai/mastra/commit/49996678b68356cad7f088430009690406c50fbd), [`e2a079c`](https://github.com/mastra-ai/mastra/commit/e2a079cc3755b1895f7bd5dc36e9be81b11c7c22), [`8ac9141`](https://github.com/mastra-ai/mastra/commit/8ac9141439caa8fdd674944c4d84f29b3c730296), [`25184ff`](https://github.com/mastra-ai/mastra/commit/25184ffaf1293ec95119426eb1a1f8d38831b96c), [`534a456`](https://github.com/mastra-ai/mastra/commit/534a456a25e4df1e5407e7e632f4cb3b1fa14f9d), [`105e454`](https://github.com/mastra-ai/mastra/commit/105e454c95af06a7c741c15969d8f9b0f02463a7), [`aebde9c`](https://github.com/mastra-ai/mastra/commit/aebde9cfacf56592c6b6350cae721740fe090b8a), [`36bae07`](https://github.com/mastra-ai/mastra/commit/36bae07c0e70b1b3006f2fd20830e8883dcbd066), [`5688881`](https://github.com/mastra-ai/mastra/commit/5688881669c7ed157f31ac77f6fc5f8d95ceea32)]:
19
+ - @mastra/core@1.33.0
20
+
3
21
  ## 1.3.1-alpha.0
4
22
 
5
23
  ### Patch Changes
@@ -3,7 +3,7 @@ name: mastra-duckdb
3
3
  description: Documentation for @mastra/duckdb. Use when working with @mastra/duckdb APIs, configuration, or implementation.
4
4
  metadata:
5
5
  package: "@mastra/duckdb"
6
- version: "1.3.1-alpha.0"
6
+ version: "1.3.2-alpha.0"
7
7
  ---
8
8
 
9
9
  ## When to use
@@ -1,5 +1,5 @@
1
1
  {
2
- "version": "1.3.1-alpha.0",
2
+ "version": "1.3.2-alpha.0",
3
3
  "package": "@mastra/duckdb",
4
4
  "exports": {
5
5
  "DuckDBConnection": {
@@ -49,7 +49,7 @@ import { Mastra } from '@mastra/core'
49
49
  import { MastraCompositeStore } from '@mastra/core/storage'
50
50
  import { LibSQLStore } from '@mastra/libsql'
51
51
  import { DuckDBStore } from '@mastra/duckdb'
52
- import { Observability, DefaultExporter } from '@mastra/observability'
52
+ import { Observability, MastraStorageExporter } from '@mastra/observability'
53
53
 
54
54
  export const mastra = new Mastra({
55
55
  storage: new MastraCompositeStore({
@@ -66,7 +66,7 @@ export const mastra = new Mastra({
66
66
  configs: {
67
67
  default: {
68
68
  serviceName: 'mastra',
69
- exporters: [new DefaultExporter()],
69
+ exporters: [new MastraStorageExporter()],
70
70
  },
71
71
  },
72
72
  }),
@@ -139,7 +139,7 @@ await duckdb.observability.init()
139
139
 
140
140
  ## Observability strategy
141
141
 
142
- DuckDB supports the `event-sourced` strategy used by `DefaultExporter`, which buffers spans in memory and writes completed events in batches. This is appropriate for development-scale traffic. For high-volume production workloads, see [`DefaultExporter` storage provider support](https://mastra.ai/docs/observability/tracing/exporters/default).
142
+ DuckDB supports the `event-sourced` strategy used by `MastraStorageExporter`, which buffers spans in memory and writes completed events in batches. This is appropriate for development-scale traffic. For high-volume production workloads, see [`MastraStorageExporter` storage provider support](https://mastra.ai/docs/observability/tracing/exporters/mastra-storage).
143
143
 
144
144
  ## Related
145
145
 
package/dist/index.cjs CHANGED
@@ -583,7 +583,7 @@ var ObservabilityStorageDuckDB = class extends storage.ObservabilityStorage {
583
583
  return null;
584
584
  }
585
585
  if (!this.loadPromise) {
586
- this.loadPromise = import('./observability-ZLFGMOSM.cjs').then(({ ObservabilityStorageDuckDB: ObservabilityStorageDuckDB2 }) => {
586
+ this.loadPromise = import('./observability-J6N3H7W7.cjs').then(({ ObservabilityStorageDuckDB: ObservabilityStorageDuckDB2 }) => {
587
587
  const delegate = new ObservabilityStorageDuckDB2({ db: this.db });
588
588
  this.delegate = delegate;
589
589
  return delegate;
package/dist/index.js CHANGED
@@ -582,7 +582,7 @@ var ObservabilityStorageDuckDB = class extends ObservabilityStorage {
582
582
  return null;
583
583
  }
584
584
  if (!this.loadPromise) {
585
- this.loadPromise = import('./observability-MKVTGAKX.js').then(({ ObservabilityStorageDuckDB: ObservabilityStorageDuckDB2 }) => {
585
+ this.loadPromise = import('./observability-TS5QIHIC.js').then(({ ObservabilityStorageDuckDB: ObservabilityStorageDuckDB2 }) => {
586
586
  const delegate = new ObservabilityStorageDuckDB2({ db: this.db });
587
587
  this.delegate = delegate;
588
588
  return delegate;
@@ -2694,7 +2694,7 @@ async function getTraceLight(db, args) {
2694
2694
  spans: rows.map((row) => rowToLightSpanRecord(row))
2695
2695
  };
2696
2696
  }
2697
- async function listTraces(db, args) {
2697
+ async function listTraceRows(db, args, reconstructSelect, mapRow, toSpans) {
2698
2698
  const filters = args.filters ?? {};
2699
2699
  const page = Number(args.pagination?.page ?? 0);
2700
2700
  const perPage = Number(args.pagination?.perPage ?? 10);
@@ -2729,16 +2729,16 @@ async function listTraces(db, args) {
2729
2729
  ${prefilterOrderBy}
2730
2730
  LIMIT ? OFFSET ?
2731
2731
  )
2732
- ${SPAN_RECONSTRUCT_SELECT}
2732
+ ${reconstructSelect}
2733
2733
  WHERE (traceId, spanId) IN (SELECT traceId, spanId FROM page_roots)
2734
2734
  GROUP BY traceId, spanId
2735
2735
  ${buildOrderByClause(orderBy)}
2736
2736
  `;
2737
2737
  const rows2 = await db.query(pageSql, [...prefilterParams, perPage, offset]);
2738
- const spans2 = rows2.map((row) => rowToSpanRecord(row));
2738
+ const spans2 = rows2.map((row) => mapRow(row));
2739
2739
  return {
2740
2740
  pagination: { total: total2, page, perPage, hasMore: (page + 1) * perPage < total2 },
2741
- spans: storage.toTraceSpans(spans2)
2741
+ spans: toSpans(spans2)
2742
2742
  };
2743
2743
  }
2744
2744
  const { clause: postAggClause, params: postAggParams } = buildWhereClause(postAgg);
@@ -2754,7 +2754,7 @@ async function listTraces(db, args) {
2754
2754
  ${prefilterWhere}
2755
2755
  ),
2756
2756
  root_spans AS (
2757
- ${SPAN_RECONSTRUCT_SELECT}
2757
+ ${reconstructSelect}
2758
2758
  WHERE (traceId, spanId) IN (SELECT traceId, spanId FROM candidate_roots)
2759
2759
  GROUP BY traceId, spanId
2760
2760
  )
@@ -2772,12 +2772,30 @@ async function listTraces(db, args) {
2772
2772
  SELECT * FROM root_spans ${postAggWhere} ${orderByClause} ${paginationClause}
2773
2773
  `;
2774
2774
  const rows = await db.query(dataSql, [...prefilterParams, ...postAggParams, ...paginationParams]);
2775
- const spans = rows.map((row) => rowToSpanRecord(row));
2775
+ const spans = rows.map((row) => mapRow(row));
2776
2776
  return {
2777
2777
  pagination: { total, page, perPage, hasMore: (page + 1) * perPage < total },
2778
- spans: storage.toTraceSpans(spans)
2778
+ spans: toSpans(spans)
2779
2779
  };
2780
2780
  }
2781
+ async function listTraces(db, args) {
2782
+ return listTraceRows(
2783
+ db,
2784
+ args,
2785
+ SPAN_RECONSTRUCT_SELECT,
2786
+ rowToSpanRecord,
2787
+ (spans) => storage.toTraceSpans(spans)
2788
+ );
2789
+ }
2790
+ async function listTracesLight(db, args) {
2791
+ return listTraceRows(
2792
+ db,
2793
+ args,
2794
+ SPAN_RECONSTRUCT_SELECT_LIGHT,
2795
+ rowToLightSpanRecord,
2796
+ (spans) => spans
2797
+ );
2798
+ }
2781
2799
  var BRANCH_SPAN_TYPE_PLACEHOLDERS = storage.BRANCH_SPAN_TYPES.map(() => "?").join(", ");
2782
2800
  async function getSpans(db, args) {
2783
2801
  if (args.spanIds.length === 0) {
@@ -3016,6 +3034,9 @@ var ObservabilityStorageDuckDB = class extends storage.ObservabilityStorage {
3016
3034
  async listTraces(args) {
3017
3035
  return listTraces(this.db, args);
3018
3036
  }
3037
+ async listTracesLight(args) {
3038
+ return listTracesLight(this.db, args);
3039
+ }
3019
3040
  async listBranches(args) {
3020
3041
  return listBranches(this.db, args);
3021
3042
  }
@@ -3121,5 +3142,5 @@ var ObservabilityStorageDuckDB = class extends storage.ObservabilityStorage {
3121
3142
  };
3122
3143
 
3123
3144
  exports.ObservabilityStorageDuckDB = ObservabilityStorageDuckDB;
3124
- //# sourceMappingURL=observability-ZLFGMOSM.cjs.map
3125
- //# sourceMappingURL=observability-ZLFGMOSM.cjs.map
3145
+ //# sourceMappingURL=observability-J6N3H7W7.cjs.map
3146
+ //# sourceMappingURL=observability-J6N3H7W7.cjs.map