@mastra/pg 1.0.0-beta.0 → 1.0.0-beta.10

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 (35) hide show
  1. package/CHANGELOG.md +495 -0
  2. package/README.md +3 -0
  3. package/dist/index.cjs +2976 -2039
  4. package/dist/index.cjs.map +1 -1
  5. package/dist/index.js +2960 -2028
  6. package/dist/index.js.map +1 -1
  7. package/dist/shared/config.d.ts +98 -3
  8. package/dist/shared/config.d.ts.map +1 -1
  9. package/dist/storage/{domains/operations → db}/index.d.ts +77 -45
  10. package/dist/storage/db/index.d.ts.map +1 -0
  11. package/dist/storage/domains/agents/index.d.ts +39 -0
  12. package/dist/storage/domains/agents/index.d.ts.map +1 -0
  13. package/dist/storage/domains/memory/index.d.ts +30 -11
  14. package/dist/storage/domains/memory/index.d.ts.map +1 -1
  15. package/dist/storage/domains/observability/index.d.ts +29 -36
  16. package/dist/storage/domains/observability/index.d.ts.map +1 -1
  17. package/dist/storage/domains/scores/index.d.ts +26 -29
  18. package/dist/storage/domains/scores/index.d.ts.map +1 -1
  19. package/dist/storage/domains/utils.d.ts +1 -5
  20. package/dist/storage/domains/utils.d.ts.map +1 -1
  21. package/dist/storage/domains/workflows/index.d.ts +31 -20
  22. package/dist/storage/domains/workflows/index.d.ts.map +1 -1
  23. package/dist/storage/index.d.ts +30 -195
  24. package/dist/storage/index.d.ts.map +1 -1
  25. package/dist/storage/performance-indexes/performance-test.d.ts +3 -1
  26. package/dist/storage/performance-indexes/performance-test.d.ts.map +1 -1
  27. package/dist/storage/test-utils.d.ts.map +1 -1
  28. package/dist/vector/index.d.ts +42 -6
  29. package/dist/vector/index.d.ts.map +1 -1
  30. package/dist/vector/sql-builder.d.ts +4 -0
  31. package/dist/vector/sql-builder.d.ts.map +1 -1
  32. package/dist/vector/types.d.ts +10 -0
  33. package/dist/vector/types.d.ts.map +1 -1
  34. package/package.json +8 -7
  35. package/dist/storage/domains/operations/index.d.ts.map +0 -1
package/CHANGELOG.md CHANGED
@@ -1,5 +1,500 @@
1
1
  # @mastra/pg
2
2
 
3
+ ## 1.0.0-beta.10
4
+
5
+ ### Patch Changes
6
+
7
+ - Fix missing timezone columns during PostgreSQL spans table migration ([#11419](https://github.com/mastra-ai/mastra/pull/11419))
8
+
9
+ Fixes issue #11410 where users upgrading to observability beta.7 encountered errors about missing `startedAtZ`, `endedAtZ`, `createdAtZ`, and `updatedAtZ` columns. The migration now properly adds timezone-aware columns for all timestamp fields when upgrading existing databases, ensuring compatibility with the new observability implementation that requires these columns for batch operations.
10
+
11
+ - Add storage composition to MastraStorage ([#11401](https://github.com/mastra-ai/mastra/pull/11401))
12
+
13
+ `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.
14
+
15
+ ```typescript
16
+ import { MastraStorage } from '@mastra/core/storage';
17
+ import { MemoryPG, WorkflowsPG, ScoresPG } from '@mastra/pg';
18
+ import { MemoryLibSQL } from '@mastra/libsql';
19
+
20
+ // Compose domains from different stores
21
+ const storage = new MastraStorage({
22
+ id: 'composite',
23
+ domains: {
24
+ memory: new MemoryLibSQL({ url: 'file:./local.db' }),
25
+ workflows: new WorkflowsPG({ connectionString: process.env.DATABASE_URL }),
26
+ scores: new ScoresPG({ connectionString: process.env.DATABASE_URL }),
27
+ },
28
+ });
29
+ ```
30
+
31
+ **Breaking changes:**
32
+ - `storage.supports` property no longer exists
33
+ - `StorageSupports` type is no longer exported from `@mastra/core/storage`
34
+
35
+ All stores now support the same features. For domain availability, use `getStore()`:
36
+
37
+ ```typescript
38
+ const store = await storage.getStore('memory');
39
+ if (store) {
40
+ // domain is available
41
+ }
42
+ ```
43
+
44
+ - 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)]:
45
+ - @mastra/core@1.0.0-beta.16
46
+
47
+ ## 1.0.0-beta.9
48
+
49
+ ### Minor Changes
50
+
51
+ - Introduce StorageDomain base class for composite storage support ([#11249](https://github.com/mastra-ai/mastra/pull/11249))
52
+
53
+ 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.
54
+
55
+ **Key changes:**
56
+ - Add `StorageDomain` abstract base class that all domain storage classes extend
57
+ - Add `InMemoryDB` class for shared state across in-memory domain implementations
58
+ - All storage domains now implement `dangerouslyClearAll()` for test cleanup
59
+ - Remove `operations` from public `StorageDomains` type (now internal to each adapter)
60
+ - Add flexible client/config patterns - domains accept either an existing database client or config to create one internally
61
+
62
+ **Why this matters:**
63
+
64
+ This enables composite storage where you can use different database adapters per domain:
65
+
66
+ ```typescript
67
+ import { Mastra } from '@mastra/core';
68
+ import { PostgresStore } from '@mastra/pg';
69
+ import { ClickhouseStore } from '@mastra/clickhouse';
70
+
71
+ // Use Postgres for most domains but Clickhouse for observability
72
+ const mastra = new Mastra({
73
+ storage: new PostgresStore({
74
+ connectionString: 'postgres://...',
75
+ }),
76
+ // Future: override specific domains
77
+ // observability: new ClickhouseStore({ ... }).getStore('observability'),
78
+ });
79
+ ```
80
+
81
+ **Standalone domain usage:**
82
+
83
+ Domains can now be used independently with flexible configuration:
84
+
85
+ ```typescript
86
+ import { MemoryLibSQL } from '@mastra/libsql/memory';
87
+
88
+ // Option 1: Pass config to create client internally
89
+ const memory = new MemoryLibSQL({
90
+ url: 'file:./local.db',
91
+ });
92
+
93
+ // Option 2: Pass existing client for shared connections
94
+ import { createClient } from '@libsql/client';
95
+ const client = createClient({ url: 'file:./local.db' });
96
+ const memory = new MemoryLibSQL({ client });
97
+ ```
98
+
99
+ **Breaking changes:**
100
+ - `StorageDomains` type no longer includes `operations` - access via `getStore()` instead
101
+ - Domain base classes now require implementing `dangerouslyClearAll()` method
102
+
103
+ - Refactor storage architecture to use domain-specific stores via `getStore()` pattern ([#11361](https://github.com/mastra-ai/mastra/pull/11361))
104
+
105
+ ### Summary
106
+
107
+ 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.
108
+
109
+ ### Migration Guide
110
+
111
+ All direct method calls on storage instances should be updated to use `getStore()`:
112
+
113
+ ```typescript
114
+ // Before
115
+ const thread = await storage.getThreadById({ threadId });
116
+ await storage.persistWorkflowSnapshot({ workflowName, runId, snapshot });
117
+ await storage.createSpan(span);
118
+
119
+ // After
120
+ const memory = await storage.getStore('memory');
121
+ const thread = await memory?.getThreadById({ threadId });
122
+
123
+ const workflows = await storage.getStore('workflows');
124
+ await workflows?.persistWorkflowSnapshot({ workflowName, runId, snapshot });
125
+
126
+ const observability = await storage.getStore('observability');
127
+ await observability?.createSpan(span);
128
+ ```
129
+
130
+ ### Available Domains
131
+ - **`memory`**: Thread and message operations (`getThreadById`, `saveThread`, `saveMessages`, etc.)
132
+ - **`workflows`**: Workflow state persistence (`persistWorkflowSnapshot`, `loadWorkflowSnapshot`, `getWorkflowRunById`, etc.)
133
+ - **`scores`**: Evaluation scores (`saveScore`, `listScoresByScorerId`, etc.)
134
+ - **`observability`**: Tracing and spans (`createSpan`, `updateSpan`, `getTrace`, etc.)
135
+ - **`agents`**: Stored agent configurations (`createAgent`, `getAgentById`, `listAgents`, etc.)
136
+
137
+ ### Breaking Changes
138
+ - Passthrough methods have been removed from `MastraStorage` base class
139
+ - All storage adapters now require accessing domains via `getStore()`
140
+ - The `stores` property on storage instances is now the canonical way to access domain storage
141
+
142
+ ### Internal Changes
143
+ - Each storage adapter now initializes domain-specific stores in its constructor
144
+ - Domain stores share database connections and handle their own table initialization
145
+
146
+ - Unified observability schema with entity-based span identification ([#11132](https://github.com/mastra-ai/mastra/pull/11132))
147
+
148
+ ## What changed
149
+
150
+ Spans now use a unified identification model with `entityId`, `entityType`, and `entityName` instead of separate `agentId`, `toolId`, `workflowId` fields.
151
+
152
+ **Before:**
153
+
154
+ ```typescript
155
+ // Old span structure
156
+ span.agentId; // 'my-agent'
157
+ span.toolId; // undefined
158
+ span.workflowId; // undefined
159
+ ```
160
+
161
+ **After:**
162
+
163
+ ```typescript
164
+ // New span structure
165
+ span.entityType; // EntityType.AGENT
166
+ span.entityId; // 'my-agent'
167
+ span.entityName; // 'My Agent'
168
+ ```
169
+
170
+ ## New `listTraces()` API
171
+
172
+ Query traces with filtering, pagination, and sorting:
173
+
174
+ ```typescript
175
+ const { spans, pagination } = await storage.listTraces({
176
+ filters: {
177
+ entityType: EntityType.AGENT,
178
+ entityId: 'my-agent',
179
+ userId: 'user-123',
180
+ environment: 'production',
181
+ status: TraceStatus.SUCCESS,
182
+ startedAt: { start: new Date('2024-01-01'), end: new Date('2024-01-31') },
183
+ },
184
+ pagination: { page: 0, perPage: 50 },
185
+ orderBy: { field: 'startedAt', direction: 'DESC' },
186
+ });
187
+ ```
188
+
189
+ **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`.
190
+
191
+ ## New retrieval methods
192
+ - `getSpan({ traceId, spanId })` - Get a single span
193
+ - `getRootSpan({ traceId })` - Get the root span of a trace
194
+ - `getTrace({ traceId })` - Get all spans for a trace
195
+
196
+ ## Backward compatibility
197
+
198
+ The legacy `getTraces()` method continues to work. When you pass `name: "agent run: my-agent"`, it automatically transforms to `entityId: "my-agent", entityType: AGENT`.
199
+
200
+ ## Migration
201
+
202
+ **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`.
203
+
204
+ **No action required:** Your existing code continues to work. Adopt the new fields and `listTraces()` API at your convenience.
205
+
206
+ ### Patch Changes
207
+
208
+ - Fix severe performance issue with semantic recall on large message tables ([#11365](https://github.com/mastra-ai/mastra/pull/11365))
209
+
210
+ The `_getIncludedMessages` method was using `ROW_NUMBER() OVER (ORDER BY createdAt)` which scanned all messages in a thread to assign row numbers. On tables with 1M+ rows, this caused 5-10 minute query times.
211
+
212
+ Replaced with cursor-based pagination using the existing `(thread_id, createdAt)` index:
213
+
214
+ ```sql
215
+ -- Before: scans entire thread
216
+ ROW_NUMBER() OVER (ORDER BY "createdAt" ASC)
217
+
218
+ -- After: uses index, fetches only needed rows
219
+ WHERE createdAt <= (target) ORDER BY createdAt DESC LIMIT N
220
+ ```
221
+
222
+ Performance improvement: ~49x faster (832ms → 17ms) for typical semantic recall queries.
223
+
224
+ - Added pre-configured client support for all storage adapters. ([#11302](https://github.com/mastra-ai/mastra/pull/11302))
225
+
226
+ **What changed**
227
+
228
+ 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.
229
+
230
+ **Example**
231
+
232
+ ```typescript
233
+ import { createClient } from '@clickhouse/client';
234
+ import { ClickhouseStore } from '@mastra/clickhouse';
235
+
236
+ // Create and configure client with custom settings
237
+ const client = createClient({
238
+ url: 'http://localhost:8123',
239
+ username: 'default',
240
+ password: '',
241
+ request_timeout: 60000,
242
+ });
243
+
244
+ // Pass pre-configured client to store
245
+ const store = new ClickhouseStore({
246
+ id: 'my-store',
247
+ client,
248
+ });
249
+ ```
250
+
251
+ **Additional improvements**
252
+ - Added input validation for required connection parameters (URL, credentials) with clear error messages
253
+
254
+ - Add index configuration options to storage stores ([#11311](https://github.com/mastra-ai/mastra/pull/11311))
255
+
256
+ Storage stores now support two new configuration options for index management:
257
+ - `skipDefaultIndexes`: When `true`, default performance indexes are not created during `init()`. Useful for custom index strategies or reducing initialization time.
258
+ - `indexes`: Array of custom index definitions to create during `init()`. Indexes are routed to the appropriate domain based on table/collection name.
259
+
260
+ ```typescript
261
+ // Skip default indexes and use custom ones
262
+ const store = new PostgresStore({
263
+ connectionString: '...',
264
+ skipDefaultIndexes: true,
265
+ indexes: [{ name: 'threads_type_idx', table: 'mastra_threads', columns: ["metadata->>'type'"] }],
266
+ });
267
+
268
+ // MongoDB equivalent
269
+ const mongoStore = new MongoDBStore({
270
+ url: 'mongodb://...',
271
+ skipDefaultIndexes: true,
272
+ indexes: [{ collection: 'mastra_threads', keys: { 'metadata.type': 1 }, options: { name: 'threads_type_idx' } }],
273
+ });
274
+ ```
275
+
276
+ Domain classes (e.g., `MemoryPG`, `MemoryStorageMongoDB`) also accept these options for standalone usage.
277
+
278
+ - Updated dependencies [[`33a4d2e`](https://github.com/mastra-ai/mastra/commit/33a4d2e4ed8af51f69256232f00c34d6b6b51d48), [`4aaa844`](https://github.com/mastra-ai/mastra/commit/4aaa844a4f19d054490f43638a990cc57bda8d2f), [`4a1a6cb`](https://github.com/mastra-ai/mastra/commit/4a1a6cb3facad54b2bb6780b00ce91d6de1edc08), [`31d13d5`](https://github.com/mastra-ai/mastra/commit/31d13d5fdc2e2380e2e3ee3ec9fb29d2a00f265d), [`4c62166`](https://github.com/mastra-ai/mastra/commit/4c621669f4a29b1f443eca3ba70b814afa286266), [`7bcbf10`](https://github.com/mastra-ai/mastra/commit/7bcbf10133516e03df964b941f9a34e9e4ab4177), [`4353600`](https://github.com/mastra-ai/mastra/commit/43536005a65988a8eede236f69122e7f5a284ba2), [`6986fb0`](https://github.com/mastra-ai/mastra/commit/6986fb064f5db6ecc24aa655e1d26529087b43b3), [`053e979`](https://github.com/mastra-ai/mastra/commit/053e9793b28e970086b0507f7f3b76ea32c1e838), [`e26dc9c`](https://github.com/mastra-ai/mastra/commit/e26dc9c3ccfec54ae3dc3e2b2589f741f9ae60a6), [`55edf73`](https://github.com/mastra-ai/mastra/commit/55edf7302149d6c964fbb7908b43babfc2b52145), [`27c0009`](https://github.com/mastra-ai/mastra/commit/27c0009777a6073d7631b0eb7b481d94e165b5ca), [`dee388d`](https://github.com/mastra-ai/mastra/commit/dee388dde02f2e63c53385ae69252a47ab6825cc), [`3f3fc30`](https://github.com/mastra-ai/mastra/commit/3f3fc3096f24c4a26cffeecfe73085928f72aa63), [`d90ea65`](https://github.com/mastra-ai/mastra/commit/d90ea6536f7aa51c6545a4e9215b55858e98e16d), [`d171e55`](https://github.com/mastra-ai/mastra/commit/d171e559ead9f52ec728d424844c8f7b164c4510), [`10c2735`](https://github.com/mastra-ai/mastra/commit/10c27355edfdad1ee2b826b897df74125eb81fb8), [`1924cf0`](https://github.com/mastra-ai/mastra/commit/1924cf06816e5e4d4d5333065ec0f4bb02a97799), [`b339816`](https://github.com/mastra-ai/mastra/commit/b339816df0984d0243d944ac2655d6ba5f809cde)]:
279
+ - @mastra/core@1.0.0-beta.15
280
+
281
+ ## 1.0.0-beta.8
282
+
283
+ ### Patch Changes
284
+
285
+ - Preserve error details when thrown from workflow steps ([#10992](https://github.com/mastra-ai/mastra/pull/10992))
286
+
287
+ Workflow errors now retain custom properties like `statusCode`, `responseHeaders`, and `cause` chains. This enables error-specific recovery logic in your applications.
288
+
289
+ **Before:**
290
+
291
+ ```typescript
292
+ const result = await workflow.execute({ input });
293
+ if (result.status === 'failed') {
294
+ // Custom error properties were lost
295
+ console.log(result.error); // "Step execution failed" (just a string)
296
+ }
297
+ ```
298
+
299
+ **After:**
300
+
301
+ ```typescript
302
+ const result = await workflow.execute({ input });
303
+ if (result.status === 'failed') {
304
+ // Custom properties are preserved
305
+ console.log(result.error.message); // "Step execution failed"
306
+ console.log(result.error.statusCode); // 429
307
+ console.log(result.error.cause?.name); // "RateLimitError"
308
+ }
309
+ ```
310
+
311
+ **Type change:** `WorkflowState.error` and `WorkflowRunState.error` types changed from `string | Error` to `SerializedError`.
312
+
313
+ Other changes:
314
+ - Added `UpdateWorkflowStateOptions` type for workflow state updates
315
+
316
+ - fix: make getSqlType consistent across storage adapters ([#11112](https://github.com/mastra-ai/mastra/pull/11112))
317
+ - PostgreSQL: use `getSqlType()` in `createTable` instead of `toUpperCase()`
318
+ - LibSQL: use `getSqlType()` in `createTable`, return `JSONB` for jsonb type (matches SQLite 3.45+ support)
319
+ - ClickHouse: use `getSqlType()` in `createTable` instead of `COLUMN_TYPES` constant, add missing types (uuid, float, boolean)
320
+ - Remove unused `getSqlType()` and `getDefaultValue()` from `MastraStorage` base class (all stores use `StoreOperations` versions)
321
+
322
+ - Updated dependencies [[`d5ed981`](https://github.com/mastra-ai/mastra/commit/d5ed981c8701c1b8a27a5f35a9a2f7d9244e695f), [`9650cce`](https://github.com/mastra-ai/mastra/commit/9650cce52a1d917ff9114653398e2a0f5c3ba808), [`932d63d`](https://github.com/mastra-ai/mastra/commit/932d63dd51be9c8bf1e00e3671fe65606c6fb9cd), [`b760b73`](https://github.com/mastra-ai/mastra/commit/b760b731aca7c8a3f041f61d57a7f125ae9cb215), [`695a621`](https://github.com/mastra-ai/mastra/commit/695a621528bdabeb87f83c2277cf2bb084c7f2b4), [`2b459f4`](https://github.com/mastra-ai/mastra/commit/2b459f466fd91688eeb2a44801dc23f7f8a887ab), [`486352b`](https://github.com/mastra-ai/mastra/commit/486352b66c746602b68a95839f830de14c7fb8c0), [`09e4bae`](https://github.com/mastra-ai/mastra/commit/09e4bae18dd5357d2ae078a4a95a2af32168ab08), [`24b76d8`](https://github.com/mastra-ai/mastra/commit/24b76d8e17656269c8ed09a0c038adb9cc2ae95a), [`243a823`](https://github.com/mastra-ai/mastra/commit/243a8239c5906f5c94e4f78b54676793f7510ae3), [`486352b`](https://github.com/mastra-ai/mastra/commit/486352b66c746602b68a95839f830de14c7fb8c0), [`c61fac3`](https://github.com/mastra-ai/mastra/commit/c61fac3add96f0dcce0208c07415279e2537eb62), [`6f14f70`](https://github.com/mastra-ai/mastra/commit/6f14f706ccaaf81b69544b6c1b75ab66a41e5317), [`09e4bae`](https://github.com/mastra-ai/mastra/commit/09e4bae18dd5357d2ae078a4a95a2af32168ab08), [`4524734`](https://github.com/mastra-ai/mastra/commit/45247343e384717a7c8404296275c56201d6470f), [`2a53598`](https://github.com/mastra-ai/mastra/commit/2a53598c6d8cfeb904a7fc74e57e526d751c8fa6), [`c7cd3c7`](https://github.com/mastra-ai/mastra/commit/c7cd3c7a187d7aaf79e2ca139de328bf609a14b4), [`847c212`](https://github.com/mastra-ai/mastra/commit/847c212caba7df0d6f2fc756b494ac3c75c3720d), [`6f941c4`](https://github.com/mastra-ai/mastra/commit/6f941c438ca5f578619788acc7608fc2e23bd176)]:
323
+ - @mastra/core@1.0.0-beta.12
324
+
325
+ ## 1.0.0-beta.7
326
+
327
+ ### Patch Changes
328
+
329
+ - Add delete workflow run API ([#10991](https://github.com/mastra-ai/mastra/pull/10991))
330
+
331
+ ```typescript
332
+ await workflow.deleteWorkflowRunById(runId);
333
+ ```
334
+
335
+ - Add halfvec type support for large dimension embeddings ([#11002](https://github.com/mastra-ai/mastra/pull/11002))
336
+
337
+ Adds `vectorType` option to `createIndex()` for choosing between full precision (`vector`) and half precision (`halfvec`) storage. halfvec uses 2 bytes per dimension instead of 4, enabling indexes on embeddings up to 4000 dimensions.
338
+
339
+ ```typescript
340
+ await pgVector.createIndex({
341
+ indexName: 'large-embeddings',
342
+ dimension: 3072, // text-embedding-3-large
343
+ metric: 'cosine',
344
+ vectorType: 'halfvec',
345
+ });
346
+ ```
347
+
348
+ Requires pgvector >= 0.7.0 for halfvec support. Docker compose files updated to use pgvector 0.8.0.
349
+
350
+ - Updated dependencies [[`edb07e4`](https://github.com/mastra-ai/mastra/commit/edb07e49283e0c28bd094a60e03439bf6ecf0221), [`b7e17d3`](https://github.com/mastra-ai/mastra/commit/b7e17d3f5390bb5a71efc112204413656fcdc18d), [`261473a`](https://github.com/mastra-ai/mastra/commit/261473ac637e633064a22076671e2e02b002214d), [`5d7000f`](https://github.com/mastra-ai/mastra/commit/5d7000f757cd65ea9dc5b05e662fd83dfd44e932), [`4f0331a`](https://github.com/mastra-ai/mastra/commit/4f0331a79bf6eb5ee598a5086e55de4b5a0ada03), [`8a000da`](https://github.com/mastra-ai/mastra/commit/8a000da0c09c679a2312f6b3aa05b2ca78ca7393)]:
351
+ - @mastra/core@1.0.0-beta.10
352
+
353
+ ## 1.0.0-beta.6
354
+
355
+ ### Minor Changes
356
+
357
+ - Add stored agents support ([#10953](https://github.com/mastra-ai/mastra/pull/10953))
358
+
359
+ 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.
360
+
361
+ ```typescript
362
+ import { Mastra } from '@mastra/core';
363
+ import { LibSQLStore } from '@mastra/libsql';
364
+
365
+ const mastra = new Mastra({
366
+ storage: new LibSQLStore({ url: ':memory:' }),
367
+ tools: { myTool },
368
+ scorers: { myScorer },
369
+ });
370
+
371
+ // Create agent in storage via API or directly
372
+ await mastra.getStorage().createAgent({
373
+ agent: {
374
+ id: 'my-agent',
375
+ name: 'My Agent',
376
+ instructions: 'You are helpful',
377
+ model: { provider: 'openai', name: 'gpt-4' },
378
+ tools: { myTool: {} },
379
+ scorers: { myScorer: { sampling: { type: 'ratio', rate: 0.5 } } },
380
+ },
381
+ });
382
+
383
+ // Load and use the agent
384
+ const agent = await mastra.getStoredAgentById('my-agent');
385
+ const response = await agent.generate({ messages: 'Hello!' });
386
+
387
+ // List all stored agents with pagination
388
+ const { agents, total, hasMore } = await mastra.listStoredAgents({
389
+ page: 0,
390
+ perPage: 10,
391
+ });
392
+ ```
393
+
394
+ Also adds a memory registry to Mastra so stored agents can reference memory instances by key.
395
+
396
+ ### Patch Changes
397
+
398
+ - Updated dependencies [[`72df8ae`](https://github.com/mastra-ai/mastra/commit/72df8ae595584cdd7747d5c39ffaca45e4507227), [`9198899`](https://github.com/mastra-ai/mastra/commit/91988995c427b185c33714b7f3be955367911324), [`653e65a`](https://github.com/mastra-ai/mastra/commit/653e65ae1f9502c2958a32f47a5a2df11e612a92), [`c6fd6fe`](https://github.com/mastra-ai/mastra/commit/c6fd6fedd09e9cf8004b03a80925f5e94826ad7e), [`0bed332`](https://github.com/mastra-ai/mastra/commit/0bed332843f627202c6520eaf671771313cd20f3)]:
399
+ - @mastra/core@1.0.0-beta.9
400
+
401
+ ## 1.0.0-beta.5
402
+
403
+ ### Patch Changes
404
+
405
+ - Fix saveScore not persisting ID correctly, breaking getScoreById retrieval ([#10915](https://github.com/mastra-ai/mastra/pull/10915))
406
+
407
+ **What Changed**
408
+ - saveScore now correctly returns scores that can be retrieved with getScoreById
409
+ - Validation errors now include contextual information (scorer, entity, trace details) for easier debugging
410
+
411
+ **Impact**
412
+ 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.
413
+
414
+ - PostgresStore was setting `this.stores = {}` in the constructor and only populating it in the async `init()` method. This broke Memory because it checks `storage.stores.memory` synchronously in `getInputProcessors()` before `init()` is called. ([#10943](https://github.com/mastra-ai/mastra/pull/10943))
415
+
416
+ The fix moves domain instance creation to the constructor. This is safe because pg-promise creates database connections lazily when queries are executed.
417
+
418
+ - Updated dependencies [[`0d41fe2`](https://github.com/mastra-ai/mastra/commit/0d41fe245355dfc66d61a0d9c85d9400aac351ff), [`6b3ba91`](https://github.com/mastra-ai/mastra/commit/6b3ba91494cc10394df96782f349a4f7b1e152cc), [`7907fd1`](https://github.com/mastra-ai/mastra/commit/7907fd1c5059813b7b870b81ca71041dc807331b)]:
419
+ - @mastra/core@1.0.0-beta.8
420
+
421
+ ## 1.0.0-beta.4
422
+
423
+ ### Minor Changes
424
+
425
+ - Add `disableInit` option to all storage adapters ([#10851](https://github.com/mastra-ai/mastra/pull/10851))
426
+
427
+ 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.
428
+
429
+ ```typescript
430
+ // CI/CD script - run migrations
431
+ const storage = new PostgresStore({
432
+ connectionString: DATABASE_URL,
433
+ id: 'pg-storage',
434
+ });
435
+ await storage.init();
436
+
437
+ // Runtime - skip auto-init
438
+ const storage = new PostgresStore({
439
+ connectionString: DATABASE_URL,
440
+ id: 'pg-storage',
441
+ disableInit: true,
442
+ });
443
+ ```
444
+
445
+ ### Patch Changes
446
+
447
+ - 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))
448
+
449
+ - Updated dependencies [[`3076c67`](https://github.com/mastra-ai/mastra/commit/3076c6778b18988ae7d5c4c5c466366974b2d63f), [`85d7ee1`](https://github.com/mastra-ai/mastra/commit/85d7ee18ff4e14d625a8a30ec6656bb49804989b), [`c6c1092`](https://github.com/mastra-ai/mastra/commit/c6c1092f8fbf76109303f69e000e96fd1960c4ce), [`81dc110`](https://github.com/mastra-ai/mastra/commit/81dc11008d147cf5bdc8996ead1aa61dbdebb6fc), [`7aedb74`](https://github.com/mastra-ai/mastra/commit/7aedb74883adf66af38e270e4068fd42e7a37036), [`8f02d80`](https://github.com/mastra-ai/mastra/commit/8f02d800777397e4b45d7f1ad041988a8b0c6630), [`d7aad50`](https://github.com/mastra-ai/mastra/commit/d7aad501ce61646b76b4b511e558ac4eea9884d0), [`ce0a73a`](https://github.com/mastra-ai/mastra/commit/ce0a73abeaa75b10ca38f9e40a255a645d50ebfb), [`a02e542`](https://github.com/mastra-ai/mastra/commit/a02e542d23179bad250b044b17ff023caa61739f), [`a372c64`](https://github.com/mastra-ai/mastra/commit/a372c640ad1fd12e8f0613cebdc682fc156b4d95), [`8846867`](https://github.com/mastra-ai/mastra/commit/8846867ffa9a3746767618e314bebac08eb77d87), [`42a42cf`](https://github.com/mastra-ai/mastra/commit/42a42cf3132b9786feecbb8c13c583dce5b0e198), [`ae08bf0`](https://github.com/mastra-ai/mastra/commit/ae08bf0ebc6a4e4da992b711c4a389c32ba84cf4), [`21735a7`](https://github.com/mastra-ai/mastra/commit/21735a7ef306963554a69a89b44f06c3bcd85141), [`1d877b8`](https://github.com/mastra-ai/mastra/commit/1d877b8d7b536a251c1a7a18db7ddcf4f68d6f8b)]:
450
+ - @mastra/core@1.0.0-beta.7
451
+
452
+ ## 1.0.0-beta.3
453
+
454
+ ### Patch Changes
455
+
456
+ - fix(pg): qualify vector type to fix schema lookup ([#10786](https://github.com/mastra-ai/mastra/pull/10786))
457
+
458
+ - feat(storage): support querying messages from multiple threads ([#10663](https://github.com/mastra-ai/mastra/pull/10663))
459
+ - Fixed TypeScript errors where `threadId: string | string[]` was being passed to places expecting `Scalar` type
460
+ - Added proper multi-thread support for `listMessages` across all adapters when `threadId` is an array
461
+ - Updated `_getIncludedMessages` to look up message threadId by ID (since message IDs are globally unique)
462
+ - **upstash**: Added `msg-idx:{messageId}` index for O(1) message lookups (backwards compatible with fallback to scan for old messages, with automatic backfill)
463
+
464
+ - fix: ensure score responses match saved payloads for Mastra Stores. ([#10557](https://github.com/mastra-ai/mastra/pull/10557))
465
+
466
+ - Unify transformScoreRow functions across storage adapters ([#10648](https://github.com/mastra-ai/mastra/pull/10648))
467
+
468
+ 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:
469
+ - `preferredTimestampFields`: Preferred source fields for timestamps (PostgreSQL, Cloudflare D1)
470
+ - `convertTimestamps`: Convert timestamp strings to Date objects (MSSQL, MongoDB, ClickHouse)
471
+ - `nullValuePattern`: Skip values matching pattern (ClickHouse's `'_null_'`)
472
+ - `fieldMappings`: Map source column names to schema fields (LibSQL's `additionalLLMContext`)
473
+
474
+ 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.
475
+
476
+ - Updated dependencies [[`ac0d2f4`](https://github.com/mastra-ai/mastra/commit/ac0d2f4ff8831f72c1c66c2be809706d17f65789), [`1a0d3fc`](https://github.com/mastra-ai/mastra/commit/1a0d3fc811482c9c376cdf79ee615c23bae9b2d6), [`85a628b`](https://github.com/mastra-ai/mastra/commit/85a628b1224a8f64cd82ea7f033774bf22df7a7e), [`c237233`](https://github.com/mastra-ai/mastra/commit/c23723399ccedf7f5744b3f40997b79246bfbe64), [`15f9e21`](https://github.com/mastra-ai/mastra/commit/15f9e216177201ea6e3f6d0bfb063fcc0953444f), [`ff94dea`](https://github.com/mastra-ai/mastra/commit/ff94dea935f4e34545c63bcb6c29804732698809), [`5b2ff46`](https://github.com/mastra-ai/mastra/commit/5b2ff4651df70c146523a7fca773f8eb0a2272f8), [`db41688`](https://github.com/mastra-ai/mastra/commit/db4168806d007417e2e60b4f68656dca4e5f40c9), [`5ca599d`](https://github.com/mastra-ai/mastra/commit/5ca599d0bb59a1595f19f58473fcd67cc71cef58), [`bff1145`](https://github.com/mastra-ai/mastra/commit/bff114556b3cbadad9b2768488708f8ad0e91475), [`5c8ca24`](https://github.com/mastra-ai/mastra/commit/5c8ca247094e0cc2cdbd7137822fb47241f86e77), [`e191844`](https://github.com/mastra-ai/mastra/commit/e1918444ca3f80e82feef1dad506cd4ec6e2875f), [`22553f1`](https://github.com/mastra-ai/mastra/commit/22553f11c63ee5e966a9c034a349822249584691), [`7237163`](https://github.com/mastra-ai/mastra/commit/72371635dbf96a87df4b073cc48fc655afbdce3d), [`2500740`](https://github.com/mastra-ai/mastra/commit/2500740ea23da067d6e50ec71c625ab3ce275e64), [`873ecbb`](https://github.com/mastra-ai/mastra/commit/873ecbb517586aa17d2f1e99283755b3ebb2863f), [`4f9bbe5`](https://github.com/mastra-ai/mastra/commit/4f9bbe5968f42c86f4930b8193de3c3c17e5bd36), [`02e51fe`](https://github.com/mastra-ai/mastra/commit/02e51feddb3d4155cfbcc42624fd0d0970d032c0), [`8f3fa3a`](https://github.com/mastra-ai/mastra/commit/8f3fa3a652bb77da092f913ec51ae46e3a7e27dc), [`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), [`cccf9c8`](https://github.com/mastra-ai/mastra/commit/cccf9c8b2d2dfc1a5e63919395b83d78c89682a0), [`61a5705`](https://github.com/mastra-ai/mastra/commit/61a570551278b6743e64243b3ce7d73de915ca8a), [`db70a48`](https://github.com/mastra-ai/mastra/commit/db70a48aeeeeb8e5f92007e8ede52c364ce15287), [`f0fdc14`](https://github.com/mastra-ai/mastra/commit/f0fdc14ee233d619266b3d2bbdeea7d25cfc6d13), [`db18bc9`](https://github.com/mastra-ai/mastra/commit/db18bc9c3825e2c1a0ad9a183cc9935f6691bfa1), [`9b37b56`](https://github.com/mastra-ai/mastra/commit/9b37b565e1f2a76c24f728945cc740c2b09be9da), [`41a23c3`](https://github.com/mastra-ai/mastra/commit/41a23c32f9877d71810f37e24930515df2ff7a0f), [`5d171ad`](https://github.com/mastra-ai/mastra/commit/5d171ad9ef340387276b77c2bb3e83e83332d729), [`f03ae60`](https://github.com/mastra-ai/mastra/commit/f03ae60500fe350c9d828621006cdafe1975fdd8), [`d1e74a0`](https://github.com/mastra-ai/mastra/commit/d1e74a0a293866dece31022047f5dbab65a304d0), [`39e7869`](https://github.com/mastra-ai/mastra/commit/39e7869bc7d0ee391077ce291474d8a84eedccff), [`5761926`](https://github.com/mastra-ai/mastra/commit/57619260c4a2cdd598763abbacd90de594c6bc76), [`c900fdd`](https://github.com/mastra-ai/mastra/commit/c900fdd504c41348efdffb205cfe80d48c38fa33), [`604a79f`](https://github.com/mastra-ai/mastra/commit/604a79fecf276e26a54a3fe01bb94e65315d2e0e), [`887f0b4`](https://github.com/mastra-ai/mastra/commit/887f0b4746cdbd7cb7d6b17ac9f82aeb58037ea5), [`2562143`](https://github.com/mastra-ai/mastra/commit/256214336b4faa78646c9c1776612393790d8784), [`ef11a61`](https://github.com/mastra-ai/mastra/commit/ef11a61920fa0ed08a5b7ceedd192875af119749)]:
477
+ - @mastra/core@1.0.0-beta.6
478
+
479
+ ## 1.0.0-beta.2
480
+
481
+ ### Patch Changes
482
+
483
+ - Add new deleteVectors, updateVector by filter ([#10408](https://github.com/mastra-ai/mastra/pull/10408))
484
+
485
+ - Updated dependencies [[`21a15de`](https://github.com/mastra-ai/mastra/commit/21a15de369fe82aac26bb642ed7be73505475e8b), [`feb7ee4`](https://github.com/mastra-ai/mastra/commit/feb7ee4d09a75edb46c6669a3beaceec78811747), [`b0e2ea5`](https://github.com/mastra-ai/mastra/commit/b0e2ea5b52c40fae438b9e2f7baee6f0f89c5442), [`c456e01`](https://github.com/mastra-ai/mastra/commit/c456e0149e3c176afcefdbd9bb1d2c5917723725), [`ab035c2`](https://github.com/mastra-ai/mastra/commit/ab035c2ef6d8cc7bb25f06f1a38508bd9e6f126b), [`1a46a56`](https://github.com/mastra-ai/mastra/commit/1a46a566f45a3fcbadc1cf36bf86d351f264bfa3), [`3cf540b`](https://github.com/mastra-ai/mastra/commit/3cf540b9fbfea8f4fc8d3a2319a4e6c0b0cbfd52), [`1c6ce51`](https://github.com/mastra-ai/mastra/commit/1c6ce51f875915ab57fd36873623013699a2a65d), [`898a972`](https://github.com/mastra-ai/mastra/commit/898a9727d286c2510d6b702dfd367e6aaf5c6b0f), [`a97003a`](https://github.com/mastra-ai/mastra/commit/a97003aa1cf2f4022a41912324a1e77263b326b8), [`ccc141e`](https://github.com/mastra-ai/mastra/commit/ccc141ed27da0abc3a3fc28e9e5128152e8e37f4), [`fe3b897`](https://github.com/mastra-ai/mastra/commit/fe3b897c2ccbcd2b10e81b099438c7337feddf89), [`00123ba`](https://github.com/mastra-ai/mastra/commit/00123ba96dc9e5cd0b110420ebdba56d8f237b25), [`29c4309`](https://github.com/mastra-ai/mastra/commit/29c4309f818b24304c041bcb4a8f19b5f13f6b62), [`16785ce`](https://github.com/mastra-ai/mastra/commit/16785ced928f6f22638f4488cf8a125d99211799), [`de8239b`](https://github.com/mastra-ai/mastra/commit/de8239bdcb1d8c0cfa06da21f1569912a66bbc8a), [`b5e6cd7`](https://github.com/mastra-ai/mastra/commit/b5e6cd77fc8c8e64e0494c1d06cee3d84e795d1e), [`3759cb0`](https://github.com/mastra-ai/mastra/commit/3759cb064935b5f74c65ac2f52a1145f7352899d), [`651e772`](https://github.com/mastra-ai/mastra/commit/651e772eb1475fb13e126d3fcc01751297a88214), [`b61b93f`](https://github.com/mastra-ai/mastra/commit/b61b93f9e058b11dd2eec169853175d31dbdd567), [`bae33d9`](https://github.com/mastra-ai/mastra/commit/bae33d91a63fbb64d1e80519e1fc1acaed1e9013), [`c0b731f`](https://github.com/mastra-ai/mastra/commit/c0b731fb27d712dc8582e846df5c0332a6a0c5ba), [`43ca8f2`](https://github.com/mastra-ai/mastra/commit/43ca8f2c7334851cc7b4d3d2f037d8784bfbdd5f), [`2ca67cc`](https://github.com/mastra-ai/mastra/commit/2ca67cc3bb1f6a617353fdcab197d9efebe60d6f), [`9e67002`](https://github.com/mastra-ai/mastra/commit/9e67002b52c9be19936c420a489dbee9c5fd6a78), [`35edc49`](https://github.com/mastra-ai/mastra/commit/35edc49ac0556db609189641d6341e76771b81fc)]:
486
+ - @mastra/core@1.0.0-beta.5
487
+
488
+ ## 1.0.0-beta.1
489
+
490
+ ### Patch Changes
491
+
492
+ - Add restart method to workflow run that allows restarting an active workflow run ([#9750](https://github.com/mastra-ai/mastra/pull/9750))
493
+ Add status filter to `listWorkflowRuns`
494
+ Add automatic restart to restart active workflow runs when server starts
495
+ - Updated dependencies [[`2319326`](https://github.com/mastra-ai/mastra/commit/2319326f8c64e503a09bbcf14be2dd65405445e0), [`d629361`](https://github.com/mastra-ai/mastra/commit/d629361a60f6565b5bfb11976fdaf7308af858e2), [`08c31c1`](https://github.com/mastra-ai/mastra/commit/08c31c188ebccd598acaf55e888b6397d01f7eae), [`fd3d338`](https://github.com/mastra-ai/mastra/commit/fd3d338a2c362174ed5b383f1f011ad9fb0302aa), [`c30400a`](https://github.com/mastra-ai/mastra/commit/c30400a49b994b1b97256fe785eb6c906fc2b232), [`69e0a87`](https://github.com/mastra-ai/mastra/commit/69e0a878896a2da9494945d86e056a5f8f05b851), [`01f8878`](https://github.com/mastra-ai/mastra/commit/01f88783de25e4de048c1c8aace43e26373c6ea5), [`4c77209`](https://github.com/mastra-ai/mastra/commit/4c77209e6c11678808b365d545845918c40045c8), [`d827d08`](https://github.com/mastra-ai/mastra/commit/d827d0808ffe1f3553a84e975806cc989b9735dd), [`23c10a1`](https://github.com/mastra-ai/mastra/commit/23c10a1efdd9a693c405511ab2dc8a1236603162), [`676ccc7`](https://github.com/mastra-ai/mastra/commit/676ccc7fe92468d2d45d39c31a87825c89fd1ea0), [`c10398d`](https://github.com/mastra-ai/mastra/commit/c10398d5b88f1d4af556f4267ff06f1d11e89179), [`00c2387`](https://github.com/mastra-ai/mastra/commit/00c2387f5f04a365316f851e58666ac43f8c4edf), [`ad6250d`](https://github.com/mastra-ai/mastra/commit/ad6250dbdaad927e29f74a27b83f6c468b50a705), [`3a73998`](https://github.com/mastra-ai/mastra/commit/3a73998fa4ebeb7f3dc9301afe78095fc63e7999), [`e16d553`](https://github.com/mastra-ai/mastra/commit/e16d55338403c7553531cc568125c63d53653dff), [`4d59f58`](https://github.com/mastra-ai/mastra/commit/4d59f58de2d90d6e2810a19d4518e38ddddb9038), [`e1bb9c9`](https://github.com/mastra-ai/mastra/commit/e1bb9c94b4eb68b019ae275981be3feb769b5365), [`351a11f`](https://github.com/mastra-ai/mastra/commit/351a11fcaf2ed1008977fa9b9a489fc422e51cd4)]:
496
+ - @mastra/core@1.0.0-beta.3
497
+
3
498
  ## 1.0.0-beta.0
4
499
 
5
500
  ### Major Changes
package/README.md CHANGED
@@ -327,6 +327,9 @@ The system automatically detects configuration changes and only rebuilds indexes
327
327
  - `buildIndex({indexName, metric?, indexConfig?})`: Build or rebuild vector index
328
328
  - `upsert({indexName, vectors, metadata?, ids?})`: Add or update vectors
329
329
  - `query({indexName, queryVector, topK?, filter?, includeVector?, minScore?})`: Search for similar vectors
330
+ - `updateVector({ indexName, id?, filter?, update })`: Update a single vector by ID or metadata filter
331
+ - `deleteVector({ indexName, id })`: Delete a single vector by ID
332
+ - `deleteVectors({ indexName, ids?, filter? })`: Delete multiple vectors by IDs or metadata filter
330
333
  - `listIndexes()`: List all vector-enabled tables
331
334
  - `describeIndex(indexName)`: Get table statistics and index configuration
332
335
  - `deleteIndex(indexName)`: Delete a table