@librechat/agents 3.1.73 → 3.1.75-dev.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (159) hide show
  1. package/README.md +66 -0
  2. package/dist/cjs/agents/AgentContext.cjs +146 -57
  3. package/dist/cjs/agents/AgentContext.cjs.map +1 -1
  4. package/dist/cjs/graphs/Graph.cjs +13 -3
  5. package/dist/cjs/graphs/Graph.cjs.map +1 -1
  6. package/dist/cjs/llm/anthropic/index.cjs +145 -52
  7. package/dist/cjs/llm/anthropic/index.cjs.map +1 -1
  8. package/dist/cjs/llm/anthropic/types.cjs.map +1 -1
  9. package/dist/cjs/llm/anthropic/utils/message_inputs.cjs +25 -15
  10. package/dist/cjs/llm/anthropic/utils/message_inputs.cjs.map +1 -1
  11. package/dist/cjs/llm/anthropic/utils/message_outputs.cjs +84 -70
  12. package/dist/cjs/llm/anthropic/utils/message_outputs.cjs.map +1 -1
  13. package/dist/cjs/llm/bedrock/index.cjs +1 -1
  14. package/dist/cjs/llm/bedrock/index.cjs.map +1 -1
  15. package/dist/cjs/llm/bedrock/utils/message_inputs.cjs +213 -3
  16. package/dist/cjs/llm/bedrock/utils/message_inputs.cjs.map +1 -1
  17. package/dist/cjs/llm/bedrock/utils/message_outputs.cjs +2 -1
  18. package/dist/cjs/llm/bedrock/utils/message_outputs.cjs.map +1 -1
  19. package/dist/cjs/llm/google/utils/common.cjs +5 -4
  20. package/dist/cjs/llm/google/utils/common.cjs.map +1 -1
  21. package/dist/cjs/llm/openai/index.cjs +468 -647
  22. package/dist/cjs/llm/openai/index.cjs.map +1 -1
  23. package/dist/cjs/llm/openai/utils/index.cjs +1 -448
  24. package/dist/cjs/llm/openai/utils/index.cjs.map +1 -1
  25. package/dist/cjs/llm/openrouter/index.cjs +57 -175
  26. package/dist/cjs/llm/openrouter/index.cjs.map +1 -1
  27. package/dist/cjs/llm/vertexai/index.cjs +5 -3
  28. package/dist/cjs/llm/vertexai/index.cjs.map +1 -1
  29. package/dist/cjs/main.cjs +1 -0
  30. package/dist/cjs/main.cjs.map +1 -1
  31. package/dist/cjs/messages/cache.cjs +39 -4
  32. package/dist/cjs/messages/cache.cjs.map +1 -1
  33. package/dist/cjs/messages/core.cjs +7 -6
  34. package/dist/cjs/messages/core.cjs.map +1 -1
  35. package/dist/cjs/messages/format.cjs +7 -6
  36. package/dist/cjs/messages/format.cjs.map +1 -1
  37. package/dist/cjs/messages/langchain.cjs +26 -0
  38. package/dist/cjs/messages/langchain.cjs.map +1 -0
  39. package/dist/cjs/messages/prune.cjs +7 -6
  40. package/dist/cjs/messages/prune.cjs.map +1 -1
  41. package/dist/cjs/tools/BashExecutor.cjs +21 -11
  42. package/dist/cjs/tools/BashExecutor.cjs.map +1 -1
  43. package/dist/cjs/tools/CodeExecutor.cjs +37 -10
  44. package/dist/cjs/tools/CodeExecutor.cjs.map +1 -1
  45. package/dist/cjs/tools/ProgrammaticToolCalling.cjs +16 -11
  46. package/dist/cjs/tools/ProgrammaticToolCalling.cjs.map +1 -1
  47. package/dist/cjs/tools/ToolNode.cjs +5 -1
  48. package/dist/cjs/tools/ToolNode.cjs.map +1 -1
  49. package/dist/esm/agents/AgentContext.mjs +147 -58
  50. package/dist/esm/agents/AgentContext.mjs.map +1 -1
  51. package/dist/esm/graphs/Graph.mjs +13 -3
  52. package/dist/esm/graphs/Graph.mjs.map +1 -1
  53. package/dist/esm/llm/anthropic/index.mjs +146 -54
  54. package/dist/esm/llm/anthropic/index.mjs.map +1 -1
  55. package/dist/esm/llm/anthropic/types.mjs.map +1 -1
  56. package/dist/esm/llm/anthropic/utils/message_inputs.mjs +25 -15
  57. package/dist/esm/llm/anthropic/utils/message_inputs.mjs.map +1 -1
  58. package/dist/esm/llm/anthropic/utils/message_outputs.mjs +84 -71
  59. package/dist/esm/llm/anthropic/utils/message_outputs.mjs.map +1 -1
  60. package/dist/esm/llm/bedrock/index.mjs +1 -1
  61. package/dist/esm/llm/bedrock/index.mjs.map +1 -1
  62. package/dist/esm/llm/bedrock/utils/message_inputs.mjs +214 -4
  63. package/dist/esm/llm/bedrock/utils/message_inputs.mjs.map +1 -1
  64. package/dist/esm/llm/bedrock/utils/message_outputs.mjs +2 -1
  65. package/dist/esm/llm/bedrock/utils/message_outputs.mjs.map +1 -1
  66. package/dist/esm/llm/google/utils/common.mjs +5 -4
  67. package/dist/esm/llm/google/utils/common.mjs.map +1 -1
  68. package/dist/esm/llm/openai/index.mjs +469 -648
  69. package/dist/esm/llm/openai/index.mjs.map +1 -1
  70. package/dist/esm/llm/openai/utils/index.mjs +4 -449
  71. package/dist/esm/llm/openai/utils/index.mjs.map +1 -1
  72. package/dist/esm/llm/openrouter/index.mjs +57 -175
  73. package/dist/esm/llm/openrouter/index.mjs.map +1 -1
  74. package/dist/esm/llm/vertexai/index.mjs +5 -3
  75. package/dist/esm/llm/vertexai/index.mjs.map +1 -1
  76. package/dist/esm/main.mjs +1 -1
  77. package/dist/esm/messages/cache.mjs +39 -4
  78. package/dist/esm/messages/cache.mjs.map +1 -1
  79. package/dist/esm/messages/core.mjs +7 -6
  80. package/dist/esm/messages/core.mjs.map +1 -1
  81. package/dist/esm/messages/format.mjs +7 -6
  82. package/dist/esm/messages/format.mjs.map +1 -1
  83. package/dist/esm/messages/langchain.mjs +23 -0
  84. package/dist/esm/messages/langchain.mjs.map +1 -0
  85. package/dist/esm/messages/prune.mjs +7 -6
  86. package/dist/esm/messages/prune.mjs.map +1 -1
  87. package/dist/esm/tools/BashExecutor.mjs +22 -12
  88. package/dist/esm/tools/BashExecutor.mjs.map +1 -1
  89. package/dist/esm/tools/CodeExecutor.mjs +37 -11
  90. package/dist/esm/tools/CodeExecutor.mjs.map +1 -1
  91. package/dist/esm/tools/ProgrammaticToolCalling.mjs +17 -12
  92. package/dist/esm/tools/ProgrammaticToolCalling.mjs.map +1 -1
  93. package/dist/esm/tools/ToolNode.mjs +5 -1
  94. package/dist/esm/tools/ToolNode.mjs.map +1 -1
  95. package/dist/types/agents/AgentContext.d.ts +29 -4
  96. package/dist/types/agents/__tests__/promptCacheLiveHelpers.d.ts +46 -0
  97. package/dist/types/llm/anthropic/index.d.ts +22 -9
  98. package/dist/types/llm/anthropic/types.d.ts +5 -1
  99. package/dist/types/llm/anthropic/utils/message_outputs.d.ts +13 -6
  100. package/dist/types/llm/anthropic/utils/output_parsers.d.ts +1 -1
  101. package/dist/types/llm/openai/index.d.ts +21 -24
  102. package/dist/types/llm/openrouter/index.d.ts +11 -9
  103. package/dist/types/llm/vertexai/index.d.ts +1 -0
  104. package/dist/types/messages/cache.d.ts +4 -1
  105. package/dist/types/messages/langchain.d.ts +27 -0
  106. package/dist/types/tools/CodeExecutor.d.ts +6 -0
  107. package/dist/types/types/graph.d.ts +26 -38
  108. package/dist/types/types/llm.d.ts +3 -3
  109. package/dist/types/types/run.d.ts +2 -0
  110. package/dist/types/types/stream.d.ts +1 -1
  111. package/dist/types/types/tools.d.ts +9 -0
  112. package/package.json +17 -16
  113. package/src/agents/AgentContext.ts +189 -71
  114. package/src/agents/__tests__/AgentContext.anthropic.live.test.ts +116 -0
  115. package/src/agents/__tests__/AgentContext.bedrock.live.test.ts +149 -0
  116. package/src/agents/__tests__/AgentContext.test.ts +333 -2
  117. package/src/agents/__tests__/promptCacheLiveHelpers.ts +165 -0
  118. package/src/graphs/Graph.ts +24 -4
  119. package/src/graphs/__tests__/composition.smoke.test.ts +188 -0
  120. package/src/llm/anthropic/index.ts +252 -84
  121. package/src/llm/anthropic/llm.spec.ts +751 -102
  122. package/src/llm/anthropic/types.ts +9 -1
  123. package/src/llm/anthropic/utils/message_inputs.ts +43 -20
  124. package/src/llm/anthropic/utils/message_outputs.ts +119 -101
  125. package/src/llm/anthropic/utils/server-tool-inputs.test.ts +77 -0
  126. package/src/llm/bedrock/index.ts +2 -2
  127. package/src/llm/bedrock/llm.spec.ts +341 -0
  128. package/src/llm/bedrock/utils/message_inputs.ts +303 -4
  129. package/src/llm/bedrock/utils/message_outputs.ts +2 -1
  130. package/src/llm/custom-chat-models.smoke.test.ts +662 -0
  131. package/src/llm/google/llm.spec.ts +339 -57
  132. package/src/llm/google/utils/common.ts +53 -48
  133. package/src/llm/openai/contentBlocks.test.ts +346 -0
  134. package/src/llm/openai/index.ts +736 -837
  135. package/src/llm/openai/utils/index.ts +84 -64
  136. package/src/llm/openrouter/index.ts +124 -247
  137. package/src/llm/openrouter/reasoning.test.ts +8 -1
  138. package/src/llm/vertexai/index.ts +11 -5
  139. package/src/llm/vertexai/llm.spec.ts +28 -1
  140. package/src/messages/cache.test.ts +106 -4
  141. package/src/messages/cache.ts +57 -5
  142. package/src/messages/core.ts +16 -9
  143. package/src/messages/format.ts +9 -6
  144. package/src/messages/langchain.ts +39 -0
  145. package/src/messages/prune.ts +12 -8
  146. package/src/scripts/caching.ts +2 -3
  147. package/src/specs/anthropic.simple.test.ts +61 -0
  148. package/src/specs/summarization.test.ts +58 -61
  149. package/src/tools/BashExecutor.ts +37 -13
  150. package/src/tools/CodeExecutor.ts +55 -11
  151. package/src/tools/ProgrammaticToolCalling.ts +29 -14
  152. package/src/tools/ToolNode.ts +5 -1
  153. package/src/tools/__tests__/ProgrammaticToolCalling.test.ts +60 -0
  154. package/src/types/graph.ts +35 -88
  155. package/src/types/llm.ts +3 -3
  156. package/src/types/run.ts +2 -0
  157. package/src/types/stream.ts +1 -1
  158. package/src/types/tools.ts +9 -0
  159. package/src/utils/llmConfig.ts +1 -6
@@ -1,7 +1,7 @@
1
1
  'use strict';
2
2
 
3
3
  var messages = require('@langchain/core/messages');
4
- var outputs = require('@langchain/core/outputs');
4
+ require('@langchain/core/outputs');
5
5
  var openai_tools = require('@langchain/core/output_parsers/openai_tools');
6
6
 
7
7
  function extractGenericMessageCustomRole(message) {
@@ -308,458 +308,11 @@ function _convertMessagesToOpenAIParams(messages$1, model, options) {
308
308
  return completionParam;
309
309
  });
310
310
  }
311
- const _FUNCTION_CALL_IDS_MAP_KEY = '__openai_function_call_ids__';
312
- function _convertReasoningSummaryToOpenAIResponsesParams(reasoning) {
313
- // combine summary parts that have the the same index and then remove the indexes
314
- const summary = (reasoning.summary.length > 1
315
- ? reasoning.summary.reduce((acc, curr) => {
316
- const last = acc.at(-1);
317
- if (last.index === curr.index) {
318
- last.text += curr.text;
319
- }
320
- else {
321
- acc.push(curr);
322
- }
323
- return acc;
324
- }, [{ ...reasoning.summary[0] }])
325
- : reasoning.summary).map((s) => Object.fromEntries(Object.entries(s).filter(([k]) => k !== 'index')));
326
- return {
327
- ...reasoning,
328
- summary,
329
- };
330
- }
331
- function _convertMessagesToOpenAIResponsesParams(messages$1, model, zdrEnabled) {
332
- return messages$1.flatMap((lcMsg) => {
333
- const additional_kwargs = lcMsg.additional_kwargs;
334
- let role = messageToOpenAIRole(lcMsg);
335
- if (role === 'system' && isReasoningModel(model))
336
- role = 'developer';
337
- if (role === 'function') {
338
- throw new Error('Function messages are not supported in Responses API');
339
- }
340
- if (role === 'tool') {
341
- const toolMessage = lcMsg;
342
- // Handle computer call output
343
- if (additional_kwargs.type === 'computer_call_output') {
344
- const output = (() => {
345
- if (typeof toolMessage.content === 'string') {
346
- return {
347
- type: 'computer_screenshot',
348
- image_url: toolMessage.content,
349
- };
350
- }
351
- if (Array.isArray(toolMessage.content)) {
352
- const oaiScreenshot = toolMessage.content.find((i) => i.type === 'computer_screenshot');
353
- if (oaiScreenshot)
354
- return oaiScreenshot;
355
- const lcImage = toolMessage.content.find((i) => i.type === 'image_url');
356
- if (lcImage) {
357
- return {
358
- type: 'computer_screenshot',
359
- image_url: typeof lcImage.image_url === 'string'
360
- ? lcImage.image_url
361
- : lcImage.image_url.url,
362
- };
363
- }
364
- }
365
- throw new Error('Invalid computer call output');
366
- })();
367
- return {
368
- type: 'computer_call_output',
369
- output,
370
- call_id: toolMessage.tool_call_id,
371
- };
372
- }
373
- return {
374
- type: 'function_call_output',
375
- call_id: toolMessage.tool_call_id,
376
- id: toolMessage.id?.startsWith('fc_') ? toolMessage.id : undefined,
377
- output: typeof toolMessage.content !== 'string'
378
- ? JSON.stringify(toolMessage.content)
379
- : toolMessage.content,
380
- };
381
- }
382
- if (role === 'assistant') {
383
- // if we have the original response items, just reuse them
384
- if (!zdrEnabled &&
385
- lcMsg.response_metadata.output != null &&
386
- Array.isArray(lcMsg.response_metadata.output) &&
387
- lcMsg.response_metadata.output.length > 0 &&
388
- lcMsg.response_metadata.output.every((item) => 'type' in item)) {
389
- return lcMsg.response_metadata.output;
390
- }
391
- // otherwise, try to reconstruct the response from what we have
392
- const input = [];
393
- // reasoning items
394
- if (additional_kwargs.reasoning && !zdrEnabled) {
395
- const reasoningItem = _convertReasoningSummaryToOpenAIResponsesParams(additional_kwargs.reasoning);
396
- input.push(reasoningItem);
397
- }
398
- // ai content
399
- let { content } = lcMsg;
400
- if (additional_kwargs.refusal) {
401
- if (typeof content === 'string') {
402
- content = [{ type: 'output_text', text: content, annotations: [] }];
403
- }
404
- content = [
405
- ...content,
406
- { type: 'refusal', refusal: additional_kwargs.refusal },
407
- ];
408
- }
409
- input.push({
410
- type: 'message',
411
- role: 'assistant',
412
- ...(lcMsg.id && !zdrEnabled && lcMsg.id.startsWith('msg_')
413
- ? { id: lcMsg.id }
414
- : {}),
415
- content: typeof content === 'string'
416
- ? content
417
- : content.flatMap((item) => {
418
- if (item.type === 'text') {
419
- return {
420
- type: 'output_text',
421
- text: item.text,
422
- // @ts-expect-error TODO: add types for `annotations`
423
- annotations: item.annotations ?? [],
424
- };
425
- }
426
- if (item.type === 'output_text' || item.type === 'refusal') {
427
- return item;
428
- }
429
- return [];
430
- }),
431
- });
432
- const functionCallIds = additional_kwargs[_FUNCTION_CALL_IDS_MAP_KEY];
433
- if (messages.isAIMessage(lcMsg) && !!lcMsg.tool_calls?.length) {
434
- input.push(...lcMsg.tool_calls.map((toolCall) => ({
435
- type: 'function_call',
436
- name: toolCall.name,
437
- arguments: JSON.stringify(toolCall.args),
438
- call_id: toolCall.id,
439
- ...(zdrEnabled ? { id: functionCallIds?.[toolCall.id] } : {}),
440
- })));
441
- }
442
- else if (additional_kwargs.tool_calls) {
443
- input.push(...additional_kwargs.tool_calls.map((toolCall) => ({
444
- type: 'function_call',
445
- name: toolCall.function.name,
446
- call_id: toolCall.id,
447
- arguments: toolCall.function.arguments,
448
- ...(zdrEnabled ? { id: functionCallIds?.[toolCall.id] } : {}),
449
- })));
450
- }
451
- const toolOutputs = (lcMsg.response_metadata.output?.length ?? 0) > 0
452
- ? lcMsg.response_metadata.output
453
- : additional_kwargs.tool_outputs;
454
- const fallthroughCallTypes = [
455
- 'computer_call',
456
- /** @ts-ignore */
457
- 'mcp_call',
458
- /** @ts-ignore */
459
- 'code_interpreter_call',
460
- /** @ts-ignore */
461
- 'image_generation_call',
462
- ];
463
- if (toolOutputs != null) {
464
- const castToolOutputs = toolOutputs;
465
- const fallthroughCalls = castToolOutputs.filter((item) => fallthroughCallTypes.includes(item.type));
466
- if (fallthroughCalls.length > 0)
467
- input.push(...fallthroughCalls);
468
- }
469
- return input;
470
- }
471
- if (role === 'user' || role === 'system' || role === 'developer') {
472
- if (typeof lcMsg.content === 'string') {
473
- return { type: 'message', role, content: lcMsg.content };
474
- }
475
- const messages$1 = [];
476
- const content = lcMsg.content.flatMap((item) => {
477
- if (item.type === 'mcp_approval_response') {
478
- messages$1.push({
479
- // @ts-ignore
480
- type: 'mcp_approval_response',
481
- approval_request_id: item.approval_request_id,
482
- approve: item.approve,
483
- });
484
- }
485
- if (messages.isDataContentBlock(item)) {
486
- return messages.convertToProviderContentBlock(item, completionsApiContentBlockConverter);
487
- }
488
- if (item.type === 'text') {
489
- return {
490
- type: 'input_text',
491
- text: item.text,
492
- };
493
- }
494
- if (item.type === 'image_url') {
495
- return {
496
- type: 'input_image',
497
- image_url: typeof item.image_url === 'string'
498
- ? item.image_url
499
- : item.image_url.url,
500
- detail: typeof item.image_url === 'string'
501
- ? 'auto'
502
- : item.image_url.detail,
503
- };
504
- }
505
- if (item.type === 'input_text' ||
506
- item.type === 'input_image' ||
507
- item.type === 'input_file') {
508
- return item;
509
- }
510
- return [];
511
- });
512
- if (content.length > 0) {
513
- messages$1.push({ type: 'message', role, content });
514
- }
515
- return messages$1;
516
- }
517
- console.warn(`Unsupported role found when converting to OpenAI Responses API: ${role}`);
518
- return [];
519
- });
520
- }
521
311
  function isReasoningModel(model) {
522
312
  return model != null && model !== '' && /\b(o\d|gpt-[5-9])\b/i.test(model);
523
313
  }
524
- function _convertOpenAIResponsesMessageToBaseMessage(response) {
525
- if (response.error) {
526
- // TODO: add support for `addLangChainErrorFields`
527
- const error = new Error(response.error.message);
528
- error.name = response.error.code;
529
- throw error;
530
- }
531
- let messageId;
532
- const content = [];
533
- const tool_calls = [];
534
- const invalid_tool_calls = [];
535
- const response_metadata = {
536
- model: response.model,
537
- created_at: response.created_at,
538
- id: response.id,
539
- incomplete_details: response.incomplete_details,
540
- metadata: response.metadata,
541
- object: response.object,
542
- status: response.status,
543
- user: response.user,
544
- service_tier: response.service_tier,
545
- // for compatibility with chat completion calls.
546
- model_name: response.model,
547
- };
548
- const additional_kwargs = {};
549
- for (const item of response.output) {
550
- if (item.type === 'message') {
551
- messageId = item.id;
552
- content.push(...item.content.flatMap((part) => {
553
- if (part.type === 'output_text') {
554
- if ('parsed' in part && part.parsed != null) {
555
- additional_kwargs.parsed = part.parsed;
556
- }
557
- return {
558
- type: 'text',
559
- text: part.text,
560
- annotations: part.annotations,
561
- };
562
- }
563
- if (part.type === 'refusal') {
564
- additional_kwargs.refusal = part.refusal;
565
- return [];
566
- }
567
- return part;
568
- }));
569
- }
570
- else if (item.type === 'function_call') {
571
- const fnAdapter = {
572
- function: { name: item.name, arguments: item.arguments },
573
- id: item.call_id,
574
- };
575
- try {
576
- tool_calls.push(openai_tools.parseToolCall(fnAdapter, { returnId: true }));
577
- }
578
- catch (e) {
579
- let errMessage;
580
- if (typeof e === 'object' &&
581
- e != null &&
582
- 'message' in e &&
583
- typeof e.message === 'string') {
584
- errMessage = e.message;
585
- }
586
- invalid_tool_calls.push(openai_tools.makeInvalidToolCall(fnAdapter, errMessage));
587
- }
588
- additional_kwargs[_FUNCTION_CALL_IDS_MAP_KEY] ??= {};
589
- if (item.id) {
590
- additional_kwargs[_FUNCTION_CALL_IDS_MAP_KEY][item.call_id] = item.id;
591
- }
592
- }
593
- else if (item.type === 'reasoning') {
594
- additional_kwargs.reasoning = item;
595
- }
596
- else {
597
- additional_kwargs.tool_outputs ??= [];
598
- additional_kwargs.tool_outputs.push(item);
599
- }
600
- }
601
- return new messages.AIMessage({
602
- id: messageId,
603
- content,
604
- tool_calls,
605
- invalid_tool_calls,
606
- usage_metadata: response.usage,
607
- additional_kwargs,
608
- response_metadata,
609
- });
610
- }
611
- function _convertOpenAIResponsesDeltaToBaseMessageChunk(chunk) {
612
- const content = [];
613
- let generationInfo = {};
614
- let usage_metadata;
615
- const tool_call_chunks = [];
616
- const response_metadata = {};
617
- const additional_kwargs = {};
618
- let id;
619
- if (chunk.type === 'response.output_text.delta') {
620
- content.push({
621
- type: 'text',
622
- text: chunk.delta,
623
- index: chunk.content_index,
624
- });
625
- /** @ts-ignore */
626
- }
627
- else if (chunk.type === 'response.output_text_annotation.added') {
628
- content.push({
629
- type: 'text',
630
- text: '',
631
- /** @ts-ignore */
632
- annotations: [chunk.annotation],
633
- /** @ts-ignore */
634
- index: chunk.content_index,
635
- });
636
- }
637
- else if (chunk.type === 'response.output_item.added' &&
638
- chunk.item.type === 'message') {
639
- id = chunk.item.id;
640
- }
641
- else if (chunk.type === 'response.output_item.added' &&
642
- chunk.item.type === 'function_call') {
643
- tool_call_chunks.push({
644
- type: 'tool_call_chunk',
645
- name: chunk.item.name,
646
- args: chunk.item.arguments,
647
- id: chunk.item.call_id,
648
- index: chunk.output_index,
649
- });
650
- additional_kwargs[_FUNCTION_CALL_IDS_MAP_KEY] = {
651
- [chunk.item.call_id]: chunk.item.id,
652
- };
653
- }
654
- else if (chunk.type === 'response.output_item.done' &&
655
- [
656
- 'web_search_call',
657
- 'file_search_call',
658
- 'computer_call',
659
- 'code_interpreter_call',
660
- 'mcp_call',
661
- 'mcp_list_tools',
662
- 'mcp_approval_request',
663
- 'image_generation_call',
664
- ].includes(chunk.item.type)) {
665
- additional_kwargs.tool_outputs = [chunk.item];
666
- }
667
- else if (chunk.type === 'response.created') {
668
- response_metadata.id = chunk.response.id;
669
- response_metadata.model_name = chunk.response.model;
670
- response_metadata.model = chunk.response.model;
671
- }
672
- else if (chunk.type === 'response.completed') {
673
- const msg = _convertOpenAIResponsesMessageToBaseMessage(chunk.response);
674
- usage_metadata = chunk.response.usage;
675
- if (chunk.response.text?.format?.type === 'json_schema') {
676
- additional_kwargs.parsed ??= JSON.parse(msg.text);
677
- }
678
- for (const [key, value] of Object.entries(chunk.response)) {
679
- if (key !== 'id')
680
- response_metadata[key] = value;
681
- }
682
- }
683
- else if (chunk.type === 'response.function_call_arguments.delta') {
684
- tool_call_chunks.push({
685
- type: 'tool_call_chunk',
686
- args: chunk.delta,
687
- index: chunk.output_index,
688
- });
689
- }
690
- else if (chunk.type === 'response.web_search_call.completed' ||
691
- chunk.type === 'response.file_search_call.completed') {
692
- generationInfo = {
693
- tool_outputs: {
694
- id: chunk.item_id,
695
- type: chunk.type.replace('response.', '').replace('.completed', ''),
696
- status: 'completed',
697
- },
698
- };
699
- }
700
- else if (chunk.type === 'response.refusal.done') {
701
- additional_kwargs.refusal = chunk.refusal;
702
- }
703
- else if (chunk.type === 'response.output_item.added' &&
704
- 'item' in chunk &&
705
- chunk.item.type === 'reasoning') {
706
- const summary = chunk
707
- .item.summary
708
- ? chunk.item.summary.map((s, index) => ({
709
- ...s,
710
- index,
711
- }))
712
- : undefined;
713
- additional_kwargs.reasoning = {
714
- // We only capture ID in the first chunk or else the concatenated result of all chunks will
715
- // have an ID field that is repeated once per chunk. There is special handling for the `type`
716
- // field that prevents this, however.
717
- id: chunk.item.id,
718
- type: chunk.item.type,
719
- ...(summary ? { summary } : {}),
720
- };
721
- }
722
- else if (chunk.type === 'response.reasoning_summary_part.added') {
723
- additional_kwargs.reasoning = {
724
- type: 'reasoning',
725
- summary: [{ ...chunk.part, index: chunk.summary_index }],
726
- };
727
- }
728
- else if (chunk.type === 'response.reasoning_summary_text.delta') {
729
- additional_kwargs.reasoning = {
730
- type: 'reasoning',
731
- summary: [
732
- { text: chunk.delta, type: 'summary_text', index: chunk.summary_index },
733
- ],
734
- };
735
- /** @ts-ignore */
736
- }
737
- else if (chunk.type === 'response.image_generation_call.partial_image') {
738
- // noop/fixme: retaining partial images in a message chunk means that _all_
739
- // partial images get kept in history, so we don't do anything here.
740
- return null;
741
- }
742
- else {
743
- return null;
744
- }
745
- return new outputs.ChatGenerationChunk({
746
- // Legacy reasons, `onLLMNewToken` should pulls this out
747
- text: content.map((part) => part.text).join(''),
748
- message: new messages.AIMessageChunk({
749
- id,
750
- content,
751
- tool_call_chunks,
752
- usage_metadata,
753
- additional_kwargs,
754
- response_metadata,
755
- }),
756
- generationInfo,
757
- });
758
- }
759
314
 
760
315
  exports._convertMessagesToOpenAIParams = _convertMessagesToOpenAIParams;
761
- exports._convertMessagesToOpenAIResponsesParams = _convertMessagesToOpenAIResponsesParams;
762
- exports._convertOpenAIResponsesDeltaToBaseMessageChunk = _convertOpenAIResponsesDeltaToBaseMessageChunk;
763
316
  exports.isReasoningModel = isReasoningModel;
764
317
  exports.messageToOpenAIRole = messageToOpenAIRole;
765
318
  //# sourceMappingURL=index.cjs.map