agents 0.0.0-2a6e66e → 0.0.0-2bea91f
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/README.md +129 -7
- package/dist/_esm-LV5FJ3HK.js +3922 -0
- package/dist/_esm-LV5FJ3HK.js.map +1 -0
- package/dist/ai-chat-agent.d.ts +8 -6
- package/dist/ai-chat-agent.js +442 -48
- package/dist/ai-chat-agent.js.map +1 -1
- package/dist/ai-chat-v5-migration.d.ts +152 -0
- package/dist/ai-chat-v5-migration.js +20 -0
- package/dist/ai-chat-v5-migration.js.map +1 -0
- package/dist/ai-react.d.ts +64 -69
- package/dist/ai-react.js +252 -99
- package/dist/ai-react.js.map +1 -1
- package/dist/ai-types.d.ts +37 -19
- package/dist/ai-types.js +7 -0
- package/dist/ccip-CMBYN64O.js +15 -0
- package/dist/ccip-CMBYN64O.js.map +1 -0
- package/dist/{chunk-CV3L6FQZ.js → chunk-254F4GDT.js} +159 -106
- package/dist/chunk-254F4GDT.js.map +1 -0
- package/dist/{chunk-HY7ZLHJB.js → chunk-3OT2NNEW.js} +412 -69
- package/dist/chunk-3OT2NNEW.js.map +1 -0
- package/dist/chunk-5Y6BEZDY.js +276 -0
- package/dist/chunk-5Y6BEZDY.js.map +1 -0
- package/dist/chunk-BER7KXUJ.js +18 -0
- package/dist/chunk-BER7KXUJ.js.map +1 -0
- package/dist/chunk-JJBFIGUC.js +5202 -0
- package/dist/chunk-JJBFIGUC.js.map +1 -0
- package/dist/chunk-PR4QN5HX.js +43 -0
- package/dist/chunk-PR4QN5HX.js.map +1 -0
- package/dist/{chunk-KUH345EY.js → chunk-QEVM4BVL.js} +5 -5
- package/dist/chunk-QEVM4BVL.js.map +1 -0
- package/dist/chunk-TYAY6AU6.js +159 -0
- package/dist/chunk-TYAY6AU6.js.map +1 -0
- package/dist/chunk-UJVEAURM.js +150 -0
- package/dist/chunk-UJVEAURM.js.map +1 -0
- package/dist/{chunk-PVQZBKN7.js → chunk-Z44WASMA.js} +11 -3
- package/dist/chunk-Z44WASMA.js.map +1 -0
- package/dist/{client-DgyzBU_8.d.ts → client-DVoPb3-C.d.ts} +555 -36
- package/dist/client.js +3 -1
- package/dist/codemode/ai.d.ts +25 -0
- package/dist/codemode/ai.js +5112 -0
- package/dist/codemode/ai.js.map +1 -0
- package/dist/index.d.ts +48 -38
- package/dist/index.js +8 -4
- package/dist/mcp/client.d.ts +2 -1
- package/dist/mcp/client.js +2 -1
- package/dist/mcp/do-oauth-client-provider.d.ts +1 -0
- package/dist/mcp/do-oauth-client-provider.js +2 -1
- package/dist/mcp/index.d.ts +50 -83
- package/dist/mcp/index.js +904 -760
- package/dist/mcp/index.js.map +1 -1
- package/dist/mcp/x402.d.ts +39 -0
- package/dist/mcp/x402.js +3195 -0
- package/dist/mcp/x402.js.map +1 -0
- package/dist/mcp-BH1fJeiU.d.ts +58 -0
- package/dist/observability/index.d.ts +12 -24
- package/dist/observability/index.js +6 -4
- package/dist/react.d.ts +11 -6
- package/dist/react.js +107 -7
- package/dist/react.js.map +1 -1
- package/dist/schedule.d.ts +76 -2
- package/dist/schedule.js +17 -2
- package/dist/schedule.js.map +1 -1
- package/dist/secp256k1-M22GZP2U.js +2193 -0
- package/dist/secp256k1-M22GZP2U.js.map +1 -0
- package/package.json +27 -7
- package/src/index.ts +237 -126
- package/dist/chunk-CV3L6FQZ.js.map +0 -1
- package/dist/chunk-HY7ZLHJB.js.map +0 -1
- package/dist/chunk-KUH345EY.js.map +0 -1
- package/dist/chunk-PVQZBKN7.js.map +0 -1
package/dist/ai-chat-agent.js
CHANGED
|
@@ -1,12 +1,21 @@
|
|
|
1
|
+
import {
|
|
2
|
+
autoTransformMessages
|
|
3
|
+
} from "./chunk-UJVEAURM.js";
|
|
1
4
|
import {
|
|
2
5
|
Agent
|
|
3
|
-
} from "./chunk-
|
|
4
|
-
import "./chunk-
|
|
5
|
-
import "./chunk-
|
|
6
|
-
import "./chunk-
|
|
6
|
+
} from "./chunk-254F4GDT.js";
|
|
7
|
+
import "./chunk-3OT2NNEW.js";
|
|
8
|
+
import "./chunk-Z44WASMA.js";
|
|
9
|
+
import "./chunk-QEVM4BVL.js";
|
|
10
|
+
import "./chunk-BER7KXUJ.js";
|
|
11
|
+
import "./chunk-PR4QN5HX.js";
|
|
7
12
|
|
|
8
13
|
// src/ai-chat-agent.ts
|
|
9
|
-
import {
|
|
14
|
+
import {
|
|
15
|
+
getToolName,
|
|
16
|
+
isToolUIPart,
|
|
17
|
+
parsePartialJson
|
|
18
|
+
} from "ai";
|
|
10
19
|
var decoder = new TextDecoder();
|
|
11
20
|
var AIChatAgent = class extends Agent {
|
|
12
21
|
constructor(ctx, env) {
|
|
@@ -16,9 +25,10 @@ var AIChatAgent = class extends Agent {
|
|
|
16
25
|
message text not null,
|
|
17
26
|
created_at datetime default current_timestamp
|
|
18
27
|
)`;
|
|
19
|
-
|
|
28
|
+
const rawMessages = (this.sql`select * from cf_ai_chat_agent_messages` || []).map((row) => {
|
|
20
29
|
return JSON.parse(row.message);
|
|
21
30
|
});
|
|
31
|
+
this.messages = autoTransformMessages(rawMessages);
|
|
22
32
|
this._chatMessageAbortControllers = /* @__PURE__ */ new Map();
|
|
23
33
|
}
|
|
24
34
|
_broadcastChatMessage(message, exclude) {
|
|
@@ -32,7 +42,7 @@ var AIChatAgent = class extends Agent {
|
|
|
32
42
|
} catch (_error) {
|
|
33
43
|
return;
|
|
34
44
|
}
|
|
35
|
-
if (data.type === "cf_agent_use_chat_request" && data.init.method === "POST") {
|
|
45
|
+
if (data.type === "cf_agent_use_chat_request" /* CF_AGENT_USE_CHAT_REQUEST */ && data.init.method === "POST") {
|
|
36
46
|
const {
|
|
37
47
|
// method,
|
|
38
48
|
// keepalive,
|
|
@@ -45,14 +55,15 @@ var AIChatAgent = class extends Agent {
|
|
|
45
55
|
// duplex
|
|
46
56
|
} = data.init;
|
|
47
57
|
const { messages } = JSON.parse(body);
|
|
58
|
+
const transformedMessages = autoTransformMessages(messages);
|
|
48
59
|
this._broadcastChatMessage(
|
|
49
60
|
{
|
|
50
|
-
messages,
|
|
51
|
-
type: "cf_agent_chat_messages"
|
|
61
|
+
messages: transformedMessages,
|
|
62
|
+
type: "cf_agent_chat_messages" /* CF_AGENT_CHAT_MESSAGES */
|
|
52
63
|
},
|
|
53
64
|
[connection.id]
|
|
54
65
|
);
|
|
55
|
-
await this.persistMessages(
|
|
66
|
+
await this.persistMessages(transformedMessages, [connection.id]);
|
|
56
67
|
this.observability?.emit(
|
|
57
68
|
{
|
|
58
69
|
displayMessage: "Chat message request",
|
|
@@ -67,12 +78,7 @@ var AIChatAgent = class extends Agent {
|
|
|
67
78
|
const abortSignal = this._getAbortSignal(chatMessageId);
|
|
68
79
|
return this._tryCatchChat(async () => {
|
|
69
80
|
const response = await this.onChatMessage(
|
|
70
|
-
async (
|
|
71
|
-
const finalMessages = appendResponseMessages({
|
|
72
|
-
messages,
|
|
73
|
-
responseMessages: response2.messages
|
|
74
|
-
});
|
|
75
|
-
await this.persistMessages(finalMessages, [connection.id]);
|
|
81
|
+
async (_finishResult) => {
|
|
76
82
|
this._removeAbortController(chatMessageId);
|
|
77
83
|
this.observability?.emit(
|
|
78
84
|
{
|
|
@@ -98,26 +104,27 @@ var AIChatAgent = class extends Agent {
|
|
|
98
104
|
body: "No response was generated by the agent.",
|
|
99
105
|
done: true,
|
|
100
106
|
id: data.id,
|
|
101
|
-
type: "cf_agent_use_chat_response"
|
|
107
|
+
type: "cf_agent_use_chat_response" /* CF_AGENT_USE_CHAT_RESPONSE */
|
|
102
108
|
},
|
|
103
109
|
[connection.id]
|
|
104
110
|
);
|
|
105
111
|
}
|
|
106
112
|
});
|
|
107
113
|
}
|
|
108
|
-
if (data.type === "cf_agent_chat_clear") {
|
|
114
|
+
if (data.type === "cf_agent_chat_clear" /* CF_AGENT_CHAT_CLEAR */) {
|
|
109
115
|
this._destroyAbortControllers();
|
|
110
116
|
this.sql`delete from cf_ai_chat_agent_messages`;
|
|
111
117
|
this.messages = [];
|
|
112
118
|
this._broadcastChatMessage(
|
|
113
119
|
{
|
|
114
|
-
type: "cf_agent_chat_clear"
|
|
120
|
+
type: "cf_agent_chat_clear" /* CF_AGENT_CHAT_CLEAR */
|
|
115
121
|
},
|
|
116
122
|
[connection.id]
|
|
117
123
|
);
|
|
118
|
-
} else if (data.type === "cf_agent_chat_messages") {
|
|
119
|
-
|
|
120
|
-
|
|
124
|
+
} else if (data.type === "cf_agent_chat_messages" /* CF_AGENT_CHAT_MESSAGES */) {
|
|
125
|
+
const transformedMessages = autoTransformMessages(data.messages);
|
|
126
|
+
await this.persistMessages(transformedMessages, [connection.id]);
|
|
127
|
+
} else if (data.type === "cf_agent_chat_request_cancel" /* CF_AGENT_CHAT_REQUEST_CANCEL */) {
|
|
121
128
|
this._cancelChatRequest(data.id);
|
|
122
129
|
}
|
|
123
130
|
}
|
|
@@ -153,24 +160,11 @@ var AIChatAgent = class extends Agent {
|
|
|
153
160
|
);
|
|
154
161
|
}
|
|
155
162
|
/**
|
|
156
|
-
* Save messages on the server side
|
|
163
|
+
* Save messages on the server side
|
|
157
164
|
* @param messages Chat messages to save
|
|
158
165
|
*/
|
|
159
166
|
async saveMessages(messages) {
|
|
160
167
|
await this.persistMessages(messages);
|
|
161
|
-
const response = await this.onChatMessage(async ({ response: response2 }) => {
|
|
162
|
-
const finalMessages = appendResponseMessages({
|
|
163
|
-
messages,
|
|
164
|
-
responseMessages: response2.messages
|
|
165
|
-
});
|
|
166
|
-
await this.persistMessages(finalMessages, []);
|
|
167
|
-
});
|
|
168
|
-
if (response) {
|
|
169
|
-
for await (const chunk of response.body) {
|
|
170
|
-
decoder.decode(chunk);
|
|
171
|
-
}
|
|
172
|
-
response.body?.cancel();
|
|
173
|
-
}
|
|
174
168
|
}
|
|
175
169
|
async persistMessages(messages, excludeBroadcastIds = []) {
|
|
176
170
|
this.sql`delete from cf_ai_chat_agent_messages`;
|
|
@@ -181,28 +175,428 @@ var AIChatAgent = class extends Agent {
|
|
|
181
175
|
this._broadcastChatMessage(
|
|
182
176
|
{
|
|
183
177
|
messages,
|
|
184
|
-
type: "cf_agent_chat_messages"
|
|
178
|
+
type: "cf_agent_chat_messages" /* CF_AGENT_CHAT_MESSAGES */
|
|
185
179
|
},
|
|
186
180
|
excludeBroadcastIds
|
|
187
181
|
);
|
|
188
182
|
}
|
|
189
183
|
async _reply(id, response) {
|
|
190
184
|
return this._tryCatchChat(async () => {
|
|
191
|
-
|
|
192
|
-
const body = decoder.decode(chunk);
|
|
185
|
+
if (!response.body) {
|
|
193
186
|
this._broadcastChatMessage({
|
|
194
|
-
body,
|
|
195
|
-
done:
|
|
187
|
+
body: "",
|
|
188
|
+
done: true,
|
|
196
189
|
id,
|
|
197
|
-
type: "cf_agent_use_chat_response"
|
|
190
|
+
type: "cf_agent_use_chat_response" /* CF_AGENT_USE_CHAT_RESPONSE */
|
|
198
191
|
});
|
|
192
|
+
return;
|
|
193
|
+
}
|
|
194
|
+
const reader = response.body.getReader();
|
|
195
|
+
const message = {
|
|
196
|
+
id: `assistant_${Date.now()}_${Math.random().toString(36).slice(2, 11)}`,
|
|
197
|
+
// default
|
|
198
|
+
role: "assistant",
|
|
199
|
+
parts: []
|
|
200
|
+
};
|
|
201
|
+
let activeTextParts = {};
|
|
202
|
+
let activeReasoningParts = {};
|
|
203
|
+
const partialToolCalls = {};
|
|
204
|
+
function updateDynamicToolPart(options) {
|
|
205
|
+
const part = message.parts.find(
|
|
206
|
+
(part2) => part2.type === "dynamic-tool" && part2.toolCallId === options.toolCallId
|
|
207
|
+
);
|
|
208
|
+
const anyOptions = options;
|
|
209
|
+
const anyPart = part;
|
|
210
|
+
if (part != null) {
|
|
211
|
+
part.state = options.state;
|
|
212
|
+
anyPart.toolName = options.toolName;
|
|
213
|
+
anyPart.input = anyOptions.input;
|
|
214
|
+
anyPart.output = anyOptions.output;
|
|
215
|
+
anyPart.errorText = anyOptions.errorText;
|
|
216
|
+
anyPart.rawInput = anyOptions.rawInput ?? anyPart.rawInput;
|
|
217
|
+
anyPart.preliminary = anyOptions.preliminary;
|
|
218
|
+
if (anyOptions.providerMetadata != null && part.state === "input-available") {
|
|
219
|
+
part.callProviderMetadata = anyOptions.providerMetadata;
|
|
220
|
+
}
|
|
221
|
+
} else {
|
|
222
|
+
message.parts.push({
|
|
223
|
+
type: "dynamic-tool",
|
|
224
|
+
toolName: options.toolName,
|
|
225
|
+
toolCallId: options.toolCallId,
|
|
226
|
+
state: options.state,
|
|
227
|
+
input: anyOptions.input,
|
|
228
|
+
output: anyOptions.output,
|
|
229
|
+
errorText: anyOptions.errorText,
|
|
230
|
+
preliminary: anyOptions.preliminary,
|
|
231
|
+
...anyOptions.providerMetadata != null ? { callProviderMetadata: anyOptions.providerMetadata } : {}
|
|
232
|
+
});
|
|
233
|
+
}
|
|
234
|
+
}
|
|
235
|
+
function updateToolPart(options) {
|
|
236
|
+
const part = message.parts.find(
|
|
237
|
+
(part2) => isToolUIPart(part2) && part2.toolCallId === options.toolCallId
|
|
238
|
+
);
|
|
239
|
+
const anyOptions = options;
|
|
240
|
+
const anyPart = part;
|
|
241
|
+
if (part != null) {
|
|
242
|
+
part.state = options.state;
|
|
243
|
+
anyPart.input = anyOptions.input;
|
|
244
|
+
anyPart.output = anyOptions.output;
|
|
245
|
+
anyPart.errorText = anyOptions.errorText;
|
|
246
|
+
anyPart.rawInput = anyOptions.rawInput;
|
|
247
|
+
anyPart.preliminary = anyOptions.preliminary;
|
|
248
|
+
anyPart.providerExecuted = anyOptions.providerExecuted ?? part.providerExecuted;
|
|
249
|
+
if (anyOptions.providerMetadata != null && part.state === "input-available") {
|
|
250
|
+
part.callProviderMetadata = anyOptions.providerMetadata;
|
|
251
|
+
}
|
|
252
|
+
} else {
|
|
253
|
+
message.parts.push({
|
|
254
|
+
type: `tool-${options.toolName}`,
|
|
255
|
+
toolCallId: options.toolCallId,
|
|
256
|
+
state: options.state,
|
|
257
|
+
input: anyOptions.input,
|
|
258
|
+
output: anyOptions.output,
|
|
259
|
+
rawInput: anyOptions.rawInput,
|
|
260
|
+
errorText: anyOptions.errorText,
|
|
261
|
+
providerExecuted: anyOptions.providerExecuted,
|
|
262
|
+
preliminary: anyOptions.preliminary,
|
|
263
|
+
...anyOptions.providerMetadata != null ? { callProviderMetadata: anyOptions.providerMetadata } : {}
|
|
264
|
+
});
|
|
265
|
+
}
|
|
266
|
+
}
|
|
267
|
+
async function updateMessageMetadata(metadata) {
|
|
268
|
+
if (metadata != null) {
|
|
269
|
+
const mergedMetadata = message.metadata != null ? { ...message.metadata, ...metadata } : metadata;
|
|
270
|
+
message.metadata = mergedMetadata;
|
|
271
|
+
}
|
|
272
|
+
}
|
|
273
|
+
try {
|
|
274
|
+
while (true) {
|
|
275
|
+
const { done, value } = await reader.read();
|
|
276
|
+
if (done) {
|
|
277
|
+
this._broadcastChatMessage({
|
|
278
|
+
body: "",
|
|
279
|
+
done: true,
|
|
280
|
+
id,
|
|
281
|
+
type: "cf_agent_use_chat_response" /* CF_AGENT_USE_CHAT_RESPONSE */
|
|
282
|
+
});
|
|
283
|
+
break;
|
|
284
|
+
}
|
|
285
|
+
const chunk = decoder.decode(value);
|
|
286
|
+
const contentType = response.headers.get("content-type") || "";
|
|
287
|
+
const isSSE = contentType.includes("text/event-stream");
|
|
288
|
+
if (isSSE) {
|
|
289
|
+
const lines = chunk.split("\n");
|
|
290
|
+
for (const line of lines) {
|
|
291
|
+
if (line.startsWith("data: ") && line !== "data: [DONE]") {
|
|
292
|
+
try {
|
|
293
|
+
const data = JSON.parse(line.slice(6));
|
|
294
|
+
switch (data.type) {
|
|
295
|
+
case "text-start": {
|
|
296
|
+
const textPart = {
|
|
297
|
+
type: "text",
|
|
298
|
+
text: "",
|
|
299
|
+
providerMetadata: data.providerMetadata,
|
|
300
|
+
state: "streaming"
|
|
301
|
+
};
|
|
302
|
+
activeTextParts[data.id] = textPart;
|
|
303
|
+
message.parts.push(textPart);
|
|
304
|
+
break;
|
|
305
|
+
}
|
|
306
|
+
case "text-delta": {
|
|
307
|
+
const textPart = activeTextParts[data.id];
|
|
308
|
+
textPart.text += data.delta;
|
|
309
|
+
textPart.providerMetadata = data.providerMetadata ?? textPart.providerMetadata;
|
|
310
|
+
break;
|
|
311
|
+
}
|
|
312
|
+
case "text-end": {
|
|
313
|
+
const textPart = activeTextParts[data.id];
|
|
314
|
+
textPart.state = "done";
|
|
315
|
+
textPart.providerMetadata = data.providerMetadata ?? textPart.providerMetadata;
|
|
316
|
+
delete activeTextParts[data.id];
|
|
317
|
+
break;
|
|
318
|
+
}
|
|
319
|
+
case "reasoning-start": {
|
|
320
|
+
const reasoningPart = {
|
|
321
|
+
type: "reasoning",
|
|
322
|
+
text: "",
|
|
323
|
+
providerMetadata: data.providerMetadata,
|
|
324
|
+
state: "streaming"
|
|
325
|
+
};
|
|
326
|
+
activeReasoningParts[data.id] = reasoningPart;
|
|
327
|
+
message.parts.push(reasoningPart);
|
|
328
|
+
break;
|
|
329
|
+
}
|
|
330
|
+
case "reasoning-delta": {
|
|
331
|
+
const reasoningPart = activeReasoningParts[data.id];
|
|
332
|
+
reasoningPart.text += data.delta;
|
|
333
|
+
reasoningPart.providerMetadata = data.providerMetadata ?? reasoningPart.providerMetadata;
|
|
334
|
+
break;
|
|
335
|
+
}
|
|
336
|
+
case "reasoning-end": {
|
|
337
|
+
const reasoningPart = activeReasoningParts[data.id];
|
|
338
|
+
reasoningPart.providerMetadata = data.providerMetadata ?? reasoningPart.providerMetadata;
|
|
339
|
+
reasoningPart.state = "done";
|
|
340
|
+
delete activeReasoningParts[data.id];
|
|
341
|
+
break;
|
|
342
|
+
}
|
|
343
|
+
case "file": {
|
|
344
|
+
message.parts.push({
|
|
345
|
+
type: "file",
|
|
346
|
+
mediaType: data.mediaType,
|
|
347
|
+
url: data.url
|
|
348
|
+
});
|
|
349
|
+
break;
|
|
350
|
+
}
|
|
351
|
+
case "source-url": {
|
|
352
|
+
message.parts.push({
|
|
353
|
+
type: "source-url",
|
|
354
|
+
sourceId: data.sourceId,
|
|
355
|
+
url: data.url,
|
|
356
|
+
title: data.title,
|
|
357
|
+
providerMetadata: data.providerMetadata
|
|
358
|
+
});
|
|
359
|
+
break;
|
|
360
|
+
}
|
|
361
|
+
case "source-document": {
|
|
362
|
+
message.parts.push({
|
|
363
|
+
type: "source-document",
|
|
364
|
+
sourceId: data.sourceId,
|
|
365
|
+
mediaType: data.mediaType,
|
|
366
|
+
title: data.title,
|
|
367
|
+
filename: data.filename,
|
|
368
|
+
providerMetadata: data.providerMetadata
|
|
369
|
+
});
|
|
370
|
+
break;
|
|
371
|
+
}
|
|
372
|
+
case "tool-input-start": {
|
|
373
|
+
const toolInvocations = message.parts.filter(isToolUIPart);
|
|
374
|
+
partialToolCalls[data.toolCallId] = {
|
|
375
|
+
text: "",
|
|
376
|
+
toolName: data.toolName,
|
|
377
|
+
index: toolInvocations.length,
|
|
378
|
+
dynamic: data.dynamic
|
|
379
|
+
};
|
|
380
|
+
if (data.dynamic) {
|
|
381
|
+
updateDynamicToolPart({
|
|
382
|
+
toolCallId: data.toolCallId,
|
|
383
|
+
toolName: data.toolName,
|
|
384
|
+
state: "input-streaming",
|
|
385
|
+
input: void 0
|
|
386
|
+
});
|
|
387
|
+
} else {
|
|
388
|
+
updateToolPart({
|
|
389
|
+
toolCallId: data.toolCallId,
|
|
390
|
+
toolName: data.toolName,
|
|
391
|
+
state: "input-streaming",
|
|
392
|
+
input: void 0
|
|
393
|
+
});
|
|
394
|
+
}
|
|
395
|
+
break;
|
|
396
|
+
}
|
|
397
|
+
case "tool-input-delta": {
|
|
398
|
+
const partialToolCall = partialToolCalls[data.toolCallId];
|
|
399
|
+
partialToolCall.text += data.inputTextDelta;
|
|
400
|
+
const { value: partialArgs } = await parsePartialJson(
|
|
401
|
+
partialToolCall.text
|
|
402
|
+
);
|
|
403
|
+
if (partialToolCall.dynamic) {
|
|
404
|
+
updateDynamicToolPart({
|
|
405
|
+
toolCallId: data.toolCallId,
|
|
406
|
+
toolName: partialToolCall.toolName,
|
|
407
|
+
state: "input-streaming",
|
|
408
|
+
input: partialArgs
|
|
409
|
+
});
|
|
410
|
+
} else {
|
|
411
|
+
updateToolPart({
|
|
412
|
+
toolCallId: data.toolCallId,
|
|
413
|
+
toolName: partialToolCall.toolName,
|
|
414
|
+
state: "input-streaming",
|
|
415
|
+
input: partialArgs
|
|
416
|
+
});
|
|
417
|
+
}
|
|
418
|
+
break;
|
|
419
|
+
}
|
|
420
|
+
case "tool-input-available": {
|
|
421
|
+
if (data.dynamic) {
|
|
422
|
+
updateDynamicToolPart({
|
|
423
|
+
toolCallId: data.toolCallId,
|
|
424
|
+
toolName: data.toolName,
|
|
425
|
+
state: "input-available",
|
|
426
|
+
input: data.input,
|
|
427
|
+
providerMetadata: data.providerMetadata
|
|
428
|
+
});
|
|
429
|
+
} else {
|
|
430
|
+
updateToolPart({
|
|
431
|
+
toolCallId: data.toolCallId,
|
|
432
|
+
toolName: data.toolName,
|
|
433
|
+
state: "input-available",
|
|
434
|
+
input: data.input,
|
|
435
|
+
providerExecuted: data.providerExecuted,
|
|
436
|
+
providerMetadata: data.providerMetadata
|
|
437
|
+
});
|
|
438
|
+
}
|
|
439
|
+
break;
|
|
440
|
+
}
|
|
441
|
+
case "tool-input-error": {
|
|
442
|
+
if (data.dynamic) {
|
|
443
|
+
updateDynamicToolPart({
|
|
444
|
+
toolCallId: data.toolCallId,
|
|
445
|
+
toolName: data.toolName,
|
|
446
|
+
state: "output-error",
|
|
447
|
+
input: data.input,
|
|
448
|
+
errorText: data.errorText,
|
|
449
|
+
providerMetadata: data.providerMetadata
|
|
450
|
+
});
|
|
451
|
+
} else {
|
|
452
|
+
updateToolPart({
|
|
453
|
+
toolCallId: data.toolCallId,
|
|
454
|
+
toolName: data.toolName,
|
|
455
|
+
state: "output-error",
|
|
456
|
+
input: void 0,
|
|
457
|
+
rawInput: data.input,
|
|
458
|
+
errorText: data.errorText,
|
|
459
|
+
providerExecuted: data.providerExecuted,
|
|
460
|
+
providerMetadata: data.providerMetadata
|
|
461
|
+
});
|
|
462
|
+
}
|
|
463
|
+
break;
|
|
464
|
+
}
|
|
465
|
+
case "tool-output-available": {
|
|
466
|
+
if (data.dynamic) {
|
|
467
|
+
const toolInvocations = message.parts.filter(
|
|
468
|
+
(part) => part.type === "dynamic-tool"
|
|
469
|
+
);
|
|
470
|
+
const toolInvocation = toolInvocations.find(
|
|
471
|
+
(invocation) => invocation.toolCallId === data.toolCallId
|
|
472
|
+
);
|
|
473
|
+
if (!toolInvocation)
|
|
474
|
+
throw new Error("Tool invocation not found");
|
|
475
|
+
updateDynamicToolPart({
|
|
476
|
+
toolCallId: data.toolCallId,
|
|
477
|
+
toolName: toolInvocation.toolName,
|
|
478
|
+
state: "output-available",
|
|
479
|
+
input: toolInvocation.input,
|
|
480
|
+
output: data.output,
|
|
481
|
+
preliminary: data.preliminary
|
|
482
|
+
});
|
|
483
|
+
} else {
|
|
484
|
+
const toolInvocations = message.parts.filter(isToolUIPart);
|
|
485
|
+
const toolInvocation = toolInvocations.find(
|
|
486
|
+
(invocation) => invocation.toolCallId === data.toolCallId
|
|
487
|
+
);
|
|
488
|
+
if (!toolInvocation)
|
|
489
|
+
throw new Error("Tool invocation not found");
|
|
490
|
+
updateToolPart({
|
|
491
|
+
toolCallId: data.toolCallId,
|
|
492
|
+
toolName: getToolName(toolInvocation),
|
|
493
|
+
state: "output-available",
|
|
494
|
+
input: toolInvocation.input,
|
|
495
|
+
output: data.output,
|
|
496
|
+
providerExecuted: data.providerExecuted,
|
|
497
|
+
preliminary: data.preliminary
|
|
498
|
+
});
|
|
499
|
+
}
|
|
500
|
+
break;
|
|
501
|
+
}
|
|
502
|
+
case "tool-output-error": {
|
|
503
|
+
if (data.dynamic) {
|
|
504
|
+
const toolInvocations = message.parts.filter(
|
|
505
|
+
(part) => part.type === "dynamic-tool"
|
|
506
|
+
);
|
|
507
|
+
const toolInvocation = toolInvocations.find(
|
|
508
|
+
(invocation) => invocation.toolCallId === data.toolCallId
|
|
509
|
+
);
|
|
510
|
+
if (!toolInvocation)
|
|
511
|
+
throw new Error("Tool invocation not found");
|
|
512
|
+
updateDynamicToolPart({
|
|
513
|
+
toolCallId: data.toolCallId,
|
|
514
|
+
toolName: toolInvocation.toolName,
|
|
515
|
+
state: "output-error",
|
|
516
|
+
input: toolInvocation.input,
|
|
517
|
+
errorText: data.errorText
|
|
518
|
+
});
|
|
519
|
+
} else {
|
|
520
|
+
const toolInvocations = message.parts.filter(isToolUIPart);
|
|
521
|
+
const toolInvocation = toolInvocations.find(
|
|
522
|
+
(invocation) => invocation.toolCallId === data.toolCallId
|
|
523
|
+
);
|
|
524
|
+
if (!toolInvocation)
|
|
525
|
+
throw new Error("Tool invocation not found");
|
|
526
|
+
updateToolPart({
|
|
527
|
+
toolCallId: data.toolCallId,
|
|
528
|
+
toolName: getToolName(toolInvocation),
|
|
529
|
+
state: "output-error",
|
|
530
|
+
input: toolInvocation.input,
|
|
531
|
+
rawInput: "rawInput" in toolInvocation ? toolInvocation.rawInput : void 0,
|
|
532
|
+
errorText: data.errorText
|
|
533
|
+
});
|
|
534
|
+
}
|
|
535
|
+
break;
|
|
536
|
+
}
|
|
537
|
+
case "start-step": {
|
|
538
|
+
message.parts.push({ type: "step-start" });
|
|
539
|
+
break;
|
|
540
|
+
}
|
|
541
|
+
case "finish-step": {
|
|
542
|
+
activeTextParts = {};
|
|
543
|
+
activeReasoningParts = {};
|
|
544
|
+
break;
|
|
545
|
+
}
|
|
546
|
+
case "start": {
|
|
547
|
+
if (data.messageId != null) {
|
|
548
|
+
message.id = data.messageId;
|
|
549
|
+
}
|
|
550
|
+
await updateMessageMetadata(data.messageMetadata);
|
|
551
|
+
break;
|
|
552
|
+
}
|
|
553
|
+
case "finish": {
|
|
554
|
+
await updateMessageMetadata(data.messageMetadata);
|
|
555
|
+
break;
|
|
556
|
+
}
|
|
557
|
+
case "message-metadata": {
|
|
558
|
+
await updateMessageMetadata(data.messageMetadata);
|
|
559
|
+
break;
|
|
560
|
+
}
|
|
561
|
+
case "error": {
|
|
562
|
+
this._broadcastChatMessage({
|
|
563
|
+
error: true,
|
|
564
|
+
body: data.errorText ?? JSON.stringify(data),
|
|
565
|
+
done: false,
|
|
566
|
+
id,
|
|
567
|
+
type: "cf_agent_use_chat_response" /* CF_AGENT_USE_CHAT_RESPONSE */
|
|
568
|
+
});
|
|
569
|
+
break;
|
|
570
|
+
}
|
|
571
|
+
}
|
|
572
|
+
this._broadcastChatMessage({
|
|
573
|
+
body: JSON.stringify(data),
|
|
574
|
+
done: false,
|
|
575
|
+
id,
|
|
576
|
+
type: "cf_agent_use_chat_response" /* CF_AGENT_USE_CHAT_RESPONSE */
|
|
577
|
+
});
|
|
578
|
+
} catch (_e) {
|
|
579
|
+
}
|
|
580
|
+
}
|
|
581
|
+
}
|
|
582
|
+
} else {
|
|
583
|
+
if (chunk.length > 0) {
|
|
584
|
+
message.parts.push({ type: "text", text: chunk });
|
|
585
|
+
this._broadcastChatMessage({
|
|
586
|
+
body: JSON.stringify({ type: "text-delta", delta: chunk }),
|
|
587
|
+
done: false,
|
|
588
|
+
id,
|
|
589
|
+
type: "cf_agent_use_chat_response" /* CF_AGENT_USE_CHAT_RESPONSE */
|
|
590
|
+
});
|
|
591
|
+
}
|
|
592
|
+
}
|
|
593
|
+
}
|
|
594
|
+
} finally {
|
|
595
|
+
reader.releaseLock();
|
|
596
|
+
}
|
|
597
|
+
if (message.parts.length > 0) {
|
|
598
|
+
await this.persistMessages([...this.messages, message]);
|
|
199
599
|
}
|
|
200
|
-
this._broadcastChatMessage({
|
|
201
|
-
body: "",
|
|
202
|
-
done: true,
|
|
203
|
-
id,
|
|
204
|
-
type: "cf_agent_use_chat_response"
|
|
205
|
-
});
|
|
206
600
|
});
|
|
207
601
|
}
|
|
208
602
|
/**
|