@mastra/ai-sdk 0.0.0-cloud-deployer-for-core-0.19.1-20251001164939 → 0.0.0-cloud-storage-adapter-20251106204059
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 +272 -3
- package/README.md +65 -1
- package/dist/chat-route.d.ts.map +1 -1
- package/dist/convert-messages.d.ts +10 -0
- package/dist/convert-messages.d.ts.map +1 -0
- package/dist/convert-streams.d.ts +18 -0
- package/dist/convert-streams.d.ts.map +1 -0
- package/dist/helpers.d.ts +37 -0
- package/dist/helpers.d.ts.map +1 -0
- package/dist/index.cjs +1189 -92
- package/dist/index.cjs.map +1 -1
- package/dist/index.d.ts +8 -2
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +1187 -92
- package/dist/index.js.map +1 -1
- package/dist/network-route.d.ts +14 -0
- package/dist/network-route.d.ts.map +1 -0
- package/dist/to-ai-sdk-format.d.ts +15 -31
- package/dist/to-ai-sdk-format.d.ts.map +1 -1
- package/dist/transformers.d.ts +133 -0
- package/dist/transformers.d.ts.map +1 -0
- package/dist/ui.cjs +16 -0
- package/dist/ui.cjs.map +1 -0
- package/dist/ui.d.ts +2 -0
- package/dist/ui.d.ts.map +1 -0
- package/dist/ui.js +13 -0
- package/dist/ui.js.map +1 -0
- package/dist/utils.d.ts +10 -0
- package/dist/utils.d.ts.map +1 -0
- package/dist/workflow-route.d.ts +10 -0
- package/dist/workflow-route.d.ts.map +1 -0
- package/package.json +22 -6
package/dist/index.cjs
CHANGED
|
@@ -1,6 +1,998 @@
|
|
|
1
1
|
'use strict';
|
|
2
2
|
|
|
3
3
|
var server = require('@mastra/core/server');
|
|
4
|
+
var ai = require('ai');
|
|
5
|
+
var stream = require('@mastra/core/stream');
|
|
6
|
+
|
|
7
|
+
// src/chat-route.ts
|
|
8
|
+
|
|
9
|
+
// src/utils.ts
|
|
10
|
+
var isDataChunkType = (chunk) => {
|
|
11
|
+
return chunk && typeof chunk === "object" && "type" in chunk && chunk.type?.startsWith("data-");
|
|
12
|
+
};
|
|
13
|
+
function safeParseErrorObject(obj) {
|
|
14
|
+
if (typeof obj !== "object" || obj === null) {
|
|
15
|
+
return String(obj);
|
|
16
|
+
}
|
|
17
|
+
try {
|
|
18
|
+
const stringified = JSON.stringify(obj);
|
|
19
|
+
if (stringified === "{}") {
|
|
20
|
+
return String(obj);
|
|
21
|
+
}
|
|
22
|
+
return stringified;
|
|
23
|
+
} catch {
|
|
24
|
+
return String(obj);
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
var isAgentExecutionDataChunkType = (chunk) => {
|
|
28
|
+
return chunk && typeof chunk === "object" && "type" in chunk && chunk.type?.startsWith("agent-execution-event-") && "payload" in chunk && typeof chunk.payload === "object" && "type" in chunk.payload && chunk.payload.type?.startsWith("data-");
|
|
29
|
+
};
|
|
30
|
+
var isWorkflowExecutionDataChunkType = (chunk) => {
|
|
31
|
+
return chunk && typeof chunk === "object" && "type" in chunk && chunk.type?.startsWith("workflow-execution-event-") && "payload" in chunk && typeof chunk.payload === "object" && "type" in chunk.payload && chunk.payload.type?.startsWith("data-");
|
|
32
|
+
};
|
|
33
|
+
|
|
34
|
+
// src/helpers.ts
|
|
35
|
+
function convertMastraChunkToAISDKv5({
|
|
36
|
+
chunk,
|
|
37
|
+
mode = "stream"
|
|
38
|
+
}) {
|
|
39
|
+
switch (chunk.type) {
|
|
40
|
+
case "start":
|
|
41
|
+
return {
|
|
42
|
+
type: "start"
|
|
43
|
+
};
|
|
44
|
+
case "step-start":
|
|
45
|
+
const { messageId: _messageId, ...rest } = chunk.payload;
|
|
46
|
+
return {
|
|
47
|
+
type: "start-step",
|
|
48
|
+
request: rest.request,
|
|
49
|
+
warnings: rest.warnings || []
|
|
50
|
+
};
|
|
51
|
+
case "raw":
|
|
52
|
+
return {
|
|
53
|
+
type: "raw",
|
|
54
|
+
rawValue: chunk.payload
|
|
55
|
+
};
|
|
56
|
+
case "finish": {
|
|
57
|
+
return {
|
|
58
|
+
type: "finish",
|
|
59
|
+
finishReason: chunk.payload.stepResult.reason,
|
|
60
|
+
totalUsage: chunk.payload.output.usage
|
|
61
|
+
};
|
|
62
|
+
}
|
|
63
|
+
case "reasoning-start":
|
|
64
|
+
return {
|
|
65
|
+
type: "reasoning-start",
|
|
66
|
+
id: chunk.payload.id,
|
|
67
|
+
providerMetadata: chunk.payload.providerMetadata
|
|
68
|
+
};
|
|
69
|
+
case "reasoning-delta":
|
|
70
|
+
return {
|
|
71
|
+
type: "reasoning-delta",
|
|
72
|
+
id: chunk.payload.id,
|
|
73
|
+
text: chunk.payload.text,
|
|
74
|
+
providerMetadata: chunk.payload.providerMetadata
|
|
75
|
+
};
|
|
76
|
+
case "reasoning-signature":
|
|
77
|
+
throw new Error('AISDKv5 chunk type "reasoning-signature" not supported');
|
|
78
|
+
// return {
|
|
79
|
+
// type: 'reasoning-signature' as const,
|
|
80
|
+
// id: chunk.payload.id,
|
|
81
|
+
// signature: chunk.payload.signature,
|
|
82
|
+
// };
|
|
83
|
+
case "redacted-reasoning":
|
|
84
|
+
throw new Error('AISDKv5 chunk type "redacted-reasoning" not supported');
|
|
85
|
+
// return {
|
|
86
|
+
// type: 'redacted-reasoning',
|
|
87
|
+
// id: chunk.payload.id,
|
|
88
|
+
// data: chunk.payload.data,
|
|
89
|
+
// };
|
|
90
|
+
case "reasoning-end":
|
|
91
|
+
return {
|
|
92
|
+
type: "reasoning-end",
|
|
93
|
+
id: chunk.payload.id,
|
|
94
|
+
providerMetadata: chunk.payload.providerMetadata
|
|
95
|
+
};
|
|
96
|
+
case "source":
|
|
97
|
+
if (chunk.payload.sourceType === "url") {
|
|
98
|
+
return {
|
|
99
|
+
type: "source",
|
|
100
|
+
sourceType: "url",
|
|
101
|
+
id: chunk.payload.id,
|
|
102
|
+
url: chunk.payload.url,
|
|
103
|
+
title: chunk.payload.title,
|
|
104
|
+
providerMetadata: chunk.payload.providerMetadata
|
|
105
|
+
};
|
|
106
|
+
} else {
|
|
107
|
+
return {
|
|
108
|
+
type: "source",
|
|
109
|
+
sourceType: "document",
|
|
110
|
+
id: chunk.payload.id,
|
|
111
|
+
mediaType: chunk.payload.mimeType,
|
|
112
|
+
title: chunk.payload.title,
|
|
113
|
+
filename: chunk.payload.filename,
|
|
114
|
+
providerMetadata: chunk.payload.providerMetadata
|
|
115
|
+
};
|
|
116
|
+
}
|
|
117
|
+
case "file":
|
|
118
|
+
if (mode === "generate") {
|
|
119
|
+
return {
|
|
120
|
+
type: "file",
|
|
121
|
+
file: new stream.DefaultGeneratedFile({
|
|
122
|
+
data: chunk.payload.data,
|
|
123
|
+
mediaType: chunk.payload.mimeType
|
|
124
|
+
})
|
|
125
|
+
};
|
|
126
|
+
}
|
|
127
|
+
return {
|
|
128
|
+
type: "file",
|
|
129
|
+
file: new stream.DefaultGeneratedFileWithType({
|
|
130
|
+
data: chunk.payload.data,
|
|
131
|
+
mediaType: chunk.payload.mimeType
|
|
132
|
+
})
|
|
133
|
+
};
|
|
134
|
+
case "tool-call":
|
|
135
|
+
return {
|
|
136
|
+
type: "tool-call",
|
|
137
|
+
toolCallId: chunk.payload.toolCallId,
|
|
138
|
+
providerMetadata: chunk.payload.providerMetadata,
|
|
139
|
+
providerExecuted: chunk.payload.providerExecuted,
|
|
140
|
+
toolName: chunk.payload.toolName,
|
|
141
|
+
input: chunk.payload.args
|
|
142
|
+
};
|
|
143
|
+
case "tool-call-input-streaming-start":
|
|
144
|
+
return {
|
|
145
|
+
type: "tool-input-start",
|
|
146
|
+
id: chunk.payload.toolCallId,
|
|
147
|
+
toolName: chunk.payload.toolName,
|
|
148
|
+
dynamic: !!chunk.payload.dynamic,
|
|
149
|
+
providerMetadata: chunk.payload.providerMetadata,
|
|
150
|
+
providerExecuted: chunk.payload.providerExecuted
|
|
151
|
+
};
|
|
152
|
+
case "tool-call-input-streaming-end":
|
|
153
|
+
return {
|
|
154
|
+
type: "tool-input-end",
|
|
155
|
+
id: chunk.payload.toolCallId,
|
|
156
|
+
providerMetadata: chunk.payload.providerMetadata
|
|
157
|
+
};
|
|
158
|
+
case "tool-call-delta":
|
|
159
|
+
return {
|
|
160
|
+
type: "tool-input-delta",
|
|
161
|
+
id: chunk.payload.toolCallId,
|
|
162
|
+
delta: chunk.payload.argsTextDelta,
|
|
163
|
+
providerMetadata: chunk.payload.providerMetadata
|
|
164
|
+
};
|
|
165
|
+
case "step-finish": {
|
|
166
|
+
const { request: _request, providerMetadata, ...rest2 } = chunk.payload.metadata;
|
|
167
|
+
return {
|
|
168
|
+
type: "finish-step",
|
|
169
|
+
response: {
|
|
170
|
+
id: chunk.payload.id || "",
|
|
171
|
+
timestamp: /* @__PURE__ */ new Date(),
|
|
172
|
+
modelId: rest2.modelId || "",
|
|
173
|
+
...rest2
|
|
174
|
+
},
|
|
175
|
+
usage: chunk.payload.output.usage,
|
|
176
|
+
finishReason: chunk.payload.stepResult.reason,
|
|
177
|
+
providerMetadata
|
|
178
|
+
};
|
|
179
|
+
}
|
|
180
|
+
case "text-delta":
|
|
181
|
+
return {
|
|
182
|
+
type: "text-delta",
|
|
183
|
+
id: chunk.payload.id,
|
|
184
|
+
text: chunk.payload.text,
|
|
185
|
+
providerMetadata: chunk.payload.providerMetadata
|
|
186
|
+
};
|
|
187
|
+
case "text-end":
|
|
188
|
+
return {
|
|
189
|
+
type: "text-end",
|
|
190
|
+
id: chunk.payload.id,
|
|
191
|
+
providerMetadata: chunk.payload.providerMetadata
|
|
192
|
+
};
|
|
193
|
+
case "text-start":
|
|
194
|
+
return {
|
|
195
|
+
type: "text-start",
|
|
196
|
+
id: chunk.payload.id,
|
|
197
|
+
providerMetadata: chunk.payload.providerMetadata
|
|
198
|
+
};
|
|
199
|
+
case "tool-result":
|
|
200
|
+
return {
|
|
201
|
+
type: "tool-result",
|
|
202
|
+
input: chunk.payload.args,
|
|
203
|
+
toolCallId: chunk.payload.toolCallId,
|
|
204
|
+
providerExecuted: chunk.payload.providerExecuted,
|
|
205
|
+
toolName: chunk.payload.toolName,
|
|
206
|
+
output: chunk.payload.result
|
|
207
|
+
// providerMetadata: chunk.payload.providerMetadata, // AI v5 types don't show this?
|
|
208
|
+
};
|
|
209
|
+
case "tool-error":
|
|
210
|
+
return {
|
|
211
|
+
type: "tool-error",
|
|
212
|
+
error: chunk.payload.error,
|
|
213
|
+
input: chunk.payload.args,
|
|
214
|
+
toolCallId: chunk.payload.toolCallId,
|
|
215
|
+
providerExecuted: chunk.payload.providerExecuted,
|
|
216
|
+
toolName: chunk.payload.toolName
|
|
217
|
+
// providerMetadata: chunk.payload.providerMetadata, // AI v5 types don't show this?
|
|
218
|
+
};
|
|
219
|
+
case "abort":
|
|
220
|
+
return {
|
|
221
|
+
type: "abort"
|
|
222
|
+
};
|
|
223
|
+
case "error":
|
|
224
|
+
return {
|
|
225
|
+
type: "error",
|
|
226
|
+
error: chunk.payload.error
|
|
227
|
+
};
|
|
228
|
+
case "object":
|
|
229
|
+
return {
|
|
230
|
+
type: "object",
|
|
231
|
+
object: chunk.object
|
|
232
|
+
};
|
|
233
|
+
default:
|
|
234
|
+
if (chunk.type && "payload" in chunk && chunk.payload) {
|
|
235
|
+
return {
|
|
236
|
+
type: chunk.type,
|
|
237
|
+
...chunk.payload || {}
|
|
238
|
+
};
|
|
239
|
+
}
|
|
240
|
+
if ("type" in chunk && chunk.type?.startsWith("data-")) {
|
|
241
|
+
return chunk;
|
|
242
|
+
}
|
|
243
|
+
return;
|
|
244
|
+
}
|
|
245
|
+
}
|
|
246
|
+
function convertFullStreamChunkToUIMessageStream({
|
|
247
|
+
part,
|
|
248
|
+
messageMetadataValue,
|
|
249
|
+
sendReasoning,
|
|
250
|
+
sendSources,
|
|
251
|
+
onError,
|
|
252
|
+
sendStart,
|
|
253
|
+
sendFinish,
|
|
254
|
+
responseMessageId
|
|
255
|
+
}) {
|
|
256
|
+
const partType = part?.type;
|
|
257
|
+
switch (partType) {
|
|
258
|
+
case "text-start": {
|
|
259
|
+
return {
|
|
260
|
+
type: "text-start",
|
|
261
|
+
id: part.id,
|
|
262
|
+
...part.providerMetadata != null ? { providerMetadata: part.providerMetadata } : {}
|
|
263
|
+
};
|
|
264
|
+
}
|
|
265
|
+
case "text-delta": {
|
|
266
|
+
return {
|
|
267
|
+
type: "text-delta",
|
|
268
|
+
id: part.id,
|
|
269
|
+
delta: part.text,
|
|
270
|
+
...part.providerMetadata != null ? { providerMetadata: part.providerMetadata } : {}
|
|
271
|
+
};
|
|
272
|
+
}
|
|
273
|
+
case "text-end": {
|
|
274
|
+
return {
|
|
275
|
+
type: "text-end",
|
|
276
|
+
id: part.id,
|
|
277
|
+
...part.providerMetadata != null ? { providerMetadata: part.providerMetadata } : {}
|
|
278
|
+
};
|
|
279
|
+
}
|
|
280
|
+
case "reasoning-start": {
|
|
281
|
+
return {
|
|
282
|
+
type: "reasoning-start",
|
|
283
|
+
id: part.id,
|
|
284
|
+
...part.providerMetadata != null ? { providerMetadata: part.providerMetadata } : {}
|
|
285
|
+
};
|
|
286
|
+
}
|
|
287
|
+
case "reasoning-delta": {
|
|
288
|
+
return;
|
|
289
|
+
}
|
|
290
|
+
case "reasoning-end": {
|
|
291
|
+
return {
|
|
292
|
+
type: "reasoning-end",
|
|
293
|
+
id: part.id,
|
|
294
|
+
...part.providerMetadata != null ? { providerMetadata: part.providerMetadata } : {}
|
|
295
|
+
};
|
|
296
|
+
}
|
|
297
|
+
case "file": {
|
|
298
|
+
return {
|
|
299
|
+
type: "file",
|
|
300
|
+
mediaType: part.file.mediaType,
|
|
301
|
+
url: `data:${part.file.mediaType};base64,${part.file.base64}`
|
|
302
|
+
};
|
|
303
|
+
}
|
|
304
|
+
case "source": {
|
|
305
|
+
return;
|
|
306
|
+
}
|
|
307
|
+
case "tool-input-start": {
|
|
308
|
+
return {
|
|
309
|
+
type: "tool-input-start",
|
|
310
|
+
toolCallId: part.id,
|
|
311
|
+
toolName: part.toolName,
|
|
312
|
+
...part.providerExecuted != null ? { providerExecuted: part.providerExecuted } : {},
|
|
313
|
+
...part.dynamic != null ? { dynamic: part.dynamic } : {}
|
|
314
|
+
};
|
|
315
|
+
}
|
|
316
|
+
case "tool-input-delta": {
|
|
317
|
+
return {
|
|
318
|
+
type: "tool-input-delta",
|
|
319
|
+
toolCallId: part.id,
|
|
320
|
+
inputTextDelta: part.delta
|
|
321
|
+
};
|
|
322
|
+
}
|
|
323
|
+
case "tool-call": {
|
|
324
|
+
return {
|
|
325
|
+
type: "tool-input-available",
|
|
326
|
+
toolCallId: part.toolCallId,
|
|
327
|
+
toolName: part.toolName,
|
|
328
|
+
input: part.input,
|
|
329
|
+
...part.providerExecuted != null ? { providerExecuted: part.providerExecuted } : {},
|
|
330
|
+
...part.providerMetadata != null ? { providerMetadata: part.providerMetadata } : {},
|
|
331
|
+
...part.dynamic != null ? { dynamic: part.dynamic } : {}
|
|
332
|
+
};
|
|
333
|
+
}
|
|
334
|
+
case "tool-result": {
|
|
335
|
+
return {
|
|
336
|
+
type: "tool-output-available",
|
|
337
|
+
toolCallId: part.toolCallId,
|
|
338
|
+
output: part.output,
|
|
339
|
+
...part.providerExecuted != null ? { providerExecuted: part.providerExecuted } : {},
|
|
340
|
+
...part.dynamic != null ? { dynamic: part.dynamic } : {}
|
|
341
|
+
};
|
|
342
|
+
}
|
|
343
|
+
case "tool-output": {
|
|
344
|
+
if (part.output.from === "AGENT") {
|
|
345
|
+
return {
|
|
346
|
+
type: "tool-agent",
|
|
347
|
+
toolCallId: part.toolCallId,
|
|
348
|
+
payload: part.output
|
|
349
|
+
};
|
|
350
|
+
} else if (part.output.from === "WORKFLOW") {
|
|
351
|
+
return {
|
|
352
|
+
type: "tool-workflow",
|
|
353
|
+
toolCallId: part.toolCallId,
|
|
354
|
+
payload: part.output
|
|
355
|
+
};
|
|
356
|
+
} else if (part.output.from === "NETWORK") {
|
|
357
|
+
return {
|
|
358
|
+
type: "tool-network",
|
|
359
|
+
toolCallId: part.toolCallId,
|
|
360
|
+
payload: part.output
|
|
361
|
+
};
|
|
362
|
+
}
|
|
363
|
+
return;
|
|
364
|
+
}
|
|
365
|
+
case "tool-error": {
|
|
366
|
+
return {
|
|
367
|
+
type: "tool-output-error",
|
|
368
|
+
toolCallId: part.toolCallId,
|
|
369
|
+
errorText: onError(part.error),
|
|
370
|
+
...part.providerExecuted != null ? { providerExecuted: part.providerExecuted } : {},
|
|
371
|
+
...part.dynamic != null ? { dynamic: part.dynamic } : {}
|
|
372
|
+
};
|
|
373
|
+
}
|
|
374
|
+
case "error": {
|
|
375
|
+
return {
|
|
376
|
+
type: "error",
|
|
377
|
+
errorText: onError(part.error)
|
|
378
|
+
};
|
|
379
|
+
}
|
|
380
|
+
case "start-step": {
|
|
381
|
+
return { type: "start-step" };
|
|
382
|
+
}
|
|
383
|
+
case "finish-step": {
|
|
384
|
+
return { type: "finish-step" };
|
|
385
|
+
}
|
|
386
|
+
case "start": {
|
|
387
|
+
{
|
|
388
|
+
return {
|
|
389
|
+
type: "start",
|
|
390
|
+
...messageMetadataValue != null ? { messageMetadata: messageMetadataValue } : {},
|
|
391
|
+
...responseMessageId != null ? { messageId: responseMessageId } : {}
|
|
392
|
+
};
|
|
393
|
+
}
|
|
394
|
+
}
|
|
395
|
+
case "finish": {
|
|
396
|
+
{
|
|
397
|
+
return {
|
|
398
|
+
type: "finish",
|
|
399
|
+
...messageMetadataValue != null ? { messageMetadata: messageMetadataValue } : {}
|
|
400
|
+
};
|
|
401
|
+
}
|
|
402
|
+
}
|
|
403
|
+
case "abort": {
|
|
404
|
+
return part;
|
|
405
|
+
}
|
|
406
|
+
case "tool-input-end": {
|
|
407
|
+
return;
|
|
408
|
+
}
|
|
409
|
+
case "raw": {
|
|
410
|
+
return;
|
|
411
|
+
}
|
|
412
|
+
default: {
|
|
413
|
+
if (isDataChunkType(part)) {
|
|
414
|
+
if (!("data" in part)) {
|
|
415
|
+
throw new Error(
|
|
416
|
+
`UI Messages require a data property when using data- prefixed chunks
|
|
417
|
+
${JSON.stringify(part)}`
|
|
418
|
+
);
|
|
419
|
+
}
|
|
420
|
+
return part;
|
|
421
|
+
}
|
|
422
|
+
return;
|
|
423
|
+
}
|
|
424
|
+
}
|
|
425
|
+
}
|
|
426
|
+
|
|
427
|
+
// src/transformers.ts
|
|
428
|
+
function WorkflowStreamToAISDKTransformer() {
|
|
429
|
+
const bufferedWorkflows = /* @__PURE__ */ new Map();
|
|
430
|
+
return new TransformStream({
|
|
431
|
+
start(controller) {
|
|
432
|
+
controller.enqueue({
|
|
433
|
+
type: "start"
|
|
434
|
+
});
|
|
435
|
+
},
|
|
436
|
+
flush(controller) {
|
|
437
|
+
controller.enqueue({
|
|
438
|
+
type: "finish"
|
|
439
|
+
});
|
|
440
|
+
},
|
|
441
|
+
transform(chunk, controller) {
|
|
442
|
+
const transformed = transformWorkflow(chunk, bufferedWorkflows);
|
|
443
|
+
if (transformed) controller.enqueue(transformed);
|
|
444
|
+
}
|
|
445
|
+
});
|
|
446
|
+
}
|
|
447
|
+
function AgentNetworkToAISDKTransformer() {
|
|
448
|
+
const bufferedNetworks = /* @__PURE__ */ new Map();
|
|
449
|
+
return new TransformStream({
|
|
450
|
+
start(controller) {
|
|
451
|
+
controller.enqueue({
|
|
452
|
+
type: "start"
|
|
453
|
+
});
|
|
454
|
+
},
|
|
455
|
+
flush(controller) {
|
|
456
|
+
controller.enqueue({
|
|
457
|
+
type: "finish"
|
|
458
|
+
});
|
|
459
|
+
},
|
|
460
|
+
transform(chunk, controller) {
|
|
461
|
+
const transformed = transformNetwork(chunk, bufferedNetworks);
|
|
462
|
+
if (transformed) controller.enqueue(transformed);
|
|
463
|
+
}
|
|
464
|
+
});
|
|
465
|
+
}
|
|
466
|
+
function AgentStreamToAISDKTransformer(lastMessageId) {
|
|
467
|
+
let bufferedSteps = /* @__PURE__ */ new Map();
|
|
468
|
+
return new TransformStream({
|
|
469
|
+
transform(chunk, controller) {
|
|
470
|
+
const part = convertMastraChunkToAISDKv5({ chunk, mode: "stream" });
|
|
471
|
+
const transformedChunk = convertFullStreamChunkToUIMessageStream({
|
|
472
|
+
part,
|
|
473
|
+
sendReasoning: false,
|
|
474
|
+
sendSources: false,
|
|
475
|
+
sendStart: true,
|
|
476
|
+
sendFinish: true,
|
|
477
|
+
responseMessageId: lastMessageId,
|
|
478
|
+
onError(error) {
|
|
479
|
+
return safeParseErrorObject(error);
|
|
480
|
+
}
|
|
481
|
+
});
|
|
482
|
+
if (transformedChunk) {
|
|
483
|
+
if (transformedChunk.type === "tool-agent") {
|
|
484
|
+
const payload = transformedChunk.payload;
|
|
485
|
+
const agentTransformed = transformAgent(payload, bufferedSteps);
|
|
486
|
+
if (agentTransformed) controller.enqueue(agentTransformed);
|
|
487
|
+
} else if (transformedChunk.type === "tool-workflow") {
|
|
488
|
+
const payload = transformedChunk.payload;
|
|
489
|
+
const workflowChunk = transformWorkflow(payload, bufferedSteps, true);
|
|
490
|
+
if (workflowChunk) controller.enqueue(workflowChunk);
|
|
491
|
+
} else if (transformedChunk.type === "tool-network") {
|
|
492
|
+
const payload = transformedChunk.payload;
|
|
493
|
+
const networkChunk = transformNetwork(payload, bufferedSteps, true);
|
|
494
|
+
if (networkChunk) controller.enqueue(networkChunk);
|
|
495
|
+
} else {
|
|
496
|
+
controller.enqueue(transformedChunk);
|
|
497
|
+
}
|
|
498
|
+
}
|
|
499
|
+
}
|
|
500
|
+
});
|
|
501
|
+
}
|
|
502
|
+
function transformAgent(payload, bufferedSteps) {
|
|
503
|
+
let hasChanged = false;
|
|
504
|
+
switch (payload.type) {
|
|
505
|
+
case "start":
|
|
506
|
+
bufferedSteps.set(payload.runId, {
|
|
507
|
+
id: payload.payload.id,
|
|
508
|
+
object: null,
|
|
509
|
+
finishReason: null,
|
|
510
|
+
usage: null,
|
|
511
|
+
warnings: [],
|
|
512
|
+
text: "",
|
|
513
|
+
reasoning: [],
|
|
514
|
+
sources: [],
|
|
515
|
+
files: [],
|
|
516
|
+
toolCalls: [],
|
|
517
|
+
toolResults: [],
|
|
518
|
+
request: {},
|
|
519
|
+
response: {
|
|
520
|
+
id: "",
|
|
521
|
+
timestamp: /* @__PURE__ */ new Date(),
|
|
522
|
+
modelId: "",
|
|
523
|
+
messages: []
|
|
524
|
+
},
|
|
525
|
+
providerMetadata: void 0,
|
|
526
|
+
steps: [],
|
|
527
|
+
status: "running"
|
|
528
|
+
});
|
|
529
|
+
hasChanged = true;
|
|
530
|
+
break;
|
|
531
|
+
case "finish":
|
|
532
|
+
bufferedSteps.set(payload.runId, {
|
|
533
|
+
...bufferedSteps.get(payload.runId),
|
|
534
|
+
finishReason: payload.payload.stepResult.reason,
|
|
535
|
+
usage: payload.payload?.output?.usage,
|
|
536
|
+
warnings: payload.payload?.stepResult?.warnings,
|
|
537
|
+
steps: bufferedSteps.get(payload.runId).steps,
|
|
538
|
+
status: "finished"
|
|
539
|
+
});
|
|
540
|
+
hasChanged = true;
|
|
541
|
+
break;
|
|
542
|
+
case "text-delta":
|
|
543
|
+
const prevData = bufferedSteps.get(payload.runId);
|
|
544
|
+
bufferedSteps.set(payload.runId, {
|
|
545
|
+
...prevData,
|
|
546
|
+
text: `${prevData.text}${payload.payload.text}`
|
|
547
|
+
});
|
|
548
|
+
hasChanged = true;
|
|
549
|
+
break;
|
|
550
|
+
case "reasoning-delta":
|
|
551
|
+
bufferedSteps.set(payload.runId, {
|
|
552
|
+
...bufferedSteps.get(payload.runId),
|
|
553
|
+
reasoning: [...bufferedSteps.get(payload.runId).reasoning, payload.payload.text]
|
|
554
|
+
});
|
|
555
|
+
hasChanged = true;
|
|
556
|
+
break;
|
|
557
|
+
case "source":
|
|
558
|
+
bufferedSteps.set(payload.runId, {
|
|
559
|
+
...bufferedSteps.get(payload.runId),
|
|
560
|
+
sources: [...bufferedSteps.get(payload.runId).sources, payload.payload]
|
|
561
|
+
});
|
|
562
|
+
hasChanged = true;
|
|
563
|
+
break;
|
|
564
|
+
case "file":
|
|
565
|
+
bufferedSteps.set(payload.runId, {
|
|
566
|
+
...bufferedSteps.get(payload.runId),
|
|
567
|
+
files: [...bufferedSteps.get(payload.runId).files, payload.payload]
|
|
568
|
+
});
|
|
569
|
+
hasChanged = true;
|
|
570
|
+
break;
|
|
571
|
+
case "tool-call":
|
|
572
|
+
bufferedSteps.set(payload.runId, {
|
|
573
|
+
...bufferedSteps.get(payload.runId),
|
|
574
|
+
toolCalls: [...bufferedSteps.get(payload.runId).toolCalls, payload.payload]
|
|
575
|
+
});
|
|
576
|
+
hasChanged = true;
|
|
577
|
+
break;
|
|
578
|
+
case "tool-result":
|
|
579
|
+
bufferedSteps.set(payload.runId, {
|
|
580
|
+
...bufferedSteps.get(payload.runId),
|
|
581
|
+
toolResults: [...bufferedSteps.get(payload.runId).toolResults, payload.payload]
|
|
582
|
+
});
|
|
583
|
+
hasChanged = true;
|
|
584
|
+
break;
|
|
585
|
+
case "object-result":
|
|
586
|
+
bufferedSteps.set(payload.runId, {
|
|
587
|
+
...bufferedSteps.get(payload.runId),
|
|
588
|
+
object: payload.object
|
|
589
|
+
});
|
|
590
|
+
hasChanged = true;
|
|
591
|
+
break;
|
|
592
|
+
case "object":
|
|
593
|
+
bufferedSteps.set(payload.runId, {
|
|
594
|
+
...bufferedSteps.get(payload.runId),
|
|
595
|
+
object: payload.object
|
|
596
|
+
});
|
|
597
|
+
hasChanged = true;
|
|
598
|
+
break;
|
|
599
|
+
case "step-finish":
|
|
600
|
+
const currentRun = bufferedSteps.get(payload.runId);
|
|
601
|
+
const stepResult = {
|
|
602
|
+
...bufferedSteps.get(payload.runId),
|
|
603
|
+
stepType: currentRun.steps.length === 0 ? "initial" : "tool-result",
|
|
604
|
+
reasoningText: bufferedSteps.get(payload.runId).reasoning.join(""),
|
|
605
|
+
staticToolCalls: bufferedSteps.get(payload.runId).toolCalls.filter((part) => part.type === "tool-call" && part.payload?.dynamic === false),
|
|
606
|
+
dynamicToolCalls: bufferedSteps.get(payload.runId).toolCalls.filter((part) => part.type === "tool-call" && part.payload?.dynamic === true),
|
|
607
|
+
staticToolResults: bufferedSteps.get(payload.runId).toolResults.filter((part) => part.type === "tool-result" && part.payload?.dynamic === false),
|
|
608
|
+
dynamicToolResults: bufferedSteps.get(payload.runId).toolResults.filter((part) => part.type === "tool-result" && part.payload?.dynamic === true),
|
|
609
|
+
finishReason: payload.payload.stepResult.reason,
|
|
610
|
+
usage: payload.payload.output.usage,
|
|
611
|
+
warnings: payload.payload.stepResult.warnings || [],
|
|
612
|
+
response: {
|
|
613
|
+
id: payload.payload.id || "",
|
|
614
|
+
timestamp: payload.payload.metadata?.timestamp || /* @__PURE__ */ new Date(),
|
|
615
|
+
modelId: payload.payload.metadata?.modelId || payload.payload.metadata?.model || "",
|
|
616
|
+
...bufferedSteps.get(payload.runId).response,
|
|
617
|
+
messages: bufferedSteps.get(payload.runId).response.messages || []
|
|
618
|
+
}
|
|
619
|
+
};
|
|
620
|
+
bufferedSteps.set(payload.runId, {
|
|
621
|
+
...bufferedSteps.get(payload.runId),
|
|
622
|
+
usage: payload.payload.output.usage,
|
|
623
|
+
warnings: payload.payload.stepResult.warnings || [],
|
|
624
|
+
steps: [...bufferedSteps.get(payload.runId).steps, stepResult]
|
|
625
|
+
});
|
|
626
|
+
hasChanged = true;
|
|
627
|
+
break;
|
|
628
|
+
}
|
|
629
|
+
if (hasChanged) {
|
|
630
|
+
return {
|
|
631
|
+
type: "data-tool-agent",
|
|
632
|
+
id: payload.runId,
|
|
633
|
+
data: bufferedSteps.get(payload.runId)
|
|
634
|
+
};
|
|
635
|
+
}
|
|
636
|
+
return null;
|
|
637
|
+
}
|
|
638
|
+
function transformWorkflow(payload, bufferedWorkflows, isNested) {
|
|
639
|
+
switch (payload.type) {
|
|
640
|
+
case "workflow-start":
|
|
641
|
+
bufferedWorkflows.set(payload.runId, {
|
|
642
|
+
name: payload.payload.workflowId,
|
|
643
|
+
steps: {}
|
|
644
|
+
});
|
|
645
|
+
return {
|
|
646
|
+
type: isNested ? "data-tool-workflow" : "data-workflow",
|
|
647
|
+
id: payload.runId,
|
|
648
|
+
data: {
|
|
649
|
+
name: bufferedWorkflows.get(payload.runId).name,
|
|
650
|
+
status: "running",
|
|
651
|
+
steps: bufferedWorkflows.get(payload.runId).steps,
|
|
652
|
+
output: null
|
|
653
|
+
}
|
|
654
|
+
};
|
|
655
|
+
case "workflow-step-start": {
|
|
656
|
+
const current = bufferedWorkflows.get(payload.runId) || { name: "", steps: {} };
|
|
657
|
+
current.steps[payload.payload.id] = {
|
|
658
|
+
name: payload.payload.id,
|
|
659
|
+
status: payload.payload.status,
|
|
660
|
+
input: payload.payload.payload ?? null,
|
|
661
|
+
output: null,
|
|
662
|
+
suspendPayload: null,
|
|
663
|
+
resumePayload: null
|
|
664
|
+
};
|
|
665
|
+
bufferedWorkflows.set(payload.runId, current);
|
|
666
|
+
return {
|
|
667
|
+
type: isNested ? "data-tool-workflow" : "data-workflow",
|
|
668
|
+
id: payload.runId,
|
|
669
|
+
data: {
|
|
670
|
+
name: current.name,
|
|
671
|
+
status: "running",
|
|
672
|
+
steps: current.steps,
|
|
673
|
+
output: null
|
|
674
|
+
}
|
|
675
|
+
};
|
|
676
|
+
}
|
|
677
|
+
case "workflow-step-result": {
|
|
678
|
+
const current = bufferedWorkflows.get(payload.runId);
|
|
679
|
+
if (!current) return null;
|
|
680
|
+
current.steps[payload.payload.id] = {
|
|
681
|
+
...current.steps[payload.payload.id],
|
|
682
|
+
status: payload.payload.status,
|
|
683
|
+
output: payload.payload.output ?? null
|
|
684
|
+
};
|
|
685
|
+
return {
|
|
686
|
+
type: isNested ? "data-tool-workflow" : "data-workflow",
|
|
687
|
+
id: payload.runId,
|
|
688
|
+
data: {
|
|
689
|
+
name: current.name,
|
|
690
|
+
status: "running",
|
|
691
|
+
steps: current.steps,
|
|
692
|
+
output: null
|
|
693
|
+
}
|
|
694
|
+
};
|
|
695
|
+
}
|
|
696
|
+
case "workflow-step-suspended": {
|
|
697
|
+
const current = bufferedWorkflows.get(payload.runId);
|
|
698
|
+
if (!current) return null;
|
|
699
|
+
current.steps[payload.payload.id] = {
|
|
700
|
+
...current.steps[payload.payload.id],
|
|
701
|
+
status: payload.payload.status,
|
|
702
|
+
suspendPayload: payload.payload.suspendPayload ?? null,
|
|
703
|
+
resumePayload: payload.payload.resumePayload ?? null,
|
|
704
|
+
output: null
|
|
705
|
+
};
|
|
706
|
+
return {
|
|
707
|
+
type: isNested ? "data-tool-workflow" : "data-workflow",
|
|
708
|
+
id: payload.runId,
|
|
709
|
+
data: {
|
|
710
|
+
name: current.name,
|
|
711
|
+
status: "suspended",
|
|
712
|
+
steps: current.steps,
|
|
713
|
+
output: null
|
|
714
|
+
}
|
|
715
|
+
};
|
|
716
|
+
}
|
|
717
|
+
case "workflow-finish": {
|
|
718
|
+
const current = bufferedWorkflows.get(payload.runId);
|
|
719
|
+
if (!current) return null;
|
|
720
|
+
return {
|
|
721
|
+
type: isNested ? "data-tool-workflow" : "data-workflow",
|
|
722
|
+
id: payload.runId,
|
|
723
|
+
data: {
|
|
724
|
+
name: current.name,
|
|
725
|
+
steps: current.steps,
|
|
726
|
+
output: payload.payload.output ?? null,
|
|
727
|
+
status: payload.payload.workflowStatus
|
|
728
|
+
}
|
|
729
|
+
};
|
|
730
|
+
}
|
|
731
|
+
default: {
|
|
732
|
+
if (isDataChunkType(payload)) {
|
|
733
|
+
if (!("data" in payload)) {
|
|
734
|
+
throw new Error(
|
|
735
|
+
`UI Messages require a data property when using data- prefixed chunks
|
|
736
|
+
${JSON.stringify(payload)}`
|
|
737
|
+
);
|
|
738
|
+
}
|
|
739
|
+
return payload;
|
|
740
|
+
}
|
|
741
|
+
return null;
|
|
742
|
+
}
|
|
743
|
+
}
|
|
744
|
+
}
|
|
745
|
+
function transformNetwork(payload, bufferedNetworks, isNested) {
|
|
746
|
+
switch (payload.type) {
|
|
747
|
+
case "routing-agent-start": {
|
|
748
|
+
if (!bufferedNetworks.has(payload.runId)) {
|
|
749
|
+
bufferedNetworks.set(payload.runId, {
|
|
750
|
+
name: payload.payload.agentId,
|
|
751
|
+
steps: [],
|
|
752
|
+
usage: null,
|
|
753
|
+
output: null
|
|
754
|
+
});
|
|
755
|
+
}
|
|
756
|
+
return {
|
|
757
|
+
type: isNested ? "data-tool-network" : "data-network",
|
|
758
|
+
id: payload.runId,
|
|
759
|
+
data: {
|
|
760
|
+
name: bufferedNetworks.get(payload.runId).name,
|
|
761
|
+
status: "running",
|
|
762
|
+
usage: null,
|
|
763
|
+
steps: bufferedNetworks.get(payload.runId).steps,
|
|
764
|
+
output: null
|
|
765
|
+
}
|
|
766
|
+
};
|
|
767
|
+
}
|
|
768
|
+
case "routing-agent-text-start": {
|
|
769
|
+
const current = bufferedNetworks.get(payload.runId);
|
|
770
|
+
if (!current) return null;
|
|
771
|
+
return {
|
|
772
|
+
type: "text-start",
|
|
773
|
+
id: payload.runId
|
|
774
|
+
};
|
|
775
|
+
}
|
|
776
|
+
case "routing-agent-text-delta": {
|
|
777
|
+
const current = bufferedNetworks.get(payload.runId);
|
|
778
|
+
if (!current) return null;
|
|
779
|
+
return {
|
|
780
|
+
type: "text-delta",
|
|
781
|
+
id: payload.runId,
|
|
782
|
+
delta: payload.payload.text
|
|
783
|
+
};
|
|
784
|
+
}
|
|
785
|
+
case "agent-execution-start": {
|
|
786
|
+
const current = bufferedNetworks.get(payload.runId) || { name: "", steps: [], usage: null, output: null };
|
|
787
|
+
current.steps.push({
|
|
788
|
+
name: payload.payload.agentId,
|
|
789
|
+
status: "running",
|
|
790
|
+
input: payload.payload.args || null,
|
|
791
|
+
output: null,
|
|
792
|
+
suspendPayload: null,
|
|
793
|
+
resumePayload: null
|
|
794
|
+
});
|
|
795
|
+
bufferedNetworks.set(payload.runId, current);
|
|
796
|
+
return {
|
|
797
|
+
type: isNested ? "data-tool-network" : "data-network",
|
|
798
|
+
id: payload.runId,
|
|
799
|
+
data: {
|
|
800
|
+
...current,
|
|
801
|
+
status: "running"
|
|
802
|
+
}
|
|
803
|
+
};
|
|
804
|
+
}
|
|
805
|
+
case "workflow-execution-start": {
|
|
806
|
+
const current = bufferedNetworks.get(payload.runId) || { name: "", steps: [], usage: null, output: null };
|
|
807
|
+
current.steps.push({
|
|
808
|
+
name: payload.payload.name,
|
|
809
|
+
status: "running",
|
|
810
|
+
input: payload.payload.args || null,
|
|
811
|
+
output: null,
|
|
812
|
+
suspendPayload: null,
|
|
813
|
+
resumePayload: null
|
|
814
|
+
});
|
|
815
|
+
bufferedNetworks.set(payload.runId, current);
|
|
816
|
+
return {
|
|
817
|
+
type: isNested ? "data-tool-network" : "data-network",
|
|
818
|
+
id: payload.runId,
|
|
819
|
+
data: {
|
|
820
|
+
...current,
|
|
821
|
+
status: "running"
|
|
822
|
+
}
|
|
823
|
+
};
|
|
824
|
+
}
|
|
825
|
+
case "tool-execution-start": {
|
|
826
|
+
const current = bufferedNetworks.get(payload.runId) || { name: "", steps: [], usage: null, output: null };
|
|
827
|
+
current.steps.push({
|
|
828
|
+
name: payload.payload.args?.toolName,
|
|
829
|
+
status: "running",
|
|
830
|
+
input: payload.payload.args?.args || null,
|
|
831
|
+
output: null,
|
|
832
|
+
suspendPayload: null,
|
|
833
|
+
resumePayload: null
|
|
834
|
+
});
|
|
835
|
+
bufferedNetworks.set(payload.runId, current);
|
|
836
|
+
return {
|
|
837
|
+
type: isNested ? "data-tool-network" : "data-network",
|
|
838
|
+
id: payload.runId,
|
|
839
|
+
data: {
|
|
840
|
+
...current,
|
|
841
|
+
status: "running"
|
|
842
|
+
}
|
|
843
|
+
};
|
|
844
|
+
}
|
|
845
|
+
case "agent-execution-end": {
|
|
846
|
+
const current = bufferedNetworks.get(payload.runId);
|
|
847
|
+
if (!current) return null;
|
|
848
|
+
current.steps.push({
|
|
849
|
+
name: payload.payload.agentId,
|
|
850
|
+
status: "success",
|
|
851
|
+
input: null,
|
|
852
|
+
output: payload.payload.result,
|
|
853
|
+
suspendPayload: null,
|
|
854
|
+
resumePayload: null
|
|
855
|
+
});
|
|
856
|
+
return {
|
|
857
|
+
type: isNested ? "data-tool-network" : "data-network",
|
|
858
|
+
id: payload.runId,
|
|
859
|
+
data: {
|
|
860
|
+
...current,
|
|
861
|
+
usage: payload.payload?.usage ?? current.usage,
|
|
862
|
+
status: "running",
|
|
863
|
+
output: payload.payload.result ?? current.output
|
|
864
|
+
}
|
|
865
|
+
};
|
|
866
|
+
}
|
|
867
|
+
case "tool-execution-end": {
|
|
868
|
+
const current = bufferedNetworks.get(payload.runId);
|
|
869
|
+
if (!current) return null;
|
|
870
|
+
current.steps.push({
|
|
871
|
+
name: payload.payload.toolName,
|
|
872
|
+
status: "success",
|
|
873
|
+
input: null,
|
|
874
|
+
output: payload.payload.result,
|
|
875
|
+
suspendPayload: null,
|
|
876
|
+
resumePayload: null
|
|
877
|
+
});
|
|
878
|
+
return {
|
|
879
|
+
type: isNested ? "data-tool-network" : "data-network",
|
|
880
|
+
id: payload.runId,
|
|
881
|
+
data: {
|
|
882
|
+
...current,
|
|
883
|
+
status: "running",
|
|
884
|
+
output: payload.payload.result ?? current.output
|
|
885
|
+
}
|
|
886
|
+
};
|
|
887
|
+
}
|
|
888
|
+
case "workflow-execution-end": {
|
|
889
|
+
const current = bufferedNetworks.get(payload.runId);
|
|
890
|
+
if (!current) return null;
|
|
891
|
+
current.steps.push({
|
|
892
|
+
name: payload.payload.name,
|
|
893
|
+
status: "success",
|
|
894
|
+
input: null,
|
|
895
|
+
output: payload.payload.result,
|
|
896
|
+
suspendPayload: null,
|
|
897
|
+
resumePayload: null
|
|
898
|
+
});
|
|
899
|
+
return {
|
|
900
|
+
type: isNested ? "data-tool-network" : "data-network",
|
|
901
|
+
id: payload.runId,
|
|
902
|
+
data: {
|
|
903
|
+
...current,
|
|
904
|
+
usage: payload.payload?.usage ?? current.usage,
|
|
905
|
+
status: "running",
|
|
906
|
+
output: payload.payload.result ?? current.output
|
|
907
|
+
}
|
|
908
|
+
};
|
|
909
|
+
}
|
|
910
|
+
case "routing-agent-end": {
|
|
911
|
+
const current = bufferedNetworks.get(payload.runId);
|
|
912
|
+
if (!current) return null;
|
|
913
|
+
return {
|
|
914
|
+
type: isNested ? "data-tool-network" : "data-network",
|
|
915
|
+
id: payload.runId,
|
|
916
|
+
data: {
|
|
917
|
+
...current,
|
|
918
|
+
status: "finished",
|
|
919
|
+
usage: payload.payload?.usage ?? current.usage,
|
|
920
|
+
output: payload.payload?.result ?? current.output
|
|
921
|
+
}
|
|
922
|
+
};
|
|
923
|
+
}
|
|
924
|
+
case "network-execution-event-step-finish": {
|
|
925
|
+
const current = bufferedNetworks.get(payload.runId);
|
|
926
|
+
if (!current) return null;
|
|
927
|
+
return {
|
|
928
|
+
type: isNested ? "data-tool-network" : "data-network",
|
|
929
|
+
id: payload.runId,
|
|
930
|
+
data: {
|
|
931
|
+
...current,
|
|
932
|
+
status: "finished",
|
|
933
|
+
output: payload.payload?.result ?? current.output
|
|
934
|
+
}
|
|
935
|
+
};
|
|
936
|
+
}
|
|
937
|
+
case "network-execution-event-finish": {
|
|
938
|
+
const current = bufferedNetworks.get(payload.runId);
|
|
939
|
+
if (!current) return null;
|
|
940
|
+
return {
|
|
941
|
+
type: isNested ? "data-tool-network" : "data-network",
|
|
942
|
+
id: payload.runId,
|
|
943
|
+
data: {
|
|
944
|
+
...current,
|
|
945
|
+
usage: payload.payload?.usage ?? current.usage,
|
|
946
|
+
status: "finished",
|
|
947
|
+
output: payload.payload?.result ?? current.output
|
|
948
|
+
}
|
|
949
|
+
};
|
|
950
|
+
}
|
|
951
|
+
default: {
|
|
952
|
+
if (isDataChunkType(payload)) {
|
|
953
|
+
if (!("data" in payload)) {
|
|
954
|
+
throw new Error(
|
|
955
|
+
`UI Messages require a data property when using data- prefixed chunks
|
|
956
|
+
${JSON.stringify(payload)}`
|
|
957
|
+
);
|
|
958
|
+
}
|
|
959
|
+
return payload;
|
|
960
|
+
}
|
|
961
|
+
if (isAgentExecutionDataChunkType(payload)) {
|
|
962
|
+
if (!("data" in payload.payload)) {
|
|
963
|
+
throw new Error(
|
|
964
|
+
`UI Messages require a data property when using data- prefixed chunks
|
|
965
|
+
${JSON.stringify(payload)}`
|
|
966
|
+
);
|
|
967
|
+
}
|
|
968
|
+
return payload.payload;
|
|
969
|
+
}
|
|
970
|
+
if (isWorkflowExecutionDataChunkType(payload)) {
|
|
971
|
+
if (!("data" in payload.payload)) {
|
|
972
|
+
throw new Error(
|
|
973
|
+
`UI Messages require a data property when using data- prefixed chunks
|
|
974
|
+
${JSON.stringify(payload)}`
|
|
975
|
+
);
|
|
976
|
+
}
|
|
977
|
+
return payload.payload;
|
|
978
|
+
}
|
|
979
|
+
return null;
|
|
980
|
+
}
|
|
981
|
+
}
|
|
982
|
+
}
|
|
983
|
+
|
|
984
|
+
// src/convert-streams.ts
|
|
985
|
+
function toAISdkV5Stream(stream, options = { from: "agent" }) {
|
|
986
|
+
const from = options?.from;
|
|
987
|
+
if (from === "workflow") {
|
|
988
|
+
return stream.pipeThrough(WorkflowStreamToAISDKTransformer());
|
|
989
|
+
}
|
|
990
|
+
if (from === "network") {
|
|
991
|
+
return stream.pipeThrough(AgentNetworkToAISDKTransformer());
|
|
992
|
+
}
|
|
993
|
+
const agentReadable = "fullStream" in stream ? stream.fullStream : stream;
|
|
994
|
+
return agentReadable.pipeThrough(AgentStreamToAISDKTransformer(options?.lastMessageId));
|
|
995
|
+
}
|
|
4
996
|
|
|
5
997
|
// src/chat-route.ts
|
|
6
998
|
function chatRoute({
|
|
@@ -107,6 +1099,7 @@ function chatRoute({
|
|
|
107
1099
|
handler: async (c) => {
|
|
108
1100
|
const { messages, ...rest } = await c.req.json();
|
|
109
1101
|
const mastra = c.get("mastra");
|
|
1102
|
+
const requestContext = c.get("requestContext");
|
|
110
1103
|
let agentToUse = agent;
|
|
111
1104
|
if (!agent) {
|
|
112
1105
|
const agentId = c.req.param("agentId");
|
|
@@ -117,6 +1110,9 @@ function chatRoute({
|
|
|
117
1110
|
`Fixed agent ID was set together with an agentId path parameter. This can lead to unexpected behavior.`
|
|
118
1111
|
);
|
|
119
1112
|
}
|
|
1113
|
+
if (requestContext && defaultOptions?.requestContext) {
|
|
1114
|
+
mastra.getLogger()?.warn(`"requestContext" set in the route options will be overridden by the request's "requestContext".`);
|
|
1115
|
+
}
|
|
120
1116
|
if (!agentToUse) {
|
|
121
1117
|
throw new Error("Agent ID is required");
|
|
122
1118
|
}
|
|
@@ -124,115 +1120,216 @@ function chatRoute({
|
|
|
124
1120
|
if (!agentObj) {
|
|
125
1121
|
throw new Error(`Agent ${agentToUse} not found`);
|
|
126
1122
|
}
|
|
127
|
-
const result = await agentObj.
|
|
1123
|
+
const result = await agentObj.stream(messages, {
|
|
128
1124
|
...defaultOptions,
|
|
129
1125
|
...rest,
|
|
130
|
-
|
|
1126
|
+
requestContext: requestContext || defaultOptions?.requestContext
|
|
1127
|
+
});
|
|
1128
|
+
let lastMessageId;
|
|
1129
|
+
if (messages.length > 0 && messages[messages.length - 1].role === "assistant") {
|
|
1130
|
+
lastMessageId = messages[messages.length - 1].id;
|
|
1131
|
+
}
|
|
1132
|
+
const uiMessageStream = ai.createUIMessageStream({
|
|
1133
|
+
originalMessages: messages,
|
|
1134
|
+
execute: async ({ writer }) => {
|
|
1135
|
+
for await (const part of toAISdkV5Stream(result, { from: "agent", lastMessageId })) {
|
|
1136
|
+
writer.write(part);
|
|
1137
|
+
}
|
|
1138
|
+
}
|
|
1139
|
+
});
|
|
1140
|
+
return ai.createUIMessageStreamResponse({
|
|
1141
|
+
stream: uiMessageStream
|
|
131
1142
|
});
|
|
132
|
-
return result.toUIMessageStreamResponse();
|
|
133
1143
|
}
|
|
134
1144
|
});
|
|
135
1145
|
}
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
|
|
168
|
-
|
|
169
|
-
status: "running",
|
|
170
|
-
steps: {},
|
|
171
|
-
output: null
|
|
1146
|
+
function workflowRoute({
|
|
1147
|
+
path = "/api/workflows/:workflowId/stream",
|
|
1148
|
+
workflow
|
|
1149
|
+
}) {
|
|
1150
|
+
if (!workflow && !path.includes("/:workflowId")) {
|
|
1151
|
+
throw new Error("Path must include :workflowId to route to the correct workflow or pass the workflow explicitly");
|
|
1152
|
+
}
|
|
1153
|
+
return server.registerApiRoute(path, {
|
|
1154
|
+
method: "POST",
|
|
1155
|
+
openapi: {
|
|
1156
|
+
summary: "Stream a workflow in AI SDK format",
|
|
1157
|
+
description: "Starts a workflow run and streams events as AI SDK UIMessage chunks",
|
|
1158
|
+
tags: ["ai-sdk"],
|
|
1159
|
+
parameters: [
|
|
1160
|
+
{
|
|
1161
|
+
name: "workflowId",
|
|
1162
|
+
in: "path",
|
|
1163
|
+
required: true,
|
|
1164
|
+
description: "The ID of the workflow to stream",
|
|
1165
|
+
schema: { type: "string" }
|
|
1166
|
+
}
|
|
1167
|
+
],
|
|
1168
|
+
requestBody: {
|
|
1169
|
+
required: true,
|
|
1170
|
+
content: {
|
|
1171
|
+
"application/json": {
|
|
1172
|
+
schema: {
|
|
1173
|
+
type: "object",
|
|
1174
|
+
properties: {
|
|
1175
|
+
inputData: { type: "object", additionalProperties: true },
|
|
1176
|
+
requestContext: { type: "object", additionalProperties: true },
|
|
1177
|
+
tracingOptions: { type: "object", additionalProperties: true }
|
|
1178
|
+
}
|
|
172
1179
|
}
|
|
173
|
-
}
|
|
174
|
-
}
|
|
175
|
-
}
|
|
176
|
-
|
|
177
|
-
|
|
178
|
-
|
|
179
|
-
|
|
180
|
-
|
|
181
|
-
|
|
182
|
-
};
|
|
183
|
-
controller.enqueue({
|
|
184
|
-
data: JSON.stringify({
|
|
185
|
-
type: "data-workflow",
|
|
186
|
-
id: chunk.runId,
|
|
187
|
-
data: {
|
|
188
|
-
name: workflowName,
|
|
189
|
-
status: "running",
|
|
190
|
-
steps,
|
|
191
|
-
output: null
|
|
1180
|
+
}
|
|
1181
|
+
}
|
|
1182
|
+
},
|
|
1183
|
+
responses: {
|
|
1184
|
+
"200": {
|
|
1185
|
+
description: "Workflow UIMessage event stream",
|
|
1186
|
+
content: {
|
|
1187
|
+
"text/plain": {
|
|
1188
|
+
schema: { type: "string", description: "SSE stream" }
|
|
192
1189
|
}
|
|
193
|
-
}
|
|
194
|
-
}
|
|
195
|
-
}
|
|
196
|
-
|
|
197
|
-
|
|
198
|
-
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
|
|
203
|
-
|
|
204
|
-
|
|
205
|
-
|
|
206
|
-
|
|
207
|
-
|
|
208
|
-
|
|
209
|
-
|
|
1190
|
+
}
|
|
1191
|
+
}
|
|
1192
|
+
}
|
|
1193
|
+
},
|
|
1194
|
+
handler: async (c) => {
|
|
1195
|
+
const { inputData, resumeData, ...rest } = await c.req.json();
|
|
1196
|
+
const mastra = c.get("mastra");
|
|
1197
|
+
let workflowToUse = workflow;
|
|
1198
|
+
if (!workflow) {
|
|
1199
|
+
const workflowId = c.req.param("workflowId");
|
|
1200
|
+
workflowToUse = workflowId;
|
|
1201
|
+
}
|
|
1202
|
+
if (c.req.param("workflowId") && workflow) {
|
|
1203
|
+
mastra.getLogger()?.warn(
|
|
1204
|
+
`Fixed workflow ID was set together with a workflowId path parameter. This can lead to unexpected behavior.`
|
|
1205
|
+
);
|
|
1206
|
+
}
|
|
1207
|
+
if (!workflowToUse) {
|
|
1208
|
+
throw new Error("Workflow ID is required");
|
|
1209
|
+
}
|
|
1210
|
+
const workflowObj = mastra.getWorkflow(workflowToUse);
|
|
1211
|
+
if (!workflowObj) {
|
|
1212
|
+
throw new Error(`Workflow ${workflowToUse} not found`);
|
|
1213
|
+
}
|
|
1214
|
+
const run = await workflowObj.createRun();
|
|
1215
|
+
const stream = resumeData ? run.resumeStream({ resumeData, ...rest }) : run.stream({ inputData, ...rest });
|
|
1216
|
+
const uiMessageStream = ai.createUIMessageStream({
|
|
1217
|
+
execute: async ({ writer }) => {
|
|
1218
|
+
for await (const part of toAISdkV5Stream(stream, { from: "workflow" })) {
|
|
1219
|
+
writer.write(part);
|
|
1220
|
+
}
|
|
1221
|
+
}
|
|
1222
|
+
});
|
|
1223
|
+
return ai.createUIMessageStreamResponse({ stream: uiMessageStream });
|
|
1224
|
+
}
|
|
1225
|
+
});
|
|
1226
|
+
}
|
|
1227
|
+
function networkRoute({
|
|
1228
|
+
path = "/network/:agentId",
|
|
1229
|
+
agent,
|
|
1230
|
+
defaultOptions
|
|
1231
|
+
}) {
|
|
1232
|
+
if (!agent && !path.includes("/:agentId")) {
|
|
1233
|
+
throw new Error("Path must include :agentId to route to the correct agent or pass the agent explicitly");
|
|
1234
|
+
}
|
|
1235
|
+
return server.registerApiRoute(path, {
|
|
1236
|
+
method: "POST",
|
|
1237
|
+
openapi: {
|
|
1238
|
+
summary: "Execute an agent network and stream AI SDK events",
|
|
1239
|
+
description: "Routes a request to an agent network and streams UIMessage chunks in AI SDK format",
|
|
1240
|
+
tags: ["ai-sdk"],
|
|
1241
|
+
parameters: [
|
|
1242
|
+
{
|
|
1243
|
+
name: "agentId",
|
|
1244
|
+
in: "path",
|
|
1245
|
+
required: true,
|
|
1246
|
+
description: "The ID of the routing agent to execute as a network",
|
|
1247
|
+
schema: { type: "string" }
|
|
1248
|
+
}
|
|
1249
|
+
],
|
|
1250
|
+
requestBody: {
|
|
1251
|
+
required: true,
|
|
1252
|
+
content: {
|
|
1253
|
+
"application/json": {
|
|
1254
|
+
schema: {
|
|
1255
|
+
type: "object",
|
|
1256
|
+
properties: {
|
|
1257
|
+
messages: { type: "array", items: { type: "object" } },
|
|
1258
|
+
requestContext: { type: "object", additionalProperties: true },
|
|
1259
|
+
runId: { type: "string" },
|
|
1260
|
+
maxSteps: { type: "number" },
|
|
1261
|
+
threadId: { type: "string" },
|
|
1262
|
+
resourceId: { type: "string" },
|
|
1263
|
+
modelSettings: { type: "object", additionalProperties: true },
|
|
1264
|
+
tools: { type: "array", items: { type: "object" } }
|
|
1265
|
+
},
|
|
1266
|
+
required: ["messages"]
|
|
210
1267
|
}
|
|
211
|
-
}
|
|
212
|
-
}
|
|
213
|
-
}
|
|
214
|
-
|
|
215
|
-
|
|
216
|
-
|
|
217
|
-
|
|
218
|
-
|
|
219
|
-
|
|
220
|
-
|
|
221
|
-
|
|
222
|
-
|
|
1268
|
+
}
|
|
1269
|
+
}
|
|
1270
|
+
},
|
|
1271
|
+
responses: {
|
|
1272
|
+
"200": {
|
|
1273
|
+
description: "Streaming AI SDK UIMessage event stream for the agent network",
|
|
1274
|
+
content: { "text/plain": { schema: { type: "string", description: "SSE stream" } } }
|
|
1275
|
+
},
|
|
1276
|
+
"404": {
|
|
1277
|
+
description: "Agent not found",
|
|
1278
|
+
content: {
|
|
1279
|
+
"application/json": {
|
|
1280
|
+
schema: { type: "object", properties: { error: { type: "string" } } }
|
|
223
1281
|
}
|
|
224
|
-
}
|
|
225
|
-
}
|
|
1282
|
+
}
|
|
1283
|
+
}
|
|
1284
|
+
}
|
|
1285
|
+
},
|
|
1286
|
+
handler: async (c) => {
|
|
1287
|
+
const { messages, ...rest } = await c.req.json();
|
|
1288
|
+
const mastra = c.get("mastra");
|
|
1289
|
+
let agentToUse = agent;
|
|
1290
|
+
if (!agent) {
|
|
1291
|
+
const agentId = c.req.param("agentId");
|
|
1292
|
+
agentToUse = agentId;
|
|
1293
|
+
}
|
|
1294
|
+
if (c.req.param("agentId") && agent) {
|
|
1295
|
+
mastra.getLogger()?.warn(
|
|
1296
|
+
`Fixed agent ID was set together with an agentId path parameter. This can lead to unexpected behavior.`
|
|
1297
|
+
);
|
|
1298
|
+
}
|
|
1299
|
+
if (!agentToUse) {
|
|
1300
|
+
throw new Error("Agent ID is required");
|
|
1301
|
+
}
|
|
1302
|
+
const agentObj = mastra.getAgent(agentToUse);
|
|
1303
|
+
if (!agentObj) {
|
|
1304
|
+
throw new Error(`Agent ${agentToUse} not found`);
|
|
226
1305
|
}
|
|
1306
|
+
const result = await agentObj.network(messages, {
|
|
1307
|
+
...defaultOptions,
|
|
1308
|
+
...rest
|
|
1309
|
+
});
|
|
1310
|
+
const uiMessageStream = ai.createUIMessageStream({
|
|
1311
|
+
execute: async ({ writer }) => {
|
|
1312
|
+
for await (const part of toAISdkV5Stream(result, { from: "network" })) {
|
|
1313
|
+
writer.write(part);
|
|
1314
|
+
}
|
|
1315
|
+
}
|
|
1316
|
+
});
|
|
1317
|
+
return ai.createUIMessageStreamResponse({ stream: uiMessageStream });
|
|
227
1318
|
}
|
|
228
1319
|
});
|
|
229
1320
|
}
|
|
230
|
-
|
|
231
|
-
|
|
1321
|
+
|
|
1322
|
+
// src/to-ai-sdk-format.ts
|
|
1323
|
+
function toAISdkFormat() {
|
|
1324
|
+
throw new Error(
|
|
1325
|
+
'toAISdkFormat() has been deprecated. Please use toAISdkStream() instead.\n\nMigration:\n import { toAISdkFormat } from "@mastra/ai-sdk";\n // Change to:\n import { toAISdkStream } from "@mastra/ai-sdk";\n\nThe function signature remains the same.'
|
|
1326
|
+
);
|
|
232
1327
|
}
|
|
233
1328
|
|
|
234
|
-
exports.WokflowStreamToAISDKTransformer = WokflowStreamToAISDKTransformer;
|
|
235
1329
|
exports.chatRoute = chatRoute;
|
|
1330
|
+
exports.networkRoute = networkRoute;
|
|
236
1331
|
exports.toAISdkFormat = toAISdkFormat;
|
|
1332
|
+
exports.toAISdkStream = toAISdkV5Stream;
|
|
1333
|
+
exports.workflowRoute = workflowRoute;
|
|
237
1334
|
//# sourceMappingURL=index.cjs.map
|
|
238
1335
|
//# sourceMappingURL=index.cjs.map
|