@mastra/inngest 1.0.0-beta.9 → 1.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +1184 -0
- package/dist/__tests__/adapters/_utils.d.ts +18 -0
- package/dist/__tests__/adapters/_utils.d.ts.map +1 -0
- package/dist/execution-engine.d.ts +102 -5
- package/dist/execution-engine.d.ts.map +1 -1
- package/dist/index.cjs +1039 -289
- package/dist/index.cjs.map +1 -1
- package/dist/index.d.ts +70 -25
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +1040 -291
- package/dist/index.js.map +1 -1
- package/dist/run.d.ts +59 -51
- package/dist/run.d.ts.map +1 -1
- package/dist/serve.d.ts +66 -3
- package/dist/serve.d.ts.map +1 -1
- package/dist/types.d.ts +7 -3
- package/dist/types.d.ts.map +1 -1
- package/dist/workflow.d.ts +5 -4
- package/dist/workflow.d.ts.map +1 -1
- package/package.json +22 -10
package/CHANGELOG.md
CHANGED
|
@@ -1,5 +1,1189 @@
|
|
|
1
1
|
# @mastra/inngest
|
|
2
2
|
|
|
3
|
+
## 1.0.0
|
|
4
|
+
|
|
5
|
+
### Major Changes
|
|
6
|
+
|
|
7
|
+
- Moving scorers under the eval domain, api method consistency, prebuilt evals, scorers require ids. ([#9589](https://github.com/mastra-ai/mastra/pull/9589))
|
|
8
|
+
|
|
9
|
+
- Refactor workflow and tool types to remove Zod-specific constraints ([#11814](https://github.com/mastra-ai/mastra/pull/11814))
|
|
10
|
+
|
|
11
|
+
Removed Zod-specific type constraints across all workflow implementations and tool types, replacing them with generic types. This ensures type consistency across default, evented, and inngest workflows while preparing for Zod v4 migration.
|
|
12
|
+
|
|
13
|
+
**Workflow Changes:**
|
|
14
|
+
- Removed `z.ZodObject<any>` and `z.ZodType<any>` constraints from all workflow generic types
|
|
15
|
+
- Updated method signatures to use `TInput` and `TState` directly instead of `z.infer<TInput>` and `z.infer<TState>`
|
|
16
|
+
- Aligned conditional types across all workflow implementations using `TInput extends unknown` pattern
|
|
17
|
+
- Fixed `TSteps` generic to properly use `TEngineType` instead of `any`
|
|
18
|
+
|
|
19
|
+
**Tool Changes:**
|
|
20
|
+
- Removed Zod schema constraints from `ToolExecutionContext` and related interfaces
|
|
21
|
+
- Simplified type parameters from `TSuspendSchema extends ZodLikeSchema` to `TSuspend` and `TResume`
|
|
22
|
+
- Updated tool execution context types to use generic types
|
|
23
|
+
|
|
24
|
+
**Type Utilities:**
|
|
25
|
+
- Refactored type helpers to work with generic schemas instead of Zod-specific types
|
|
26
|
+
- Updated type extraction utilities for better compatibility
|
|
27
|
+
|
|
28
|
+
This change maintains backward compatibility while improving type consistency and preparing for Zod v4 support across all affected packages.
|
|
29
|
+
|
|
30
|
+
- Bump minimum required Node.js version to 22.13.0 ([#9706](https://github.com/mastra-ai/mastra/pull/9706))
|
|
31
|
+
|
|
32
|
+
- Rename RuntimeContext to RequestContext ([#9511](https://github.com/mastra-ai/mastra/pull/9511))
|
|
33
|
+
|
|
34
|
+
- **Breaking Change**: Convert OUTPUT generic from `OutputSchema` constraint to plain generic ([#11741](https://github.com/mastra-ai/mastra/pull/11741))
|
|
35
|
+
|
|
36
|
+
This change removes the direct dependency on Zod typings in the public API by converting all `OUTPUT extends OutputSchema` generic constraints to plain `OUTPUT` generics throughout the codebase. This is preparation for moving to a standard schema approach.
|
|
37
|
+
- All generic type parameters previously constrained to `OutputSchema` (e.g., `<OUTPUT extends OutputSchema = undefined>`) are now plain generics with defaults (e.g., `<OUTPUT = undefined>`)
|
|
38
|
+
- Affects all public APIs including `Agent`, `MastraModelOutput`, `AgentExecutionOptions`, and stream/generate methods
|
|
39
|
+
- `InferSchemaOutput<OUTPUT>` replaced with `OUTPUT` throughout
|
|
40
|
+
- `PartialSchemaOutput<OUTPUT>` replaced with `Partial<OUTPUT>`
|
|
41
|
+
- Schema fields now use `NonNullable<OutputSchema<OUTPUT>>` instead of `OUTPUT` directly
|
|
42
|
+
- Added `FullOutput<OUTPUT>` type representing complete output with all fields
|
|
43
|
+
- Added `AgentExecutionOptionsBase<OUTPUT>` type
|
|
44
|
+
- `getFullOutput()` method now returns `Promise<FullOutput<OUTPUT>>`
|
|
45
|
+
- `Agent` class now generic: `Agent<TAgentId, TTools, TOutput>`
|
|
46
|
+
- `agent.generate()` and `agent.stream()` methods have updated signatures
|
|
47
|
+
- `MastraModelOutput<OUTPUT>` no longer requires `OutputSchema` constraint
|
|
48
|
+
- Network route and streaming APIs updated to use plain OUTPUT generic
|
|
49
|
+
|
|
50
|
+
**Before:**
|
|
51
|
+
|
|
52
|
+
```typescript
|
|
53
|
+
const output = await agent.generate<z.ZodType>([...], {
|
|
54
|
+
structuredOutput: { schema: mySchema }
|
|
55
|
+
});
|
|
56
|
+
|
|
57
|
+
**After:**
|
|
58
|
+
const output = await agent.generate<z.infer<typeof mySchema>>([...], {
|
|
59
|
+
structuredOutput: { schema: mySchema }
|
|
60
|
+
});
|
|
61
|
+
// Or rely on type inference:
|
|
62
|
+
const output = await agent.generate([...], {
|
|
63
|
+
structuredOutput: { schema: mySchema }
|
|
64
|
+
});
|
|
65
|
+
|
|
66
|
+
```
|
|
67
|
+
|
|
68
|
+
- **Breaking Change**: Remove legacy v1 watch events and consolidate on v2 implementation. ([#9252](https://github.com/mastra-ai/mastra/pull/9252))
|
|
69
|
+
|
|
70
|
+
This change simplifies the workflow watching API by removing the legacy v1 event system and promoting v2 as the standard (renamed to just `watch`).
|
|
71
|
+
|
|
72
|
+
**What's Changed**
|
|
73
|
+
- Removed legacy v1 watch event handlers and types
|
|
74
|
+
- Renamed `watch-v2` to `watch` throughout the codebase
|
|
75
|
+
- Removed `.watch()` method from client-js SDK (`Workflow` and `AgentBuilder` classes)
|
|
76
|
+
- Removed `/watch` HTTP endpoints from server and deployer
|
|
77
|
+
- Removed `WorkflowWatchResult` and v1 `WatchEvent` types
|
|
78
|
+
|
|
79
|
+
- ```ts ([#9709](https://github.com/mastra-ai/mastra/pull/9709))
|
|
80
|
+
import { Mastra } from '@mastra/core';
|
|
81
|
+
import { Observability } from '@mastra/observability'; // Explicit import
|
|
82
|
+
|
|
83
|
+
const mastra = new Mastra({
|
|
84
|
+
...other_config,
|
|
85
|
+
observability: new Observability({
|
|
86
|
+
default: { enabled: true },
|
|
87
|
+
}), // Instance
|
|
88
|
+
});
|
|
89
|
+
```
|
|
90
|
+
|
|
91
|
+
Instead of:
|
|
92
|
+
|
|
93
|
+
```ts
|
|
94
|
+
import { Mastra } from '@mastra/core';
|
|
95
|
+
import '@mastra/observability/init'; // Explicit import
|
|
96
|
+
|
|
97
|
+
const mastra = new Mastra({
|
|
98
|
+
...other_config,
|
|
99
|
+
observability: {
|
|
100
|
+
default: { enabled: true },
|
|
101
|
+
},
|
|
102
|
+
});
|
|
103
|
+
```
|
|
104
|
+
|
|
105
|
+
Also renamed a bunch of:
|
|
106
|
+
- `Tracing` things to `Observability` things.
|
|
107
|
+
- `AI-` things to just things.
|
|
108
|
+
|
|
109
|
+
- Changing getAgents -> listAgents, getTools -> listTools, getWorkflows -> listWorkflows ([#9495](https://github.com/mastra-ai/mastra/pull/9495))
|
|
110
|
+
|
|
111
|
+
- Removed old tracing code based on OpenTelemetry ([#9237](https://github.com/mastra-ai/mastra/pull/9237))
|
|
112
|
+
|
|
113
|
+
- Mark as stable ([`83d5942`](https://github.com/mastra-ai/mastra/commit/83d5942669ce7bba4a6ca4fd4da697a10eb5ebdc))
|
|
114
|
+
|
|
115
|
+
- moved ai-tracing code into @mastra/observability ([#9661](https://github.com/mastra-ai/mastra/pull/9661))
|
|
116
|
+
|
|
117
|
+
- Remove legacy evals from Mastra ([#9491](https://github.com/mastra-ai/mastra/pull/9491))
|
|
118
|
+
|
|
119
|
+
### Minor Changes
|
|
120
|
+
|
|
121
|
+
- Update peer dependencies to match core package version bump (1.0.0) ([#9237](https://github.com/mastra-ai/mastra/pull/9237))
|
|
122
|
+
|
|
123
|
+
- Update peer dependencies to match core package version bump (0.22.1) ([#8649](https://github.com/mastra-ai/mastra/pull/8649))
|
|
124
|
+
|
|
125
|
+
- Update peer dependencies to match core package version bump (0.22.3) ([#9153](https://github.com/mastra-ai/mastra/pull/9153))
|
|
126
|
+
|
|
127
|
+
- Unified observability schema with entity-based span identification ([#11132](https://github.com/mastra-ai/mastra/pull/11132))
|
|
128
|
+
|
|
129
|
+
## What changed
|
|
130
|
+
|
|
131
|
+
Spans now use a unified identification model with `entityId`, `entityType`, and `entityName` instead of separate `agentId`, `toolId`, `workflowId` fields.
|
|
132
|
+
|
|
133
|
+
**Before:**
|
|
134
|
+
|
|
135
|
+
```typescript
|
|
136
|
+
// Old span structure
|
|
137
|
+
span.agentId; // 'my-agent'
|
|
138
|
+
span.toolId; // undefined
|
|
139
|
+
span.workflowId; // undefined
|
|
140
|
+
```
|
|
141
|
+
|
|
142
|
+
**After:**
|
|
143
|
+
|
|
144
|
+
```typescript
|
|
145
|
+
// New span structure
|
|
146
|
+
span.entityType; // EntityType.AGENT
|
|
147
|
+
span.entityId; // 'my-agent'
|
|
148
|
+
span.entityName; // 'My Agent'
|
|
149
|
+
```
|
|
150
|
+
|
|
151
|
+
## New `listTraces()` API
|
|
152
|
+
|
|
153
|
+
Query traces with filtering, pagination, and sorting:
|
|
154
|
+
|
|
155
|
+
```typescript
|
|
156
|
+
const { spans, pagination } = await storage.listTraces({
|
|
157
|
+
filters: {
|
|
158
|
+
entityType: EntityType.AGENT,
|
|
159
|
+
entityId: 'my-agent',
|
|
160
|
+
userId: 'user-123',
|
|
161
|
+
environment: 'production',
|
|
162
|
+
status: TraceStatus.SUCCESS,
|
|
163
|
+
startedAt: { start: new Date('2024-01-01'), end: new Date('2024-01-31') },
|
|
164
|
+
},
|
|
165
|
+
pagination: { page: 0, perPage: 50 },
|
|
166
|
+
orderBy: { field: 'startedAt', direction: 'DESC' },
|
|
167
|
+
});
|
|
168
|
+
```
|
|
169
|
+
|
|
170
|
+
**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`.
|
|
171
|
+
|
|
172
|
+
## New retrieval methods
|
|
173
|
+
- `getSpan({ traceId, spanId })` - Get a single span
|
|
174
|
+
- `getRootSpan({ traceId })` - Get the root span of a trace
|
|
175
|
+
- `getTrace({ traceId })` - Get all spans for a trace
|
|
176
|
+
|
|
177
|
+
## Backward compatibility
|
|
178
|
+
|
|
179
|
+
The legacy `getTraces()` method continues to work. When you pass `name: "agent run: my-agent"`, it automatically transforms to `entityId: "my-agent", entityType: AGENT`.
|
|
180
|
+
|
|
181
|
+
## Migration
|
|
182
|
+
|
|
183
|
+
**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`.
|
|
184
|
+
|
|
185
|
+
**No action required:** Your existing code continues to work. Adopt the new fields and `listTraces()` API at your convenience.
|
|
186
|
+
|
|
187
|
+
- Added `createServe` factory function to support multiple web framework adapters for Inngest workflows. ([#11667](https://github.com/mastra-ai/mastra/pull/11667))
|
|
188
|
+
|
|
189
|
+
Previously, the `serve` function only supported Hono. Now you can use any framework adapter provided by the Inngest package (Express, Fastify, Koa, Next.js, and more).
|
|
190
|
+
|
|
191
|
+
**Before (Hono only)**
|
|
192
|
+
|
|
193
|
+
```typescript
|
|
194
|
+
import { serve } from '@mastra/inngest';
|
|
195
|
+
|
|
196
|
+
// Only worked with Hono
|
|
197
|
+
app.all('/api/inngest', c => serve({ mastra, inngest })(c));
|
|
198
|
+
```
|
|
199
|
+
|
|
200
|
+
**After (any framework)**
|
|
201
|
+
|
|
202
|
+
```typescript
|
|
203
|
+
import { createServe } from '@mastra/inngest';
|
|
204
|
+
import { serve as expressAdapter } from 'inngest/express';
|
|
205
|
+
import { serve as fastifyAdapter } from 'inngest/fastify';
|
|
206
|
+
|
|
207
|
+
// Express
|
|
208
|
+
app.use('/api/inngest', createServe(expressAdapter)({ mastra, inngest }));
|
|
209
|
+
|
|
210
|
+
// Fastify
|
|
211
|
+
fastify.route({
|
|
212
|
+
method: ['GET', 'POST', 'PUT'],
|
|
213
|
+
url: '/api/inngest',
|
|
214
|
+
handler: createServe(fastifyAdapter)({ mastra, inngest }),
|
|
215
|
+
});
|
|
216
|
+
```
|
|
217
|
+
|
|
218
|
+
The existing `serve` export remains available for backward compatibility with Hono.
|
|
219
|
+
|
|
220
|
+
Fixes #10053
|
|
221
|
+
|
|
222
|
+
### Patch Changes
|
|
223
|
+
|
|
224
|
+
- dependencies updates: ([#10120](https://github.com/mastra-ai/mastra/pull/10120))
|
|
225
|
+
- Updated dependency [`@inngest/realtime@^0.4.5` ↗︎](https://www.npmjs.com/package/@inngest/realtime/v/0.4.5) (from `^0.4.4`, in `dependencies`)
|
|
226
|
+
|
|
227
|
+
- Add support for `retries` and `scorers` parameters across all `createStep` overloads.
|
|
228
|
+
([#11495](https://github.com/mastra-ai/mastra/pull/11495))
|
|
229
|
+
|
|
230
|
+
The `createStep` function now includes support for the `retries` and `scorers` fields across all step creation patterns, enabling step-level retry configuration and AI evaluation support for regular steps, agent-based steps, and tool-based steps.
|
|
231
|
+
|
|
232
|
+
```typescript
|
|
233
|
+
import { init } from '@mastra/inngest';
|
|
234
|
+
import { z } from 'zod';
|
|
235
|
+
|
|
236
|
+
const { createStep } = init(inngest);
|
|
237
|
+
|
|
238
|
+
// 1. Regular step with retries
|
|
239
|
+
const regularStep = createStep({
|
|
240
|
+
id: 'api-call',
|
|
241
|
+
inputSchema: z.object({ url: z.string() }),
|
|
242
|
+
outputSchema: z.object({ data: z.any() }),
|
|
243
|
+
retries: 3, // ← Will retry up to 3 times on failure
|
|
244
|
+
execute: async ({ inputData }) => {
|
|
245
|
+
const response = await fetch(inputData.url);
|
|
246
|
+
return { data: await response.json() };
|
|
247
|
+
},
|
|
248
|
+
});
|
|
249
|
+
|
|
250
|
+
// 2. Agent step with retries and scorers
|
|
251
|
+
const agentStep = createStep(myAgent, {
|
|
252
|
+
retries: 3,
|
|
253
|
+
scorers: [{ id: 'accuracy-scorer', scorer: myAccuracyScorer }],
|
|
254
|
+
});
|
|
255
|
+
|
|
256
|
+
// 3. Tool step with retries and scorers
|
|
257
|
+
const toolStep = createStep(myTool, {
|
|
258
|
+
retries: 2,
|
|
259
|
+
scorers: [{ id: 'quality-scorer', scorer: myQualityScorer }],
|
|
260
|
+
});
|
|
261
|
+
```
|
|
262
|
+
|
|
263
|
+
This change ensures API consistency across all `createStep` overloads. All step types now support retry and evaluation configurations.
|
|
264
|
+
|
|
265
|
+
This is a non-breaking change - steps without these parameters continue to work exactly as before.
|
|
266
|
+
|
|
267
|
+
Fixes #9351
|
|
268
|
+
|
|
269
|
+
- Remove `streamVNext`, `resumeStreamVNext`, and `observeStreamVNext` methods, call `stream`, `resumeStream` and `observeStream` directly ([#11499](https://github.com/mastra-ai/mastra/pull/11499))
|
|
270
|
+
|
|
271
|
+
```diff
|
|
272
|
+
+ const run = await workflow.createRun({ runId: '123' });
|
|
273
|
+
- const stream = await run.streamVNext({ inputData: { ... } });
|
|
274
|
+
+ const stream = await run.stream({ inputData: { ... } });
|
|
275
|
+
```
|
|
276
|
+
|
|
277
|
+
- Add additional context to workflow `onFinish` and `onError` callbacks ([#11705](https://github.com/mastra-ai/mastra/pull/11705))
|
|
278
|
+
|
|
279
|
+
The `onFinish` and `onError` lifecycle callbacks now receive additional properties:
|
|
280
|
+
- `runId` - The unique identifier for the workflow run
|
|
281
|
+
- `workflowId` - The workflow's identifier
|
|
282
|
+
- `resourceId` - Optional resource identifier (if provided when creating the run)
|
|
283
|
+
- `getInitData()` - Function that returns the initial input data passed to the workflow
|
|
284
|
+
- `mastra` - The Mastra instance (if workflow is registered with Mastra)
|
|
285
|
+
- `requestContext` - Request-scoped context data
|
|
286
|
+
- `logger` - The workflow's logger instance
|
|
287
|
+
- `state` - The workflow's current state object
|
|
288
|
+
|
|
289
|
+
```typescript
|
|
290
|
+
const workflow = createWorkflow({
|
|
291
|
+
id: 'order-processing',
|
|
292
|
+
inputSchema: z.object({ orderId: z.string() }),
|
|
293
|
+
outputSchema: z.object({ status: z.string() }),
|
|
294
|
+
options: {
|
|
295
|
+
onFinish: async ({ runId, workflowId, getInitData, logger, state, mastra }) => {
|
|
296
|
+
const inputData = getInitData();
|
|
297
|
+
logger.info(`Workflow ${workflowId} run ${runId} completed`, {
|
|
298
|
+
orderId: inputData.orderId,
|
|
299
|
+
finalState: state,
|
|
300
|
+
});
|
|
301
|
+
|
|
302
|
+
// Access other Mastra components if needed
|
|
303
|
+
const agent = mastra?.getAgent('notification-agent');
|
|
304
|
+
},
|
|
305
|
+
onError: async ({ runId, workflowId, error, logger, requestContext }) => {
|
|
306
|
+
logger.error(`Workflow ${workflowId} run ${runId} failed: ${error?.message}`);
|
|
307
|
+
// Access request context for additional debugging
|
|
308
|
+
const userId = requestContext.get('userId');
|
|
309
|
+
},
|
|
310
|
+
},
|
|
311
|
+
});
|
|
312
|
+
```
|
|
313
|
+
|
|
314
|
+
- Deprecate `runCount` parameter in favor of `retryCount` for better naming clarity. The name `runCount` was misleading as it doesn't represent the total number of times a step has run, but rather the number of retry attempts made for a step. ([#9153](https://github.com/mastra-ai/mastra/pull/9153))
|
|
315
|
+
|
|
316
|
+
`runCount` is available in `execute()` functions and methods that interact with the step execution. This also applies to condition functions and loop condition functions that use this parameter. If your code uses `runCount`, change the name to `retryCount`.
|
|
317
|
+
|
|
318
|
+
Here's an example migration:
|
|
319
|
+
|
|
320
|
+
```diff
|
|
321
|
+
const myStep = createStep({
|
|
322
|
+
// Rest of step...
|
|
323
|
+
- execute: async ({ runCount, ...params }) => {
|
|
324
|
+
+ execute: async ({ retryCount, ...params }) => {
|
|
325
|
+
// ... rest of your logic
|
|
326
|
+
}
|
|
327
|
+
});
|
|
328
|
+
```
|
|
329
|
+
|
|
330
|
+
- - Fix tool suspension throwing error when `outputSchema` is passed to tool during creation ([#10444](https://github.com/mastra-ai/mastra/pull/10444))
|
|
331
|
+
- Pass `suspendSchema` and `resumeSchema` from tool into step created when creating step from tool
|
|
332
|
+
|
|
333
|
+
- Fix Inngest workflow tests by adding missing imports and updating middleware path. ([#9259](https://github.com/mastra-ai/mastra/pull/9259))
|
|
334
|
+
|
|
335
|
+
- Internal code refactoring ([#10830](https://github.com/mastra-ai/mastra/pull/10830))
|
|
336
|
+
|
|
337
|
+
- Add `onFinish` and `onError` lifecycle callbacks to workflow options ([#11200](https://github.com/mastra-ai/mastra/pull/11200))
|
|
338
|
+
|
|
339
|
+
Workflows now support lifecycle callbacks for server-side handling of workflow completion and errors:
|
|
340
|
+
- `onFinish`: Called when workflow completes with any status (success, failed, suspended, tripwire)
|
|
341
|
+
- `onError`: Called only when workflow fails (failed or tripwire status)
|
|
342
|
+
|
|
343
|
+
```typescript
|
|
344
|
+
const workflow = createWorkflow({
|
|
345
|
+
id: 'my-workflow',
|
|
346
|
+
inputSchema: z.object({ ... }),
|
|
347
|
+
outputSchema: z.object({ ... }),
|
|
348
|
+
options: {
|
|
349
|
+
onFinish: async (result) => {
|
|
350
|
+
// Handle any workflow completion
|
|
351
|
+
await updateJobStatus(result.status);
|
|
352
|
+
},
|
|
353
|
+
onError: async (errorInfo) => {
|
|
354
|
+
// Handle workflow failures
|
|
355
|
+
await logError(errorInfo.error);
|
|
356
|
+
},
|
|
357
|
+
},
|
|
358
|
+
});
|
|
359
|
+
```
|
|
360
|
+
|
|
361
|
+
Both callbacks support sync and async functions. Callback errors are caught and logged, not propagated to the workflow result.
|
|
362
|
+
|
|
363
|
+
- Include `.input` in workflow results for both engines and remove the option to omit them from Inngest workflows. ([#10688](https://github.com/mastra-ai/mastra/pull/10688))
|
|
364
|
+
|
|
365
|
+
- Add support for typed structured output in agent workflow steps ([#11014](https://github.com/mastra-ai/mastra/pull/11014))
|
|
366
|
+
|
|
367
|
+
When wrapping an agent with `createStep()` and providing a `structuredOutput.schema`, the step's `outputSchema` is now correctly inferred from the provided schema instead of defaulting to `{ text: string }`.
|
|
368
|
+
|
|
369
|
+
This enables type-safe chaining of agent steps with structured output to subsequent steps:
|
|
370
|
+
|
|
371
|
+
```typescript
|
|
372
|
+
const articleSchema = z.object({
|
|
373
|
+
title: z.string(),
|
|
374
|
+
summary: z.string(),
|
|
375
|
+
tags: z.array(z.string()),
|
|
376
|
+
});
|
|
377
|
+
|
|
378
|
+
// Agent step with structured output - outputSchema is now articleSchema
|
|
379
|
+
const agentStep = createStep(agent, {
|
|
380
|
+
structuredOutput: { schema: articleSchema },
|
|
381
|
+
});
|
|
382
|
+
|
|
383
|
+
// Next step can receive the structured output directly
|
|
384
|
+
const processStep = createStep({
|
|
385
|
+
id: 'process',
|
|
386
|
+
inputSchema: articleSchema, // Matches agent's outputSchema
|
|
387
|
+
outputSchema: z.object({ tagCount: z.number() }),
|
|
388
|
+
execute: async ({ inputData }) => ({
|
|
389
|
+
tagCount: inputData.tags.length, // Fully typed!
|
|
390
|
+
}),
|
|
391
|
+
});
|
|
392
|
+
|
|
393
|
+
workflow.then(agentStep).then(processStep).commit();
|
|
394
|
+
```
|
|
395
|
+
|
|
396
|
+
When `structuredOutput` is not provided, the agent step continues to use the default `{ text: string }` output schema.
|
|
397
|
+
|
|
398
|
+
- Preserve error details when thrown from workflow steps ([#10992](https://github.com/mastra-ai/mastra/pull/10992))
|
|
399
|
+
- Errors thrown in workflow steps now preserve full error details including `cause` chain and custom properties
|
|
400
|
+
- Added `SerializedError` type with proper cause chain support
|
|
401
|
+
- Added `SerializedStepResult` and `SerializedStepFailure` types for handling errors loaded from storage
|
|
402
|
+
- Enhanced `addErrorToJSON` to recursively serialize error cause chains with max depth protection
|
|
403
|
+
- Added `hydrateSerializedStepErrors` to convert serialized errors back to Error instances
|
|
404
|
+
- Fixed Inngest workflow error handling to extract original error from `NonRetriableError.cause`
|
|
405
|
+
|
|
406
|
+
- Update tool execution signature ([#9587](https://github.com/mastra-ai/mastra/pull/9587))
|
|
407
|
+
|
|
408
|
+
Consolidated the 3 different execution contexts to one
|
|
409
|
+
|
|
410
|
+
```typescript
|
|
411
|
+
// before depending on the context the tool was executed in
|
|
412
|
+
tool.execute({ context: data });
|
|
413
|
+
tool.execute({ context: { inputData: data } });
|
|
414
|
+
tool.execute(data);
|
|
415
|
+
|
|
416
|
+
// now, for all contexts
|
|
417
|
+
tool.execute(data, context);
|
|
418
|
+
```
|
|
419
|
+
|
|
420
|
+
**Before:**
|
|
421
|
+
|
|
422
|
+
```typescript
|
|
423
|
+
inputSchema: z.object({ something: z.string() }),
|
|
424
|
+
execute: async ({ context, tracingContext, runId, ... }) => {
|
|
425
|
+
return doSomething(context.string);
|
|
426
|
+
}
|
|
427
|
+
```
|
|
428
|
+
|
|
429
|
+
**After:**
|
|
430
|
+
|
|
431
|
+
```typescript
|
|
432
|
+
inputSchema: z.object({ something: z.string() }),
|
|
433
|
+
execute: async (inputData, context) => {
|
|
434
|
+
const { agent, mcp, workflow, ...sharedContext } = context
|
|
435
|
+
|
|
436
|
+
// context that only an agent would get like toolCallId, messages, suspend, resume, etc
|
|
437
|
+
if (agent) {
|
|
438
|
+
doSomething(inputData.something, agent)
|
|
439
|
+
// context that only a workflow would get like runId, state, suspend, resume, etc
|
|
440
|
+
} else if (workflow) {
|
|
441
|
+
doSomething(inputData.something, workflow)
|
|
442
|
+
// context that only a workflow would get like "extra", "elicitation"
|
|
443
|
+
} else if (mcp) {
|
|
444
|
+
doSomething(inputData.something, mcp)
|
|
445
|
+
} else {
|
|
446
|
+
// Running a tool in no execution context
|
|
447
|
+
return doSomething(inputData.something);
|
|
448
|
+
}
|
|
449
|
+
}
|
|
450
|
+
```
|
|
451
|
+
|
|
452
|
+
- Refactor internal event system from Emitter to PubSub abstraction for workflow event handling. This change replaces the EventEmitter-based event system with a pluggable PubSub interface, enabling support for distributed workflow execution backends like Inngest. Adds `close()` method to PubSub implementations for proper cleanup. ([#11052](https://github.com/mastra-ai/mastra/pull/11052))
|
|
453
|
+
|
|
454
|
+
- Add `startAsync()` method and fix Inngest duplicate workflow execution bug ([#11093](https://github.com/mastra-ai/mastra/pull/11093))
|
|
455
|
+
|
|
456
|
+
**New Feature: `startAsync()` for fire-and-forget workflow execution**
|
|
457
|
+
- Add `Run.startAsync()` to base workflow class - starts workflow in background and returns `{ runId }` immediately
|
|
458
|
+
- Add `EventedRun.startAsync()` - publishes workflow start event without subscribing for completion
|
|
459
|
+
- Add `InngestRun.startAsync()` - sends Inngest event without polling for result
|
|
460
|
+
|
|
461
|
+
**Prevent duplicate Inngest workflow executions**
|
|
462
|
+
- Fix `getRuns()` to properly handle rate limits (429), empty responses, and JSON parse errors with retry logic and exponential backoff
|
|
463
|
+
- Fix `getRunOutput()` to throw `NonRetriableError` when polling fails, preventing Inngest from retrying the parent function and re-triggering the workflow
|
|
464
|
+
- Add timeout to `getRunOutput()` polling (default 5 minutes) with `NonRetriableError` on timeout
|
|
465
|
+
|
|
466
|
+
This fixes a production issue where polling failures after successful workflow completion caused Inngest to retry the parent function, which fired a new workflow event and resulted in duplicate executions (e.g., duplicate Slack messages).
|
|
467
|
+
|
|
468
|
+
- Preserve error details when thrown from workflow steps ([#10992](https://github.com/mastra-ai/mastra/pull/10992))
|
|
469
|
+
|
|
470
|
+
Workflow errors now retain custom properties like `statusCode`, `responseHeaders`, and `cause` chains. This enables error-specific recovery logic in your applications.
|
|
471
|
+
|
|
472
|
+
**Before:**
|
|
473
|
+
|
|
474
|
+
```typescript
|
|
475
|
+
const result = await workflow.execute({ input });
|
|
476
|
+
if (result.status === 'failed') {
|
|
477
|
+
// Custom error properties were lost
|
|
478
|
+
console.log(result.error); // "Step execution failed" (just a string)
|
|
479
|
+
}
|
|
480
|
+
```
|
|
481
|
+
|
|
482
|
+
**After:**
|
|
483
|
+
|
|
484
|
+
```typescript
|
|
485
|
+
const result = await workflow.execute({ input });
|
|
486
|
+
if (result.status === 'failed') {
|
|
487
|
+
// Custom properties are preserved
|
|
488
|
+
console.log(result.error.message); // "Step execution failed"
|
|
489
|
+
console.log(result.error.statusCode); // 429
|
|
490
|
+
console.log(result.error.cause?.name); // "RateLimitError"
|
|
491
|
+
}
|
|
492
|
+
```
|
|
493
|
+
|
|
494
|
+
**Type change:** `WorkflowState.error` and `WorkflowRunState.error` types changed from `string | Error` to `SerializedError`.
|
|
495
|
+
|
|
496
|
+
Other changes:
|
|
497
|
+
- Added `UpdateWorkflowStateOptions` type for workflow state updates
|
|
498
|
+
|
|
499
|
+
- Improved TypeScript type inference for workflow steps. ([#11953](https://github.com/mastra-ai/mastra/pull/11953))
|
|
500
|
+
|
|
501
|
+
**What changed:**
|
|
502
|
+
- Step input/output type mismatches are now caught at compile time when chaining steps with `.then()`
|
|
503
|
+
- The `execute` function now properly infers types from `inputSchema`, `outputSchema`, `stateSchema`, and other schema parameters
|
|
504
|
+
- Clearer error messages when step types don't match workflow requirements
|
|
505
|
+
|
|
506
|
+
**Why:**
|
|
507
|
+
Previously, type errors in workflow step chains would only surface at runtime. Now TypeScript validates that each step's input requirements are satisfied by the previous step's output, helping you catch integration issues earlier in development.
|
|
508
|
+
|
|
509
|
+
- fix resumeStream type to use resumeSchema ([#10202](https://github.com/mastra-ai/mastra/pull/10202))
|
|
510
|
+
|
|
511
|
+
- feat: Add field filtering and nested workflow control to workflow execution result endpoint ([#11246](https://github.com/mastra-ai/mastra/pull/11246))
|
|
512
|
+
|
|
513
|
+
Adds two optional query parameters to `/api/workflows/:workflowId/runs/:runId/execution-result` endpoint:
|
|
514
|
+
- `fields`: Request only specific fields (e.g., `status`, `result`, `error`)
|
|
515
|
+
- `withNestedWorkflows`: Control whether to fetch nested workflow data
|
|
516
|
+
|
|
517
|
+
This significantly reduces response payload size and improves response times for large workflows.
|
|
518
|
+
|
|
519
|
+
## Server Endpoint Usage
|
|
520
|
+
|
|
521
|
+
```http
|
|
522
|
+
# Get only status (minimal payload - fastest)
|
|
523
|
+
GET /api/workflows/:workflowId/runs/:runId/execution-result?fields=status
|
|
524
|
+
|
|
525
|
+
# Get status and result
|
|
526
|
+
GET /api/workflows/:workflowId/runs/:runId/execution-result?fields=status,result
|
|
527
|
+
|
|
528
|
+
# Get all fields but without nested workflow data (faster)
|
|
529
|
+
GET /api/workflows/:workflowId/runs/:runId/execution-result?withNestedWorkflows=false
|
|
530
|
+
|
|
531
|
+
# Get only specific fields without nested workflow data
|
|
532
|
+
GET /api/workflows/:workflowId/runs/:runId/execution-result?fields=status,steps&withNestedWorkflows=false
|
|
533
|
+
|
|
534
|
+
# Get full data (default behavior)
|
|
535
|
+
GET /api/workflows/:workflowId/runs/:runId/execution-result
|
|
536
|
+
```
|
|
537
|
+
|
|
538
|
+
## Client SDK Usage
|
|
539
|
+
|
|
540
|
+
```typescript
|
|
541
|
+
import { MastraClient } from '@mastra/client-js';
|
|
542
|
+
|
|
543
|
+
const client = new MastraClient({ baseUrl: 'http://localhost:4111' });
|
|
544
|
+
const workflow = client.getWorkflow('myWorkflow');
|
|
545
|
+
|
|
546
|
+
// Get only status (minimal payload - fastest)
|
|
547
|
+
const statusOnly = await workflow.runExecutionResult(runId, {
|
|
548
|
+
fields: ['status'],
|
|
549
|
+
});
|
|
550
|
+
console.log(statusOnly.status); // 'success' | 'failed' | 'running' | etc.
|
|
551
|
+
|
|
552
|
+
// Get status and result
|
|
553
|
+
const statusAndResult = await workflow.runExecutionResult(runId, {
|
|
554
|
+
fields: ['status', 'result'],
|
|
555
|
+
});
|
|
556
|
+
|
|
557
|
+
// Get all fields but without nested workflow data (faster)
|
|
558
|
+
const resultWithoutNested = await workflow.runExecutionResult(runId, {
|
|
559
|
+
withNestedWorkflows: false,
|
|
560
|
+
});
|
|
561
|
+
|
|
562
|
+
// Get specific fields without nested workflow data
|
|
563
|
+
const optimized = await workflow.runExecutionResult(runId, {
|
|
564
|
+
fields: ['status', 'steps'],
|
|
565
|
+
withNestedWorkflows: false,
|
|
566
|
+
});
|
|
567
|
+
|
|
568
|
+
// Get full execution result (default behavior)
|
|
569
|
+
const fullResult = await workflow.runExecutionResult(runId);
|
|
570
|
+
```
|
|
571
|
+
|
|
572
|
+
## Core API Changes
|
|
573
|
+
|
|
574
|
+
The `Workflow.getWorkflowRunExecutionResult` method now accepts an options object:
|
|
575
|
+
|
|
576
|
+
```typescript
|
|
577
|
+
await workflow.getWorkflowRunExecutionResult(runId, {
|
|
578
|
+
withNestedWorkflows: false, // default: true, set to false to skip nested workflow data
|
|
579
|
+
fields: ['status', 'result'], // optional field filtering
|
|
580
|
+
});
|
|
581
|
+
```
|
|
582
|
+
|
|
583
|
+
## Inngest Compatibility
|
|
584
|
+
|
|
585
|
+
The `@mastra/inngest` package has been updated to use the new options object API. This is a non-breaking internal change - no action required from inngest workflow users.
|
|
586
|
+
|
|
587
|
+
## Performance Impact
|
|
588
|
+
|
|
589
|
+
For workflows with large step outputs:
|
|
590
|
+
- Requesting only `status`: ~99% reduction in payload size
|
|
591
|
+
- Requesting `status,result,error`: ~95% reduction in payload size
|
|
592
|
+
- Using `withNestedWorkflows=false`: Avoids expensive nested workflow data fetching
|
|
593
|
+
- Combining both: Maximum performance optimization
|
|
594
|
+
|
|
595
|
+
- Refactor storage architecture to use domain-specific stores via `getStore()` pattern ([#11361](https://github.com/mastra-ai/mastra/pull/11361))
|
|
596
|
+
|
|
597
|
+
### Summary
|
|
598
|
+
|
|
599
|
+
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.
|
|
600
|
+
|
|
601
|
+
### Migration Guide
|
|
602
|
+
|
|
603
|
+
All direct method calls on storage instances should be updated to use `getStore()`:
|
|
604
|
+
|
|
605
|
+
```typescript
|
|
606
|
+
// Before
|
|
607
|
+
const thread = await storage.getThreadById({ threadId });
|
|
608
|
+
await storage.persistWorkflowSnapshot({ workflowName, runId, snapshot });
|
|
609
|
+
await storage.createSpan(span);
|
|
610
|
+
|
|
611
|
+
// After
|
|
612
|
+
const memory = await storage.getStore('memory');
|
|
613
|
+
const thread = await memory?.getThreadById({ threadId });
|
|
614
|
+
|
|
615
|
+
const workflows = await storage.getStore('workflows');
|
|
616
|
+
await workflows?.persistWorkflowSnapshot({ workflowName, runId, snapshot });
|
|
617
|
+
|
|
618
|
+
const observability = await storage.getStore('observability');
|
|
619
|
+
await observability?.createSpan(span);
|
|
620
|
+
```
|
|
621
|
+
|
|
622
|
+
### Available Domains
|
|
623
|
+
- **`memory`**: Thread and message operations (`getThreadById`, `saveThread`, `saveMessages`, etc.)
|
|
624
|
+
- **`workflows`**: Workflow state persistence (`persistWorkflowSnapshot`, `loadWorkflowSnapshot`, `getWorkflowRunById`, etc.)
|
|
625
|
+
- **`scores`**: Evaluation scores (`saveScore`, `listScoresByScorerId`, etc.)
|
|
626
|
+
- **`observability`**: Tracing and spans (`createSpan`, `updateSpan`, `getTrace`, etc.)
|
|
627
|
+
- **`agents`**: Stored agent configurations (`createAgent`, `getAgentById`, `listAgents`, etc.)
|
|
628
|
+
|
|
629
|
+
### Breaking Changes
|
|
630
|
+
- Passthrough methods have been removed from `MastraStorage` base class
|
|
631
|
+
- All storage adapters now require accessing domains via `getStore()`
|
|
632
|
+
- The `stores` property on storage instances is now the canonical way to access domain storage
|
|
633
|
+
|
|
634
|
+
### Internal Changes
|
|
635
|
+
- Each storage adapter now initializes domain-specific stores in its constructor
|
|
636
|
+
- Domain stores share database connections and handle their own table initialization
|
|
637
|
+
|
|
638
|
+
- Add tool call approval ([#8649](https://github.com/mastra-ai/mastra/pull/8649))
|
|
639
|
+
|
|
640
|
+
- Add debugger-like click-through UI to workflow graph ([#11350](https://github.com/mastra-ai/mastra/pull/11350))
|
|
641
|
+
|
|
642
|
+
- Using `createStep` with a nested Inngest workflow now returns the workflow itself, maintaining the correct `.invoke()` execution flow Inngest workflows need to operate. ([#10689](https://github.com/mastra-ai/mastra/pull/10689))
|
|
643
|
+
|
|
644
|
+
- Refactored default engine to fit durable execution better, and the inngest engine to match. ([#10627](https://github.com/mastra-ai/mastra/pull/10627))
|
|
645
|
+
Also fixes requestContext persistence by relying on inngest step memoization.
|
|
646
|
+
|
|
647
|
+
Unifies some of the stepResults and error formats in both engines.
|
|
648
|
+
|
|
649
|
+
- Add `perStep` option to workflow run methods, allowing a workflow to run just a step instead of all the workflow steps ([#11276](https://github.com/mastra-ai/mastra/pull/11276))
|
|
650
|
+
|
|
651
|
+
- Miscellanous bug fixes and test fixes: ([#10515](https://github.com/mastra-ai/mastra/pull/10515))
|
|
652
|
+
- cloneWorkflow passing options correctly
|
|
653
|
+
- start event in streamLegacy
|
|
654
|
+
- Many test cases with outdated or incorrect expected values
|
|
655
|
+
|
|
656
|
+
- Added support for .streamVNext and .stream that uses it in the inngest execution engine ([#9434](https://github.com/mastra-ai/mastra/pull/9434))
|
|
657
|
+
|
|
658
|
+
- Add restart method to workflow run that allows restarting an active workflow run ([#9750](https://github.com/mastra-ai/mastra/pull/9750))
|
|
659
|
+
Add status filter to `listWorkflowRuns`
|
|
660
|
+
Add automatic restart to restart active workflow runs when server starts
|
|
661
|
+
|
|
662
|
+
- Prevent changing workflow status to suspended when some parallel steps are still running ([#9431](https://github.com/mastra-ai/mastra/pull/9431))
|
|
663
|
+
|
|
664
|
+
- Fix custom error properties being lost through Inngest serialization ([#11962](https://github.com/mastra-ai/mastra/pull/11962))
|
|
665
|
+
|
|
666
|
+
Inngest's error serialization only captures standard Error properties (message, name, stack, code, cause). Custom properties like `statusCode`, `responseHeaders`, or `isRetryable` from API/AI SDK errors were being stripped during serialization. Errors are now wrapped with a cause structure that preserves custom properties through the serialization boundary.
|
|
667
|
+
|
|
668
|
+
- Validate schemas by default in workflow. Previously, if you want schemas in the workflow to be validated, you'd have to add `validateInputs` option, now, this will be done by default but can be disabled. ([#10186](https://github.com/mastra-ai/mastra/pull/10186))
|
|
669
|
+
|
|
670
|
+
For workflows whose schemas and step schemas you don't want validated, do this
|
|
671
|
+
|
|
672
|
+
```diff
|
|
673
|
+
createWorkflow({
|
|
674
|
+
+ options: {
|
|
675
|
+
+ validateInputs: false
|
|
676
|
+
+ }
|
|
677
|
+
})
|
|
678
|
+
```
|
|
679
|
+
|
|
680
|
+
- Fix inngest parallel workflow ([#10169](https://github.com/mastra-ai/mastra/pull/10169))
|
|
681
|
+
Fix tool as step in inngest
|
|
682
|
+
Fix inngest nested workflow
|
|
683
|
+
|
|
684
|
+
- Remove `waitForEvent` from workflows. `waitForEvent` is now removed, please use suspend & resume flow instead. See https://mastra.ai/en/docs/workflows/suspend-and-resume for more details on suspend & resume flow. ([#9214](https://github.com/mastra-ai/mastra/pull/9214))
|
|
685
|
+
|
|
686
|
+
- Emit workflow-step-result and workflow-step-finish when step fails in inngest workflow ([#10555](https://github.com/mastra-ai/mastra/pull/10555))
|
|
687
|
+
|
|
688
|
+
- Real-time span export for Inngest workflow engine ([#11973](https://github.com/mastra-ai/mastra/pull/11973))
|
|
689
|
+
- Spans are now exported immediately when created and ended, instead of being batched at workflow completion
|
|
690
|
+
- Added durable span lifecycle hooks (`createStepSpan`, `endStepSpan`, `errorStepSpan`, `createChildSpan`, `endChildSpan`, `errorChildSpan`) that wrap span operations in Inngest's `step.run()` for memoization
|
|
691
|
+
- Added `rebuildSpan()` method to reconstruct span objects from exported data after Inngest replay
|
|
692
|
+
- Fixed nested workflow step spans missing output data
|
|
693
|
+
- Spans correctly maintain parent-child relationships across Inngest's durable execution boundaries using `tracingIds`
|
|
694
|
+
|
|
695
|
+
- Support new Workflow tripwire run status. Tripwires that are thrown from within a workflow will now bubble up and return a graceful state with information about tripwires. ([#10947](https://github.com/mastra-ai/mastra/pull/10947))
|
|
696
|
+
|
|
697
|
+
When a workflow contains an agent step that triggers a tripwire, the workflow returns with `status: 'tripwire'` and includes tripwire details:
|
|
698
|
+
|
|
699
|
+
```typescript
|
|
700
|
+
const run = await workflow.createRun();
|
|
701
|
+
const result = await run.start({ inputData: { message: 'Hello' } });
|
|
702
|
+
|
|
703
|
+
if (result.status === 'tripwire') {
|
|
704
|
+
console.log('Workflow terminated by tripwire:', result.tripwire?.reason);
|
|
705
|
+
console.log('Processor ID:', result.tripwire?.processorId);
|
|
706
|
+
console.log('Retry requested:', result.tripwire?.retry);
|
|
707
|
+
}
|
|
708
|
+
```
|
|
709
|
+
|
|
710
|
+
Adds new UI state for tripwire in agent chat and workflow UI.
|
|
711
|
+
|
|
712
|
+
This is distinct from `status: 'failed'` which indicates an unexpected error. A tripwire status means a processor intentionally stopped execution (e.g., for content moderation).
|
|
713
|
+
|
|
714
|
+
- Add timeTravel to workflows. This makes it possible to start a workflow run from a particular step in the workflow ([#9994](https://github.com/mastra-ai/mastra/pull/9994))
|
|
715
|
+
|
|
716
|
+
Example code:
|
|
717
|
+
|
|
718
|
+
```ts
|
|
719
|
+
const result = await run.timeTravel({
|
|
720
|
+
step: 'step2',
|
|
721
|
+
inputData: {
|
|
722
|
+
value: 'input',
|
|
723
|
+
},
|
|
724
|
+
});
|
|
725
|
+
```
|
|
726
|
+
|
|
727
|
+
- Unified `getWorkflowRunById` and `getWorkflowRunExecutionResult` into a single API that returns `WorkflowState` with both metadata and execution state. ([#11429](https://github.com/mastra-ai/mastra/pull/11429))
|
|
728
|
+
|
|
729
|
+
**What changed:**
|
|
730
|
+
- `getWorkflowRunById` now returns a unified `WorkflowState` object containing metadata (runId, workflowName, resourceId, createdAt, updatedAt) along with processed execution state (status, result, error, payload, steps)
|
|
731
|
+
- Added optional `fields` parameter to request only specific fields for better performance
|
|
732
|
+
- Added optional `withNestedWorkflows` parameter to control nested workflow step inclusion
|
|
733
|
+
- Removed `getWorkflowRunExecutionResult` - use `getWorkflowRunById` instead (breaking change)
|
|
734
|
+
- Removed `/execution-result` API endpoints from server (breaking change)
|
|
735
|
+
- Removed `runExecutionResult()` method from client SDK (breaking change)
|
|
736
|
+
- Removed `GetWorkflowRunExecutionResultResponse` type from client SDK (breaking change)
|
|
737
|
+
|
|
738
|
+
**Before:**
|
|
739
|
+
|
|
740
|
+
```typescript
|
|
741
|
+
// Had to call two different methods for different data
|
|
742
|
+
const run = await workflow.getWorkflowRunById(runId); // Returns raw WorkflowRun with snapshot
|
|
743
|
+
const result = await workflow.getWorkflowRunExecutionResult(runId); // Returns processed execution state
|
|
744
|
+
```
|
|
745
|
+
|
|
746
|
+
**After:**
|
|
747
|
+
|
|
748
|
+
```typescript
|
|
749
|
+
// Single method returns everything
|
|
750
|
+
const run = await workflow.getWorkflowRunById(runId);
|
|
751
|
+
// Returns: { runId, workflowName, resourceId, createdAt, updatedAt, status, result, error, payload, steps }
|
|
752
|
+
|
|
753
|
+
// Request only specific fields for better performance (avoids expensive step fetching)
|
|
754
|
+
const status = await workflow.getWorkflowRunById(runId, { fields: ['status'] });
|
|
755
|
+
|
|
756
|
+
// Skip nested workflow steps for faster response
|
|
757
|
+
const run = await workflow.getWorkflowRunById(runId, { withNestedWorkflows: false });
|
|
758
|
+
```
|
|
759
|
+
|
|
760
|
+
**Why:** The previous API required calling two separate methods to get complete workflow run information. This unification simplifies the API surface and gives users control over performance - fetching all steps (especially nested workflows) can be expensive, so the `fields` and `withNestedWorkflows` options let users request only what they need.
|
|
761
|
+
|
|
762
|
+
- Make suspendPayload optional when calling `suspend()` ([#9926](https://github.com/mastra-ai/mastra/pull/9926))
|
|
763
|
+
Save value returned as `suspendOutput` if user returns data still after calling `suspend()`
|
|
764
|
+
Automatically call `commit()` on uncommitted workflows when registering in Mastra instance
|
|
765
|
+
Show actual suspendPayload on Studio in suspend/resume flow
|
|
766
|
+
|
|
767
|
+
- Fix observability tracing for Inngest workflows ([#11885](https://github.com/mastra-ai/mastra/pull/11885))
|
|
768
|
+
- Use SpanCollector to capture span hierarchy during execution and create real spans in the memoized finalize step
|
|
769
|
+
- Fix span timing by using step result `startedAt`/`endedAt` (memoized by Inngest) instead of replay-time timestamps
|
|
770
|
+
- Ensures proper parent-child span relationships and accurate durations in traces
|
|
771
|
+
- Multi-replica safe: no shared state needed across server instances
|
|
772
|
+
|
|
773
|
+
- Add cron scheduling support to Inngest workflows. Workflows can now be automatically triggered on a schedule by adding a `cron` property along with optional `inputData` and `initialState`: ([#11518](https://github.com/mastra-ai/mastra/pull/11518))
|
|
774
|
+
|
|
775
|
+
```typescript
|
|
776
|
+
const workflow = createWorkflow({
|
|
777
|
+
id: 'scheduled-workflow',
|
|
778
|
+
inputSchema: z.object({ value: z.string() }),
|
|
779
|
+
outputSchema: z.object({ result: z.string() }),
|
|
780
|
+
steps: [step1],
|
|
781
|
+
cron: '0 0 * * *', // Run daily at midnight
|
|
782
|
+
inputData: { value: 'scheduled-run' }, // Optional inputData for the scheduled workflow run
|
|
783
|
+
initialState: { count: 0 }, // Optional initialState for the scheduled workflow run
|
|
784
|
+
});
|
|
785
|
+
```
|
|
786
|
+
|
|
787
|
+
- 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)]:
|
|
788
|
+
- @mastra/core@1.0.0
|
|
789
|
+
|
|
790
|
+
## 1.0.0-beta.13
|
|
791
|
+
|
|
792
|
+
### Major Changes
|
|
793
|
+
|
|
794
|
+
- Refactor workflow and tool types to remove Zod-specific constraints ([#11814](https://github.com/mastra-ai/mastra/pull/11814))
|
|
795
|
+
|
|
796
|
+
Removed Zod-specific type constraints across all workflow implementations and tool types, replacing them with generic types. This ensures type consistency across default, evented, and inngest workflows while preparing for Zod v4 migration.
|
|
797
|
+
|
|
798
|
+
**Workflow Changes:**
|
|
799
|
+
- Removed `z.ZodObject<any>` and `z.ZodType<any>` constraints from all workflow generic types
|
|
800
|
+
- Updated method signatures to use `TInput` and `TState` directly instead of `z.infer<TInput>` and `z.infer<TState>`
|
|
801
|
+
- Aligned conditional types across all workflow implementations using `TInput extends unknown` pattern
|
|
802
|
+
- Fixed `TSteps` generic to properly use `TEngineType` instead of `any`
|
|
803
|
+
|
|
804
|
+
**Tool Changes:**
|
|
805
|
+
- Removed Zod schema constraints from `ToolExecutionContext` and related interfaces
|
|
806
|
+
- Simplified type parameters from `TSuspendSchema extends ZodLikeSchema` to `TSuspend` and `TResume`
|
|
807
|
+
- Updated tool execution context types to use generic types
|
|
808
|
+
|
|
809
|
+
**Type Utilities:**
|
|
810
|
+
- Refactored type helpers to work with generic schemas instead of Zod-specific types
|
|
811
|
+
- Updated type extraction utilities for better compatibility
|
|
812
|
+
|
|
813
|
+
This change maintains backward compatibility while improving type consistency and preparing for Zod v4 support across all affected packages.
|
|
814
|
+
|
|
815
|
+
- **Breaking Change**: Convert OUTPUT generic from `OutputSchema` constraint to plain generic ([#11741](https://github.com/mastra-ai/mastra/pull/11741))
|
|
816
|
+
|
|
817
|
+
This change removes the direct dependency on Zod typings in the public API by converting all `OUTPUT extends OutputSchema` generic constraints to plain `OUTPUT` generics throughout the codebase. This is preparation for moving to a standard schema approach.
|
|
818
|
+
- All generic type parameters previously constrained to `OutputSchema` (e.g., `<OUTPUT extends OutputSchema = undefined>`) are now plain generics with defaults (e.g., `<OUTPUT = undefined>`)
|
|
819
|
+
- Affects all public APIs including `Agent`, `MastraModelOutput`, `AgentExecutionOptions`, and stream/generate methods
|
|
820
|
+
- `InferSchemaOutput<OUTPUT>` replaced with `OUTPUT` throughout
|
|
821
|
+
- `PartialSchemaOutput<OUTPUT>` replaced with `Partial<OUTPUT>`
|
|
822
|
+
- Schema fields now use `NonNullable<OutputSchema<OUTPUT>>` instead of `OUTPUT` directly
|
|
823
|
+
- Added `FullOutput<OUTPUT>` type representing complete output with all fields
|
|
824
|
+
- Added `AgentExecutionOptionsBase<OUTPUT>` type
|
|
825
|
+
- `getFullOutput()` method now returns `Promise<FullOutput<OUTPUT>>`
|
|
826
|
+
- `Agent` class now generic: `Agent<TAgentId, TTools, TOutput>`
|
|
827
|
+
- `agent.generate()` and `agent.stream()` methods have updated signatures
|
|
828
|
+
- `MastraModelOutput<OUTPUT>` no longer requires `OutputSchema` constraint
|
|
829
|
+
- Network route and streaming APIs updated to use plain OUTPUT generic
|
|
830
|
+
|
|
831
|
+
**Before:**
|
|
832
|
+
|
|
833
|
+
```typescript
|
|
834
|
+
const output = await agent.generate<z.ZodType>({
|
|
835
|
+
messages: [...],
|
|
836
|
+
structuredOutput: { schema: mySchema }
|
|
837
|
+
});
|
|
838
|
+
|
|
839
|
+
**After:**
|
|
840
|
+
const output = await agent.generate<z.infer<typeof mySchema>>({
|
|
841
|
+
messages: [...],
|
|
842
|
+
structuredOutput: { schema: mySchema }
|
|
843
|
+
});
|
|
844
|
+
// Or rely on type inference:
|
|
845
|
+
const output = await agent.generate({
|
|
846
|
+
messages: [...],
|
|
847
|
+
structuredOutput: { schema: mySchema }
|
|
848
|
+
});
|
|
849
|
+
|
|
850
|
+
```
|
|
851
|
+
|
|
852
|
+
### Patch Changes
|
|
853
|
+
|
|
854
|
+
- Improved TypeScript type inference for workflow steps. ([#11953](https://github.com/mastra-ai/mastra/pull/11953))
|
|
855
|
+
|
|
856
|
+
**What changed:**
|
|
857
|
+
- Step input/output type mismatches are now caught at compile time when chaining steps with `.then()`
|
|
858
|
+
- The `execute` function now properly infers types from `inputSchema`, `outputSchema`, `stateSchema`, and other schema parameters
|
|
859
|
+
- Clearer error messages when step types don't match workflow requirements
|
|
860
|
+
|
|
861
|
+
**Why:**
|
|
862
|
+
Previously, type errors in workflow step chains would only surface at runtime. Now TypeScript validates that each step's input requirements are satisfied by the previous step's output, helping you catch integration issues earlier in development.
|
|
863
|
+
|
|
864
|
+
- Fix custom error properties being lost through Inngest serialization ([#11962](https://github.com/mastra-ai/mastra/pull/11962))
|
|
865
|
+
|
|
866
|
+
Inngest's error serialization only captures standard Error properties (message, name, stack, code, cause). Custom properties like `statusCode`, `responseHeaders`, or `isRetryable` from API/AI SDK errors were being stripped during serialization. Errors are now wrapped with a cause structure that preserves custom properties through the serialization boundary.
|
|
867
|
+
|
|
868
|
+
- Real-time span export for Inngest workflow engine ([#11973](https://github.com/mastra-ai/mastra/pull/11973))
|
|
869
|
+
- Spans are now exported immediately when created and ended, instead of being batched at workflow completion
|
|
870
|
+
- Added durable span lifecycle hooks (`createStepSpan`, `endStepSpan`, `errorStepSpan`, `createChildSpan`, `endChildSpan`, `errorChildSpan`) that wrap span operations in Inngest's `step.run()` for memoization
|
|
871
|
+
- Added `rebuildSpan()` method to reconstruct span objects from exported data after Inngest replay
|
|
872
|
+
- Fixed nested workflow step spans missing output data
|
|
873
|
+
- Spans correctly maintain parent-child relationships across Inngest's durable execution boundaries using `tracingIds`
|
|
874
|
+
|
|
875
|
+
- Fix observability tracing for Inngest workflows ([#11885](https://github.com/mastra-ai/mastra/pull/11885))
|
|
876
|
+
- Use SpanCollector to capture span hierarchy during execution and create real spans in the memoized finalize step
|
|
877
|
+
- Fix span timing by using step result `startedAt`/`endedAt` (memoized by Inngest) instead of replay-time timestamps
|
|
878
|
+
- Ensures proper parent-child span relationships and accurate durations in traces
|
|
879
|
+
- Multi-replica safe: no shared state needed across server instances
|
|
880
|
+
|
|
881
|
+
- 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)]:
|
|
882
|
+
- @mastra/core@1.0.0-beta.22
|
|
883
|
+
|
|
884
|
+
## 1.0.0-beta.12
|
|
885
|
+
|
|
886
|
+
### Minor Changes
|
|
887
|
+
|
|
888
|
+
- Added `createServe` factory function to support multiple web framework adapters for Inngest workflows. ([#11667](https://github.com/mastra-ai/mastra/pull/11667))
|
|
889
|
+
|
|
890
|
+
Previously, the `serve` function only supported Hono. Now you can use any framework adapter provided by the Inngest package (Express, Fastify, Koa, Next.js, and more).
|
|
891
|
+
|
|
892
|
+
**Before (Hono only)**
|
|
893
|
+
|
|
894
|
+
```typescript
|
|
895
|
+
import { serve } from '@mastra/inngest';
|
|
896
|
+
|
|
897
|
+
// Only worked with Hono
|
|
898
|
+
app.all('/api/inngest', c => serve({ mastra, inngest })(c));
|
|
899
|
+
```
|
|
900
|
+
|
|
901
|
+
**After (any framework)**
|
|
902
|
+
|
|
903
|
+
```typescript
|
|
904
|
+
import { createServe } from '@mastra/inngest';
|
|
905
|
+
import { serve as expressAdapter } from 'inngest/express';
|
|
906
|
+
import { serve as fastifyAdapter } from 'inngest/fastify';
|
|
907
|
+
|
|
908
|
+
// Express
|
|
909
|
+
app.use('/api/inngest', createServe(expressAdapter)({ mastra, inngest }));
|
|
910
|
+
|
|
911
|
+
// Fastify
|
|
912
|
+
fastify.route({
|
|
913
|
+
method: ['GET', 'POST', 'PUT'],
|
|
914
|
+
url: '/api/inngest',
|
|
915
|
+
handler: createServe(fastifyAdapter)({ mastra, inngest }),
|
|
916
|
+
});
|
|
917
|
+
```
|
|
918
|
+
|
|
919
|
+
The existing `serve` export remains available for backward compatibility with Hono.
|
|
920
|
+
|
|
921
|
+
Fixes #10053
|
|
922
|
+
|
|
923
|
+
### Patch Changes
|
|
924
|
+
|
|
925
|
+
- Add additional context to workflow `onFinish` and `onError` callbacks ([#11705](https://github.com/mastra-ai/mastra/pull/11705))
|
|
926
|
+
|
|
927
|
+
The `onFinish` and `onError` lifecycle callbacks now receive additional properties:
|
|
928
|
+
- `runId` - The unique identifier for the workflow run
|
|
929
|
+
- `workflowId` - The workflow's identifier
|
|
930
|
+
- `resourceId` - Optional resource identifier (if provided when creating the run)
|
|
931
|
+
- `getInitData()` - Function that returns the initial input data passed to the workflow
|
|
932
|
+
- `mastra` - The Mastra instance (if workflow is registered with Mastra)
|
|
933
|
+
- `requestContext` - Request-scoped context data
|
|
934
|
+
- `logger` - The workflow's logger instance
|
|
935
|
+
- `state` - The workflow's current state object
|
|
936
|
+
|
|
937
|
+
```typescript
|
|
938
|
+
const workflow = createWorkflow({
|
|
939
|
+
id: 'order-processing',
|
|
940
|
+
inputSchema: z.object({ orderId: z.string() }),
|
|
941
|
+
outputSchema: z.object({ status: z.string() }),
|
|
942
|
+
options: {
|
|
943
|
+
onFinish: async ({ runId, workflowId, getInitData, logger, state, mastra }) => {
|
|
944
|
+
const inputData = getInitData();
|
|
945
|
+
logger.info(`Workflow ${workflowId} run ${runId} completed`, {
|
|
946
|
+
orderId: inputData.orderId,
|
|
947
|
+
finalState: state,
|
|
948
|
+
});
|
|
949
|
+
|
|
950
|
+
// Access other Mastra components if needed
|
|
951
|
+
const agent = mastra?.getAgent('notification-agent');
|
|
952
|
+
},
|
|
953
|
+
onError: async ({ runId, workflowId, error, logger, requestContext }) => {
|
|
954
|
+
logger.error(`Workflow ${workflowId} run ${runId} failed: ${error?.message}`);
|
|
955
|
+
// Access request context for additional debugging
|
|
956
|
+
const userId = requestContext.get('userId');
|
|
957
|
+
},
|
|
958
|
+
},
|
|
959
|
+
});
|
|
960
|
+
```
|
|
961
|
+
|
|
962
|
+
- Updated dependencies [[`08766f1`](https://github.com/mastra-ai/mastra/commit/08766f15e13ac0692fde2a8bd366c2e16e4321df), [`ae8baf7`](https://github.com/mastra-ai/mastra/commit/ae8baf7d8adcb0ff9dac11880400452bc49b33ff), [`cfabdd4`](https://github.com/mastra-ai/mastra/commit/cfabdd4aae7a726b706942d6836eeca110fb6267), [`a0e437f`](https://github.com/mastra-ai/mastra/commit/a0e437fac561b28ee719e0302d72b2f9b4c138f0), [`bec5efd`](https://github.com/mastra-ai/mastra/commit/bec5efde96653ccae6604e68c696d1bc6c1a0bf5), [`9eedf7d`](https://github.com/mastra-ai/mastra/commit/9eedf7de1d6e0022a2f4e5e9e6fe1ec468f9b43c)]:
|
|
963
|
+
- @mastra/core@1.0.0-beta.21
|
|
964
|
+
|
|
965
|
+
## 1.0.0-beta.11
|
|
966
|
+
|
|
967
|
+
### Patch Changes
|
|
968
|
+
|
|
969
|
+
- Add support for `retries` and `scorers` parameters across all `createStep` overloads.
|
|
970
|
+
([#11495](https://github.com/mastra-ai/mastra/pull/11495))
|
|
971
|
+
|
|
972
|
+
The `createStep` function now includes support for the `retries` and `scorers` fields across all step creation patterns, enabling step-level retry configuration and AI evaluation support for regular steps, agent-based steps, and tool-based steps.
|
|
973
|
+
|
|
974
|
+
```typescript
|
|
975
|
+
import { init } from '@mastra/inngest';
|
|
976
|
+
import { z } from 'zod';
|
|
977
|
+
|
|
978
|
+
const { createStep } = init(inngest);
|
|
979
|
+
|
|
980
|
+
// 1. Regular step with retries
|
|
981
|
+
const regularStep = createStep({
|
|
982
|
+
id: 'api-call',
|
|
983
|
+
inputSchema: z.object({ url: z.string() }),
|
|
984
|
+
outputSchema: z.object({ data: z.any() }),
|
|
985
|
+
retries: 3, // ← Will retry up to 3 times on failure
|
|
986
|
+
execute: async ({ inputData }) => {
|
|
987
|
+
const response = await fetch(inputData.url);
|
|
988
|
+
return { data: await response.json() };
|
|
989
|
+
},
|
|
990
|
+
});
|
|
991
|
+
|
|
992
|
+
// 2. Agent step with retries and scorers
|
|
993
|
+
const agentStep = createStep(myAgent, {
|
|
994
|
+
retries: 3,
|
|
995
|
+
scorers: [{ id: 'accuracy-scorer', scorer: myAccuracyScorer }],
|
|
996
|
+
});
|
|
997
|
+
|
|
998
|
+
// 3. Tool step with retries and scorers
|
|
999
|
+
const toolStep = createStep(myTool, {
|
|
1000
|
+
retries: 2,
|
|
1001
|
+
scorers: [{ id: 'quality-scorer', scorer: myQualityScorer }],
|
|
1002
|
+
});
|
|
1003
|
+
```
|
|
1004
|
+
|
|
1005
|
+
This change ensures API consistency across all `createStep` overloads. All step types now support retry and evaluation configurations.
|
|
1006
|
+
|
|
1007
|
+
This is a non-breaking change - steps without these parameters continue to work exactly as before.
|
|
1008
|
+
|
|
1009
|
+
Fixes #9351
|
|
1010
|
+
|
|
1011
|
+
- Remove `streamVNext`, `resumeStreamVNext`, and `observeStreamVNext` methods, call `stream`, `resumeStream` and `observeStream` directly ([#11499](https://github.com/mastra-ai/mastra/pull/11499))
|
|
1012
|
+
|
|
1013
|
+
```diff
|
|
1014
|
+
+ const run = await workflow.createRun({ runId: '123' });
|
|
1015
|
+
- const stream = await run.streamVNext({ inputData: { ... } });
|
|
1016
|
+
+ const stream = await run.stream({ inputData: { ... } });
|
|
1017
|
+
```
|
|
1018
|
+
|
|
1019
|
+
- Unified `getWorkflowRunById` and `getWorkflowRunExecutionResult` into a single API that returns `WorkflowState` with both metadata and execution state. ([#11429](https://github.com/mastra-ai/mastra/pull/11429))
|
|
1020
|
+
|
|
1021
|
+
**What changed:**
|
|
1022
|
+
- `getWorkflowRunById` now returns a unified `WorkflowState` object containing metadata (runId, workflowName, resourceId, createdAt, updatedAt) along with processed execution state (status, result, error, payload, steps)
|
|
1023
|
+
- Added optional `fields` parameter to request only specific fields for better performance
|
|
1024
|
+
- Added optional `withNestedWorkflows` parameter to control nested workflow step inclusion
|
|
1025
|
+
- Removed `getWorkflowRunExecutionResult` - use `getWorkflowRunById` instead (breaking change)
|
|
1026
|
+
- Removed `/execution-result` API endpoints from server (breaking change)
|
|
1027
|
+
- Removed `runExecutionResult()` method from client SDK (breaking change)
|
|
1028
|
+
- Removed `GetWorkflowRunExecutionResultResponse` type from client SDK (breaking change)
|
|
1029
|
+
|
|
1030
|
+
**Before:**
|
|
1031
|
+
|
|
1032
|
+
```typescript
|
|
1033
|
+
// Had to call two different methods for different data
|
|
1034
|
+
const run = await workflow.getWorkflowRunById(runId); // Returns raw WorkflowRun with snapshot
|
|
1035
|
+
const result = await workflow.getWorkflowRunExecutionResult(runId); // Returns processed execution state
|
|
1036
|
+
```
|
|
1037
|
+
|
|
1038
|
+
**After:**
|
|
1039
|
+
|
|
1040
|
+
```typescript
|
|
1041
|
+
// Single method returns everything
|
|
1042
|
+
const run = await workflow.getWorkflowRunById(runId);
|
|
1043
|
+
// Returns: { runId, workflowName, resourceId, createdAt, updatedAt, status, result, error, payload, steps }
|
|
1044
|
+
|
|
1045
|
+
// Request only specific fields for better performance (avoids expensive step fetching)
|
|
1046
|
+
const status = await workflow.getWorkflowRunById(runId, { fields: ['status'] });
|
|
1047
|
+
|
|
1048
|
+
// Skip nested workflow steps for faster response
|
|
1049
|
+
const run = await workflow.getWorkflowRunById(runId, { withNestedWorkflows: false });
|
|
1050
|
+
```
|
|
1051
|
+
|
|
1052
|
+
**Why:** The previous API required calling two separate methods to get complete workflow run information. This unification simplifies the API surface and gives users control over performance - fetching all steps (especially nested workflows) can be expensive, so the `fields` and `withNestedWorkflows` options let users request only what they need.
|
|
1053
|
+
|
|
1054
|
+
- Add cron scheduling support to Inngest workflows. Workflows can now be automatically triggered on a schedule by adding a `cron` property along with optional `inputData` and `initialState`: ([#11518](https://github.com/mastra-ai/mastra/pull/11518))
|
|
1055
|
+
|
|
1056
|
+
```typescript
|
|
1057
|
+
const workflow = createWorkflow({
|
|
1058
|
+
id: 'scheduled-workflow',
|
|
1059
|
+
inputSchema: z.object({ value: z.string() }),
|
|
1060
|
+
outputSchema: z.object({ result: z.string() }),
|
|
1061
|
+
steps: [step1],
|
|
1062
|
+
cron: '0 0 * * *', // Run daily at midnight
|
|
1063
|
+
inputData: { value: 'scheduled-run' }, // Optional inputData for the scheduled workflow run
|
|
1064
|
+
initialState: { count: 0 }, // Optional initialState for the scheduled workflow run
|
|
1065
|
+
});
|
|
1066
|
+
```
|
|
1067
|
+
|
|
1068
|
+
- 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)]:
|
|
1069
|
+
- @mastra/core@1.0.0-beta.20
|
|
1070
|
+
|
|
1071
|
+
## 1.0.0-beta.10
|
|
1072
|
+
|
|
1073
|
+
### Minor Changes
|
|
1074
|
+
|
|
1075
|
+
- Unified observability schema with entity-based span identification ([#11132](https://github.com/mastra-ai/mastra/pull/11132))
|
|
1076
|
+
|
|
1077
|
+
## What changed
|
|
1078
|
+
|
|
1079
|
+
Spans now use a unified identification model with `entityId`, `entityType`, and `entityName` instead of separate `agentId`, `toolId`, `workflowId` fields.
|
|
1080
|
+
|
|
1081
|
+
**Before:**
|
|
1082
|
+
|
|
1083
|
+
```typescript
|
|
1084
|
+
// Old span structure
|
|
1085
|
+
span.agentId; // 'my-agent'
|
|
1086
|
+
span.toolId; // undefined
|
|
1087
|
+
span.workflowId; // undefined
|
|
1088
|
+
```
|
|
1089
|
+
|
|
1090
|
+
**After:**
|
|
1091
|
+
|
|
1092
|
+
```typescript
|
|
1093
|
+
// New span structure
|
|
1094
|
+
span.entityType; // EntityType.AGENT
|
|
1095
|
+
span.entityId; // 'my-agent'
|
|
1096
|
+
span.entityName; // 'My Agent'
|
|
1097
|
+
```
|
|
1098
|
+
|
|
1099
|
+
## New `listTraces()` API
|
|
1100
|
+
|
|
1101
|
+
Query traces with filtering, pagination, and sorting:
|
|
1102
|
+
|
|
1103
|
+
```typescript
|
|
1104
|
+
const { spans, pagination } = await storage.listTraces({
|
|
1105
|
+
filters: {
|
|
1106
|
+
entityType: EntityType.AGENT,
|
|
1107
|
+
entityId: 'my-agent',
|
|
1108
|
+
userId: 'user-123',
|
|
1109
|
+
environment: 'production',
|
|
1110
|
+
status: TraceStatus.SUCCESS,
|
|
1111
|
+
startedAt: { start: new Date('2024-01-01'), end: new Date('2024-01-31') },
|
|
1112
|
+
},
|
|
1113
|
+
pagination: { page: 0, perPage: 50 },
|
|
1114
|
+
orderBy: { field: 'startedAt', direction: 'DESC' },
|
|
1115
|
+
});
|
|
1116
|
+
```
|
|
1117
|
+
|
|
1118
|
+
**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`.
|
|
1119
|
+
|
|
1120
|
+
## New retrieval methods
|
|
1121
|
+
- `getSpan({ traceId, spanId })` - Get a single span
|
|
1122
|
+
- `getRootSpan({ traceId })` - Get the root span of a trace
|
|
1123
|
+
- `getTrace({ traceId })` - Get all spans for a trace
|
|
1124
|
+
|
|
1125
|
+
## Backward compatibility
|
|
1126
|
+
|
|
1127
|
+
The legacy `getTraces()` method continues to work. When you pass `name: "agent run: my-agent"`, it automatically transforms to `entityId: "my-agent", entityType: AGENT`.
|
|
1128
|
+
|
|
1129
|
+
## Migration
|
|
1130
|
+
|
|
1131
|
+
**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`.
|
|
1132
|
+
|
|
1133
|
+
**No action required:** Your existing code continues to work. Adopt the new fields and `listTraces()` API at your convenience.
|
|
1134
|
+
|
|
1135
|
+
### Patch Changes
|
|
1136
|
+
|
|
1137
|
+
- Refactor storage architecture to use domain-specific stores via `getStore()` pattern ([#11361](https://github.com/mastra-ai/mastra/pull/11361))
|
|
1138
|
+
|
|
1139
|
+
### Summary
|
|
1140
|
+
|
|
1141
|
+
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.
|
|
1142
|
+
|
|
1143
|
+
### Migration Guide
|
|
1144
|
+
|
|
1145
|
+
All direct method calls on storage instances should be updated to use `getStore()`:
|
|
1146
|
+
|
|
1147
|
+
```typescript
|
|
1148
|
+
// Before
|
|
1149
|
+
const thread = await storage.getThreadById({ threadId });
|
|
1150
|
+
await storage.persistWorkflowSnapshot({ workflowName, runId, snapshot });
|
|
1151
|
+
await storage.createSpan(span);
|
|
1152
|
+
|
|
1153
|
+
// After
|
|
1154
|
+
const memory = await storage.getStore('memory');
|
|
1155
|
+
const thread = await memory?.getThreadById({ threadId });
|
|
1156
|
+
|
|
1157
|
+
const workflows = await storage.getStore('workflows');
|
|
1158
|
+
await workflows?.persistWorkflowSnapshot({ workflowName, runId, snapshot });
|
|
1159
|
+
|
|
1160
|
+
const observability = await storage.getStore('observability');
|
|
1161
|
+
await observability?.createSpan(span);
|
|
1162
|
+
```
|
|
1163
|
+
|
|
1164
|
+
### Available Domains
|
|
1165
|
+
- **`memory`**: Thread and message operations (`getThreadById`, `saveThread`, `saveMessages`, etc.)
|
|
1166
|
+
- **`workflows`**: Workflow state persistence (`persistWorkflowSnapshot`, `loadWorkflowSnapshot`, `getWorkflowRunById`, etc.)
|
|
1167
|
+
- **`scores`**: Evaluation scores (`saveScore`, `listScoresByScorerId`, etc.)
|
|
1168
|
+
- **`observability`**: Tracing and spans (`createSpan`, `updateSpan`, `getTrace`, etc.)
|
|
1169
|
+
- **`agents`**: Stored agent configurations (`createAgent`, `getAgentById`, `listAgents`, etc.)
|
|
1170
|
+
|
|
1171
|
+
### Breaking Changes
|
|
1172
|
+
- Passthrough methods have been removed from `MastraStorage` base class
|
|
1173
|
+
- All storage adapters now require accessing domains via `getStore()`
|
|
1174
|
+
- The `stores` property on storage instances is now the canonical way to access domain storage
|
|
1175
|
+
|
|
1176
|
+
### Internal Changes
|
|
1177
|
+
- Each storage adapter now initializes domain-specific stores in its constructor
|
|
1178
|
+
- Domain stores share database connections and handle their own table initialization
|
|
1179
|
+
|
|
1180
|
+
- Add debugger-like click-through UI to workflow graph ([#11350](https://github.com/mastra-ai/mastra/pull/11350))
|
|
1181
|
+
|
|
1182
|
+
- Add `perStep` option to workflow run methods, allowing a workflow to run just a step instead of all the workflow steps ([#11276](https://github.com/mastra-ai/mastra/pull/11276))
|
|
1183
|
+
|
|
1184
|
+
- 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)]:
|
|
1185
|
+
- @mastra/core@1.0.0-beta.15
|
|
1186
|
+
|
|
3
1187
|
## 1.0.0-beta.9
|
|
4
1188
|
|
|
5
1189
|
### Patch Changes
|