@mastra/libsql 1.0.0-beta.9 → 1.1.0-alpha.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (47) hide show
  1. package/CHANGELOG.md +1241 -0
  2. package/dist/docs/README.md +39 -0
  3. package/dist/docs/SKILL.md +40 -0
  4. package/dist/docs/SOURCE_MAP.json +6 -0
  5. package/dist/docs/agents/01-agent-memory.md +166 -0
  6. package/dist/docs/agents/02-networks.md +292 -0
  7. package/dist/docs/agents/03-agent-approval.md +377 -0
  8. package/dist/docs/agents/04-network-approval.md +274 -0
  9. package/dist/docs/core/01-reference.md +151 -0
  10. package/dist/docs/guides/01-ai-sdk.md +120 -0
  11. package/dist/docs/memory/01-overview.md +45 -0
  12. package/dist/docs/memory/02-storage.md +261 -0
  13. package/dist/docs/memory/03-message-history.md +249 -0
  14. package/dist/docs/memory/04-working-memory.md +411 -0
  15. package/dist/docs/memory/05-semantic-recall.md +256 -0
  16. package/dist/docs/memory/06-memory-processors.md +318 -0
  17. package/dist/docs/memory/07-reference.md +133 -0
  18. package/dist/docs/observability/01-overview.md +73 -0
  19. package/dist/docs/observability/02-default.md +214 -0
  20. package/dist/docs/rag/01-retrieval.md +548 -0
  21. package/dist/docs/storage/01-reference.md +556 -0
  22. package/dist/docs/vectors/01-reference.md +213 -0
  23. package/dist/docs/workflows/01-snapshots.md +240 -0
  24. package/dist/index.cjs +817 -108
  25. package/dist/index.cjs.map +1 -1
  26. package/dist/index.js +814 -110
  27. package/dist/index.js.map +1 -1
  28. package/dist/storage/db/index.d.ts +42 -1
  29. package/dist/storage/db/index.d.ts.map +1 -1
  30. package/dist/storage/db/utils.d.ts +16 -1
  31. package/dist/storage/db/utils.d.ts.map +1 -1
  32. package/dist/storage/domains/agents/index.d.ts +10 -1
  33. package/dist/storage/domains/agents/index.d.ts.map +1 -1
  34. package/dist/storage/domains/memory/index.d.ts +3 -2
  35. package/dist/storage/domains/memory/index.d.ts.map +1 -1
  36. package/dist/storage/domains/observability/index.d.ts +25 -5
  37. package/dist/storage/domains/observability/index.d.ts.map +1 -1
  38. package/dist/storage/domains/scores/index.d.ts +0 -1
  39. package/dist/storage/domains/scores/index.d.ts.map +1 -1
  40. package/dist/storage/domains/workflows/index.d.ts +1 -0
  41. package/dist/storage/domains/workflows/index.d.ts.map +1 -1
  42. package/dist/storage/index.d.ts +10 -4
  43. package/dist/storage/index.d.ts.map +1 -1
  44. package/dist/vector/index.d.ts +6 -2
  45. package/dist/vector/index.d.ts.map +1 -1
  46. package/dist/vector/sql-builder.d.ts.map +1 -1
  47. package/package.json +12 -11
package/CHANGELOG.md CHANGED
@@ -1,5 +1,1246 @@
1
1
  # @mastra/libsql
2
2
 
3
+ ## 1.1.0-alpha.0
4
+
5
+ ### Minor Changes
6
+
7
+ - Added dynamic agent management with CRUD operations and version tracking ([#12038](https://github.com/mastra-ai/mastra/pull/12038))
8
+
9
+ **New Features:**
10
+ - Create, edit, and delete agents directly from the Mastra Studio UI
11
+ - Full version history for agents with compare and restore capabilities
12
+ - Visual diff viewer to compare agent configurations across versions
13
+ - Agent creation modal with comprehensive configuration options (model selection, instructions, tools, workflows, sub-agents, memory)
14
+ - AI-powered instruction enhancement
15
+
16
+ **Storage:**
17
+ - New storage interfaces for stored agents and agent versions
18
+ - PostgreSQL, LibSQL, and MongoDB implementations included
19
+ - In-memory storage for development and testing
20
+
21
+ **API:**
22
+ - RESTful endpoints for agent CRUD operations
23
+ - Version management endpoints (create, list, activate, restore, delete, compare)
24
+ - Automatic versioning on agent updates when enabled
25
+
26
+ **Client SDK:**
27
+ - JavaScript client with full support for stored agents and versions
28
+ - Type-safe methods for all CRUD and version operations
29
+
30
+ **Usage Example:**
31
+
32
+ ```typescript
33
+ // Server-side: Configure storage
34
+ import { Mastra } from '@mastra/core';
35
+ import { PgAgentsStorage } from '@mastra/pg';
36
+
37
+ const mastra = new Mastra({
38
+ agents: { agentOne },
39
+ storage: {
40
+ agents: new PgAgentsStorage({
41
+ connectionString: process.env.DATABASE_URL,
42
+ }),
43
+ },
44
+ });
45
+
46
+ // Client-side: Use the SDK
47
+ import { MastraClient } from '@mastra/client-js';
48
+
49
+ const client = new MastraClient({ baseUrl: 'http://localhost:3000' });
50
+
51
+ // Create a stored agent
52
+ const agent = await client.createStoredAgent({
53
+ name: 'Customer Support Agent',
54
+ description: 'Handles customer inquiries',
55
+ model: { provider: 'ANTHROPIC', name: 'claude-sonnet-4-5' },
56
+ instructions: 'You are a helpful customer support agent...',
57
+ tools: ['search', 'email'],
58
+ });
59
+
60
+ // Create a version snapshot
61
+ await client.storedAgent(agent.id).createVersion({
62
+ name: 'v1.0 - Initial release',
63
+ changeMessage: 'First production version',
64
+ });
65
+
66
+ // Compare versions
67
+ const diff = await client.storedAgent(agent.id).compareVersions('version-1', 'version-2');
68
+ ```
69
+
70
+ **Why:**
71
+ This feature enables teams to manage agents dynamically without code changes, making it easier to iterate on agent configurations and maintain a complete audit trail of changes.
72
+
73
+ - Added `status` field to `listTraces` response. The status field indicates the trace state: `success` (completed without error), `error` (has error), or `running` (still in progress). This makes it easier to filter and display traces by their current state without having to derive it from the `error` and `endedAt` fields. ([#12213](https://github.com/mastra-ai/mastra/pull/12213))
74
+
75
+ ### Patch Changes
76
+
77
+ - Updated dependencies [[`90fc0e5`](https://github.com/mastra-ai/mastra/commit/90fc0e5717cb280c2d4acf4f0410b510bb4c0a72), [`1cf5d2e`](https://github.com/mastra-ai/mastra/commit/1cf5d2ea1b085be23e34fb506c80c80a4e6d9c2b), [`833ae96`](https://github.com/mastra-ai/mastra/commit/833ae96c3e34370e58a1e979571c41f39a720592), [`943772b`](https://github.com/mastra-ai/mastra/commit/943772b4378f625f0f4e19ea2b7c392bd8e71786), [`b5c711b`](https://github.com/mastra-ai/mastra/commit/b5c711b281dd1fb81a399a766bc9f86c55efc13e), [`3efbe5a`](https://github.com/mastra-ai/mastra/commit/3efbe5ae20864c4f3143457f4f3ee7dc2fa5ca76), [`1e49e7a`](https://github.com/mastra-ai/mastra/commit/1e49e7ab5f173582154cb26b29d424de67d09aef), [`751eaab`](https://github.com/mastra-ai/mastra/commit/751eaab4e0d3820a94e4c3d39a2ff2663ded3d91), [`69d8156`](https://github.com/mastra-ai/mastra/commit/69d81568bcf062557c24471ce26812446bec465d), [`60d9d89`](https://github.com/mastra-ai/mastra/commit/60d9d899e44b35bc43f1bcd967a74e0ce010b1af), [`5c544c8`](https://github.com/mastra-ai/mastra/commit/5c544c8d12b08ab40d64d8f37b3c4215bee95b87), [`771ad96`](https://github.com/mastra-ai/mastra/commit/771ad962441996b5c43549391a3e6a02c6ddedc2), [`2b0936b`](https://github.com/mastra-ai/mastra/commit/2b0936b0c9a43eeed9bef63e614d7e02ee803f7e), [`3b04f30`](https://github.com/mastra-ai/mastra/commit/3b04f3010604f3cdfc8a0674731700ad66471cee), [`97e26de`](https://github.com/mastra-ai/mastra/commit/97e26deaebd9836647a67b96423281d66421ca07), [`10523f4`](https://github.com/mastra-ai/mastra/commit/10523f4882d9b874b40ce6e3715f66dbcd4947d2), [`cb72d20`](https://github.com/mastra-ai/mastra/commit/cb72d2069d7339bda8a0e76d4f35615debb07b84), [`42856b1`](https://github.com/mastra-ai/mastra/commit/42856b1c8aeea6371c9ee77ae2f5f5fe34400933), [`66f33ff`](https://github.com/mastra-ai/mastra/commit/66f33ff68620018513e499c394411d1d39b3aa5c), [`ab3c190`](https://github.com/mastra-ai/mastra/commit/ab3c1901980a99910ca9b96a7090c22e24060113), [`d4f06c8`](https://github.com/mastra-ai/mastra/commit/d4f06c85ffa5bb0da38fb82ebf3b040cc6b4ec4e), [`0350626`](https://github.com/mastra-ai/mastra/commit/03506267ec41b67add80d994c0c0fcce93bbc75f), [`bc9fa00`](https://github.com/mastra-ai/mastra/commit/bc9fa00859c5c4a796d53a0a5cae46ab4a3072e4), [`f46a478`](https://github.com/mastra-ai/mastra/commit/f46a4782f595949c696569e891f81c8d26338508), [`90fc0e5`](https://github.com/mastra-ai/mastra/commit/90fc0e5717cb280c2d4acf4f0410b510bb4c0a72), [`f05a3a5`](https://github.com/mastra-ai/mastra/commit/f05a3a5cf2b9a9c2d40c09cb8c762a4b6cd5d565), [`a291da9`](https://github.com/mastra-ai/mastra/commit/a291da9363efd92dafd8775dccb4f2d0511ece7a), [`c5d71da`](https://github.com/mastra-ai/mastra/commit/c5d71da1c680ce5640b1a7f8ca0e024a4ab1cfed), [`07042f9`](https://github.com/mastra-ai/mastra/commit/07042f9f89080f38b8f72713ba1c972d5b1905b8), [`0423442`](https://github.com/mastra-ai/mastra/commit/0423442b7be2dfacba95890bea8f4a810db4d603)]:
78
+ - @mastra/core@1.1.0-alpha.0
79
+
80
+ ## 1.0.0
81
+
82
+ ### Major Changes
83
+
84
+ - Moving scorers under the eval domain, api method consistency, prebuilt evals, scorers require ids. ([#9589](https://github.com/mastra-ai/mastra/pull/9589))
85
+
86
+ - 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))
87
+
88
+ Primitives that are added to other primitives are also automatically added to the Mastra instance
89
+
90
+ - 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))
91
+
92
+ - Remove `getMessagesPaginated()` and add `perPage: false` support ([#9670](https://github.com/mastra-ai/mastra/pull/9670))
93
+
94
+ Removes deprecated `getMessagesPaginated()` method. The `listMessages()` API and score handlers now support `perPage: false` to fetch all records without pagination limits.
95
+
96
+ **Storage changes:**
97
+ - `StoragePagination.perPage` type changed from `number` to `number | false`
98
+ - All storage implementations support `perPage: false`:
99
+ - Memory: `listMessages()`
100
+ - Scores: `listScoresBySpan()`, `listScoresByRunId()`, `listScoresByExecutionId()`
101
+ - HTTP query parser accepts `"false"` string (e.g., `?perPage=false`)
102
+
103
+ **Memory changes:**
104
+ - `memory.query()` parameter type changed from `StorageGetMessagesArg` to `StorageListMessagesInput`
105
+ - Uses flat parameters (`page`, `perPage`, `include`, `filter`, `vectorSearchString`) instead of `selectBy` object
106
+
107
+ **Stricter validation:**
108
+ - `listMessages()` requires non-empty, non-whitespace `threadId` (throws error instead of returning empty results)
109
+
110
+ **Migration:**
111
+
112
+ ```typescript
113
+ // Storage/Memory: Replace getMessagesPaginated with listMessages
114
+ - storage.getMessagesPaginated({ threadId, selectBy: { pagination: { page: 0, perPage: 20 } } })
115
+ + storage.listMessages({ threadId, page: 0, perPage: 20 })
116
+ + storage.listMessages({ threadId, page: 0, perPage: false }) // Fetch all
117
+
118
+ // Memory: Replace selectBy with flat parameters
119
+ - memory.query({ threadId, selectBy: { last: 20, include: [...] } })
120
+ + memory.query({ threadId, perPage: 20, include: [...] })
121
+
122
+ // Client SDK
123
+ - thread.getMessagesPaginated({ selectBy: { pagination: { page: 0 } } })
124
+ + thread.listMessages({ page: 0, perPage: 20 })
125
+ ```
126
+
127
+ - **Removed `storage.getMessages()`** ([#9695](https://github.com/mastra-ai/mastra/pull/9695))
128
+
129
+ The `getMessages()` method has been removed from all storage implementations. Use `listMessages()` instead, which provides pagination support.
130
+
131
+ **Migration:**
132
+
133
+ ```typescript
134
+ // Before
135
+ const messages = await storage.getMessages({ threadId: 'thread-1' });
136
+
137
+ // After
138
+ const result = await storage.listMessages({
139
+ threadId: 'thread-1',
140
+ page: 0,
141
+ perPage: 50,
142
+ });
143
+ const messages = result.messages; // Access messages array
144
+ console.log(result.total); // Total count
145
+ console.log(result.hasMore); // Whether more pages exist
146
+ ```
147
+
148
+ **Message ordering default**
149
+
150
+ `listMessages()` defaults to ASC (oldest first) ordering by `createdAt`, matching the previous `getMessages()` behavior.
151
+
152
+ **To use DESC ordering (newest first):**
153
+
154
+ ```typescript
155
+ const result = await storage.listMessages({
156
+ threadId: 'thread-1',
157
+ orderBy: { field: 'createdAt', direction: 'DESC' },
158
+ });
159
+ ```
160
+
161
+ **Renamed `client.getThreadMessages()` → `client.listThreadMessages()`**
162
+
163
+ **Migration:**
164
+
165
+ ```typescript
166
+ // Before
167
+ const response = await client.getThreadMessages(threadId, { agentId });
168
+
169
+ // After
170
+ const response = await client.listThreadMessages(threadId, { agentId });
171
+ ```
172
+
173
+ The response format remains the same.
174
+
175
+ **Removed `StorageGetMessagesArg` type**
176
+
177
+ Use `StorageListMessagesInput` instead:
178
+
179
+ ```typescript
180
+ // Before
181
+ import type { StorageGetMessagesArg } from '@mastra/core';
182
+
183
+ // After
184
+ import type { StorageListMessagesInput } from '@mastra/core';
185
+ ```
186
+
187
+ - Bump minimum required Node.js version to 22.13.0 ([#9706](https://github.com/mastra-ai/mastra/pull/9706))
188
+
189
+ - 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))
190
+
191
+ - Rename RuntimeContext to RequestContext ([#9511](https://github.com/mastra-ai/mastra/pull/9511))
192
+
193
+ - Implement listMessages API for replacing previous methods ([#9531](https://github.com/mastra-ai/mastra/pull/9531))
194
+
195
+ - 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))
196
+
197
+ - 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))
198
+
199
+ - Renamed a bunch of observability/tracing-related things to drop the AI prefix. ([#9744](https://github.com/mastra-ai/mastra/pull/9744))
200
+
201
+ - Pagination APIs now use `page`/`perPage` instead of `offset`/`limit` ([#9592](https://github.com/mastra-ai/mastra/pull/9592))
202
+
203
+ 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.
204
+
205
+ **Affected APIs:**
206
+ - `Memory.listThreadsByResourceId()`
207
+ - `Memory.listMessages()`
208
+ - `Storage.listWorkflowRuns()`
209
+
210
+ **Migration:**
211
+
212
+ ```typescript
213
+ // Before
214
+ await memory.listThreadsByResourceId({
215
+ resourceId: 'user-123',
216
+ offset: 20,
217
+ limit: 10,
218
+ });
219
+
220
+ // After
221
+ await memory.listThreadsByResourceId({
222
+ resourceId: 'user-123',
223
+ page: 2, // page = Math.floor(offset / limit)
224
+ perPage: 10,
225
+ });
226
+
227
+ // Before
228
+ await memory.listMessages({
229
+ threadId: 'thread-456',
230
+ offset: 20,
231
+ limit: 10,
232
+ });
233
+
234
+ // After
235
+ await memory.listMessages({
236
+ threadId: 'thread-456',
237
+ page: 2,
238
+ perPage: 10,
239
+ });
240
+
241
+ // Before
242
+ await storage.listWorkflowRuns({
243
+ workflowName: 'my-workflow',
244
+ offset: 20,
245
+ limit: 10,
246
+ });
247
+
248
+ // After
249
+ await storage.listWorkflowRuns({
250
+ workflowName: 'my-workflow',
251
+ page: 2,
252
+ perPage: 10,
253
+ });
254
+ ```
255
+
256
+ **Additional improvements:**
257
+ - Added validation for negative `page` values in all storage implementations
258
+ - Improved `perPage` validation to handle edge cases (negative values, `0`, `false`)
259
+ - Added reusable query parser utilities for consistent validation in handlers
260
+
261
+ - ```ts ([#9709](https://github.com/mastra-ai/mastra/pull/9709))
262
+ import { Mastra } from '@mastra/core';
263
+ import { Observability } from '@mastra/observability'; // Explicit import
264
+
265
+ const mastra = new Mastra({
266
+ ...other_config,
267
+ observability: new Observability({
268
+ default: { enabled: true },
269
+ }), // Instance
270
+ });
271
+ ```
272
+
273
+ Instead of:
274
+
275
+ ```ts
276
+ import { Mastra } from '@mastra/core';
277
+ import '@mastra/observability/init'; // Explicit import
278
+
279
+ const mastra = new Mastra({
280
+ ...other_config,
281
+ observability: {
282
+ default: { enabled: true },
283
+ },
284
+ });
285
+ ```
286
+
287
+ Also renamed a bunch of:
288
+ - `Tracing` things to `Observability` things.
289
+ - `AI-` things to just things.
290
+
291
+ - Removed old tracing code based on OpenTelemetry ([#9237](https://github.com/mastra-ai/mastra/pull/9237))
292
+
293
+ - Mark as stable ([`83d5942`](https://github.com/mastra-ai/mastra/commit/83d5942669ce7bba4a6ca4fd4da697a10eb5ebdc))
294
+
295
+ - Renamed `MastraMessageV2` to `MastraDBMessage` ([#9255](https://github.com/mastra-ai/mastra/pull/9255))
296
+ 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
297
+
298
+ - Remove legacy evals from Mastra ([#9491](https://github.com/mastra-ai/mastra/pull/9491))
299
+
300
+ ### Minor Changes
301
+
302
+ - Add stored agents support ([#10953](https://github.com/mastra-ai/mastra/pull/10953))
303
+
304
+ 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.
305
+
306
+ ```typescript
307
+ import { Mastra } from '@mastra/core';
308
+ import { LibSQLStore } from '@mastra/libsql';
309
+
310
+ const mastra = new Mastra({
311
+ storage: new LibSQLStore({ url: ':memory:' }),
312
+ tools: { myTool },
313
+ scorers: { myScorer },
314
+ });
315
+
316
+ // Create agent in storage via API or directly
317
+ await mastra.getStorage().createAgent({
318
+ agent: {
319
+ id: 'my-agent',
320
+ name: 'My Agent',
321
+ instructions: 'You are helpful',
322
+ model: { provider: 'openai', name: 'gpt-4' },
323
+ tools: { myTool: {} },
324
+ scorers: { myScorer: { sampling: { type: 'ratio', rate: 0.5 } } },
325
+ },
326
+ });
327
+
328
+ // Load and use the agent
329
+ const agent = await mastra.getStoredAgentById('my-agent');
330
+ const response = await agent.generate('Hello!');
331
+
332
+ // List all stored agents with pagination
333
+ const { agents, total, hasMore } = await mastra.listStoredAgents({
334
+ page: 0,
335
+ perPage: 10,
336
+ });
337
+ ```
338
+
339
+ Also adds a memory registry to Mastra so stored agents can reference memory instances by key.
340
+
341
+ - Update peer dependencies to match core package version bump (1.0.0) ([#9237](https://github.com/mastra-ai/mastra/pull/9237))
342
+
343
+ - Changed JSON columns from TEXT to JSONB in `mastra_threads` and `mastra_workflow_snapshot` tables. ([#11853](https://github.com/mastra-ai/mastra/pull/11853))
344
+
345
+ **Why this change?**
346
+
347
+ 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.
348
+
349
+ **Columns Changed:**
350
+ - `mastra_threads.metadata` - Thread metadata
351
+ - `mastra_workflow_snapshot.snapshot` - Workflow run state
352
+
353
+ **PostgreSQL**
354
+
355
+ Migration Required - PostgreSQL enforces column types, so existing tables must be migrated. Note: Migration will fail if existing column values contain invalid JSON.
356
+
357
+ ```sql
358
+ ALTER TABLE mastra_threads
359
+ ALTER COLUMN metadata TYPE jsonb
360
+ USING metadata::jsonb;
361
+
362
+ ALTER TABLE mastra_workflow_snapshot
363
+ ALTER COLUMN snapshot TYPE jsonb
364
+ USING snapshot::jsonb;
365
+ ```
366
+
367
+ **LibSQL**
368
+
369
+ 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:
370
+ - Existing TEXT JSON data continues to work
371
+ - New data is stored in binary JSONB format
372
+ - Both formats can coexist in the same table
373
+ - All JSON functions (`json_extract`, etc.) work on both formats
374
+
375
+ New installations automatically use JSONB. Existing applications continue to work without any changes.
376
+
377
+ - Introduce StorageDomain base class for composite storage support ([#11249](https://github.com/mastra-ai/mastra/pull/11249))
378
+
379
+ 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.
380
+
381
+ **Key changes:**
382
+ - Add `StorageDomain` abstract base class that all domain storage classes extend
383
+ - Add `InMemoryDB` class for shared state across in-memory domain implementations
384
+ - All storage domains now implement `dangerouslyClearAll()` for test cleanup
385
+ - Remove `operations` from public `StorageDomains` type (now internal to each adapter)
386
+ - Add flexible client/config patterns - domains accept either an existing database client or config to create one internally
387
+
388
+ **Why this matters:**
389
+
390
+ This enables composite storage where you can use different database adapters per domain:
391
+
392
+ ```typescript
393
+ import { Mastra } from '@mastra/core';
394
+ import { PostgresStore } from '@mastra/pg';
395
+ import { ClickhouseStore } from '@mastra/clickhouse';
396
+
397
+ // Use Postgres for most domains but Clickhouse for observability
398
+ const mastra = new Mastra({
399
+ storage: new PostgresStore({
400
+ connectionString: 'postgres://...',
401
+ }),
402
+ // Future: override specific domains
403
+ // observability: new ClickhouseStore({ ... }).getStore('observability'),
404
+ });
405
+ ```
406
+
407
+ **Standalone domain usage:**
408
+
409
+ Domains can now be used independently with flexible configuration:
410
+
411
+ ```typescript
412
+ import { MemoryLibSQL } from '@mastra/libsql/memory';
413
+
414
+ // Option 1: Pass config to create client internally
415
+ const memory = new MemoryLibSQL({
416
+ url: 'file:./local.db',
417
+ });
418
+
419
+ // Option 2: Pass existing client for shared connections
420
+ import { createClient } from '@libsql/client';
421
+ const client = createClient({ url: 'file:./local.db' });
422
+ const memory = new MemoryLibSQL({ client });
423
+ ```
424
+
425
+ **Breaking changes:**
426
+ - `StorageDomains` type no longer includes `operations` - access via `getStore()` instead
427
+ - Domain base classes now require implementing `dangerouslyClearAll()` method
428
+
429
+ - Refactor storage architecture to use domain-specific stores via `getStore()` pattern ([#11361](https://github.com/mastra-ai/mastra/pull/11361))
430
+
431
+ ### Summary
432
+
433
+ 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.
434
+
435
+ ### Migration Guide
436
+
437
+ All direct method calls on storage instances should be updated to use `getStore()`:
438
+
439
+ ```typescript
440
+ // Before
441
+ const thread = await storage.getThreadById({ threadId });
442
+ await storage.persistWorkflowSnapshot({ workflowName, runId, snapshot });
443
+ await storage.createSpan(span);
444
+
445
+ // After
446
+ const memory = await storage.getStore('memory');
447
+ const thread = await memory?.getThreadById({ threadId });
448
+
449
+ const workflows = await storage.getStore('workflows');
450
+ await workflows?.persistWorkflowSnapshot({ workflowName, runId, snapshot });
451
+
452
+ const observability = await storage.getStore('observability');
453
+ await observability?.createSpan(span);
454
+ ```
455
+
456
+ ### Available Domains
457
+ - **`memory`**: Thread and message operations (`getThreadById`, `saveThread`, `saveMessages`, etc.)
458
+ - **`workflows`**: Workflow state persistence (`persistWorkflowSnapshot`, `loadWorkflowSnapshot`, `getWorkflowRunById`, etc.)
459
+ - **`scores`**: Evaluation scores (`saveScore`, `listScoresByScorerId`, etc.)
460
+ - **`observability`**: Tracing and spans (`createSpan`, `updateSpan`, `getTrace`, etc.)
461
+ - **`agents`**: Stored agent configurations (`createAgent`, `getAgentById`, `listAgents`, etc.)
462
+
463
+ ### Breaking Changes
464
+ - Passthrough methods have been removed from `MastraStorage` base class
465
+ - All storage adapters now require accessing domains via `getStore()`
466
+ - The `stores` property on storage instances is now the canonical way to access domain storage
467
+
468
+ ### Internal Changes
469
+ - Each storage adapter now initializes domain-specific stores in its constructor
470
+ - Domain stores share database connections and handle their own table initialization
471
+
472
+ - Unified observability schema with entity-based span identification ([#11132](https://github.com/mastra-ai/mastra/pull/11132))
473
+
474
+ ## What changed
475
+
476
+ Spans now use a unified identification model with `entityId`, `entityType`, and `entityName` instead of separate `agentId`, `toolId`, `workflowId` fields.
477
+
478
+ **Before:**
479
+
480
+ ```typescript
481
+ // Old span structure
482
+ span.agentId; // 'my-agent'
483
+ span.toolId; // undefined
484
+ span.workflowId; // undefined
485
+ ```
486
+
487
+ **After:**
488
+
489
+ ```typescript
490
+ // New span structure
491
+ span.entityType; // EntityType.AGENT
492
+ span.entityId; // 'my-agent'
493
+ span.entityName; // 'My Agent'
494
+ ```
495
+
496
+ ## New `listTraces()` API
497
+
498
+ Query traces with filtering, pagination, and sorting:
499
+
500
+ ```typescript
501
+ const { spans, pagination } = await storage.listTraces({
502
+ filters: {
503
+ entityType: EntityType.AGENT,
504
+ entityId: 'my-agent',
505
+ userId: 'user-123',
506
+ environment: 'production',
507
+ status: TraceStatus.SUCCESS,
508
+ startedAt: { start: new Date('2024-01-01'), end: new Date('2024-01-31') },
509
+ },
510
+ pagination: { page: 0, perPage: 50 },
511
+ orderBy: { field: 'startedAt', direction: 'DESC' },
512
+ });
513
+ ```
514
+
515
+ **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`.
516
+
517
+ ## New retrieval methods
518
+ - `getSpan({ traceId, spanId })` - Get a single span
519
+ - `getRootSpan({ traceId })` - Get the root span of a trace
520
+ - `getTrace({ traceId })` - Get all spans for a trace
521
+
522
+ ## Backward compatibility
523
+
524
+ The legacy `getTraces()` method continues to work. When you pass `name: "agent run: my-agent"`, it automatically transforms to `entityId: "my-agent", entityType: AGENT`.
525
+
526
+ ## Migration
527
+
528
+ **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`.
529
+
530
+ **No action required:** Your existing code continues to work. Adopt the new fields and `listTraces()` API at your convenience.
531
+
532
+ - 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))
533
+
534
+ **Why this change?**
535
+
536
+ 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.
537
+
538
+ **@mastra/libsql** (Breaking)
539
+
540
+ Renamed `connectionUrl` to `url` to match the `@libsql/client` API and align with LibSQLStorage.
541
+
542
+ ```typescript
543
+ // Before
544
+ new LibSQLVector({ id: 'my-vector', connectionUrl: 'file:./db.sqlite' });
545
+
546
+ // After
547
+ new LibSQLVector({ id: 'my-vector', url: 'file:./db.sqlite' });
548
+ ```
549
+
550
+ **@mastra/opensearch** (Breaking)
551
+
552
+ Renamed `url` to `node` and added support for all OpenSearch `ClientOptions` including authentication, SSL, and compression.
553
+
554
+ ```typescript
555
+ // Before
556
+ new OpenSearchVector({ id: 'my-vector', url: 'http://localhost:9200' });
557
+
558
+ // After
559
+ new OpenSearchVector({ id: 'my-vector', node: 'http://localhost:9200' });
560
+
561
+ // With authentication (now possible)
562
+ new OpenSearchVector({
563
+ id: 'my-vector',
564
+ node: 'https://localhost:9200',
565
+ auth: { username: 'admin', password: 'admin' },
566
+ ssl: { rejectUnauthorized: false },
567
+ });
568
+ ```
569
+
570
+ **@mastra/pinecone** (Breaking)
571
+
572
+ Removed `environment` parameter. Use `controllerHostUrl` instead (the actual Pinecone SDK field name). Added support for all `PineconeConfiguration` options.
573
+
574
+ ```typescript
575
+ // Before
576
+ new PineconeVector({ id: 'my-vector', apiKey: '...', environment: '...' });
577
+
578
+ // After
579
+ new PineconeVector({ id: 'my-vector', apiKey: '...' });
580
+
581
+ // With custom controller host (if needed)
582
+ new PineconeVector({ id: 'my-vector', apiKey: '...', controllerHostUrl: '...' });
583
+ ```
584
+
585
+ **@mastra/clickhouse**
586
+
587
+ Added support for all `ClickHouseClientConfigOptions` like `request_timeout`, `compression`, `keep_alive`, and `database`. Existing configurations continue to work unchanged.
588
+
589
+ **@mastra/cloudflare, @mastra/cloudflare-d1, @mastra/lance, @mastra/libsql, @mastra/mongodb, @mastra/pg, @mastra/upstash**
590
+
591
+ Improved logging by replacing `console.warn` with structured logger in workflow storage domains.
592
+
593
+ **@mastra/deployer-cloud**
594
+
595
+ Updated internal LibSQLVector configuration for compatibility with the new API.
596
+
597
+ - Add `disableInit` option to all storage adapters ([#10851](https://github.com/mastra-ai/mastra/pull/10851))
598
+
599
+ 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.
600
+
601
+ ```typescript
602
+ // CI/CD script - run migrations
603
+ const storage = new PostgresStore({
604
+ connectionString: DATABASE_URL,
605
+ id: 'pg-storage',
606
+ });
607
+ await storage.init();
608
+
609
+ // Runtime - skip auto-init
610
+ const storage = new PostgresStore({
611
+ connectionString: DATABASE_URL,
612
+ id: 'pg-storage',
613
+ disableInit: true,
614
+ });
615
+ ```
616
+
617
+ ### Patch Changes
618
+
619
+ - Add embedded documentation support for Mastra packages ([#11472](https://github.com/mastra-ai/mastra/pull/11472))
620
+
621
+ 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`.
622
+
623
+ Each package includes:
624
+ - **SKILL.md** - Entry point explaining the package's purpose and capabilities
625
+ - **SOURCE_MAP.json** - Machine-readable index mapping exports to types and implementation files
626
+ - **Topic folders** - Conceptual documentation organized by feature area
627
+
628
+ 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.
629
+
630
+ - 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))
631
+
632
+ - Fix saveScore not persisting ID correctly, breaking getScoreById retrieval ([#10915](https://github.com/mastra-ai/mastra/pull/10915))
633
+
634
+ **What Changed**
635
+ - saveScore now correctly returns scores that can be retrieved with getScoreById
636
+ - Validation errors now include contextual information (scorer, entity, trace details) for easier debugging
637
+
638
+ **Impact**
639
+ 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.
640
+
641
+ - Add new deleteVectors, updateVector by filter ([#10408](https://github.com/mastra-ai/mastra/pull/10408))
642
+
643
+ - - Fixed TypeScript errors where `threadId: string | string[]` was being passed to places expecting `Scalar` type ([#10663](https://github.com/mastra-ai/mastra/pull/10663))
644
+ - Added proper multi-thread support for `listMessages` across all adapters when `threadId` is an array
645
+ - Updated `_getIncludedMessages` to look up message threadId by ID (since message IDs are globally unique)
646
+ - **upstash**: Added `msg-idx:{messageId}` index for O(1) message lookups (backwards compatible with fallback to scan for old messages, with automatic backfill)
647
+
648
+ - Preserve error details when thrown from workflow steps ([#10992](https://github.com/mastra-ai/mastra/pull/10992))
649
+
650
+ Workflow errors now retain custom properties like `statusCode`, `responseHeaders`, and `cause` chains. This enables error-specific recovery logic in your applications.
651
+
652
+ **Before:**
653
+
654
+ ```typescript
655
+ const result = await workflow.execute({ input });
656
+ if (result.status === 'failed') {
657
+ // Custom error properties were lost
658
+ console.log(result.error); // "Step execution failed" (just a string)
659
+ }
660
+ ```
661
+
662
+ **After:**
663
+
664
+ ```typescript
665
+ const result = await workflow.execute({ input });
666
+ if (result.status === 'failed') {
667
+ // Custom properties are preserved
668
+ console.log(result.error.message); // "Step execution failed"
669
+ console.log(result.error.statusCode); // 429
670
+ console.log(result.error.cause?.name); // "RateLimitError"
671
+ }
672
+ ```
673
+
674
+ **Type change:** `WorkflowState.error` and `WorkflowRunState.error` types changed from `string | Error` to `SerializedError`.
675
+
676
+ Other changes:
677
+ - Added `UpdateWorkflowStateOptions` type for workflow state updates
678
+
679
+ - Added `startExclusive` and `endExclusive` options to `dateRange` filter for message queries. ([#11479](https://github.com/mastra-ai/mastra/pull/11479))
680
+
681
+ **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.
682
+
683
+ **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.
684
+
685
+ **Example:**
686
+
687
+ ```typescript
688
+ // Get first page
689
+ const page1 = await memory.recall({
690
+ threadId: 'thread-123',
691
+ perPage: 10,
692
+ orderBy: { field: 'createdAt', direction: 'DESC' },
693
+ });
694
+
695
+ // Get next page using cursor-based pagination
696
+ const oldestMessage = page1.messages[page1.messages.length - 1];
697
+ const page2 = await memory.recall({
698
+ threadId: 'thread-123',
699
+ perPage: 10,
700
+ orderBy: { field: 'createdAt', direction: 'DESC' },
701
+ filter: {
702
+ dateRange: {
703
+ end: oldestMessage.createdAt,
704
+ endExclusive: true, // Excludes the cursor message
705
+ },
706
+ },
707
+ });
708
+ ```
709
+
710
+ - 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))
711
+
712
+ **Deduplication rules (in priority order):**
713
+ 1. Keep completed spans (those with `endedAt` set) over incomplete spans
714
+ 2. Among spans with the same completion status, keep the one with the newest `updatedAt`
715
+ 3. Use `createdAt` as the final tiebreaker
716
+
717
+ **What changed:**
718
+ - Added `migrateSpans()` method to observability stores for manual migration
719
+ - Added `checkSpansMigrationStatus()` method to check if migration is needed
720
+ - All stores use optimized single-query deduplication to avoid memory issues on large tables
721
+
722
+ **Usage example:**
723
+
724
+ ```typescript
725
+ const observability = await storage.getStore('observability');
726
+ const status = await observability.checkSpansMigrationStatus();
727
+ if (status.needsMigration) {
728
+ const result = await observability.migrateSpans();
729
+ console.log(`Migration complete: ${result.duplicatesRemoved} duplicates removed`);
730
+ }
731
+ ```
732
+
733
+ Fixes #11840
734
+
735
+ - Add storage composition to MastraStorage ([#11401](https://github.com/mastra-ai/mastra/pull/11401))
736
+
737
+ `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.
738
+
739
+ ```typescript
740
+ import { MastraStorage } from '@mastra/core/storage';
741
+ import { MemoryPG, WorkflowsPG, ScoresPG } from '@mastra/pg';
742
+ import { MemoryLibSQL } from '@mastra/libsql';
743
+
744
+ // Compose domains from different stores
745
+ const storage = new MastraStorage({
746
+ id: 'composite',
747
+ domains: {
748
+ memory: new MemoryLibSQL({ url: 'file:./local.db' }),
749
+ workflows: new WorkflowsPG({ connectionString: process.env.DATABASE_URL }),
750
+ scores: new ScoresPG({ connectionString: process.env.DATABASE_URL }),
751
+ },
752
+ });
753
+ ```
754
+
755
+ **Breaking changes:**
756
+ - `storage.supports` property no longer exists
757
+ - `StorageSupports` type is no longer exported from `@mastra/core/storage`
758
+
759
+ All stores now support the same features. For domain availability, use `getStore()`:
760
+
761
+ ```typescript
762
+ const store = await storage.getStore('memory');
763
+ if (store) {
764
+ // domain is available
765
+ }
766
+ ```
767
+
768
+ - - PostgreSQL: use `getSqlType()` in `createTable` instead of `toUpperCase()` ([#11112](https://github.com/mastra-ai/mastra/pull/11112))
769
+ - LibSQL: use `getSqlType()` in `createTable`, return `JSONB` for jsonb type (matches SQLite 3.45+ support)
770
+ - ClickHouse: use `getSqlType()` in `createTable` instead of `COLUMN_TYPES` constant, add missing types (uuid, float, boolean)
771
+ - Remove unused `getSqlType()` and `getDefaultValue()` from `MastraStorage` base class (all stores use `StoreOperations` versions)
772
+
773
+ - Add delete workflow run API ([#10991](https://github.com/mastra-ai/mastra/pull/10991))
774
+
775
+ ```typescript
776
+ await workflow.deleteWorkflowRunById(runId);
777
+ ```
778
+
779
+ - 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))
780
+ - `preferredTimestampFields`: Preferred source fields for timestamps (PostgreSQL, Cloudflare D1)
781
+ - `convertTimestamps`: Convert timestamp strings to Date objects (MSSQL, MongoDB, ClickHouse)
782
+ - `nullValuePattern`: Skip values matching pattern (ClickHouse's `'_null_'`)
783
+ - `fieldMappings`: Map source column names to schema fields (LibSQL's `additionalLLMContext`)
784
+
785
+ 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.
786
+
787
+ - Added new `listThreads` method for flexible thread filtering across all storage adapters. ([#11832](https://github.com/mastra-ai/mastra/pull/11832))
788
+
789
+ **New Features**
790
+ - Filter threads by `resourceId`, `metadata`, or both (with AND logic for metadata key-value pairs)
791
+ - All filter parameters are optional, allowing you to list all threads or filter as needed
792
+ - Full pagination and sorting support
793
+
794
+ **Example Usage**
795
+
796
+ ```typescript
797
+ // List all threads
798
+ const allThreads = await memory.listThreads({});
799
+
800
+ // Filter by resourceId only
801
+ const userThreads = await memory.listThreads({
802
+ filter: { resourceId: 'user-123' },
803
+ });
804
+
805
+ // Filter by metadata only
806
+ const supportThreads = await memory.listThreads({
807
+ filter: { metadata: { category: 'support' } },
808
+ });
809
+
810
+ // Filter by both with pagination
811
+ const filteredThreads = await memory.listThreads({
812
+ filter: {
813
+ resourceId: 'user-123',
814
+ metadata: { priority: 'high', status: 'open' },
815
+ },
816
+ orderBy: { field: 'updatedAt', direction: 'DESC' },
817
+ page: 0,
818
+ perPage: 20,
819
+ });
820
+ ```
821
+
822
+ **Security Improvements**
823
+ - Added validation to prevent SQL injection via malicious metadata keys
824
+ - Added pagination parameter validation to prevent integer overflow attacks
825
+
826
+ - Add restart method to workflow run that allows restarting an active workflow run ([#9750](https://github.com/mastra-ai/mastra/pull/9750))
827
+ Add status filter to `listWorkflowRuns`
828
+ Add automatic restart to restart active workflow runs when server starts
829
+
830
+ - 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))
831
+
832
+ **Migration:**
833
+
834
+ Update your imports and usage:
835
+
836
+ ```typescript
837
+ // Before
838
+ import { MastraStorage } from '@mastra/core/storage';
839
+
840
+ const storage = new MastraStorage({
841
+ id: 'composite',
842
+ domains: { ... }
843
+ });
844
+
845
+ // After
846
+ import { MastraCompositeStore } from '@mastra/core/storage';
847
+
848
+ const storage = new MastraCompositeStore({
849
+ id: 'composite',
850
+ domains: { ... }
851
+ });
852
+ ```
853
+
854
+ 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.
855
+
856
+ - Adds thread cloning to create independent copies of conversations that can diverge. ([#11517](https://github.com/mastra-ai/mastra/pull/11517))
857
+
858
+ ```typescript
859
+ // Clone a thread
860
+ const { thread, clonedMessages } = await memory.cloneThread({
861
+ sourceThreadId: 'thread-123',
862
+ title: 'My Clone',
863
+ options: {
864
+ messageLimit: 10, // optional: only copy last N messages
865
+ },
866
+ });
867
+
868
+ // Check if a thread is a clone
869
+ if (memory.isClone(thread)) {
870
+ const source = await memory.getSourceThread(thread.id);
871
+ }
872
+
873
+ // List all clones of a thread
874
+ const clones = await memory.listClones('thread-123');
875
+ ```
876
+
877
+ Includes:
878
+ - Storage implementations for InMemory, PostgreSQL, LibSQL, Upstash
879
+ - API endpoint: `POST /api/memory/threads/:threadId/clone`
880
+ - Embeddings created for cloned messages (semantic recall)
881
+ - Clone button in playground UI Memory tab
882
+
883
+ - Added pre-configured client support for all storage adapters. ([#11302](https://github.com/mastra-ai/mastra/pull/11302))
884
+
885
+ **What changed**
886
+
887
+ 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.
888
+
889
+ **Example**
890
+
891
+ ```typescript
892
+ import { createClient } from '@clickhouse/client';
893
+ import { ClickhouseStore } from '@mastra/clickhouse';
894
+
895
+ // Create and configure client with custom settings
896
+ const client = createClient({
897
+ url: 'http://localhost:8123',
898
+ username: 'default',
899
+ password: '',
900
+ request_timeout: 60000,
901
+ });
902
+
903
+ // Pass pre-configured client to store
904
+ const store = new ClickhouseStore({
905
+ id: 'my-store',
906
+ client,
907
+ });
908
+ ```
909
+
910
+ **Additional improvements**
911
+ - Added input validation for required connection parameters (URL, credentials) with clear error messages
912
+
913
+ - 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)]:
914
+ - @mastra/core@1.0.0
915
+
916
+ ## 1.0.0-beta.14
917
+
918
+ ### Patch Changes
919
+
920
+ - 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))
921
+
922
+ **Deduplication rules (in priority order):**
923
+ 1. Keep completed spans (those with `endedAt` set) over incomplete spans
924
+ 2. Among spans with the same completion status, keep the one with the newest `updatedAt`
925
+ 3. Use `createdAt` as the final tiebreaker
926
+
927
+ **What changed:**
928
+ - Added `migrateSpans()` method to observability stores for manual migration
929
+ - Added `checkSpansMigrationStatus()` method to check if migration is needed
930
+ - All stores use optimized single-query deduplication to avoid memory issues on large tables
931
+
932
+ **Usage example:**
933
+
934
+ ```typescript
935
+ const observability = await storage.getStore('observability');
936
+ const status = await observability.checkSpansMigrationStatus();
937
+ if (status.needsMigration) {
938
+ const result = await observability.migrateSpans();
939
+ console.log(`Migration complete: ${result.duplicatesRemoved} duplicates removed`);
940
+ }
941
+ ```
942
+
943
+ Fixes #11840
944
+
945
+ - 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))
946
+
947
+ **Migration:**
948
+
949
+ Update your imports and usage:
950
+
951
+ ```typescript
952
+ // Before
953
+ import { MastraStorage } from '@mastra/core/storage';
954
+
955
+ const storage = new MastraStorage({
956
+ id: 'composite',
957
+ domains: { ... }
958
+ });
959
+
960
+ // After
961
+ import { MastraCompositeStore } from '@mastra/core/storage';
962
+
963
+ const storage = new MastraCompositeStore({
964
+ id: 'composite',
965
+ domains: { ... }
966
+ });
967
+ ```
968
+
969
+ 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.
970
+
971
+ - Updated dependencies [[`026b848`](https://github.com/mastra-ai/mastra/commit/026b8483fbf5b6d977be8f7e6aac8d15c75558ac), [`ffa553a`](https://github.com/mastra-ai/mastra/commit/ffa553a3edc1bd17d73669fba66d6b6f4ac10897)]:
972
+ - @mastra/core@1.0.0-beta.26
973
+
974
+ ## 1.0.0-beta.13
975
+
976
+ ### Patch Changes
977
+
978
+ - Added new `listThreads` method for flexible thread filtering across all storage adapters. ([#11832](https://github.com/mastra-ai/mastra/pull/11832))
979
+
980
+ **New Features**
981
+ - Filter threads by `resourceId`, `metadata`, or both (with AND logic for metadata key-value pairs)
982
+ - All filter parameters are optional, allowing you to list all threads or filter as needed
983
+ - Full pagination and sorting support
984
+
985
+ **Example Usage**
986
+
987
+ ```typescript
988
+ // List all threads
989
+ const allThreads = await memory.listThreads({});
990
+
991
+ // Filter by resourceId only
992
+ const userThreads = await memory.listThreads({
993
+ filter: { resourceId: 'user-123' },
994
+ });
995
+
996
+ // Filter by metadata only
997
+ const supportThreads = await memory.listThreads({
998
+ filter: { metadata: { category: 'support' } },
999
+ });
1000
+
1001
+ // Filter by both with pagination
1002
+ const filteredThreads = await memory.listThreads({
1003
+ filter: {
1004
+ resourceId: 'user-123',
1005
+ metadata: { priority: 'high', status: 'open' },
1006
+ },
1007
+ orderBy: { field: 'updatedAt', direction: 'DESC' },
1008
+ page: 0,
1009
+ perPage: 20,
1010
+ });
1011
+ ```
1012
+
1013
+ **Security Improvements**
1014
+ - Added validation to prevent SQL injection via malicious metadata keys
1015
+ - Added pagination parameter validation to prevent integer overflow attacks
1016
+
1017
+ - 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)]:
1018
+ - @mastra/core@1.0.0-beta.25
1019
+
1020
+ ## 1.0.0-beta.12
1021
+
1022
+ ### Minor Changes
1023
+
1024
+ - Changed JSON columns from TEXT to JSONB in `mastra_threads` and `mastra_workflow_snapshot` tables. ([#11853](https://github.com/mastra-ai/mastra/pull/11853))
1025
+
1026
+ **Why this change?**
1027
+
1028
+ 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.
1029
+
1030
+ **Columns Changed:**
1031
+ - `mastra_threads.metadata` - Thread metadata
1032
+ - `mastra_workflow_snapshot.snapshot` - Workflow run state
1033
+
1034
+ **PostgreSQL**
1035
+
1036
+ Migration Required - PostgreSQL enforces column types, so existing tables must be migrated. Note: Migration will fail if existing column values contain invalid JSON.
1037
+
1038
+ ```sql
1039
+ ALTER TABLE mastra_threads
1040
+ ALTER COLUMN metadata TYPE jsonb
1041
+ USING metadata::jsonb;
1042
+
1043
+ ALTER TABLE mastra_workflow_snapshot
1044
+ ALTER COLUMN snapshot TYPE jsonb
1045
+ USING snapshot::jsonb;
1046
+ ```
1047
+
1048
+ **LibSQL**
1049
+
1050
+ 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:
1051
+ - Existing TEXT JSON data continues to work
1052
+ - New data is stored in binary JSONB format
1053
+ - Both formats can coexist in the same table
1054
+ - All JSON functions (`json_extract`, etc.) work on both formats
1055
+
1056
+ New installations automatically use JSONB. Existing applications continue to work without any changes.
1057
+
1058
+ - 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))
1059
+
1060
+ **Why this change?**
1061
+
1062
+ 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.
1063
+
1064
+ **@mastra/libsql** (Breaking)
1065
+
1066
+ Renamed `connectionUrl` to `url` to match the `@libsql/client` API and align with LibSQLStorage.
1067
+
1068
+ ```typescript
1069
+ // Before
1070
+ new LibSQLVector({ id: 'my-vector', connectionUrl: 'file:./db.sqlite' });
1071
+
1072
+ // After
1073
+ new LibSQLVector({ id: 'my-vector', url: 'file:./db.sqlite' });
1074
+ ```
1075
+
1076
+ **@mastra/opensearch** (Breaking)
1077
+
1078
+ Renamed `url` to `node` and added support for all OpenSearch `ClientOptions` including authentication, SSL, and compression.
1079
+
1080
+ ```typescript
1081
+ // Before
1082
+ new OpenSearchVector({ id: 'my-vector', url: 'http://localhost:9200' });
1083
+
1084
+ // After
1085
+ new OpenSearchVector({ id: 'my-vector', node: 'http://localhost:9200' });
1086
+
1087
+ // With authentication (now possible)
1088
+ new OpenSearchVector({
1089
+ id: 'my-vector',
1090
+ node: 'https://localhost:9200',
1091
+ auth: { username: 'admin', password: 'admin' },
1092
+ ssl: { rejectUnauthorized: false },
1093
+ });
1094
+ ```
1095
+
1096
+ **@mastra/pinecone** (Breaking)
1097
+
1098
+ Removed `environment` parameter. Use `controllerHostUrl` instead (the actual Pinecone SDK field name). Added support for all `PineconeConfiguration` options.
1099
+
1100
+ ```typescript
1101
+ // Before
1102
+ new PineconeVector({ id: 'my-vector', apiKey: '...', environment: '...' });
1103
+
1104
+ // After
1105
+ new PineconeVector({ id: 'my-vector', apiKey: '...' });
1106
+
1107
+ // With custom controller host (if needed)
1108
+ new PineconeVector({ id: 'my-vector', apiKey: '...', controllerHostUrl: '...' });
1109
+ ```
1110
+
1111
+ **@mastra/clickhouse**
1112
+
1113
+ Added support for all `ClickHouseClientConfigOptions` like `request_timeout`, `compression`, `keep_alive`, and `database`. Existing configurations continue to work unchanged.
1114
+
1115
+ **@mastra/cloudflare, @mastra/cloudflare-d1, @mastra/lance, @mastra/libsql, @mastra/mongodb, @mastra/pg, @mastra/upstash**
1116
+
1117
+ Improved logging by replacing `console.warn` with structured logger in workflow storage domains.
1118
+
1119
+ **@mastra/deployer-cloud**
1120
+
1121
+ Updated internal LibSQLVector configuration for compatibility with the new API.
1122
+
1123
+ ### Patch Changes
1124
+
1125
+ - 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)]:
1126
+ - @mastra/core@1.0.0-beta.22
1127
+
1128
+ ## 1.0.0-beta.11
1129
+
1130
+ ### Patch Changes
1131
+
1132
+ - Add embedded documentation support for Mastra packages ([#11472](https://github.com/mastra-ai/mastra/pull/11472))
1133
+
1134
+ 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`.
1135
+
1136
+ Each package includes:
1137
+ - **SKILL.md** - Entry point explaining the package's purpose and capabilities
1138
+ - **SOURCE_MAP.json** - Machine-readable index mapping exports to types and implementation files
1139
+ - **Topic folders** - Conceptual documentation organized by feature area
1140
+
1141
+ 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.
1142
+
1143
+ - Added `startExclusive` and `endExclusive` options to `dateRange` filter for message queries. ([#11479](https://github.com/mastra-ai/mastra/pull/11479))
1144
+
1145
+ **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.
1146
+
1147
+ **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.
1148
+
1149
+ **Example:**
1150
+
1151
+ ```typescript
1152
+ // Get first page
1153
+ const page1 = await memory.recall({
1154
+ threadId: 'thread-123',
1155
+ perPage: 10,
1156
+ orderBy: { field: 'createdAt', direction: 'DESC' },
1157
+ });
1158
+
1159
+ // Get next page using cursor-based pagination
1160
+ const oldestMessage = page1.messages[page1.messages.length - 1];
1161
+ const page2 = await memory.recall({
1162
+ threadId: 'thread-123',
1163
+ perPage: 10,
1164
+ orderBy: { field: 'createdAt', direction: 'DESC' },
1165
+ filter: {
1166
+ dateRange: {
1167
+ end: oldestMessage.createdAt,
1168
+ endExclusive: true, // Excludes the cursor message
1169
+ },
1170
+ },
1171
+ });
1172
+ ```
1173
+
1174
+ - Adds thread cloning to create independent copies of conversations that can diverge. ([#11517](https://github.com/mastra-ai/mastra/pull/11517))
1175
+
1176
+ ```typescript
1177
+ // Clone a thread
1178
+ const { thread, clonedMessages } = await memory.cloneThread({
1179
+ sourceThreadId: 'thread-123',
1180
+ title: 'My Clone',
1181
+ options: {
1182
+ messageLimit: 10, // optional: only copy last N messages
1183
+ },
1184
+ });
1185
+
1186
+ // Check if a thread is a clone
1187
+ if (memory.isClone(thread)) {
1188
+ const source = await memory.getSourceThread(thread.id);
1189
+ }
1190
+
1191
+ // List all clones of a thread
1192
+ const clones = await memory.listClones('thread-123');
1193
+ ```
1194
+
1195
+ Includes:
1196
+ - Storage implementations for InMemory, PostgreSQL, LibSQL, Upstash
1197
+ - API endpoint: `POST /api/memory/threads/:threadId/clone`
1198
+ - Embeddings created for cloned messages (semantic recall)
1199
+ - Clone button in playground UI Memory tab
1200
+
1201
+ - 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)]:
1202
+ - @mastra/core@1.0.0-beta.20
1203
+
1204
+ ## 1.0.0-beta.10
1205
+
1206
+ ### Patch Changes
1207
+
1208
+ - Add storage composition to MastraStorage ([#11401](https://github.com/mastra-ai/mastra/pull/11401))
1209
+
1210
+ `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.
1211
+
1212
+ ```typescript
1213
+ import { MastraStorage } from '@mastra/core/storage';
1214
+ import { MemoryPG, WorkflowsPG, ScoresPG } from '@mastra/pg';
1215
+ import { MemoryLibSQL } from '@mastra/libsql';
1216
+
1217
+ // Compose domains from different stores
1218
+ const storage = new MastraStorage({
1219
+ id: 'composite',
1220
+ domains: {
1221
+ memory: new MemoryLibSQL({ url: 'file:./local.db' }),
1222
+ workflows: new WorkflowsPG({ connectionString: process.env.DATABASE_URL }),
1223
+ scores: new ScoresPG({ connectionString: process.env.DATABASE_URL }),
1224
+ },
1225
+ });
1226
+ ```
1227
+
1228
+ **Breaking changes:**
1229
+ - `storage.supports` property no longer exists
1230
+ - `StorageSupports` type is no longer exported from `@mastra/core/storage`
1231
+
1232
+ All stores now support the same features. For domain availability, use `getStore()`:
1233
+
1234
+ ```typescript
1235
+ const store = await storage.getStore('memory');
1236
+ if (store) {
1237
+ // domain is available
1238
+ }
1239
+ ```
1240
+
1241
+ - 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)]:
1242
+ - @mastra/core@1.0.0-beta.16
1243
+
3
1244
  ## 1.0.0-beta.9
4
1245
 
5
1246
  ### Minor Changes