@illuma-ai/agents 1.0.90 → 1.0.94

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 (839) hide show
  1. package/dist/cjs/agents/AgentContext.cjs +98 -49
  2. package/dist/cjs/agents/AgentContext.cjs.map +1 -1
  3. package/dist/cjs/common/constants.cjs +25 -0
  4. package/dist/cjs/common/constants.cjs.map +1 -0
  5. package/dist/cjs/common/enum.cjs +30 -0
  6. package/dist/cjs/common/enum.cjs.map +1 -1
  7. package/dist/cjs/events.cjs +9 -4
  8. package/dist/cjs/events.cjs.map +1 -1
  9. package/dist/cjs/graphs/Graph.cjs +397 -92
  10. package/dist/cjs/graphs/Graph.cjs.map +1 -1
  11. package/dist/cjs/graphs/MultiAgentGraph.cjs +223 -92
  12. package/dist/cjs/graphs/MultiAgentGraph.cjs.map +1 -1
  13. package/dist/cjs/instrumentation.cjs +30 -14
  14. package/dist/cjs/instrumentation.cjs.map +1 -1
  15. package/dist/cjs/llm/anthropic/index.cjs +43 -11
  16. package/dist/cjs/llm/anthropic/index.cjs.map +1 -1
  17. package/dist/cjs/llm/anthropic/types.cjs.map +1 -1
  18. package/dist/cjs/llm/anthropic/utils/message_inputs.cjs +10 -7
  19. package/dist/cjs/llm/anthropic/utils/message_inputs.cjs.map +1 -1
  20. package/dist/cjs/llm/anthropic/utils/message_outputs.cjs +32 -0
  21. package/dist/cjs/llm/anthropic/utils/message_outputs.cjs.map +1 -1
  22. package/dist/cjs/llm/anthropic/utils/tools.cjs.map +1 -1
  23. package/dist/cjs/llm/bedrock/index.cjs +129 -101
  24. package/dist/cjs/llm/bedrock/index.cjs.map +1 -1
  25. package/dist/cjs/llm/bedrock/utils/message_inputs.cjs +489 -0
  26. package/dist/cjs/llm/bedrock/utils/message_inputs.cjs.map +1 -0
  27. package/dist/cjs/llm/bedrock/utils/message_outputs.cjs +176 -0
  28. package/dist/cjs/llm/bedrock/utils/message_outputs.cjs.map +1 -0
  29. package/dist/cjs/llm/fake.cjs.map +1 -1
  30. package/dist/cjs/llm/google/index.cjs.map +1 -1
  31. package/dist/cjs/llm/google/utils/common.cjs.map +1 -1
  32. package/dist/cjs/llm/openai/index.cjs +1 -1
  33. package/dist/cjs/llm/openai/index.cjs.map +1 -1
  34. package/dist/cjs/llm/openai/utils/index.cjs.map +1 -1
  35. package/dist/cjs/llm/openrouter/index.cjs +59 -5
  36. package/dist/cjs/llm/openrouter/index.cjs.map +1 -1
  37. package/dist/cjs/llm/providers.cjs.map +1 -1
  38. package/dist/cjs/llm/text.cjs.map +1 -1
  39. package/dist/cjs/llm/vertexai/index.cjs +80 -2
  40. package/dist/cjs/llm/vertexai/index.cjs.map +1 -1
  41. package/dist/cjs/main.cjs +60 -27
  42. package/dist/cjs/main.cjs.map +1 -1
  43. package/dist/cjs/messages/cache.cjs +131 -108
  44. package/dist/cjs/messages/cache.cjs.map +1 -1
  45. package/dist/cjs/messages/content.cjs.map +1 -1
  46. package/dist/cjs/messages/core.cjs +3 -0
  47. package/dist/cjs/messages/core.cjs.map +1 -1
  48. package/dist/cjs/messages/format.cjs +265 -47
  49. package/dist/cjs/messages/format.cjs.map +1 -1
  50. package/dist/cjs/messages/ids.cjs.map +1 -1
  51. package/dist/cjs/messages/prune.cjs +55 -2
  52. package/dist/cjs/messages/prune.cjs.map +1 -1
  53. package/dist/cjs/messages/summarize.cjs +170 -0
  54. package/dist/cjs/messages/summarize.cjs.map +1 -0
  55. package/dist/cjs/messages/tools.cjs.map +1 -1
  56. package/dist/cjs/run.cjs +87 -30
  57. package/dist/cjs/run.cjs.map +1 -1
  58. package/dist/cjs/schemas/validate.cjs.map +1 -1
  59. package/dist/cjs/splitStream.cjs.map +1 -1
  60. package/dist/cjs/stream.cjs +59 -25
  61. package/dist/cjs/stream.cjs.map +1 -1
  62. package/dist/cjs/tools/AskUser.cjs +131 -0
  63. package/dist/cjs/tools/AskUser.cjs.map +1 -0
  64. package/dist/cjs/tools/BrowserTools.cjs +11 -7
  65. package/dist/cjs/tools/BrowserTools.cjs.map +1 -1
  66. package/dist/cjs/tools/Calculator.cjs.map +1 -1
  67. package/dist/cjs/tools/CodeExecutor.cjs +60 -5
  68. package/dist/cjs/tools/CodeExecutor.cjs.map +1 -1
  69. package/dist/cjs/tools/ProgrammaticToolCalling.cjs +36 -53
  70. package/dist/cjs/tools/ProgrammaticToolCalling.cjs.map +1 -1
  71. package/dist/cjs/tools/StreamingToolCallBuffer.cjs +208 -0
  72. package/dist/cjs/tools/StreamingToolCallBuffer.cjs.map +1 -0
  73. package/dist/cjs/tools/ToolNode.cjs +333 -30
  74. package/dist/cjs/tools/ToolNode.cjs.map +1 -1
  75. package/dist/cjs/tools/ToolSearch.cjs +66 -30
  76. package/dist/cjs/tools/ToolSearch.cjs.map +1 -1
  77. package/dist/cjs/tools/handlers.cjs +94 -8
  78. package/dist/cjs/tools/handlers.cjs.map +1 -1
  79. package/dist/cjs/tools/schema.cjs.map +1 -1
  80. package/dist/cjs/tools/search/content.cjs.map +1 -1
  81. package/dist/cjs/tools/search/firecrawl.cjs.map +1 -1
  82. package/dist/cjs/tools/search/format.cjs.map +1 -1
  83. package/dist/cjs/tools/search/highlights.cjs.map +1 -1
  84. package/dist/cjs/tools/search/rerankers.cjs.map +1 -1
  85. package/dist/cjs/tools/search/schema.cjs.map +1 -1
  86. package/dist/cjs/tools/search/search.cjs +1 -0
  87. package/dist/cjs/tools/search/search.cjs.map +1 -1
  88. package/dist/cjs/tools/search/serper-scraper.cjs.map +1 -1
  89. package/dist/cjs/tools/search/tool.cjs.map +1 -1
  90. package/dist/cjs/tools/search/utils.cjs.map +1 -1
  91. package/dist/cjs/types/graph.cjs +1 -1
  92. package/dist/cjs/types/graph.cjs.map +1 -1
  93. package/dist/cjs/utils/contextAnalytics.cjs +23 -6
  94. package/dist/cjs/utils/contextAnalytics.cjs.map +1 -1
  95. package/dist/cjs/utils/events.cjs.map +1 -1
  96. package/dist/cjs/utils/graph.cjs.map +1 -1
  97. package/dist/cjs/utils/handlers.cjs.map +1 -1
  98. package/dist/cjs/utils/llm.cjs.map +1 -1
  99. package/dist/cjs/utils/misc.cjs.map +1 -1
  100. package/dist/cjs/utils/run.cjs +3 -1
  101. package/dist/cjs/utils/run.cjs.map +1 -1
  102. package/dist/cjs/utils/schema.cjs.map +1 -1
  103. package/dist/cjs/utils/title.cjs.map +1 -1
  104. package/dist/cjs/utils/tokens.cjs +33 -58
  105. package/dist/cjs/utils/tokens.cjs.map +1 -1
  106. package/dist/cjs/utils/toolCallContinuation.cjs +55 -0
  107. package/dist/cjs/utils/toolCallContinuation.cjs.map +1 -0
  108. package/dist/cjs/utils/toonFormat.cjs.map +1 -1
  109. package/dist/esm/agents/AgentContext.mjs +98 -49
  110. package/dist/esm/agents/AgentContext.mjs.map +1 -1
  111. package/dist/esm/common/constants.mjs +22 -0
  112. package/dist/esm/common/constants.mjs.map +1 -0
  113. package/dist/esm/common/enum.mjs +31 -1
  114. package/dist/esm/common/enum.mjs.map +1 -1
  115. package/dist/esm/events.mjs +9 -4
  116. package/dist/esm/events.mjs.map +1 -1
  117. package/dist/esm/graphs/Graph.mjs +393 -88
  118. package/dist/esm/graphs/Graph.mjs.map +1 -1
  119. package/dist/esm/graphs/MultiAgentGraph.mjs +224 -93
  120. package/dist/esm/graphs/MultiAgentGraph.mjs.map +1 -1
  121. package/dist/esm/instrumentation.mjs +30 -14
  122. package/dist/esm/instrumentation.mjs.map +1 -1
  123. package/dist/esm/llm/anthropic/index.mjs +43 -11
  124. package/dist/esm/llm/anthropic/index.mjs.map +1 -1
  125. package/dist/esm/llm/anthropic/types.mjs.map +1 -1
  126. package/dist/esm/llm/anthropic/utils/message_inputs.mjs +10 -7
  127. package/dist/esm/llm/anthropic/utils/message_inputs.mjs.map +1 -1
  128. package/dist/esm/llm/anthropic/utils/message_outputs.mjs +32 -0
  129. package/dist/esm/llm/anthropic/utils/message_outputs.mjs.map +1 -1
  130. package/dist/esm/llm/anthropic/utils/tools.mjs.map +1 -1
  131. package/dist/esm/llm/bedrock/index.mjs +128 -101
  132. package/dist/esm/llm/bedrock/index.mjs.map +1 -1
  133. package/dist/esm/llm/bedrock/utils/message_inputs.mjs +484 -0
  134. package/dist/esm/llm/bedrock/utils/message_inputs.mjs.map +1 -0
  135. package/dist/esm/llm/bedrock/utils/message_outputs.mjs +171 -0
  136. package/dist/esm/llm/bedrock/utils/message_outputs.mjs.map +1 -0
  137. package/dist/esm/llm/fake.mjs.map +1 -1
  138. package/dist/esm/llm/google/index.mjs.map +1 -1
  139. package/dist/esm/llm/google/utils/common.mjs.map +1 -1
  140. package/dist/esm/llm/openai/index.mjs +1 -1
  141. package/dist/esm/llm/openai/index.mjs.map +1 -1
  142. package/dist/esm/llm/openai/utils/index.mjs.map +1 -1
  143. package/dist/esm/llm/openrouter/index.mjs +59 -5
  144. package/dist/esm/llm/openrouter/index.mjs.map +1 -1
  145. package/dist/esm/llm/providers.mjs.map +1 -1
  146. package/dist/esm/llm/text.mjs.map +1 -1
  147. package/dist/esm/llm/vertexai/index.mjs +80 -2
  148. package/dist/esm/llm/vertexai/index.mjs.map +1 -1
  149. package/dist/esm/main.mjs +8 -3
  150. package/dist/esm/main.mjs.map +1 -1
  151. package/dist/esm/messages/cache.mjs +131 -108
  152. package/dist/esm/messages/cache.mjs.map +1 -1
  153. package/dist/esm/messages/content.mjs.map +1 -1
  154. package/dist/esm/messages/core.mjs +4 -1
  155. package/dist/esm/messages/core.mjs.map +1 -1
  156. package/dist/esm/messages/format.mjs +267 -49
  157. package/dist/esm/messages/format.mjs.map +1 -1
  158. package/dist/esm/messages/ids.mjs.map +1 -1
  159. package/dist/esm/messages/prune.mjs +56 -4
  160. package/dist/esm/messages/prune.mjs.map +1 -1
  161. package/dist/esm/messages/summarize.mjs +161 -0
  162. package/dist/esm/messages/summarize.mjs.map +1 -0
  163. package/dist/esm/messages/tools.mjs.map +1 -1
  164. package/dist/esm/run.mjs +88 -31
  165. package/dist/esm/run.mjs.map +1 -1
  166. package/dist/esm/schemas/validate.mjs.map +1 -1
  167. package/dist/esm/splitStream.mjs.map +1 -1
  168. package/dist/esm/stream.mjs +60 -26
  169. package/dist/esm/stream.mjs.map +1 -1
  170. package/dist/esm/tools/AskUser.mjs +125 -0
  171. package/dist/esm/tools/AskUser.mjs.map +1 -0
  172. package/dist/esm/tools/BrowserTools.mjs +11 -7
  173. package/dist/esm/tools/BrowserTools.mjs.map +1 -1
  174. package/dist/esm/tools/Calculator.mjs.map +1 -1
  175. package/dist/esm/tools/CodeExecutor.mjs +60 -5
  176. package/dist/esm/tools/CodeExecutor.mjs.map +1 -1
  177. package/dist/esm/tools/ProgrammaticToolCalling.mjs +37 -54
  178. package/dist/esm/tools/ProgrammaticToolCalling.mjs.map +1 -1
  179. package/dist/esm/tools/StreamingToolCallBuffer.mjs +206 -0
  180. package/dist/esm/tools/StreamingToolCallBuffer.mjs.map +1 -0
  181. package/dist/esm/tools/ToolNode.mjs +333 -30
  182. package/dist/esm/tools/ToolNode.mjs.map +1 -1
  183. package/dist/esm/tools/ToolSearch.mjs +66 -30
  184. package/dist/esm/tools/ToolSearch.mjs.map +1 -1
  185. package/dist/esm/tools/handlers.mjs +95 -9
  186. package/dist/esm/tools/handlers.mjs.map +1 -1
  187. package/dist/esm/tools/schema.mjs.map +1 -1
  188. package/dist/esm/tools/search/content.mjs.map +1 -1
  189. package/dist/esm/tools/search/firecrawl.mjs.map +1 -1
  190. package/dist/esm/tools/search/format.mjs.map +1 -1
  191. package/dist/esm/tools/search/highlights.mjs.map +1 -1
  192. package/dist/esm/tools/search/rerankers.mjs.map +1 -1
  193. package/dist/esm/tools/search/schema.mjs.map +1 -1
  194. package/dist/esm/tools/search/search.mjs +1 -0
  195. package/dist/esm/tools/search/search.mjs.map +1 -1
  196. package/dist/esm/tools/search/serper-scraper.mjs.map +1 -1
  197. package/dist/esm/tools/search/tool.mjs.map +1 -1
  198. package/dist/esm/tools/search/utils.mjs.map +1 -1
  199. package/dist/esm/types/graph.mjs +1 -1
  200. package/dist/esm/types/graph.mjs.map +1 -1
  201. package/dist/esm/utils/contextAnalytics.mjs +23 -6
  202. package/dist/esm/utils/contextAnalytics.mjs.map +1 -1
  203. package/dist/esm/utils/events.mjs.map +1 -1
  204. package/dist/esm/utils/graph.mjs.map +1 -1
  205. package/dist/esm/utils/handlers.mjs.map +1 -1
  206. package/dist/esm/utils/llm.mjs.map +1 -1
  207. package/dist/esm/utils/misc.mjs.map +1 -1
  208. package/dist/esm/utils/run.mjs +3 -1
  209. package/dist/esm/utils/run.mjs.map +1 -1
  210. package/dist/esm/utils/schema.mjs.map +1 -1
  211. package/dist/esm/utils/title.mjs.map +1 -1
  212. package/dist/esm/utils/tokens.mjs +33 -59
  213. package/dist/esm/utils/tokens.mjs.map +1 -1
  214. package/dist/esm/utils/toolCallContinuation.mjs +52 -0
  215. package/dist/esm/utils/toolCallContinuation.mjs.map +1 -0
  216. package/dist/esm/utils/toonFormat.mjs.map +1 -1
  217. package/dist/types/agents/AgentContext.d.ts +14 -7
  218. package/dist/types/common/constants.d.ts +18 -0
  219. package/dist/types/common/enum.d.ts +28 -0
  220. package/dist/types/common/index.d.ts +1 -0
  221. package/dist/types/events.d.ts +10 -3
  222. package/dist/types/graphs/Graph.d.ts +37 -0
  223. package/dist/types/index.d.ts +4 -0
  224. package/dist/types/llm/anthropic/index.d.ts +7 -1
  225. package/dist/types/llm/anthropic/types.d.ts +5 -2
  226. package/dist/types/llm/anthropic/utils/message_outputs.d.ts +1 -1
  227. package/dist/types/llm/bedrock/index.d.ts +40 -33
  228. package/dist/types/llm/bedrock/utils/message_outputs.d.ts +1 -1
  229. package/dist/types/llm/google/index.d.ts +2 -3
  230. package/dist/types/llm/openrouter/index.d.ts +21 -1
  231. package/dist/types/llm/vertexai/index.d.ts +3 -2
  232. package/dist/types/messages/cache.d.ts +1 -1
  233. package/dist/types/messages/index.d.ts +1 -0
  234. package/dist/types/messages/prune.d.ts +2 -7
  235. package/dist/types/messages/summarize.d.ts +33 -0
  236. package/dist/types/run.d.ts +6 -0
  237. package/dist/types/tools/AskUser.d.ts +408 -0
  238. package/dist/types/tools/BrowserTools.d.ts +2 -2
  239. package/dist/types/tools/CodeExecutor.d.ts +28 -4
  240. package/dist/types/tools/StreamingToolCallBuffer.d.ts +106 -0
  241. package/dist/types/tools/ToolNode.d.ts +55 -3
  242. package/dist/types/tools/ToolSearch.d.ts +9 -5
  243. package/dist/types/tools/handlers.d.ts +2 -2
  244. package/dist/types/types/graph.d.ts +9 -2
  245. package/dist/types/types/llm.d.ts +8 -3
  246. package/dist/types/types/run.d.ts +2 -0
  247. package/dist/types/types/tools.d.ts +20 -2
  248. package/dist/types/utils/contextAnalytics.d.ts +5 -4
  249. package/dist/types/utils/index.d.ts +1 -0
  250. package/dist/types/utils/tokens.d.ts +6 -19
  251. package/dist/types/utils/toolCallContinuation.d.ts +30 -0
  252. package/package.json +15 -8
  253. package/src/agents/AgentContext.js +782 -0
  254. package/src/agents/AgentContext.js.map +1 -0
  255. package/src/agents/AgentContext.test.js +421 -0
  256. package/src/agents/AgentContext.test.js.map +1 -0
  257. package/src/agents/AgentContext.ts +132 -64
  258. package/src/agents/__tests__/AgentContext.test.js +678 -0
  259. package/src/agents/__tests__/AgentContext.test.js.map +1 -0
  260. package/src/agents/__tests__/AgentContext.test.ts +25 -4
  261. package/src/agents/__tests__/resolveStructuredOutputMode.test.js +117 -0
  262. package/src/agents/__tests__/resolveStructuredOutputMode.test.js.map +1 -0
  263. package/src/common/__tests__/enum.test.ts +135 -0
  264. package/src/common/constants.ts +21 -0
  265. package/src/common/enum.js +192 -0
  266. package/src/common/enum.js.map +1 -0
  267. package/src/common/enum.ts +30 -0
  268. package/src/common/index.js +3 -0
  269. package/src/common/index.js.map +1 -0
  270. package/src/common/index.ts +2 -1
  271. package/src/events.js +166 -0
  272. package/src/events.js.map +1 -0
  273. package/src/events.ts +11 -14
  274. package/src/graphs/Graph.js +1857 -0
  275. package/src/graphs/Graph.js.map +1 -0
  276. package/src/graphs/Graph.ts +580 -162
  277. package/src/graphs/MultiAgentGraph.js +1092 -0
  278. package/src/graphs/MultiAgentGraph.js.map +1 -0
  279. package/src/graphs/MultiAgentGraph.ts +331 -112
  280. package/src/graphs/__tests__/adaptive-thinking.test.ts +369 -0
  281. package/src/graphs/__tests__/graph-direct-tool-names.test.ts +210 -0
  282. package/src/graphs/__tests__/multi-agent-edges.test.ts +237 -0
  283. package/src/graphs/__tests__/structured-output.integration.test.js +624 -0
  284. package/src/graphs/__tests__/structured-output.integration.test.js.map +1 -0
  285. package/src/graphs/__tests__/structured-output.test.js +144 -0
  286. package/src/graphs/__tests__/structured-output.test.js.map +1 -0
  287. package/src/graphs/contextManagement.e2e.test.js +718 -0
  288. package/src/graphs/contextManagement.e2e.test.js.map +1 -0
  289. package/src/graphs/contextManagement.e2e.test.ts +990 -0
  290. package/src/graphs/contextManagement.test.js +485 -0
  291. package/src/graphs/contextManagement.test.js.map +1 -0
  292. package/src/graphs/contextManagement.test.ts +625 -0
  293. package/src/graphs/handoffValidation.test.js +276 -0
  294. package/src/graphs/handoffValidation.test.js.map +1 -0
  295. package/src/graphs/handoffValidation.test.ts +353 -0
  296. package/src/graphs/index.js +3 -0
  297. package/src/graphs/index.js.map +1 -0
  298. package/src/index.js +28 -0
  299. package/src/index.js.map +1 -0
  300. package/src/index.ts +13 -0
  301. package/src/instrumentation.js +21 -0
  302. package/src/instrumentation.js.map +1 -0
  303. package/src/instrumentation.ts +38 -17
  304. package/src/llm/anthropic/index.js +319 -0
  305. package/src/llm/anthropic/index.js.map +1 -0
  306. package/src/llm/anthropic/index.ts +68 -15
  307. package/src/llm/anthropic/llm.spec.ts +402 -0
  308. package/src/llm/anthropic/types.js +46 -0
  309. package/src/llm/anthropic/types.js.map +1 -0
  310. package/src/llm/anthropic/types.ts +8 -2
  311. package/src/llm/anthropic/utils/message_inputs.js +627 -0
  312. package/src/llm/anthropic/utils/message_inputs.js.map +1 -0
  313. package/src/llm/anthropic/utils/message_inputs.ts +16 -33
  314. package/src/llm/anthropic/utils/message_outputs.js +290 -0
  315. package/src/llm/anthropic/utils/message_outputs.js.map +1 -0
  316. package/src/llm/anthropic/utils/message_outputs.ts +40 -1
  317. package/src/llm/anthropic/utils/output_parsers.js +89 -0
  318. package/src/llm/anthropic/utils/output_parsers.js.map +1 -0
  319. package/src/llm/anthropic/utils/tools.js +25 -0
  320. package/src/llm/anthropic/utils/tools.js.map +1 -0
  321. package/src/llm/bedrock/__tests__/bedrock-caching.test.js +392 -0
  322. package/src/llm/bedrock/__tests__/bedrock-caching.test.js.map +1 -0
  323. package/src/llm/bedrock/__tests__/bedrock-caching.test.ts +24 -40
  324. package/src/llm/bedrock/index.js +303 -0
  325. package/src/llm/bedrock/index.js.map +1 -0
  326. package/src/llm/bedrock/index.ts +171 -134
  327. package/src/llm/bedrock/llm.spec.ts +395 -52
  328. package/src/llm/bedrock/types.js +2 -0
  329. package/src/llm/bedrock/types.js.map +1 -0
  330. package/src/llm/bedrock/utils/index.js +6 -0
  331. package/src/llm/bedrock/utils/index.js.map +1 -0
  332. package/src/llm/bedrock/utils/message_inputs.js +463 -0
  333. package/src/llm/bedrock/utils/message_inputs.js.map +1 -0
  334. package/src/llm/bedrock/utils/message_inputs.ts +30 -5
  335. package/src/llm/bedrock/utils/message_outputs.js +269 -0
  336. package/src/llm/bedrock/utils/message_outputs.js.map +1 -0
  337. package/src/llm/bedrock/utils/message_outputs.ts +70 -22
  338. package/src/llm/fake.js +92 -0
  339. package/src/llm/fake.js.map +1 -0
  340. package/src/llm/google/index.js +215 -0
  341. package/src/llm/google/index.js.map +1 -0
  342. package/src/llm/google/index.ts +2 -3
  343. package/src/llm/google/types.js +12 -0
  344. package/src/llm/google/types.js.map +1 -0
  345. package/src/llm/google/utils/common.js +670 -0
  346. package/src/llm/google/utils/common.js.map +1 -0
  347. package/src/llm/google/utils/tools.js +111 -0
  348. package/src/llm/google/utils/tools.js.map +1 -0
  349. package/src/llm/google/utils/zod_to_genai_parameters.js +47 -0
  350. package/src/llm/google/utils/zod_to_genai_parameters.js.map +1 -0
  351. package/src/llm/openai/index.js +1033 -0
  352. package/src/llm/openai/index.js.map +1 -0
  353. package/src/llm/openai/types.js +2 -0
  354. package/src/llm/openai/types.js.map +1 -0
  355. package/src/llm/openai/utils/index.js +756 -0
  356. package/src/llm/openai/utils/index.js.map +1 -0
  357. package/src/llm/openai/utils/isReasoningModel.test.js +79 -0
  358. package/src/llm/openai/utils/isReasoningModel.test.js.map +1 -0
  359. package/src/llm/openrouter/index.js +261 -0
  360. package/src/llm/openrouter/index.js.map +1 -0
  361. package/src/llm/openrouter/index.ts +117 -6
  362. package/src/llm/openrouter/reasoning.test.js +181 -0
  363. package/src/llm/openrouter/reasoning.test.js.map +1 -0
  364. package/src/llm/openrouter/reasoning.test.ts +207 -0
  365. package/src/llm/providers.js +36 -0
  366. package/src/llm/providers.js.map +1 -0
  367. package/src/llm/text.js +65 -0
  368. package/src/llm/text.js.map +1 -0
  369. package/src/llm/vertexai/index.js +402 -0
  370. package/src/llm/vertexai/index.js.map +1 -0
  371. package/src/llm/vertexai/index.ts +115 -5
  372. package/src/llm/vertexai/llm.spec.ts +114 -0
  373. package/src/messages/__tests__/tools.test.js +392 -0
  374. package/src/messages/__tests__/tools.test.js.map +1 -0
  375. package/src/messages/cache.js +404 -0
  376. package/src/messages/cache.js.map +1 -0
  377. package/src/messages/cache.test.js +1167 -0
  378. package/src/messages/cache.test.js.map +1 -0
  379. package/src/messages/cache.test.ts +178 -16
  380. package/src/messages/cache.ts +152 -147
  381. package/src/messages/content.js +48 -0
  382. package/src/messages/content.js.map +1 -0
  383. package/src/messages/content.test.js +314 -0
  384. package/src/messages/content.test.js.map +1 -0
  385. package/src/messages/core.js +359 -0
  386. package/src/messages/core.js.map +1 -0
  387. package/src/messages/core.ts +5 -0
  388. package/src/messages/ensureThinkingBlock.test.js +997 -0
  389. package/src/messages/ensureThinkingBlock.test.js.map +1 -0
  390. package/src/messages/ensureThinkingBlock.test.ts +751 -10
  391. package/src/messages/format.js +973 -0
  392. package/src/messages/format.js.map +1 -0
  393. package/src/messages/format.ts +334 -57
  394. package/src/messages/formatAgentMessages.test.js +2278 -0
  395. package/src/messages/formatAgentMessages.test.js.map +1 -0
  396. package/src/messages/formatAgentMessages.test.ts +1175 -1
  397. package/src/messages/formatAgentMessages.tools.test.js +362 -0
  398. package/src/messages/formatAgentMessages.tools.test.js.map +1 -0
  399. package/src/messages/formatMessage.test.js +608 -0
  400. package/src/messages/formatMessage.test.js.map +1 -0
  401. package/src/messages/ids.js +18 -0
  402. package/src/messages/ids.js.map +1 -0
  403. package/src/messages/index.js +9 -0
  404. package/src/messages/index.js.map +1 -0
  405. package/src/messages/index.ts +1 -0
  406. package/src/messages/labelContentByAgent.test.js +725 -0
  407. package/src/messages/labelContentByAgent.test.js.map +1 -0
  408. package/src/messages/prune.js +438 -0
  409. package/src/messages/prune.js.map +1 -0
  410. package/src/messages/prune.ts +87 -25
  411. package/src/messages/reducer.js +60 -0
  412. package/src/messages/reducer.js.map +1 -0
  413. package/src/messages/shiftIndexTokenCountMap.test.js +63 -0
  414. package/src/messages/shiftIndexTokenCountMap.test.js.map +1 -0
  415. package/src/messages/summarize.js +146 -0
  416. package/src/messages/summarize.js.map +1 -0
  417. package/src/messages/summarize.test.js +332 -0
  418. package/src/messages/summarize.test.js.map +1 -0
  419. package/src/messages/summarize.test.ts +466 -0
  420. package/src/messages/summarize.ts +222 -0
  421. package/src/messages/tools.js +90 -0
  422. package/src/messages/tools.js.map +1 -0
  423. package/src/mockStream.js +81 -0
  424. package/src/mockStream.js.map +1 -0
  425. package/src/prompts/collab.js +7 -0
  426. package/src/prompts/collab.js.map +1 -0
  427. package/src/prompts/index.js +3 -0
  428. package/src/prompts/index.js.map +1 -0
  429. package/src/prompts/taskmanager.js +58 -0
  430. package/src/prompts/taskmanager.js.map +1 -0
  431. package/src/run.js +427 -0
  432. package/src/run.js.map +1 -0
  433. package/src/run.ts +101 -33
  434. package/src/schemas/index.js +3 -0
  435. package/src/schemas/index.js.map +1 -0
  436. package/src/schemas/schema-preparation.test.js +370 -0
  437. package/src/schemas/schema-preparation.test.js.map +1 -0
  438. package/src/schemas/validate.js +314 -0
  439. package/src/schemas/validate.js.map +1 -0
  440. package/src/schemas/validate.test.js +264 -0
  441. package/src/schemas/validate.test.js.map +1 -0
  442. package/src/scripts/abort.js +127 -0
  443. package/src/scripts/abort.js.map +1 -0
  444. package/src/scripts/ant_web_search.js +130 -0
  445. package/src/scripts/ant_web_search.js.map +1 -0
  446. package/src/scripts/ant_web_search.ts +1 -0
  447. package/src/scripts/ant_web_search_edge_case.js +133 -0
  448. package/src/scripts/ant_web_search_edge_case.js.map +1 -0
  449. package/src/scripts/ant_web_search_edge_case.ts +1 -0
  450. package/src/scripts/ant_web_search_error_edge_case.js +119 -0
  451. package/src/scripts/ant_web_search_error_edge_case.js.map +1 -0
  452. package/src/scripts/ant_web_search_error_edge_case.ts +1 -0
  453. package/src/scripts/args.js +41 -0
  454. package/src/scripts/args.js.map +1 -0
  455. package/src/scripts/bedrock-cache-debug.js +186 -0
  456. package/src/scripts/bedrock-cache-debug.js.map +1 -0
  457. package/src/scripts/bedrock-cache-debug.ts +250 -0
  458. package/src/scripts/bedrock-content-aggregation-test.js +195 -0
  459. package/src/scripts/bedrock-content-aggregation-test.js.map +1 -0
  460. package/src/scripts/bedrock-content-aggregation-test.ts +266 -0
  461. package/src/scripts/bedrock-merge-test.js +80 -0
  462. package/src/scripts/bedrock-merge-test.js.map +1 -0
  463. package/src/scripts/bedrock-merge-test.ts +107 -0
  464. package/src/scripts/bedrock-parallel-tools-test.js +150 -0
  465. package/src/scripts/bedrock-parallel-tools-test.js.map +1 -0
  466. package/src/scripts/bedrock-parallel-tools-test.ts +204 -0
  467. package/src/scripts/caching.js +106 -0
  468. package/src/scripts/caching.js.map +1 -0
  469. package/src/scripts/caching.ts +1 -0
  470. package/src/scripts/cli.js +152 -0
  471. package/src/scripts/cli.js.map +1 -0
  472. package/src/scripts/cli2.js +119 -0
  473. package/src/scripts/cli2.js.map +1 -0
  474. package/src/scripts/cli3.js +163 -0
  475. package/src/scripts/cli3.js.map +1 -0
  476. package/src/scripts/cli4.js +165 -0
  477. package/src/scripts/cli4.js.map +1 -0
  478. package/src/scripts/cli5.js +165 -0
  479. package/src/scripts/cli5.js.map +1 -0
  480. package/src/scripts/code_exec.js +171 -0
  481. package/src/scripts/code_exec.js.map +1 -0
  482. package/src/scripts/code_exec.ts +1 -0
  483. package/src/scripts/code_exec_files.js +180 -0
  484. package/src/scripts/code_exec_files.js.map +1 -0
  485. package/src/scripts/code_exec_files.ts +1 -0
  486. package/src/scripts/code_exec_multi_session.js +185 -0
  487. package/src/scripts/code_exec_multi_session.js.map +1 -0
  488. package/src/scripts/code_exec_multi_session.ts +9 -13
  489. package/src/scripts/code_exec_ptc.js +265 -0
  490. package/src/scripts/code_exec_ptc.js.map +1 -0
  491. package/src/scripts/code_exec_ptc.ts +1 -0
  492. package/src/scripts/code_exec_session.js +217 -0
  493. package/src/scripts/code_exec_session.js.map +1 -0
  494. package/src/scripts/code_exec_session.ts +1 -0
  495. package/src/scripts/code_exec_simple.js +120 -0
  496. package/src/scripts/code_exec_simple.js.map +1 -0
  497. package/src/scripts/code_exec_simple.ts +1 -0
  498. package/src/scripts/content.js +111 -0
  499. package/src/scripts/content.js.map +1 -0
  500. package/src/scripts/content.ts +1 -0
  501. package/src/scripts/empty_input.js +125 -0
  502. package/src/scripts/empty_input.js.map +1 -0
  503. package/src/scripts/handoff-test.js +96 -0
  504. package/src/scripts/handoff-test.js.map +1 -0
  505. package/src/scripts/image.js +138 -0
  506. package/src/scripts/image.js.map +1 -0
  507. package/src/scripts/image.ts +3 -1
  508. package/src/scripts/memory.js +83 -0
  509. package/src/scripts/memory.js.map +1 -0
  510. package/src/scripts/memory.ts +16 -6
  511. package/src/scripts/multi-agent-chain.js +271 -0
  512. package/src/scripts/multi-agent-chain.js.map +1 -0
  513. package/src/scripts/multi-agent-chain.ts +1 -0
  514. package/src/scripts/multi-agent-conditional.js +185 -0
  515. package/src/scripts/multi-agent-conditional.js.map +1 -0
  516. package/src/scripts/multi-agent-conditional.ts +1 -0
  517. package/src/scripts/multi-agent-document-review-chain.js +171 -0
  518. package/src/scripts/multi-agent-document-review-chain.js.map +1 -0
  519. package/src/scripts/multi-agent-document-review-chain.ts +1 -0
  520. package/src/scripts/multi-agent-hybrid-flow.js +264 -0
  521. package/src/scripts/multi-agent-hybrid-flow.js.map +1 -0
  522. package/src/scripts/multi-agent-hybrid-flow.ts +1 -0
  523. package/src/scripts/multi-agent-parallel-start.js +214 -0
  524. package/src/scripts/multi-agent-parallel-start.js.map +1 -0
  525. package/src/scripts/multi-agent-parallel-start.ts +4 -4
  526. package/src/scripts/multi-agent-parallel.js +346 -0
  527. package/src/scripts/multi-agent-parallel.js.map +1 -0
  528. package/src/scripts/multi-agent-parallel.ts +1 -0
  529. package/src/scripts/multi-agent-sequence.js +184 -0
  530. package/src/scripts/multi-agent-sequence.js.map +1 -0
  531. package/src/scripts/multi-agent-sequence.ts +4 -4
  532. package/src/scripts/multi-agent-supervisor.js +324 -0
  533. package/src/scripts/multi-agent-supervisor.js.map +1 -0
  534. package/src/scripts/multi-agent-supervisor.ts +1 -0
  535. package/src/scripts/multi-agent-test.js +147 -0
  536. package/src/scripts/multi-agent-test.js.map +1 -0
  537. package/src/scripts/multi-agent-test.ts +1 -0
  538. package/src/scripts/parallel-asymmetric-tools-test.js +202 -0
  539. package/src/scripts/parallel-asymmetric-tools-test.js.map +1 -0
  540. package/src/scripts/parallel-asymmetric-tools-test.ts +1 -0
  541. package/src/scripts/parallel-full-metadata-test.js +176 -0
  542. package/src/scripts/parallel-full-metadata-test.js.map +1 -0
  543. package/src/scripts/parallel-full-metadata-test.ts +1 -0
  544. package/src/scripts/parallel-tools-test.js +256 -0
  545. package/src/scripts/parallel-tools-test.js.map +1 -0
  546. package/src/scripts/parallel-tools-test.ts +1 -0
  547. package/src/scripts/poc-multi-agent-comprehensive.ts +1222 -0
  548. package/src/scripts/programmatic_exec.js +277 -0
  549. package/src/scripts/programmatic_exec.js.map +1 -0
  550. package/src/scripts/programmatic_exec_agent.js +168 -0
  551. package/src/scripts/programmatic_exec_agent.js.map +1 -0
  552. package/src/scripts/programmatic_exec_agent.ts +1 -0
  553. package/src/scripts/search.js +118 -0
  554. package/src/scripts/search.js.map +1 -0
  555. package/src/scripts/search.ts +1 -0
  556. package/src/scripts/sequential-full-metadata-test.js +143 -0
  557. package/src/scripts/sequential-full-metadata-test.js.map +1 -0
  558. package/src/scripts/sequential-full-metadata-test.ts +1 -0
  559. package/src/scripts/simple.js +174 -0
  560. package/src/scripts/simple.js.map +1 -0
  561. package/src/scripts/simple.ts +2 -1
  562. package/src/scripts/single-agent-metadata-test.js +152 -0
  563. package/src/scripts/single-agent-metadata-test.js.map +1 -0
  564. package/src/scripts/single-agent-metadata-test.ts +4 -6
  565. package/src/scripts/stream.js +113 -0
  566. package/src/scripts/stream.js.map +1 -0
  567. package/src/scripts/stream.ts +1 -0
  568. package/src/scripts/test-custom-prompt-key.js +132 -0
  569. package/src/scripts/test-custom-prompt-key.js.map +1 -0
  570. package/src/scripts/test-handoff-input.js +143 -0
  571. package/src/scripts/test-handoff-input.js.map +1 -0
  572. package/src/scripts/test-handoff-preamble.js +227 -0
  573. package/src/scripts/test-handoff-preamble.js.map +1 -0
  574. package/src/scripts/test-handoff-preamble.ts +1 -0
  575. package/src/scripts/test-handoff-steering.js +353 -0
  576. package/src/scripts/test-handoff-steering.js.map +1 -0
  577. package/src/scripts/test-handoff-steering.ts +430 -0
  578. package/src/scripts/test-multi-agent-list-handoff.js +318 -0
  579. package/src/scripts/test-multi-agent-list-handoff.js.map +1 -0
  580. package/src/scripts/test-multi-agent-list-handoff.ts +1 -0
  581. package/src/scripts/test-parallel-agent-labeling.js +253 -0
  582. package/src/scripts/test-parallel-agent-labeling.js.map +1 -0
  583. package/src/scripts/test-parallel-agent-labeling.ts +2 -0
  584. package/src/scripts/test-parallel-handoffs.js +229 -0
  585. package/src/scripts/test-parallel-handoffs.js.map +1 -0
  586. package/src/scripts/test-parallel-handoffs.ts +1 -0
  587. package/src/scripts/test-thinking-handoff-bedrock.js +132 -0
  588. package/src/scripts/test-thinking-handoff-bedrock.js.map +1 -0
  589. package/src/scripts/test-thinking-handoff-bedrock.ts +1 -0
  590. package/src/scripts/test-thinking-handoff.js +132 -0
  591. package/src/scripts/test-thinking-handoff.js.map +1 -0
  592. package/src/scripts/test-thinking-handoff.ts +1 -0
  593. package/src/scripts/test-thinking-to-thinking-handoff-bedrock.js +140 -0
  594. package/src/scripts/test-thinking-to-thinking-handoff-bedrock.js.map +1 -0
  595. package/src/scripts/test-thinking-to-thinking-handoff-bedrock.ts +166 -0
  596. package/src/scripts/test-tool-before-handoff-role-order.js +223 -0
  597. package/src/scripts/test-tool-before-handoff-role-order.js.map +1 -0
  598. package/src/scripts/test-tool-before-handoff-role-order.ts +276 -0
  599. package/src/scripts/test-tools-before-handoff.js +187 -0
  600. package/src/scripts/test-tools-before-handoff.js.map +1 -0
  601. package/src/scripts/test-tools-before-handoff.ts +4 -8
  602. package/src/scripts/test_code_api.js +263 -0
  603. package/src/scripts/test_code_api.js.map +1 -0
  604. package/src/scripts/thinking-bedrock.js +128 -0
  605. package/src/scripts/thinking-bedrock.js.map +1 -0
  606. package/src/scripts/thinking-bedrock.ts +1 -0
  607. package/src/scripts/thinking-vertexai.js +130 -0
  608. package/src/scripts/thinking-vertexai.js.map +1 -0
  609. package/src/scripts/thinking-vertexai.ts +168 -0
  610. package/src/scripts/thinking.js +134 -0
  611. package/src/scripts/thinking.js.map +1 -0
  612. package/src/scripts/thinking.ts +1 -0
  613. package/src/scripts/tool_search.js +114 -0
  614. package/src/scripts/tool_search.js.map +1 -0
  615. package/src/scripts/tools.js +125 -0
  616. package/src/scripts/tools.js.map +1 -0
  617. package/src/scripts/tools.ts +5 -19
  618. package/src/specs/agent-handoffs-bedrock.integration.test.js +280 -0
  619. package/src/specs/agent-handoffs-bedrock.integration.test.js.map +1 -0
  620. package/src/specs/agent-handoffs-bedrock.integration.test.ts +412 -375
  621. package/src/specs/agent-handoffs.test.js +924 -0
  622. package/src/specs/agent-handoffs.test.js.map +1 -0
  623. package/src/specs/agent-handoffs.test.ts +152 -39
  624. package/src/specs/anthropic.simple.test.js +287 -0
  625. package/src/specs/anthropic.simple.test.js.map +1 -0
  626. package/src/specs/anthropic.simple.test.ts +7 -4
  627. package/src/specs/azure.simple.test.js +381 -0
  628. package/src/specs/azure.simple.test.js.map +1 -0
  629. package/src/specs/azure.simple.test.ts +143 -5
  630. package/src/specs/cache.simple.test.js +282 -0
  631. package/src/specs/cache.simple.test.js.map +1 -0
  632. package/src/specs/cache.simple.test.ts +9 -2
  633. package/src/specs/custom-event-await.test.js +148 -0
  634. package/src/specs/custom-event-await.test.js.map +1 -0
  635. package/src/specs/custom-event-await.test.ts +215 -0
  636. package/src/specs/deepseek.simple.test.js +189 -0
  637. package/src/specs/deepseek.simple.test.js.map +1 -0
  638. package/src/specs/deepseek.simple.test.ts +4 -2
  639. package/src/specs/emergency-prune.test.js +308 -0
  640. package/src/specs/emergency-prune.test.js.map +1 -0
  641. package/src/specs/moonshot.simple.test.js +237 -0
  642. package/src/specs/moonshot.simple.test.js.map +1 -0
  643. package/src/specs/moonshot.simple.test.ts +6 -2
  644. package/src/specs/observability.integration.test.js +1337 -0
  645. package/src/specs/observability.integration.test.js.map +1 -0
  646. package/src/specs/observability.integration.test.ts +2223 -0
  647. package/src/specs/openai.simple.test.js +233 -0
  648. package/src/specs/openai.simple.test.js.map +1 -0
  649. package/src/specs/openai.simple.test.ts +4 -2
  650. package/src/specs/openrouter.simple.test.js +202 -0
  651. package/src/specs/openrouter.simple.test.js.map +1 -0
  652. package/src/specs/openrouter.simple.test.ts +165 -4
  653. package/src/specs/prune.test.js +733 -0
  654. package/src/specs/prune.test.js.map +1 -0
  655. package/src/specs/prune.test.ts +1 -0
  656. package/src/specs/reasoning.test.js +144 -0
  657. package/src/specs/reasoning.test.js.map +1 -0
  658. package/src/specs/reasoning.test.ts +2 -2
  659. package/src/specs/spec.utils.js +4 -0
  660. package/src/specs/spec.utils.js.map +1 -0
  661. package/src/specs/thinking-handoff.test.js +486 -0
  662. package/src/specs/thinking-handoff.test.js.map +1 -0
  663. package/src/specs/thinking-handoff.test.ts +3 -2
  664. package/src/specs/thinking-prune.test.js +600 -0
  665. package/src/specs/thinking-prune.test.js.map +1 -0
  666. package/src/specs/token-distribution-edge-case.test.js +246 -0
  667. package/src/specs/token-distribution-edge-case.test.js.map +1 -0
  668. package/src/specs/token-memoization.test.js +32 -0
  669. package/src/specs/token-memoization.test.js.map +1 -0
  670. package/src/specs/token-memoization.test.ts +14 -5
  671. package/src/specs/tokens.test.js +49 -0
  672. package/src/specs/tokens.test.js.map +1 -0
  673. package/src/specs/tokens.test.ts +64 -0
  674. package/src/specs/tool-error.test.js +139 -0
  675. package/src/specs/tool-error.test.js.map +1 -0
  676. package/src/specs/tool-error.test.ts +2 -2
  677. package/src/splitStream.js +204 -0
  678. package/src/splitStream.js.map +1 -0
  679. package/src/splitStream.test.js +504 -0
  680. package/src/splitStream.test.js.map +1 -0
  681. package/src/stream.js +650 -0
  682. package/src/stream.js.map +1 -0
  683. package/src/stream.test.js +225 -0
  684. package/src/stream.test.js.map +1 -0
  685. package/src/stream.test.ts +25 -15
  686. package/src/stream.ts +82 -32
  687. package/src/test/mockTools.js +340 -0
  688. package/src/test/mockTools.js.map +1 -0
  689. package/src/tools/AskUser.ts +159 -0
  690. package/src/tools/BrowserTools.js +245 -0
  691. package/src/tools/BrowserTools.js.map +1 -0
  692. package/src/tools/BrowserTools.ts +12 -8
  693. package/src/tools/Calculator.js +38 -0
  694. package/src/tools/Calculator.js.map +1 -0
  695. package/src/tools/Calculator.test.js +225 -0
  696. package/src/tools/Calculator.test.js.map +1 -0
  697. package/src/tools/CodeExecutor.js +233 -0
  698. package/src/tools/CodeExecutor.js.map +1 -0
  699. package/src/tools/CodeExecutor.selfhealing.test.ts +435 -0
  700. package/src/tools/CodeExecutor.ts +82 -5
  701. package/src/tools/ProgrammaticToolCalling.js +602 -0
  702. package/src/tools/ProgrammaticToolCalling.js.map +1 -0
  703. package/src/tools/ProgrammaticToolCalling.ts +40 -52
  704. package/src/tools/StreamingToolCallBuffer.js +179 -0
  705. package/src/tools/StreamingToolCallBuffer.js.map +1 -0
  706. package/src/tools/StreamingToolCallBuffer.ts +218 -0
  707. package/src/tools/ToolNode.js +930 -0
  708. package/src/tools/ToolNode.js.map +1 -0
  709. package/src/tools/ToolNode.ts +454 -41
  710. package/src/tools/ToolSearch.js +904 -0
  711. package/src/tools/ToolSearch.js.map +1 -0
  712. package/src/tools/ToolSearch.ts +84 -33
  713. package/src/tools/__tests__/AskUser.test.ts +537 -0
  714. package/src/tools/__tests__/BrowserTools.test.js +306 -0
  715. package/src/tools/__tests__/BrowserTools.test.js.map +1 -0
  716. package/src/tools/__tests__/BrowserTools.test.ts +131 -6
  717. package/src/tools/__tests__/CodeExecutor.test.ts +76 -0
  718. package/src/tools/__tests__/ProgrammaticToolCalling.integration.test.js +276 -0
  719. package/src/tools/__tests__/ProgrammaticToolCalling.integration.test.js.map +1 -0
  720. package/src/tools/__tests__/ProgrammaticToolCalling.test.js +807 -0
  721. package/src/tools/__tests__/ProgrammaticToolCalling.test.js.map +1 -0
  722. package/src/tools/__tests__/StreamingToolCallBuffer.test.js +175 -0
  723. package/src/tools/__tests__/StreamingToolCallBuffer.test.js.map +1 -0
  724. package/src/tools/__tests__/StreamingToolCallBuffer.test.ts +263 -0
  725. package/src/tools/__tests__/ToolApproval.test.js +675 -0
  726. package/src/tools/__tests__/ToolApproval.test.js.map +1 -0
  727. package/src/tools/__tests__/ToolApproval.test.ts +194 -20
  728. package/src/tools/__tests__/ToolNode.hitl.test.ts +267 -0
  729. package/src/tools/__tests__/ToolNode.recovery.test.js +200 -0
  730. package/src/tools/__tests__/ToolNode.recovery.test.js.map +1 -0
  731. package/src/tools/__tests__/ToolNode.recovery.test.ts +276 -0
  732. package/src/tools/__tests__/ToolNode.session.test.js +319 -0
  733. package/src/tools/__tests__/ToolNode.session.test.js.map +1 -0
  734. package/src/tools/__tests__/ToolNode.session.test.ts +465 -0
  735. package/src/tools/__tests__/ToolSearch.integration.test.js +125 -0
  736. package/src/tools/__tests__/ToolSearch.integration.test.js.map +1 -0
  737. package/src/tools/__tests__/ToolSearch.test.js +812 -0
  738. package/src/tools/__tests__/ToolSearch.test.js.map +1 -0
  739. package/src/tools/__tests__/ToolSearch.test.ts +78 -5
  740. package/src/tools/__tests__/handlers.test.js +799 -0
  741. package/src/tools/__tests__/handlers.test.js.map +1 -0
  742. package/src/tools/__tests__/handlers.test.ts +1100 -0
  743. package/src/tools/__tests__/truncation-recovery.integration.test.js +362 -0
  744. package/src/tools/__tests__/truncation-recovery.integration.test.js.map +1 -0
  745. package/src/tools/__tests__/truncation-recovery.integration.test.ts +560 -0
  746. package/src/tools/handlers.js +306 -0
  747. package/src/tools/handlers.js.map +1 -0
  748. package/src/tools/handlers.ts +119 -16
  749. package/src/tools/schema.js +25 -0
  750. package/src/tools/schema.js.map +1 -0
  751. package/src/tools/search/anthropic.js +34 -0
  752. package/src/tools/search/anthropic.js.map +1 -0
  753. package/src/tools/search/content.js +116 -0
  754. package/src/tools/search/content.js.map +1 -0
  755. package/src/tools/search/content.test.js +133 -0
  756. package/src/tools/search/content.test.js.map +1 -0
  757. package/src/tools/search/firecrawl.js +173 -0
  758. package/src/tools/search/firecrawl.js.map +1 -0
  759. package/src/tools/search/format.js +198 -0
  760. package/src/tools/search/format.js.map +1 -0
  761. package/src/tools/search/highlights.js +241 -0
  762. package/src/tools/search/highlights.js.map +1 -0
  763. package/src/tools/search/index.js +3 -0
  764. package/src/tools/search/index.js.map +1 -0
  765. package/src/tools/search/jina-reranker.test.js +106 -0
  766. package/src/tools/search/jina-reranker.test.js.map +1 -0
  767. package/src/tools/search/rerankers.js +165 -0
  768. package/src/tools/search/rerankers.js.map +1 -0
  769. package/src/tools/search/schema.js +102 -0
  770. package/src/tools/search/schema.js.map +1 -0
  771. package/src/tools/search/search.js +561 -0
  772. package/src/tools/search/search.js.map +1 -0
  773. package/src/tools/search/serper-scraper.js +126 -0
  774. package/src/tools/search/serper-scraper.js.map +1 -0
  775. package/src/tools/search/test.js +129 -0
  776. package/src/tools/search/test.js.map +1 -0
  777. package/src/tools/search/tool.js +453 -0
  778. package/src/tools/search/tool.js.map +1 -0
  779. package/src/tools/search/types.js +2 -0
  780. package/src/tools/search/types.js.map +1 -0
  781. package/src/tools/search/utils.js +59 -0
  782. package/src/tools/search/utils.js.map +1 -0
  783. package/src/types/graph.js +24 -0
  784. package/src/types/graph.js.map +1 -0
  785. package/src/types/graph.test.js +192 -0
  786. package/src/types/graph.test.js.map +1 -0
  787. package/src/types/graph.ts +26 -6
  788. package/src/types/index.js +7 -0
  789. package/src/types/index.js.map +1 -0
  790. package/src/types/llm.js +2 -0
  791. package/src/types/llm.js.map +1 -0
  792. package/src/types/llm.ts +8 -3
  793. package/src/types/messages.js +2 -0
  794. package/src/types/messages.js.map +1 -0
  795. package/src/types/run.js +2 -0
  796. package/src/types/run.js.map +1 -0
  797. package/src/types/run.ts +2 -0
  798. package/src/types/stream.js +2 -0
  799. package/src/types/stream.js.map +1 -0
  800. package/src/types/tools.js +2 -0
  801. package/src/types/tools.js.map +1 -0
  802. package/src/types/tools.ts +21 -2
  803. package/src/utils/contextAnalytics.js +79 -0
  804. package/src/utils/contextAnalytics.js.map +1 -0
  805. package/src/utils/contextAnalytics.test.js +166 -0
  806. package/src/utils/contextAnalytics.test.js.map +1 -0
  807. package/src/utils/contextAnalytics.test.ts +222 -0
  808. package/src/utils/contextAnalytics.ts +27 -9
  809. package/src/utils/events.js +26 -0
  810. package/src/utils/events.js.map +1 -0
  811. package/src/utils/graph.js +11 -0
  812. package/src/utils/graph.js.map +1 -0
  813. package/src/utils/handlers.js +65 -0
  814. package/src/utils/handlers.js.map +1 -0
  815. package/src/utils/index.js +10 -0
  816. package/src/utils/index.js.map +1 -0
  817. package/src/utils/index.ts +1 -0
  818. package/src/utils/llm.js +21 -0
  819. package/src/utils/llm.js.map +1 -0
  820. package/src/utils/llmConfig.js +205 -0
  821. package/src/utils/llmConfig.js.map +1 -0
  822. package/src/utils/llmConfig.ts +5 -5
  823. package/src/utils/logging.js +37 -0
  824. package/src/utils/logging.js.map +1 -0
  825. package/src/utils/misc.js +51 -0
  826. package/src/utils/misc.js.map +1 -0
  827. package/src/utils/run.js +69 -0
  828. package/src/utils/run.js.map +1 -0
  829. package/src/utils/run.ts +108 -106
  830. package/src/utils/schema.js +21 -0
  831. package/src/utils/schema.js.map +1 -0
  832. package/src/utils/title.js +119 -0
  833. package/src/utils/title.js.map +1 -0
  834. package/src/utils/tokens.js +92 -0
  835. package/src/utils/tokens.js.map +1 -0
  836. package/src/utils/tokens.ts +118 -142
  837. package/src/utils/toolCallContinuation.ts +55 -0
  838. package/src/utils/toonFormat.js +379 -0
  839. package/src/utils/toonFormat.js.map +1 -0
@@ -0,0 +1,973 @@
1
+ /* eslint-disable @typescript-eslint/no-explicit-any */
2
+ import { AIMessage, AIMessageChunk, ToolMessage, HumanMessage, SystemMessage, } from '@langchain/core/messages';
3
+ import { Providers, ContentTypes, Constants } from '@/common';
4
+ import { processToolOutput } from '@/utils/toonFormat';
5
+ /**
6
+ * Formats a message with media content (images, documents, videos, audios) to API payload format.
7
+ *
8
+ * @param params - The parameters for formatting.
9
+ * @returns - The formatted message.
10
+ */
11
+ export const formatMediaMessage = ({ message, endpoint, mediaParts, }) => {
12
+ // Create a new object to avoid mutating the input
13
+ const result = {
14
+ ...message,
15
+ content: [],
16
+ };
17
+ if (endpoint === Providers.ANTHROPIC) {
18
+ result.content = [
19
+ ...mediaParts,
20
+ { type: ContentTypes.TEXT, text: message.content },
21
+ ];
22
+ return result;
23
+ }
24
+ result.content = [
25
+ { type: ContentTypes.TEXT, text: message.content },
26
+ ...mediaParts,
27
+ ];
28
+ return result;
29
+ };
30
+ /**
31
+ * Formats a message to OpenAI payload format based on the provided options.
32
+ *
33
+ * @param params - The parameters for formatting.
34
+ * @returns - The formatted message.
35
+ */
36
+ export const formatMessage = ({ message, userName, endpoint, assistantName, langChain = false, }) => {
37
+ // eslint-disable-next-line prefer-const
38
+ let { role: _role, _name, sender, text, content: _content, lc_id } = message;
39
+ if (lc_id && lc_id[2] && !langChain) {
40
+ const roleMapping = {
41
+ SystemMessage: 'system',
42
+ HumanMessage: 'user',
43
+ AIMessage: 'assistant',
44
+ };
45
+ _role = roleMapping[lc_id[2]] || _role;
46
+ }
47
+ const role = _role ??
48
+ (sender != null && sender && sender.toLowerCase() === 'user'
49
+ ? 'user'
50
+ : 'assistant');
51
+ const content = _content ?? text ?? '';
52
+ const formattedMessage = {
53
+ role,
54
+ content,
55
+ };
56
+ // Set name fields first
57
+ if (_name != null && _name) {
58
+ formattedMessage.name = _name;
59
+ }
60
+ if (userName != null && userName && formattedMessage.role === 'user') {
61
+ formattedMessage.name = userName;
62
+ }
63
+ if (assistantName != null &&
64
+ assistantName &&
65
+ formattedMessage.role === 'assistant') {
66
+ formattedMessage.name = assistantName;
67
+ }
68
+ if (formattedMessage.name != null && formattedMessage.name) {
69
+ // Conform to API regex: ^[a-zA-Z0-9_-]{1,64}$
70
+ // https://community.openai.com/t/the-format-of-the-name-field-in-the-documentation-is-incorrect/175684/2
71
+ formattedMessage.name = formattedMessage.name.replace(/[^a-zA-Z0-9_-]/g, '_');
72
+ if (formattedMessage.name.length > 64) {
73
+ formattedMessage.name = formattedMessage.name.substring(0, 64);
74
+ }
75
+ }
76
+ const { image_urls, documents, videos, audios } = message;
77
+ const mediaParts = [];
78
+ if (Array.isArray(documents) && documents.length > 0) {
79
+ mediaParts.push(...documents);
80
+ }
81
+ if (Array.isArray(videos) && videos.length > 0) {
82
+ mediaParts.push(...videos);
83
+ }
84
+ if (Array.isArray(audios) && audios.length > 0) {
85
+ mediaParts.push(...audios);
86
+ }
87
+ if (Array.isArray(image_urls) && image_urls.length > 0) {
88
+ mediaParts.push(...image_urls);
89
+ }
90
+ if (mediaParts.length > 0 && role === 'user') {
91
+ const mediaMessage = formatMediaMessage({
92
+ message: {
93
+ ...formattedMessage,
94
+ content: typeof formattedMessage.content === 'string'
95
+ ? formattedMessage.content
96
+ : '',
97
+ },
98
+ mediaParts,
99
+ endpoint,
100
+ });
101
+ if (!langChain) {
102
+ return mediaMessage;
103
+ }
104
+ return new HumanMessage(mediaMessage);
105
+ }
106
+ if (!langChain) {
107
+ return formattedMessage;
108
+ }
109
+ if (role === 'user') {
110
+ return new HumanMessage(formattedMessage);
111
+ }
112
+ else if (role === 'assistant') {
113
+ return new AIMessage(formattedMessage);
114
+ }
115
+ else {
116
+ return new SystemMessage(formattedMessage);
117
+ }
118
+ };
119
+ /**
120
+ * Formats an array of messages for LangChain.
121
+ *
122
+ * @param messages - The array of messages to format.
123
+ * @param formatOptions - The options for formatting each message.
124
+ * @returns - The array of formatted LangChain messages.
125
+ */
126
+ export const formatLangChainMessages = (messages, formatOptions) => {
127
+ return messages.map((msg) => {
128
+ const formatted = formatMessage({
129
+ ...formatOptions,
130
+ message: msg,
131
+ langChain: true,
132
+ });
133
+ return formatted;
134
+ });
135
+ };
136
+ /**
137
+ * Formats a LangChain message object by merging properties from `lc_kwargs` or `kwargs` and `additional_kwargs`.
138
+ *
139
+ * @param message - The message object to format.
140
+ * @returns - The formatted LangChain message.
141
+ */
142
+ export const formatFromLangChain = (message) => {
143
+ const kwargs = message.lc_kwargs ?? message.kwargs ?? {};
144
+ const { additional_kwargs = {}, ...message_kwargs } = kwargs;
145
+ return {
146
+ ...message_kwargs,
147
+ ...additional_kwargs,
148
+ };
149
+ };
150
+ /**
151
+ * Helper function to format an assistant message
152
+ * @param message The message to format
153
+ * @returns Array of formatted messages
154
+ */
155
+ function formatAssistantMessage(message) {
156
+ const formattedMessages = [];
157
+ let currentContent = [];
158
+ let lastAIMessage = null;
159
+ let hasReasoning = false;
160
+ if (Array.isArray(message.content)) {
161
+ for (const part of message.content) {
162
+ if (part == null) {
163
+ continue;
164
+ }
165
+ if (part.type === ContentTypes.TEXT && part.tool_call_ids) {
166
+ /*
167
+ If there's pending content, it needs to be aggregated as a single string to prepare for tool calls.
168
+ For Anthropic models, the "tool_calls" field on a message is only respected if content is a string.
169
+ */
170
+ if (currentContent.length > 0) {
171
+ let content = currentContent.reduce((acc, curr) => {
172
+ if (curr.type === ContentTypes.TEXT) {
173
+ return `${acc}${String(curr[ContentTypes.TEXT] ?? '')}\n`;
174
+ }
175
+ return acc;
176
+ }, '');
177
+ content =
178
+ `${content}\n${part[ContentTypes.TEXT] ?? part.text ?? ''}`.trim();
179
+ lastAIMessage = new AIMessage({ content });
180
+ formattedMessages.push(lastAIMessage);
181
+ currentContent = [];
182
+ continue;
183
+ }
184
+ // Create a new AIMessage with this text and prepare for tool calls
185
+ lastAIMessage = new AIMessage({
186
+ content: part.text != null ? part.text : '',
187
+ });
188
+ formattedMessages.push(lastAIMessage);
189
+ }
190
+ else if (part.type === ContentTypes.TOOL_CALL) {
191
+ // Skip malformed tool call entries without tool_call property
192
+ if (part.tool_call == null) {
193
+ continue;
194
+ }
195
+ // Note: `tool_calls` list is defined when constructed by `AIMessage` class, and outputs should be excluded from it
196
+ const { output, args: _args, ..._tool_call } = part.tool_call;
197
+ // Skip invalid tool calls that have no name AND no output
198
+ if (_tool_call.name == null ||
199
+ (_tool_call.name === '' && (output == null || output === ''))) {
200
+ continue;
201
+ }
202
+ if (!lastAIMessage) {
203
+ // "Heal" the payload by creating an AIMessage to precede the tool call
204
+ lastAIMessage = new AIMessage({ content: '' });
205
+ formattedMessages.push(lastAIMessage);
206
+ }
207
+ const tool_call = _tool_call;
208
+ // TODO: investigate; args as dictionary may need to be providers-or-tool-specific
209
+ let args = _args;
210
+ try {
211
+ if (typeof _args === 'string') {
212
+ args = JSON.parse(_args);
213
+ }
214
+ }
215
+ catch {
216
+ if (typeof _args === 'string') {
217
+ args = { input: _args };
218
+ }
219
+ }
220
+ tool_call.args = args;
221
+ if (!lastAIMessage.tool_calls) {
222
+ lastAIMessage.tool_calls = [];
223
+ }
224
+ lastAIMessage.tool_calls.push(tool_call);
225
+ // Apply TOON compression to historical tool outputs for context efficiency
226
+ // processToolOutput handles: JSON→TOON conversion, already-TOON detection (skip), truncation
227
+ // Skip TOON for content_tool — its output is line-numbered source code that must stay verbatim
228
+ // for accurate edit (str_replace) matching.
229
+ const processedOutput = output != null
230
+ ? processToolOutput(output, {
231
+ enableToon: tool_call.name !== 'content_tool',
232
+ }).content
233
+ : '';
234
+ formattedMessages.push(new ToolMessage({
235
+ tool_call_id: tool_call.id ?? '',
236
+ name: tool_call.name,
237
+ content: processedOutput,
238
+ }));
239
+ }
240
+ else if (part.type === ContentTypes.THINK ||
241
+ part.type === ContentTypes.THINKING ||
242
+ part.type === ContentTypes.REASONING_CONTENT ||
243
+ part.type === 'redacted_thinking') {
244
+ hasReasoning = true;
245
+ continue;
246
+ }
247
+ else if (part.type === ContentTypes.ERROR ||
248
+ part.type === ContentTypes.AGENT_UPDATE) {
249
+ continue;
250
+ }
251
+ else {
252
+ if (part.type === ContentTypes.TEXT &&
253
+ !String(part.text ?? '').trim()) {
254
+ continue;
255
+ }
256
+ currentContent.push(part);
257
+ }
258
+ }
259
+ }
260
+ if (hasReasoning && currentContent.length > 0) {
261
+ const content = currentContent
262
+ .reduce((acc, curr) => {
263
+ if (curr.type === ContentTypes.TEXT) {
264
+ return `${acc}${String(curr[ContentTypes.TEXT] ?? '')}\n`;
265
+ }
266
+ return acc;
267
+ }, '')
268
+ .trim();
269
+ if (content) {
270
+ formattedMessages.push(new AIMessage({ content }));
271
+ }
272
+ }
273
+ else if (currentContent.length > 0) {
274
+ formattedMessages.push(new AIMessage({ content: currentContent }));
275
+ }
276
+ return formattedMessages;
277
+ }
278
+ /**
279
+ * Labels all agent content for parallel patterns (fan-out/fan-in)
280
+ * Groups consecutive content by agent and wraps with clear labels
281
+ */
282
+ function labelAllAgentContent(contentParts, agentIdMap, agentNames) {
283
+ const result = [];
284
+ let currentAgentId;
285
+ let agentContentBuffer = [];
286
+ const flushAgentBuffer = () => {
287
+ if (agentContentBuffer.length === 0) {
288
+ return;
289
+ }
290
+ if (currentAgentId != null && currentAgentId !== '') {
291
+ const agentName = (agentNames?.[currentAgentId] ?? '') || currentAgentId;
292
+ const formattedParts = [];
293
+ formattedParts.push(`--- ${agentName} ---`);
294
+ for (const part of agentContentBuffer) {
295
+ if (part.type === ContentTypes.THINK) {
296
+ const thinkContent = part.think || '';
297
+ if (thinkContent) {
298
+ formattedParts.push(`${agentName}: ${JSON.stringify({
299
+ type: 'think',
300
+ think: thinkContent,
301
+ })}`);
302
+ }
303
+ }
304
+ else if (part.type === ContentTypes.TEXT) {
305
+ const textContent = part.text ?? '';
306
+ if (textContent) {
307
+ formattedParts.push(`${agentName}: ${textContent}`);
308
+ }
309
+ }
310
+ else if (part.type === ContentTypes.TOOL_CALL) {
311
+ formattedParts.push(`${agentName}: ${JSON.stringify({
312
+ type: 'tool_call',
313
+ tool_call: part.tool_call,
314
+ })}`);
315
+ }
316
+ }
317
+ formattedParts.push(`--- End of ${agentName} ---`);
318
+ // Create a single text content part with all agent content
319
+ result.push({
320
+ type: ContentTypes.TEXT,
321
+ text: formattedParts.join('\n\n'),
322
+ });
323
+ }
324
+ else {
325
+ // No agent ID, pass through as-is
326
+ result.push(...agentContentBuffer);
327
+ }
328
+ agentContentBuffer = [];
329
+ };
330
+ for (let i = 0; i < contentParts.length; i++) {
331
+ const part = contentParts[i];
332
+ const agentId = agentIdMap[i];
333
+ // If agent changed, flush previous buffer
334
+ if (agentId !== currentAgentId && currentAgentId !== undefined) {
335
+ flushAgentBuffer();
336
+ }
337
+ currentAgentId = agentId;
338
+ agentContentBuffer.push(part);
339
+ }
340
+ // Flush any remaining content
341
+ flushAgentBuffer();
342
+ return result;
343
+ }
344
+ /**
345
+ * Groups content parts by agent and formats them with agent labels
346
+ * This preprocesses multi-agent content to prevent identity confusion
347
+ *
348
+ * @param contentParts - The content parts from a run
349
+ * @param agentIdMap - Map of content part index to agent ID
350
+ * @param agentNames - Optional map of agent ID to display name
351
+ * @param options - Configuration options
352
+ * @param options.labelNonTransferContent - If true, labels all agent transitions (for parallel patterns)
353
+ * @returns Modified content parts with agent labels where appropriate
354
+ */
355
+ export const labelContentByAgent = (contentParts, agentIdMap, agentNames, options) => {
356
+ if (!agentIdMap || Object.keys(agentIdMap).length === 0) {
357
+ return contentParts;
358
+ }
359
+ // If labelNonTransferContent is true, use a different strategy for parallel patterns
360
+ if (options?.labelNonTransferContent === true) {
361
+ return labelAllAgentContent(contentParts, agentIdMap, agentNames);
362
+ }
363
+ const result = [];
364
+ let currentAgentId;
365
+ let agentContentBuffer = [];
366
+ let transferToolCallIndex;
367
+ let transferToolCallId;
368
+ const flushAgentBuffer = () => {
369
+ if (agentContentBuffer.length === 0) {
370
+ return;
371
+ }
372
+ // If this is content from a transferred agent, format it specially
373
+ if (currentAgentId != null &&
374
+ currentAgentId !== '' &&
375
+ transferToolCallIndex !== undefined) {
376
+ const agentName = (agentNames?.[currentAgentId] ?? '') || currentAgentId;
377
+ const formattedParts = [];
378
+ formattedParts.push(`--- Transfer to ${agentName} ---`);
379
+ for (const part of agentContentBuffer) {
380
+ if (part.type === ContentTypes.THINK) {
381
+ formattedParts.push(`${agentName}: ${JSON.stringify({
382
+ type: 'think',
383
+ think: part.think,
384
+ })}`);
385
+ }
386
+ else if ('text' in part && part.type === ContentTypes.TEXT) {
387
+ const textContent = part.text ?? '';
388
+ if (textContent) {
389
+ formattedParts.push(`${agentName}: ${JSON.stringify({
390
+ type: 'text',
391
+ text: textContent,
392
+ })}`);
393
+ }
394
+ }
395
+ else if (part.type === ContentTypes.TOOL_CALL) {
396
+ formattedParts.push(`${agentName}: ${JSON.stringify({
397
+ type: 'tool_call',
398
+ tool_call: part.tool_call,
399
+ })}`);
400
+ }
401
+ }
402
+ formattedParts.push(`--- End of ${agentName} response ---`);
403
+ // Find the tool call that triggered this transfer and update its output
404
+ if (transferToolCallIndex < result.length) {
405
+ const transferToolCall = result[transferToolCallIndex];
406
+ if (transferToolCall.type === ContentTypes.TOOL_CALL &&
407
+ transferToolCall.tool_call?.id === transferToolCallId) {
408
+ transferToolCall.tool_call.output = formattedParts.join('\n\n');
409
+ }
410
+ }
411
+ }
412
+ else {
413
+ // Not from a transfer, add as-is
414
+ result.push(...agentContentBuffer);
415
+ }
416
+ agentContentBuffer = [];
417
+ transferToolCallIndex = undefined;
418
+ transferToolCallId = undefined;
419
+ };
420
+ for (let i = 0; i < contentParts.length; i++) {
421
+ const part = contentParts[i];
422
+ const agentId = agentIdMap[i];
423
+ // Check if this is a transfer tool call
424
+ const isTransferTool = (part.type === ContentTypes.TOOL_CALL &&
425
+ part.tool_call?.name?.startsWith('lc_transfer_to_')) ??
426
+ false;
427
+ // If agent changed, flush previous buffer
428
+ if (agentId !== currentAgentId && currentAgentId !== undefined) {
429
+ flushAgentBuffer();
430
+ }
431
+ currentAgentId = agentId;
432
+ if (isTransferTool) {
433
+ // Flush any existing buffer first
434
+ flushAgentBuffer();
435
+ // Add the transfer tool call to result
436
+ result.push(part);
437
+ // Mark that the next agent's content should be captured
438
+ transferToolCallIndex = result.length - 1;
439
+ transferToolCallId = part.tool_call?.id;
440
+ currentAgentId = undefined; // Reset to capture the next agent
441
+ }
442
+ else {
443
+ agentContentBuffer.push(part);
444
+ }
445
+ }
446
+ flushAgentBuffer();
447
+ return result;
448
+ };
449
+ /** Extracts tool names from a tool_search output JSON string. */
450
+ function extractToolNamesFromSearchOutput(output) {
451
+ try {
452
+ const parsed = JSON.parse(output);
453
+ if (typeof parsed === 'object' &&
454
+ parsed !== null &&
455
+ Array.isArray(parsed.tools)) {
456
+ return parsed.tools
457
+ .map((t) => t.name)
458
+ .filter((name) => typeof name === 'string');
459
+ }
460
+ }
461
+ catch {
462
+ /** Output may have warnings prepended, try to find JSON within it */
463
+ const jsonMatch = output.match(/\{[\s\S]*\}/);
464
+ if (jsonMatch) {
465
+ try {
466
+ const parsed = JSON.parse(jsonMatch[0]);
467
+ if (typeof parsed === 'object' &&
468
+ parsed !== null &&
469
+ Array.isArray(parsed.tools)) {
470
+ return parsed.tools
471
+ .map((t) => t.name)
472
+ .filter((name) => typeof name === 'string');
473
+ }
474
+ }
475
+ catch {
476
+ /* ignore */
477
+ }
478
+ }
479
+ }
480
+ return [];
481
+ }
482
+ /**
483
+ * Formats an array of messages for LangChain, handling tool calls and creating ToolMessage instances.
484
+ *
485
+ * @param payload - The array of messages to format.
486
+ * @param indexTokenCountMap - Optional map of message indices to token counts.
487
+ * @param tools - Optional set of tool names that are allowed in the request.
488
+ * @returns - Object containing formatted messages and updated indexTokenCountMap if provided.
489
+ */
490
+ export const formatAgentMessages = (payload, indexTokenCountMap, tools) => {
491
+ const messages = [];
492
+ // If indexTokenCountMap is provided, create a new map to track the updated indices
493
+ const updatedIndexTokenCountMap = {};
494
+ // Keep track of the mapping from original payload indices to result indices
495
+ const indexMapping = {};
496
+ /**
497
+ * Create a mutable copy of the tools set that can be expanded dynamically.
498
+ * When we encounter tool_search results, we add discovered tools to this set,
499
+ * making their subsequent tool calls valid.
500
+ */
501
+ const discoveredTools = tools ? new Set(tools) : undefined;
502
+ // Process messages with tool conversion if tools set is provided
503
+ for (let i = 0; i < payload.length; i++) {
504
+ const message = payload[i];
505
+ // Q: Store the current length of messages to track where this payload message starts in the result?
506
+ // const startIndex = messages.length;
507
+ if (typeof message.content === 'string') {
508
+ message.content = [
509
+ { type: ContentTypes.TEXT, [ContentTypes.TEXT]: message.content },
510
+ ];
511
+ }
512
+ if (message.role !== 'assistant') {
513
+ messages.push(formatMessage({
514
+ message: message,
515
+ langChain: true,
516
+ }));
517
+ // Update the index mapping for this message
518
+ indexMapping[i] = [messages.length - 1];
519
+ continue;
520
+ }
521
+ // For assistant messages, track the starting index before processing
522
+ const startMessageIndex = messages.length;
523
+ /**
524
+ * If tools set is provided, process tool_calls:
525
+ * - Keep valid tool_calls (tools in the set or dynamically discovered)
526
+ * - Convert invalid tool_calls to string representation for context preservation
527
+ * - Dynamically expand the set when tool_search results are encountered
528
+ */
529
+ let processedMessage = message;
530
+ if (discoveredTools) {
531
+ const content = message.content;
532
+ if (content && Array.isArray(content)) {
533
+ const filteredContent = [];
534
+ const invalidToolCallIds = new Set();
535
+ const invalidToolStrings = [];
536
+ for (const part of content) {
537
+ if (part.type !== ContentTypes.TOOL_CALL) {
538
+ filteredContent.push(part);
539
+ continue;
540
+ }
541
+ /** Skip malformed tool_call entries */
542
+ if (part.tool_call == null ||
543
+ part.tool_call.name == null ||
544
+ part.tool_call.name === '') {
545
+ if (typeof part.tool_call?.id === 'string' &&
546
+ part.tool_call.id !== '') {
547
+ invalidToolCallIds.add(part.tool_call.id);
548
+ }
549
+ continue;
550
+ }
551
+ const toolName = part.tool_call.name;
552
+ /**
553
+ * If this is a tool_search result with output, extract discovered tool names
554
+ * and add them to the discoveredTools set for subsequent validation.
555
+ */
556
+ if (toolName === Constants.TOOL_SEARCH &&
557
+ typeof part.tool_call.output === 'string' &&
558
+ part.tool_call.output !== '') {
559
+ const extracted = extractToolNamesFromSearchOutput(part.tool_call.output);
560
+ for (const name of extracted) {
561
+ discoveredTools.add(name);
562
+ }
563
+ }
564
+ if (discoveredTools.has(toolName)) {
565
+ /** Valid tool - keep it */
566
+ filteredContent.push(part);
567
+ }
568
+ else {
569
+ /** Invalid tool - convert to string for context preservation */
570
+ if (typeof part.tool_call.id === 'string' &&
571
+ part.tool_call.id !== '') {
572
+ invalidToolCallIds.add(part.tool_call.id);
573
+ }
574
+ const output = part.tool_call.output ?? '';
575
+ invalidToolStrings.push(`Tool: ${toolName}, ${output}`);
576
+ }
577
+ }
578
+ /** Remove tool_call_ids references to invalid tools from text parts */
579
+ if (invalidToolCallIds.size > 0) {
580
+ for (const part of filteredContent) {
581
+ if (part.type === ContentTypes.TEXT &&
582
+ Array.isArray(part.tool_call_ids)) {
583
+ part.tool_call_ids = part.tool_call_ids.filter((id) => !invalidToolCallIds.has(id));
584
+ if (part.tool_call_ids.length === 0) {
585
+ delete part.tool_call_ids;
586
+ }
587
+ }
588
+ }
589
+ }
590
+ /** Append invalid tool strings to the content for context preservation */
591
+ if (invalidToolStrings.length > 0) {
592
+ /** Find the last text part or create one */
593
+ let lastTextPartIndex = -1;
594
+ for (let j = filteredContent.length - 1; j >= 0; j--) {
595
+ if (filteredContent[j].type === ContentTypes.TEXT) {
596
+ lastTextPartIndex = j;
597
+ break;
598
+ }
599
+ }
600
+ const invalidToolText = invalidToolStrings.join('\n');
601
+ if (lastTextPartIndex >= 0) {
602
+ const lastTextPart = filteredContent[lastTextPartIndex];
603
+ const existingText = lastTextPart[ContentTypes.TEXT] ?? lastTextPart.text ?? '';
604
+ filteredContent[lastTextPartIndex] = {
605
+ ...lastTextPart,
606
+ [ContentTypes.TEXT]: existingText
607
+ ? `${existingText}\n${invalidToolText}`
608
+ : invalidToolText,
609
+ };
610
+ }
611
+ else {
612
+ /** No text part exists, create one */
613
+ filteredContent.push({
614
+ type: ContentTypes.TEXT,
615
+ [ContentTypes.TEXT]: invalidToolText,
616
+ });
617
+ }
618
+ }
619
+ /** Use filtered content if we made any changes */
620
+ if (filteredContent.length !== content.length ||
621
+ invalidToolStrings.length > 0) {
622
+ processedMessage = { ...message, content: filteredContent };
623
+ }
624
+ }
625
+ }
626
+ // Process the assistant message using the helper function
627
+ const formattedMessages = formatAssistantMessage(processedMessage);
628
+ messages.push(...formattedMessages);
629
+ // Update the index mapping for this assistant message
630
+ // Store all indices that were created from this original message
631
+ const endMessageIndex = messages.length;
632
+ const resultIndices = [];
633
+ for (let j = startMessageIndex; j < endMessageIndex; j++) {
634
+ resultIndices.push(j);
635
+ }
636
+ indexMapping[i] = resultIndices;
637
+ }
638
+ if (indexTokenCountMap) {
639
+ for (let originalIndex = 0; originalIndex < payload.length; originalIndex++) {
640
+ const resultIndices = indexMapping[originalIndex] || [];
641
+ const tokenCount = indexTokenCountMap[originalIndex];
642
+ if (tokenCount === undefined) {
643
+ continue;
644
+ }
645
+ const msgCount = resultIndices.length;
646
+ if (msgCount === 1) {
647
+ updatedIndexTokenCountMap[resultIndices[0]] = tokenCount;
648
+ continue;
649
+ }
650
+ if (msgCount < 2) {
651
+ continue;
652
+ }
653
+ let totalLength = 0;
654
+ const lastIdx = msgCount - 1;
655
+ const lengths = new Array(msgCount);
656
+ for (let k = 0; k < msgCount; k++) {
657
+ const msg = messages[resultIndices[k]];
658
+ const { content } = msg;
659
+ let len = 0;
660
+ if (typeof content === 'string') {
661
+ len = content.length;
662
+ }
663
+ else if (Array.isArray(content)) {
664
+ for (const part of content) {
665
+ if (typeof part === 'string') {
666
+ len += part.length;
667
+ }
668
+ else if (part != null && typeof part === 'object') {
669
+ const val = part.text ?? part.content;
670
+ if (typeof val === 'string') {
671
+ len += val.length;
672
+ }
673
+ }
674
+ }
675
+ }
676
+ const toolCalls = msg.tool_calls;
677
+ if (Array.isArray(toolCalls)) {
678
+ for (const tc of toolCalls) {
679
+ if (typeof tc.name === 'string') {
680
+ len += tc.name.length;
681
+ }
682
+ const { args } = tc;
683
+ if (typeof args === 'string') {
684
+ len += args.length;
685
+ }
686
+ else if (args != null) {
687
+ len += JSON.stringify(args).length;
688
+ }
689
+ }
690
+ }
691
+ lengths[k] = len;
692
+ totalLength += len;
693
+ }
694
+ if (totalLength === 0) {
695
+ const countPerMessage = Math.floor(tokenCount / msgCount);
696
+ for (let k = 0; k < lastIdx; k++) {
697
+ updatedIndexTokenCountMap[resultIndices[k]] = countPerMessage;
698
+ }
699
+ updatedIndexTokenCountMap[resultIndices[lastIdx]] =
700
+ tokenCount - countPerMessage * lastIdx;
701
+ }
702
+ else {
703
+ let distributed = 0;
704
+ for (let k = 0; k < lastIdx; k++) {
705
+ const share = Math.floor((lengths[k] / totalLength) * tokenCount);
706
+ updatedIndexTokenCountMap[resultIndices[k]] = share;
707
+ distributed += share;
708
+ }
709
+ updatedIndexTokenCountMap[resultIndices[lastIdx]] =
710
+ tokenCount - distributed;
711
+ }
712
+ }
713
+ }
714
+ return {
715
+ messages,
716
+ indexTokenCountMap: indexTokenCountMap
717
+ ? updatedIndexTokenCountMap
718
+ : undefined,
719
+ };
720
+ };
721
+ /**
722
+ * Adds a value at key 0 for system messages and shifts all key indices by one in an indexTokenCountMap.
723
+ * This is useful when adding a system message at the beginning of a conversation.
724
+ *
725
+ * @param indexTokenCountMap - The original map of message indices to token counts
726
+ * @param instructionsTokenCount - The token count for the system message to add at index 0
727
+ * @returns A new map with the system message at index 0 and all other indices shifted by 1
728
+ */
729
+ export function shiftIndexTokenCountMap(indexTokenCountMap, instructionsTokenCount) {
730
+ // Create a new map to avoid modifying the original
731
+ const shiftedMap = {};
732
+ shiftedMap[0] = instructionsTokenCount;
733
+ // Shift all existing indices by 1
734
+ for (const [indexStr, tokenCount] of Object.entries(indexTokenCountMap)) {
735
+ const index = Number(indexStr);
736
+ shiftedMap[index + 1] = tokenCount;
737
+ }
738
+ return shiftedMap;
739
+ }
740
+ /** Block types that contain binary image data and must be preserved structurally. */
741
+ const IMAGE_BLOCK_TYPES = new Set(['image_url', 'image']);
742
+ /** Checks whether a BaseMessage is a tool-role message. */
743
+ const isToolMessage = (m) => m instanceof ToolMessage || ('role' in m && m.role === 'tool');
744
+ /** Flushes accumulated text chunks into `parts` as a single text block. */
745
+ function flushTextChunks(textChunks, parts) {
746
+ if (textChunks.length === 0) {
747
+ return;
748
+ }
749
+ parts.push({
750
+ type: ContentTypes.TEXT,
751
+ text: textChunks.join('\n'),
752
+ });
753
+ textChunks.length = 0;
754
+ }
755
+ /**
756
+ * Appends a single message's content to the running `textChunks` / `parts`
757
+ * accumulators. Image blocks are shallow-copied into `parts` as-is so that
758
+ * binary data (base64 images) never becomes text tokens. All other block
759
+ * types are serialized to text — unrecognized types are JSON-serialized
760
+ * rather than silently dropped.
761
+ *
762
+ * When `content` is an array containing tool_use blocks, `tool_calls` is NOT
763
+ * additionally serialized (avoiding double output). `tool_calls` is used as
764
+ * a fallback when `content` is a plain string or an array with no tool_use.
765
+ */
766
+ function appendMessageContent(msg, role, textChunks, parts) {
767
+ const { content } = msg;
768
+ if (typeof content === 'string') {
769
+ if (content) {
770
+ textChunks.push(`${role}: ${content}`);
771
+ }
772
+ appendToolCalls(msg, role, textChunks);
773
+ return;
774
+ }
775
+ if (!Array.isArray(content)) {
776
+ appendToolCalls(msg, role, textChunks);
777
+ return;
778
+ }
779
+ let hasToolUseBlock = false;
780
+ for (const block of content) {
781
+ if (IMAGE_BLOCK_TYPES.has(block.type ?? '')) {
782
+ flushTextChunks(textChunks, parts);
783
+ parts.push({ ...block });
784
+ continue;
785
+ }
786
+ if (block.type === 'tool_use') {
787
+ hasToolUseBlock = true;
788
+ textChunks.push(`${role}: [tool_use] ${String(block.name ?? '')} ${JSON.stringify(block.input ?? {})}`);
789
+ continue;
790
+ }
791
+ const text = block.text ?? block.input;
792
+ if (typeof text === 'string' && text) {
793
+ textChunks.push(`${role}: ${text}`);
794
+ continue;
795
+ }
796
+ // Fallback: serialize unrecognized block types to preserve context
797
+ if (block.type != null && block.type !== '') {
798
+ textChunks.push(`${role}: [${block.type}] ${JSON.stringify(block)}`);
799
+ }
800
+ }
801
+ // If content array had no tool_use blocks, fall back to tool_calls metadata
802
+ // (handles edge case: empty content array with tool_calls populated)
803
+ if (!hasToolUseBlock) {
804
+ appendToolCalls(msg, role, textChunks);
805
+ }
806
+ }
807
+ function appendToolCalls(msg, role, textChunks) {
808
+ if (role !== 'AI') {
809
+ return;
810
+ }
811
+ const aiMsg = msg;
812
+ if (!aiMsg.tool_calls || aiMsg.tool_calls.length === 0) {
813
+ return;
814
+ }
815
+ for (const tc of aiMsg.tool_calls) {
816
+ textChunks.push(`AI: [tool_call] ${tc.name}(${JSON.stringify(tc.args)})`);
817
+ }
818
+ }
819
+ /**
820
+ * Ensures compatibility when switching from a non-thinking agent to a thinking-enabled agent.
821
+ * Converts AI messages with tool calls (that lack thinking/reasoning blocks) into buffer strings,
822
+ * avoiding the thinking block signature requirement.
823
+ *
824
+ * Recognizes the following as valid thinking/reasoning blocks:
825
+ * - ContentTypes.THINKING (Anthropic)
826
+ * - ContentTypes.REASONING_CONTENT (Bedrock)
827
+ * - ContentTypes.REASONING (VertexAI / Google)
828
+ * - 'redacted_thinking'
829
+ *
830
+ * @param messages - Array of messages to process
831
+ * @param provider - The provider being used (unused but kept for future compatibility)
832
+ * @returns The messages array with tool sequences converted to buffer strings if necessary
833
+ */
834
+ export function ensureThinkingBlockInMessages(messages, _provider) {
835
+ if (messages.length === 0) {
836
+ return messages;
837
+ }
838
+ // If the last message is already a HumanMessage, there is no trailing tool
839
+ // sequence to convert — return early to preserve prompt caching and avoid
840
+ // redundant token overhead from re-processing the entire history.
841
+ const lastMsg = messages[messages.length - 1];
842
+ const lastIsHuman = lastMsg instanceof HumanMessage ||
843
+ ('role' in lastMsg && lastMsg.role === 'user');
844
+ if (lastIsHuman) {
845
+ return messages;
846
+ }
847
+ const result = [];
848
+ let i = 0;
849
+ while (i < messages.length) {
850
+ const msg = messages[i];
851
+ /** Detect AI messages by instanceof OR by role, in case cache-control cloning
852
+ produced a plain object that lost the LangChain prototype. */
853
+ const isAI = msg instanceof AIMessage ||
854
+ msg instanceof AIMessageChunk ||
855
+ ('role' in msg && msg.role === 'assistant');
856
+ if (!isAI) {
857
+ result.push(msg);
858
+ i++;
859
+ continue;
860
+ }
861
+ const aiMsg = msg;
862
+ const hasToolCalls = aiMsg.tool_calls && aiMsg.tool_calls.length > 0;
863
+ const contentIsArray = Array.isArray(aiMsg.content);
864
+ // Check if the message has tool calls or tool_use content
865
+ let hasToolUse = hasToolCalls ?? false;
866
+ let hasThinkingBlock = false;
867
+ if (contentIsArray && aiMsg.content.length > 0) {
868
+ for (const c of aiMsg.content) {
869
+ if (typeof c !== 'object') {
870
+ continue;
871
+ }
872
+ if (c.type === 'tool_use') {
873
+ hasToolUse = true;
874
+ }
875
+ else if (c.type === ContentTypes.THINKING ||
876
+ c.type === ContentTypes.REASONING_CONTENT ||
877
+ c.type === ContentTypes.REASONING ||
878
+ c.type === 'redacted_thinking') {
879
+ hasThinkingBlock = true;
880
+ }
881
+ if (hasToolUse && hasThinkingBlock) {
882
+ break;
883
+ }
884
+ }
885
+ }
886
+ // Bedrock also stores reasoning in additional_kwargs (may not be in content array)
887
+ if (!hasThinkingBlock &&
888
+ aiMsg.additional_kwargs.reasoning_content != null) {
889
+ hasThinkingBlock = true;
890
+ }
891
+ // If message has tool use but no thinking block, check whether this is a
892
+ // continuation of a thinking-enabled agent's chain before converting.
893
+ // Bedrock reasoning models can produce multiple AI→Tool rounds after an
894
+ // initial reasoning response: the first AI message has reasoning_content,
895
+ // but follow-ups have content: "" with only tool_calls. These are the
896
+ // same agent's turn and must NOT be converted to HumanMessages.
897
+ if (hasToolUse && !hasThinkingBlock) {
898
+ // Walk backwards — if an earlier AI message in the same chain (before
899
+ // the nearest HumanMessage) has a thinking/reasoning block, this is a
900
+ // continuation of a thinking-enabled turn, not a non-thinking handoff.
901
+ if (chainHasThinkingBlock(messages, i)) {
902
+ result.push(msg);
903
+ i++;
904
+ continue;
905
+ }
906
+ // Build structured content in a single pass over the AI + following
907
+ // ToolMessages — preserves image blocks as-is to avoid serializing
908
+ // binary data as text (which caused 174× token amplification).
909
+ const parts = [];
910
+ const textChunks = ['[Previous agent context]'];
911
+ appendMessageContent(msg, 'AI', textChunks, parts);
912
+ let j = i + 1;
913
+ while (j < messages.length && isToolMessage(messages[j])) {
914
+ appendMessageContent(messages[j], 'Tool', textChunks, parts);
915
+ j++;
916
+ }
917
+ flushTextChunks(textChunks, parts);
918
+ result.push(new HumanMessage({ content: parts }));
919
+ i = j;
920
+ }
921
+ else {
922
+ // Keep the message as is
923
+ result.push(msg);
924
+ i++;
925
+ }
926
+ }
927
+ return result;
928
+ }
929
+ /**
930
+ * Walks backwards from `currentIndex` through the message array to check
931
+ * whether an earlier AI message in the same "chain" (no HumanMessage boundary)
932
+ * contains a thinking/reasoning block.
933
+ *
934
+ * A "chain" is a contiguous sequence of AI + Tool messages with no intervening
935
+ * HumanMessage. Bedrock reasoning models produce reasoning on the first AI
936
+ * response, then issue follow-up tool calls with `content: ""` and no
937
+ * reasoning block. These follow-ups are part of the same thinking-enabled
938
+ * turn and should not be converted.
939
+ */
940
+ function chainHasThinkingBlock(messages, currentIndex) {
941
+ for (let k = currentIndex - 1; k >= 0; k--) {
942
+ const prev = messages[k];
943
+ // HumanMessage = turn boundary — stop searching
944
+ if (prev instanceof HumanMessage ||
945
+ ('role' in prev && prev.role === 'user')) {
946
+ return false;
947
+ }
948
+ // Check AI messages for thinking/reasoning blocks
949
+ const isPrevAI = prev instanceof AIMessage ||
950
+ prev instanceof AIMessageChunk ||
951
+ ('role' in prev && prev.role === 'assistant');
952
+ if (isPrevAI) {
953
+ const prevAiMsg = prev;
954
+ if (Array.isArray(prevAiMsg.content) && prevAiMsg.content.length > 0) {
955
+ const content = prevAiMsg.content;
956
+ if (content.some((c) => typeof c === 'object' &&
957
+ (c.type === ContentTypes.THINKING ||
958
+ c.type === ContentTypes.REASONING_CONTENT ||
959
+ c.type === ContentTypes.REASONING ||
960
+ c.type === 'redacted_thinking'))) {
961
+ return true;
962
+ }
963
+ }
964
+ // Bedrock also stores reasoning in additional_kwargs
965
+ if (prevAiMsg.additional_kwargs.reasoning_content != null) {
966
+ return true;
967
+ }
968
+ }
969
+ // ToolMessages are part of the chain — keep walking back
970
+ }
971
+ return false;
972
+ }
973
+ //# sourceMappingURL=format.js.map