@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,217 @@
1
+ import { config } from 'dotenv';
2
+ config();
3
+
4
+ import { HumanMessage, BaseMessage } from '@langchain/core/messages';
5
+ import { Run } from '@/run';
6
+ import { Providers, GraphEvents } from '@/common';
7
+ import { ChatModelStreamHandler, createContentAggregator } from '@/stream';
8
+ import { ToolEndHandler, ModelEndHandler } from '@/events';
9
+ import type * as t from '@/types';
10
+
11
+ const conversationHistory: BaseMessage[] = [];
12
+
13
+ /**
14
+ * Example of simple sequential multi-agent system
15
+ *
16
+ * Graph structure:
17
+ * START -> agent_a -> agent_b -> agent_c -> END
18
+ *
19
+ * No conditions, no tools, just automatic sequential flow
20
+ */
21
+ async function testSequentialMultiAgent() {
22
+ console.log('Testing Sequential Multi-Agent System (A → B → C)...\n');
23
+
24
+ // Set up content aggregator
25
+ const { contentParts, aggregateContent, contentMetadataMap } =
26
+ createContentAggregator();
27
+
28
+ // Define three simple agents
29
+ const agents: t.AgentInputs[] = [
30
+ {
31
+ agentId: 'agent_a',
32
+ provider: Providers.ANTHROPIC,
33
+ clientOptions: {
34
+ modelName: 'claude-haiku-4-5',
35
+ apiKey: process.env.ANTHROPIC_API_KEY,
36
+ },
37
+ instructions: `You are Agent A, the first agent in a sequential workflow.
38
+ Your job is to:
39
+ 1. Receive the initial user request
40
+ 2. Process it and add your perspective (keep it brief, 2-3 sentences)
41
+ 3. Pass it along to Agent B
42
+
43
+ Start your response with "AGENT A:" and end with "Passing to Agent B..."`,
44
+ maxContextTokens: 8000,
45
+ },
46
+ {
47
+ agentId: 'agent_b',
48
+ provider: Providers.ANTHROPIC,
49
+ clientOptions: {
50
+ modelName: 'claude-haiku-4-5',
51
+ apiKey: process.env.ANTHROPIC_API_KEY,
52
+ },
53
+ instructions: `You are Agent B, the second agent in a sequential workflow.
54
+ Your job is to:
55
+ 1. Receive the context from Agent A
56
+ 2. Add your own analysis or perspective (keep it brief, 2-3 sentences)
57
+ 3. Pass it along to Agent C
58
+
59
+ Start your response with "AGENT B:" and end with "Passing to Agent C..."`,
60
+ maxContextTokens: 8000,
61
+ },
62
+ {
63
+ agentId: 'agent_c',
64
+ provider: Providers.ANTHROPIC,
65
+ clientOptions: {
66
+ modelName: 'claude-haiku-4-5',
67
+ apiKey: process.env.ANTHROPIC_API_KEY,
68
+ },
69
+ instructions: `You are Agent C, the final agent in a sequential workflow.
70
+ Your job is to:
71
+ 1. Receive the context from Agents A and B
72
+ 2. Provide a final summary or conclusion based on all previous inputs
73
+ 3. Complete the workflow
74
+
75
+ Start your response with "AGENT C:" and end with "Workflow complete."`,
76
+ maxContextTokens: 8000,
77
+ },
78
+ ];
79
+
80
+ // Define sequential edges using 'direct' type to avoid tool creation
81
+ // This creates automatic transitions without requiring agents to call tools
82
+ const edges: t.GraphEdge[] = [
83
+ {
84
+ from: 'agent_a',
85
+ to: 'agent_b',
86
+ edgeType: 'direct', // This creates direct edges without tools
87
+ description: 'Automatic transition from A to B',
88
+ },
89
+ {
90
+ from: 'agent_b',
91
+ to: 'agent_c',
92
+ edgeType: 'direct', // This creates direct edges without tools
93
+ description: 'Automatic transition from B to C',
94
+ },
95
+ ];
96
+
97
+ // Track agent progression
98
+ let currentAgent = '';
99
+
100
+ // Create custom handlers
101
+ const customHandlers = {
102
+ [GraphEvents.TOOL_END]: new ToolEndHandler(),
103
+ [GraphEvents.CHAT_MODEL_END]: new ModelEndHandler(),
104
+ [GraphEvents.CHAT_MODEL_STREAM]: new ChatModelStreamHandler(),
105
+ [GraphEvents.ON_RUN_STEP]: {
106
+ handle: (
107
+ event: GraphEvents.ON_RUN_STEP,
108
+ data: t.StreamEventData
109
+ ): void => {
110
+ const runStepData = data as any;
111
+ if (runStepData?.name) {
112
+ currentAgent = runStepData.name;
113
+ console.log(`\n→ ${currentAgent} is processing...`);
114
+ }
115
+ aggregateContent({ event, data: data as t.RunStep });
116
+ },
117
+ },
118
+ [GraphEvents.ON_RUN_STEP_COMPLETED]: {
119
+ handle: (
120
+ event: GraphEvents.ON_RUN_STEP_COMPLETED,
121
+ data: t.StreamEventData
122
+ ): void => {
123
+ const runStepData = data as any;
124
+ if (runStepData?.name) {
125
+ console.log(`✓ ${runStepData.name} completed`);
126
+ }
127
+ aggregateContent({
128
+ event,
129
+ data: data as unknown as { result: t.ToolEndEvent },
130
+ });
131
+ },
132
+ },
133
+ [GraphEvents.ON_RUN_STEP_DELTA]: {
134
+ handle: (
135
+ event: GraphEvents.ON_RUN_STEP_DELTA,
136
+ data: t.StreamEventData
137
+ ): void => {
138
+ aggregateContent({ event, data: data as t.RunStepDeltaEvent });
139
+ },
140
+ },
141
+ [GraphEvents.ON_MESSAGE_DELTA]: {
142
+ handle: (
143
+ event: GraphEvents.ON_MESSAGE_DELTA,
144
+ data: t.StreamEventData
145
+ ): void => {
146
+ aggregateContent({ event, data: data as t.MessageDeltaEvent });
147
+ },
148
+ },
149
+ };
150
+
151
+ // Create multi-agent run configuration
152
+ const runConfig: t.RunConfig = {
153
+ runId: `sequential-multi-agent-${Date.now()}`,
154
+ graphConfig: {
155
+ type: 'multi-agent',
156
+ agents,
157
+ edges,
158
+ },
159
+ customHandlers,
160
+ returnContent: true,
161
+ };
162
+
163
+ try {
164
+ // Create and execute the run
165
+ const run = await Run.create(runConfig);
166
+
167
+ // Test with a simple question
168
+ const userMessage =
169
+ 'What are the key considerations for building a recommendation system?';
170
+ conversationHistory.push(new HumanMessage(userMessage));
171
+
172
+ console.log(`User: "${userMessage}"\n`);
173
+ console.log('Starting sequential workflow...\n');
174
+
175
+ const config = {
176
+ configurable: {
177
+ thread_id: 'sequential-conversation-1',
178
+ },
179
+ streamMode: 'values',
180
+ version: 'v2' as const,
181
+ };
182
+
183
+ // Process with streaming
184
+ const inputs = {
185
+ messages: conversationHistory,
186
+ };
187
+
188
+ const finalContentParts = await run.processStream(inputs, config);
189
+ const finalMessages = run.getRunMessages();
190
+
191
+ if (finalMessages) {
192
+ conversationHistory.push(...finalMessages);
193
+ }
194
+
195
+ console.log('\n\n=== Final Output ===');
196
+ console.log('Sequential flow completed successfully!');
197
+ console.log(`Total content parts: ${contentParts.length}`);
198
+ console.log('\n=== Content Parts (clean, no metadata) ===');
199
+ console.dir(contentParts, { depth: null });
200
+ console.log('\n=== Content Metadata Map (separate from content) ===');
201
+ console.dir(Object.fromEntries(contentMetadataMap), { depth: null });
202
+
203
+ // Display the sequential responses
204
+ const aiMessages = conversationHistory.filter(
205
+ (msg) => msg._getType() === 'ai'
206
+ );
207
+ aiMessages.forEach((msg, index) => {
208
+ console.log(`\n--- Response ${index + 1} ---`);
209
+ console.log(msg.content);
210
+ });
211
+ } catch (error) {
212
+ console.error('Error in sequential multi-agent test:', error);
213
+ }
214
+ }
215
+
216
+ // Run the test
217
+ testSequentialMultiAgent();
@@ -0,0 +1,365 @@
1
+ import { config } from 'dotenv';
2
+ config();
3
+
4
+ import { HumanMessage, BaseMessage } from '@langchain/core/messages';
5
+ import type * as t from '@/types';
6
+ import { ChatModelStreamHandler, createContentAggregator } from '@/stream';
7
+ import { ToolEndHandler, ModelEndHandler } from '@/events';
8
+ import { Providers, GraphEvents } from '@/common';
9
+ import { sleep } from '@/utils/run';
10
+ import { Run } from '@/run';
11
+
12
+ const conversationHistory: BaseMessage[] = [];
13
+
14
+ /**
15
+ * Example of supervisor-based multi-agent system
16
+ *
17
+ * The supervisor has handoff tools for 5 different specialists.
18
+ * To demonstrate the concept while respecting LangGraph constraints,
19
+ * we show two approaches:
20
+ *
21
+ * 1. All 5 specialists exist but share the same adaptive configuration
22
+ * 2. Only 2 agents total by using a single adaptive specialist (requires workaround)
23
+ */
24
+ async function testSupervisorMultiAgent() {
25
+ console.log('Testing Supervisor-Based Multi-Agent System...\n');
26
+
27
+ // NOTE: To truly have only 2 agents with 5 handoff tools, you would need:
28
+ // 1. Custom tool implementation (see multi-agent-supervisor-mock.ts)
29
+ // 2. Or modify MultiAgentGraph to support "virtual" agents
30
+ // 3. Or use a single conditional edge with role parameter
31
+ //
32
+ // This example shows the concept using 6 agents that share configuration
33
+
34
+ // Set up content aggregator
35
+ const { contentParts, aggregateContent } = createContentAggregator();
36
+
37
+ // Define configurations for all possible specialists
38
+ const specialistConfigs = {
39
+ data_analyst: {
40
+ provider: Providers.OPENAI,
41
+ clientOptions: {
42
+ modelName: 'gpt-4.1',
43
+ apiKey: process.env.OPENAI_API_KEY,
44
+ },
45
+ instructions: `You are a Data Analyst specialist. Your expertise includes:
46
+ - Statistical analysis and data visualization
47
+ - SQL queries and database optimization
48
+ - Python/R for data science
49
+ - Machine learning model evaluation
50
+ - A/B testing and experiment design
51
+
52
+ Follow the supervisor's specific instructions carefully.`,
53
+ maxContextTokens: 8000,
54
+ },
55
+ security_expert: {
56
+ provider: Providers.OPENAI,
57
+ clientOptions: {
58
+ modelName: 'gpt-4.1',
59
+ apiKey: process.env.OPENAI_API_KEY,
60
+ },
61
+ instructions: `You are a Security Expert. Your expertise includes:
62
+ - Cybersecurity best practices
63
+ - Vulnerability assessment and penetration testing
64
+ - Security architecture and threat modeling
65
+ - Compliance (GDPR, HIPAA, SOC2, etc.)
66
+ - Incident response and forensics
67
+
68
+ Follow the supervisor's specific instructions carefully.`,
69
+ maxContextTokens: 8000,
70
+ },
71
+ product_designer: {
72
+ provider: Providers.OPENAI,
73
+ clientOptions: {
74
+ modelName: 'gpt-4.1',
75
+ apiKey: process.env.OPENAI_API_KEY,
76
+ },
77
+ instructions: `You are a Product Designer. Your expertise includes:
78
+ - User experience (UX) design principles
79
+ - User interface (UI) design and prototyping
80
+ - Design systems and component libraries
81
+ - User research and usability testing
82
+ - Accessibility and inclusive design
83
+
84
+ Follow the supervisor's specific instructions carefully.`,
85
+ maxContextTokens: 8000,
86
+ },
87
+ devops_engineer: {
88
+ provider: Providers.OPENAI,
89
+ clientOptions: {
90
+ modelName: 'gpt-4.1',
91
+ apiKey: process.env.OPENAI_API_KEY,
92
+ },
93
+ instructions: `You are a DevOps Engineer. Your expertise includes:
94
+ - CI/CD pipeline design and optimization
95
+ - Infrastructure as Code (Terraform, CloudFormation)
96
+ - Container orchestration (Kubernetes, Docker)
97
+ - Cloud platforms (AWS, GCP, Azure)
98
+ - Monitoring, logging, and observability
99
+
100
+ Follow the supervisor's specific instructions carefully.`,
101
+ maxContextTokens: 8000,
102
+ },
103
+ legal_advisor: {
104
+ provider: Providers.OPENAI,
105
+ clientOptions: {
106
+ modelName: 'gpt-4.1',
107
+ apiKey: process.env.OPENAI_API_KEY,
108
+ },
109
+ instructions: `You are a Legal Advisor specializing in technology. Your expertise includes:
110
+ - Software licensing and open source compliance
111
+ - Data privacy and protection laws
112
+ - Intellectual property and patents
113
+ - Contract review and negotiation
114
+ - Regulatory compliance for tech companies
115
+
116
+ Follow the supervisor's specific instructions carefully.`,
117
+ maxContextTokens: 8000,
118
+ },
119
+ };
120
+
121
+ // Track which specialist role was selected
122
+ let selectedRole = '';
123
+ let roleInstructions = '';
124
+
125
+ // Create custom handlers
126
+ const customHandlers = {
127
+ [GraphEvents.TOOL_END]: new ToolEndHandler(),
128
+ [GraphEvents.CHAT_MODEL_END]: new ModelEndHandler(),
129
+ [GraphEvents.CHAT_MODEL_STREAM]: new ChatModelStreamHandler(),
130
+ [GraphEvents.ON_RUN_STEP]: {
131
+ handle: (
132
+ event: GraphEvents.ON_RUN_STEP,
133
+ data: t.StreamEventData
134
+ ): void => {
135
+ const runStepData = data as any;
136
+ if (runStepData?.name) {
137
+ console.log(`\n[${runStepData.name}] Processing...`);
138
+ }
139
+ aggregateContent({ event, data: data as t.RunStep });
140
+ },
141
+ },
142
+ [GraphEvents.ON_RUN_STEP_COMPLETED]: {
143
+ handle: (
144
+ event: GraphEvents.ON_RUN_STEP_COMPLETED,
145
+ data: t.StreamEventData
146
+ ): void => {
147
+ aggregateContent({
148
+ event,
149
+ data: data as unknown as { result: t.ToolEndEvent },
150
+ });
151
+ },
152
+ },
153
+ [GraphEvents.ON_MESSAGE_DELTA]: {
154
+ handle: (
155
+ event: GraphEvents.ON_MESSAGE_DELTA,
156
+ data: t.StreamEventData
157
+ ): void => {
158
+ console.dir(data, { depth: null });
159
+ aggregateContent({ event, data: data as t.MessageDeltaEvent });
160
+ },
161
+ },
162
+ [GraphEvents.TOOL_START]: {
163
+ handle: (
164
+ _event: string,
165
+ data: t.StreamEventData,
166
+ metadata?: Record<string, unknown>
167
+ ): void => {
168
+ const toolData = data as any;
169
+ if (toolData?.name?.includes('transfer_to_')) {
170
+ const specialist = toolData.name.replace('transfer_to_', '');
171
+ console.log(`\n🔀 Transferring to ${specialist}...`);
172
+ selectedRole = specialist;
173
+ }
174
+ },
175
+ },
176
+ };
177
+
178
+ // Function to create the graph with supervisor having multiple handoff options
179
+ function createSupervisorGraph(): t.RunConfig {
180
+ console.log(`\nCreating graph with supervisor and 5 specialist agents.`);
181
+ console.log('All specialists share the same adaptive configuration.\n');
182
+
183
+ // Define the adaptive specialist configuration that will be reused
184
+ const specialistConfig = {
185
+ provider: Providers.OPENAI,
186
+ clientOptions: {
187
+ modelName: 'gpt-4.1',
188
+ apiKey: process.env.OPENAI_API_KEY,
189
+ },
190
+ instructions: `You are an Adaptive Specialist. Your agent ID indicates your role:
191
+
192
+ - data_analyst: Focus on statistical analysis, metrics, ML evaluation, A/B testing
193
+ - security_expert: Focus on cybersecurity, vulnerability assessment, compliance
194
+ - product_designer: Focus on UX/UI design, user research, accessibility
195
+ - devops_engineer: Focus on CI/CD, infrastructure, cloud platforms, monitoring
196
+ - legal_advisor: Focus on licensing, privacy laws, contracts, regulatory compliance
197
+
198
+ The supervisor will provide specific instructions. Follow them while maintaining your expert perspective.`,
199
+ maxContextTokens: 8000,
200
+ };
201
+
202
+ // Create the graph with supervisor and all 5 specialists
203
+ // All specialists share the same adaptive configuration
204
+ const agents: t.AgentInputs[] = [
205
+ {
206
+ agentId: 'supervisor',
207
+ provider: Providers.OPENAI,
208
+ clientOptions: {
209
+ modelName: 'gpt-4.1-mini',
210
+ apiKey: process.env.OPENAI_API_KEY,
211
+ },
212
+ instructions: `You are a Task Supervisor with access to 5 specialist agents:
213
+ 1. transfer_to_data_analyst - For statistical analysis and metrics
214
+ 2. transfer_to_security_expert - For cybersecurity and vulnerability assessment
215
+ 3. transfer_to_product_designer - For UX/UI design
216
+ 4. transfer_to_devops_engineer - For infrastructure and deployment
217
+ 5. transfer_to_legal_advisor - For compliance and licensing
218
+
219
+ Your role is to:
220
+ 1. Analyze the incoming request
221
+ 2. Decide which specialist is best suited
222
+ 3. Use the appropriate transfer tool (e.g., transfer_to_data_analyst)
223
+ 4. Provide specific instructions to guide their work
224
+
225
+ Be specific about what you need from the specialist.`,
226
+ maxContextTokens: 8000,
227
+ },
228
+ // Include all 5 specialists with the same adaptive configuration
229
+ {
230
+ agentId: 'data_analyst',
231
+ ...specialistConfig,
232
+ },
233
+ {
234
+ agentId: 'security_expert',
235
+ ...specialistConfig,
236
+ },
237
+ {
238
+ agentId: 'product_designer',
239
+ ...specialistConfig,
240
+ },
241
+ {
242
+ agentId: 'devops_engineer',
243
+ ...specialistConfig,
244
+ },
245
+ {
246
+ agentId: 'legal_advisor',
247
+ ...specialistConfig,
248
+ },
249
+ ];
250
+
251
+ // Create edges from supervisor to all 5 specialists
252
+ const edges: t.GraphEdge[] = [
253
+ {
254
+ from: 'supervisor',
255
+ to: 'data_analyst',
256
+ description:
257
+ 'Transfer to data analyst for statistical analysis and metrics',
258
+ edgeType: 'handoff',
259
+ },
260
+ {
261
+ from: 'supervisor',
262
+ to: 'security_expert',
263
+ description: 'Transfer to security expert for cybersecurity assessment',
264
+ edgeType: 'handoff',
265
+ },
266
+ {
267
+ from: 'supervisor',
268
+ to: 'product_designer',
269
+ description: 'Transfer to product designer for UX/UI design',
270
+ edgeType: 'handoff',
271
+ },
272
+ {
273
+ from: 'supervisor',
274
+ to: 'devops_engineer',
275
+ description:
276
+ 'Transfer to DevOps engineer for infrastructure and deployment',
277
+ edgeType: 'handoff',
278
+ },
279
+ {
280
+ from: 'supervisor',
281
+ to: 'legal_advisor',
282
+ description: 'Transfer to legal advisor for compliance and licensing',
283
+ edgeType: 'handoff',
284
+ },
285
+ ];
286
+
287
+ return {
288
+ runId: `supervisor-multi-agent-${Date.now()}`,
289
+ graphConfig: {
290
+ type: 'multi-agent',
291
+ agents,
292
+ edges,
293
+ },
294
+ customHandlers,
295
+ returnContent: true,
296
+ };
297
+ }
298
+
299
+ try {
300
+ // Test with different queries
301
+ const testQueries = [
302
+ 'How can we analyze user engagement metrics to improve our product?',
303
+ // 'What security measures should we implement for our new API?',
304
+ // 'Can you help design a better onboarding flow for our mobile app?',
305
+ // 'We need to set up a CI/CD pipeline for our microservices.',
306
+ // 'What are the legal implications of using GPL-licensed code in our product?',
307
+ ];
308
+
309
+ const config = {
310
+ configurable: {
311
+ thread_id: 'supervisor-conversation-1',
312
+ },
313
+ streamMode: 'values',
314
+ version: 'v2' as const,
315
+ };
316
+
317
+ for (const query of testQueries) {
318
+ console.log(`\n${'='.repeat(60)}`);
319
+ console.log(`USER QUERY: "${query}"`);
320
+ console.log('='.repeat(60));
321
+
322
+ // Reset conversation
323
+ conversationHistory.length = 0;
324
+ conversationHistory.push(new HumanMessage(query));
325
+
326
+ // Create graph with supervisor having 5 handoff tools to 1 adaptive specialist
327
+ const runConfig = createSupervisorGraph();
328
+ const run = await Run.create(runConfig);
329
+
330
+ console.log('Processing request...');
331
+
332
+ // Process with streaming
333
+ const inputs = {
334
+ messages: conversationHistory,
335
+ };
336
+
337
+ const finalContentParts = await run.processStream(inputs, config);
338
+ const finalMessages = run.getRunMessages();
339
+
340
+ if (finalMessages) {
341
+ conversationHistory.push(...finalMessages);
342
+ }
343
+
344
+ // Show summary
345
+ console.log(`\n${'─'.repeat(60)}`);
346
+ console.log(`Agents in graph: 6 total (supervisor + 5 specialists)`);
347
+ console.log(`All specialists share the same adaptive configuration`);
348
+ console.log(
349
+ `Supervisor tools: transfer_to_data_analyst, transfer_to_security_expert,`
350
+ );
351
+ console.log(
352
+ ` transfer_to_product_designer, transfer_to_devops_engineer,`
353
+ );
354
+ console.log(` transfer_to_legal_advisor`);
355
+ console.log('─'.repeat(60));
356
+ console.dir(contentParts, { depth: null });
357
+ }
358
+ await sleep(3000);
359
+ } catch (error) {
360
+ console.error('Error in supervisor multi-agent test:', error);
361
+ }
362
+ }
363
+
364
+ // Run the test
365
+ testSupervisorMultiAgent();