@illuma-ai/agents 1.4.0-alpha.5 → 1.5.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (769) hide show
  1. package/README.md +62 -0
  2. package/dist/cjs/agents/AgentContext.cjs +274 -67
  3. package/dist/cjs/agents/AgentContext.cjs.map +1 -1
  4. package/dist/cjs/common/enum.cjs +44 -13
  5. package/dist/cjs/common/enum.cjs.map +1 -1
  6. package/dist/cjs/graphs/Graph.cjs +182 -5
  7. package/dist/cjs/graphs/Graph.cjs.map +1 -1
  8. package/dist/cjs/graphs/MultiAgentGraph.cjs +152 -1167
  9. package/dist/cjs/graphs/MultiAgentGraph.cjs.map +1 -1
  10. package/dist/cjs/hooks/HookRegistry.cjs +162 -0
  11. package/dist/cjs/hooks/HookRegistry.cjs.map +1 -0
  12. package/dist/cjs/hooks/executeHooks.cjs +276 -0
  13. package/dist/cjs/hooks/executeHooks.cjs.map +1 -0
  14. package/dist/cjs/hooks/matchers.cjs +256 -0
  15. package/dist/cjs/hooks/matchers.cjs.map +1 -0
  16. package/dist/cjs/hooks/types.cjs +27 -0
  17. package/dist/cjs/hooks/types.cjs.map +1 -0
  18. package/dist/cjs/langchain/google-common.cjs +3 -0
  19. package/dist/cjs/langchain/google-common.cjs.map +1 -0
  20. package/dist/cjs/langchain/index.cjs +86 -0
  21. package/dist/cjs/langchain/index.cjs.map +1 -0
  22. package/dist/cjs/langchain/language_models/chat_models.cjs +3 -0
  23. package/dist/cjs/langchain/language_models/chat_models.cjs.map +1 -0
  24. package/dist/cjs/langchain/messages/tool.cjs +3 -0
  25. package/dist/cjs/langchain/messages/tool.cjs.map +1 -0
  26. package/dist/cjs/langchain/messages.cjs +51 -0
  27. package/dist/cjs/langchain/messages.cjs.map +1 -0
  28. package/dist/cjs/langchain/openai.cjs +3 -0
  29. package/dist/cjs/langchain/openai.cjs.map +1 -0
  30. package/dist/cjs/langchain/prompts.cjs +11 -0
  31. package/dist/cjs/langchain/prompts.cjs.map +1 -0
  32. package/dist/cjs/langchain/runnables.cjs +19 -0
  33. package/dist/cjs/langchain/runnables.cjs.map +1 -0
  34. package/dist/cjs/langchain/tools.cjs +23 -0
  35. package/dist/cjs/langchain/tools.cjs.map +1 -0
  36. package/dist/cjs/langchain/utils/env.cjs +11 -0
  37. package/dist/cjs/langchain/utils/env.cjs.map +1 -0
  38. package/dist/cjs/llm/anthropic/utils/message_inputs.cjs +5 -1
  39. package/dist/cjs/llm/anthropic/utils/message_inputs.cjs.map +1 -1
  40. package/dist/cjs/llm/bedrock/cacheSupport.cjs +55 -0
  41. package/dist/cjs/llm/bedrock/cacheSupport.cjs.map +1 -0
  42. package/dist/cjs/llm/bedrock/index.cjs +61 -33
  43. package/dist/cjs/llm/bedrock/index.cjs.map +1 -1
  44. package/dist/cjs/llm/openai/index.cjs +0 -3
  45. package/dist/cjs/llm/openai/index.cjs.map +1 -1
  46. package/dist/cjs/llm/openai/utils/index.cjs +27 -10
  47. package/dist/cjs/llm/openai/utils/index.cjs.map +1 -1
  48. package/dist/cjs/main.cjs +178 -117
  49. package/dist/cjs/main.cjs.map +1 -1
  50. package/dist/cjs/messages/cache.cjs +89 -0
  51. package/dist/cjs/messages/cache.cjs.map +1 -1
  52. package/dist/cjs/messages/contextPruning.cjs +156 -0
  53. package/dist/cjs/messages/contextPruning.cjs.map +1 -0
  54. package/dist/cjs/messages/contextPruningSettings.cjs +53 -0
  55. package/dist/cjs/messages/contextPruningSettings.cjs.map +1 -0
  56. package/dist/cjs/messages/format.cjs +144 -20
  57. package/dist/cjs/messages/format.cjs.map +1 -1
  58. package/dist/cjs/messages/prune.cjs +505 -4
  59. package/dist/cjs/messages/prune.cjs.map +1 -1
  60. package/dist/cjs/run.cjs +141 -1
  61. package/dist/cjs/run.cjs.map +1 -1
  62. package/dist/cjs/tools/BashExecutor.cjs +235 -0
  63. package/dist/cjs/tools/BashExecutor.cjs.map +1 -0
  64. package/dist/cjs/tools/BashProgrammaticToolCalling.cjs +297 -0
  65. package/dist/cjs/tools/BashProgrammaticToolCalling.cjs.map +1 -0
  66. package/dist/cjs/tools/CodeExecutor.cjs +44 -47
  67. package/dist/cjs/tools/CodeExecutor.cjs.map +1 -1
  68. package/dist/cjs/tools/ProgrammaticToolCalling.cjs +16 -11
  69. package/dist/cjs/tools/ProgrammaticToolCalling.cjs.map +1 -1
  70. package/dist/cjs/tools/ReadFile.cjs +44 -0
  71. package/dist/cjs/tools/ReadFile.cjs.map +1 -0
  72. package/dist/cjs/tools/SkillTool.cjs +51 -0
  73. package/dist/cjs/tools/SkillTool.cjs.map +1 -0
  74. package/dist/cjs/tools/SubagentTool.cjs +93 -0
  75. package/dist/cjs/tools/SubagentTool.cjs.map +1 -0
  76. package/dist/cjs/tools/ToolNode.cjs +450 -24
  77. package/dist/cjs/tools/ToolNode.cjs.map +1 -1
  78. package/dist/cjs/tools/search/search.cjs +11 -3
  79. package/dist/cjs/tools/search/search.cjs.map +1 -1
  80. package/dist/cjs/tools/search/tavily-scraper.cjs +189 -0
  81. package/dist/cjs/tools/search/tavily-scraper.cjs.map +1 -0
  82. package/dist/cjs/tools/search/tavily-search.cjs +372 -0
  83. package/dist/cjs/tools/search/tavily-search.cjs.map +1 -0
  84. package/dist/cjs/tools/search/tool.cjs +28 -4
  85. package/dist/cjs/tools/search/tool.cjs.map +1 -1
  86. package/dist/cjs/tools/search/utils.cjs +10 -3
  87. package/dist/cjs/tools/search/utils.cjs.map +1 -1
  88. package/dist/cjs/tools/skillCatalog.cjs +84 -0
  89. package/dist/cjs/tools/skillCatalog.cjs.map +1 -0
  90. package/dist/cjs/tools/subagent/SubagentExecutor.cjs +512 -0
  91. package/dist/cjs/tools/subagent/SubagentExecutor.cjs.map +1 -0
  92. package/dist/cjs/tools/toolOutputReferences.cjs +670 -0
  93. package/dist/cjs/tools/toolOutputReferences.cjs.map +1 -0
  94. package/dist/cjs/types/agent-cache.cjs +53 -0
  95. package/dist/cjs/types/agent-cache.cjs.map +1 -0
  96. package/dist/cjs/types/graph.cjs.map +1 -1
  97. package/dist/cjs/utils/truncation.cjs +135 -0
  98. package/dist/cjs/utils/truncation.cjs.map +1 -0
  99. package/dist/esm/agents/AgentContext.mjs +274 -67
  100. package/dist/esm/agents/AgentContext.mjs.map +1 -1
  101. package/dist/esm/common/enum.mjs +44 -12
  102. package/dist/esm/common/enum.mjs.map +1 -1
  103. package/dist/esm/graphs/Graph.mjs +182 -5
  104. package/dist/esm/graphs/Graph.mjs.map +1 -1
  105. package/dist/esm/graphs/MultiAgentGraph.mjs +155 -1170
  106. package/dist/esm/graphs/MultiAgentGraph.mjs.map +1 -1
  107. package/dist/esm/hooks/HookRegistry.mjs +160 -0
  108. package/dist/esm/hooks/HookRegistry.mjs.map +1 -0
  109. package/dist/esm/hooks/executeHooks.mjs +273 -0
  110. package/dist/esm/hooks/executeHooks.mjs.map +1 -0
  111. package/dist/esm/hooks/matchers.mjs +251 -0
  112. package/dist/esm/hooks/matchers.mjs.map +1 -0
  113. package/dist/esm/hooks/types.mjs +25 -0
  114. package/dist/esm/hooks/types.mjs.map +1 -0
  115. package/dist/esm/langchain/google-common.mjs +2 -0
  116. package/dist/esm/langchain/google-common.mjs.map +1 -0
  117. package/dist/esm/langchain/index.mjs +5 -0
  118. package/dist/esm/langchain/index.mjs.map +1 -0
  119. package/dist/esm/langchain/language_models/chat_models.mjs +2 -0
  120. package/dist/esm/langchain/language_models/chat_models.mjs.map +1 -0
  121. package/dist/esm/langchain/messages/tool.mjs +2 -0
  122. package/dist/esm/langchain/messages/tool.mjs.map +1 -0
  123. package/dist/esm/langchain/messages.mjs +2 -0
  124. package/dist/esm/langchain/messages.mjs.map +1 -0
  125. package/dist/esm/langchain/openai.mjs +2 -0
  126. package/dist/esm/langchain/openai.mjs.map +1 -0
  127. package/dist/esm/langchain/prompts.mjs +2 -0
  128. package/dist/esm/langchain/prompts.mjs.map +1 -0
  129. package/dist/esm/langchain/runnables.mjs +2 -0
  130. package/dist/esm/langchain/runnables.mjs.map +1 -0
  131. package/dist/esm/langchain/tools.mjs +2 -0
  132. package/dist/esm/langchain/tools.mjs.map +1 -0
  133. package/dist/esm/langchain/utils/env.mjs +2 -0
  134. package/dist/esm/langchain/utils/env.mjs.map +1 -0
  135. package/dist/esm/llm/anthropic/utils/message_inputs.mjs +5 -1
  136. package/dist/esm/llm/anthropic/utils/message_inputs.mjs.map +1 -1
  137. package/dist/esm/llm/bedrock/cacheSupport.mjs +52 -0
  138. package/dist/esm/llm/bedrock/cacheSupport.mjs.map +1 -0
  139. package/dist/esm/llm/bedrock/index.mjs +61 -34
  140. package/dist/esm/llm/bedrock/index.mjs.map +1 -1
  141. package/dist/esm/llm/openai/index.mjs +0 -3
  142. package/dist/esm/llm/openai/index.mjs.map +1 -1
  143. package/dist/esm/llm/openai/utils/index.mjs +27 -10
  144. package/dist/esm/llm/openai/utils/index.mjs.map +1 -1
  145. package/dist/esm/main.mjs +21 -24
  146. package/dist/esm/main.mjs.map +1 -1
  147. package/dist/esm/messages/cache.mjs +89 -0
  148. package/dist/esm/messages/cache.mjs.map +1 -1
  149. package/dist/esm/messages/contextPruning.mjs +154 -0
  150. package/dist/esm/messages/contextPruning.mjs.map +1 -0
  151. package/dist/esm/messages/contextPruningSettings.mjs +50 -0
  152. package/dist/esm/messages/contextPruningSettings.mjs.map +1 -0
  153. package/dist/esm/messages/format.mjs +136 -12
  154. package/dist/esm/messages/format.mjs.map +1 -1
  155. package/dist/esm/messages/prune.mjs +504 -7
  156. package/dist/esm/messages/prune.mjs.map +1 -1
  157. package/dist/esm/run.mjs +141 -1
  158. package/dist/esm/run.mjs.map +1 -1
  159. package/dist/esm/tools/BashExecutor.mjs +227 -0
  160. package/dist/esm/tools/BashExecutor.mjs.map +1 -0
  161. package/dist/esm/tools/BashProgrammaticToolCalling.mjs +288 -0
  162. package/dist/esm/tools/BashProgrammaticToolCalling.mjs.map +1 -0
  163. package/dist/esm/tools/CodeExecutor.mjs +44 -48
  164. package/dist/esm/tools/CodeExecutor.mjs.map +1 -1
  165. package/dist/esm/tools/ProgrammaticToolCalling.mjs +17 -12
  166. package/dist/esm/tools/ProgrammaticToolCalling.mjs.map +1 -1
  167. package/dist/esm/tools/ReadFile.mjs +39 -0
  168. package/dist/esm/tools/ReadFile.mjs.map +1 -0
  169. package/dist/esm/tools/SkillTool.mjs +46 -0
  170. package/dist/esm/tools/SkillTool.mjs.map +1 -0
  171. package/dist/esm/tools/SubagentTool.mjs +86 -0
  172. package/dist/esm/tools/SubagentTool.mjs.map +1 -0
  173. package/dist/esm/tools/ToolNode.mjs +452 -26
  174. package/dist/esm/tools/ToolNode.mjs.map +1 -1
  175. package/dist/esm/tools/search/search.mjs +11 -3
  176. package/dist/esm/tools/search/search.mjs.map +1 -1
  177. package/dist/esm/tools/search/tavily-scraper.mjs +186 -0
  178. package/dist/esm/tools/search/tavily-scraper.mjs.map +1 -0
  179. package/dist/esm/tools/search/tavily-search.mjs +370 -0
  180. package/dist/esm/tools/search/tavily-search.mjs.map +1 -0
  181. package/dist/esm/tools/search/tool.mjs +28 -4
  182. package/dist/esm/tools/search/tool.mjs.map +1 -1
  183. package/dist/esm/tools/search/utils.mjs +10 -3
  184. package/dist/esm/tools/search/utils.mjs.map +1 -1
  185. package/dist/esm/tools/skillCatalog.mjs +82 -0
  186. package/dist/esm/tools/skillCatalog.mjs.map +1 -0
  187. package/dist/esm/tools/subagent/SubagentExecutor.mjs +506 -0
  188. package/dist/esm/tools/subagent/SubagentExecutor.mjs.map +1 -0
  189. package/dist/esm/tools/toolOutputReferences.mjs +662 -0
  190. package/dist/esm/tools/toolOutputReferences.mjs.map +1 -0
  191. package/dist/esm/types/agent-cache.mjs +51 -0
  192. package/dist/esm/types/agent-cache.mjs.map +1 -0
  193. package/dist/esm/types/graph.mjs.map +1 -1
  194. package/dist/esm/utils/truncation.mjs +128 -0
  195. package/dist/esm/utils/truncation.mjs.map +1 -0
  196. package/dist/types/agents/AgentContext.d.ts +101 -8
  197. package/dist/types/common/enum.d.ts +39 -12
  198. package/dist/types/common/index.d.ts +0 -1
  199. package/dist/types/graphs/Graph.d.ts +43 -0
  200. package/dist/types/graphs/MultiAgentGraph.d.ts +26 -150
  201. package/dist/types/graphs/index.d.ts +0 -1
  202. package/dist/types/hooks/HookRegistry.d.ts +56 -0
  203. package/dist/types/hooks/executeHooks.d.ts +79 -0
  204. package/dist/types/hooks/index.d.ts +6 -0
  205. package/dist/types/hooks/matchers.d.ts +95 -0
  206. package/dist/types/hooks/types.d.ts +320 -0
  207. package/dist/types/index.d.ts +9 -4
  208. package/dist/types/langchain/google-common.d.ts +1 -0
  209. package/dist/types/langchain/index.d.ts +8 -0
  210. package/dist/types/langchain/language_models/chat_models.d.ts +1 -0
  211. package/dist/types/langchain/messages/tool.d.ts +1 -0
  212. package/dist/types/langchain/messages.d.ts +2 -0
  213. package/dist/types/langchain/openai.d.ts +1 -0
  214. package/dist/types/langchain/prompts.d.ts +1 -0
  215. package/dist/types/langchain/runnables.d.ts +2 -0
  216. package/dist/types/langchain/tools.d.ts +2 -0
  217. package/dist/types/langchain/utils/env.d.ts +1 -0
  218. package/dist/types/llm/bedrock/cacheSupport.d.ts +35 -0
  219. package/dist/types/llm/bedrock/index.d.ts +54 -1
  220. package/dist/types/messages/contextPruning.d.ts +42 -0
  221. package/dist/types/messages/contextPruningSettings.d.ts +44 -0
  222. package/dist/types/messages/format.d.ts +9 -1
  223. package/dist/types/messages/index.d.ts +2 -0
  224. package/dist/types/messages/prune.d.ts +91 -1
  225. package/dist/types/run.d.ts +2 -0
  226. package/dist/types/tools/BashExecutor.d.ts +76 -0
  227. package/dist/types/tools/BashProgrammaticToolCalling.d.ts +72 -0
  228. package/dist/types/tools/CodeExecutor.d.ts +8 -26
  229. package/dist/types/tools/ReadFile.d.ts +28 -0
  230. package/dist/types/tools/SkillTool.d.ts +40 -0
  231. package/dist/types/tools/SubagentTool.d.ts +36 -0
  232. package/dist/types/tools/ToolNode.d.ts +77 -5
  233. package/dist/types/tools/search/tavily-scraper.d.ts +19 -0
  234. package/dist/types/tools/search/tavily-search.d.ts +4 -0
  235. package/dist/types/tools/search/types.d.ts +99 -5
  236. package/dist/types/tools/search/utils.d.ts +2 -2
  237. package/dist/types/tools/skillCatalog.d.ts +19 -0
  238. package/dist/types/tools/subagent/SubagentExecutor.d.ts +137 -0
  239. package/dist/types/tools/subagent/index.d.ts +2 -0
  240. package/dist/types/tools/subagent/types.d.ts +84 -0
  241. package/dist/types/tools/toolOutputReferences.d.ts +236 -0
  242. package/dist/types/types/agent-cache.d.ts +70 -0
  243. package/dist/types/types/graph.d.ts +162 -22
  244. package/dist/types/types/index.d.ts +3 -0
  245. package/dist/types/types/messages.d.ts +26 -0
  246. package/dist/types/types/run.d.ts +22 -0
  247. package/dist/types/types/skill.d.ts +9 -0
  248. package/dist/types/types/tools.d.ts +111 -0
  249. package/dist/types/utils/index.d.ts +1 -3
  250. package/dist/types/utils/truncation.d.ts +70 -0
  251. package/package.json +58 -13
  252. package/src/agents/AgentContext.js.map +1 -0
  253. package/src/agents/AgentContext.test.js.map +1 -0
  254. package/src/agents/AgentContext.ts +321 -78
  255. package/src/agents/__tests__/AgentContext.cacheTtl.live.test.ts +259 -0
  256. package/src/agents/__tests__/AgentContext.crossAgentTier1.live.test.ts +264 -0
  257. package/src/agents/__tests__/AgentContext.crossUserCache.live.test.ts +342 -0
  258. package/src/agents/__tests__/AgentContext.test.js.map +1 -0
  259. package/src/agents/__tests__/AgentContext.test.ts +632 -0
  260. package/src/agents/__tests__/resolveStructuredOutputMode.test.js.map +1 -0
  261. package/src/common/__tests__/enum.test.ts +7 -17
  262. package/src/common/enum.js.map +1 -0
  263. package/src/common/enum.ts +43 -12
  264. package/src/common/index.js.map +1 -0
  265. package/src/common/index.ts +0 -1
  266. package/src/events.js.map +1 -0
  267. package/src/graphs/Graph.js.map +1 -0
  268. package/src/graphs/Graph.ts +222 -2
  269. package/src/graphs/MultiAgentGraph.js.map +1 -0
  270. package/src/graphs/MultiAgentGraph.ts +154 -1466
  271. package/src/graphs/__tests__/MultiAgentGraph.test.ts +91 -0
  272. package/src/graphs/__tests__/structured-output.integration.test.js.map +1 -0
  273. package/src/graphs/__tests__/structured-output.test.js.map +1 -0
  274. package/src/graphs/contextManagement.e2e.test.js.map +1 -0
  275. package/src/graphs/contextManagement.test.js.map +1 -0
  276. package/src/graphs/handoffValidation.test.js.map +1 -0
  277. package/src/graphs/index.js.map +1 -0
  278. package/src/graphs/index.ts +0 -1
  279. package/src/hooks/HookRegistry.ts +208 -0
  280. package/src/hooks/__tests__/HookRegistry.test.ts +190 -0
  281. package/src/hooks/__tests__/compactHooks.test.ts +214 -0
  282. package/src/hooks/__tests__/executeHooks.test.ts +1013 -0
  283. package/src/hooks/__tests__/integration.test.ts +337 -0
  284. package/src/hooks/__tests__/matchers.test.ts +238 -0
  285. package/src/hooks/__tests__/toolHooks.test.ts +665 -0
  286. package/src/hooks/executeHooks.ts +375 -0
  287. package/src/hooks/index.ts +57 -0
  288. package/src/hooks/matchers.ts +280 -0
  289. package/src/hooks/types.ts +404 -0
  290. package/src/index.js.map +1 -0
  291. package/src/index.ts +15 -5
  292. package/src/instrumentation.js.map +1 -0
  293. package/src/langchain/google-common.ts +1 -0
  294. package/src/langchain/index.ts +8 -0
  295. package/src/langchain/language_models/chat_models.ts +1 -0
  296. package/src/langchain/messages/tool.ts +5 -0
  297. package/src/langchain/messages.ts +21 -0
  298. package/src/langchain/openai.ts +1 -0
  299. package/src/langchain/prompts.ts +1 -0
  300. package/src/langchain/runnables.ts +7 -0
  301. package/src/langchain/tools.ts +8 -0
  302. package/src/langchain/utils/env.ts +1 -0
  303. package/src/llm/anthropic/index.js.map +1 -0
  304. package/src/llm/anthropic/types.js.map +1 -0
  305. package/src/llm/anthropic/utils/message_inputs.js.map +1 -0
  306. package/src/llm/anthropic/utils/message_inputs.ts +10 -1
  307. package/src/llm/anthropic/utils/message_outputs.js.map +1 -0
  308. package/src/llm/anthropic/utils/output_parsers.js.map +1 -0
  309. package/src/llm/anthropic/utils/server-tool-inputs.test.ts +436 -0
  310. package/src/llm/anthropic/utils/tools.js.map +1 -0
  311. package/src/llm/bedrock/__tests__/bedrock-caching.test.js.map +1 -0
  312. package/src/llm/bedrock/__tests__/bedrock-caching.test.ts +166 -18
  313. package/src/llm/bedrock/cacheSupport.test.ts +99 -0
  314. package/src/llm/bedrock/cacheSupport.ts +53 -0
  315. package/src/llm/bedrock/index.js.map +1 -0
  316. package/src/llm/bedrock/index.ts +116 -41
  317. package/src/llm/bedrock/types.js.map +1 -0
  318. package/src/llm/bedrock/utils/index.js.map +1 -0
  319. package/src/llm/bedrock/utils/message_inputs.js.map +1 -0
  320. package/src/llm/bedrock/utils/message_outputs.js.map +1 -0
  321. package/src/llm/fake.js.map +1 -0
  322. package/src/llm/google/index.js.map +1 -0
  323. package/src/llm/google/types.js.map +1 -0
  324. package/src/llm/google/utils/common.js.map +1 -0
  325. package/src/llm/google/utils/tools.js.map +1 -0
  326. package/src/llm/google/utils/zod_to_genai_parameters.js.map +1 -0
  327. package/src/llm/openai/index.js.map +1 -0
  328. package/src/llm/openai/types.js.map +1 -0
  329. package/src/llm/openai/utils/index.js.map +1 -0
  330. package/src/llm/openai/utils/index.ts +31 -14
  331. package/src/llm/openai/utils/isReasoningModel.test.js.map +1 -0
  332. package/src/llm/openrouter/index.js.map +1 -0
  333. package/src/llm/openrouter/reasoning.test.js.map +1 -0
  334. package/src/llm/providers.js.map +1 -0
  335. package/src/llm/text.js.map +1 -0
  336. package/src/llm/vertexai/index.js.map +1 -0
  337. package/src/messages/__tests__/contextPruning.test.ts +228 -0
  338. package/src/messages/__tests__/tools.test.js.map +1 -0
  339. package/src/messages/cache.js.map +1 -0
  340. package/src/messages/cache.test.js.map +1 -0
  341. package/src/messages/cache.test.ts +62 -24
  342. package/src/messages/cache.ts +112 -0
  343. package/src/messages/content.js.map +1 -0
  344. package/src/messages/content.test.js.map +1 -0
  345. package/src/messages/contextPruning.ts +191 -0
  346. package/src/messages/contextPruningSettings.ts +90 -0
  347. package/src/messages/core.js.map +1 -0
  348. package/src/messages/ensureThinkingBlock.test.js.map +1 -0
  349. package/src/messages/format.js.map +1 -0
  350. package/src/messages/format.ts +164 -12
  351. package/src/messages/formatAgentMessages.skills.test.ts +413 -0
  352. package/src/messages/formatAgentMessages.test.js.map +1 -0
  353. package/src/messages/formatAgentMessages.tools.test.js.map +1 -0
  354. package/src/messages/formatMessage.test.js.map +1 -0
  355. package/src/messages/ids.js.map +1 -0
  356. package/src/messages/index.js.map +1 -0
  357. package/src/messages/index.ts +2 -0
  358. package/src/messages/labelContentByAgent.test.js.map +1 -0
  359. package/src/messages/prune.js.map +1 -0
  360. package/src/messages/prune.ts +661 -4
  361. package/src/messages/reducer.js.map +1 -0
  362. package/src/messages/shiftIndexTokenCountMap.test.js.map +1 -0
  363. package/src/messages/summarize.js.map +1 -0
  364. package/src/messages/summarize.test.js.map +1 -0
  365. package/src/messages/tools.js.map +1 -0
  366. package/src/mockStream.js.map +1 -0
  367. package/src/prompts/collab.js.map +1 -0
  368. package/src/prompts/index.js.map +1 -0
  369. package/src/prompts/taskmanager.js.map +1 -0
  370. package/src/run.js.map +1 -0
  371. package/src/run.ts +155 -1
  372. package/src/schemas/index.js.map +1 -0
  373. package/src/schemas/schema-preparation.test.js.map +1 -0
  374. package/src/schemas/validate.js.map +1 -0
  375. package/src/schemas/validate.test.js.map +1 -0
  376. package/src/scripts/abort.js.map +1 -0
  377. package/src/scripts/ant_web_search.js.map +1 -0
  378. package/src/scripts/ant_web_search_edge_case.js.map +1 -0
  379. package/src/scripts/ant_web_search_error_edge_case.js.map +1 -0
  380. package/src/scripts/args.js.map +1 -0
  381. package/src/scripts/bedrock-cache-debug.js.map +1 -0
  382. package/src/scripts/bedrock-content-aggregation-test.js.map +1 -0
  383. package/src/scripts/bedrock-merge-test.js.map +1 -0
  384. package/src/scripts/bedrock-parallel-tools-test.js.map +1 -0
  385. package/src/scripts/caching.js.map +1 -0
  386. package/src/scripts/cli.js.map +1 -0
  387. package/src/scripts/cli2.js.map +1 -0
  388. package/src/scripts/cli3.js.map +1 -0
  389. package/src/scripts/cli4.js.map +1 -0
  390. package/src/scripts/cli5.js.map +1 -0
  391. package/src/scripts/code_exec.js.map +1 -0
  392. package/src/scripts/code_exec_files.js.map +1 -0
  393. package/src/scripts/code_exec_multi_session.js.map +1 -0
  394. package/src/scripts/code_exec_ptc.js.map +1 -0
  395. package/src/scripts/code_exec_session.js.map +1 -0
  396. package/src/scripts/code_exec_simple.js.map +1 -0
  397. package/src/scripts/content.js.map +1 -0
  398. package/src/scripts/empty_input.js.map +1 -0
  399. package/src/scripts/handoff-test.js.map +1 -0
  400. package/src/scripts/image.js.map +1 -0
  401. package/src/scripts/memory.js.map +1 -0
  402. package/src/scripts/multi-agent-chain.js.map +1 -0
  403. package/src/scripts/multi-agent-chain.ts +2 -2
  404. package/src/scripts/multi-agent-conditional.js.map +1 -0
  405. package/src/scripts/multi-agent-document-review-chain.js.map +1 -0
  406. package/src/scripts/multi-agent-document-review-chain.ts +2 -2
  407. package/src/scripts/multi-agent-hybrid-flow.js.map +1 -0
  408. package/src/scripts/multi-agent-hybrid-flow.ts +4 -4
  409. package/src/scripts/multi-agent-parallel-start.js.map +1 -0
  410. package/src/scripts/multi-agent-parallel.js.map +1 -0
  411. package/src/scripts/multi-agent-parallel.ts +3 -3
  412. package/src/scripts/multi-agent-sequence.js.map +1 -0
  413. package/src/scripts/multi-agent-sequence.ts +3 -3
  414. package/src/scripts/multi-agent-subagent.ts +246 -0
  415. package/src/scripts/multi-agent-supervisor.js.map +1 -0
  416. package/src/scripts/multi-agent-supervisor.ts +5 -5
  417. package/src/scripts/multi-agent-test.js.map +1 -0
  418. package/src/scripts/parallel-asymmetric-tools-test.js.map +1 -0
  419. package/src/scripts/parallel-full-metadata-test.js.map +1 -0
  420. package/src/scripts/parallel-tools-test.js.map +1 -0
  421. package/src/scripts/poc-multi-agent-comprehensive.ts +8 -8
  422. package/src/scripts/programmatic_exec.js.map +1 -0
  423. package/src/scripts/programmatic_exec_agent.js.map +1 -0
  424. package/src/scripts/search.js.map +1 -0
  425. package/src/scripts/sequential-full-metadata-test.js.map +1 -0
  426. package/src/scripts/sequential-full-metadata-test.ts +2 -2
  427. package/src/scripts/simple.js.map +1 -0
  428. package/src/scripts/single-agent-metadata-test.js.map +1 -0
  429. package/src/scripts/stream.js.map +1 -0
  430. package/src/scripts/subagent-event-driven-debug.ts +190 -0
  431. package/src/scripts/subagent-tools-debug.ts +160 -0
  432. package/src/scripts/test-custom-prompt-key.js.map +1 -0
  433. package/src/scripts/test-custom-prompt-key.ts +3 -3
  434. package/src/scripts/test-handoff-input.js.map +1 -0
  435. package/src/scripts/test-handoff-input.ts +1 -1
  436. package/src/scripts/test-handoff-preamble.js.map +1 -0
  437. package/src/scripts/test-handoff-steering.js.map +1 -0
  438. package/src/scripts/test-handoff-steering.ts +3 -3
  439. package/src/scripts/test-multi-agent-list-handoff.js.map +1 -0
  440. package/src/scripts/test-multi-agent-list-handoff.ts +1 -1
  441. package/src/scripts/test-parallel-agent-labeling.js.map +1 -0
  442. package/src/scripts/test-parallel-agent-labeling.ts +3 -3
  443. package/src/scripts/test-parallel-handoffs.js.map +1 -0
  444. package/src/scripts/test-parallel-handoffs.ts +2 -2
  445. package/src/scripts/test-thinking-handoff-bedrock.js.map +1 -0
  446. package/src/scripts/test-thinking-handoff-bedrock.ts +1 -1
  447. package/src/scripts/test-thinking-handoff.js.map +1 -0
  448. package/src/scripts/test-thinking-handoff.ts +1 -1
  449. package/src/scripts/test-thinking-to-thinking-handoff-bedrock.js.map +1 -0
  450. package/src/scripts/test-thinking-to-thinking-handoff-bedrock.ts +1 -1
  451. package/src/scripts/test-tool-before-handoff-role-order.js.map +1 -0
  452. package/src/scripts/test-tool-before-handoff-role-order.ts +1 -1
  453. package/src/scripts/test-tools-before-handoff.js.map +1 -0
  454. package/src/scripts/test-tools-before-handoff.ts +1 -1
  455. package/src/scripts/test_code_api.js.map +1 -0
  456. package/src/scripts/thinking-bedrock.js.map +1 -0
  457. package/src/scripts/thinking-vertexai.js.map +1 -0
  458. package/src/scripts/thinking.js.map +1 -0
  459. package/src/scripts/tool_search.js.map +1 -0
  460. package/src/scripts/tools.js.map +1 -0
  461. package/src/specs/agent-handoffs-bedrock.integration.test.js.map +1 -0
  462. package/src/specs/agent-handoffs.test.js.map +1 -0
  463. package/src/specs/agent-handoffs.test.ts +26 -483
  464. package/src/specs/anthropic.simple.test.js.map +1 -0
  465. package/src/specs/anthropic.simple.test.ts +61 -0
  466. package/src/specs/azure.simple.test.js.map +1 -0
  467. package/src/specs/cache.simple.test.js.map +1 -0
  468. package/src/specs/custom-event-await.test.js.map +1 -0
  469. package/src/specs/deepseek.simple.test.js.map +1 -0
  470. package/src/specs/emergency-prune.test.js.map +1 -0
  471. package/src/specs/moonshot.simple.test.js.map +1 -0
  472. package/src/specs/multi-agent-summarization.test.ts +396 -0
  473. package/src/specs/observability.integration.test.js.map +1 -0
  474. package/src/specs/openai.simple.test.js.map +1 -0
  475. package/src/specs/openrouter.simple.test.js.map +1 -0
  476. package/src/specs/prune.orphans.test.ts +248 -0
  477. package/src/specs/prune.test.js.map +1 -0
  478. package/src/specs/prune.test.ts +104 -16
  479. package/src/specs/reasoning.test.js.map +1 -0
  480. package/src/specs/spec.utils.js.map +1 -0
  481. package/src/specs/thinking-handoff.test.js.map +1 -0
  482. package/src/specs/thinking-handoff.test.ts +19 -19
  483. package/src/specs/thinking-prune.test.js.map +1 -0
  484. package/src/specs/token-distribution-edge-case.test.js.map +1 -0
  485. package/src/specs/token-memoization.test.js.map +1 -0
  486. package/src/specs/tokens.test.js.map +1 -0
  487. package/src/specs/tool-error.test.js.map +1 -0
  488. package/src/splitStream.js.map +1 -0
  489. package/src/splitStream.test.js.map +1 -0
  490. package/src/stream.js.map +1 -0
  491. package/src/stream.test.js.map +1 -0
  492. package/src/test/mockTools.js.map +1 -0
  493. package/src/tools/BashExecutor.ts +281 -0
  494. package/src/tools/BashProgrammaticToolCalling.ts +397 -0
  495. package/src/tools/BrowserTools.js.map +1 -0
  496. package/src/tools/Calculator.js.map +1 -0
  497. package/src/tools/Calculator.test.js.map +1 -0
  498. package/src/tools/CodeExecutor.js.map +1 -0
  499. package/src/tools/CodeExecutor.ts +62 -54
  500. package/src/tools/ProgrammaticToolCalling.js.map +1 -0
  501. package/src/tools/ProgrammaticToolCalling.ts +29 -14
  502. package/src/tools/ReadFile.ts +39 -0
  503. package/src/tools/SkillTool.ts +46 -0
  504. package/src/tools/StreamingToolCallBuffer.js.map +1 -0
  505. package/src/tools/SubagentTool.ts +100 -0
  506. package/src/tools/ToolNode.js.map +1 -0
  507. package/src/tools/ToolNode.ts +548 -26
  508. package/src/tools/ToolSearch.js.map +1 -0
  509. package/src/tools/__tests__/BashExecutor.test.ts +49 -0
  510. package/src/tools/__tests__/BrowserTools.test.js.map +1 -0
  511. package/src/tools/__tests__/CodeExecutor.test.ts +37 -36
  512. package/src/tools/__tests__/ProgrammaticToolCalling.integration.test.js.map +1 -0
  513. package/src/tools/__tests__/ProgrammaticToolCalling.test.js.map +1 -0
  514. package/src/tools/__tests__/ProgrammaticToolCalling.test.ts +60 -0
  515. package/src/tools/__tests__/ReadFile.test.ts +44 -0
  516. package/src/tools/__tests__/SkillTool.test.ts +442 -0
  517. package/src/tools/__tests__/StreamingToolCallBuffer.test.js.map +1 -0
  518. package/src/tools/__tests__/SubagentExecutor.test.ts +1148 -0
  519. package/src/tools/__tests__/SubagentTool.test.ts +149 -0
  520. package/src/tools/__tests__/ToolApproval.test.js.map +1 -0
  521. package/src/tools/__tests__/ToolNode.outputReferences.test.ts +1438 -0
  522. package/src/tools/__tests__/ToolNode.recovery.test.js.map +1 -0
  523. package/src/tools/__tests__/ToolNode.session.test.js.map +1 -0
  524. package/src/tools/__tests__/ToolSearch.integration.test.js.map +1 -0
  525. package/src/tools/__tests__/ToolSearch.test.js.map +1 -0
  526. package/src/tools/__tests__/annotateMessagesForLLM.test.ts +479 -0
  527. package/src/tools/__tests__/handlers.test.js.map +1 -0
  528. package/src/tools/__tests__/skillCatalog.test.ts +161 -0
  529. package/src/tools/__tests__/subagentHooks.test.ts +210 -0
  530. package/src/tools/__tests__/toolOutputReferences.test.ts +415 -0
  531. package/src/tools/__tests__/truncation-recovery.integration.test.js.map +1 -0
  532. package/src/tools/handlers.js.map +1 -0
  533. package/src/tools/schema.js.map +1 -0
  534. package/src/tools/search/anthropic.js.map +1 -0
  535. package/src/tools/search/content.js.map +1 -0
  536. package/src/tools/search/content.test.js.map +1 -0
  537. package/src/tools/search/firecrawl.js.map +1 -0
  538. package/src/tools/search/format.js.map +1 -0
  539. package/src/tools/search/highlights.js.map +1 -0
  540. package/src/tools/search/index.js.map +1 -0
  541. package/src/tools/search/jina-reranker.test.js.map +1 -0
  542. package/src/tools/search/rerankers.js.map +1 -0
  543. package/src/tools/search/schema.js.map +1 -0
  544. package/src/tools/search/search.js.map +1 -0
  545. package/src/tools/search/search.ts +12 -2
  546. package/src/tools/search/serper-scraper.js.map +1 -0
  547. package/src/tools/search/tavily-scraper.ts +235 -0
  548. package/src/tools/search/tavily-search.ts +424 -0
  549. package/src/tools/search/tavily.test.ts +965 -0
  550. package/src/tools/search/test.js.map +1 -0
  551. package/src/tools/search/tool.js.map +1 -0
  552. package/src/tools/search/tool.ts +36 -2
  553. package/src/tools/search/types.js.map +1 -0
  554. package/src/tools/search/types.ts +133 -8
  555. package/src/tools/search/utils.js.map +1 -0
  556. package/src/tools/search/utils.ts +13 -5
  557. package/src/tools/skillCatalog.ts +126 -0
  558. package/src/tools/subagent/SubagentExecutor.ts +676 -0
  559. package/src/tools/subagent/index.ts +13 -0
  560. package/src/tools/subagent/types.test.ts +70 -0
  561. package/src/tools/subagent/types.ts +115 -0
  562. package/src/tools/toolOutputReferences.ts +825 -0
  563. package/src/types/agent-cache.ts +73 -0
  564. package/src/types/graph.js.map +1 -0
  565. package/src/types/graph.test.js.map +1 -0
  566. package/src/types/graph.ts +171 -20
  567. package/src/types/index.js.map +1 -0
  568. package/src/types/index.ts +3 -0
  569. package/src/types/llm.js.map +1 -0
  570. package/src/types/messages.js.map +1 -0
  571. package/src/types/messages.ts +27 -0
  572. package/src/types/run.js.map +1 -0
  573. package/src/types/run.ts +22 -0
  574. package/src/types/skill.ts +11 -0
  575. package/src/types/stream.js.map +1 -0
  576. package/src/types/tools.js.map +1 -0
  577. package/src/types/tools.ts +118 -0
  578. package/src/utils/__tests__/truncation.test.ts +66 -0
  579. package/src/utils/contextAnalytics.js.map +1 -0
  580. package/src/utils/contextAnalytics.test.js.map +1 -0
  581. package/src/utils/events.js.map +1 -0
  582. package/src/utils/graph.js.map +1 -0
  583. package/src/utils/handlers.js.map +1 -0
  584. package/src/utils/index.js.map +1 -0
  585. package/src/utils/index.ts +1 -3
  586. package/src/utils/llm.js.map +1 -0
  587. package/src/utils/llmConfig.js.map +1 -0
  588. package/src/utils/logging.js.map +1 -0
  589. package/src/utils/misc.js.map +1 -0
  590. package/src/utils/run.js.map +1 -0
  591. package/src/utils/schema.js.map +1 -0
  592. package/src/utils/title.js.map +1 -0
  593. package/src/utils/tokens.js.map +1 -0
  594. package/src/utils/toonFormat.js.map +1 -0
  595. package/src/utils/truncation.ts +154 -0
  596. package/dist/cjs/common/spawnPath.cjs +0 -104
  597. package/dist/cjs/common/spawnPath.cjs.map +0 -1
  598. package/dist/cjs/graphs/HandoffRegistry.cjs +0 -143
  599. package/dist/cjs/graphs/HandoffRegistry.cjs.map +0 -1
  600. package/dist/cjs/providers/a2a/A2ACapabilityProvider.cjs +0 -288
  601. package/dist/cjs/providers/a2a/A2ACapabilityProvider.cjs.map +0 -1
  602. package/dist/cjs/providers/a2a/client.cjs +0 -92
  603. package/dist/cjs/providers/a2a/client.cjs.map +0 -1
  604. package/dist/cjs/providers/a2a/config.cjs +0 -38
  605. package/dist/cjs/providers/a2a/config.cjs.map +0 -1
  606. package/dist/cjs/providers/capabilityNaming.cjs +0 -43
  607. package/dist/cjs/providers/capabilityNaming.cjs.map +0 -1
  608. package/dist/cjs/providers/mcp/MCPCapabilityProvider.cjs +0 -244
  609. package/dist/cjs/providers/mcp/MCPCapabilityProvider.cjs.map +0 -1
  610. package/dist/cjs/providers/mcp/config.cjs +0 -42
  611. package/dist/cjs/providers/mcp/config.cjs.map +0 -1
  612. package/dist/cjs/providers/mcp/transport.cjs +0 -65
  613. package/dist/cjs/providers/mcp/transport.cjs.map +0 -1
  614. package/dist/cjs/providers/tools-server/ToolsServerCapabilityProvider.cjs +0 -128
  615. package/dist/cjs/providers/tools-server/ToolsServerCapabilityProvider.cjs.map +0 -1
  616. package/dist/cjs/providers/types.cjs +0 -51
  617. package/dist/cjs/providers/types.cjs.map +0 -1
  618. package/dist/cjs/tools/artifacts/schema.cjs +0 -86
  619. package/dist/cjs/tools/artifacts/schema.cjs.map +0 -1
  620. package/dist/cjs/tools/artifacts/tool.cjs +0 -219
  621. package/dist/cjs/tools/artifacts/tool.cjs.map +0 -1
  622. package/dist/cjs/tools/fileSearch/formatter.cjs +0 -93
  623. package/dist/cjs/tools/fileSearch/formatter.cjs.map +0 -1
  624. package/dist/cjs/tools/fileSearch/ragClient.cjs +0 -102
  625. package/dist/cjs/tools/fileSearch/ragClient.cjs.map +0 -1
  626. package/dist/cjs/tools/fileSearch/schema.cjs +0 -18
  627. package/dist/cjs/tools/fileSearch/schema.cjs.map +0 -1
  628. package/dist/cjs/tools/fileSearch/tool.cjs +0 -155
  629. package/dist/cjs/tools/fileSearch/tool.cjs.map +0 -1
  630. package/dist/cjs/tools/proxyTool.cjs +0 -102
  631. package/dist/cjs/tools/proxyTool.cjs.map +0 -1
  632. package/dist/cjs/utils/childAgentContext.cjs +0 -242
  633. package/dist/cjs/utils/childAgentContext.cjs.map +0 -1
  634. package/dist/cjs/utils/credentials.cjs +0 -142
  635. package/dist/cjs/utils/credentials.cjs.map +0 -1
  636. package/dist/cjs/utils/httpClient.cjs +0 -74
  637. package/dist/cjs/utils/httpClient.cjs.map +0 -1
  638. package/dist/cjs/utils/toolManifest.cjs +0 -100
  639. package/dist/cjs/utils/toolManifest.cjs.map +0 -1
  640. package/dist/esm/common/spawnPath.mjs +0 -95
  641. package/dist/esm/common/spawnPath.mjs.map +0 -1
  642. package/dist/esm/graphs/HandoffRegistry.mjs +0 -141
  643. package/dist/esm/graphs/HandoffRegistry.mjs.map +0 -1
  644. package/dist/esm/providers/a2a/A2ACapabilityProvider.mjs +0 -281
  645. package/dist/esm/providers/a2a/A2ACapabilityProvider.mjs.map +0 -1
  646. package/dist/esm/providers/a2a/client.mjs +0 -88
  647. package/dist/esm/providers/a2a/client.mjs.map +0 -1
  648. package/dist/esm/providers/a2a/config.mjs +0 -35
  649. package/dist/esm/providers/a2a/config.mjs.map +0 -1
  650. package/dist/esm/providers/capabilityNaming.mjs +0 -39
  651. package/dist/esm/providers/capabilityNaming.mjs.map +0 -1
  652. package/dist/esm/providers/mcp/MCPCapabilityProvider.mjs +0 -240
  653. package/dist/esm/providers/mcp/MCPCapabilityProvider.mjs.map +0 -1
  654. package/dist/esm/providers/mcp/config.mjs +0 -39
  655. package/dist/esm/providers/mcp/config.mjs.map +0 -1
  656. package/dist/esm/providers/mcp/transport.mjs +0 -63
  657. package/dist/esm/providers/mcp/transport.mjs.map +0 -1
  658. package/dist/esm/providers/tools-server/ToolsServerCapabilityProvider.mjs +0 -126
  659. package/dist/esm/providers/tools-server/ToolsServerCapabilityProvider.mjs.map +0 -1
  660. package/dist/esm/providers/types.mjs +0 -51
  661. package/dist/esm/providers/types.mjs.map +0 -1
  662. package/dist/esm/tools/artifacts/schema.mjs +0 -79
  663. package/dist/esm/tools/artifacts/schema.mjs.map +0 -1
  664. package/dist/esm/tools/artifacts/tool.mjs +0 -213
  665. package/dist/esm/tools/artifacts/tool.mjs.map +0 -1
  666. package/dist/esm/tools/fileSearch/formatter.mjs +0 -90
  667. package/dist/esm/tools/fileSearch/formatter.mjs.map +0 -1
  668. package/dist/esm/tools/fileSearch/ragClient.mjs +0 -98
  669. package/dist/esm/tools/fileSearch/ragClient.mjs.map +0 -1
  670. package/dist/esm/tools/fileSearch/schema.mjs +0 -15
  671. package/dist/esm/tools/fileSearch/schema.mjs.map +0 -1
  672. package/dist/esm/tools/fileSearch/tool.mjs +0 -152
  673. package/dist/esm/tools/fileSearch/tool.mjs.map +0 -1
  674. package/dist/esm/tools/proxyTool.mjs +0 -100
  675. package/dist/esm/tools/proxyTool.mjs.map +0 -1
  676. package/dist/esm/utils/childAgentContext.mjs +0 -237
  677. package/dist/esm/utils/childAgentContext.mjs.map +0 -1
  678. package/dist/esm/utils/credentials.mjs +0 -135
  679. package/dist/esm/utils/credentials.mjs.map +0 -1
  680. package/dist/esm/utils/httpClient.mjs +0 -70
  681. package/dist/esm/utils/httpClient.mjs.map +0 -1
  682. package/dist/esm/utils/toolManifest.mjs +0 -96
  683. package/dist/esm/utils/toolManifest.mjs.map +0 -1
  684. package/dist/types/common/spawnPath.d.ts +0 -59
  685. package/dist/types/graphs/HandoffRegistry.d.ts +0 -97
  686. package/dist/types/providers/a2a/A2ACapabilityProvider.d.ts +0 -89
  687. package/dist/types/providers/a2a/client.d.ts +0 -47
  688. package/dist/types/providers/a2a/config.d.ts +0 -18
  689. package/dist/types/providers/a2a/index.d.ts +0 -6
  690. package/dist/types/providers/a2a/types.d.ts +0 -173
  691. package/dist/types/providers/capabilityNaming.d.ts +0 -25
  692. package/dist/types/providers/index.d.ts +0 -12
  693. package/dist/types/providers/mcp/MCPCapabilityProvider.d.ts +0 -54
  694. package/dist/types/providers/mcp/config.d.ts +0 -20
  695. package/dist/types/providers/mcp/index.d.ts +0 -5
  696. package/dist/types/providers/mcp/transport.d.ts +0 -18
  697. package/dist/types/providers/mcp/types.d.ts +0 -112
  698. package/dist/types/providers/tools-server/ToolsServerCapabilityProvider.d.ts +0 -59
  699. package/dist/types/providers/tools-server/index.d.ts +0 -1
  700. package/dist/types/providers/types.d.ts +0 -184
  701. package/dist/types/tools/artifacts/index.d.ts +0 -3
  702. package/dist/types/tools/artifacts/schema.d.ts +0 -63
  703. package/dist/types/tools/artifacts/tool.d.ts +0 -16
  704. package/dist/types/tools/artifacts/types.d.ts +0 -127
  705. package/dist/types/tools/fileSearch/formatter.d.ts +0 -25
  706. package/dist/types/tools/fileSearch/index.d.ts +0 -5
  707. package/dist/types/tools/fileSearch/ragClient.d.ts +0 -32
  708. package/dist/types/tools/fileSearch/schema.d.ts +0 -13
  709. package/dist/types/tools/fileSearch/tool.d.ts +0 -18
  710. package/dist/types/tools/fileSearch/types.d.ts +0 -139
  711. package/dist/types/tools/proxyTool.d.ts +0 -62
  712. package/dist/types/utils/childAgentContext.d.ts +0 -99
  713. package/dist/types/utils/credentials.d.ts +0 -77
  714. package/dist/types/utils/httpClient.d.ts +0 -46
  715. package/dist/types/utils/toolManifest.d.ts +0 -49
  716. package/src/common/__tests__/spawnPath.test.ts +0 -110
  717. package/src/common/spawnPath.ts +0 -101
  718. package/src/graphs/HandoffRegistry.ts +0 -199
  719. package/src/graphs/__tests__/HandoffRegistry.test.ts +0 -410
  720. package/src/graphs/__tests__/multi-agent-delegate.test.ts +0 -458
  721. package/src/graphs/__tests__/multi-agent-edges.test.ts +0 -276
  722. package/src/graphs/__tests__/multi-agent-nested-subgraph.test.ts +0 -221
  723. package/src/graphs/handoffValidation.test.ts +0 -353
  724. package/src/providers/__tests__/ToolsServerCapabilityProvider.integration.spec.ts +0 -79
  725. package/src/providers/__tests__/ToolsServerCapabilityProvider.test.ts +0 -269
  726. package/src/providers/__tests__/types.test.ts +0 -64
  727. package/src/providers/a2a/A2ACapabilityProvider.ts +0 -384
  728. package/src/providers/a2a/__tests__/A2ACapabilityProvider.integration.spec.ts +0 -345
  729. package/src/providers/a2a/__tests__/A2ACapabilityProvider.test.ts +0 -460
  730. package/src/providers/a2a/client.ts +0 -115
  731. package/src/providers/a2a/config.ts +0 -40
  732. package/src/providers/a2a/index.ts +0 -29
  733. package/src/providers/a2a/types.ts +0 -191
  734. package/src/providers/capabilityNaming.ts +0 -42
  735. package/src/providers/index.ts +0 -68
  736. package/src/providers/mcp/MCPCapabilityProvider.ts +0 -345
  737. package/src/providers/mcp/__tests__/MCPCapabilityProvider.integration.spec.ts +0 -386
  738. package/src/providers/mcp/__tests__/MCPCapabilityProvider.test.ts +0 -371
  739. package/src/providers/mcp/config.ts +0 -45
  740. package/src/providers/mcp/index.ts +0 -21
  741. package/src/providers/mcp/transport.ts +0 -76
  742. package/src/providers/mcp/types.ts +0 -139
  743. package/src/providers/tools-server/ToolsServerCapabilityProvider.ts +0 -248
  744. package/src/providers/tools-server/index.ts +0 -1
  745. package/src/providers/types.ts +0 -204
  746. package/src/scripts/test-bedrock-handoff-autonomous.ts +0 -267
  747. package/src/scripts/test-handoff-preamble.ts +0 -278
  748. package/src/specs/agent-handoffs-bedrock.integration.test.ts +0 -415
  749. package/src/tools/artifacts/__tests__/tool.test.ts +0 -259
  750. package/src/tools/artifacts/index.ts +0 -33
  751. package/src/tools/artifacts/schema.ts +0 -99
  752. package/src/tools/artifacts/tool.ts +0 -289
  753. package/src/tools/artifacts/types.ts +0 -162
  754. package/src/tools/fileSearch/__tests__/tool.test.ts +0 -261
  755. package/src/tools/fileSearch/formatter.ts +0 -129
  756. package/src/tools/fileSearch/index.ts +0 -23
  757. package/src/tools/fileSearch/ragClient.ts +0 -137
  758. package/src/tools/fileSearch/schema.ts +0 -19
  759. package/src/tools/fileSearch/tool.ts +0 -207
  760. package/src/tools/fileSearch/types.ts +0 -149
  761. package/src/tools/proxyTool.ts +0 -166
  762. package/src/utils/__tests__/childAgentContext.test.ts +0 -217
  763. package/src/utils/__tests__/credentials.test.ts +0 -130
  764. package/src/utils/__tests__/httpClient.test.ts +0 -75
  765. package/src/utils/__tests__/toolManifest.test.ts +0 -116
  766. package/src/utils/childAgentContext.ts +0 -259
  767. package/src/utils/credentials.ts +0 -157
  768. package/src/utils/httpClient.ts +0 -92
  769. package/src/utils/toolManifest.ts +0 -109
@@ -12,6 +12,8 @@ import type * as t from '@/types';
12
12
  import type { createPruneMessages } from '@/messages';
13
13
  import { createSchemaOnlyTools } from '@/tools/schema';
14
14
  import { ContentTypes, Providers } from '@/common';
15
+ import { MAX_SYSTEM_CACHE_BLOCKS } from '@/types/agent-cache';
16
+ import { isBedrockCacheSupported } from '@/llm/bedrock/cacheSupport';
15
17
  import { toJsonSchema } from '@/utils/schema';
16
18
 
17
19
  /**
@@ -37,7 +39,9 @@ export class AgentContext {
37
39
  toolEnd,
38
40
  toolRegistry,
39
41
  toolDefinitions,
42
+ system_cache_blocks,
40
43
  instructions,
44
+ instructions_cache_ttl,
41
45
  additional_instructions,
42
46
  streamBuffer,
43
47
  maxContextTokens,
@@ -85,7 +89,9 @@ export class AgentContext {
85
89
  toolMap,
86
90
  toolRegistry,
87
91
  toolDefinitions,
92
+ systemCacheBlocks: system_cache_blocks,
88
93
  instructions,
94
+ instructionsCacheTtl: instructions_cache_ttl,
89
95
  additionalInstructions: additional_instructions,
90
96
  reasoningKey,
91
97
  toolEnd,
@@ -101,6 +107,16 @@ export class AgentContext {
101
107
  fileManifest,
102
108
  });
103
109
 
110
+ /**
111
+ * Track upstream-aligned subagent inputs on the context. `_sourceInputs`
112
+ * preserves the original AgentInputs so SubagentExecutor can self-spawn
113
+ * (`SubagentConfig.self === true`) without separate config; the other
114
+ * two flow straight from agentConfig.
115
+ */
116
+ agentContext._sourceInputs = agentConfig;
117
+ agentContext.subagentConfigs = agentConfig.subagentConfigs;
118
+ agentContext.maxSubagentDepth = agentConfig.maxSubagentDepth;
119
+
104
120
  if (tokenCounter) {
105
121
  // Initialize system runnable BEFORE async tool token calculation
106
122
  // This ensures system message tokens are in instructionTokens before
@@ -173,9 +189,18 @@ export class AgentContext {
173
189
  toolDefinitions?: t.LCTool[];
174
190
  /** Set of tool names discovered via tool search (to be loaded) */
175
191
  discoveredToolNames: Set<string> = new Set();
176
- /** Instructions for this agent */
192
+ /**
193
+ * Cacheable system content blocks emitted before `instructions`. Each
194
+ * gets its own cache marker (cachePoint on Bedrock, cache_control on
195
+ * Anthropic). Earlier entries = wider cache key (best for cross-tenant
196
+ * sharing). See `src/types/agent-cache.ts`.
197
+ */
198
+ systemCacheBlocks?: t.SystemCacheBlock[];
199
+ /** Stable/cacheable instructions for this agent (gets trailing marker). */
177
200
  instructions?: string;
178
- /** Additional instructions for this agent */
201
+ /** TTL for the trailing instructions cache marker. Defaults to '5m'. */
202
+ instructionsCacheTtl?: t.AgentCacheTTL;
203
+ /** Dynamic system tail (per-user / per-message — never cached). */
179
204
  additionalInstructions?: string;
180
205
  /**
181
206
  * Dynamic context that changes per-request (e.g., current time, user info).
@@ -254,6 +279,12 @@ export class AgentContext {
254
279
  summarizationConfig?: t.SummarizationConfig;
255
280
  /** Lightweight file manifest for file-aware compaction (IDs and names only, no content) */
256
281
  fileManifest?: t.FileManifestEntry[];
282
+ /** Original AgentInputs used to create this context — used for self-spawn subagent resolution. */
283
+ _sourceInputs?: t.AgentInputs;
284
+ /** Subagent configurations for hierarchical delegation. */
285
+ subagentConfigs?: t.SubagentConfig[];
286
+ /** Maximum subagent nesting depth. */
287
+ maxSubagentDepth?: number;
257
288
 
258
289
  constructor({
259
290
  agentId,
@@ -268,7 +299,9 @@ export class AgentContext {
268
299
  toolMap,
269
300
  toolRegistry,
270
301
  toolDefinitions,
302
+ systemCacheBlocks,
271
303
  instructions,
304
+ instructionsCacheTtl,
272
305
  additionalInstructions,
273
306
  dynamicContext,
274
307
  reasoningKey,
@@ -294,7 +327,9 @@ export class AgentContext {
294
327
  toolMap?: t.ToolMap;
295
328
  toolRegistry?: t.LCToolRegistry;
296
329
  toolDefinitions?: t.LCTool[];
330
+ systemCacheBlocks?: t.SystemCacheBlock[];
297
331
  instructions?: string;
332
+ instructionsCacheTtl?: t.AgentCacheTTL;
298
333
  additionalInstructions?: string;
299
334
  dynamicContext?: string;
300
335
  reasoningKey?: 'reasoning_content' | 'reasoning';
@@ -322,7 +357,20 @@ export class AgentContext {
322
357
  this.toolMap = toolMap;
323
358
  this.toolRegistry = toolRegistry;
324
359
  this.toolDefinitions = toolDefinitions;
360
+ if (
361
+ systemCacheBlocks &&
362
+ systemCacheBlocks.length > MAX_SYSTEM_CACHE_BLOCKS
363
+ ) {
364
+ throw new Error(
365
+ `system_cache_blocks supports at most ${MAX_SYSTEM_CACHE_BLOCKS} entries ` +
366
+ `(received ${systemCacheBlocks.length}); excess entries would exceed ` +
367
+ `Bedrock's 4-cachePoint per-request budget once the tools array and ` +
368
+ `trailing 'instructions' marker are counted. See src/types/agent-cache.ts.`,
369
+ );
370
+ }
371
+ this.systemCacheBlocks = systemCacheBlocks;
325
372
  this.instructions = instructions;
373
+ this.instructionsCacheTtl = instructionsCacheTtl;
326
374
  this.additionalInstructions = additionalInstructions;
327
375
  this.dynamicContext = dynamicContext;
328
376
  this.structuredOutput = structuredOutput;
@@ -557,8 +605,11 @@ export class AgentContext {
557
605
  }
558
606
 
559
607
  // Stale or first access - rebuild
560
- const instructionsString = this.buildInstructionsString();
561
- this.cachedSystemRunnable = this.buildSystemRunnable(instructionsString);
608
+ this.cachedSystemRunnable = this.buildSystemRunnable({
609
+ systemCacheBlocks: this.systemCacheBlocks ?? [],
610
+ stableInstructions: this.buildStableInstructionsString(),
611
+ dynamicInstructions: this.buildDynamicInstructionsString(),
612
+ });
562
613
  this.systemRunnableStale = false;
563
614
  return this.cachedSystemRunnable;
564
615
  }
@@ -569,17 +620,27 @@ export class AgentContext {
569
620
  */
570
621
  initializeSystemRunnable(): void {
571
622
  if (this.systemRunnableStale || this.cachedSystemRunnable === undefined) {
572
- const instructionsString = this.buildInstructionsString();
573
- this.cachedSystemRunnable = this.buildSystemRunnable(instructionsString);
623
+ this.cachedSystemRunnable = this.buildSystemRunnable({
624
+ systemCacheBlocks: this.systemCacheBlocks ?? [],
625
+ stableInstructions: this.buildStableInstructionsString(),
626
+ dynamicInstructions: this.buildDynamicInstructionsString(),
627
+ });
574
628
  this.systemRunnableStale = false;
575
629
  }
576
630
  }
577
631
 
578
632
  /**
579
- * Builds the raw instructions string (without creating SystemMessage).
580
- * Includes agent identity preamble and handoff context when available.
633
+ * Builds the cacheable instructions string (without creating SystemMessage).
634
+ * Includes agent identity preamble, the agent's static instructions, and
635
+ * programmatic-only tool documentation. This is the part of the system
636
+ * message that stays byte-stable across turns and across users for the
637
+ * same agent — the prompt cache prefix.
638
+ *
639
+ * Per-user/per-message dynamic context belongs in
640
+ * `buildDynamicInstructionsString()` so it does not invalidate the cache
641
+ * marker. (See `feedback_cache_stability_invariant` for the rule.)
581
642
  */
582
- private buildInstructionsString(): string {
643
+ private buildStableInstructionsString(): string {
583
644
  const parts: string[] = [];
584
645
 
585
646
  /** Build agent identity and handoff context preamble */
@@ -593,7 +654,27 @@ export class AgentContext {
593
654
  parts.push(this.instructions);
594
655
  }
595
656
 
596
- /** Add additional instructions */
657
+ /** Add programmatic tools documentation */
658
+ const programmaticToolsDoc = this.buildProgrammaticOnlyToolsInstructions();
659
+ if (programmaticToolsDoc) {
660
+ parts.push(programmaticToolsDoc);
661
+ }
662
+
663
+ return parts.join('\n\n');
664
+ }
665
+
666
+ /**
667
+ * Builds the dynamic system-tail string (without creating SystemMessage).
668
+ * Keep this out of prompt-cache-marked content so volatile per-call
669
+ * context does not invalidate the stable prefix.
670
+ *
671
+ * `additional_instructions` is treated as dynamic (per-user/per-message
672
+ * memory, runtime context, etc.) and intentionally excluded from the
673
+ * cacheable prefix.
674
+ */
675
+ private buildDynamicInstructionsString(): string {
676
+ const parts: string[] = [];
677
+
597
678
  if (
598
679
  this.additionalInstructions != null &&
599
680
  this.additionalInstructions !== ''
@@ -601,12 +682,6 @@ export class AgentContext {
601
682
  parts.push(this.additionalInstructions);
602
683
  }
603
684
 
604
- /** Add programmatic tools documentation */
605
- const programmaticToolsDoc = this.buildProgrammaticOnlyToolsInstructions();
606
- if (programmaticToolsDoc) {
607
- parts.push(programmaticToolsDoc);
608
- }
609
-
610
685
  return parts.join('\n\n');
611
686
  }
612
687
 
@@ -662,43 +737,168 @@ export class AgentContext {
662
737
  }
663
738
 
664
739
  /**
665
- * Build system runnable from pre-built instructions string.
666
- * Only called when content has actually changed.
740
+ * True when Anthropic prompt caching is enabled for this agent.
741
+ * Used by `buildSystemRunnable` to decide whether to emit a cache_control
742
+ * marker on the stable instructions prefix.
743
+ */
744
+ private hasAnthropicPromptCache(): boolean {
745
+ if (this.provider !== Providers.ANTHROPIC) {
746
+ return false;
747
+ }
748
+ const anthropicOptions = this.clientOptions as
749
+ | t.AnthropicClientOptions
750
+ | undefined;
751
+ return anthropicOptions?.promptCache === true;
752
+ }
753
+
754
+ /**
755
+ * True when Bedrock prompt caching is enabled for this agent AND the
756
+ * configured model supports `cachePoint` blocks. Only Claude (and Nova)
757
+ * models on Bedrock honour cachePoint — Llama / Titan reject it.
758
+ *
759
+ * Used by `buildSystemRunnable` to inline a `cachePoint` block right
760
+ * after the stable system text so the system prefix is cached at the
761
+ * AWS account level (cross-user, cross-conversation).
762
+ */
763
+ private hasBedrockPromptCache(): boolean {
764
+ if (this.provider !== Providers.BEDROCK) {
765
+ return false;
766
+ }
767
+ const bedrockOptions = this.clientOptions as
768
+ | (t.BedrockAnthropicClientOptions & {
769
+ model?: string;
770
+ bedrockCacheModelPatterns?: readonly RegExp[];
771
+ })
772
+ | undefined;
773
+ if (bedrockOptions?.promptCache !== true) {
774
+ return false;
775
+ }
776
+ /* Allowlist-based check (see src/llm/bedrock/cacheSupport.ts). The
777
+ * `bedrockCacheModelPatterns` clientOption lets consumers add new
778
+ * model patterns without forking the library — useful when AWS adds
779
+ * a new family before the next library release. */
780
+ return isBedrockCacheSupported(
781
+ bedrockOptions.model,
782
+ bedrockOptions.bedrockCacheModelPatterns,
783
+ );
784
+ }
785
+
786
+ /**
787
+ * Build system runnable from cacheable blocks + the trailing
788
+ * `instructions` block + optional dynamic tail.
789
+ *
790
+ * ┌──────────────────────────────────────────┐
791
+ * │ system_cache_blocks[0].text │ ← consumer-defined block 0
792
+ * ├──── cache marker (TTL = blocks[0].ttl) ──┤
793
+ * │ system_cache_blocks[1].text │ ← consumer-defined block 1
794
+ * ├──── cache marker (TTL = blocks[1].ttl) ──┤
795
+ * │ instructions │ ← per-agent stable
796
+ * ├──── cache marker (TTL = instructionsCacheTtl) ┤
797
+ * │ additional_instructions │ ← dynamic (uncached)
798
+ * └──────────────────────────────────────────┘
799
+ *
800
+ * If `system_cache_blocks` is empty, behavior reduces to the 2-tier
801
+ * (instructions + dynamic) path used by simpler consumers.
802
+ *
803
+ * Provider-specific cache marker:
804
+ * - Anthropic: `cache_control: { type: 'ephemeral', ttl?: '1h'|'5m' }` on
805
+ * each cacheable text block. Up to 4 cache breakpoints per workspace.
806
+ * - Bedrock (Claude/Nova): a `{ cachePoint: { type: 'default', ttl?: '1h'|'5m' } }`
807
+ * block inserted after each cacheable section. Up to 4 cachePoints per
808
+ * request, of which the tools array can consume up to 2.
809
+ *
810
+ * Cache key composition: every byte from message start to a given cache
811
+ * marker forms that marker's cache key. Earlier blocks = wider cache key
812
+ * = more cross-tenant share. Place the most stable content first.
667
813
  */
668
- private buildSystemRunnable(
669
- instructionsString: string
670
- ):
814
+ private buildSystemRunnable({
815
+ systemCacheBlocks,
816
+ stableInstructions,
817
+ dynamicInstructions,
818
+ }: {
819
+ systemCacheBlocks: t.SystemCacheBlock[];
820
+ stableInstructions: string;
821
+ dynamicInstructions: string;
822
+ }):
671
823
  | Runnable<
672
824
  BaseMessage[],
673
825
  (BaseMessage | SystemMessage)[],
674
826
  RunnableConfig<Record<string, unknown>>
675
827
  >
676
828
  | undefined {
677
- if (!instructionsString) {
829
+ const hasAnyCacheBlocks = systemCacheBlocks.length > 0;
830
+ if (!hasAnyCacheBlocks && !stableInstructions && !dynamicInstructions) {
678
831
  // Remove previous tokens if we had a system message before
679
832
  this.instructionTokens -= this.systemMessageTokens;
680
833
  this.systemMessageTokens = 0;
681
834
  return undefined;
682
835
  }
683
836
 
684
- let finalInstructions: string | BaseMessageFields = instructionsString;
685
-
686
- // Handle Anthropic prompt caching (Direct API)
687
- if (this.provider === Providers.ANTHROPIC) {
688
- const anthropicOptions = this.clientOptions as
689
- | t.AnthropicClientOptions
690
- | undefined;
691
- if (anthropicOptions?.promptCache === true) {
692
- finalInstructions = {
693
- content: [
694
- {
695
- type: 'text',
696
- text: instructionsString,
697
- cache_control: { type: 'ephemeral' },
698
- },
699
- ],
700
- };
837
+ const useAnthropicCache = this.hasAnthropicPromptCache();
838
+ const useBedrockCache = this.hasBedrockPromptCache();
839
+ const instructionsTtl: t.AgentCacheTTL = this.instructionsCacheTtl ?? '5m';
840
+
841
+ let finalInstructions: string | BaseMessageFields;
842
+ if (useAnthropicCache) {
843
+ type AnthropicTextBlock = {
844
+ type: 'text';
845
+ text: string;
846
+ cache_control?: { type: 'ephemeral'; ttl?: t.AgentCacheTTL };
847
+ };
848
+ const content: AnthropicTextBlock[] = [];
849
+ // Emit each system_cache_blocks entry with its own cache_control.
850
+ for (const block of systemCacheBlocks) {
851
+ if (!block.text) continue;
852
+ content.push({
853
+ type: 'text',
854
+ text: block.text,
855
+ cache_control: { type: 'ephemeral', ttl: block.ttl ?? '5m' },
856
+ });
857
+ }
858
+ // Trailing stable instructions block (also cacheable).
859
+ if (stableInstructions) {
860
+ content.push({
861
+ type: 'text',
862
+ text: stableInstructions,
863
+ cache_control: { type: 'ephemeral', ttl: instructionsTtl },
864
+ });
865
+ }
866
+ if (dynamicInstructions) {
867
+ // Dynamic tail: NO cache_control so it doesn't shift the cache prefix.
868
+ content.push({ type: 'text', text: dynamicInstructions });
701
869
  }
870
+ finalInstructions = { content } as BaseMessageFields;
871
+ } else if (useBedrockCache && (hasAnyCacheBlocks || stableInstructions)) {
872
+ type BedrockBlock =
873
+ | { type: 'text'; text: string }
874
+ | { cachePoint: { type: 'default'; ttl?: t.AgentCacheTTL } };
875
+ const content: BedrockBlock[] = [];
876
+ // Emit each system_cache_blocks entry as text + cachePoint pair.
877
+ for (const block of systemCacheBlocks) {
878
+ if (!block.text) continue;
879
+ content.push({ type: 'text', text: block.text });
880
+ content.push({
881
+ cachePoint: { type: 'default', ttl: block.ttl ?? '5m' },
882
+ });
883
+ }
884
+ if (stableInstructions) {
885
+ content.push({ type: 'text', text: stableInstructions });
886
+ content.push({
887
+ cachePoint: { type: 'default', ttl: instructionsTtl },
888
+ });
889
+ }
890
+ if (dynamicInstructions) {
891
+ content.push({ type: 'text', text: dynamicInstructions });
892
+ }
893
+ finalInstructions = { content } as unknown as BaseMessageFields;
894
+ } else {
895
+ finalInstructions = [
896
+ ...systemCacheBlocks.map((b) => b.text),
897
+ stableInstructions,
898
+ dynamicInstructions,
899
+ ]
900
+ .filter((part) => part !== '')
901
+ .join('\n\n');
702
902
  }
703
903
 
704
904
  const systemMessage = new SystemMessage(finalInstructions);
@@ -774,6 +974,49 @@ export class AgentContext {
774
974
  }
775
975
  }
776
976
 
977
+ /** Active tool definitions for token accounting (excludes deferred-and-undiscovered entries
978
+ * and definitions whose `allowed_callers` exclude `'direct'`). Mirrors the gate
979
+ * `getEventDrivenToolsForBinding` applies so accounting and binding stay aligned. */
980
+ private getActiveToolDefinitions(): t.LCTool[] {
981
+ if (!this.toolDefinitions) {
982
+ return [];
983
+ }
984
+ return this.toolDefinitions.filter((def) => {
985
+ const allowedCallers = def.allowed_callers ?? ['direct'];
986
+ if (!allowedCallers.includes('direct')) {
987
+ return false;
988
+ }
989
+ return (
990
+ def.defer_loading !== true || this.discoveredToolNames.has(def.name)
991
+ );
992
+ });
993
+ }
994
+
995
+ /**
996
+ * Single source of truth for "which entries of `this.tools` should be
997
+ * treated as actually bound". Callers:
998
+ * - `getToolsForBinding` (non-event-driven branch)
999
+ * - `getEventDrivenToolsForBinding` (appends instance tools alongside
1000
+ * schema-only definitions)
1001
+ * - `calculateInstructionTokens` (counts schema bytes for accounting)
1002
+ *
1003
+ * In event-driven mode (`toolDefinitions` present) instance tools are
1004
+ * appended unfiltered; outside event-driven mode they pass through
1005
+ * `filterToolsForBinding`. Centralizing the decision here prevents the
1006
+ * accounting/binding paths from drifting apart, which was the root
1007
+ * cause of the original miscount (Fixes upstream #121).
1008
+ */
1009
+ private getEffectiveInstanceTools(): t.GraphTools | undefined {
1010
+ if (!this.tools) {
1011
+ return undefined;
1012
+ }
1013
+ const isEventDriven = (this.toolDefinitions?.length ?? 0) > 0;
1014
+ if (isEventDriven || !this.toolRegistry) {
1015
+ return this.tools;
1016
+ }
1017
+ return this.filterToolsForBinding(this.tools);
1018
+ }
1019
+
777
1020
  /**
778
1021
  * Calculate tool tokens and add to instruction tokens
779
1022
  * Note: System message tokens are calculated during systemRunnable creation
@@ -791,9 +1034,17 @@ export class AgentContext {
791
1034
  // Reset per-tool breakdown
792
1035
  this.toolsDetail = [];
793
1036
 
1037
+ /* Use `getEffectiveInstanceTools()` so accounting reflects exactly the
1038
+ * subset that `getToolsForBinding` would emit — preventing the
1039
+ * worst-case-ceiling miscount that triggered spurious `empty_messages`
1040
+ * preflight rejections at low `maxContextTokens`. Deferred and
1041
+ * non-`'direct'` `toolDefinitions` are excluded by
1042
+ * `getActiveToolDefinitions()` below. */
1043
+ const effectiveInstanceTools = this.getEffectiveInstanceTools();
1044
+
794
1045
  // Count tokens for bound tools (StructuredTool instances with .schema)
795
- if (this.tools && this.tools.length > 0) {
796
- for (const tool of this.tools) {
1046
+ if (effectiveInstanceTools && effectiveInstanceTools.length > 0) {
1047
+ for (const tool of effectiveInstanceTools) {
797
1048
  const genericTool = tool as Record<string, unknown>;
798
1049
  if (
799
1050
  genericTool.schema != null &&
@@ -822,25 +1073,27 @@ export class AgentContext {
822
1073
  // Count tokens for tool definitions (MCP / event-driven tools).
823
1074
  // These are sent to the provider API as tool schemas alongside bound tools.
824
1075
  // Both can be populated simultaneously (graph tools + MCP tools).
825
- if (this.toolDefinitions && this.toolDefinitions.length > 0) {
826
- for (const def of this.toolDefinitions) {
827
- if (countedToolNames.has(def.name)) {
828
- continue; // Already counted via this.tools
829
- }
830
- const schema = {
831
- name: def.name,
832
- description: def.description ?? '',
833
- parameters: def.parameters ?? {},
834
- };
835
- const defTokens = tokenCounter(
836
- new SystemMessage(JSON.stringify(schema))
837
- );
838
- this.toolsDetail.push({
839
- name: def.name || 'unknown',
840
- tokens: defTokens,
841
- });
842
- toolTokens += defTokens;
1076
+ // Use `getActiveToolDefinitions()` so programmatic-only definitions
1077
+ // (e.g. `allowed_callers: ['code_execution']`) and deferred-and-
1078
+ // -undiscovered ones don't inflate `toolSchemaTokens` while never
1079
+ // being bound to the model.
1080
+ for (const def of this.getActiveToolDefinitions()) {
1081
+ if (countedToolNames.has(def.name)) {
1082
+ continue; // Already counted via this.tools
843
1083
  }
1084
+ const schema = {
1085
+ name: def.name,
1086
+ description: def.description ?? '',
1087
+ parameters: def.parameters ?? {},
1088
+ };
1089
+ const defTokens = tokenCounter(
1090
+ new SystemMessage(JSON.stringify(schema))
1091
+ );
1092
+ this.toolsDetail.push({
1093
+ name: def.name || 'unknown',
1094
+ tokens: defTokens,
1095
+ });
1096
+ toolTokens += defTokens;
844
1097
  }
845
1098
 
846
1099
  // Store total tool tokens for breakdown reporting
@@ -1011,10 +1264,7 @@ export class AgentContext {
1011
1264
  }
1012
1265
 
1013
1266
  /** Traditional mode: filter actual tool instances */
1014
- const filtered =
1015
- !this.tools || !this.toolRegistry
1016
- ? this.tools
1017
- : this.filterToolsForBinding(this.tools);
1267
+ const filtered = this.getEffectiveInstanceTools();
1018
1268
 
1019
1269
  if (this.graphTools && this.graphTools.length > 0) {
1020
1270
  return [...(filtered ?? []), ...this.graphTools];
@@ -1029,21 +1279,11 @@ export class AgentContext {
1029
1279
  return this.graphTools ?? [];
1030
1280
  }
1031
1281
 
1032
- const defsToInclude = this.toolDefinitions.filter((def) => {
1033
- const allowedCallers = def.allowed_callers ?? ['direct'];
1034
- if (!allowedCallers.includes('direct')) {
1035
- return false;
1036
- }
1037
- if (
1038
- def.defer_loading === true &&
1039
- !this.discoveredToolNames.has(def.name)
1040
- ) {
1041
- return false;
1042
- }
1043
- return true;
1044
- });
1045
-
1046
- const schemaTools = createSchemaOnlyTools(defsToInclude) as t.GraphTools;
1282
+ /* Reuse `getActiveToolDefinitions()` so the binding gate matches the
1283
+ * accounting filter exactly (single source of truth). */
1284
+ const schemaTools = createSchemaOnlyTools(
1285
+ this.getActiveToolDefinitions()
1286
+ ) as t.GraphTools;
1047
1287
 
1048
1288
  const allTools = [...schemaTools];
1049
1289
 
@@ -1051,6 +1291,9 @@ export class AgentContext {
1051
1291
  allTools.push(...this.graphTools);
1052
1292
  }
1053
1293
 
1294
+ /* In event-driven mode, instance tools are appended UNFILTERED (matching
1295
+ * `getEffectiveInstanceTools()`'s event-driven branch). Deferred /
1296
+ * non-direct logic is represented in `toolDefinitions`, not here. */
1054
1297
  if (this.tools && this.tools.length > 0) {
1055
1298
  allTools.push(...this.tools);
1056
1299
  }