agents 0.0.0-ecf8926 → 0.0.0-ed3f94d

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (64) hide show
  1. package/README.md +126 -4
  2. package/dist/_esm-LV5FJ3HK.js +3922 -0
  3. package/dist/_esm-LV5FJ3HK.js.map +1 -0
  4. package/dist/ai-chat-agent.d.ts +2 -1
  5. package/dist/ai-chat-agent.js +391 -76
  6. package/dist/ai-chat-agent.js.map +1 -1
  7. package/dist/ai-chat-v5-migration.js +1 -0
  8. package/dist/ai-react.d.ts +8 -1
  9. package/dist/ai-react.js +157 -111
  10. package/dist/ai-react.js.map +1 -1
  11. package/dist/ai-types.d.ts +1 -0
  12. package/dist/ai-types.js +2 -1
  13. package/dist/ccip-CMBYN64O.js +15 -0
  14. package/dist/ccip-CMBYN64O.js.map +1 -0
  15. package/dist/{chunk-EGCWEPQL.js → chunk-254F4GDT.js} +151 -98
  16. package/dist/chunk-254F4GDT.js.map +1 -0
  17. package/dist/{chunk-DS7BJNPH.js → chunk-3OT2NNEW.js} +411 -68
  18. package/dist/chunk-3OT2NNEW.js.map +1 -0
  19. package/dist/chunk-5Y6BEZDY.js +276 -0
  20. package/dist/chunk-5Y6BEZDY.js.map +1 -0
  21. package/dist/{chunk-AVYJQSLW.js → chunk-BER7KXUJ.js} +2 -1
  22. package/dist/chunk-BER7KXUJ.js.map +1 -0
  23. package/dist/chunk-JJBFIGUC.js +5202 -0
  24. package/dist/chunk-JJBFIGUC.js.map +1 -0
  25. package/dist/chunk-PR4QN5HX.js +43 -0
  26. package/dist/chunk-PR4QN5HX.js.map +1 -0
  27. package/dist/chunk-TYAY6AU6.js +159 -0
  28. package/dist/chunk-TYAY6AU6.js.map +1 -0
  29. package/dist/{chunk-PVQZBKN7.js → chunk-Z44WASMA.js} +11 -3
  30. package/dist/chunk-Z44WASMA.js.map +1 -0
  31. package/dist/{client-BAqDHqAV.d.ts → client-DVoPb3-C.d.ts} +549 -30
  32. package/dist/client.js +2 -1
  33. package/dist/codemode/ai.d.ts +25 -0
  34. package/dist/codemode/ai.js +5112 -0
  35. package/dist/codemode/ai.js.map +1 -0
  36. package/dist/index.d.ts +44 -35
  37. package/dist/index.js +7 -4
  38. package/dist/mcp/client.d.ts +2 -1
  39. package/dist/mcp/client.js +2 -1
  40. package/dist/mcp/do-oauth-client-provider.d.ts +1 -0
  41. package/dist/mcp/do-oauth-client-provider.js +2 -1
  42. package/dist/mcp/index.d.ts +50 -83
  43. package/dist/mcp/index.js +903 -760
  44. package/dist/mcp/index.js.map +1 -1
  45. package/dist/mcp/x402.d.ts +39 -0
  46. package/dist/mcp/x402.js +3195 -0
  47. package/dist/mcp/x402.js.map +1 -0
  48. package/dist/mcp-BH1fJeiU.d.ts +58 -0
  49. package/dist/observability/index.d.ts +12 -24
  50. package/dist/observability/index.js +5 -4
  51. package/dist/react.d.ts +10 -6
  52. package/dist/react.js +101 -3
  53. package/dist/react.js.map +1 -1
  54. package/dist/schedule.d.ts +76 -2
  55. package/dist/schedule.js +17 -2
  56. package/dist/schedule.js.map +1 -1
  57. package/dist/secp256k1-M22GZP2U.js +2193 -0
  58. package/dist/secp256k1-M22GZP2U.js.map +1 -0
  59. package/package.json +22 -7
  60. package/src/index.ts +226 -116
  61. package/dist/chunk-AVYJQSLW.js.map +0 -1
  62. package/dist/chunk-DS7BJNPH.js.map +0 -1
  63. package/dist/chunk-EGCWEPQL.js.map +0 -1
  64. package/dist/chunk-PVQZBKN7.js.map +0 -1
@@ -3,13 +3,19 @@ import {
3
3
  } from "./chunk-UJVEAURM.js";
4
4
  import {
5
5
  Agent
6
- } from "./chunk-EGCWEPQL.js";
7
- import "./chunk-DS7BJNPH.js";
8
- import "./chunk-PVQZBKN7.js";
6
+ } from "./chunk-254F4GDT.js";
7
+ import "./chunk-3OT2NNEW.js";
8
+ import "./chunk-Z44WASMA.js";
9
9
  import "./chunk-QEVM4BVL.js";
10
- import "./chunk-AVYJQSLW.js";
10
+ import "./chunk-BER7KXUJ.js";
11
+ import "./chunk-PR4QN5HX.js";
11
12
 
12
13
  // src/ai-chat-agent.ts
14
+ import {
15
+ getToolName,
16
+ isToolUIPart,
17
+ parsePartialJson
18
+ } from "ai";
13
19
  var decoder = new TextDecoder();
14
20
  var AIChatAgent = class extends Agent {
15
21
  constructor(ctx, env) {
@@ -186,8 +192,84 @@ var AIChatAgent = class extends Agent {
186
192
  return;
187
193
  }
188
194
  const reader = response.body.getReader();
189
- let fullResponseText = "";
190
- const toolCalls = /* @__PURE__ */ new Map();
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
+ }
191
273
  try {
192
274
  while (true) {
193
275
  const { done, value } = await reader.read();
@@ -201,86 +283,319 @@ var AIChatAgent = class extends Agent {
201
283
  break;
202
284
  }
203
285
  const chunk = decoder.decode(value);
204
- const lines = chunk.split("\n");
205
- for (const line of lines) {
206
- if (line.startsWith("data: ") && line !== "data: [DONE]") {
207
- try {
208
- const data = JSON.parse(line.slice(6));
209
- switch (data.type) {
210
- // SSE event signaling the tool input is ready. We track by
211
- // `toolCallId` so we can persist it as a tool part in the message.
212
- case "tool-input-available": {
213
- const { toolCallId, toolName, input } = data;
214
- toolCalls.set(toolCallId, {
215
- toolCallId,
216
- toolName,
217
- input,
218
- type: toolName ? `tool-${toolName}` : "dynamic-tool",
219
- state: "input-available"
220
- });
221
- break;
222
- }
223
- // SSE event signaling the tool output is ready. We should've
224
- // already received the input in a previous event so an entry
225
- // with `toolCallId` should already be present
226
- case "tool-output-available": {
227
- const { toolCallId, output, isError, errorText } = data;
228
- const toolPart = toolCalls.get(toolCallId);
229
- if (toolPart)
230
- toolCalls.set(toolCallId, {
231
- ...toolPart,
232
- output,
233
- isError,
234
- errorText,
235
- state: "output-available"
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
236
348
  });
237
- break;
238
- }
239
- case "error": {
240
- this._broadcastChatMessage({
241
- error: true,
242
- body: data.errorText ?? JSON.stringify(data),
243
- done: false,
244
- id,
245
- type: "cf_agent_use_chat_response" /* CF_AGENT_USE_CHAT_RESPONSE */
246
- });
247
- return;
248
- }
249
- case "text-delta": {
250
- if (data.delta) fullResponseText += data.delta;
251
- break;
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
+ }
252
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) {
253
579
  }
254
- this._broadcastChatMessage({
255
- body: JSON.stringify(data),
256
- done: false,
257
- id,
258
- type: "cf_agent_use_chat_response" /* CF_AGENT_USE_CHAT_RESPONSE */
259
- });
260
- } catch (_e) {
261
580
  }
262
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
+ }
263
592
  }
264
593
  }
265
594
  } finally {
266
595
  reader.releaseLock();
267
596
  }
268
- const messageParts = [];
269
- Array.from(toolCalls.values()).forEach((t) => {
270
- messageParts.push(t);
271
- });
272
- if (fullResponseText.trim()) {
273
- messageParts.push({ type: "text", text: fullResponseText });
274
- }
275
- if (messageParts.length > 0) {
276
- await this.persistMessages([
277
- ...this.messages,
278
- {
279
- id: `assistant_${Date.now()}_${Math.random().toString(36).slice(2, 11)}`,
280
- role: "assistant",
281
- parts: messageParts
282
- }
283
- ]);
597
+ if (message.parts.length > 0) {
598
+ await this.persistMessages([...this.messages, message]);
284
599
  }
285
600
  });
286
601
  }