@mastra/pg 1.0.0-beta.8 → 1.0.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.
Files changed (50) hide show
  1. package/CHANGELOG.md +1638 -0
  2. package/dist/docs/README.md +36 -0
  3. package/dist/docs/SKILL.md +37 -0
  4. package/dist/docs/SOURCE_MAP.json +6 -0
  5. package/dist/docs/memory/01-storage.md +233 -0
  6. package/dist/docs/memory/02-working-memory.md +390 -0
  7. package/dist/docs/memory/03-semantic-recall.md +233 -0
  8. package/dist/docs/memory/04-reference.md +133 -0
  9. package/dist/docs/processors/01-reference.md +297 -0
  10. package/dist/docs/rag/01-overview.md +74 -0
  11. package/dist/docs/rag/02-vector-databases.md +643 -0
  12. package/dist/docs/rag/03-retrieval.md +548 -0
  13. package/dist/docs/rag/04-reference.md +369 -0
  14. package/dist/docs/storage/01-reference.md +828 -0
  15. package/dist/docs/tools/01-reference.md +440 -0
  16. package/dist/docs/vectors/01-reference.md +307 -0
  17. package/dist/index.cjs +3253 -2225
  18. package/dist/index.cjs.map +1 -1
  19. package/dist/index.d.ts +1 -1
  20. package/dist/index.d.ts.map +1 -1
  21. package/dist/index.js +3250 -2227
  22. package/dist/index.js.map +1 -1
  23. package/dist/shared/config.d.ts +102 -32
  24. package/dist/shared/config.d.ts.map +1 -1
  25. package/dist/storage/client.d.ts +91 -0
  26. package/dist/storage/client.d.ts.map +1 -0
  27. package/dist/storage/db/index.d.ts +216 -0
  28. package/dist/storage/db/index.d.ts.map +1 -0
  29. package/dist/storage/domains/agents/index.d.ts +22 -8
  30. package/dist/storage/domains/agents/index.d.ts.map +1 -1
  31. package/dist/storage/domains/memory/index.d.ts +32 -12
  32. package/dist/storage/domains/memory/index.d.ts.map +1 -1
  33. package/dist/storage/domains/observability/index.d.ts +52 -36
  34. package/dist/storage/domains/observability/index.d.ts.map +1 -1
  35. package/dist/storage/domains/scores/index.d.ts +25 -28
  36. package/dist/storage/domains/scores/index.d.ts.map +1 -1
  37. package/dist/storage/domains/utils.d.ts +1 -5
  38. package/dist/storage/domains/utils.d.ts.map +1 -1
  39. package/dist/storage/domains/workflows/index.d.ts +26 -12
  40. package/dist/storage/domains/workflows/index.d.ts.map +1 -1
  41. package/dist/storage/index.d.ts +52 -195
  42. package/dist/storage/index.d.ts.map +1 -1
  43. package/dist/storage/performance-indexes/performance-test.d.ts +3 -1
  44. package/dist/storage/performance-indexes/performance-test.d.ts.map +1 -1
  45. package/dist/storage/test-utils.d.ts.map +1 -1
  46. package/dist/vector/index.d.ts.map +1 -1
  47. package/dist/vector/sql-builder.d.ts.map +1 -1
  48. package/package.json +11 -11
  49. package/dist/storage/domains/operations/index.d.ts +0 -119
  50. package/dist/storage/domains/operations/index.d.ts.map +0 -1
package/CHANGELOG.md CHANGED
@@ -1,5 +1,1643 @@
1
1
  # @mastra/pg
2
2
 
3
+ ## 1.0.0
4
+
5
+ ### Major Changes
6
+
7
+ - Moving scorers under the eval domain, api method consistency, prebuilt evals, scorers require ids. ([#9589](https://github.com/mastra-ai/mastra/pull/9589))
8
+
9
+ - Every Mastra primitive (agent, MCPServer, workflow, tool, processor, scorer, and vector) now has a get, list, and add method associated with it. Each primitive also now requires an id to be set. ([#9675](https://github.com/mastra-ai/mastra/pull/9675))
10
+
11
+ Primitives that are added to other primitives are also automatically added to the Mastra instance
12
+
13
+ - Update handlers to use `listWorkflowRuns` instead of `getWorkflowRuns`. Fix type names from `StoragelistThreadsByResourceIdInput/Output` to `StorageListThreadsByResourceIdInput/Output`. ([#9507](https://github.com/mastra-ai/mastra/pull/9507))
14
+
15
+ - Remove `getMessagesPaginated()` and add `perPage: false` support ([#9670](https://github.com/mastra-ai/mastra/pull/9670))
16
+
17
+ Removes deprecated `getMessagesPaginated()` method. The `listMessages()` API and score handlers now support `perPage: false` to fetch all records without pagination limits.
18
+
19
+ **Storage changes:**
20
+ - `StoragePagination.perPage` type changed from `number` to `number | false`
21
+ - All storage implementations support `perPage: false`:
22
+ - Memory: `listMessages()`
23
+ - Scores: `listScoresBySpan()`, `listScoresByRunId()`, `listScoresByExecutionId()`
24
+ - HTTP query parser accepts `"false"` string (e.g., `?perPage=false`)
25
+
26
+ **Memory changes:**
27
+ - `memory.query()` parameter type changed from `StorageGetMessagesArg` to `StorageListMessagesInput`
28
+ - Uses flat parameters (`page`, `perPage`, `include`, `filter`, `vectorSearchString`) instead of `selectBy` object
29
+
30
+ **Stricter validation:**
31
+ - `listMessages()` requires non-empty, non-whitespace `threadId` (throws error instead of returning empty results)
32
+
33
+ **Migration:**
34
+
35
+ ```typescript
36
+ // Storage/Memory: Replace getMessagesPaginated with listMessages
37
+ - storage.getMessagesPaginated({ threadId, selectBy: { pagination: { page: 0, perPage: 20 } } })
38
+ + storage.listMessages({ threadId, page: 0, perPage: 20 })
39
+ + storage.listMessages({ threadId, page: 0, perPage: false }) // Fetch all
40
+
41
+ // Memory: Replace selectBy with flat parameters
42
+ - memory.query({ threadId, selectBy: { last: 20, include: [...] } })
43
+ + memory.query({ threadId, perPage: 20, include: [...] })
44
+
45
+ // Client SDK
46
+ - thread.getMessagesPaginated({ selectBy: { pagination: { page: 0 } } })
47
+ + thread.listMessages({ page: 0, perPage: 20 })
48
+ ```
49
+
50
+ - **Removed `storage.getMessages()`** ([#9695](https://github.com/mastra-ai/mastra/pull/9695))
51
+
52
+ The `getMessages()` method has been removed from all storage implementations. Use `listMessages()` instead, which provides pagination support.
53
+
54
+ **Migration:**
55
+
56
+ ```typescript
57
+ // Before
58
+ const messages = await storage.getMessages({ threadId: 'thread-1' });
59
+
60
+ // After
61
+ const result = await storage.listMessages({
62
+ threadId: 'thread-1',
63
+ page: 0,
64
+ perPage: 50,
65
+ });
66
+ const messages = result.messages; // Access messages array
67
+ console.log(result.total); // Total count
68
+ console.log(result.hasMore); // Whether more pages exist
69
+ ```
70
+
71
+ **Message ordering default**
72
+
73
+ `listMessages()` defaults to ASC (oldest first) ordering by `createdAt`, matching the previous `getMessages()` behavior.
74
+
75
+ **To use DESC ordering (newest first):**
76
+
77
+ ```typescript
78
+ const result = await storage.listMessages({
79
+ threadId: 'thread-1',
80
+ orderBy: { field: 'createdAt', direction: 'DESC' },
81
+ });
82
+ ```
83
+
84
+ **Renamed `client.getThreadMessages()` → `client.listThreadMessages()`**
85
+
86
+ **Migration:**
87
+
88
+ ```typescript
89
+ // Before
90
+ const response = await client.getThreadMessages(threadId, { agentId });
91
+
92
+ // After
93
+ const response = await client.listThreadMessages(threadId, { agentId });
94
+ ```
95
+
96
+ The response format remains the same.
97
+
98
+ **Removed `StorageGetMessagesArg` type**
99
+
100
+ Use `StorageListMessagesInput` instead:
101
+
102
+ ```typescript
103
+ // Before
104
+ import type { StorageGetMessagesArg } from '@mastra/core';
105
+
106
+ // After
107
+ import type { StorageListMessagesInput } from '@mastra/core';
108
+ ```
109
+
110
+ - Bump minimum required Node.js version to 22.13.0 ([#9706](https://github.com/mastra-ai/mastra/pull/9706))
111
+
112
+ - Add new list methods to storage API: `listMessages`, `listMessagesById`, `listThreadsByResourceId`, and `listWorkflowRuns`. Most methods are currently wrappers around existing methods. Full implementations will be added when migrating away from legacy methods. ([#9489](https://github.com/mastra-ai/mastra/pull/9489))
113
+
114
+ - Rename RuntimeContext to RequestContext ([#9511](https://github.com/mastra-ai/mastra/pull/9511))
115
+
116
+ - Implement listMessages API for replacing previous methods ([#9531](https://github.com/mastra-ai/mastra/pull/9531))
117
+
118
+ - Remove `getThreadsByResourceId` and `getThreadsByResourceIdPaginated` methods from storage interfaces in favor of `listThreadsByResourceId`. The new method uses `offset`/`limit` pagination and a nested `orderBy` object structure (`{ field, direction }`). ([#9536](https://github.com/mastra-ai/mastra/pull/9536))
119
+
120
+ - Remove `getMessagesById` method from storage interfaces in favor of `listMessagesById`. The new method only returns V2-format messages and removes the format parameter, simplifying the API surface. Users should migrate from `getMessagesById({ messageIds, format })` to `listMessagesById({ messageIds })`. ([#9534](https://github.com/mastra-ai/mastra/pull/9534))
121
+
122
+ - Renamed a bunch of observability/tracing-related things to drop the AI prefix. ([#9744](https://github.com/mastra-ai/mastra/pull/9744))
123
+
124
+ - Pagination APIs now use `page`/`perPage` instead of `offset`/`limit` ([#9592](https://github.com/mastra-ai/mastra/pull/9592))
125
+
126
+ All storage and memory pagination APIs have been updated to use `page` (0-indexed) and `perPage` instead of `offset` and `limit`, aligning with standard REST API patterns.
127
+
128
+ **Affected APIs:**
129
+ - `Memory.listThreadsByResourceId()`
130
+ - `Memory.listMessages()`
131
+ - `Storage.listWorkflowRuns()`
132
+
133
+ **Migration:**
134
+
135
+ ```typescript
136
+ // Before
137
+ await memory.listThreadsByResourceId({
138
+ resourceId: 'user-123',
139
+ offset: 20,
140
+ limit: 10,
141
+ });
142
+
143
+ // After
144
+ await memory.listThreadsByResourceId({
145
+ resourceId: 'user-123',
146
+ page: 2, // page = Math.floor(offset / limit)
147
+ perPage: 10,
148
+ });
149
+
150
+ // Before
151
+ await memory.listMessages({
152
+ threadId: 'thread-456',
153
+ offset: 20,
154
+ limit: 10,
155
+ });
156
+
157
+ // After
158
+ await memory.listMessages({
159
+ threadId: 'thread-456',
160
+ page: 2,
161
+ perPage: 10,
162
+ });
163
+
164
+ // Before
165
+ await storage.listWorkflowRuns({
166
+ workflowName: 'my-workflow',
167
+ offset: 20,
168
+ limit: 10,
169
+ });
170
+
171
+ // After
172
+ await storage.listWorkflowRuns({
173
+ workflowName: 'my-workflow',
174
+ page: 2,
175
+ perPage: 10,
176
+ });
177
+ ```
178
+
179
+ **Additional improvements:**
180
+ - Added validation for negative `page` values in all storage implementations
181
+ - Improved `perPage` validation to handle edge cases (negative values, `0`, `false`)
182
+ - Added reusable query parser utilities for consistent validation in handlers
183
+
184
+ - ```ts ([#9709](https://github.com/mastra-ai/mastra/pull/9709))
185
+ import { Mastra } from '@mastra/core';
186
+ import { Observability } from '@mastra/observability'; // Explicit import
187
+
188
+ const mastra = new Mastra({
189
+ ...other_config,
190
+ observability: new Observability({
191
+ default: { enabled: true },
192
+ }), // Instance
193
+ });
194
+ ```
195
+
196
+ Instead of:
197
+
198
+ ```ts
199
+ import { Mastra } from '@mastra/core';
200
+ import '@mastra/observability/init'; // Explicit import
201
+
202
+ const mastra = new Mastra({
203
+ ...other_config,
204
+ observability: {
205
+ default: { enabled: true },
206
+ },
207
+ });
208
+ ```
209
+
210
+ Also renamed a bunch of:
211
+ - `Tracing` things to `Observability` things.
212
+ - `AI-` things to just things.
213
+
214
+ - Removed old tracing code based on OpenTelemetry ([#9237](https://github.com/mastra-ai/mastra/pull/9237))
215
+
216
+ - Mark as stable ([`83d5942`](https://github.com/mastra-ai/mastra/commit/83d5942669ce7bba4a6ca4fd4da697a10eb5ebdc))
217
+
218
+ - Renamed `MastraMessageV2` to `MastraDBMessage` ([#9255](https://github.com/mastra-ai/mastra/pull/9255))
219
+ Made the return format of all methods that return db messages consistent. It's always `{ messages: MastraDBMessage[] }` now, and messages can be converted after that using `@mastra/ai-sdk/ui`'s `toAISdkV4/5Messages()` function
220
+
221
+ - moved ai-tracing code into @mastra/observability ([#9661](https://github.com/mastra-ai/mastra/pull/9661))
222
+
223
+ - Remove legacy evals from Mastra ([#9491](https://github.com/mastra-ai/mastra/pull/9491))
224
+
225
+ ### Minor Changes
226
+
227
+ - Add stored agents support ([#10953](https://github.com/mastra-ai/mastra/pull/10953))
228
+
229
+ Agents can now be stored in the database and loaded at runtime. This lets you persist agent configurations and dynamically create executable Agent instances from storage.
230
+
231
+ ```typescript
232
+ import { Mastra } from '@mastra/core';
233
+ import { LibSQLStore } from '@mastra/libsql';
234
+
235
+ const mastra = new Mastra({
236
+ storage: new LibSQLStore({ url: ':memory:' }),
237
+ tools: { myTool },
238
+ scorers: { myScorer },
239
+ });
240
+
241
+ // Create agent in storage via API or directly
242
+ await mastra.getStorage().createAgent({
243
+ agent: {
244
+ id: 'my-agent',
245
+ name: 'My Agent',
246
+ instructions: 'You are helpful',
247
+ model: { provider: 'openai', name: 'gpt-4' },
248
+ tools: { myTool: {} },
249
+ scorers: { myScorer: { sampling: { type: 'ratio', rate: 0.5 } } },
250
+ },
251
+ });
252
+
253
+ // Load and use the agent
254
+ const agent = await mastra.getStoredAgentById('my-agent');
255
+ const response = await agent.generate('Hello!');
256
+
257
+ // List all stored agents with pagination
258
+ const { agents, total, hasMore } = await mastra.listStoredAgents({
259
+ page: 0,
260
+ perPage: 10,
261
+ });
262
+ ```
263
+
264
+ Also adds a memory registry to Mastra so stored agents can reference memory instances by key.
265
+
266
+ - Update peer dependencies to match core package version bump (1.0.0) ([#9237](https://github.com/mastra-ai/mastra/pull/9237))
267
+
268
+ - Changed JSON columns from TEXT to JSONB in `mastra_threads` and `mastra_workflow_snapshot` tables. ([#11853](https://github.com/mastra-ai/mastra/pull/11853))
269
+
270
+ **Why this change?**
271
+
272
+ These were the last remaining columns storing JSON as TEXT. This change aligns them with other tables that already use JSONB, enabling native JSON operators and improved performance. See [#8978](https://github.com/mastra-ai/mastra/issues/8978) for details.
273
+
274
+ **Columns Changed:**
275
+ - `mastra_threads.metadata` - Thread metadata
276
+ - `mastra_workflow_snapshot.snapshot` - Workflow run state
277
+
278
+ **PostgreSQL**
279
+
280
+ Migration Required - PostgreSQL enforces column types, so existing tables must be migrated. Note: Migration will fail if existing column values contain invalid JSON.
281
+
282
+ ```sql
283
+ ALTER TABLE mastra_threads
284
+ ALTER COLUMN metadata TYPE jsonb
285
+ USING metadata::jsonb;
286
+
287
+ ALTER TABLE mastra_workflow_snapshot
288
+ ALTER COLUMN snapshot TYPE jsonb
289
+ USING snapshot::jsonb;
290
+ ```
291
+
292
+ **LibSQL**
293
+
294
+ No Migration Required - LibSQL now uses native SQLite JSONB format (added in SQLite 3.45) for ~3x performance improvement on JSON operations. The changes are fully backwards compatible:
295
+ - Existing TEXT JSON data continues to work
296
+ - New data is stored in binary JSONB format
297
+ - Both formats can coexist in the same table
298
+ - All JSON functions (`json_extract`, etc.) work on both formats
299
+
300
+ New installations automatically use JSONB. Existing applications continue to work without any changes.
301
+
302
+ - Introduce StorageDomain base class for composite storage support ([#11249](https://github.com/mastra-ai/mastra/pull/11249))
303
+
304
+ Storage adapters now use a domain-based architecture where each domain (memory, workflows, scores, observability, agents) extends a `StorageDomain` base class with `init()` and `dangerouslyClearAll()` methods.
305
+
306
+ **Key changes:**
307
+ - Add `StorageDomain` abstract base class that all domain storage classes extend
308
+ - Add `InMemoryDB` class for shared state across in-memory domain implementations
309
+ - All storage domains now implement `dangerouslyClearAll()` for test cleanup
310
+ - Remove `operations` from public `StorageDomains` type (now internal to each adapter)
311
+ - Add flexible client/config patterns - domains accept either an existing database client or config to create one internally
312
+
313
+ **Why this matters:**
314
+
315
+ This enables composite storage where you can use different database adapters per domain:
316
+
317
+ ```typescript
318
+ import { Mastra } from '@mastra/core';
319
+ import { PostgresStore } from '@mastra/pg';
320
+ import { ClickhouseStore } from '@mastra/clickhouse';
321
+
322
+ // Use Postgres for most domains but Clickhouse for observability
323
+ const mastra = new Mastra({
324
+ storage: new PostgresStore({
325
+ connectionString: 'postgres://...',
326
+ }),
327
+ // Future: override specific domains
328
+ // observability: new ClickhouseStore({ ... }).getStore('observability'),
329
+ });
330
+ ```
331
+
332
+ **Standalone domain usage:**
333
+
334
+ Domains can now be used independently with flexible configuration:
335
+
336
+ ```typescript
337
+ import { MemoryLibSQL } from '@mastra/libsql/memory';
338
+
339
+ // Option 1: Pass config to create client internally
340
+ const memory = new MemoryLibSQL({
341
+ url: 'file:./local.db',
342
+ });
343
+
344
+ // Option 2: Pass existing client for shared connections
345
+ import { createClient } from '@libsql/client';
346
+ const client = createClient({ url: 'file:./local.db' });
347
+ const memory = new MemoryLibSQL({ client });
348
+ ```
349
+
350
+ **Breaking changes:**
351
+ - `StorageDomains` type no longer includes `operations` - access via `getStore()` instead
352
+ - Domain base classes now require implementing `dangerouslyClearAll()` method
353
+
354
+ - Refactor storage architecture to use domain-specific stores via `getStore()` pattern ([#11361](https://github.com/mastra-ai/mastra/pull/11361))
355
+
356
+ ### Summary
357
+
358
+ This release introduces a new storage architecture that replaces passthrough methods on `MastraStorage` with domain-specific storage interfaces accessed via `getStore()`. This change reduces code duplication across storage adapters and provides a cleaner, more modular API.
359
+
360
+ ### Migration Guide
361
+
362
+ All direct method calls on storage instances should be updated to use `getStore()`:
363
+
364
+ ```typescript
365
+ // Before
366
+ const thread = await storage.getThreadById({ threadId });
367
+ await storage.persistWorkflowSnapshot({ workflowName, runId, snapshot });
368
+ await storage.createSpan(span);
369
+
370
+ // After
371
+ const memory = await storage.getStore('memory');
372
+ const thread = await memory?.getThreadById({ threadId });
373
+
374
+ const workflows = await storage.getStore('workflows');
375
+ await workflows?.persistWorkflowSnapshot({ workflowName, runId, snapshot });
376
+
377
+ const observability = await storage.getStore('observability');
378
+ await observability?.createSpan(span);
379
+ ```
380
+
381
+ ### Available Domains
382
+ - **`memory`**: Thread and message operations (`getThreadById`, `saveThread`, `saveMessages`, etc.)
383
+ - **`workflows`**: Workflow state persistence (`persistWorkflowSnapshot`, `loadWorkflowSnapshot`, `getWorkflowRunById`, etc.)
384
+ - **`scores`**: Evaluation scores (`saveScore`, `listScoresByScorerId`, etc.)
385
+ - **`observability`**: Tracing and spans (`createSpan`, `updateSpan`, `getTrace`, etc.)
386
+ - **`agents`**: Stored agent configurations (`createAgent`, `getAgentById`, `listAgents`, etc.)
387
+
388
+ ### Breaking Changes
389
+ - Passthrough methods have been removed from `MastraStorage` base class
390
+ - All storage adapters now require accessing domains via `getStore()`
391
+ - The `stores` property on storage instances is now the canonical way to access domain storage
392
+
393
+ ### Internal Changes
394
+ - Each storage adapter now initializes domain-specific stores in its constructor
395
+ - Domain stores share database connections and handle their own table initialization
396
+
397
+ - Unified observability schema with entity-based span identification ([#11132](https://github.com/mastra-ai/mastra/pull/11132))
398
+
399
+ ## What changed
400
+
401
+ Spans now use a unified identification model with `entityId`, `entityType`, and `entityName` instead of separate `agentId`, `toolId`, `workflowId` fields.
402
+
403
+ **Before:**
404
+
405
+ ```typescript
406
+ // Old span structure
407
+ span.agentId; // 'my-agent'
408
+ span.toolId; // undefined
409
+ span.workflowId; // undefined
410
+ ```
411
+
412
+ **After:**
413
+
414
+ ```typescript
415
+ // New span structure
416
+ span.entityType; // EntityType.AGENT
417
+ span.entityId; // 'my-agent'
418
+ span.entityName; // 'My Agent'
419
+ ```
420
+
421
+ ## New `listTraces()` API
422
+
423
+ Query traces with filtering, pagination, and sorting:
424
+
425
+ ```typescript
426
+ const { spans, pagination } = await storage.listTraces({
427
+ filters: {
428
+ entityType: EntityType.AGENT,
429
+ entityId: 'my-agent',
430
+ userId: 'user-123',
431
+ environment: 'production',
432
+ status: TraceStatus.SUCCESS,
433
+ startedAt: { start: new Date('2024-01-01'), end: new Date('2024-01-31') },
434
+ },
435
+ pagination: { page: 0, perPage: 50 },
436
+ orderBy: { field: 'startedAt', direction: 'DESC' },
437
+ });
438
+ ```
439
+
440
+ **Available filters:** date ranges (`startedAt`, `endedAt`), entity (`entityType`, `entityId`, `entityName`), identity (`userId`, `organizationId`), correlation IDs (`runId`, `sessionId`, `threadId`), deployment (`environment`, `source`, `serviceName`), `tags`, `metadata`, and `status`.
441
+
442
+ ## New retrieval methods
443
+ - `getSpan({ traceId, spanId })` - Get a single span
444
+ - `getRootSpan({ traceId })` - Get the root span of a trace
445
+ - `getTrace({ traceId })` - Get all spans for a trace
446
+
447
+ ## Backward compatibility
448
+
449
+ The legacy `getTraces()` method continues to work. When you pass `name: "agent run: my-agent"`, it automatically transforms to `entityId: "my-agent", entityType: AGENT`.
450
+
451
+ ## Migration
452
+
453
+ **Automatic:** SQL-based stores (PostgreSQL, LibSQL, MSSQL) automatically add new columns to existing `spans` tables on initialization. Existing data is preserved with new columns set to `NULL`.
454
+
455
+ **No action required:** Your existing code continues to work. Adopt the new fields and `listTraces()` API at your convenience.
456
+
457
+ - Remove pg-promise dependency and use pg.Pool directly ([#11450](https://github.com/mastra-ai/mastra/pull/11450))
458
+
459
+ **BREAKING CHANGE**: This release replaces pg-promise with vanilla node-postgres (`pg`).
460
+
461
+ ### Breaking Changes
462
+ - **Removed `store.pgp`**: The pg-promise library instance is no longer exposed
463
+ - **Config change**: `{ client: pgPromiseDb }` is no longer supported. Use `{ pool: pgPool }` instead
464
+ - **Cloud SQL config**: `max` and `idleTimeoutMillis` must now be passed via `pgPoolOptions`
465
+
466
+ ### New Features
467
+ - **`store.pool`**: Exposes the underlying `pg.Pool` for direct database access or ORM integration (e.g., Drizzle)
468
+ - **`store.db`**: Provides a `DbClient` interface with methods like `one()`, `any()`, `tx()`, etc.
469
+ - **`store.db.connect()`**: Acquire a client for session-level operations
470
+
471
+ ### Migration
472
+
473
+ ```typescript
474
+ // Before (pg-promise)
475
+ import pgPromise from 'pg-promise';
476
+ const pgp = pgPromise();
477
+ const client = pgp(connectionString);
478
+ const store = new PostgresStore({ id: 'my-store', client });
479
+
480
+ // After (pg.Pool)
481
+ import { Pool } from 'pg';
482
+ const pool = new Pool({ connectionString });
483
+ const store = new PostgresStore({ id: 'my-store', pool });
484
+
485
+ // Use store.pool with any library that accepts a pg.Pool
486
+ ```
487
+
488
+ - Add `disableInit` option to all storage adapters ([#10851](https://github.com/mastra-ai/mastra/pull/10851))
489
+
490
+ Adds a new `disableInit` config option to all storage providers that allows users to disable automatic table creation/migrations at runtime. This is useful for CI/CD pipelines where you want to run migrations during deployment with elevated credentials, then run the application with `disableInit: true` so it doesn't attempt schema changes at runtime.
491
+
492
+ ```typescript
493
+ // CI/CD script - run migrations
494
+ const storage = new PostgresStore({
495
+ connectionString: DATABASE_URL,
496
+ id: 'pg-storage',
497
+ });
498
+ await storage.init();
499
+
500
+ // Runtime - skip auto-init
501
+ const storage = new PostgresStore({
502
+ connectionString: DATABASE_URL,
503
+ id: 'pg-storage',
504
+ disableInit: true,
505
+ });
506
+ ```
507
+
508
+ ### Patch Changes
509
+
510
+ - Add embedded documentation support for Mastra packages ([#11472](https://github.com/mastra-ai/mastra/pull/11472))
511
+
512
+ Mastra packages now include embedded documentation in the published npm package under `dist/docs/`. This enables coding agents and AI assistants to understand and use the framework by reading documentation directly from `node_modules`.
513
+
514
+ Each package includes:
515
+ - **SKILL.md** - Entry point explaining the package's purpose and capabilities
516
+ - **SOURCE_MAP.json** - Machine-readable index mapping exports to types and implementation files
517
+ - **Topic folders** - Conceptual documentation organized by feature area
518
+
519
+ Documentation is driven by the `packages` frontmatter field in MDX files, which maps docs to their corresponding packages. CI validation ensures all docs include this field.
520
+
521
+ - Added `exportSchemas()` function to generate Mastra database schema as SQL DDL without a database connection. ([#11448](https://github.com/mastra-ai/mastra/pull/11448))
522
+
523
+ **What's New**
524
+
525
+ You can now export your Mastra database schema as SQL DDL statements without connecting to a database. This is useful for:
526
+ - Generating migration scripts
527
+ - Reviewing the schema before deployment
528
+ - Creating database schemas in environments where the application doesn't have CREATE privileges
529
+
530
+ **Example**
531
+
532
+ ```typescript
533
+ import { exportSchemas } from '@mastra/pg';
534
+
535
+ // Export schema for default 'public' schema
536
+ const ddl = exportSchemas();
537
+ console.log(ddl);
538
+
539
+ // Export schema for a custom schema
540
+ const customDdl = exportSchemas('my_schema');
541
+ // Creates: CREATE SCHEMA IF NOT EXISTS "my_schema"; and all tables within it
542
+ ```
543
+
544
+ - Fix pg listThreadsByResourceId page number validation ([#9671](https://github.com/mastra-ai/mastra/pull/9671))
545
+
546
+ - Standardize error IDs across all storage and vector stores using centralized helper functions (`createStorageErrorId` and `createVectorErrorId`). This ensures consistent error ID patterns (`MASTRA_STORAGE_{STORE}_{OPERATION}_{STATUS}` and `MASTRA_VECTOR_{STORE}_{OPERATION}_{STATUS}`) across the codebase for better error tracking and debugging. ([#10913](https://github.com/mastra-ai/mastra/pull/10913))
547
+
548
+ - Fix missing timezone columns during PostgreSQL spans table migration ([#11419](https://github.com/mastra-ai/mastra/pull/11419))
549
+
550
+ Fixes issue #11410 where users upgrading to observability beta.7 encountered errors about missing `startedAtZ`, `endedAtZ`, `createdAtZ`, and `updatedAtZ` columns. The migration now properly adds timezone-aware columns for all timestamp fields when upgrading existing databases, ensuring compatibility with the new observability implementation that requires these columns for batch operations.
551
+
552
+ - Fix saveScore not persisting ID correctly, breaking getScoreById retrieval ([#10915](https://github.com/mastra-ai/mastra/pull/10915))
553
+
554
+ **What Changed**
555
+ - saveScore now correctly returns scores that can be retrieved with getScoreById
556
+ - Validation errors now include contextual information (scorer, entity, trace details) for easier debugging
557
+
558
+ **Impact**
559
+ Previously, calling getScoreById after saveScore would return null because the generated ID wasn't persisted to the database. This is now fixed across all store implementations, ensuring consistent behavior and data integrity.
560
+
561
+ - Add new deleteVectors, updateVector by filter ([#10408](https://github.com/mastra-ai/mastra/pull/10408))
562
+
563
+ - PostgresStore was setting `this.stores = {}` in the constructor and only populating it in the async `init()` method. This broke Memory because it checks `storage.stores.memory` synchronously in `getInputProcessors()` before `init()` is called. ([#10943](https://github.com/mastra-ai/mastra/pull/10943))
564
+
565
+ The fix moves domain instance creation to the constructor. This is safe because pg-promise creates database connections lazily when queries are executed.
566
+
567
+ - Fix `listWorkflowRuns` failing with "unsupported Unicode escape sequence" error when filtering by status on snapshots containing null characters (`\u0000`) or unpaired Unicode surrogates (`\uD800-\uDFFF`). ([#11616](https://github.com/mastra-ai/mastra/pull/11616))
568
+
569
+ The fix uses `regexp_replace` to sanitize problematic escape sequences before casting to JSONB in the WHERE clause, while preserving the original data in the returned results.
570
+
571
+ - qualify vector type to fix schema lookup ([#10786](https://github.com/mastra-ai/mastra/pull/10786))
572
+
573
+ - - Fixed TypeScript errors where `threadId: string | string[]` was being passed to places expecting `Scalar` type ([#10663](https://github.com/mastra-ai/mastra/pull/10663))
574
+ - Added proper multi-thread support for `listMessages` across all adapters when `threadId` is an array
575
+ - Updated `_getIncludedMessages` to look up message threadId by ID (since message IDs are globally unique)
576
+ - **upstash**: Added `msg-idx:{messageId}` index for O(1) message lookups (backwards compatible with fallback to scan for old messages, with automatic backfill)
577
+
578
+ - Fix severe performance issue with semantic recall on large message tables ([#11365](https://github.com/mastra-ai/mastra/pull/11365))
579
+
580
+ The `_getIncludedMessages` method was using `ROW_NUMBER() OVER (ORDER BY createdAt)` which scanned all messages in a thread to assign row numbers. On tables with 1M+ rows, this caused 5-10 minute query times.
581
+
582
+ Replaced with cursor-based pagination using the existing `(thread_id, createdAt)` index:
583
+
584
+ ```sql
585
+ -- Before: scans entire thread
586
+ ROW_NUMBER() OVER (ORDER BY "createdAt" ASC)
587
+
588
+ -- After: uses index, fetches only needed rows
589
+ WHERE createdAt <= (target) ORDER BY createdAt DESC LIMIT N
590
+ ```
591
+
592
+ Performance improvement: ~49x faster (832ms → 17ms) for typical semantic recall queries.
593
+
594
+ - Fixed PostgreSQL migration errors when upgrading from v0.x to v1 ([#11633](https://github.com/mastra-ai/mastra/pull/11633))
595
+
596
+ **What changed:** PostgreSQL storage now automatically adds missing `spanId` and `requestContext` columns to the scorers table during initialization, preventing "column does not exist" errors when upgrading from v0.x to v1.0.0.
597
+
598
+ **Why:** Previously, upgrading to v1 could fail with errors like `column "requestContext" of relation "mastra_scorers" does not exist` if your database was created with an older version.
599
+
600
+ Related: #11631
601
+
602
+ - Preserve error details when thrown from workflow steps ([#10992](https://github.com/mastra-ai/mastra/pull/10992))
603
+
604
+ Workflow errors now retain custom properties like `statusCode`, `responseHeaders`, and `cause` chains. This enables error-specific recovery logic in your applications.
605
+
606
+ **Before:**
607
+
608
+ ```typescript
609
+ const result = await workflow.execute({ input });
610
+ if (result.status === 'failed') {
611
+ // Custom error properties were lost
612
+ console.log(result.error); // "Step execution failed" (just a string)
613
+ }
614
+ ```
615
+
616
+ **After:**
617
+
618
+ ```typescript
619
+ const result = await workflow.execute({ input });
620
+ if (result.status === 'failed') {
621
+ // Custom properties are preserved
622
+ console.log(result.error.message); // "Step execution failed"
623
+ console.log(result.error.statusCode); // 429
624
+ console.log(result.error.cause?.name); // "RateLimitError"
625
+ }
626
+ ```
627
+
628
+ **Type change:** `WorkflowState.error` and `WorkflowRunState.error` types changed from `string | Error` to `SerializedError`.
629
+
630
+ Other changes:
631
+ - Added `UpdateWorkflowStateOptions` type for workflow state updates
632
+
633
+ - Added `startExclusive` and `endExclusive` options to `dateRange` filter for message queries. ([#11479](https://github.com/mastra-ai/mastra/pull/11479))
634
+
635
+ **What changed:** The `filter.dateRange` parameter in `listMessages()` and `Memory.recall()` now supports `startExclusive` and `endExclusive` boolean options. When set to `true`, messages with timestamps exactly matching the boundary are excluded from results.
636
+
637
+ **Why this matters:** Enables cursor-based pagination for chat applications. When new messages arrive during a session, offset-based pagination can skip or duplicate messages. Using `endExclusive: true` with the oldest message's timestamp as a cursor ensures consistent pagination without gaps or duplicates.
638
+
639
+ **Example:**
640
+
641
+ ```typescript
642
+ // Get first page
643
+ const page1 = await memory.recall({
644
+ threadId: 'thread-123',
645
+ perPage: 10,
646
+ orderBy: { field: 'createdAt', direction: 'DESC' },
647
+ });
648
+
649
+ // Get next page using cursor-based pagination
650
+ const oldestMessage = page1.messages[page1.messages.length - 1];
651
+ const page2 = await memory.recall({
652
+ threadId: 'thread-123',
653
+ perPage: 10,
654
+ orderBy: { field: 'createdAt', direction: 'DESC' },
655
+ filter: {
656
+ dateRange: {
657
+ end: oldestMessage.createdAt,
658
+ endExclusive: true, // Excludes the cursor message
659
+ },
660
+ },
661
+ });
662
+ ```
663
+
664
+ - Ensure score responses match saved payloads for Mastra Stores. ([#10557](https://github.com/mastra-ai/mastra/pull/10557))
665
+
666
+ - Fixed duplicate spans migration issue across all storage backends. When upgrading from older versions, existing duplicate (traceId, spanId) combinations in the spans table could prevent the unique constraint from being created. The migration deduplicates spans before adding the constraint. ([#12073](https://github.com/mastra-ai/mastra/pull/12073))
667
+
668
+ **Deduplication rules (in priority order):**
669
+ 1. Keep completed spans (those with `endedAt` set) over incomplete spans
670
+ 2. Among spans with the same completion status, keep the one with the newest `updatedAt`
671
+ 3. Use `createdAt` as the final tiebreaker
672
+
673
+ **What changed:**
674
+ - Added `migrateSpans()` method to observability stores for manual migration
675
+ - Added `checkSpansMigrationStatus()` method to check if migration is needed
676
+ - All stores use optimized single-query deduplication to avoid memory issues on large tables
677
+
678
+ **Usage example:**
679
+
680
+ ```typescript
681
+ const observability = await storage.getStore('observability');
682
+ const status = await observability.checkSpansMigrationStatus();
683
+ if (status.needsMigration) {
684
+ const result = await observability.migrateSpans();
685
+ console.log(`Migration complete: ${result.duplicatesRemoved} duplicates removed`);
686
+ }
687
+ ```
688
+
689
+ Fixes #11840
690
+
691
+ - Fix thread timestamps being returned in incorrect timezone from listThreadsByResourceId ([#11498](https://github.com/mastra-ai/mastra/pull/11498))
692
+
693
+ The method was not using the timezone-aware columns (createdAtZ/updatedAtZ), causing timestamps to be interpreted in local timezone instead of UTC. Now correctly uses TIMESTAMPTZ columns with fallback for legacy data.
694
+
695
+ - Add storage composition to MastraStorage ([#11401](https://github.com/mastra-ai/mastra/pull/11401))
696
+
697
+ `MastraStorage` can now compose storage domains from different adapters. Use it when you need different databases for different purposes - for example, PostgreSQL for memory and workflows, but a different database for observability.
698
+
699
+ ```typescript
700
+ import { MastraStorage } from '@mastra/core/storage';
701
+ import { MemoryPG, WorkflowsPG, ScoresPG } from '@mastra/pg';
702
+ import { MemoryLibSQL } from '@mastra/libsql';
703
+
704
+ // Compose domains from different stores
705
+ const storage = new MastraStorage({
706
+ id: 'composite',
707
+ domains: {
708
+ memory: new MemoryLibSQL({ url: 'file:./local.db' }),
709
+ workflows: new WorkflowsPG({ connectionString: process.env.DATABASE_URL }),
710
+ scores: new ScoresPG({ connectionString: process.env.DATABASE_URL }),
711
+ },
712
+ });
713
+ ```
714
+
715
+ **Breaking changes:**
716
+ - `storage.supports` property no longer exists
717
+ - `StorageSupports` type is no longer exported from `@mastra/core/storage`
718
+
719
+ All stores now support the same features. For domain availability, use `getStore()`:
720
+
721
+ ```typescript
722
+ const store = await storage.getStore('memory');
723
+ if (store) {
724
+ // domain is available
725
+ }
726
+ ```
727
+
728
+ - - PostgreSQL: use `getSqlType()` in `createTable` instead of `toUpperCase()` ([#11112](https://github.com/mastra-ai/mastra/pull/11112))
729
+ - LibSQL: use `getSqlType()` in `createTable`, return `JSONB` for jsonb type (matches SQLite 3.45+ support)
730
+ - ClickHouse: use `getSqlType()` in `createTable` instead of `COLUMN_TYPES` constant, add missing types (uuid, float, boolean)
731
+ - Remove unused `getSqlType()` and `getDefaultValue()` from `MastraStorage` base class (all stores use `StoreOperations` versions)
732
+
733
+ - Add delete workflow run API ([#10991](https://github.com/mastra-ai/mastra/pull/10991))
734
+
735
+ ```typescript
736
+ await workflow.deleteWorkflowRunById(runId);
737
+ ```
738
+
739
+ - Add halfvec type support for large dimension embeddings ([#11002](https://github.com/mastra-ai/mastra/pull/11002))
740
+
741
+ Adds `vectorType` option to `createIndex()` for choosing between full precision (`vector`) and half precision (`halfvec`) storage. halfvec uses 2 bytes per dimension instead of 4, enabling indexes on embeddings up to 4000 dimensions.
742
+
743
+ ```typescript
744
+ await pgVector.createIndex({
745
+ indexName: 'large-embeddings',
746
+ dimension: 3072, // text-embedding-3-large
747
+ metric: 'cosine',
748
+ vectorType: 'halfvec',
749
+ });
750
+ ```
751
+
752
+ Requires pgvector >= 0.7.0 for halfvec support. Docker compose files updated to use pgvector 0.8.0.
753
+
754
+ - Fixes "invalid input syntax for type json" error in tracing with PostgreSQL. ([#9154](https://github.com/mastra-ai/mastra/pull/9154))
755
+
756
+ - Added a unified `transformScoreRow` function in `@mastra/core/storage` that provides schema-driven row transformation for score data. This eliminates code duplication across 10 storage adapters while maintaining store-specific behavior through configurable options: ([#10648](https://github.com/mastra-ai/mastra/pull/10648))
757
+ - `preferredTimestampFields`: Preferred source fields for timestamps (PostgreSQL, Cloudflare D1)
758
+ - `convertTimestamps`: Convert timestamp strings to Date objects (MSSQL, MongoDB, ClickHouse)
759
+ - `nullValuePattern`: Skip values matching pattern (ClickHouse's `'_null_'`)
760
+ - `fieldMappings`: Map source column names to schema fields (LibSQL's `additionalLLMContext`)
761
+
762
+ Each store adapter now uses the unified function with appropriate options, reducing ~200 lines of duplicate transformation logic while ensuring consistent behavior across all storage backends.
763
+
764
+ - Added new `listThreads` method for flexible thread filtering across all storage adapters. ([#11832](https://github.com/mastra-ai/mastra/pull/11832))
765
+
766
+ **New Features**
767
+ - Filter threads by `resourceId`, `metadata`, or both (with AND logic for metadata key-value pairs)
768
+ - All filter parameters are optional, allowing you to list all threads or filter as needed
769
+ - Full pagination and sorting support
770
+
771
+ **Example Usage**
772
+
773
+ ```typescript
774
+ // List all threads
775
+ const allThreads = await memory.listThreads({});
776
+
777
+ // Filter by resourceId only
778
+ const userThreads = await memory.listThreads({
779
+ filter: { resourceId: 'user-123' },
780
+ });
781
+
782
+ // Filter by metadata only
783
+ const supportThreads = await memory.listThreads({
784
+ filter: { metadata: { category: 'support' } },
785
+ });
786
+
787
+ // Filter by both with pagination
788
+ const filteredThreads = await memory.listThreads({
789
+ filter: {
790
+ resourceId: 'user-123',
791
+ metadata: { priority: 'high', status: 'open' },
792
+ },
793
+ orderBy: { field: 'updatedAt', direction: 'DESC' },
794
+ page: 0,
795
+ perPage: 20,
796
+ });
797
+ ```
798
+
799
+ **Security Improvements**
800
+ - Added validation to prevent SQL injection via malicious metadata keys
801
+ - Added pagination parameter validation to prevent integer overflow attacks
802
+
803
+ - Aligned vector store configuration with underlying library APIs, giving you access to all library options directly. ([#11742](https://github.com/mastra-ai/mastra/pull/11742))
804
+
805
+ **Why this change?**
806
+
807
+ Previously, each vector store defined its own configuration types that only exposed a subset of the underlying library's options. This meant users couldn't access advanced features like authentication, SSL, compression, or custom headers without creating their own client instances. Now, the configuration types extend the library types directly, so all options are available.
808
+
809
+ **@mastra/libsql** (Breaking)
810
+
811
+ Renamed `connectionUrl` to `url` to match the `@libsql/client` API and align with LibSQLStorage.
812
+
813
+ ```typescript
814
+ // Before
815
+ new LibSQLVector({ id: 'my-vector', connectionUrl: 'file:./db.sqlite' });
816
+
817
+ // After
818
+ new LibSQLVector({ id: 'my-vector', url: 'file:./db.sqlite' });
819
+ ```
820
+
821
+ **@mastra/opensearch** (Breaking)
822
+
823
+ Renamed `url` to `node` and added support for all OpenSearch `ClientOptions` including authentication, SSL, and compression.
824
+
825
+ ```typescript
826
+ // Before
827
+ new OpenSearchVector({ id: 'my-vector', url: 'http://localhost:9200' });
828
+
829
+ // After
830
+ new OpenSearchVector({ id: 'my-vector', node: 'http://localhost:9200' });
831
+
832
+ // With authentication (now possible)
833
+ new OpenSearchVector({
834
+ id: 'my-vector',
835
+ node: 'https://localhost:9200',
836
+ auth: { username: 'admin', password: 'admin' },
837
+ ssl: { rejectUnauthorized: false },
838
+ });
839
+ ```
840
+
841
+ **@mastra/pinecone** (Breaking)
842
+
843
+ Removed `environment` parameter. Use `controllerHostUrl` instead (the actual Pinecone SDK field name). Added support for all `PineconeConfiguration` options.
844
+
845
+ ```typescript
846
+ // Before
847
+ new PineconeVector({ id: 'my-vector', apiKey: '...', environment: '...' });
848
+
849
+ // After
850
+ new PineconeVector({ id: 'my-vector', apiKey: '...' });
851
+
852
+ // With custom controller host (if needed)
853
+ new PineconeVector({ id: 'my-vector', apiKey: '...', controllerHostUrl: '...' });
854
+ ```
855
+
856
+ **@mastra/clickhouse**
857
+
858
+ Added support for all `ClickHouseClientConfigOptions` like `request_timeout`, `compression`, `keep_alive`, and `database`. Existing configurations continue to work unchanged.
859
+
860
+ **@mastra/cloudflare, @mastra/cloudflare-d1, @mastra/lance, @mastra/libsql, @mastra/mongodb, @mastra/pg, @mastra/upstash**
861
+
862
+ Improved logging by replacing `console.warn` with structured logger in workflow storage domains.
863
+
864
+ **@mastra/deployer-cloud**
865
+
866
+ Updated internal LibSQLVector configuration for compatibility with the new API.
867
+
868
+ - Fixed PostgreSQL storage issues after JSONB migration. ([#11906](https://github.com/mastra-ai/mastra/pull/11906))
869
+
870
+ **Bug Fixes**
871
+ - Fixed `clearTable()` using incorrect default schema. The method was checking for table existence in the 'mastra' schema instead of PostgreSQL's default 'public' schema, causing table truncation to be skipped and leading to duplicate key violations in tests and production code that uses `dangerouslyClearAll()`.
872
+ - Fixed `listWorkflowRuns()` status filter failing with "function regexp_replace(jsonb, ...) does not exist" error. After the TEXT to JSONB migration, the query tried to use `regexp_replace()` directly on a JSONB column. Now casts to text first: `regexp_replace(snapshot::text, ...)`.
873
+ - Added Unicode sanitization when persisting workflow snapshots to handle null characters (\u0000) and unpaired surrogates (\uD800-\uDFFF) that PostgreSQL's JSONB type rejects, preventing "unsupported Unicode escape sequence" errors.
874
+
875
+ - Add restart method to workflow run that allows restarting an active workflow run ([#9750](https://github.com/mastra-ai/mastra/pull/9750))
876
+ Add status filter to `listWorkflowRuns`
877
+ Add automatic restart to restart active workflow runs when server starts
878
+
879
+ - Renamed MastraStorage to MastraCompositeStore for better clarity. The old MastraStorage name remains available as a deprecated alias for backward compatibility, but will be removed in a future version. ([#12093](https://github.com/mastra-ai/mastra/pull/12093))
880
+
881
+ **Migration:**
882
+
883
+ Update your imports and usage:
884
+
885
+ ```typescript
886
+ // Before
887
+ import { MastraStorage } from '@mastra/core/storage';
888
+
889
+ const storage = new MastraStorage({
890
+ id: 'composite',
891
+ domains: { ... }
892
+ });
893
+
894
+ // After
895
+ import { MastraCompositeStore } from '@mastra/core/storage';
896
+
897
+ const storage = new MastraCompositeStore({
898
+ id: 'composite',
899
+ domains: { ... }
900
+ });
901
+ ```
902
+
903
+ The new name better reflects that this is a composite storage implementation that routes different domains (workflows, traces, messages) to different underlying stores, avoiding confusion with the general "Mastra Storage" concept.
904
+
905
+ - Adds thread cloning to create independent copies of conversations that can diverge. ([#11517](https://github.com/mastra-ai/mastra/pull/11517))
906
+
907
+ ```typescript
908
+ // Clone a thread
909
+ const { thread, clonedMessages } = await memory.cloneThread({
910
+ sourceThreadId: 'thread-123',
911
+ title: 'My Clone',
912
+ options: {
913
+ messageLimit: 10, // optional: only copy last N messages
914
+ },
915
+ });
916
+
917
+ // Check if a thread is a clone
918
+ if (memory.isClone(thread)) {
919
+ const source = await memory.getSourceThread(thread.id);
920
+ }
921
+
922
+ // List all clones of a thread
923
+ const clones = await memory.listClones('thread-123');
924
+ ```
925
+
926
+ Includes:
927
+ - Storage implementations for InMemory, PostgreSQL, LibSQL, Upstash
928
+ - API endpoint: `POST /api/memory/threads/:threadId/clone`
929
+ - Embeddings created for cloned messages (semantic recall)
930
+ - Clone button in playground UI Memory tab
931
+
932
+ - Added pre-configured client support for all storage adapters. ([#11302](https://github.com/mastra-ai/mastra/pull/11302))
933
+
934
+ **What changed**
935
+
936
+ All storage adapters now accept pre-configured database clients in addition to connection credentials. This allows you to customize client settings (connection pools, timeouts, interceptors) before passing them to Mastra.
937
+
938
+ **Example**
939
+
940
+ ```typescript
941
+ import { createClient } from '@clickhouse/client';
942
+ import { ClickhouseStore } from '@mastra/clickhouse';
943
+
944
+ // Create and configure client with custom settings
945
+ const client = createClient({
946
+ url: 'http://localhost:8123',
947
+ username: 'default',
948
+ password: '',
949
+ request_timeout: 60000,
950
+ });
951
+
952
+ // Pass pre-configured client to store
953
+ const store = new ClickhouseStore({
954
+ id: 'my-store',
955
+ client,
956
+ });
957
+ ```
958
+
959
+ **Additional improvements**
960
+ - Added input validation for required connection parameters (URL, credentials) with clear error messages
961
+
962
+ - Add index configuration options to storage stores ([#11311](https://github.com/mastra-ai/mastra/pull/11311))
963
+
964
+ Storage stores now support two new configuration options for index management:
965
+ - `skipDefaultIndexes`: When `true`, default performance indexes are not created during `init()`. Useful for custom index strategies or reducing initialization time.
966
+ - `indexes`: Array of custom index definitions to create during `init()`. Indexes are routed to the appropriate domain based on table/collection name.
967
+
968
+ ```typescript
969
+ // Skip default indexes and use custom ones
970
+ const store = new PostgresStore({
971
+ connectionString: '...',
972
+ skipDefaultIndexes: true,
973
+ indexes: [{ name: 'threads_type_idx', table: 'mastra_threads', columns: ["metadata->>'type'"] }],
974
+ });
975
+
976
+ // MongoDB equivalent
977
+ const mongoStore = new MongoDBStore({
978
+ url: 'mongodb://...',
979
+ skipDefaultIndexes: true,
980
+ indexes: [{ collection: 'mastra_threads', keys: { 'metadata.type': 1 }, options: { name: 'threads_type_idx' } }],
981
+ });
982
+ ```
983
+
984
+ Domain classes (e.g., `MemoryPG`, `MemoryStorageMongoDB`) also accept these options for standalone usage.
985
+
986
+ - Updated dependencies [[`ac0d2f4`](https://github.com/mastra-ai/mastra/commit/ac0d2f4ff8831f72c1c66c2be809706d17f65789), [`2319326`](https://github.com/mastra-ai/mastra/commit/2319326f8c64e503a09bbcf14be2dd65405445e0), [`d2d3e22`](https://github.com/mastra-ai/mastra/commit/d2d3e22a419ee243f8812a84e3453dd44365ecb0), [`08766f1`](https://github.com/mastra-ai/mastra/commit/08766f15e13ac0692fde2a8bd366c2e16e4321df), [`72df8ae`](https://github.com/mastra-ai/mastra/commit/72df8ae595584cdd7747d5c39ffaca45e4507227), [`ebae12a`](https://github.com/mastra-ai/mastra/commit/ebae12a2dd0212e75478981053b148a2c246962d), [`c8417b4`](https://github.com/mastra-ai/mastra/commit/c8417b41d9f3486854dc7842d977fbe5e2166264), [`bc72b52`](https://github.com/mastra-ai/mastra/commit/bc72b529ee4478fe89ecd85a8be47ce0127b82a0), [`39c9743`](https://github.com/mastra-ai/mastra/commit/39c97432d084294f8ba85fbf3ef28098ff21459e), [`1dbd8c7`](https://github.com/mastra-ai/mastra/commit/1dbd8c729fb6536ec52f00064d76b80253d346e9), [`c61a0a5`](https://github.com/mastra-ai/mastra/commit/c61a0a5de4904c88fd8b3718bc26d1be1c2ec6e7), [`05b8bee`](https://github.com/mastra-ai/mastra/commit/05b8bee9e50e6c2a4a2bf210eca25ee212ca24fa), [`3076c67`](https://github.com/mastra-ai/mastra/commit/3076c6778b18988ae7d5c4c5c466366974b2d63f), [`3d93a15`](https://github.com/mastra-ai/mastra/commit/3d93a15796b158c617461c8b98bede476ebb43e2), [`9198899`](https://github.com/mastra-ai/mastra/commit/91988995c427b185c33714b7f3be955367911324), [`ed3e3dd`](https://github.com/mastra-ai/mastra/commit/ed3e3ddec69d564fe2b125e083437f76331f1283), [`c59e13c`](https://github.com/mastra-ai/mastra/commit/c59e13c7688284bd96b2baee3e314335003548de), [`c042bd0`](https://github.com/mastra-ai/mastra/commit/c042bd0b743e0e86199d0cb83344ca7690e34a9c), [`f743dbb`](https://github.com/mastra-ai/mastra/commit/f743dbb8b40d1627b5c10c0e6fc154f4ebb6e394), [`21a15de`](https://github.com/mastra-ai/mastra/commit/21a15de369fe82aac26bb642ed7be73505475e8b), [`e54953e`](https://github.com/mastra-ai/mastra/commit/e54953ed8ce1b28c0d62a19950163039af7834b4), [`ae8baf7`](https://github.com/mastra-ai/mastra/commit/ae8baf7d8adcb0ff9dac11880400452bc49b33ff), [`fec5129`](https://github.com/mastra-ai/mastra/commit/fec5129de7fc64423ea03661a56cef31dc747a0d), [`940a2b2`](https://github.com/mastra-ai/mastra/commit/940a2b27480626ed7e74f55806dcd2181c1dd0c2), [`1a0d3fc`](https://github.com/mastra-ai/mastra/commit/1a0d3fc811482c9c376cdf79ee615c23bae9b2d6), [`85d7ee1`](https://github.com/mastra-ai/mastra/commit/85d7ee18ff4e14d625a8a30ec6656bb49804989b), [`c6c1092`](https://github.com/mastra-ai/mastra/commit/c6c1092f8fbf76109303f69e000e96fd1960c4ce), [`0491e7c`](https://github.com/mastra-ai/mastra/commit/0491e7c9b714cb0ba22187ee062147ec2dd7c712), [`f6f4903`](https://github.com/mastra-ai/mastra/commit/f6f4903397314f73362061dc5a3e8e7c61ea34aa), [`d5ed981`](https://github.com/mastra-ai/mastra/commit/d5ed981c8701c1b8a27a5f35a9a2f7d9244e695f), [`85a628b`](https://github.com/mastra-ai/mastra/commit/85a628b1224a8f64cd82ea7f033774bf22df7a7e), [`0e8ed46`](https://github.com/mastra-ai/mastra/commit/0e8ed467c54d6901a6a365f270ec15d6faadb36c), [`33a4d2e`](https://github.com/mastra-ai/mastra/commit/33a4d2e4ed8af51f69256232f00c34d6b6b51d48), [`9650cce`](https://github.com/mastra-ai/mastra/commit/9650cce52a1d917ff9114653398e2a0f5c3ba808), [`6c049d9`](https://github.com/mastra-ai/mastra/commit/6c049d94063fdcbd5b81c4912a2bf82a92c9cc0b), [`910db9e`](https://github.com/mastra-ai/mastra/commit/910db9e0312888495eb5617b567f247d03303814), [`2f897df`](https://github.com/mastra-ai/mastra/commit/2f897df208508f46f51b7625e5dd20c37f93e0e3), [`d629361`](https://github.com/mastra-ai/mastra/commit/d629361a60f6565b5bfb11976fdaf7308af858e2), [`4f94ed8`](https://github.com/mastra-ai/mastra/commit/4f94ed8177abfde3ec536e3574883e075423350c), [`feb7ee4`](https://github.com/mastra-ai/mastra/commit/feb7ee4d09a75edb46c6669a3beaceec78811747), [`4aaa844`](https://github.com/mastra-ai/mastra/commit/4aaa844a4f19d054490f43638a990cc57bda8d2f), [`c237233`](https://github.com/mastra-ai/mastra/commit/c23723399ccedf7f5744b3f40997b79246bfbe64), [`38380b6`](https://github.com/mastra-ai/mastra/commit/38380b60fca905824bdf6b43df307a58efb1aa15), [`6833c69`](https://github.com/mastra-ai/mastra/commit/6833c69607418d257750bbcdd84638993d343539), [`932d63d`](https://github.com/mastra-ai/mastra/commit/932d63dd51be9c8bf1e00e3671fe65606c6fb9cd), [`4a1a6cb`](https://github.com/mastra-ai/mastra/commit/4a1a6cb3facad54b2bb6780b00ce91d6de1edc08), [`08c31c1`](https://github.com/mastra-ai/mastra/commit/08c31c188ebccd598acaf55e888b6397d01f7eae), [`919a22b`](https://github.com/mastra-ai/mastra/commit/919a22b25876f9ed5891efe5facbe682c30ff497), [`15f9e21`](https://github.com/mastra-ai/mastra/commit/15f9e216177201ea6e3f6d0bfb063fcc0953444f), [`3443770`](https://github.com/mastra-ai/mastra/commit/3443770662df8eb24c9df3589b2792d78cfcb811), [`69136e7`](https://github.com/mastra-ai/mastra/commit/69136e748e32f57297728a4e0f9a75988462f1a7), [`b0e2ea5`](https://github.com/mastra-ai/mastra/commit/b0e2ea5b52c40fae438b9e2f7baee6f0f89c5442), [`f0a07e0`](https://github.com/mastra-ai/mastra/commit/f0a07e0111b3307c5fabfa4094c5c2cfb734fbe6), [`ff94dea`](https://github.com/mastra-ai/mastra/commit/ff94dea935f4e34545c63bcb6c29804732698809), [`0d41fe2`](https://github.com/mastra-ai/mastra/commit/0d41fe245355dfc66d61a0d9c85d9400aac351ff), [`b760b73`](https://github.com/mastra-ai/mastra/commit/b760b731aca7c8a3f041f61d57a7f125ae9cb215), [`aaa40e7`](https://github.com/mastra-ai/mastra/commit/aaa40e788628b319baa8e889407d11ad626547fa), [`1521d71`](https://github.com/mastra-ai/mastra/commit/1521d716e5daedc74690c983fbd961123c56756b), [`449aed2`](https://github.com/mastra-ai/mastra/commit/449aed2ba9d507b75bf93d427646ea94f734dfd1), [`eb648a2`](https://github.com/mastra-ai/mastra/commit/eb648a2cc1728f7678768dd70cd77619b448dab9), [`695a621`](https://github.com/mastra-ai/mastra/commit/695a621528bdabeb87f83c2277cf2bb084c7f2b4), [`9e1911d`](https://github.com/mastra-ai/mastra/commit/9e1911db2b4db85e0e768c3f15e0d61e319869f6), [`ac3cc23`](https://github.com/mastra-ai/mastra/commit/ac3cc2397d1966bc0fc2736a223abc449d3c7719), [`c456e01`](https://github.com/mastra-ai/mastra/commit/c456e0149e3c176afcefdbd9bb1d2c5917723725), [`ebac155`](https://github.com/mastra-ai/mastra/commit/ebac15564a590117db7078233f927a7e28a85106), [`a86f4df`](https://github.com/mastra-ai/mastra/commit/a86f4df0407311e0d2ea49b9a541f0938810d6a9), [`dd1c38d`](https://github.com/mastra-ai/mastra/commit/dd1c38d1b75f1b695c27b40d8d9d6ed00d5e0f6f), [`5948e6a`](https://github.com/mastra-ai/mastra/commit/5948e6a5146c83666ba3f294b2be576c82a513fb), [`5b2ff46`](https://github.com/mastra-ai/mastra/commit/5b2ff4651df70c146523a7fca773f8eb0a2272f8), [`edb07e4`](https://github.com/mastra-ai/mastra/commit/edb07e49283e0c28bd094a60e03439bf6ecf0221), [`e0941c3`](https://github.com/mastra-ai/mastra/commit/e0941c3d7fc75695d5d258e7008fd5d6e650800c), [`db41688`](https://github.com/mastra-ai/mastra/commit/db4168806d007417e2e60b4f68656dca4e5f40c9), [`2b459f4`](https://github.com/mastra-ai/mastra/commit/2b459f466fd91688eeb2a44801dc23f7f8a887ab), [`798d0c7`](https://github.com/mastra-ai/mastra/commit/798d0c740232653b1d754870e6b43a55c364ffe2), [`0c0580a`](https://github.com/mastra-ai/mastra/commit/0c0580a42f697cd2a7d5973f25bfe7da9055038a), [`8940859`](https://github.com/mastra-ai/mastra/commit/89408593658199b4ad67f7b65e888f344e64a442), [`486352b`](https://github.com/mastra-ai/mastra/commit/486352b66c746602b68a95839f830de14c7fb8c0), [`ab035c2`](https://github.com/mastra-ai/mastra/commit/ab035c2ef6d8cc7bb25f06f1a38508bd9e6f126b), [`e629310`](https://github.com/mastra-ai/mastra/commit/e629310f1a73fa236d49ec7a1d1cceb6229dc7cc), [`0131105`](https://github.com/mastra-ai/mastra/commit/0131105532e83bdcbb73352fc7d0879eebf140dc), [`5ca599d`](https://github.com/mastra-ai/mastra/commit/5ca599d0bb59a1595f19f58473fcd67cc71cef58), [`09e4bae`](https://github.com/mastra-ai/mastra/commit/09e4bae18dd5357d2ae078a4a95a2af32168ab08), [`47b1c16`](https://github.com/mastra-ai/mastra/commit/47b1c16a01c7ffb6765fe1e499b49092f8b7eba3), [`4c6b492`](https://github.com/mastra-ai/mastra/commit/4c6b492c4dd591c6a592520c1f6855d6e936d71f), [`bff1145`](https://github.com/mastra-ai/mastra/commit/bff114556b3cbadad9b2768488708f8ad0e91475), [`dff01d8`](https://github.com/mastra-ai/mastra/commit/dff01d81ce1f4e4087cfac20fa868e6db138dd14), [`9d5059e`](https://github.com/mastra-ai/mastra/commit/9d5059eae810829935fb08e81a9bb7ecd5b144a7), [`ffe84d5`](https://github.com/mastra-ai/mastra/commit/ffe84d54f3b0f85167fe977efd027dba027eb998), [`5c8ca24`](https://github.com/mastra-ai/mastra/commit/5c8ca247094e0cc2cdbd7137822fb47241f86e77), [`9d819d5`](https://github.com/mastra-ai/mastra/commit/9d819d54b61481639f4008e4694791bddf187edd), [`24b76d8`](https://github.com/mastra-ai/mastra/commit/24b76d8e17656269c8ed09a0c038adb9cc2ae95a), [`31d13d5`](https://github.com/mastra-ai/mastra/commit/31d13d5fdc2e2380e2e3ee3ec9fb29d2a00f265d), [`ef756c6`](https://github.com/mastra-ai/mastra/commit/ef756c65f82d16531c43f49a27290a416611e526), [`e191844`](https://github.com/mastra-ai/mastra/commit/e1918444ca3f80e82feef1dad506cd4ec6e2875f), [`243a823`](https://github.com/mastra-ai/mastra/commit/243a8239c5906f5c94e4f78b54676793f7510ae3), [`b00ccd3`](https://github.com/mastra-ai/mastra/commit/b00ccd325ebd5d9e37e34dd0a105caae67eb568f), [`28f5f89`](https://github.com/mastra-ai/mastra/commit/28f5f89705f2409921e3c45178796c0e0d0bbb64), [`22553f1`](https://github.com/mastra-ai/mastra/commit/22553f11c63ee5e966a9c034a349822249584691), [`4c62166`](https://github.com/mastra-ai/mastra/commit/4c621669f4a29b1f443eca3ba70b814afa286266), [`e601b27`](https://github.com/mastra-ai/mastra/commit/e601b272c70f3a5ecca610373aa6223012704892), [`7d56d92`](https://github.com/mastra-ai/mastra/commit/7d56d9213886e8353956d7d40df10045fd12b299), [`81dc110`](https://github.com/mastra-ai/mastra/commit/81dc11008d147cf5bdc8996ead1aa61dbdebb6fc), [`7bcbf10`](https://github.com/mastra-ai/mastra/commit/7bcbf10133516e03df964b941f9a34e9e4ab4177), [`029540c`](https://github.com/mastra-ai/mastra/commit/029540ca1e582fc2dd8d288ecd4a9b0f31a954ef), [`7237163`](https://github.com/mastra-ai/mastra/commit/72371635dbf96a87df4b073cc48fc655afbdce3d), [`2500740`](https://github.com/mastra-ai/mastra/commit/2500740ea23da067d6e50ec71c625ab3ce275e64), [`4353600`](https://github.com/mastra-ai/mastra/commit/43536005a65988a8eede236f69122e7f5a284ba2), [`653e65a`](https://github.com/mastra-ai/mastra/commit/653e65ae1f9502c2958a32f47a5a2df11e612a92), [`873ecbb`](https://github.com/mastra-ai/mastra/commit/873ecbb517586aa17d2f1e99283755b3ebb2863f), [`6986fb0`](https://github.com/mastra-ai/mastra/commit/6986fb064f5db6ecc24aa655e1d26529087b43b3), [`3d3366f`](https://github.com/mastra-ai/mastra/commit/3d3366f31683e7137d126a3a57174a222c5801fb), [`5a4953f`](https://github.com/mastra-ai/mastra/commit/5a4953f7d25bb15ca31ed16038092a39cb3f98b3), [`4f9bbe5`](https://github.com/mastra-ai/mastra/commit/4f9bbe5968f42c86f4930b8193de3c3c17e5bd36), [`efe406a`](https://github.com/mastra-ai/mastra/commit/efe406a1353c24993280ebc2ed61dd9f65b84b26), [`eb9e522`](https://github.com/mastra-ai/mastra/commit/eb9e522ce3070a405e5b949b7bf5609ca51d7fe2), [`fd3d338`](https://github.com/mastra-ai/mastra/commit/fd3d338a2c362174ed5b383f1f011ad9fb0302aa), [`20e6f19`](https://github.com/mastra-ai/mastra/commit/20e6f1971d51d3ff6dd7accad8aaaae826d540ed), [`053e979`](https://github.com/mastra-ai/mastra/commit/053e9793b28e970086b0507f7f3b76ea32c1e838), [`02e51fe`](https://github.com/mastra-ai/mastra/commit/02e51feddb3d4155cfbcc42624fd0d0970d032c0), [`71c8d6c`](https://github.com/mastra-ai/mastra/commit/71c8d6c161253207b2b9588bdadb7eed604f7253), [`7aedb74`](https://github.com/mastra-ai/mastra/commit/7aedb74883adf66af38e270e4068fd42e7a37036), [`3bdfa75`](https://github.com/mastra-ai/mastra/commit/3bdfa7507a91db66f176ba8221aa28dd546e464a), [`119e5c6`](https://github.com/mastra-ai/mastra/commit/119e5c65008f3e5cfca954eefc2eb85e3bf40da4), [`c6fd6fe`](https://github.com/mastra-ai/mastra/commit/c6fd6fedd09e9cf8004b03a80925f5e94826ad7e), [`8f02d80`](https://github.com/mastra-ai/mastra/commit/8f02d800777397e4b45d7f1ad041988a8b0c6630), [`fdac646`](https://github.com/mastra-ai/mastra/commit/fdac646033a0930a1a4e00d13aa64c40bb7f1e02), [`6179a9b`](https://github.com/mastra-ai/mastra/commit/6179a9ba36ffac326de3cc3c43cdc8028d37c251), [`8f3fa3a`](https://github.com/mastra-ai/mastra/commit/8f3fa3a652bb77da092f913ec51ae46e3a7e27dc), [`d07b568`](https://github.com/mastra-ai/mastra/commit/d07b5687819ea8cb1dffa776d0c1765faf4aa1ae), [`e770de9`](https://github.com/mastra-ai/mastra/commit/e770de941a287a49b1964d44db5a5763d19890a6), [`e26dc9c`](https://github.com/mastra-ai/mastra/commit/e26dc9c3ccfec54ae3dc3e2b2589f741f9ae60a6), [`55edf73`](https://github.com/mastra-ai/mastra/commit/55edf7302149d6c964fbb7908b43babfc2b52145), [`c30400a`](https://github.com/mastra-ai/mastra/commit/c30400a49b994b1b97256fe785eb6c906fc2b232), [`486352b`](https://github.com/mastra-ai/mastra/commit/486352b66c746602b68a95839f830de14c7fb8c0), [`00f4921`](https://github.com/mastra-ai/mastra/commit/00f4921dd2c91a1e5446799599ef7116a8214a1a), [`1a46a56`](https://github.com/mastra-ai/mastra/commit/1a46a566f45a3fcbadc1cf36bf86d351f264bfa3), [`ca8041c`](https://github.com/mastra-ai/mastra/commit/ca8041cce0379fda22ed293a565bcb5b6ddca68a), [`b5dc973`](https://github.com/mastra-ai/mastra/commit/b5dc9733a5158850298dfb103acb3babdba8a318), [`7051bf3`](https://github.com/mastra-ai/mastra/commit/7051bf38b3b122a069008f861f7bfc004a6d9f6e), [`a8f1494`](https://github.com/mastra-ai/mastra/commit/a8f1494f4bbdc2770bcf327d4c7d869e332183f1), [`52e2716`](https://github.com/mastra-ai/mastra/commit/52e2716b42df6eff443de72360ae83e86ec23993), [`d7aad50`](https://github.com/mastra-ai/mastra/commit/d7aad501ce61646b76b4b511e558ac4eea9884d0), [`4f0b3c6`](https://github.com/mastra-ai/mastra/commit/4f0b3c66f196c06448487f680ccbb614d281e2f7), [`27b4040`](https://github.com/mastra-ai/mastra/commit/27b4040bfa1a95d92546f420a02a626b1419a1d6), [`c61fac3`](https://github.com/mastra-ai/mastra/commit/c61fac3add96f0dcce0208c07415279e2537eb62), [`6f14f70`](https://github.com/mastra-ai/mastra/commit/6f14f706ccaaf81b69544b6c1b75ab66a41e5317), [`69e0a87`](https://github.com/mastra-ai/mastra/commit/69e0a878896a2da9494945d86e056a5f8f05b851), [`cd29ad2`](https://github.com/mastra-ai/mastra/commit/cd29ad23a255534e8191f249593849ed29160886), [`bdf4d8c`](https://github.com/mastra-ai/mastra/commit/bdf4d8cdc656d8a2c21d81834bfa3bfa70f56c16), [`854e3da`](https://github.com/mastra-ai/mastra/commit/854e3dad5daac17a91a20986399d3a51f54bf68b), [`ce18d38`](https://github.com/mastra-ai/mastra/commit/ce18d38678c65870350d123955014a8432075fd9), [`3cf540b`](https://github.com/mastra-ai/mastra/commit/3cf540b9fbfea8f4fc8d3a2319a4e6c0b0cbfd52), [`352a5d6`](https://github.com/mastra-ai/mastra/commit/352a5d625cfe09849b21e8f52a24c9f0366759d5), [`1c6ce51`](https://github.com/mastra-ai/mastra/commit/1c6ce51f875915ab57fd36873623013699a2a65d), [`74c4f22`](https://github.com/mastra-ai/mastra/commit/74c4f22ed4c71e72598eacc346ba95cdbc00294f), [`3a76a80`](https://github.com/mastra-ai/mastra/commit/3a76a80284cb71a0faa975abb3d4b2a9631e60cd), [`898a972`](https://github.com/mastra-ai/mastra/commit/898a9727d286c2510d6b702dfd367e6aaf5c6b0f), [`0793497`](https://github.com/mastra-ai/mastra/commit/079349753620c40246ffd673e3f9d7d9820beff3), [`09e4bae`](https://github.com/mastra-ai/mastra/commit/09e4bae18dd5357d2ae078a4a95a2af32168ab08), [`026b848`](https://github.com/mastra-ai/mastra/commit/026b8483fbf5b6d977be8f7e6aac8d15c75558ac), [`2c212e7`](https://github.com/mastra-ai/mastra/commit/2c212e704c90e2db83d4109e62c03f0f6ebd2667), [`a97003a`](https://github.com/mastra-ai/mastra/commit/a97003aa1cf2f4022a41912324a1e77263b326b8), [`f9a2509`](https://github.com/mastra-ai/mastra/commit/f9a25093ea72d210a5e52cfcb3bcc8b5e02dc25c), [`66741d1`](https://github.com/mastra-ai/mastra/commit/66741d1a99c4f42cf23a16109939e8348ac6852e), [`ccc141e`](https://github.com/mastra-ai/mastra/commit/ccc141ed27da0abc3a3fc28e9e5128152e8e37f4), [`27c0009`](https://github.com/mastra-ai/mastra/commit/27c0009777a6073d7631b0eb7b481d94e165b5ca), [`01f8878`](https://github.com/mastra-ai/mastra/commit/01f88783de25e4de048c1c8aace43e26373c6ea5), [`dee388d`](https://github.com/mastra-ai/mastra/commit/dee388dde02f2e63c53385ae69252a47ab6825cc), [`610a70b`](https://github.com/mastra-ai/mastra/commit/610a70bdad282079f0c630e0d7bb284578f20151), [`5df9cce`](https://github.com/mastra-ai/mastra/commit/5df9cce1a753438413f64c11eeef8f845745c2a8), [`b7e17d3`](https://github.com/mastra-ai/mastra/commit/b7e17d3f5390bb5a71efc112204413656fcdc18d), [`4c77209`](https://github.com/mastra-ai/mastra/commit/4c77209e6c11678808b365d545845918c40045c8), [`a854ede`](https://github.com/mastra-ai/mastra/commit/a854ede62bf5ac0945a624ac48913dd69c73aabf), [`fe3b897`](https://github.com/mastra-ai/mastra/commit/fe3b897c2ccbcd2b10e81b099438c7337feddf89), [`c576fc0`](https://github.com/mastra-ai/mastra/commit/c576fc0b100b2085afded91a37c97a0ea0ec09c7), [`3defc80`](https://github.com/mastra-ai/mastra/commit/3defc80cf2b88a1b7fc1cc4ddcb91e982a614609), [`00123ba`](https://github.com/mastra-ai/mastra/commit/00123ba96dc9e5cd0b110420ebdba56d8f237b25), [`16153fe`](https://github.com/mastra-ai/mastra/commit/16153fe7eb13c99401f48e6ca32707c965ee28b9), [`9f4a683`](https://github.com/mastra-ai/mastra/commit/9f4a6833e88b52574665c028fd5508ad5c2f6004), [`bc94344`](https://github.com/mastra-ai/mastra/commit/bc943444a1342d8a662151b7bce1df7dae32f59c), [`4ca4306`](https://github.com/mastra-ai/mastra/commit/4ca430614daa5fa04730205a302a43bf4accfe9f), [`cccf9c8`](https://github.com/mastra-ai/mastra/commit/cccf9c8b2d2dfc1a5e63919395b83d78c89682a0), [`74e504a`](https://github.com/mastra-ai/mastra/commit/74e504a3b584eafd2f198001c6a113bbec589fd3), [`29c4309`](https://github.com/mastra-ai/mastra/commit/29c4309f818b24304c041bcb4a8f19b5f13f6b62), [`16785ce`](https://github.com/mastra-ai/mastra/commit/16785ced928f6f22638f4488cf8a125d99211799), [`57d157f`](https://github.com/mastra-ai/mastra/commit/57d157f0b163a95c3e6c9eae31bdb11d1bfc64f9), [`61a5705`](https://github.com/mastra-ai/mastra/commit/61a570551278b6743e64243b3ce7d73de915ca8a), [`903f67d`](https://github.com/mastra-ai/mastra/commit/903f67d184504a273893818c02b961f5423a79ad), [`3f3fc30`](https://github.com/mastra-ai/mastra/commit/3f3fc3096f24c4a26cffeecfe73085928f72aa63), [`d827d08`](https://github.com/mastra-ai/mastra/commit/d827d0808ffe1f3553a84e975806cc989b9735dd), [`e33fdbd`](https://github.com/mastra-ai/mastra/commit/e33fdbd07b33920d81e823122331b0c0bee0bb59), [`4524734`](https://github.com/mastra-ai/mastra/commit/45247343e384717a7c8404296275c56201d6470f), [`7a010c5`](https://github.com/mastra-ai/mastra/commit/7a010c56b846a313a49ae42fccd3d8de2b9f292d), [`2a90c55`](https://github.com/mastra-ai/mastra/commit/2a90c55a86a9210697d5adaab5ee94584b079adc), [`2a53598`](https://github.com/mastra-ai/mastra/commit/2a53598c6d8cfeb904a7fc74e57e526d751c8fa6), [`81b6a8f`](https://github.com/mastra-ai/mastra/commit/81b6a8ff79f49a7549d15d66624ac1a0b8f5f971), [`8538a0d`](https://github.com/mastra-ai/mastra/commit/8538a0d232619bf55dad7ddc2a8b0ca77c679a87), [`d90ea65`](https://github.com/mastra-ai/mastra/commit/d90ea6536f7aa51c6545a4e9215b55858e98e16d), [`db70a48`](https://github.com/mastra-ai/mastra/commit/db70a48aeeeeb8e5f92007e8ede52c364ce15287), [`261473a`](https://github.com/mastra-ai/mastra/commit/261473ac637e633064a22076671e2e02b002214d), [`eb09742`](https://github.com/mastra-ai/mastra/commit/eb09742197f66c4c38154c3beec78313e69760b2), [`de8239b`](https://github.com/mastra-ai/mastra/commit/de8239bdcb1d8c0cfa06da21f1569912a66bbc8a), [`e4d366a`](https://github.com/mastra-ai/mastra/commit/e4d366aeb500371dd4210d6aa8361a4c21d87034), [`23c10a1`](https://github.com/mastra-ai/mastra/commit/23c10a1efdd9a693c405511ab2dc8a1236603162), [`b5e6cd7`](https://github.com/mastra-ai/mastra/commit/b5e6cd77fc8c8e64e0494c1d06cee3d84e795d1e), [`d171e55`](https://github.com/mastra-ai/mastra/commit/d171e559ead9f52ec728d424844c8f7b164c4510), [`f0fdc14`](https://github.com/mastra-ai/mastra/commit/f0fdc14ee233d619266b3d2bbdeea7d25cfc6d13), [`a4f010b`](https://github.com/mastra-ai/mastra/commit/a4f010b22e4355a5fdee70a1fe0f6e4a692cc29e), [`c7cd3c7`](https://github.com/mastra-ai/mastra/commit/c7cd3c7a187d7aaf79e2ca139de328bf609a14b4), [`db18bc9`](https://github.com/mastra-ai/mastra/commit/db18bc9c3825e2c1a0ad9a183cc9935f6691bfa1), [`96d35f6`](https://github.com/mastra-ai/mastra/commit/96d35f61376bc2b1bf148648a2c1985bd51bef55), [`68ec97d`](https://github.com/mastra-ai/mastra/commit/68ec97d4c07c6393fcf95c2481fc5d73da99f8c8), [`8dc7f55`](https://github.com/mastra-ai/mastra/commit/8dc7f55900395771da851dc7d78d53ae84fe34ec), [`cfabdd4`](https://github.com/mastra-ai/mastra/commit/cfabdd4aae7a726b706942d6836eeca110fb6267), [`9b37b56`](https://github.com/mastra-ai/mastra/commit/9b37b565e1f2a76c24f728945cc740c2b09be9da), [`01b20fe`](https://github.com/mastra-ai/mastra/commit/01b20fefb7c67c2b7d79417598ef4e60256d1225), [`dd4f34c`](https://github.com/mastra-ai/mastra/commit/dd4f34c78cbae24063463475b0619575c415f9b8), [`8379099`](https://github.com/mastra-ai/mastra/commit/8379099fc467af6bef54dd7f80c9bd75bf8bbddf), [`0dbf199`](https://github.com/mastra-ai/mastra/commit/0dbf199110f22192ce5c95b1c8148d4872b4d119), [`5cbe88a`](https://github.com/mastra-ai/mastra/commit/5cbe88aefbd9f933bca669fd371ea36bf939ac6d), [`41a23c3`](https://github.com/mastra-ai/mastra/commit/41a23c32f9877d71810f37e24930515df2ff7a0f), [`a1bd7b8`](https://github.com/mastra-ai/mastra/commit/a1bd7b8571db16b94eb01588f451a74758c96d65), [`d78b38d`](https://github.com/mastra-ai/mastra/commit/d78b38d898fce285260d3bbb4befade54331617f), [`a0a5b4b`](https://github.com/mastra-ai/mastra/commit/a0a5b4bbebe6c701ebbadf744873aa0d5ca01371), [`ce0a73a`](https://github.com/mastra-ai/mastra/commit/ce0a73abeaa75b10ca38f9e40a255a645d50ebfb), [`5d171ad`](https://github.com/mastra-ai/mastra/commit/5d171ad9ef340387276b77c2bb3e83e83332d729), [`0633100`](https://github.com/mastra-ai/mastra/commit/0633100a911ad22f5256471bdf753da21c104742), [`3759cb0`](https://github.com/mastra-ai/mastra/commit/3759cb064935b5f74c65ac2f52a1145f7352899d), [`929f69c`](https://github.com/mastra-ai/mastra/commit/929f69c3436fa20dd0f0e2f7ebe8270bd82a1529), [`c710c16`](https://github.com/mastra-ai/mastra/commit/c710c1652dccfdc4111c8412bca7a6bb1d48b441), [`10c2735`](https://github.com/mastra-ai/mastra/commit/10c27355edfdad1ee2b826b897df74125eb81fb8), [`354ad0b`](https://github.com/mastra-ai/mastra/commit/354ad0b7b1b8183ac567f236a884fc7ede6d7138), [`cfae733`](https://github.com/mastra-ai/mastra/commit/cfae73394f4920635e6c919c8e95ff9a0788e2e5), [`8c0ec25`](https://github.com/mastra-ai/mastra/commit/8c0ec25646c8a7df253ed1e5ff4863a0d3f1316c), [`e3dfda7`](https://github.com/mastra-ai/mastra/commit/e3dfda7b11bf3b8c4bb55637028befb5f387fc74), [`69ea758`](https://github.com/mastra-ai/mastra/commit/69ea758358edd7117f191c2e69c8bb5fc79e7a1a), [`73b0bb3`](https://github.com/mastra-ai/mastra/commit/73b0bb394dba7c9482eb467a97ab283dbc0ef4db), [`651e772`](https://github.com/mastra-ai/mastra/commit/651e772eb1475fb13e126d3fcc01751297a88214), [`a02e542`](https://github.com/mastra-ai/mastra/commit/a02e542d23179bad250b044b17ff023caa61739f), [`f03ae60`](https://github.com/mastra-ai/mastra/commit/f03ae60500fe350c9d828621006cdafe1975fdd8), [`6b3ba91`](https://github.com/mastra-ai/mastra/commit/6b3ba91494cc10394df96782f349a4f7b1e152cc), [`a372c64`](https://github.com/mastra-ai/mastra/commit/a372c640ad1fd12e8f0613cebdc682fc156b4d95), [`993ad98`](https://github.com/mastra-ai/mastra/commit/993ad98d7ad3bebda9ecef5fec5c94349a0d04bc), [`676ccc7`](https://github.com/mastra-ai/mastra/commit/676ccc7fe92468d2d45d39c31a87825c89fd1ea0), [`3ff2c17`](https://github.com/mastra-ai/mastra/commit/3ff2c17a58e312fad5ea37377262c12d92ca0908), [`a0e437f`](https://github.com/mastra-ai/mastra/commit/a0e437fac561b28ee719e0302d72b2f9b4c138f0), [`d1e74a0`](https://github.com/mastra-ai/mastra/commit/d1e74a0a293866dece31022047f5dbab65a304d0), [`844ea5d`](https://github.com/mastra-ai/mastra/commit/844ea5dc0c248961e7bf73629ae7dcff503e853c), [`5627a8c`](https://github.com/mastra-ai/mastra/commit/5627a8c6dc11fe3711b3fa7a6ffd6eb34100a306), [`398fde3`](https://github.com/mastra-ai/mastra/commit/398fde3f39e707cda79372cdae8f9870e3b57c8d), [`c10398d`](https://github.com/mastra-ai/mastra/commit/c10398d5b88f1d4af556f4267ff06f1d11e89179), [`3ff45d1`](https://github.com/mastra-ai/mastra/commit/3ff45d10e0c80c5335a957ab563da72feb623520), [`f0f8f12`](https://github.com/mastra-ai/mastra/commit/f0f8f125c308f2d0fd36942ef652fd852df7522f), [`b61b93f`](https://github.com/mastra-ai/mastra/commit/b61b93f9e058b11dd2eec169853175d31dbdd567), [`bae33d9`](https://github.com/mastra-ai/mastra/commit/bae33d91a63fbb64d1e80519e1fc1acaed1e9013), [`39e7869`](https://github.com/mastra-ai/mastra/commit/39e7869bc7d0ee391077ce291474d8a84eedccff), [`0d7618b`](https://github.com/mastra-ai/mastra/commit/0d7618bc650bf2800934b243eca5648f4aeed9c2), [`7b763e5`](https://github.com/mastra-ai/mastra/commit/7b763e52fc3eaf699c2a99f2adf418dd46e4e9a5), [`251df45`](https://github.com/mastra-ai/mastra/commit/251df4531407dfa46d805feb40ff3fb49769f455), [`d36cfbb`](https://github.com/mastra-ai/mastra/commit/d36cfbbb6565ba5f827883cc9bb648eb14befdc1), [`f894d14`](https://github.com/mastra-ai/mastra/commit/f894d148946629af7b1f452d65a9cf864cec3765), [`8846867`](https://github.com/mastra-ai/mastra/commit/8846867ffa9a3746767618e314bebac08eb77d87), [`1924cf0`](https://github.com/mastra-ai/mastra/commit/1924cf06816e5e4d4d5333065ec0f4bb02a97799), [`c0b731f`](https://github.com/mastra-ai/mastra/commit/c0b731fb27d712dc8582e846df5c0332a6a0c5ba), [`5761926`](https://github.com/mastra-ai/mastra/commit/57619260c4a2cdd598763abbacd90de594c6bc76), [`c2b9547`](https://github.com/mastra-ai/mastra/commit/c2b9547bf435f56339f23625a743b2147ab1c7a6), [`3697853`](https://github.com/mastra-ai/mastra/commit/3697853deeb72017d90e0f38a93c1e29221aeca0), [`c900fdd`](https://github.com/mastra-ai/mastra/commit/c900fdd504c41348efdffb205cfe80d48c38fa33), [`9312dcd`](https://github.com/mastra-ai/mastra/commit/9312dcd1c6f5b321929e7d382e763d95fdc030f5), [`b2e45ec`](https://github.com/mastra-ai/mastra/commit/b2e45eca727a8db01a81ba93f1a5219c7183c839), [`5d7000f`](https://github.com/mastra-ai/mastra/commit/5d7000f757cd65ea9dc5b05e662fd83dfd44e932), [`43ca8f2`](https://github.com/mastra-ai/mastra/commit/43ca8f2c7334851cc7b4d3d2f037d8784bfbdd5f), [`d6d49f7`](https://github.com/mastra-ai/mastra/commit/d6d49f7b8714fa19a52ff9c7cf7fb7e73751901e), [`00c2387`](https://github.com/mastra-ai/mastra/commit/00c2387f5f04a365316f851e58666ac43f8c4edf), [`a534e95`](https://github.com/mastra-ai/mastra/commit/a534e9591f83b3cc1ebff99c67edf4cda7bf81d3), [`9d0e7fe`](https://github.com/mastra-ai/mastra/commit/9d0e7feca8ed98de959f53476ee1456073673348), [`53d927c`](https://github.com/mastra-ai/mastra/commit/53d927cc6f03bff33655b7e2b788da445a08731d), [`ad6250d`](https://github.com/mastra-ai/mastra/commit/ad6250dbdaad927e29f74a27b83f6c468b50a705), [`580b592`](https://github.com/mastra-ai/mastra/commit/580b5927afc82fe460dfdf9a38a902511b6b7e7f), [`604a79f`](https://github.com/mastra-ai/mastra/commit/604a79fecf276e26a54a3fe01bb94e65315d2e0e), [`42a42cf`](https://github.com/mastra-ai/mastra/commit/42a42cf3132b9786feecbb8c13c583dce5b0e198), [`3f2faf2`](https://github.com/mastra-ai/mastra/commit/3f2faf2e2d685d6c053cc5af1bf9fedf267b2ce5), [`22f64bc`](https://github.com/mastra-ai/mastra/commit/22f64bc1d37149480b58bf2fefe35b79a1e3e7d5), [`ff4d9a6`](https://github.com/mastra-ai/mastra/commit/ff4d9a6704fc87b31a380a76ed22736fdedbba5a), [`50fd320`](https://github.com/mastra-ai/mastra/commit/50fd320003d0d93831c230ef531bef41f5ba7b3a), [`847c212`](https://github.com/mastra-ai/mastra/commit/847c212caba7df0d6f2fc756b494ac3c75c3720d), [`69821ef`](https://github.com/mastra-ai/mastra/commit/69821ef806482e2c44e2197ac0b050c3fe3a5285), [`3a73998`](https://github.com/mastra-ai/mastra/commit/3a73998fa4ebeb7f3dc9301afe78095fc63e7999), [`ffa553a`](https://github.com/mastra-ai/mastra/commit/ffa553a3edc1bd17d73669fba66d6b6f4ac10897), [`83d5942`](https://github.com/mastra-ai/mastra/commit/83d5942669ce7bba4a6ca4fd4da697a10eb5ebdc), [`58e3931`](https://github.com/mastra-ai/mastra/commit/58e3931af9baa5921688566210f00fb0c10479fa), [`ae08bf0`](https://github.com/mastra-ai/mastra/commit/ae08bf0ebc6a4e4da992b711c4a389c32ba84cf4), [`0bed332`](https://github.com/mastra-ai/mastra/commit/0bed332843f627202c6520eaf671771313cd20f3), [`887f0b4`](https://github.com/mastra-ai/mastra/commit/887f0b4746cdbd7cb7d6b17ac9f82aeb58037ea5), [`2562143`](https://github.com/mastra-ai/mastra/commit/256214336b4faa78646c9c1776612393790d8784), [`b7959e6`](https://github.com/mastra-ai/mastra/commit/b7959e6e25a46b480f9ea2217c4c6c588c423791), [`a7ce182`](https://github.com/mastra-ai/mastra/commit/a7ce1822a8785ce45d62dd5c911af465e144f7d7), [`bda6370`](https://github.com/mastra-ai/mastra/commit/bda637009360649aaf579919e7873e33553c273e), [`d7acd8e`](https://github.com/mastra-ai/mastra/commit/d7acd8e987b5d7eff4fd98b0906c17c06a2e83d5), [`c7f1f7d`](https://github.com/mastra-ai/mastra/commit/c7f1f7d24f61f247f018cc2d1f33bf63212959a7), [`0bddc6d`](https://github.com/mastra-ai/mastra/commit/0bddc6d8dbd6f6008c0cba2e4960a2da75a55af1), [`bec5efd`](https://github.com/mastra-ai/mastra/commit/bec5efde96653ccae6604e68c696d1bc6c1a0bf5), [`5947fcd`](https://github.com/mastra-ai/mastra/commit/5947fcdd425531f29f9422026d466c2ee3113c93), [`4aa55b3`](https://github.com/mastra-ai/mastra/commit/4aa55b383cf06043943359ea316572fd969861a7), [`21735a7`](https://github.com/mastra-ai/mastra/commit/21735a7ef306963554a69a89b44f06c3bcd85141), [`735d8c1`](https://github.com/mastra-ai/mastra/commit/735d8c1c0d19fbc09e6f8b66cf41bc7655993838), [`7907fd1`](https://github.com/mastra-ai/mastra/commit/7907fd1c5059813b7b870b81ca71041dc807331b), [`1ed5716`](https://github.com/mastra-ai/mastra/commit/1ed5716830867b3774c4a1b43cc0d82935f32b96), [`acf322e`](https://github.com/mastra-ai/mastra/commit/acf322e0f1fd0189684cf529d91c694bea918a45), [`2ca67cc`](https://github.com/mastra-ai/mastra/commit/2ca67cc3bb1f6a617353fdcab197d9efebe60d6f), [`9eedf7d`](https://github.com/mastra-ai/mastra/commit/9eedf7de1d6e0022a2f4e5e9e6fe1ec468f9b43c), [`b339816`](https://github.com/mastra-ai/mastra/commit/b339816df0984d0243d944ac2655d6ba5f809cde), [`e16d553`](https://github.com/mastra-ai/mastra/commit/e16d55338403c7553531cc568125c63d53653dff), [`6f941c4`](https://github.com/mastra-ai/mastra/commit/6f941c438ca5f578619788acc7608fc2e23bd176), [`4186bdd`](https://github.com/mastra-ai/mastra/commit/4186bdd00731305726fa06adba0b076a1d50b49f), [`08bb631`](https://github.com/mastra-ai/mastra/commit/08bb631ae2b14684b2678e3549d0b399a6f0561e), [`c942802`](https://github.com/mastra-ai/mastra/commit/c942802a477a925b01859a7b8688d4355715caaa), [`4f0331a`](https://github.com/mastra-ai/mastra/commit/4f0331a79bf6eb5ee598a5086e55de4b5a0ada03), [`a0c8c1b`](https://github.com/mastra-ai/mastra/commit/a0c8c1b87d4fee252aebda73e8637fbe01d761c9), [`1d877b8`](https://github.com/mastra-ai/mastra/commit/1d877b8d7b536a251c1a7a18db7ddcf4f68d6f8b), [`cc34739`](https://github.com/mastra-ai/mastra/commit/cc34739c34b6266a91bea561119240a7acf47887), [`c218bd3`](https://github.com/mastra-ai/mastra/commit/c218bd3759e32423735b04843a09404572631014), [`9e67002`](https://github.com/mastra-ai/mastra/commit/9e67002b52c9be19936c420a489dbee9c5fd6a78), [`7aaf973`](https://github.com/mastra-ai/mastra/commit/7aaf973f83fbbe9521f1f9e7a4fd99b8de464617), [`2c4438b`](https://github.com/mastra-ai/mastra/commit/2c4438b87817ab7eed818c7990fef010475af1a3), [`35edc49`](https://github.com/mastra-ai/mastra/commit/35edc49ac0556db609189641d6341e76771b81fc), [`4d59f58`](https://github.com/mastra-ai/mastra/commit/4d59f58de2d90d6e2810a19d4518e38ddddb9038), [`ef11a61`](https://github.com/mastra-ai/mastra/commit/ef11a61920fa0ed08a5b7ceedd192875af119749), [`2b8893c`](https://github.com/mastra-ai/mastra/commit/2b8893cb108ef9acb72ee7835cd625610d2c1a4a), [`8e5c75b`](https://github.com/mastra-ai/mastra/commit/8e5c75bdb1d08a42d45309a4c72def4b6890230f), [`e1bb9c9`](https://github.com/mastra-ai/mastra/commit/e1bb9c94b4eb68b019ae275981be3feb769b5365), [`351a11f`](https://github.com/mastra-ai/mastra/commit/351a11fcaf2ed1008977fa9b9a489fc422e51cd4), [`8a73529`](https://github.com/mastra-ai/mastra/commit/8a73529ca01187f604b1f3019d0a725ac63ae55f), [`e59e0d3`](https://github.com/mastra-ai/mastra/commit/e59e0d32afb5fcf2c9f3c00c8f81f6c21d3a63fa), [`4fba91b`](https://github.com/mastra-ai/mastra/commit/4fba91bec7c95911dc28e369437596b152b04cd0), [`465ac05`](https://github.com/mastra-ai/mastra/commit/465ac0526a91d175542091c675181f1a96c98c46), [`fa8409b`](https://github.com/mastra-ai/mastra/commit/fa8409bc39cfd8ba6643b9db5269b90b22e2a2f7), [`8a000da`](https://github.com/mastra-ai/mastra/commit/8a000da0c09c679a2312f6b3aa05b2ca78ca7393), [`e7266a2`](https://github.com/mastra-ai/mastra/commit/e7266a278db02035c97a5e9cd9d1669a6b7a535d), [`173c535`](https://github.com/mastra-ai/mastra/commit/173c535c0645b0da404fe09f003778f0b0d4e019), [`12b0cc4`](https://github.com/mastra-ai/mastra/commit/12b0cc4077d886b1a552637dedb70a7ade93528c), [`3bf6c5f`](https://github.com/mastra-ai/mastra/commit/3bf6c5f104c25226cd84e0c77f9dec15f2cac2db)]:
987
+ - @mastra/core@1.0.0
988
+
989
+ ## 1.0.0-beta.15
990
+
991
+ ### Patch Changes
992
+
993
+ - Fixed duplicate spans migration issue across all storage backends. When upgrading from older versions, existing duplicate (traceId, spanId) combinations in the spans table could prevent the unique constraint from being created. The migration deduplicates spans before adding the constraint. ([#12073](https://github.com/mastra-ai/mastra/pull/12073))
994
+
995
+ **Deduplication rules (in priority order):**
996
+ 1. Keep completed spans (those with `endedAt` set) over incomplete spans
997
+ 2. Among spans with the same completion status, keep the one with the newest `updatedAt`
998
+ 3. Use `createdAt` as the final tiebreaker
999
+
1000
+ **What changed:**
1001
+ - Added `migrateSpans()` method to observability stores for manual migration
1002
+ - Added `checkSpansMigrationStatus()` method to check if migration is needed
1003
+ - All stores use optimized single-query deduplication to avoid memory issues on large tables
1004
+
1005
+ **Usage example:**
1006
+
1007
+ ```typescript
1008
+ const observability = await storage.getStore('observability');
1009
+ const status = await observability.checkSpansMigrationStatus();
1010
+ if (status.needsMigration) {
1011
+ const result = await observability.migrateSpans();
1012
+ console.log(`Migration complete: ${result.duplicatesRemoved} duplicates removed`);
1013
+ }
1014
+ ```
1015
+
1016
+ Fixes #11840
1017
+
1018
+ - Renamed MastraStorage to MastraCompositeStore for better clarity. The old MastraStorage name remains available as a deprecated alias for backward compatibility, but will be removed in a future version. ([#12093](https://github.com/mastra-ai/mastra/pull/12093))
1019
+
1020
+ **Migration:**
1021
+
1022
+ Update your imports and usage:
1023
+
1024
+ ```typescript
1025
+ // Before
1026
+ import { MastraStorage } from '@mastra/core/storage';
1027
+
1028
+ const storage = new MastraStorage({
1029
+ id: 'composite',
1030
+ domains: { ... }
1031
+ });
1032
+
1033
+ // After
1034
+ import { MastraCompositeStore } from '@mastra/core/storage';
1035
+
1036
+ const storage = new MastraCompositeStore({
1037
+ id: 'composite',
1038
+ domains: { ... }
1039
+ });
1040
+ ```
1041
+
1042
+ The new name better reflects that this is a composite storage implementation that routes different domains (workflows, traces, messages) to different underlying stores, avoiding confusion with the general "Mastra Storage" concept.
1043
+
1044
+ - Updated dependencies [[`026b848`](https://github.com/mastra-ai/mastra/commit/026b8483fbf5b6d977be8f7e6aac8d15c75558ac), [`ffa553a`](https://github.com/mastra-ai/mastra/commit/ffa553a3edc1bd17d73669fba66d6b6f4ac10897)]:
1045
+ - @mastra/core@1.0.0-beta.26
1046
+
1047
+ ## 1.0.0-beta.14
1048
+
1049
+ ### Patch Changes
1050
+
1051
+ - Added new `listThreads` method for flexible thread filtering across all storage adapters. ([#11832](https://github.com/mastra-ai/mastra/pull/11832))
1052
+
1053
+ **New Features**
1054
+ - Filter threads by `resourceId`, `metadata`, or both (with AND logic for metadata key-value pairs)
1055
+ - All filter parameters are optional, allowing you to list all threads or filter as needed
1056
+ - Full pagination and sorting support
1057
+
1058
+ **Example Usage**
1059
+
1060
+ ```typescript
1061
+ // List all threads
1062
+ const allThreads = await memory.listThreads({});
1063
+
1064
+ // Filter by resourceId only
1065
+ const userThreads = await memory.listThreads({
1066
+ filter: { resourceId: 'user-123' },
1067
+ });
1068
+
1069
+ // Filter by metadata only
1070
+ const supportThreads = await memory.listThreads({
1071
+ filter: { metadata: { category: 'support' } },
1072
+ });
1073
+
1074
+ // Filter by both with pagination
1075
+ const filteredThreads = await memory.listThreads({
1076
+ filter: {
1077
+ resourceId: 'user-123',
1078
+ metadata: { priority: 'high', status: 'open' },
1079
+ },
1080
+ orderBy: { field: 'updatedAt', direction: 'DESC' },
1081
+ page: 0,
1082
+ perPage: 20,
1083
+ });
1084
+ ```
1085
+
1086
+ **Security Improvements**
1087
+ - Added validation to prevent SQL injection via malicious metadata keys
1088
+ - Added pagination parameter validation to prevent integer overflow attacks
1089
+
1090
+ - Updated dependencies [[`ed3e3dd`](https://github.com/mastra-ai/mastra/commit/ed3e3ddec69d564fe2b125e083437f76331f1283), [`6833c69`](https://github.com/mastra-ai/mastra/commit/6833c69607418d257750bbcdd84638993d343539), [`47b1c16`](https://github.com/mastra-ai/mastra/commit/47b1c16a01c7ffb6765fe1e499b49092f8b7eba3), [`3a76a80`](https://github.com/mastra-ai/mastra/commit/3a76a80284cb71a0faa975abb3d4b2a9631e60cd), [`8538a0d`](https://github.com/mastra-ai/mastra/commit/8538a0d232619bf55dad7ddc2a8b0ca77c679a87), [`9312dcd`](https://github.com/mastra-ai/mastra/commit/9312dcd1c6f5b321929e7d382e763d95fdc030f5)]:
1091
+ - @mastra/core@1.0.0-beta.25
1092
+
1093
+ ## 1.0.0-beta.13
1094
+
1095
+ ### Minor Changes
1096
+
1097
+ - Changed JSON columns from TEXT to JSONB in `mastra_threads` and `mastra_workflow_snapshot` tables. ([#11853](https://github.com/mastra-ai/mastra/pull/11853))
1098
+
1099
+ **Why this change?**
1100
+
1101
+ These were the last remaining columns storing JSON as TEXT. This change aligns them with other tables that already use JSONB, enabling native JSON operators and improved performance. See [#8978](https://github.com/mastra-ai/mastra/issues/8978) for details.
1102
+
1103
+ **Columns Changed:**
1104
+ - `mastra_threads.metadata` - Thread metadata
1105
+ - `mastra_workflow_snapshot.snapshot` - Workflow run state
1106
+
1107
+ **PostgreSQL**
1108
+
1109
+ Migration Required - PostgreSQL enforces column types, so existing tables must be migrated. Note: Migration will fail if existing column values contain invalid JSON.
1110
+
1111
+ ```sql
1112
+ ALTER TABLE mastra_threads
1113
+ ALTER COLUMN metadata TYPE jsonb
1114
+ USING metadata::jsonb;
1115
+
1116
+ ALTER TABLE mastra_workflow_snapshot
1117
+ ALTER COLUMN snapshot TYPE jsonb
1118
+ USING snapshot::jsonb;
1119
+ ```
1120
+
1121
+ **LibSQL**
1122
+
1123
+ No Migration Required - LibSQL now uses native SQLite JSONB format (added in SQLite 3.45) for ~3x performance improvement on JSON operations. The changes are fully backwards compatible:
1124
+ - Existing TEXT JSON data continues to work
1125
+ - New data is stored in binary JSONB format
1126
+ - Both formats can coexist in the same table
1127
+ - All JSON functions (`json_extract`, etc.) work on both formats
1128
+
1129
+ New installations automatically use JSONB. Existing applications continue to work without any changes.
1130
+
1131
+ ### Patch Changes
1132
+
1133
+ - Fix `listWorkflowRuns` failing with "unsupported Unicode escape sequence" error when filtering by status on snapshots containing null characters (`\u0000`) or unpaired Unicode surrogates (`\uD800-\uDFFF`). ([#11616](https://github.com/mastra-ai/mastra/pull/11616))
1134
+
1135
+ The fix uses `regexp_replace` to sanitize problematic escape sequences before casting to JSONB in the WHERE clause, while preserving the original data in the returned results.
1136
+
1137
+ - Fixed PostgreSQL migration errors when upgrading from v0.x to v1 ([#11633](https://github.com/mastra-ai/mastra/pull/11633))
1138
+
1139
+ **What changed:** PostgreSQL storage now automatically adds missing `spanId` and `requestContext` columns to the scorers table during initialization, preventing "column does not exist" errors when upgrading from v0.x to v1.0.0.
1140
+
1141
+ **Why:** Previously, upgrading to v1 could fail with errors like `column "requestContext" of relation "mastra_scorers" does not exist` if your database was created with an older version.
1142
+
1143
+ Related: #11631
1144
+
1145
+ - Aligned vector store configuration with underlying library APIs, giving you access to all library options directly. ([#11742](https://github.com/mastra-ai/mastra/pull/11742))
1146
+
1147
+ **Why this change?**
1148
+
1149
+ Previously, each vector store defined its own configuration types that only exposed a subset of the underlying library's options. This meant users couldn't access advanced features like authentication, SSL, compression, or custom headers without creating their own client instances. Now, the configuration types extend the library types directly, so all options are available.
1150
+
1151
+ **@mastra/libsql** (Breaking)
1152
+
1153
+ Renamed `connectionUrl` to `url` to match the `@libsql/client` API and align with LibSQLStorage.
1154
+
1155
+ ```typescript
1156
+ // Before
1157
+ new LibSQLVector({ id: 'my-vector', connectionUrl: 'file:./db.sqlite' });
1158
+
1159
+ // After
1160
+ new LibSQLVector({ id: 'my-vector', url: 'file:./db.sqlite' });
1161
+ ```
1162
+
1163
+ **@mastra/opensearch** (Breaking)
1164
+
1165
+ Renamed `url` to `node` and added support for all OpenSearch `ClientOptions` including authentication, SSL, and compression.
1166
+
1167
+ ```typescript
1168
+ // Before
1169
+ new OpenSearchVector({ id: 'my-vector', url: 'http://localhost:9200' });
1170
+
1171
+ // After
1172
+ new OpenSearchVector({ id: 'my-vector', node: 'http://localhost:9200' });
1173
+
1174
+ // With authentication (now possible)
1175
+ new OpenSearchVector({
1176
+ id: 'my-vector',
1177
+ node: 'https://localhost:9200',
1178
+ auth: { username: 'admin', password: 'admin' },
1179
+ ssl: { rejectUnauthorized: false },
1180
+ });
1181
+ ```
1182
+
1183
+ **@mastra/pinecone** (Breaking)
1184
+
1185
+ Removed `environment` parameter. Use `controllerHostUrl` instead (the actual Pinecone SDK field name). Added support for all `PineconeConfiguration` options.
1186
+
1187
+ ```typescript
1188
+ // Before
1189
+ new PineconeVector({ id: 'my-vector', apiKey: '...', environment: '...' });
1190
+
1191
+ // After
1192
+ new PineconeVector({ id: 'my-vector', apiKey: '...' });
1193
+
1194
+ // With custom controller host (if needed)
1195
+ new PineconeVector({ id: 'my-vector', apiKey: '...', controllerHostUrl: '...' });
1196
+ ```
1197
+
1198
+ **@mastra/clickhouse**
1199
+
1200
+ Added support for all `ClickHouseClientConfigOptions` like `request_timeout`, `compression`, `keep_alive`, and `database`. Existing configurations continue to work unchanged.
1201
+
1202
+ **@mastra/cloudflare, @mastra/cloudflare-d1, @mastra/lance, @mastra/libsql, @mastra/mongodb, @mastra/pg, @mastra/upstash**
1203
+
1204
+ Improved logging by replacing `console.warn` with structured logger in workflow storage domains.
1205
+
1206
+ **@mastra/deployer-cloud**
1207
+
1208
+ Updated internal LibSQLVector configuration for compatibility with the new API.
1209
+
1210
+ - Fixed PostgreSQL storage issues after JSONB migration. ([#11906](https://github.com/mastra-ai/mastra/pull/11906))
1211
+
1212
+ **Bug Fixes**
1213
+ - Fixed `clearTable()` using incorrect default schema. The method was checking for table existence in the 'mastra' schema instead of PostgreSQL's default 'public' schema, causing table truncation to be skipped and leading to duplicate key violations in tests and production code that uses `dangerouslyClearAll()`.
1214
+ - Fixed `listWorkflowRuns()` status filter failing with "function regexp_replace(jsonb, ...) does not exist" error. After the TEXT to JSONB migration, the query tried to use `regexp_replace()` directly on a JSONB column. Now casts to text first: `regexp_replace(snapshot::text, ...)`.
1215
+ - Added Unicode sanitization when persisting workflow snapshots to handle null characters (\u0000) and unpaired surrogates (\uD800-\uDFFF) that PostgreSQL's JSONB type rejects, preventing "unsupported Unicode escape sequence" errors.
1216
+
1217
+ - Updated dependencies [[`ebae12a`](https://github.com/mastra-ai/mastra/commit/ebae12a2dd0212e75478981053b148a2c246962d), [`c61a0a5`](https://github.com/mastra-ai/mastra/commit/c61a0a5de4904c88fd8b3718bc26d1be1c2ec6e7), [`69136e7`](https://github.com/mastra-ai/mastra/commit/69136e748e32f57297728a4e0f9a75988462f1a7), [`449aed2`](https://github.com/mastra-ai/mastra/commit/449aed2ba9d507b75bf93d427646ea94f734dfd1), [`eb648a2`](https://github.com/mastra-ai/mastra/commit/eb648a2cc1728f7678768dd70cd77619b448dab9), [`0131105`](https://github.com/mastra-ai/mastra/commit/0131105532e83bdcbb73352fc7d0879eebf140dc), [`9d5059e`](https://github.com/mastra-ai/mastra/commit/9d5059eae810829935fb08e81a9bb7ecd5b144a7), [`ef756c6`](https://github.com/mastra-ai/mastra/commit/ef756c65f82d16531c43f49a27290a416611e526), [`b00ccd3`](https://github.com/mastra-ai/mastra/commit/b00ccd325ebd5d9e37e34dd0a105caae67eb568f), [`3bdfa75`](https://github.com/mastra-ai/mastra/commit/3bdfa7507a91db66f176ba8221aa28dd546e464a), [`e770de9`](https://github.com/mastra-ai/mastra/commit/e770de941a287a49b1964d44db5a5763d19890a6), [`52e2716`](https://github.com/mastra-ai/mastra/commit/52e2716b42df6eff443de72360ae83e86ec23993), [`27b4040`](https://github.com/mastra-ai/mastra/commit/27b4040bfa1a95d92546f420a02a626b1419a1d6), [`610a70b`](https://github.com/mastra-ai/mastra/commit/610a70bdad282079f0c630e0d7bb284578f20151), [`8dc7f55`](https://github.com/mastra-ai/mastra/commit/8dc7f55900395771da851dc7d78d53ae84fe34ec), [`8379099`](https://github.com/mastra-ai/mastra/commit/8379099fc467af6bef54dd7f80c9bd75bf8bbddf), [`8c0ec25`](https://github.com/mastra-ai/mastra/commit/8c0ec25646c8a7df253ed1e5ff4863a0d3f1316c), [`ff4d9a6`](https://github.com/mastra-ai/mastra/commit/ff4d9a6704fc87b31a380a76ed22736fdedbba5a), [`69821ef`](https://github.com/mastra-ai/mastra/commit/69821ef806482e2c44e2197ac0b050c3fe3a5285), [`1ed5716`](https://github.com/mastra-ai/mastra/commit/1ed5716830867b3774c4a1b43cc0d82935f32b96), [`4186bdd`](https://github.com/mastra-ai/mastra/commit/4186bdd00731305726fa06adba0b076a1d50b49f), [`7aaf973`](https://github.com/mastra-ai/mastra/commit/7aaf973f83fbbe9521f1f9e7a4fd99b8de464617)]:
1218
+ - @mastra/core@1.0.0-beta.22
1219
+
1220
+ ## 1.0.0-beta.12
1221
+
1222
+ ### Patch Changes
1223
+
1224
+ - Add embedded documentation support for Mastra packages ([#11472](https://github.com/mastra-ai/mastra/pull/11472))
1225
+
1226
+ Mastra packages now include embedded documentation in the published npm package under `dist/docs/`. This enables coding agents and AI assistants to understand and use the framework by reading documentation directly from `node_modules`.
1227
+
1228
+ Each package includes:
1229
+ - **SKILL.md** - Entry point explaining the package's purpose and capabilities
1230
+ - **SOURCE_MAP.json** - Machine-readable index mapping exports to types and implementation files
1231
+ - **Topic folders** - Conceptual documentation organized by feature area
1232
+
1233
+ Documentation is driven by the `packages` frontmatter field in MDX files, which maps docs to their corresponding packages. CI validation ensures all docs include this field.
1234
+
1235
+ - Added `startExclusive` and `endExclusive` options to `dateRange` filter for message queries. ([#11479](https://github.com/mastra-ai/mastra/pull/11479))
1236
+
1237
+ **What changed:** The `filter.dateRange` parameter in `listMessages()` and `Memory.recall()` now supports `startExclusive` and `endExclusive` boolean options. When set to `true`, messages with timestamps exactly matching the boundary are excluded from results.
1238
+
1239
+ **Why this matters:** Enables cursor-based pagination for chat applications. When new messages arrive during a session, offset-based pagination can skip or duplicate messages. Using `endExclusive: true` with the oldest message's timestamp as a cursor ensures consistent pagination without gaps or duplicates.
1240
+
1241
+ **Example:**
1242
+
1243
+ ```typescript
1244
+ // Get first page
1245
+ const page1 = await memory.recall({
1246
+ threadId: 'thread-123',
1247
+ perPage: 10,
1248
+ orderBy: { field: 'createdAt', direction: 'DESC' },
1249
+ });
1250
+
1251
+ // Get next page using cursor-based pagination
1252
+ const oldestMessage = page1.messages[page1.messages.length - 1];
1253
+ const page2 = await memory.recall({
1254
+ threadId: 'thread-123',
1255
+ perPage: 10,
1256
+ orderBy: { field: 'createdAt', direction: 'DESC' },
1257
+ filter: {
1258
+ dateRange: {
1259
+ end: oldestMessage.createdAt,
1260
+ endExclusive: true, // Excludes the cursor message
1261
+ },
1262
+ },
1263
+ });
1264
+ ```
1265
+
1266
+ - Fix thread timestamps being returned in incorrect timezone from listThreadsByResourceId ([#11498](https://github.com/mastra-ai/mastra/pull/11498))
1267
+
1268
+ The method was not using the timezone-aware columns (createdAtZ/updatedAtZ), causing timestamps to be interpreted in local timezone instead of UTC. Now correctly uses TIMESTAMPTZ columns with fallback for legacy data.
1269
+
1270
+ - Adds thread cloning to create independent copies of conversations that can diverge. ([#11517](https://github.com/mastra-ai/mastra/pull/11517))
1271
+
1272
+ ```typescript
1273
+ // Clone a thread
1274
+ const { thread, clonedMessages } = await memory.cloneThread({
1275
+ sourceThreadId: 'thread-123',
1276
+ title: 'My Clone',
1277
+ options: {
1278
+ messageLimit: 10, // optional: only copy last N messages
1279
+ },
1280
+ });
1281
+
1282
+ // Check if a thread is a clone
1283
+ if (memory.isClone(thread)) {
1284
+ const source = await memory.getSourceThread(thread.id);
1285
+ }
1286
+
1287
+ // List all clones of a thread
1288
+ const clones = await memory.listClones('thread-123');
1289
+ ```
1290
+
1291
+ Includes:
1292
+ - Storage implementations for InMemory, PostgreSQL, LibSQL, Upstash
1293
+ - API endpoint: `POST /api/memory/threads/:threadId/clone`
1294
+ - Embeddings created for cloned messages (semantic recall)
1295
+ - Clone button in playground UI Memory tab
1296
+
1297
+ - Updated dependencies [[`d2d3e22`](https://github.com/mastra-ai/mastra/commit/d2d3e22a419ee243f8812a84e3453dd44365ecb0), [`bc72b52`](https://github.com/mastra-ai/mastra/commit/bc72b529ee4478fe89ecd85a8be47ce0127b82a0), [`05b8bee`](https://github.com/mastra-ai/mastra/commit/05b8bee9e50e6c2a4a2bf210eca25ee212ca24fa), [`c042bd0`](https://github.com/mastra-ai/mastra/commit/c042bd0b743e0e86199d0cb83344ca7690e34a9c), [`940a2b2`](https://github.com/mastra-ai/mastra/commit/940a2b27480626ed7e74f55806dcd2181c1dd0c2), [`e0941c3`](https://github.com/mastra-ai/mastra/commit/e0941c3d7fc75695d5d258e7008fd5d6e650800c), [`0c0580a`](https://github.com/mastra-ai/mastra/commit/0c0580a42f697cd2a7d5973f25bfe7da9055038a), [`28f5f89`](https://github.com/mastra-ai/mastra/commit/28f5f89705f2409921e3c45178796c0e0d0bbb64), [`e601b27`](https://github.com/mastra-ai/mastra/commit/e601b272c70f3a5ecca610373aa6223012704892), [`3d3366f`](https://github.com/mastra-ai/mastra/commit/3d3366f31683e7137d126a3a57174a222c5801fb), [`5a4953f`](https://github.com/mastra-ai/mastra/commit/5a4953f7d25bb15ca31ed16038092a39cb3f98b3), [`eb9e522`](https://github.com/mastra-ai/mastra/commit/eb9e522ce3070a405e5b949b7bf5609ca51d7fe2), [`20e6f19`](https://github.com/mastra-ai/mastra/commit/20e6f1971d51d3ff6dd7accad8aaaae826d540ed), [`4f0b3c6`](https://github.com/mastra-ai/mastra/commit/4f0b3c66f196c06448487f680ccbb614d281e2f7), [`74c4f22`](https://github.com/mastra-ai/mastra/commit/74c4f22ed4c71e72598eacc346ba95cdbc00294f), [`81b6a8f`](https://github.com/mastra-ai/mastra/commit/81b6a8ff79f49a7549d15d66624ac1a0b8f5f971), [`e4d366a`](https://github.com/mastra-ai/mastra/commit/e4d366aeb500371dd4210d6aa8361a4c21d87034), [`a4f010b`](https://github.com/mastra-ai/mastra/commit/a4f010b22e4355a5fdee70a1fe0f6e4a692cc29e), [`73b0bb3`](https://github.com/mastra-ai/mastra/commit/73b0bb394dba7c9482eb467a97ab283dbc0ef4db), [`5627a8c`](https://github.com/mastra-ai/mastra/commit/5627a8c6dc11fe3711b3fa7a6ffd6eb34100a306), [`3ff45d1`](https://github.com/mastra-ai/mastra/commit/3ff45d10e0c80c5335a957ab563da72feb623520), [`251df45`](https://github.com/mastra-ai/mastra/commit/251df4531407dfa46d805feb40ff3fb49769f455), [`f894d14`](https://github.com/mastra-ai/mastra/commit/f894d148946629af7b1f452d65a9cf864cec3765), [`c2b9547`](https://github.com/mastra-ai/mastra/commit/c2b9547bf435f56339f23625a743b2147ab1c7a6), [`580b592`](https://github.com/mastra-ai/mastra/commit/580b5927afc82fe460dfdf9a38a902511b6b7e7f), [`58e3931`](https://github.com/mastra-ai/mastra/commit/58e3931af9baa5921688566210f00fb0c10479fa), [`08bb631`](https://github.com/mastra-ai/mastra/commit/08bb631ae2b14684b2678e3549d0b399a6f0561e), [`4fba91b`](https://github.com/mastra-ai/mastra/commit/4fba91bec7c95911dc28e369437596b152b04cd0), [`12b0cc4`](https://github.com/mastra-ai/mastra/commit/12b0cc4077d886b1a552637dedb70a7ade93528c)]:
1298
+ - @mastra/core@1.0.0-beta.20
1299
+
1300
+ ## 1.0.0-beta.11
1301
+
1302
+ ### Minor Changes
1303
+
1304
+ - Remove pg-promise dependency and use pg.Pool directly ([#11450](https://github.com/mastra-ai/mastra/pull/11450))
1305
+
1306
+ **BREAKING CHANGE**: This release replaces pg-promise with vanilla node-postgres (`pg`).
1307
+
1308
+ ### Breaking Changes
1309
+ - **Removed `store.pgp`**: The pg-promise library instance is no longer exposed
1310
+ - **Config change**: `{ client: pgPromiseDb }` is no longer supported. Use `{ pool: pgPool }` instead
1311
+ - **Cloud SQL config**: `max` and `idleTimeoutMillis` must now be passed via `pgPoolOptions`
1312
+
1313
+ ### New Features
1314
+ - **`store.pool`**: Exposes the underlying `pg.Pool` for direct database access or ORM integration (e.g., Drizzle)
1315
+ - **`store.db`**: Provides a `DbClient` interface with methods like `one()`, `any()`, `tx()`, etc.
1316
+ - **`store.db.connect()`**: Acquire a client for session-level operations
1317
+
1318
+ ### Migration
1319
+
1320
+ ```typescript
1321
+ // Before (pg-promise)
1322
+ import pgPromise from 'pg-promise';
1323
+ const pgp = pgPromise();
1324
+ const client = pgp(connectionString);
1325
+ const store = new PostgresStore({ id: 'my-store', client });
1326
+
1327
+ // After (pg.Pool)
1328
+ import { Pool } from 'pg';
1329
+ const pool = new Pool({ connectionString });
1330
+ const store = new PostgresStore({ id: 'my-store', pool });
1331
+
1332
+ // Use store.pool with any library that accepts a pg.Pool
1333
+ ```
1334
+
1335
+ ### Patch Changes
1336
+
1337
+ - Added `exportSchemas()` function to generate Mastra database schema as SQL DDL without a database connection. ([#11448](https://github.com/mastra-ai/mastra/pull/11448))
1338
+
1339
+ **What's New**
1340
+
1341
+ You can now export your Mastra database schema as SQL DDL statements without connecting to a database. This is useful for:
1342
+ - Generating migration scripts
1343
+ - Reviewing the schema before deployment
1344
+ - Creating database schemas in environments where the application doesn't have CREATE privileges
1345
+
1346
+ **Example**
1347
+
1348
+ ```typescript
1349
+ import { exportSchemas } from '@mastra/pg';
1350
+
1351
+ // Export schema for default 'public' schema
1352
+ const ddl = exportSchemas();
1353
+ console.log(ddl);
1354
+
1355
+ // Export schema for a custom schema
1356
+ const customDdl = exportSchemas('my_schema');
1357
+ // Creates: CREATE SCHEMA IF NOT EXISTS "my_schema"; and all tables within it
1358
+ ```
1359
+
1360
+ - Updated dependencies [[`e54953e`](https://github.com/mastra-ai/mastra/commit/e54953ed8ce1b28c0d62a19950163039af7834b4), [`7d56d92`](https://github.com/mastra-ai/mastra/commit/7d56d9213886e8353956d7d40df10045fd12b299), [`fdac646`](https://github.com/mastra-ai/mastra/commit/fdac646033a0930a1a4e00d13aa64c40bb7f1e02), [`d07b568`](https://github.com/mastra-ai/mastra/commit/d07b5687819ea8cb1dffa776d0c1765faf4aa1ae), [`68ec97d`](https://github.com/mastra-ai/mastra/commit/68ec97d4c07c6393fcf95c2481fc5d73da99f8c8), [`4aa55b3`](https://github.com/mastra-ai/mastra/commit/4aa55b383cf06043943359ea316572fd969861a7)]:
1361
+ - @mastra/core@1.0.0-beta.19
1362
+
1363
+ ## 1.0.0-beta.10
1364
+
1365
+ ### Patch Changes
1366
+
1367
+ - Fix missing timezone columns during PostgreSQL spans table migration ([#11419](https://github.com/mastra-ai/mastra/pull/11419))
1368
+
1369
+ Fixes issue #11410 where users upgrading to observability beta.7 encountered errors about missing `startedAtZ`, `endedAtZ`, `createdAtZ`, and `updatedAtZ` columns. The migration now properly adds timezone-aware columns for all timestamp fields when upgrading existing databases, ensuring compatibility with the new observability implementation that requires these columns for batch operations.
1370
+
1371
+ - Add storage composition to MastraStorage ([#11401](https://github.com/mastra-ai/mastra/pull/11401))
1372
+
1373
+ `MastraStorage` can now compose storage domains from different adapters. Use it when you need different databases for different purposes - for example, PostgreSQL for memory and workflows, but a different database for observability.
1374
+
1375
+ ```typescript
1376
+ import { MastraStorage } from '@mastra/core/storage';
1377
+ import { MemoryPG, WorkflowsPG, ScoresPG } from '@mastra/pg';
1378
+ import { MemoryLibSQL } from '@mastra/libsql';
1379
+
1380
+ // Compose domains from different stores
1381
+ const storage = new MastraStorage({
1382
+ id: 'composite',
1383
+ domains: {
1384
+ memory: new MemoryLibSQL({ url: 'file:./local.db' }),
1385
+ workflows: new WorkflowsPG({ connectionString: process.env.DATABASE_URL }),
1386
+ scores: new ScoresPG({ connectionString: process.env.DATABASE_URL }),
1387
+ },
1388
+ });
1389
+ ```
1390
+
1391
+ **Breaking changes:**
1392
+ - `storage.supports` property no longer exists
1393
+ - `StorageSupports` type is no longer exported from `@mastra/core/storage`
1394
+
1395
+ All stores now support the same features. For domain availability, use `getStore()`:
1396
+
1397
+ ```typescript
1398
+ const store = await storage.getStore('memory');
1399
+ if (store) {
1400
+ // domain is available
1401
+ }
1402
+ ```
1403
+
1404
+ - Updated dependencies [[`3d93a15`](https://github.com/mastra-ai/mastra/commit/3d93a15796b158c617461c8b98bede476ebb43e2), [`efe406a`](https://github.com/mastra-ai/mastra/commit/efe406a1353c24993280ebc2ed61dd9f65b84b26), [`119e5c6`](https://github.com/mastra-ai/mastra/commit/119e5c65008f3e5cfca954eefc2eb85e3bf40da4), [`74e504a`](https://github.com/mastra-ai/mastra/commit/74e504a3b584eafd2f198001c6a113bbec589fd3), [`e33fdbd`](https://github.com/mastra-ai/mastra/commit/e33fdbd07b33920d81e823122331b0c0bee0bb59), [`929f69c`](https://github.com/mastra-ai/mastra/commit/929f69c3436fa20dd0f0e2f7ebe8270bd82a1529), [`8a73529`](https://github.com/mastra-ai/mastra/commit/8a73529ca01187f604b1f3019d0a725ac63ae55f)]:
1405
+ - @mastra/core@1.0.0-beta.16
1406
+
1407
+ ## 1.0.0-beta.9
1408
+
1409
+ ### Minor Changes
1410
+
1411
+ - Introduce StorageDomain base class for composite storage support ([#11249](https://github.com/mastra-ai/mastra/pull/11249))
1412
+
1413
+ Storage adapters now use a domain-based architecture where each domain (memory, workflows, scores, observability, agents) extends a `StorageDomain` base class with `init()` and `dangerouslyClearAll()` methods.
1414
+
1415
+ **Key changes:**
1416
+ - Add `StorageDomain` abstract base class that all domain storage classes extend
1417
+ - Add `InMemoryDB` class for shared state across in-memory domain implementations
1418
+ - All storage domains now implement `dangerouslyClearAll()` for test cleanup
1419
+ - Remove `operations` from public `StorageDomains` type (now internal to each adapter)
1420
+ - Add flexible client/config patterns - domains accept either an existing database client or config to create one internally
1421
+
1422
+ **Why this matters:**
1423
+
1424
+ This enables composite storage where you can use different database adapters per domain:
1425
+
1426
+ ```typescript
1427
+ import { Mastra } from '@mastra/core';
1428
+ import { PostgresStore } from '@mastra/pg';
1429
+ import { ClickhouseStore } from '@mastra/clickhouse';
1430
+
1431
+ // Use Postgres for most domains but Clickhouse for observability
1432
+ const mastra = new Mastra({
1433
+ storage: new PostgresStore({
1434
+ connectionString: 'postgres://...',
1435
+ }),
1436
+ // Future: override specific domains
1437
+ // observability: new ClickhouseStore({ ... }).getStore('observability'),
1438
+ });
1439
+ ```
1440
+
1441
+ **Standalone domain usage:**
1442
+
1443
+ Domains can now be used independently with flexible configuration:
1444
+
1445
+ ```typescript
1446
+ import { MemoryLibSQL } from '@mastra/libsql/memory';
1447
+
1448
+ // Option 1: Pass config to create client internally
1449
+ const memory = new MemoryLibSQL({
1450
+ url: 'file:./local.db',
1451
+ });
1452
+
1453
+ // Option 2: Pass existing client for shared connections
1454
+ import { createClient } from '@libsql/client';
1455
+ const client = createClient({ url: 'file:./local.db' });
1456
+ const memory = new MemoryLibSQL({ client });
1457
+ ```
1458
+
1459
+ **Breaking changes:**
1460
+ - `StorageDomains` type no longer includes `operations` - access via `getStore()` instead
1461
+ - Domain base classes now require implementing `dangerouslyClearAll()` method
1462
+
1463
+ - Refactor storage architecture to use domain-specific stores via `getStore()` pattern ([#11361](https://github.com/mastra-ai/mastra/pull/11361))
1464
+
1465
+ ### Summary
1466
+
1467
+ This release introduces a new storage architecture that replaces passthrough methods on `MastraStorage` with domain-specific storage interfaces accessed via `getStore()`. This change reduces code duplication across storage adapters and provides a cleaner, more modular API.
1468
+
1469
+ ### Migration Guide
1470
+
1471
+ All direct method calls on storage instances should be updated to use `getStore()`:
1472
+
1473
+ ```typescript
1474
+ // Before
1475
+ const thread = await storage.getThreadById({ threadId });
1476
+ await storage.persistWorkflowSnapshot({ workflowName, runId, snapshot });
1477
+ await storage.createSpan(span);
1478
+
1479
+ // After
1480
+ const memory = await storage.getStore('memory');
1481
+ const thread = await memory?.getThreadById({ threadId });
1482
+
1483
+ const workflows = await storage.getStore('workflows');
1484
+ await workflows?.persistWorkflowSnapshot({ workflowName, runId, snapshot });
1485
+
1486
+ const observability = await storage.getStore('observability');
1487
+ await observability?.createSpan(span);
1488
+ ```
1489
+
1490
+ ### Available Domains
1491
+ - **`memory`**: Thread and message operations (`getThreadById`, `saveThread`, `saveMessages`, etc.)
1492
+ - **`workflows`**: Workflow state persistence (`persistWorkflowSnapshot`, `loadWorkflowSnapshot`, `getWorkflowRunById`, etc.)
1493
+ - **`scores`**: Evaluation scores (`saveScore`, `listScoresByScorerId`, etc.)
1494
+ - **`observability`**: Tracing and spans (`createSpan`, `updateSpan`, `getTrace`, etc.)
1495
+ - **`agents`**: Stored agent configurations (`createAgent`, `getAgentById`, `listAgents`, etc.)
1496
+
1497
+ ### Breaking Changes
1498
+ - Passthrough methods have been removed from `MastraStorage` base class
1499
+ - All storage adapters now require accessing domains via `getStore()`
1500
+ - The `stores` property on storage instances is now the canonical way to access domain storage
1501
+
1502
+ ### Internal Changes
1503
+ - Each storage adapter now initializes domain-specific stores in its constructor
1504
+ - Domain stores share database connections and handle their own table initialization
1505
+
1506
+ - Unified observability schema with entity-based span identification ([#11132](https://github.com/mastra-ai/mastra/pull/11132))
1507
+
1508
+ ## What changed
1509
+
1510
+ Spans now use a unified identification model with `entityId`, `entityType`, and `entityName` instead of separate `agentId`, `toolId`, `workflowId` fields.
1511
+
1512
+ **Before:**
1513
+
1514
+ ```typescript
1515
+ // Old span structure
1516
+ span.agentId; // 'my-agent'
1517
+ span.toolId; // undefined
1518
+ span.workflowId; // undefined
1519
+ ```
1520
+
1521
+ **After:**
1522
+
1523
+ ```typescript
1524
+ // New span structure
1525
+ span.entityType; // EntityType.AGENT
1526
+ span.entityId; // 'my-agent'
1527
+ span.entityName; // 'My Agent'
1528
+ ```
1529
+
1530
+ ## New `listTraces()` API
1531
+
1532
+ Query traces with filtering, pagination, and sorting:
1533
+
1534
+ ```typescript
1535
+ const { spans, pagination } = await storage.listTraces({
1536
+ filters: {
1537
+ entityType: EntityType.AGENT,
1538
+ entityId: 'my-agent',
1539
+ userId: 'user-123',
1540
+ environment: 'production',
1541
+ status: TraceStatus.SUCCESS,
1542
+ startedAt: { start: new Date('2024-01-01'), end: new Date('2024-01-31') },
1543
+ },
1544
+ pagination: { page: 0, perPage: 50 },
1545
+ orderBy: { field: 'startedAt', direction: 'DESC' },
1546
+ });
1547
+ ```
1548
+
1549
+ **Available filters:** date ranges (`startedAt`, `endedAt`), entity (`entityType`, `entityId`, `entityName`), identity (`userId`, `organizationId`), correlation IDs (`runId`, `sessionId`, `threadId`), deployment (`environment`, `source`, `serviceName`), `tags`, `metadata`, and `status`.
1550
+
1551
+ ## New retrieval methods
1552
+ - `getSpan({ traceId, spanId })` - Get a single span
1553
+ - `getRootSpan({ traceId })` - Get the root span of a trace
1554
+ - `getTrace({ traceId })` - Get all spans for a trace
1555
+
1556
+ ## Backward compatibility
1557
+
1558
+ The legacy `getTraces()` method continues to work. When you pass `name: "agent run: my-agent"`, it automatically transforms to `entityId: "my-agent", entityType: AGENT`.
1559
+
1560
+ ## Migration
1561
+
1562
+ **Automatic:** SQL-based stores (PostgreSQL, LibSQL, MSSQL) automatically add new columns to existing `spans` tables on initialization. Existing data is preserved with new columns set to `NULL`.
1563
+
1564
+ **No action required:** Your existing code continues to work. Adopt the new fields and `listTraces()` API at your convenience.
1565
+
1566
+ ### Patch Changes
1567
+
1568
+ - Fix severe performance issue with semantic recall on large message tables ([#11365](https://github.com/mastra-ai/mastra/pull/11365))
1569
+
1570
+ The `_getIncludedMessages` method was using `ROW_NUMBER() OVER (ORDER BY createdAt)` which scanned all messages in a thread to assign row numbers. On tables with 1M+ rows, this caused 5-10 minute query times.
1571
+
1572
+ Replaced with cursor-based pagination using the existing `(thread_id, createdAt)` index:
1573
+
1574
+ ```sql
1575
+ -- Before: scans entire thread
1576
+ ROW_NUMBER() OVER (ORDER BY "createdAt" ASC)
1577
+
1578
+ -- After: uses index, fetches only needed rows
1579
+ WHERE createdAt <= (target) ORDER BY createdAt DESC LIMIT N
1580
+ ```
1581
+
1582
+ Performance improvement: ~49x faster (832ms → 17ms) for typical semantic recall queries.
1583
+
1584
+ - Added pre-configured client support for all storage adapters. ([#11302](https://github.com/mastra-ai/mastra/pull/11302))
1585
+
1586
+ **What changed**
1587
+
1588
+ All storage adapters now accept pre-configured database clients in addition to connection credentials. This allows you to customize client settings (connection pools, timeouts, interceptors) before passing them to Mastra.
1589
+
1590
+ **Example**
1591
+
1592
+ ```typescript
1593
+ import { createClient } from '@clickhouse/client';
1594
+ import { ClickhouseStore } from '@mastra/clickhouse';
1595
+
1596
+ // Create and configure client with custom settings
1597
+ const client = createClient({
1598
+ url: 'http://localhost:8123',
1599
+ username: 'default',
1600
+ password: '',
1601
+ request_timeout: 60000,
1602
+ });
1603
+
1604
+ // Pass pre-configured client to store
1605
+ const store = new ClickhouseStore({
1606
+ id: 'my-store',
1607
+ client,
1608
+ });
1609
+ ```
1610
+
1611
+ **Additional improvements**
1612
+ - Added input validation for required connection parameters (URL, credentials) with clear error messages
1613
+
1614
+ - Add index configuration options to storage stores ([#11311](https://github.com/mastra-ai/mastra/pull/11311))
1615
+
1616
+ Storage stores now support two new configuration options for index management:
1617
+ - `skipDefaultIndexes`: When `true`, default performance indexes are not created during `init()`. Useful for custom index strategies or reducing initialization time.
1618
+ - `indexes`: Array of custom index definitions to create during `init()`. Indexes are routed to the appropriate domain based on table/collection name.
1619
+
1620
+ ```typescript
1621
+ // Skip default indexes and use custom ones
1622
+ const store = new PostgresStore({
1623
+ connectionString: '...',
1624
+ skipDefaultIndexes: true,
1625
+ indexes: [{ name: 'threads_type_idx', table: 'mastra_threads', columns: ["metadata->>'type'"] }],
1626
+ });
1627
+
1628
+ // MongoDB equivalent
1629
+ const mongoStore = new MongoDBStore({
1630
+ url: 'mongodb://...',
1631
+ skipDefaultIndexes: true,
1632
+ indexes: [{ collection: 'mastra_threads', keys: { 'metadata.type': 1 }, options: { name: 'threads_type_idx' } }],
1633
+ });
1634
+ ```
1635
+
1636
+ Domain classes (e.g., `MemoryPG`, `MemoryStorageMongoDB`) also accept these options for standalone usage.
1637
+
1638
+ - Updated dependencies [[`33a4d2e`](https://github.com/mastra-ai/mastra/commit/33a4d2e4ed8af51f69256232f00c34d6b6b51d48), [`4aaa844`](https://github.com/mastra-ai/mastra/commit/4aaa844a4f19d054490f43638a990cc57bda8d2f), [`4a1a6cb`](https://github.com/mastra-ai/mastra/commit/4a1a6cb3facad54b2bb6780b00ce91d6de1edc08), [`31d13d5`](https://github.com/mastra-ai/mastra/commit/31d13d5fdc2e2380e2e3ee3ec9fb29d2a00f265d), [`4c62166`](https://github.com/mastra-ai/mastra/commit/4c621669f4a29b1f443eca3ba70b814afa286266), [`7bcbf10`](https://github.com/mastra-ai/mastra/commit/7bcbf10133516e03df964b941f9a34e9e4ab4177), [`4353600`](https://github.com/mastra-ai/mastra/commit/43536005a65988a8eede236f69122e7f5a284ba2), [`6986fb0`](https://github.com/mastra-ai/mastra/commit/6986fb064f5db6ecc24aa655e1d26529087b43b3), [`053e979`](https://github.com/mastra-ai/mastra/commit/053e9793b28e970086b0507f7f3b76ea32c1e838), [`e26dc9c`](https://github.com/mastra-ai/mastra/commit/e26dc9c3ccfec54ae3dc3e2b2589f741f9ae60a6), [`55edf73`](https://github.com/mastra-ai/mastra/commit/55edf7302149d6c964fbb7908b43babfc2b52145), [`27c0009`](https://github.com/mastra-ai/mastra/commit/27c0009777a6073d7631b0eb7b481d94e165b5ca), [`dee388d`](https://github.com/mastra-ai/mastra/commit/dee388dde02f2e63c53385ae69252a47ab6825cc), [`3f3fc30`](https://github.com/mastra-ai/mastra/commit/3f3fc3096f24c4a26cffeecfe73085928f72aa63), [`d90ea65`](https://github.com/mastra-ai/mastra/commit/d90ea6536f7aa51c6545a4e9215b55858e98e16d), [`d171e55`](https://github.com/mastra-ai/mastra/commit/d171e559ead9f52ec728d424844c8f7b164c4510), [`10c2735`](https://github.com/mastra-ai/mastra/commit/10c27355edfdad1ee2b826b897df74125eb81fb8), [`1924cf0`](https://github.com/mastra-ai/mastra/commit/1924cf06816e5e4d4d5333065ec0f4bb02a97799), [`b339816`](https://github.com/mastra-ai/mastra/commit/b339816df0984d0243d944ac2655d6ba5f809cde)]:
1639
+ - @mastra/core@1.0.0-beta.15
1640
+
3
1641
  ## 1.0.0-beta.8
4
1642
 
5
1643
  ### Patch Changes