@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,198 @@
1
+ import { config } from 'dotenv';
2
+ config();
3
+
4
+ import { HumanMessage, BaseMessage } from '@langchain/core/messages';
5
+ import { v4 as uuidv4 } from 'uuid';
6
+ import type * as t from '@/types';
7
+ import { ChatModelStreamHandler, createContentAggregator } from '@/stream';
8
+ import { ToolEndHandler, ModelEndHandler } from '@/events';
9
+ import { Providers, GraphEvents } from '@/common';
10
+ import { sleep } from '@/utils/run';
11
+ import { Run } from '@/run';
12
+
13
+ const conversationHistory: BaseMessage[] = [];
14
+
15
+ /**
16
+ * Single agent test with extensive metadata logging
17
+ * Compare with multi-agent-parallel-start.ts to see metadata differences
18
+ */
19
+ async function testSingleAgent() {
20
+ console.log('Testing Single Agent with Metadata Logging...\n');
21
+
22
+ // Set up content aggregator
23
+ const { contentParts, aggregateContent, contentMetadataMap } =
24
+ createContentAggregator();
25
+
26
+ const startTime = Date.now();
27
+
28
+ // Create custom handlers with extensive metadata logging
29
+ const customHandlers = {
30
+ [GraphEvents.TOOL_END]: new ToolEndHandler(),
31
+ [GraphEvents.CHAT_MODEL_END]: {
32
+ handle: (
33
+ _event: string,
34
+ _data: t.StreamEventData,
35
+ metadata?: Record<string, unknown>
36
+ ): void => {
37
+ console.log('\n====== CHAT_MODEL_END METADATA ======');
38
+ console.dir(metadata, { depth: null });
39
+ const elapsed = Date.now() - startTime;
40
+ console.log(`ā±ļø COMPLETED at ${elapsed}ms`);
41
+ },
42
+ },
43
+ [GraphEvents.CHAT_MODEL_START]: {
44
+ handle: (
45
+ _event: string,
46
+ _data: t.StreamEventData,
47
+ metadata?: Record<string, unknown>
48
+ ): void => {
49
+ console.log('\n====== CHAT_MODEL_START METADATA ======');
50
+ console.dir(metadata, { depth: null });
51
+ const elapsed = Date.now() - startTime;
52
+ console.log(`ā±ļø STARTED at ${elapsed}ms`);
53
+ },
54
+ },
55
+ [GraphEvents.CHAT_MODEL_STREAM]: new ChatModelStreamHandler(),
56
+ [GraphEvents.ON_RUN_STEP_COMPLETED]: {
57
+ handle: (
58
+ event: GraphEvents.ON_RUN_STEP_COMPLETED,
59
+ data: t.StreamEventData,
60
+ metadata?: Record<string, unknown>
61
+ ): void => {
62
+ console.log('\n====== ON_RUN_STEP_COMPLETED ======');
63
+ console.log('DATA:');
64
+ console.dir(data, { depth: null });
65
+ console.log('METADATA:');
66
+ console.dir(metadata, { depth: null });
67
+ aggregateContent({
68
+ event,
69
+ data: data as unknown as { result: t.ToolEndEvent },
70
+ });
71
+ },
72
+ },
73
+ [GraphEvents.ON_RUN_STEP]: {
74
+ handle: (
75
+ event: GraphEvents.ON_RUN_STEP,
76
+ data: t.StreamEventData,
77
+ metadata?: Record<string, unknown>
78
+ ): void => {
79
+ console.log('\n====== ON_RUN_STEP ======');
80
+ console.log('DATA:');
81
+ console.dir(data, { depth: null });
82
+ console.log('METADATA:');
83
+ console.dir(metadata, { depth: null });
84
+ aggregateContent({ event, data: data as t.RunStep });
85
+ },
86
+ },
87
+ [GraphEvents.ON_RUN_STEP_DELTA]: {
88
+ handle: (
89
+ event: GraphEvents.ON_RUN_STEP_DELTA,
90
+ data: t.StreamEventData,
91
+ metadata?: Record<string, unknown>
92
+ ): void => {
93
+ console.log('\n====== ON_RUN_STEP_DELTA ======');
94
+ console.log('DATA:');
95
+ console.dir(data, { depth: null });
96
+ console.log('METADATA:');
97
+ console.dir(metadata, { depth: null });
98
+ aggregateContent({ event, data: data as t.RunStepDeltaEvent });
99
+ },
100
+ },
101
+ [GraphEvents.ON_MESSAGE_DELTA]: {
102
+ handle: (
103
+ event: GraphEvents.ON_MESSAGE_DELTA,
104
+ data: t.StreamEventData,
105
+ metadata?: Record<string, unknown>
106
+ ): void => {
107
+ console.log('\n====== ON_MESSAGE_DELTA ======');
108
+ console.log('DATA:');
109
+ console.dir(data, { depth: null });
110
+ console.log('METADATA:');
111
+ console.dir(metadata, { depth: null });
112
+ aggregateContent({ event, data: data as t.MessageDeltaEvent });
113
+ },
114
+ },
115
+ };
116
+
117
+ // Create single-agent run configuration (standard graph, not multi-agent)
118
+ const runConfig: t.RunConfig = {
119
+ runId: `single-agent-${Date.now()}`,
120
+ graphConfig: {
121
+ type: 'standard',
122
+ llmConfig: {
123
+ provider: Providers.ANTHROPIC,
124
+ modelName: 'claude-haiku-4-5',
125
+ apiKey: process.env.ANTHROPIC_API_KEY,
126
+ },
127
+ instructions: `You are a helpful AI assistant. Keep your response concise (50-100 words).`,
128
+ },
129
+ customHandlers,
130
+ returnContent: true,
131
+ };
132
+
133
+ try {
134
+ // Create and execute the run
135
+ const run = await Run.create(runConfig);
136
+
137
+ // Debug: Log the graph structure
138
+ console.log('=== DEBUG: Graph Structure ===');
139
+ const graph = (run as any).Graph;
140
+ console.log('Graph exists:', !!graph);
141
+ if (graph) {
142
+ console.log('Graph type:', graph.constructor.name);
143
+ console.log('AgentContexts exists:', !!graph.agentContexts);
144
+ if (graph.agentContexts) {
145
+ console.log('AgentContexts size:', graph.agentContexts.size);
146
+ for (const [agentId, context] of graph.agentContexts) {
147
+ console.log(`\nAgent: ${agentId}`);
148
+ console.log(
149
+ `Tools: ${context.tools?.map((t: any) => t.name || 'unnamed').join(', ') || 'none'}`
150
+ );
151
+ }
152
+ }
153
+ }
154
+ console.log('=== END DEBUG ===\n');
155
+
156
+ const userMessage = `What are the best approaches to learning a new programming language?`;
157
+ conversationHistory.push(new HumanMessage(userMessage));
158
+
159
+ console.log('Invoking single-agent graph...\n');
160
+
161
+ const config = {
162
+ configurable: {
163
+ thread_id: 'single-agent-conversation-1',
164
+ },
165
+ streamMode: 'values',
166
+ version: 'v2' as const,
167
+ };
168
+
169
+ // Process with streaming
170
+ const inputs = {
171
+ messages: conversationHistory,
172
+ };
173
+
174
+ const finalContentParts = await run.processStream(inputs, config);
175
+ const finalMessages = run.getRunMessages();
176
+
177
+ if (finalMessages) {
178
+ conversationHistory.push(...finalMessages);
179
+ }
180
+
181
+ console.log('\n\n========== SUMMARY ==========');
182
+ console.log('Final content parts:', contentParts.length, 'parts');
183
+ console.log('\n=== Content Parts (clean, no metadata) ===');
184
+ console.dir(contentParts, { depth: null });
185
+ console.log(
186
+ '\n=== Content Metadata Map (should be empty for single-agent) ==='
187
+ );
188
+ console.dir(Object.fromEntries(contentMetadataMap), { depth: null });
189
+ console.log('====================================\n');
190
+
191
+ await sleep(3000);
192
+ } catch (error) {
193
+ console.error('Error in single-agent test:', error);
194
+ }
195
+ }
196
+
197
+ // Run the test
198
+ testSingleAgent();
@@ -0,0 +1,140 @@
1
+ /* eslint-disable no-console */
2
+ // src/scripts/cli.ts
3
+ import { config } from 'dotenv';
4
+ config();
5
+ import { HumanMessage, BaseMessage } from '@langchain/core/messages';
6
+ import type * as t from '@/types';
7
+ import { ChatModelStreamHandler, createContentAggregator } from '@/stream';
8
+ import { ToolEndHandler } from '@/events';
9
+
10
+ import { getArgs } from '@/scripts/args';
11
+ import { Run } from '@/run';
12
+ import { GraphEvents, Callback } from '@/common';
13
+ import { getLLMConfig } from '@/utils/llmConfig';
14
+
15
+ const conversationHistory: BaseMessage[] = [];
16
+ async function testStandardStreaming(): Promise<void> {
17
+ const { userName, location, provider, currentDate } = await getArgs();
18
+ const { contentParts, aggregateContent } = createContentAggregator();
19
+ const customHandlers = {
20
+ [GraphEvents.TOOL_END]: new ToolEndHandler(),
21
+ // [GraphEvents.CHAT_MODEL_END]: new ModelEndHandler(),
22
+ [GraphEvents.CHAT_MODEL_STREAM]: new ChatModelStreamHandler(),
23
+ [GraphEvents.ON_RUN_STEP_COMPLETED]: {
24
+ handle: (
25
+ event: GraphEvents.ON_RUN_STEP_COMPLETED,
26
+ data: t.StreamEventData
27
+ ): void => {
28
+ console.log('====== ON_RUN_STEP_COMPLETED ======');
29
+ // console.dir(data, { depth: null });
30
+ aggregateContent({
31
+ event,
32
+ data: data as unknown as { result: t.ToolEndEvent },
33
+ });
34
+ },
35
+ },
36
+ [GraphEvents.ON_RUN_STEP]: {
37
+ handle: (
38
+ event: GraphEvents.ON_RUN_STEP,
39
+ data: t.StreamEventData
40
+ ): void => {
41
+ console.log('====== ON_RUN_STEP ======');
42
+ console.dir(data, { depth: null });
43
+ aggregateContent({ event, data: data as t.RunStep });
44
+ },
45
+ },
46
+ [GraphEvents.ON_RUN_STEP_DELTA]: {
47
+ handle: (
48
+ event: GraphEvents.ON_RUN_STEP_DELTA,
49
+ data: t.StreamEventData
50
+ ): void => {
51
+ console.log('====== ON_RUN_STEP_DELTA ======');
52
+ console.dir(data, { depth: null });
53
+ aggregateContent({ event, data: data as t.RunStepDeltaEvent });
54
+ },
55
+ },
56
+ [GraphEvents.ON_MESSAGE_DELTA]: {
57
+ handle: (
58
+ event: GraphEvents.ON_MESSAGE_DELTA,
59
+ data: t.StreamEventData
60
+ ): void => {
61
+ console.log('====== ON_MESSAGE_DELTA ======');
62
+ console.dir(data, { depth: null });
63
+ aggregateContent({ event, data: data as t.MessageDeltaEvent });
64
+ },
65
+ },
66
+ [GraphEvents.TOOL_START]: {
67
+ handle: (
68
+ _event: string,
69
+ data: t.StreamEventData,
70
+ metadata?: Record<string, unknown>
71
+ ): void => {
72
+ console.log('====== TOOL_START ======');
73
+ // console.dir(data, { depth: null });
74
+ },
75
+ },
76
+ };
77
+
78
+ const llmConfig = getLLMConfig(provider);
79
+
80
+ const run = await Run.create<t.IState>({
81
+ runId: 'test-run-id',
82
+ graphConfig: {
83
+ type: 'standard',
84
+ llmConfig,
85
+ tools: [],
86
+ instructions:
87
+ 'You are a friendly AI assistant. Always address the user by their name.',
88
+ additional_instructions: `The user's name is ${userName} and they are located in ${location}.`,
89
+ streamBuffer: 3000,
90
+ },
91
+ returnContent: true,
92
+ customHandlers,
93
+ });
94
+
95
+ const config = {
96
+ configurable: {
97
+ provider,
98
+ thread_id: 'conversation-num-1',
99
+ },
100
+ streamMode: 'values',
101
+ version: 'v2' as const,
102
+ };
103
+
104
+ console.log('Test 1: Weather query (content parts test)');
105
+
106
+ const userMessage = `
107
+ Make a search for the weather in ${location} today, which is ${currentDate}.
108
+ Before making the search, please let me know what you're about to do, then immediately start searching without hesitation.
109
+ Make sure to always refer to me by name, which is ${userName}.
110
+ After giving me a thorough summary, tell me a joke about the weather forecast we went over.
111
+ `;
112
+
113
+ conversationHistory.push(new HumanMessage(userMessage));
114
+
115
+ const inputs = {
116
+ messages: conversationHistory,
117
+ };
118
+ const finalContentParts = await run.processStream(inputs, config);
119
+ const finalMessages = run.getRunMessages();
120
+ if (finalMessages) {
121
+ conversationHistory.push(...finalMessages);
122
+ console.dir(conversationHistory, { depth: null });
123
+ }
124
+ // console.dir(finalContentParts, { depth: null });
125
+ console.log('\n\n====================\n\n');
126
+ // console.dir(contentParts, { depth: null });
127
+ }
128
+
129
+ process.on('unhandledRejection', (reason, promise) => {
130
+ console.error('Unhandled Rejection at:', promise, 'reason:', reason);
131
+ console.log('Conversation history:');
132
+ process.exit(1);
133
+ });
134
+
135
+ testStandardStreaming().catch((err) => {
136
+ console.error(err);
137
+ console.log('Conversation history:');
138
+ console.dir(conversationHistory, { depth: null });
139
+ process.exit(1);
140
+ });
@@ -0,0 +1,145 @@
1
+ #!/usr/bin/env bun
2
+
3
+ import { config } from 'dotenv';
4
+ config();
5
+
6
+ import { HumanMessage } from '@langchain/core/messages';
7
+ import { Run } from '@/run';
8
+ import { Providers } from '@/common';
9
+ import type * as t from '@/types';
10
+
11
+ /**
12
+ * Test the custom promptKey feature for handoff edges
13
+ * This demonstrates how to use custom parameter names instead of "instructions"
14
+ */
15
+ async function testCustomPromptKey() {
16
+ console.log('Testing Custom Prompt Key Feature...\n');
17
+
18
+ const runConfig: t.RunConfig = {
19
+ runId: `test-custom-prompt-key-${Date.now()}`,
20
+ graphConfig: {
21
+ type: 'multi-agent',
22
+ agents: [
23
+ {
24
+ agentId: 'supervisor',
25
+ provider: Providers.ANTHROPIC,
26
+ clientOptions: {
27
+ modelName: 'claude-haiku-4-5',
28
+ apiKey: process.env.ANTHROPIC_API_KEY,
29
+ },
30
+ instructions: `You are a Task Supervisor managing different agents:
31
+
32
+ 1. transfer_to_researcher - For research tasks (uses "query" parameter)
33
+ 2. transfer_to_designer - For design tasks (uses "requirements" parameter)
34
+ 3. transfer_to_coder - For coding tasks (uses "specification" parameter)
35
+
36
+ Each agent expects different parameter names in their handoff tools.
37
+ Pay attention to the parameter names when calling each tool.`,
38
+ maxContextTokens: 8000,
39
+ },
40
+ {
41
+ agentId: 'researcher',
42
+ provider: Providers.ANTHROPIC,
43
+ clientOptions: {
44
+ modelName: 'claude-haiku-4-5',
45
+ apiKey: process.env.ANTHROPIC_API_KEY,
46
+ },
47
+ instructions: `You are a Research Agent. You receive research queries to investigate.
48
+ Look for the "Query:" field in the transfer message.`,
49
+ maxContextTokens: 8000,
50
+ },
51
+ {
52
+ agentId: 'designer',
53
+ provider: Providers.ANTHROPIC,
54
+ clientOptions: {
55
+ modelName: 'claude-haiku-4-5',
56
+ apiKey: process.env.ANTHROPIC_API_KEY,
57
+ },
58
+ instructions: `You are a Design Agent. You receive design requirements to implement.
59
+ Look for the "Requirements:" field in the transfer message.`,
60
+ maxContextTokens: 8000,
61
+ },
62
+ {
63
+ agentId: 'coder',
64
+ provider: Providers.ANTHROPIC,
65
+ clientOptions: {
66
+ modelName: 'claude-haiku-4-5',
67
+ apiKey: process.env.ANTHROPIC_API_KEY,
68
+ },
69
+ instructions: `You are a Coding Agent. You receive technical specifications to implement.
70
+ Look for the "Specification:" field in the transfer message.`,
71
+ maxContextTokens: 8000,
72
+ },
73
+ ],
74
+ edges: [
75
+ {
76
+ from: 'supervisor',
77
+ to: 'researcher',
78
+ edgeType: 'handoff',
79
+ // Custom parameter name: "query"
80
+ prompt: 'The research question or topic to investigate',
81
+ promptKey: 'query',
82
+ },
83
+ {
84
+ from: 'supervisor',
85
+ to: 'designer',
86
+ edgeType: 'handoff',
87
+ // Custom parameter name: "requirements"
88
+ prompt: 'The design requirements and constraints',
89
+ promptKey: 'requirements',
90
+ },
91
+ {
92
+ from: 'supervisor',
93
+ to: 'coder',
94
+ edgeType: 'handoff',
95
+ // Custom parameter name: "specification"
96
+ prompt: 'The technical specification for the code to implement',
97
+ promptKey: 'specification',
98
+ },
99
+ ],
100
+ },
101
+ };
102
+
103
+ const run = await Run.create(runConfig);
104
+
105
+ // Test queries for different agents
106
+ const testQueries = [
107
+ // 'Research the latest trends in sustainable energy storage technologies',
108
+ 'Design a mobile app interface for a fitness tracking application',
109
+ // 'Write a Python function that calculates the Fibonacci sequence recursively',
110
+ ];
111
+
112
+ const config = {
113
+ configurable: {
114
+ thread_id: 'custom-prompt-key-test-1',
115
+ },
116
+ streamMode: 'values',
117
+ version: 'v2' as const,
118
+ };
119
+
120
+ for (const query of testQueries) {
121
+ console.log(`\n${'='.repeat(60)}`);
122
+ console.log(`USER QUERY: "${query}"`);
123
+ console.log('='.repeat(60));
124
+
125
+ const inputs = {
126
+ messages: [new HumanMessage(query)],
127
+ };
128
+
129
+ await run.processStream(inputs, config);
130
+
131
+ console.log(`\n${'─'.repeat(60)}`);
132
+ console.log('Each agent receives instructions via their custom parameter:');
133
+ console.log('- Researcher expects "query"');
134
+ console.log('- Designer expects "requirements"');
135
+ console.log('- Coder expects "specification"');
136
+ console.log('─'.repeat(60));
137
+ }
138
+
139
+ console.log('\n\nDemonstration complete!');
140
+ console.log('The promptKey feature allows for more semantic parameter names');
141
+ console.log('that better match the domain and purpose of each agent.');
142
+ }
143
+
144
+ // Run the test
145
+ testCustomPromptKey().catch(console.error);
@@ -0,0 +1,170 @@
1
+ import { config } from 'dotenv';
2
+ config();
3
+
4
+ import { HumanMessage } 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
+ /**
12
+ * Test the new handoff input feature using the prompt field
13
+ * This demonstrates how supervisors can pass specific instructions to specialists
14
+ */
15
+ async function testHandoffInput() {
16
+ console.log('Testing Handoff Input Feature...\n');
17
+ // Set up content aggregator
18
+ const { contentParts, aggregateContent } = createContentAggregator();
19
+
20
+ // Track which specialist role was selected
21
+ let selectedRole = '';
22
+ let roleInstructions = '';
23
+
24
+ // Create custom handlers
25
+ const customHandlers = {
26
+ [GraphEvents.TOOL_END]: new ToolEndHandler(),
27
+ [GraphEvents.CHAT_MODEL_END]: new ModelEndHandler(),
28
+ [GraphEvents.CHAT_MODEL_STREAM]: new ChatModelStreamHandler(),
29
+ [GraphEvents.ON_RUN_STEP]: {
30
+ handle: (
31
+ event: GraphEvents.ON_RUN_STEP,
32
+ data: t.StreamEventData
33
+ ): void => {
34
+ const runStepData = data as any;
35
+ if (runStepData?.name) {
36
+ console.log(`\n[${runStepData.name}] Processing...`);
37
+ }
38
+ aggregateContent({ event, data: data as t.RunStep });
39
+ },
40
+ },
41
+ [GraphEvents.ON_RUN_STEP_COMPLETED]: {
42
+ handle: (
43
+ event: GraphEvents.ON_RUN_STEP_COMPLETED,
44
+ data: t.StreamEventData
45
+ ): void => {
46
+ aggregateContent({
47
+ event,
48
+ data: data as unknown as { result: t.ToolEndEvent },
49
+ });
50
+ },
51
+ },
52
+ [GraphEvents.ON_MESSAGE_DELTA]: {
53
+ handle: (
54
+ event: GraphEvents.ON_MESSAGE_DELTA,
55
+ data: t.StreamEventData
56
+ ): void => {
57
+ console.dir(data, { depth: null });
58
+ aggregateContent({ event, data: data as t.MessageDeltaEvent });
59
+ },
60
+ },
61
+ [GraphEvents.TOOL_START]: {
62
+ handle: (
63
+ _event: string,
64
+ data: t.StreamEventData,
65
+ metadata?: Record<string, unknown>
66
+ ): void => {
67
+ const toolData = data as any;
68
+ if (toolData?.name?.includes('transfer_to_')) {
69
+ const specialist = toolData.name.replace('transfer_to_', '');
70
+ console.log(`\nšŸ”€ Transferring to ${specialist}...`);
71
+ selectedRole = specialist;
72
+ }
73
+ },
74
+ },
75
+ };
76
+
77
+ const runConfig: t.RunConfig = {
78
+ customHandlers,
79
+ runId: `test-handoff-input-${Date.now()}`,
80
+ graphConfig: {
81
+ type: 'multi-agent',
82
+ agents: [
83
+ {
84
+ agentId: 'supervisor',
85
+ provider: Providers.ANTHROPIC,
86
+ clientOptions: {
87
+ modelName: 'claude-haiku-4-5',
88
+ apiKey: process.env.ANTHROPIC_API_KEY,
89
+ },
90
+ instructions: `You are a Task Supervisor. You have access to two specialist agents:
91
+
92
+ 1. transfer_to_analyst - For data analysis tasks
93
+ 2. transfer_to_writer - For content creation tasks
94
+
95
+ When transferring to a specialist, you MUST provide specific instructions
96
+ in the tool call to guide their work. Be detailed about what you need.`,
97
+ maxContextTokens: 8000,
98
+ },
99
+ {
100
+ agentId: 'analyst',
101
+ provider: Providers.ANTHROPIC,
102
+ clientOptions: {
103
+ modelName: 'claude-haiku-4-5',
104
+ apiKey: process.env.ANTHROPIC_API_KEY,
105
+ },
106
+ instructions: `You are a Data Analyst. Follow the supervisor's instructions carefully.
107
+ When you receive instructions, acknowledge them and perform the requested analysis.`,
108
+ maxContextTokens: 8000,
109
+ },
110
+ {
111
+ agentId: 'writer',
112
+ provider: Providers.ANTHROPIC,
113
+ clientOptions: {
114
+ modelName: 'claude-haiku-4-5',
115
+ apiKey: process.env.ANTHROPIC_API_KEY,
116
+ },
117
+ instructions: `You are a Content Writer. Follow the supervisor's instructions carefully.
118
+ When you receive instructions, acknowledge them and create the requested content.`,
119
+ maxContextTokens: 8000,
120
+ },
121
+ ],
122
+ edges: [
123
+ {
124
+ from: 'supervisor',
125
+ to: ['analyst', 'writer'],
126
+ edgeType: 'handoff',
127
+ // This prompt field now serves as the description for the input parameter
128
+ prompt:
129
+ 'Specific instructions for the specialist to follow. Be detailed about what analysis to perform, what data to focus on, or what content to create.',
130
+ },
131
+ ],
132
+ },
133
+ };
134
+
135
+ const run = await Run.create(runConfig);
136
+
137
+ // Test queries that should result in different handoffs with specific instructions
138
+ const testQueries = [
139
+ // 'Analyze our Q4 sales data and identify the top 3 performing products',
140
+ 'Write a blog post about the benefits of remote work for software developers',
141
+ ];
142
+
143
+ const config = {
144
+ configurable: {
145
+ thread_id: 'handoff-input-test-1',
146
+ },
147
+ streamMode: 'values',
148
+ version: 'v2' as const,
149
+ };
150
+
151
+ for (const query of testQueries) {
152
+ console.log(`\n${'='.repeat(60)}`);
153
+ console.log(`USER QUERY: "${query}"`);
154
+ console.log('='.repeat(60));
155
+
156
+ const inputs = {
157
+ messages: [new HumanMessage(query)],
158
+ };
159
+
160
+ const finalContentParts = await run.processStream(inputs, config);
161
+
162
+ console.log(`\n${'─'.repeat(60)}`);
163
+ console.log('Notice how the supervisor passes specific instructions');
164
+ console.log('to the specialist through the handoff tool input parameter.');
165
+ console.log('─'.repeat(60));
166
+ }
167
+ }
168
+
169
+ // Run the test
170
+ testHandoffInput().catch(console.error);