@illuma-ai/agents 1.0.81

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 (558) hide show
  1. package/README.md +485 -0
  2. package/dist/cjs/agents/AgentContext.cjs +734 -0
  3. package/dist/cjs/agents/AgentContext.cjs.map +1 -0
  4. package/dist/cjs/common/enum.cjs +190 -0
  5. package/dist/cjs/common/enum.cjs.map +1 -0
  6. package/dist/cjs/events.cjs +172 -0
  7. package/dist/cjs/events.cjs.map +1 -0
  8. package/dist/cjs/graphs/Graph.cjs +1615 -0
  9. package/dist/cjs/graphs/Graph.cjs.map +1 -0
  10. package/dist/cjs/graphs/MultiAgentGraph.cjs +890 -0
  11. package/dist/cjs/graphs/MultiAgentGraph.cjs.map +1 -0
  12. package/dist/cjs/instrumentation.cjs +21 -0
  13. package/dist/cjs/instrumentation.cjs.map +1 -0
  14. package/dist/cjs/llm/anthropic/index.cjs +292 -0
  15. package/dist/cjs/llm/anthropic/index.cjs.map +1 -0
  16. package/dist/cjs/llm/anthropic/types.cjs +50 -0
  17. package/dist/cjs/llm/anthropic/types.cjs.map +1 -0
  18. package/dist/cjs/llm/anthropic/utils/message_inputs.cjs +630 -0
  19. package/dist/cjs/llm/anthropic/utils/message_inputs.cjs.map +1 -0
  20. package/dist/cjs/llm/anthropic/utils/message_outputs.cjs +218 -0
  21. package/dist/cjs/llm/anthropic/utils/message_outputs.cjs.map +1 -0
  22. package/dist/cjs/llm/anthropic/utils/tools.cjs +29 -0
  23. package/dist/cjs/llm/anthropic/utils/tools.cjs.map +1 -0
  24. package/dist/cjs/llm/bedrock/index.cjs +282 -0
  25. package/dist/cjs/llm/bedrock/index.cjs.map +1 -0
  26. package/dist/cjs/llm/fake.cjs +97 -0
  27. package/dist/cjs/llm/fake.cjs.map +1 -0
  28. package/dist/cjs/llm/google/index.cjs +216 -0
  29. package/dist/cjs/llm/google/index.cjs.map +1 -0
  30. package/dist/cjs/llm/google/utils/common.cjs +647 -0
  31. package/dist/cjs/llm/google/utils/common.cjs.map +1 -0
  32. package/dist/cjs/llm/openai/index.cjs +1028 -0
  33. package/dist/cjs/llm/openai/index.cjs.map +1 -0
  34. package/dist/cjs/llm/openai/utils/index.cjs +765 -0
  35. package/dist/cjs/llm/openai/utils/index.cjs.map +1 -0
  36. package/dist/cjs/llm/openrouter/index.cjs +212 -0
  37. package/dist/cjs/llm/openrouter/index.cjs.map +1 -0
  38. package/dist/cjs/llm/providers.cjs +43 -0
  39. package/dist/cjs/llm/providers.cjs.map +1 -0
  40. package/dist/cjs/llm/text.cjs +69 -0
  41. package/dist/cjs/llm/text.cjs.map +1 -0
  42. package/dist/cjs/llm/vertexai/index.cjs +329 -0
  43. package/dist/cjs/llm/vertexai/index.cjs.map +1 -0
  44. package/dist/cjs/main.cjs +240 -0
  45. package/dist/cjs/main.cjs.map +1 -0
  46. package/dist/cjs/messages/cache.cjs +387 -0
  47. package/dist/cjs/messages/cache.cjs.map +1 -0
  48. package/dist/cjs/messages/content.cjs +53 -0
  49. package/dist/cjs/messages/content.cjs.map +1 -0
  50. package/dist/cjs/messages/core.cjs +367 -0
  51. package/dist/cjs/messages/core.cjs.map +1 -0
  52. package/dist/cjs/messages/format.cjs +761 -0
  53. package/dist/cjs/messages/format.cjs.map +1 -0
  54. package/dist/cjs/messages/ids.cjs +23 -0
  55. package/dist/cjs/messages/ids.cjs.map +1 -0
  56. package/dist/cjs/messages/prune.cjs +398 -0
  57. package/dist/cjs/messages/prune.cjs.map +1 -0
  58. package/dist/cjs/messages/tools.cjs +96 -0
  59. package/dist/cjs/messages/tools.cjs.map +1 -0
  60. package/dist/cjs/run.cjs +328 -0
  61. package/dist/cjs/run.cjs.map +1 -0
  62. package/dist/cjs/schemas/validate.cjs +324 -0
  63. package/dist/cjs/schemas/validate.cjs.map +1 -0
  64. package/dist/cjs/splitStream.cjs +210 -0
  65. package/dist/cjs/splitStream.cjs.map +1 -0
  66. package/dist/cjs/stream.cjs +620 -0
  67. package/dist/cjs/stream.cjs.map +1 -0
  68. package/dist/cjs/tools/BrowserTools.cjs +248 -0
  69. package/dist/cjs/tools/BrowserTools.cjs.map +1 -0
  70. package/dist/cjs/tools/Calculator.cjs +66 -0
  71. package/dist/cjs/tools/Calculator.cjs.map +1 -0
  72. package/dist/cjs/tools/CodeExecutor.cjs +234 -0
  73. package/dist/cjs/tools/CodeExecutor.cjs.map +1 -0
  74. package/dist/cjs/tools/ProgrammaticToolCalling.cjs +636 -0
  75. package/dist/cjs/tools/ProgrammaticToolCalling.cjs.map +1 -0
  76. package/dist/cjs/tools/ToolNode.cjs +548 -0
  77. package/dist/cjs/tools/ToolNode.cjs.map +1 -0
  78. package/dist/cjs/tools/ToolSearch.cjs +909 -0
  79. package/dist/cjs/tools/ToolSearch.cjs.map +1 -0
  80. package/dist/cjs/tools/handlers.cjs +255 -0
  81. package/dist/cjs/tools/handlers.cjs.map +1 -0
  82. package/dist/cjs/tools/schema.cjs +31 -0
  83. package/dist/cjs/tools/schema.cjs.map +1 -0
  84. package/dist/cjs/tools/search/anthropic.cjs +40 -0
  85. package/dist/cjs/tools/search/anthropic.cjs.map +1 -0
  86. package/dist/cjs/tools/search/content.cjs +140 -0
  87. package/dist/cjs/tools/search/content.cjs.map +1 -0
  88. package/dist/cjs/tools/search/firecrawl.cjs +179 -0
  89. package/dist/cjs/tools/search/firecrawl.cjs.map +1 -0
  90. package/dist/cjs/tools/search/format.cjs +203 -0
  91. package/dist/cjs/tools/search/format.cjs.map +1 -0
  92. package/dist/cjs/tools/search/highlights.cjs +245 -0
  93. package/dist/cjs/tools/search/highlights.cjs.map +1 -0
  94. package/dist/cjs/tools/search/rerankers.cjs +174 -0
  95. package/dist/cjs/tools/search/rerankers.cjs.map +1 -0
  96. package/dist/cjs/tools/search/schema.cjs +117 -0
  97. package/dist/cjs/tools/search/schema.cjs.map +1 -0
  98. package/dist/cjs/tools/search/search.cjs +566 -0
  99. package/dist/cjs/tools/search/search.cjs.map +1 -0
  100. package/dist/cjs/tools/search/serper-scraper.cjs +132 -0
  101. package/dist/cjs/tools/search/serper-scraper.cjs.map +1 -0
  102. package/dist/cjs/tools/search/tool.cjs +456 -0
  103. package/dist/cjs/tools/search/tool.cjs.map +1 -0
  104. package/dist/cjs/tools/search/utils.cjs +66 -0
  105. package/dist/cjs/tools/search/utils.cjs.map +1 -0
  106. package/dist/cjs/types/graph.cjs +29 -0
  107. package/dist/cjs/types/graph.cjs.map +1 -0
  108. package/dist/cjs/utils/contextAnalytics.cjs +66 -0
  109. package/dist/cjs/utils/contextAnalytics.cjs.map +1 -0
  110. package/dist/cjs/utils/events.cjs +31 -0
  111. package/dist/cjs/utils/events.cjs.map +1 -0
  112. package/dist/cjs/utils/graph.cjs +16 -0
  113. package/dist/cjs/utils/graph.cjs.map +1 -0
  114. package/dist/cjs/utils/handlers.cjs +70 -0
  115. package/dist/cjs/utils/handlers.cjs.map +1 -0
  116. package/dist/cjs/utils/llm.cjs +27 -0
  117. package/dist/cjs/utils/llm.cjs.map +1 -0
  118. package/dist/cjs/utils/misc.cjs +56 -0
  119. package/dist/cjs/utils/misc.cjs.map +1 -0
  120. package/dist/cjs/utils/run.cjs +73 -0
  121. package/dist/cjs/utils/run.cjs.map +1 -0
  122. package/dist/cjs/utils/schema.cjs +27 -0
  123. package/dist/cjs/utils/schema.cjs.map +1 -0
  124. package/dist/cjs/utils/title.cjs +125 -0
  125. package/dist/cjs/utils/title.cjs.map +1 -0
  126. package/dist/cjs/utils/tokens.cjs +125 -0
  127. package/dist/cjs/utils/tokens.cjs.map +1 -0
  128. package/dist/cjs/utils/toonFormat.cjs +388 -0
  129. package/dist/cjs/utils/toonFormat.cjs.map +1 -0
  130. package/dist/esm/agents/AgentContext.mjs +732 -0
  131. package/dist/esm/agents/AgentContext.mjs.map +1 -0
  132. package/dist/esm/common/enum.mjs +190 -0
  133. package/dist/esm/common/enum.mjs.map +1 -0
  134. package/dist/esm/events.mjs +164 -0
  135. package/dist/esm/events.mjs.map +1 -0
  136. package/dist/esm/graphs/Graph.mjs +1612 -0
  137. package/dist/esm/graphs/Graph.mjs.map +1 -0
  138. package/dist/esm/graphs/MultiAgentGraph.mjs +888 -0
  139. package/dist/esm/graphs/MultiAgentGraph.mjs.map +1 -0
  140. package/dist/esm/instrumentation.mjs +19 -0
  141. package/dist/esm/instrumentation.mjs.map +1 -0
  142. package/dist/esm/llm/anthropic/index.mjs +290 -0
  143. package/dist/esm/llm/anthropic/index.mjs.map +1 -0
  144. package/dist/esm/llm/anthropic/types.mjs +48 -0
  145. package/dist/esm/llm/anthropic/types.mjs.map +1 -0
  146. package/dist/esm/llm/anthropic/utils/message_inputs.mjs +627 -0
  147. package/dist/esm/llm/anthropic/utils/message_inputs.mjs.map +1 -0
  148. package/dist/esm/llm/anthropic/utils/message_outputs.mjs +216 -0
  149. package/dist/esm/llm/anthropic/utils/message_outputs.mjs.map +1 -0
  150. package/dist/esm/llm/anthropic/utils/tools.mjs +27 -0
  151. package/dist/esm/llm/anthropic/utils/tools.mjs.map +1 -0
  152. package/dist/esm/llm/bedrock/index.mjs +280 -0
  153. package/dist/esm/llm/bedrock/index.mjs.map +1 -0
  154. package/dist/esm/llm/fake.mjs +94 -0
  155. package/dist/esm/llm/fake.mjs.map +1 -0
  156. package/dist/esm/llm/google/index.mjs +214 -0
  157. package/dist/esm/llm/google/index.mjs.map +1 -0
  158. package/dist/esm/llm/google/utils/common.mjs +638 -0
  159. package/dist/esm/llm/google/utils/common.mjs.map +1 -0
  160. package/dist/esm/llm/openai/index.mjs +1018 -0
  161. package/dist/esm/llm/openai/index.mjs.map +1 -0
  162. package/dist/esm/llm/openai/utils/index.mjs +759 -0
  163. package/dist/esm/llm/openai/utils/index.mjs.map +1 -0
  164. package/dist/esm/llm/openrouter/index.mjs +210 -0
  165. package/dist/esm/llm/openrouter/index.mjs.map +1 -0
  166. package/dist/esm/llm/providers.mjs +39 -0
  167. package/dist/esm/llm/providers.mjs.map +1 -0
  168. package/dist/esm/llm/text.mjs +67 -0
  169. package/dist/esm/llm/text.mjs.map +1 -0
  170. package/dist/esm/llm/vertexai/index.mjs +327 -0
  171. package/dist/esm/llm/vertexai/index.mjs.map +1 -0
  172. package/dist/esm/main.mjs +37 -0
  173. package/dist/esm/main.mjs.map +1 -0
  174. package/dist/esm/messages/cache.mjs +382 -0
  175. package/dist/esm/messages/cache.mjs.map +1 -0
  176. package/dist/esm/messages/content.mjs +51 -0
  177. package/dist/esm/messages/content.mjs.map +1 -0
  178. package/dist/esm/messages/core.mjs +359 -0
  179. package/dist/esm/messages/core.mjs.map +1 -0
  180. package/dist/esm/messages/format.mjs +752 -0
  181. package/dist/esm/messages/format.mjs.map +1 -0
  182. package/dist/esm/messages/ids.mjs +21 -0
  183. package/dist/esm/messages/ids.mjs.map +1 -0
  184. package/dist/esm/messages/prune.mjs +393 -0
  185. package/dist/esm/messages/prune.mjs.map +1 -0
  186. package/dist/esm/messages/tools.mjs +93 -0
  187. package/dist/esm/messages/tools.mjs.map +1 -0
  188. package/dist/esm/run.mjs +325 -0
  189. package/dist/esm/run.mjs.map +1 -0
  190. package/dist/esm/schemas/validate.mjs +317 -0
  191. package/dist/esm/schemas/validate.mjs.map +1 -0
  192. package/dist/esm/splitStream.mjs +207 -0
  193. package/dist/esm/splitStream.mjs.map +1 -0
  194. package/dist/esm/stream.mjs +616 -0
  195. package/dist/esm/stream.mjs.map +1 -0
  196. package/dist/esm/tools/BrowserTools.mjs +244 -0
  197. package/dist/esm/tools/BrowserTools.mjs.map +1 -0
  198. package/dist/esm/tools/Calculator.mjs +41 -0
  199. package/dist/esm/tools/Calculator.mjs.map +1 -0
  200. package/dist/esm/tools/CodeExecutor.mjs +226 -0
  201. package/dist/esm/tools/CodeExecutor.mjs.map +1 -0
  202. package/dist/esm/tools/ProgrammaticToolCalling.mjs +622 -0
  203. package/dist/esm/tools/ProgrammaticToolCalling.mjs.map +1 -0
  204. package/dist/esm/tools/ToolNode.mjs +545 -0
  205. package/dist/esm/tools/ToolNode.mjs.map +1 -0
  206. package/dist/esm/tools/ToolSearch.mjs +870 -0
  207. package/dist/esm/tools/ToolSearch.mjs.map +1 -0
  208. package/dist/esm/tools/handlers.mjs +250 -0
  209. package/dist/esm/tools/handlers.mjs.map +1 -0
  210. package/dist/esm/tools/schema.mjs +28 -0
  211. package/dist/esm/tools/schema.mjs.map +1 -0
  212. package/dist/esm/tools/search/anthropic.mjs +37 -0
  213. package/dist/esm/tools/search/anthropic.mjs.map +1 -0
  214. package/dist/esm/tools/search/content.mjs +119 -0
  215. package/dist/esm/tools/search/content.mjs.map +1 -0
  216. package/dist/esm/tools/search/firecrawl.mjs +176 -0
  217. package/dist/esm/tools/search/firecrawl.mjs.map +1 -0
  218. package/dist/esm/tools/search/format.mjs +201 -0
  219. package/dist/esm/tools/search/format.mjs.map +1 -0
  220. package/dist/esm/tools/search/highlights.mjs +243 -0
  221. package/dist/esm/tools/search/highlights.mjs.map +1 -0
  222. package/dist/esm/tools/search/rerankers.mjs +168 -0
  223. package/dist/esm/tools/search/rerankers.mjs.map +1 -0
  224. package/dist/esm/tools/search/schema.mjs +104 -0
  225. package/dist/esm/tools/search/schema.mjs.map +1 -0
  226. package/dist/esm/tools/search/search.mjs +563 -0
  227. package/dist/esm/tools/search/search.mjs.map +1 -0
  228. package/dist/esm/tools/search/serper-scraper.mjs +129 -0
  229. package/dist/esm/tools/search/serper-scraper.mjs.map +1 -0
  230. package/dist/esm/tools/search/tool.mjs +454 -0
  231. package/dist/esm/tools/search/tool.mjs.map +1 -0
  232. package/dist/esm/tools/search/utils.mjs +61 -0
  233. package/dist/esm/tools/search/utils.mjs.map +1 -0
  234. package/dist/esm/types/graph.mjs +26 -0
  235. package/dist/esm/types/graph.mjs.map +1 -0
  236. package/dist/esm/utils/contextAnalytics.mjs +64 -0
  237. package/dist/esm/utils/contextAnalytics.mjs.map +1 -0
  238. package/dist/esm/utils/events.mjs +29 -0
  239. package/dist/esm/utils/events.mjs.map +1 -0
  240. package/dist/esm/utils/graph.mjs +13 -0
  241. package/dist/esm/utils/graph.mjs.map +1 -0
  242. package/dist/esm/utils/handlers.mjs +68 -0
  243. package/dist/esm/utils/handlers.mjs.map +1 -0
  244. package/dist/esm/utils/llm.mjs +24 -0
  245. package/dist/esm/utils/llm.mjs.map +1 -0
  246. package/dist/esm/utils/misc.mjs +53 -0
  247. package/dist/esm/utils/misc.mjs.map +1 -0
  248. package/dist/esm/utils/run.mjs +70 -0
  249. package/dist/esm/utils/run.mjs.map +1 -0
  250. package/dist/esm/utils/schema.mjs +24 -0
  251. package/dist/esm/utils/schema.mjs.map +1 -0
  252. package/dist/esm/utils/title.mjs +122 -0
  253. package/dist/esm/utils/title.mjs.map +1 -0
  254. package/dist/esm/utils/tokens.mjs +121 -0
  255. package/dist/esm/utils/tokens.mjs.map +1 -0
  256. package/dist/esm/utils/toonFormat.mjs +381 -0
  257. package/dist/esm/utils/toonFormat.mjs.map +1 -0
  258. package/dist/types/agents/AgentContext.d.ts +293 -0
  259. package/dist/types/common/enum.d.ts +155 -0
  260. package/dist/types/common/index.d.ts +1 -0
  261. package/dist/types/events.d.ts +31 -0
  262. package/dist/types/graphs/Graph.d.ts +216 -0
  263. package/dist/types/graphs/MultiAgentGraph.d.ts +104 -0
  264. package/dist/types/graphs/index.d.ts +2 -0
  265. package/dist/types/index.d.ts +21 -0
  266. package/dist/types/instrumentation.d.ts +1 -0
  267. package/dist/types/llm/anthropic/index.d.ts +39 -0
  268. package/dist/types/llm/anthropic/types.d.ts +37 -0
  269. package/dist/types/llm/anthropic/utils/message_inputs.d.ts +14 -0
  270. package/dist/types/llm/anthropic/utils/message_outputs.d.ts +14 -0
  271. package/dist/types/llm/anthropic/utils/output_parsers.d.ts +22 -0
  272. package/dist/types/llm/anthropic/utils/tools.d.ts +3 -0
  273. package/dist/types/llm/bedrock/index.d.ts +141 -0
  274. package/dist/types/llm/bedrock/types.d.ts +27 -0
  275. package/dist/types/llm/bedrock/utils/index.d.ts +5 -0
  276. package/dist/types/llm/bedrock/utils/message_inputs.d.ts +31 -0
  277. package/dist/types/llm/bedrock/utils/message_outputs.d.ts +33 -0
  278. package/dist/types/llm/fake.d.ts +31 -0
  279. package/dist/types/llm/google/index.d.ts +24 -0
  280. package/dist/types/llm/google/types.d.ts +42 -0
  281. package/dist/types/llm/google/utils/common.d.ts +34 -0
  282. package/dist/types/llm/google/utils/tools.d.ts +10 -0
  283. package/dist/types/llm/google/utils/zod_to_genai_parameters.d.ts +14 -0
  284. package/dist/types/llm/openai/index.d.ts +127 -0
  285. package/dist/types/llm/openai/types.d.ts +10 -0
  286. package/dist/types/llm/openai/utils/index.d.ts +29 -0
  287. package/dist/types/llm/openrouter/index.d.ts +15 -0
  288. package/dist/types/llm/providers.d.ts +5 -0
  289. package/dist/types/llm/text.d.ts +21 -0
  290. package/dist/types/llm/vertexai/index.d.ts +293 -0
  291. package/dist/types/messages/cache.d.ts +54 -0
  292. package/dist/types/messages/content.d.ts +7 -0
  293. package/dist/types/messages/core.d.ts +14 -0
  294. package/dist/types/messages/format.d.ts +137 -0
  295. package/dist/types/messages/ids.d.ts +3 -0
  296. package/dist/types/messages/index.d.ts +7 -0
  297. package/dist/types/messages/prune.d.ts +52 -0
  298. package/dist/types/messages/reducer.d.ts +9 -0
  299. package/dist/types/messages/tools.d.ts +17 -0
  300. package/dist/types/mockStream.d.ts +32 -0
  301. package/dist/types/prompts/collab.d.ts +1 -0
  302. package/dist/types/prompts/index.d.ts +2 -0
  303. package/dist/types/prompts/taskmanager.d.ts +41 -0
  304. package/dist/types/run.d.ts +41 -0
  305. package/dist/types/schemas/index.d.ts +1 -0
  306. package/dist/types/schemas/validate.d.ts +59 -0
  307. package/dist/types/splitStream.d.ts +37 -0
  308. package/dist/types/stream.d.ts +15 -0
  309. package/dist/types/test/mockTools.d.ts +28 -0
  310. package/dist/types/tools/BrowserTools.d.ts +87 -0
  311. package/dist/types/tools/Calculator.d.ts +34 -0
  312. package/dist/types/tools/CodeExecutor.d.ts +57 -0
  313. package/dist/types/tools/ProgrammaticToolCalling.d.ts +138 -0
  314. package/dist/types/tools/ToolNode.d.ts +51 -0
  315. package/dist/types/tools/ToolSearch.d.ts +219 -0
  316. package/dist/types/tools/handlers.d.ts +22 -0
  317. package/dist/types/tools/schema.d.ts +12 -0
  318. package/dist/types/tools/search/anthropic.d.ts +16 -0
  319. package/dist/types/tools/search/content.d.ts +4 -0
  320. package/dist/types/tools/search/firecrawl.d.ts +54 -0
  321. package/dist/types/tools/search/format.d.ts +5 -0
  322. package/dist/types/tools/search/highlights.d.ts +13 -0
  323. package/dist/types/tools/search/index.d.ts +3 -0
  324. package/dist/types/tools/search/rerankers.d.ts +38 -0
  325. package/dist/types/tools/search/schema.d.ts +103 -0
  326. package/dist/types/tools/search/search.d.ts +8 -0
  327. package/dist/types/tools/search/serper-scraper.d.ts +59 -0
  328. package/dist/types/tools/search/test.d.ts +1 -0
  329. package/dist/types/tools/search/tool.d.ts +3 -0
  330. package/dist/types/tools/search/types.d.ts +575 -0
  331. package/dist/types/tools/search/utils.d.ts +10 -0
  332. package/dist/types/types/graph.d.ts +399 -0
  333. package/dist/types/types/index.d.ts +5 -0
  334. package/dist/types/types/llm.d.ts +105 -0
  335. package/dist/types/types/messages.d.ts +4 -0
  336. package/dist/types/types/run.d.ts +112 -0
  337. package/dist/types/types/stream.d.ts +308 -0
  338. package/dist/types/types/tools.d.ts +296 -0
  339. package/dist/types/utils/contextAnalytics.d.ts +37 -0
  340. package/dist/types/utils/events.d.ts +6 -0
  341. package/dist/types/utils/graph.d.ts +2 -0
  342. package/dist/types/utils/handlers.d.ts +34 -0
  343. package/dist/types/utils/index.d.ts +9 -0
  344. package/dist/types/utils/llm.d.ts +3 -0
  345. package/dist/types/utils/llmConfig.d.ts +3 -0
  346. package/dist/types/utils/logging.d.ts +1 -0
  347. package/dist/types/utils/misc.d.ts +7 -0
  348. package/dist/types/utils/run.d.ts +27 -0
  349. package/dist/types/utils/schema.d.ts +8 -0
  350. package/dist/types/utils/title.d.ts +4 -0
  351. package/dist/types/utils/tokens.d.ts +28 -0
  352. package/dist/types/utils/toonFormat.d.ts +111 -0
  353. package/package.json +190 -0
  354. package/src/agents/AgentContext.test.ts +458 -0
  355. package/src/agents/AgentContext.ts +972 -0
  356. package/src/agents/__tests__/AgentContext.test.ts +805 -0
  357. package/src/agents/__tests__/resolveStructuredOutputMode.test.ts +137 -0
  358. package/src/common/enum.ts +203 -0
  359. package/src/common/index.ts +2 -0
  360. package/src/events.ts +223 -0
  361. package/src/graphs/Graph.ts +2228 -0
  362. package/src/graphs/MultiAgentGraph.ts +1063 -0
  363. package/src/graphs/__tests__/structured-output.integration.test.ts +809 -0
  364. package/src/graphs/__tests__/structured-output.test.ts +183 -0
  365. package/src/graphs/index.ts +2 -0
  366. package/src/index.ts +34 -0
  367. package/src/instrumentation.ts +22 -0
  368. package/src/llm/anthropic/Jacob_Lee_Resume_2023.pdf +0 -0
  369. package/src/llm/anthropic/index.ts +413 -0
  370. package/src/llm/anthropic/llm.spec.ts +1442 -0
  371. package/src/llm/anthropic/types.ts +140 -0
  372. package/src/llm/anthropic/utils/message_inputs.ts +757 -0
  373. package/src/llm/anthropic/utils/message_outputs.ts +289 -0
  374. package/src/llm/anthropic/utils/output_parsers.ts +133 -0
  375. package/src/llm/anthropic/utils/tools.ts +29 -0
  376. package/src/llm/bedrock/__tests__/bedrock-caching.test.ts +495 -0
  377. package/src/llm/bedrock/index.ts +411 -0
  378. package/src/llm/bedrock/llm.spec.ts +616 -0
  379. package/src/llm/bedrock/types.ts +51 -0
  380. package/src/llm/bedrock/utils/index.ts +18 -0
  381. package/src/llm/bedrock/utils/message_inputs.ts +563 -0
  382. package/src/llm/bedrock/utils/message_outputs.ts +310 -0
  383. package/src/llm/fake.ts +133 -0
  384. package/src/llm/google/data/gettysburg10.wav +0 -0
  385. package/src/llm/google/data/hotdog.jpg +0 -0
  386. package/src/llm/google/index.ts +337 -0
  387. package/src/llm/google/llm.spec.ts +934 -0
  388. package/src/llm/google/types.ts +56 -0
  389. package/src/llm/google/utils/common.ts +873 -0
  390. package/src/llm/google/utils/tools.ts +160 -0
  391. package/src/llm/google/utils/zod_to_genai_parameters.ts +86 -0
  392. package/src/llm/openai/index.ts +1366 -0
  393. package/src/llm/openai/types.ts +24 -0
  394. package/src/llm/openai/utils/index.ts +1035 -0
  395. package/src/llm/openai/utils/isReasoningModel.test.ts +90 -0
  396. package/src/llm/openrouter/index.ts +291 -0
  397. package/src/llm/providers.ts +52 -0
  398. package/src/llm/text.ts +94 -0
  399. package/src/llm/vertexai/index.ts +359 -0
  400. package/src/messages/__tests__/tools.test.ts +473 -0
  401. package/src/messages/cache.test.ts +1261 -0
  402. package/src/messages/cache.ts +518 -0
  403. package/src/messages/content.test.ts +362 -0
  404. package/src/messages/content.ts +63 -0
  405. package/src/messages/core.ts +473 -0
  406. package/src/messages/ensureThinkingBlock.test.ts +468 -0
  407. package/src/messages/format.ts +1029 -0
  408. package/src/messages/formatAgentMessages.test.ts +1513 -0
  409. package/src/messages/formatAgentMessages.tools.test.ts +419 -0
  410. package/src/messages/formatMessage.test.ts +693 -0
  411. package/src/messages/ids.ts +26 -0
  412. package/src/messages/index.ts +7 -0
  413. package/src/messages/labelContentByAgent.test.ts +887 -0
  414. package/src/messages/prune.ts +568 -0
  415. package/src/messages/reducer.ts +80 -0
  416. package/src/messages/shiftIndexTokenCountMap.test.ts +81 -0
  417. package/src/messages/tools.ts +108 -0
  418. package/src/mockStream.ts +99 -0
  419. package/src/prompts/collab.ts +6 -0
  420. package/src/prompts/index.ts +2 -0
  421. package/src/prompts/taskmanager.ts +61 -0
  422. package/src/run.ts +467 -0
  423. package/src/schemas/index.ts +2 -0
  424. package/src/schemas/schema-preparation.test.ts +500 -0
  425. package/src/schemas/validate.test.ts +358 -0
  426. package/src/schemas/validate.ts +454 -0
  427. package/src/scripts/abort.ts +157 -0
  428. package/src/scripts/ant_web_search.ts +158 -0
  429. package/src/scripts/ant_web_search_edge_case.ts +162 -0
  430. package/src/scripts/ant_web_search_error_edge_case.ts +148 -0
  431. package/src/scripts/args.ts +48 -0
  432. package/src/scripts/caching.ts +132 -0
  433. package/src/scripts/cli.ts +172 -0
  434. package/src/scripts/cli2.ts +133 -0
  435. package/src/scripts/cli3.ts +184 -0
  436. package/src/scripts/cli4.ts +191 -0
  437. package/src/scripts/cli5.ts +191 -0
  438. package/src/scripts/code_exec.ts +213 -0
  439. package/src/scripts/code_exec_files.ts +236 -0
  440. package/src/scripts/code_exec_multi_session.ts +241 -0
  441. package/src/scripts/code_exec_ptc.ts +334 -0
  442. package/src/scripts/code_exec_session.ts +282 -0
  443. package/src/scripts/code_exec_simple.ts +147 -0
  444. package/src/scripts/content.ts +138 -0
  445. package/src/scripts/empty_input.ts +137 -0
  446. package/src/scripts/handoff-test.ts +135 -0
  447. package/src/scripts/image.ts +178 -0
  448. package/src/scripts/memory.ts +97 -0
  449. package/src/scripts/multi-agent-chain.ts +331 -0
  450. package/src/scripts/multi-agent-conditional.ts +221 -0
  451. package/src/scripts/multi-agent-document-review-chain.ts +197 -0
  452. package/src/scripts/multi-agent-hybrid-flow.ts +310 -0
  453. package/src/scripts/multi-agent-parallel-start.ts +265 -0
  454. package/src/scripts/multi-agent-parallel.ts +394 -0
  455. package/src/scripts/multi-agent-sequence.ts +217 -0
  456. package/src/scripts/multi-agent-supervisor.ts +365 -0
  457. package/src/scripts/multi-agent-test.ts +186 -0
  458. package/src/scripts/parallel-asymmetric-tools-test.ts +274 -0
  459. package/src/scripts/parallel-full-metadata-test.ts +240 -0
  460. package/src/scripts/parallel-tools-test.ts +340 -0
  461. package/src/scripts/programmatic_exec.ts +396 -0
  462. package/src/scripts/programmatic_exec_agent.ts +231 -0
  463. package/src/scripts/search.ts +146 -0
  464. package/src/scripts/sequential-full-metadata-test.ts +197 -0
  465. package/src/scripts/simple.ts +225 -0
  466. package/src/scripts/single-agent-metadata-test.ts +198 -0
  467. package/src/scripts/stream.ts +140 -0
  468. package/src/scripts/test-custom-prompt-key.ts +145 -0
  469. package/src/scripts/test-handoff-input.ts +170 -0
  470. package/src/scripts/test-handoff-preamble.ts +277 -0
  471. package/src/scripts/test-multi-agent-list-handoff.ts +417 -0
  472. package/src/scripts/test-parallel-agent-labeling.ts +325 -0
  473. package/src/scripts/test-parallel-handoffs.ts +291 -0
  474. package/src/scripts/test-thinking-handoff-bedrock.ts +153 -0
  475. package/src/scripts/test-thinking-handoff.ts +155 -0
  476. package/src/scripts/test-tools-before-handoff.ts +226 -0
  477. package/src/scripts/test_code_api.ts +361 -0
  478. package/src/scripts/thinking-bedrock.ts +159 -0
  479. package/src/scripts/thinking.ts +171 -0
  480. package/src/scripts/tool_search.ts +162 -0
  481. package/src/scripts/tools.ts +177 -0
  482. package/src/specs/agent-handoffs.test.ts +888 -0
  483. package/src/specs/anthropic.simple.test.ts +387 -0
  484. package/src/specs/azure.simple.test.ts +364 -0
  485. package/src/specs/cache.simple.test.ts +396 -0
  486. package/src/specs/deepseek.simple.test.ts +283 -0
  487. package/src/specs/emergency-prune.test.ts +407 -0
  488. package/src/specs/moonshot.simple.test.ts +358 -0
  489. package/src/specs/openai.simple.test.ts +311 -0
  490. package/src/specs/openrouter.simple.test.ts +107 -0
  491. package/src/specs/prune.test.ts +901 -0
  492. package/src/specs/reasoning.test.ts +201 -0
  493. package/src/specs/spec.utils.ts +3 -0
  494. package/src/specs/thinking-handoff.test.ts +620 -0
  495. package/src/specs/thinking-prune.test.ts +703 -0
  496. package/src/specs/token-distribution-edge-case.test.ts +316 -0
  497. package/src/specs/token-memoization.test.ts +32 -0
  498. package/src/specs/tool-error.test.ts +198 -0
  499. package/src/splitStream.test.ts +691 -0
  500. package/src/splitStream.ts +234 -0
  501. package/src/stream.test.ts +94 -0
  502. package/src/stream.ts +801 -0
  503. package/src/test/mockTools.ts +386 -0
  504. package/src/tools/BrowserTools.ts +393 -0
  505. package/src/tools/Calculator.test.ts +278 -0
  506. package/src/tools/Calculator.ts +46 -0
  507. package/src/tools/CodeExecutor.ts +270 -0
  508. package/src/tools/ProgrammaticToolCalling.ts +785 -0
  509. package/src/tools/ToolNode.ts +674 -0
  510. package/src/tools/ToolSearch.ts +1095 -0
  511. package/src/tools/__tests__/BrowserTools.test.ts +265 -0
  512. package/src/tools/__tests__/ProgrammaticToolCalling.integration.test.ts +319 -0
  513. package/src/tools/__tests__/ProgrammaticToolCalling.test.ts +1006 -0
  514. package/src/tools/__tests__/ToolSearch.integration.test.ts +162 -0
  515. package/src/tools/__tests__/ToolSearch.test.ts +1003 -0
  516. package/src/tools/handlers.ts +363 -0
  517. package/src/tools/schema.ts +37 -0
  518. package/src/tools/search/anthropic.ts +51 -0
  519. package/src/tools/search/content.test.ts +173 -0
  520. package/src/tools/search/content.ts +147 -0
  521. package/src/tools/search/firecrawl.ts +210 -0
  522. package/src/tools/search/format.ts +250 -0
  523. package/src/tools/search/highlights.ts +320 -0
  524. package/src/tools/search/index.ts +3 -0
  525. package/src/tools/search/jina-reranker.test.ts +130 -0
  526. package/src/tools/search/output.md +2775 -0
  527. package/src/tools/search/rerankers.ts +242 -0
  528. package/src/tools/search/schema.ts +113 -0
  529. package/src/tools/search/search.ts +768 -0
  530. package/src/tools/search/serper-scraper.ts +155 -0
  531. package/src/tools/search/test.html +884 -0
  532. package/src/tools/search/test.md +643 -0
  533. package/src/tools/search/test.ts +159 -0
  534. package/src/tools/search/tool.ts +657 -0
  535. package/src/tools/search/types.ts +665 -0
  536. package/src/tools/search/utils.ts +79 -0
  537. package/src/types/graph.test.ts +218 -0
  538. package/src/types/graph.ts +533 -0
  539. package/src/types/index.ts +6 -0
  540. package/src/types/llm.ts +140 -0
  541. package/src/types/messages.ts +4 -0
  542. package/src/types/run.ts +128 -0
  543. package/src/types/stream.ts +417 -0
  544. package/src/types/tools.ts +355 -0
  545. package/src/utils/contextAnalytics.ts +103 -0
  546. package/src/utils/events.ts +32 -0
  547. package/src/utils/graph.ts +11 -0
  548. package/src/utils/handlers.ts +107 -0
  549. package/src/utils/index.ts +9 -0
  550. package/src/utils/llm.ts +26 -0
  551. package/src/utils/llmConfig.ts +208 -0
  552. package/src/utils/logging.ts +48 -0
  553. package/src/utils/misc.ts +57 -0
  554. package/src/utils/run.ts +106 -0
  555. package/src/utils/schema.ts +35 -0
  556. package/src/utils/title.ts +177 -0
  557. package/src/utils/tokens.ts +142 -0
  558. package/src/utils/toonFormat.ts +475 -0
@@ -0,0 +1,411 @@
1
+ /**
2
+ * Optimized ChatBedrockConverse wrapper that fixes contentBlockIndex conflicts
3
+ * and adds support for:
4
+ *
5
+ * - Prompt caching support for Bedrock Converse API (Illuma feature)
6
+ * - Application Inference Profiles (PR #9129)
7
+ * - Service Tiers (Priority/Standard/Flex) (PR #9785) - requires AWS SDK 3.966.0+
8
+ *
9
+ * Bedrock sends the same contentBlockIndex for both text and tool_use content blocks,
10
+ * causing LangChain's merge logic to fail with "field[contentBlockIndex] already exists"
11
+ * errors. This wrapper simply strips contentBlockIndex from response_metadata to avoid
12
+ * the conflict.
13
+ *
14
+ * The contentBlockIndex field is only used internally by Bedrock's streaming protocol
15
+ * and isn't needed by application logic - the index field on tool_call_chunks serves
16
+ * the purpose of tracking tool call ordering.
17
+ *
18
+ * PROMPT CACHING:
19
+ * When promptCache: true is set, this wrapper adds cachePoint markers to the tools array
20
+ * to enable Bedrock prompt caching for tool definitions. This allows tool schemas to be
21
+ * cached and reused across requests, reducing latency and costs.
22
+ *
23
+ * CACHE TOKEN EXTRACTION:
24
+ * LangChain AWS doesn't extract cacheReadInputTokens/cacheWriteInputTokens from Bedrock's
25
+ * response. This wrapper adds input_token_details to usage_metadata with cache information.
26
+ */
27
+
28
+ import { ChatBedrockConverse } from '@langchain/aws';
29
+ import { AIMessageChunk } from '@langchain/core/messages';
30
+ import type { BaseMessage, UsageMetadata } from '@langchain/core/messages';
31
+ import { ChatGenerationChunk, ChatResult } from '@langchain/core/outputs';
32
+ import type { CallbackManagerForLLMRun } from '@langchain/core/callbacks/manager';
33
+ import type { ChatBedrockConverseInput } from '@langchain/aws';
34
+
35
+ /**
36
+ * Service tier type for Bedrock invocations.
37
+ * Requires AWS SDK >= 3.966.0 to actually work.
38
+ * @see https://docs.aws.amazon.com/bedrock/latest/userguide/service-tiers-inference.html
39
+ */
40
+ export type ServiceTierType = 'priority' | 'default' | 'flex' | 'reserved';
41
+
42
+ /**
43
+ * Extended input interface with additional features:
44
+ * - promptCache: Enable Bedrock prompt caching for tool definitions
45
+ * - applicationInferenceProfile: Use an inference profile ARN instead of model ID
46
+ * - serviceTier: Specify service tier (Priority, Standard, Flex, Reserved)
47
+ */
48
+ export interface CustomChatBedrockConverseInput
49
+ extends ChatBedrockConverseInput {
50
+ /**
51
+ * Enable Bedrock prompt caching for tool definitions.
52
+ * When true, adds cachePoint markers to tools array.
53
+ */
54
+ promptCache?: boolean;
55
+
56
+ /**
57
+ * Application Inference Profile ARN to use for the model.
58
+ * For example, "arn:aws:bedrock:eu-west-1:123456789102:application-inference-profile/fm16bt65tzgx"
59
+ * When provided, this ARN will be used for the actual inference calls instead of the model ID.
60
+ * Must still provide `model` as normal modelId to benefit from all the metadata.
61
+ * @see https://docs.aws.amazon.com/bedrock/latest/userguide/inference-profiles-create.html
62
+ */
63
+ applicationInferenceProfile?: string;
64
+
65
+ /**
66
+ * Service tier for model invocation.
67
+ * Specifies the processing tier type used for serving the request.
68
+ * Supported values are 'priority', 'default', 'flex', and 'reserved'.
69
+ *
70
+ * - 'priority': Prioritized processing for lower latency
71
+ * - 'default': Standard processing tier
72
+ * - 'flex': Flexible processing tier with lower cost
73
+ * - 'reserved': Reserved capacity for consistent performance
74
+ *
75
+ * If not provided, AWS uses the default tier.
76
+ * Note: Requires AWS SDK >= 3.966.0 to work.
77
+ * @see https://docs.aws.amazon.com/bedrock/latest/userguide/service-tiers-inference.html
78
+ */
79
+ serviceTier?: ServiceTierType;
80
+ }
81
+
82
+ /**
83
+ * Extended call options with serviceTier override support.
84
+ */
85
+ export interface CustomChatBedrockConverseCallOptions {
86
+ serviceTier?: ServiceTierType;
87
+ }
88
+
89
+ export class CustomChatBedrockConverse extends ChatBedrockConverse {
90
+ /** Enable Bedrock prompt caching for tool definitions */
91
+ promptCache: boolean;
92
+
93
+ /** Application Inference Profile ARN to use instead of model ID */
94
+ applicationInferenceProfile?: string;
95
+
96
+ /** Service tier for model invocation */
97
+ serviceTier?: ServiceTierType;
98
+
99
+ constructor(fields?: CustomChatBedrockConverseInput) {
100
+ super(fields);
101
+ this.promptCache = fields?.promptCache ?? false;
102
+ this.applicationInferenceProfile = fields?.applicationInferenceProfile;
103
+ this.serviceTier = fields?.serviceTier;
104
+
105
+ // Fix: Force supportsToolChoiceValues for Claude models
106
+ // The parent constructor checks `model.includes('claude-3')` but this fails when:
107
+ // 1. Using applicationInferenceProfile ARNs (arn:aws:bedrock:...)
108
+ // 2. Using different naming conventions (claude-4, claude-opus-4, etc.)
109
+ // We need to ensure tool_choice is properly set for withStructuredOutput to work
110
+ const modelName = (fields?.model ?? '').toLowerCase();
111
+ const profileName = (fields?.applicationInferenceProfile ?? '').toLowerCase();
112
+ const isClaudeModel =
113
+ modelName.includes('claude') ||
114
+ modelName.includes('anthropic') ||
115
+ profileName.includes('claude') ||
116
+ profileName.includes('anthropic');
117
+
118
+ if (isClaudeModel && !this.supportsToolChoiceValues?.length) {
119
+ // Claude models support all tool choice values
120
+ this.supportsToolChoiceValues = ['auto', 'any', 'tool'];
121
+ }
122
+ }
123
+
124
+ static lc_name(): string {
125
+ return 'IllumaBedrockConverse';
126
+ }
127
+
128
+ /**
129
+ * Get the model ID to use for API calls.
130
+ * Returns applicationInferenceProfile if set, otherwise returns this.model.
131
+ */
132
+ protected getModelId(): string {
133
+ return this.applicationInferenceProfile ?? this.model;
134
+ }
135
+
136
+ /**
137
+ * Override invocationParams to:
138
+ * 1. Add cachePoint to tools when promptCache is enabled
139
+ * 2. Add serviceTier support
140
+ *
141
+ * CACHING STRATEGY: Separate cachePoints for core tools and MCP tools
142
+ * - Core tools (web_search, execute_code, etc.) are stable → cache first
143
+ * - MCP tools (have '_mcp_' in name) are dynamic → cache separately after
144
+ * - This allows core tools to stay cached when MCP selection changes
145
+ *
146
+ * NOTE: Only Claude models support cachePoint - Nova and other models will reject it.
147
+ */
148
+ override invocationParams(
149
+ options?: this['ParsedCallOptions'] & CustomChatBedrockConverseCallOptions
150
+ ): ReturnType<ChatBedrockConverse['invocationParams']> & {
151
+ serviceTier?: { type: ServiceTierType };
152
+ } {
153
+ const params = super.invocationParams(options);
154
+
155
+ // Add cachePoint to tools array if promptCache is enabled and tools exist
156
+ // Only Claude models support cachePoint - check model name
157
+ const modelId = this.model.toLowerCase();
158
+ const isClaudeModel =
159
+ modelId.includes('claude') || modelId.includes('anthropic');
160
+
161
+ if (
162
+ this.promptCache &&
163
+ isClaudeModel &&
164
+ params.toolConfig?.tools &&
165
+ Array.isArray(params.toolConfig.tools) &&
166
+ params.toolConfig.tools.length > 0
167
+ ) {
168
+ // Separate core tools from MCP tools
169
+ // MCP tools have '_mcp_' in their name (e.g., 'search_emails_mcp_Google-Workspace')
170
+ const coreTools: typeof params.toolConfig.tools = [];
171
+ const mcpTools: typeof params.toolConfig.tools = [];
172
+
173
+ for (const tool of params.toolConfig.tools) {
174
+ // Check if tool has a name property with '_mcp_' pattern
175
+ const toolName =
176
+ (tool as { toolSpec?: { name?: string } }).toolSpec?.name ?? '';
177
+ if (toolName.includes('_mcp_')) {
178
+ mcpTools.push(tool);
179
+ } else {
180
+ coreTools.push(tool);
181
+ }
182
+ }
183
+
184
+ // Build tools array with strategic cachePoints:
185
+ // [CoreTool1, CoreTool2, cachePoint] + [MCPTool1, MCPTool2, cachePoint]
186
+ const toolsWithCache: typeof params.toolConfig.tools = [];
187
+
188
+ // Add core tools with cachePoint (if any)
189
+ if (coreTools.length > 0) {
190
+ toolsWithCache.push(...coreTools);
191
+ toolsWithCache.push({ cachePoint: { type: 'default' } });
192
+ }
193
+
194
+ // Add MCP tools with their own cachePoint (if any)
195
+ if (mcpTools.length > 0) {
196
+ toolsWithCache.push(...mcpTools);
197
+ toolsWithCache.push({ cachePoint: { type: 'default' } });
198
+ }
199
+
200
+ // If no tools at all (shouldn't happen but safety check)
201
+ if (toolsWithCache.length === 0) {
202
+ toolsWithCache.push({ cachePoint: { type: 'default' } });
203
+ }
204
+
205
+ params.toolConfig.tools = toolsWithCache;
206
+ }
207
+
208
+ // Add serviceTier support
209
+ const serviceTierType = options?.serviceTier ?? this.serviceTier;
210
+
211
+ return {
212
+ ...params,
213
+ serviceTier: serviceTierType ? { type: serviceTierType } : undefined,
214
+ };
215
+ }
216
+
217
+ /**
218
+ * Override _generateNonStreaming to use applicationInferenceProfile as modelId.
219
+ * Uses the same model-swapping pattern as streaming for consistency.
220
+ */
221
+ override async _generateNonStreaming(
222
+ messages: BaseMessage[],
223
+ options: this['ParsedCallOptions'] & CustomChatBedrockConverseCallOptions,
224
+ runManager?: CallbackManagerForLLMRun
225
+ ): Promise<ChatResult> {
226
+ // Temporarily swap model for applicationInferenceProfile support
227
+ const originalModel = this.model;
228
+ if (
229
+ this.applicationInferenceProfile != null &&
230
+ this.applicationInferenceProfile !== ''
231
+ ) {
232
+ this.model = this.applicationInferenceProfile;
233
+ }
234
+
235
+ try {
236
+ return await super._generateNonStreaming(messages, options, runManager);
237
+ } finally {
238
+ // Restore original model
239
+ this.model = originalModel;
240
+ }
241
+ }
242
+
243
+ /**
244
+ * Override _streamResponseChunks to:
245
+ * 1. Use applicationInferenceProfile as modelId (by temporarily swapping this.model)
246
+ * 2. Strip contentBlockIndex from response_metadata to prevent merge conflicts
247
+ * 3. Extract cacheReadInputTokens/cacheWriteInputTokens and add to usage_metadata
248
+ *
249
+ * Note: We delegate to super._streamResponseChunks() to preserve @langchain/aws's
250
+ * internal chunk handling which correctly preserves array content for reasoning blocks.
251
+ */
252
+ override async *_streamResponseChunks(
253
+ messages: BaseMessage[],
254
+ options: this['ParsedCallOptions'] & CustomChatBedrockConverseCallOptions,
255
+ runManager?: CallbackManagerForLLMRun
256
+ ): AsyncGenerator<ChatGenerationChunk> {
257
+ // Temporarily swap model for applicationInferenceProfile support
258
+ const originalModel = this.model;
259
+ if (
260
+ this.applicationInferenceProfile != null &&
261
+ this.applicationInferenceProfile !== ''
262
+ ) {
263
+ this.model = this.applicationInferenceProfile;
264
+ }
265
+
266
+ try {
267
+ // Use parent's streaming logic which correctly handles reasoning content
268
+ const baseStream = super._streamResponseChunks(
269
+ messages,
270
+ options,
271
+ runManager
272
+ );
273
+
274
+ for await (const chunk of baseStream) {
275
+ // Clean and enhance chunk
276
+ yield this.processChunk(chunk);
277
+ }
278
+ } finally {
279
+ // Restore original model
280
+ this.model = originalModel;
281
+ }
282
+ }
283
+
284
+ /**
285
+ * Process a chunk by:
286
+ * 1. Removing contentBlockIndex from response_metadata
287
+ * 2. Extracting cache token information from Bedrock's usage data
288
+ */
289
+ private processChunk(chunk: ChatGenerationChunk): ChatGenerationChunk {
290
+ const message = chunk.message;
291
+ if (!(message instanceof AIMessageChunk)) {
292
+ return chunk;
293
+ }
294
+
295
+ const responseMetadata = message.response_metadata as Record<
296
+ string,
297
+ unknown
298
+ >;
299
+ let needsModification = false;
300
+ let cleanedMetadata = responseMetadata;
301
+
302
+ // Check if contentBlockIndex exists anywhere in response_metadata
303
+ const hasContentBlockIndex = this.hasContentBlockIndex(responseMetadata);
304
+ if (hasContentBlockIndex) {
305
+ cleanedMetadata = this.removeContentBlockIndex(
306
+ responseMetadata
307
+ ) as Record<string, unknown>;
308
+ needsModification = true;
309
+ }
310
+
311
+ // Extract cache tokens from metadata.usage (Bedrock streaming format)
312
+ // The metadata chunk contains usage with cacheReadInputTokens/cacheWriteInputTokens
313
+ const metadata = responseMetadata.metadata as
314
+ | Record<string, unknown>
315
+ | undefined;
316
+ const usage = (metadata?.usage ?? responseMetadata.usage) as
317
+ | Record<string, unknown>
318
+ | undefined;
319
+
320
+ let enhancedUsageMetadata: UsageMetadata | undefined =
321
+ message.usage_metadata;
322
+
323
+ if (usage) {
324
+ const cacheRead = (usage.cacheReadInputTokens as number | undefined) ?? 0;
325
+ const cacheWrite =
326
+ (usage.cacheWriteInputTokens as number | undefined) ?? 0;
327
+ const inputTokens = (usage.inputTokens as number | undefined) ?? 0;
328
+ const outputTokens = (usage.outputTokens as number | undefined) ?? 0;
329
+
330
+ if (cacheRead > 0 || cacheWrite > 0) {
331
+ needsModification = true;
332
+ enhancedUsageMetadata = {
333
+ input_tokens: message.usage_metadata?.input_tokens ?? inputTokens,
334
+ output_tokens: message.usage_metadata?.output_tokens ?? outputTokens,
335
+ total_tokens:
336
+ message.usage_metadata?.total_tokens ??
337
+ (usage.totalTokens as number | undefined) ??
338
+ 0,
339
+ input_token_details: {
340
+ cache_read: cacheRead,
341
+ cache_creation: cacheWrite,
342
+ },
343
+ };
344
+ }
345
+ }
346
+
347
+ if (needsModification) {
348
+ return new ChatGenerationChunk({
349
+ text: chunk.text,
350
+ message: new AIMessageChunk({
351
+ ...message,
352
+ response_metadata: cleanedMetadata,
353
+ usage_metadata: enhancedUsageMetadata,
354
+ }),
355
+ generationInfo: chunk.generationInfo,
356
+ });
357
+ }
358
+
359
+ return chunk;
360
+ }
361
+
362
+ /**
363
+ * Check if contentBlockIndex exists at any level in the object
364
+ */
365
+ private hasContentBlockIndex(obj: unknown): boolean {
366
+ if (obj === null || obj === undefined || typeof obj !== 'object') {
367
+ return false;
368
+ }
369
+
370
+ if ('contentBlockIndex' in obj) {
371
+ return true;
372
+ }
373
+
374
+ for (const value of Object.values(obj)) {
375
+ if (typeof value === 'object' && value !== null) {
376
+ if (this.hasContentBlockIndex(value)) {
377
+ return true;
378
+ }
379
+ }
380
+ }
381
+
382
+ return false;
383
+ }
384
+
385
+ /**
386
+ * Recursively remove contentBlockIndex from all levels of an object
387
+ */
388
+ private removeContentBlockIndex(obj: unknown): unknown {
389
+ if (obj === null || obj === undefined) {
390
+ return obj;
391
+ }
392
+
393
+ if (Array.isArray(obj)) {
394
+ return obj.map((item) => this.removeContentBlockIndex(item));
395
+ }
396
+
397
+ if (typeof obj === 'object') {
398
+ const cleaned: Record<string, unknown> = {};
399
+ for (const [key, value] of Object.entries(obj)) {
400
+ if (key !== 'contentBlockIndex') {
401
+ cleaned[key] = this.removeContentBlockIndex(value);
402
+ }
403
+ }
404
+ return cleaned;
405
+ }
406
+
407
+ return obj;
408
+ }
409
+ }
410
+
411
+ export type { ChatBedrockConverseInput };