illuma-agents 1.0.2

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 (437) hide show
  1. package/LICENSE +21 -0
  2. package/dist/cjs/common/enum.cjs +163 -0
  3. package/dist/cjs/common/enum.cjs.map +1 -0
  4. package/dist/cjs/events.cjs +143 -0
  5. package/dist/cjs/events.cjs.map +1 -0
  6. package/dist/cjs/graphs/Graph.cjs +581 -0
  7. package/dist/cjs/graphs/Graph.cjs.map +1 -0
  8. package/dist/cjs/instrumentation.cjs +21 -0
  9. package/dist/cjs/instrumentation.cjs.map +1 -0
  10. package/dist/cjs/llm/anthropic/index.cjs +292 -0
  11. package/dist/cjs/llm/anthropic/index.cjs.map +1 -0
  12. package/dist/cjs/llm/anthropic/types.cjs +50 -0
  13. package/dist/cjs/llm/anthropic/types.cjs.map +1 -0
  14. package/dist/cjs/llm/anthropic/utils/message_inputs.cjs +553 -0
  15. package/dist/cjs/llm/anthropic/utils/message_inputs.cjs.map +1 -0
  16. package/dist/cjs/llm/anthropic/utils/message_outputs.cjs +218 -0
  17. package/dist/cjs/llm/anthropic/utils/message_outputs.cjs.map +1 -0
  18. package/dist/cjs/llm/anthropic/utils/tools.cjs +29 -0
  19. package/dist/cjs/llm/anthropic/utils/tools.cjs.map +1 -0
  20. package/dist/cjs/llm/fake.cjs +97 -0
  21. package/dist/cjs/llm/fake.cjs.map +1 -0
  22. package/dist/cjs/llm/google/index.cjs +147 -0
  23. package/dist/cjs/llm/google/index.cjs.map +1 -0
  24. package/dist/cjs/llm/google/utils/common.cjs +490 -0
  25. package/dist/cjs/llm/google/utils/common.cjs.map +1 -0
  26. package/dist/cjs/llm/ollama/index.cjs +70 -0
  27. package/dist/cjs/llm/ollama/index.cjs.map +1 -0
  28. package/dist/cjs/llm/ollama/utils.cjs +158 -0
  29. package/dist/cjs/llm/ollama/utils.cjs.map +1 -0
  30. package/dist/cjs/llm/openai/index.cjs +613 -0
  31. package/dist/cjs/llm/openai/index.cjs.map +1 -0
  32. package/dist/cjs/llm/openai/utils/index.cjs +677 -0
  33. package/dist/cjs/llm/openai/utils/index.cjs.map +1 -0
  34. package/dist/cjs/llm/openrouter/index.cjs +29 -0
  35. package/dist/cjs/llm/openrouter/index.cjs.map +1 -0
  36. package/dist/cjs/llm/providers.cjs +47 -0
  37. package/dist/cjs/llm/providers.cjs.map +1 -0
  38. package/dist/cjs/llm/text.cjs +69 -0
  39. package/dist/cjs/llm/text.cjs.map +1 -0
  40. package/dist/cjs/llm/vertexai/index.cjs +330 -0
  41. package/dist/cjs/llm/vertexai/index.cjs.map +1 -0
  42. package/dist/cjs/main.cjs +127 -0
  43. package/dist/cjs/main.cjs.map +1 -0
  44. package/dist/cjs/messages/core.cjs +359 -0
  45. package/dist/cjs/messages/core.cjs.map +1 -0
  46. package/dist/cjs/messages/format.cjs +455 -0
  47. package/dist/cjs/messages/format.cjs.map +1 -0
  48. package/dist/cjs/messages/ids.cjs +23 -0
  49. package/dist/cjs/messages/ids.cjs.map +1 -0
  50. package/dist/cjs/messages/prune.cjs +398 -0
  51. package/dist/cjs/messages/prune.cjs.map +1 -0
  52. package/dist/cjs/run.cjs +264 -0
  53. package/dist/cjs/run.cjs.map +1 -0
  54. package/dist/cjs/splitStream.cjs +210 -0
  55. package/dist/cjs/splitStream.cjs.map +1 -0
  56. package/dist/cjs/stream.cjs +504 -0
  57. package/dist/cjs/stream.cjs.map +1 -0
  58. package/dist/cjs/tools/CodeExecutor.cjs +192 -0
  59. package/dist/cjs/tools/CodeExecutor.cjs.map +1 -0
  60. package/dist/cjs/tools/ToolNode.cjs +125 -0
  61. package/dist/cjs/tools/ToolNode.cjs.map +1 -0
  62. package/dist/cjs/tools/handlers.cjs +250 -0
  63. package/dist/cjs/tools/handlers.cjs.map +1 -0
  64. package/dist/cjs/tools/search/anthropic.cjs +40 -0
  65. package/dist/cjs/tools/search/anthropic.cjs.map +1 -0
  66. package/dist/cjs/tools/search/content.cjs +140 -0
  67. package/dist/cjs/tools/search/content.cjs.map +1 -0
  68. package/dist/cjs/tools/search/firecrawl.cjs +179 -0
  69. package/dist/cjs/tools/search/firecrawl.cjs.map +1 -0
  70. package/dist/cjs/tools/search/format.cjs +203 -0
  71. package/dist/cjs/tools/search/format.cjs.map +1 -0
  72. package/dist/cjs/tools/search/highlights.cjs +245 -0
  73. package/dist/cjs/tools/search/highlights.cjs.map +1 -0
  74. package/dist/cjs/tools/search/rerankers.cjs +174 -0
  75. package/dist/cjs/tools/search/rerankers.cjs.map +1 -0
  76. package/dist/cjs/tools/search/schema.cjs +70 -0
  77. package/dist/cjs/tools/search/schema.cjs.map +1 -0
  78. package/dist/cjs/tools/search/search.cjs +561 -0
  79. package/dist/cjs/tools/search/search.cjs.map +1 -0
  80. package/dist/cjs/tools/search/serper-scraper.cjs +132 -0
  81. package/dist/cjs/tools/search/serper-scraper.cjs.map +1 -0
  82. package/dist/cjs/tools/search/tool.cjs +331 -0
  83. package/dist/cjs/tools/search/tool.cjs.map +1 -0
  84. package/dist/cjs/tools/search/utils.cjs +66 -0
  85. package/dist/cjs/tools/search/utils.cjs.map +1 -0
  86. package/dist/cjs/utils/graph.cjs +16 -0
  87. package/dist/cjs/utils/graph.cjs.map +1 -0
  88. package/dist/cjs/utils/llm.cjs +28 -0
  89. package/dist/cjs/utils/llm.cjs.map +1 -0
  90. package/dist/cjs/utils/misc.cjs +56 -0
  91. package/dist/cjs/utils/misc.cjs.map +1 -0
  92. package/dist/cjs/utils/run.cjs +69 -0
  93. package/dist/cjs/utils/run.cjs.map +1 -0
  94. package/dist/cjs/utils/title.cjs +111 -0
  95. package/dist/cjs/utils/title.cjs.map +1 -0
  96. package/dist/cjs/utils/tokens.cjs +65 -0
  97. package/dist/cjs/utils/tokens.cjs.map +1 -0
  98. package/dist/esm/common/enum.mjs +163 -0
  99. package/dist/esm/common/enum.mjs.map +1 -0
  100. package/dist/esm/events.mjs +135 -0
  101. package/dist/esm/events.mjs.map +1 -0
  102. package/dist/esm/graphs/Graph.mjs +578 -0
  103. package/dist/esm/graphs/Graph.mjs.map +1 -0
  104. package/dist/esm/instrumentation.mjs +19 -0
  105. package/dist/esm/instrumentation.mjs.map +1 -0
  106. package/dist/esm/llm/anthropic/index.mjs +290 -0
  107. package/dist/esm/llm/anthropic/index.mjs.map +1 -0
  108. package/dist/esm/llm/anthropic/types.mjs +48 -0
  109. package/dist/esm/llm/anthropic/types.mjs.map +1 -0
  110. package/dist/esm/llm/anthropic/utils/message_inputs.mjs +550 -0
  111. package/dist/esm/llm/anthropic/utils/message_inputs.mjs.map +1 -0
  112. package/dist/esm/llm/anthropic/utils/message_outputs.mjs +216 -0
  113. package/dist/esm/llm/anthropic/utils/message_outputs.mjs.map +1 -0
  114. package/dist/esm/llm/anthropic/utils/tools.mjs +27 -0
  115. package/dist/esm/llm/anthropic/utils/tools.mjs.map +1 -0
  116. package/dist/esm/llm/fake.mjs +94 -0
  117. package/dist/esm/llm/fake.mjs.map +1 -0
  118. package/dist/esm/llm/google/index.mjs +145 -0
  119. package/dist/esm/llm/google/index.mjs.map +1 -0
  120. package/dist/esm/llm/google/utils/common.mjs +484 -0
  121. package/dist/esm/llm/google/utils/common.mjs.map +1 -0
  122. package/dist/esm/llm/ollama/index.mjs +68 -0
  123. package/dist/esm/llm/ollama/index.mjs.map +1 -0
  124. package/dist/esm/llm/ollama/utils.mjs +155 -0
  125. package/dist/esm/llm/ollama/utils.mjs.map +1 -0
  126. package/dist/esm/llm/openai/index.mjs +604 -0
  127. package/dist/esm/llm/openai/index.mjs.map +1 -0
  128. package/dist/esm/llm/openai/utils/index.mjs +671 -0
  129. package/dist/esm/llm/openai/utils/index.mjs.map +1 -0
  130. package/dist/esm/llm/openrouter/index.mjs +27 -0
  131. package/dist/esm/llm/openrouter/index.mjs.map +1 -0
  132. package/dist/esm/llm/providers.mjs +43 -0
  133. package/dist/esm/llm/providers.mjs.map +1 -0
  134. package/dist/esm/llm/text.mjs +67 -0
  135. package/dist/esm/llm/text.mjs.map +1 -0
  136. package/dist/esm/llm/vertexai/index.mjs +328 -0
  137. package/dist/esm/llm/vertexai/index.mjs.map +1 -0
  138. package/dist/esm/main.mjs +20 -0
  139. package/dist/esm/main.mjs.map +1 -0
  140. package/dist/esm/messages/core.mjs +351 -0
  141. package/dist/esm/messages/core.mjs.map +1 -0
  142. package/dist/esm/messages/format.mjs +447 -0
  143. package/dist/esm/messages/format.mjs.map +1 -0
  144. package/dist/esm/messages/ids.mjs +21 -0
  145. package/dist/esm/messages/ids.mjs.map +1 -0
  146. package/dist/esm/messages/prune.mjs +393 -0
  147. package/dist/esm/messages/prune.mjs.map +1 -0
  148. package/dist/esm/run.mjs +261 -0
  149. package/dist/esm/run.mjs.map +1 -0
  150. package/dist/esm/splitStream.mjs +207 -0
  151. package/dist/esm/splitStream.mjs.map +1 -0
  152. package/dist/esm/stream.mjs +500 -0
  153. package/dist/esm/stream.mjs.map +1 -0
  154. package/dist/esm/tools/CodeExecutor.mjs +188 -0
  155. package/dist/esm/tools/CodeExecutor.mjs.map +1 -0
  156. package/dist/esm/tools/ToolNode.mjs +122 -0
  157. package/dist/esm/tools/ToolNode.mjs.map +1 -0
  158. package/dist/esm/tools/handlers.mjs +245 -0
  159. package/dist/esm/tools/handlers.mjs.map +1 -0
  160. package/dist/esm/tools/search/anthropic.mjs +37 -0
  161. package/dist/esm/tools/search/anthropic.mjs.map +1 -0
  162. package/dist/esm/tools/search/content.mjs +119 -0
  163. package/dist/esm/tools/search/content.mjs.map +1 -0
  164. package/dist/esm/tools/search/firecrawl.mjs +176 -0
  165. package/dist/esm/tools/search/firecrawl.mjs.map +1 -0
  166. package/dist/esm/tools/search/format.mjs +201 -0
  167. package/dist/esm/tools/search/format.mjs.map +1 -0
  168. package/dist/esm/tools/search/highlights.mjs +243 -0
  169. package/dist/esm/tools/search/highlights.mjs.map +1 -0
  170. package/dist/esm/tools/search/rerankers.mjs +168 -0
  171. package/dist/esm/tools/search/rerankers.mjs.map +1 -0
  172. package/dist/esm/tools/search/schema.mjs +61 -0
  173. package/dist/esm/tools/search/schema.mjs.map +1 -0
  174. package/dist/esm/tools/search/search.mjs +558 -0
  175. package/dist/esm/tools/search/search.mjs.map +1 -0
  176. package/dist/esm/tools/search/serper-scraper.mjs +129 -0
  177. package/dist/esm/tools/search/serper-scraper.mjs.map +1 -0
  178. package/dist/esm/tools/search/tool.mjs +329 -0
  179. package/dist/esm/tools/search/tool.mjs.map +1 -0
  180. package/dist/esm/tools/search/utils.mjs +61 -0
  181. package/dist/esm/tools/search/utils.mjs.map +1 -0
  182. package/dist/esm/utils/graph.mjs +13 -0
  183. package/dist/esm/utils/graph.mjs.map +1 -0
  184. package/dist/esm/utils/llm.mjs +25 -0
  185. package/dist/esm/utils/llm.mjs.map +1 -0
  186. package/dist/esm/utils/misc.mjs +53 -0
  187. package/dist/esm/utils/misc.mjs.map +1 -0
  188. package/dist/esm/utils/run.mjs +66 -0
  189. package/dist/esm/utils/run.mjs.map +1 -0
  190. package/dist/esm/utils/title.mjs +108 -0
  191. package/dist/esm/utils/title.mjs.map +1 -0
  192. package/dist/esm/utils/tokens.mjs +62 -0
  193. package/dist/esm/utils/tokens.mjs.map +1 -0
  194. package/dist/types/common/enum.d.ts +128 -0
  195. package/dist/types/common/index.d.ts +1 -0
  196. package/dist/types/events.d.ts +29 -0
  197. package/dist/types/graphs/Graph.d.ts +122 -0
  198. package/dist/types/graphs/index.d.ts +1 -0
  199. package/dist/types/index.d.ts +13 -0
  200. package/dist/types/instrumentation.d.ts +1 -0
  201. package/dist/types/llm/anthropic/index.d.ts +39 -0
  202. package/dist/types/llm/anthropic/types.d.ts +37 -0
  203. package/dist/types/llm/anthropic/utils/message_inputs.d.ts +14 -0
  204. package/dist/types/llm/anthropic/utils/message_outputs.d.ts +14 -0
  205. package/dist/types/llm/anthropic/utils/output_parsers.d.ts +22 -0
  206. package/dist/types/llm/anthropic/utils/tools.d.ts +3 -0
  207. package/dist/types/llm/fake.d.ts +31 -0
  208. package/dist/types/llm/google/index.d.ts +14 -0
  209. package/dist/types/llm/google/types.d.ts +32 -0
  210. package/dist/types/llm/google/utils/common.d.ts +19 -0
  211. package/dist/types/llm/google/utils/tools.d.ts +10 -0
  212. package/dist/types/llm/google/utils/zod_to_genai_parameters.d.ts +14 -0
  213. package/dist/types/llm/ollama/index.d.ts +8 -0
  214. package/dist/types/llm/ollama/utils.d.ts +7 -0
  215. package/dist/types/llm/openai/index.d.ts +103 -0
  216. package/dist/types/llm/openai/types.d.ts +10 -0
  217. package/dist/types/llm/openai/utils/index.d.ts +20 -0
  218. package/dist/types/llm/openrouter/index.d.ts +12 -0
  219. package/dist/types/llm/providers.d.ts +5 -0
  220. package/dist/types/llm/text.d.ts +21 -0
  221. package/dist/types/llm/vertexai/index.d.ts +293 -0
  222. package/dist/types/messages/core.d.ts +14 -0
  223. package/dist/types/messages/format.d.ts +113 -0
  224. package/dist/types/messages/ids.d.ts +3 -0
  225. package/dist/types/messages/index.d.ts +4 -0
  226. package/dist/types/messages/prune.d.ts +51 -0
  227. package/dist/types/mockStream.d.ts +32 -0
  228. package/dist/types/prompts/collab.d.ts +1 -0
  229. package/dist/types/prompts/index.d.ts +2 -0
  230. package/dist/types/prompts/taskmanager.d.ts +41 -0
  231. package/dist/types/run.d.ts +30 -0
  232. package/dist/types/scripts/abort.d.ts +1 -0
  233. package/dist/types/scripts/ant_web_search.d.ts +1 -0
  234. package/dist/types/scripts/args.d.ts +7 -0
  235. package/dist/types/scripts/caching.d.ts +1 -0
  236. package/dist/types/scripts/cli.d.ts +1 -0
  237. package/dist/types/scripts/cli2.d.ts +1 -0
  238. package/dist/types/scripts/cli3.d.ts +1 -0
  239. package/dist/types/scripts/cli4.d.ts +1 -0
  240. package/dist/types/scripts/cli5.d.ts +1 -0
  241. package/dist/types/scripts/code_exec.d.ts +1 -0
  242. package/dist/types/scripts/code_exec_files.d.ts +1 -0
  243. package/dist/types/scripts/code_exec_simple.d.ts +1 -0
  244. package/dist/types/scripts/content.d.ts +1 -0
  245. package/dist/types/scripts/empty_input.d.ts +1 -0
  246. package/dist/types/scripts/image.d.ts +1 -0
  247. package/dist/types/scripts/memory.d.ts +1 -0
  248. package/dist/types/scripts/search.d.ts +1 -0
  249. package/dist/types/scripts/simple.d.ts +1 -0
  250. package/dist/types/scripts/stream.d.ts +1 -0
  251. package/dist/types/scripts/thinking.d.ts +1 -0
  252. package/dist/types/scripts/tools.d.ts +1 -0
  253. package/dist/types/specs/spec.utils.d.ts +1 -0
  254. package/dist/types/splitStream.d.ts +37 -0
  255. package/dist/types/stream.d.ts +14 -0
  256. package/dist/types/tools/CodeExecutor.d.ts +23 -0
  257. package/dist/types/tools/ToolNode.d.ts +22 -0
  258. package/dist/types/tools/example.d.ts +78 -0
  259. package/dist/types/tools/handlers.d.ts +19 -0
  260. package/dist/types/tools/search/anthropic.d.ts +16 -0
  261. package/dist/types/tools/search/content.d.ts +4 -0
  262. package/dist/types/tools/search/firecrawl.d.ts +54 -0
  263. package/dist/types/tools/search/format.d.ts +5 -0
  264. package/dist/types/tools/search/highlights.d.ts +13 -0
  265. package/dist/types/tools/search/index.d.ts +2 -0
  266. package/dist/types/tools/search/rerankers.d.ts +38 -0
  267. package/dist/types/tools/search/schema.d.ts +16 -0
  268. package/dist/types/tools/search/search.d.ts +8 -0
  269. package/dist/types/tools/search/serper-scraper.d.ts +59 -0
  270. package/dist/types/tools/search/test.d.ts +1 -0
  271. package/dist/types/tools/search/tool.d.ts +54 -0
  272. package/dist/types/tools/search/types.d.ts +591 -0
  273. package/dist/types/tools/search/utils.d.ts +10 -0
  274. package/dist/types/types/graph.d.ts +138 -0
  275. package/dist/types/types/index.d.ts +5 -0
  276. package/dist/types/types/llm.d.ts +102 -0
  277. package/dist/types/types/run.d.ts +74 -0
  278. package/dist/types/types/stream.d.ts +293 -0
  279. package/dist/types/types/tools.d.ts +61 -0
  280. package/dist/types/utils/graph.d.ts +2 -0
  281. package/dist/types/utils/index.d.ts +5 -0
  282. package/dist/types/utils/llm.d.ts +3 -0
  283. package/dist/types/utils/llmConfig.d.ts +3 -0
  284. package/dist/types/utils/logging.d.ts +1 -0
  285. package/dist/types/utils/misc.d.ts +7 -0
  286. package/dist/types/utils/run.d.ts +27 -0
  287. package/dist/types/utils/title.d.ts +4 -0
  288. package/dist/types/utils/tokens.d.ts +3 -0
  289. package/package.json +145 -0
  290. package/src/common/enum.ts +176 -0
  291. package/src/common/index.ts +2 -0
  292. package/src/events.ts +191 -0
  293. package/src/graphs/Graph.ts +846 -0
  294. package/src/graphs/index.ts +1 -0
  295. package/src/index.ts +24 -0
  296. package/src/instrumentation.ts +22 -0
  297. package/src/llm/anthropic/Jacob_Lee_Resume_2023.pdf +0 -0
  298. package/src/llm/anthropic/index.ts +413 -0
  299. package/src/llm/anthropic/llm.spec.ts +1442 -0
  300. package/src/llm/anthropic/types.ts +140 -0
  301. package/src/llm/anthropic/utils/message_inputs.ts +660 -0
  302. package/src/llm/anthropic/utils/message_outputs.ts +289 -0
  303. package/src/llm/anthropic/utils/output_parsers.ts +133 -0
  304. package/src/llm/anthropic/utils/tools.ts +29 -0
  305. package/src/llm/fake.ts +133 -0
  306. package/src/llm/google/index.ts +222 -0
  307. package/src/llm/google/types.ts +43 -0
  308. package/src/llm/google/utils/common.ts +660 -0
  309. package/src/llm/google/utils/tools.ts +160 -0
  310. package/src/llm/google/utils/zod_to_genai_parameters.ts +88 -0
  311. package/src/llm/ollama/index.ts +92 -0
  312. package/src/llm/ollama/utils.ts +193 -0
  313. package/src/llm/openai/index.ts +853 -0
  314. package/src/llm/openai/types.ts +24 -0
  315. package/src/llm/openai/utils/index.ts +918 -0
  316. package/src/llm/openai/utils/isReasoningModel.test.ts +90 -0
  317. package/src/llm/openrouter/index.ts +60 -0
  318. package/src/llm/providers.ts +57 -0
  319. package/src/llm/text.ts +94 -0
  320. package/src/llm/vertexai/index.ts +360 -0
  321. package/src/messages/core.ts +463 -0
  322. package/src/messages/format.ts +625 -0
  323. package/src/messages/formatAgentMessages.test.ts +917 -0
  324. package/src/messages/formatAgentMessages.tools.test.ts +400 -0
  325. package/src/messages/formatMessage.test.ts +693 -0
  326. package/src/messages/ids.ts +26 -0
  327. package/src/messages/index.ts +4 -0
  328. package/src/messages/prune.ts +567 -0
  329. package/src/messages/shiftIndexTokenCountMap.test.ts +81 -0
  330. package/src/mockStream.ts +99 -0
  331. package/src/prompts/collab.ts +6 -0
  332. package/src/prompts/index.ts +2 -0
  333. package/src/prompts/taskmanager.ts +61 -0
  334. package/src/proto/CollabGraph.ts +269 -0
  335. package/src/proto/TaskManager.ts +243 -0
  336. package/src/proto/collab.ts +200 -0
  337. package/src/proto/collab_design.ts +184 -0
  338. package/src/proto/collab_design_v2.ts +224 -0
  339. package/src/proto/collab_design_v3.ts +255 -0
  340. package/src/proto/collab_design_v4.ts +220 -0
  341. package/src/proto/collab_design_v5.ts +251 -0
  342. package/src/proto/collab_graph.ts +181 -0
  343. package/src/proto/collab_original.ts +123 -0
  344. package/src/proto/example.ts +93 -0
  345. package/src/proto/example_new.ts +68 -0
  346. package/src/proto/example_old.ts +201 -0
  347. package/src/proto/example_test.ts +152 -0
  348. package/src/proto/example_test_anthropic.ts +100 -0
  349. package/src/proto/log_stream.ts +202 -0
  350. package/src/proto/main_collab_community_event.ts +133 -0
  351. package/src/proto/main_collab_design_v2.ts +96 -0
  352. package/src/proto/main_collab_design_v4.ts +100 -0
  353. package/src/proto/main_collab_design_v5.ts +135 -0
  354. package/src/proto/main_collab_global_analysis.ts +122 -0
  355. package/src/proto/main_collab_hackathon_event.ts +153 -0
  356. package/src/proto/main_collab_space_mission.ts +153 -0
  357. package/src/proto/main_philosophy.ts +210 -0
  358. package/src/proto/original_script.ts +126 -0
  359. package/src/proto/standard.ts +100 -0
  360. package/src/proto/stream.ts +56 -0
  361. package/src/proto/tasks.ts +118 -0
  362. package/src/proto/tools/global_analysis_tools.ts +86 -0
  363. package/src/proto/tools/space_mission_tools.ts +60 -0
  364. package/src/proto/vertexai.ts +54 -0
  365. package/src/run.ts +381 -0
  366. package/src/scripts/abort.ts +138 -0
  367. package/src/scripts/ant_web_search.ts +158 -0
  368. package/src/scripts/args.ts +48 -0
  369. package/src/scripts/caching.ts +124 -0
  370. package/src/scripts/cli.ts +167 -0
  371. package/src/scripts/cli2.ts +125 -0
  372. package/src/scripts/cli3.ts +178 -0
  373. package/src/scripts/cli4.ts +184 -0
  374. package/src/scripts/cli5.ts +184 -0
  375. package/src/scripts/code_exec.ts +214 -0
  376. package/src/scripts/code_exec_files.ts +193 -0
  377. package/src/scripts/code_exec_simple.ts +129 -0
  378. package/src/scripts/content.ts +120 -0
  379. package/src/scripts/empty_input.ts +137 -0
  380. package/src/scripts/image.ts +178 -0
  381. package/src/scripts/memory.ts +97 -0
  382. package/src/scripts/search.ts +150 -0
  383. package/src/scripts/simple.ts +225 -0
  384. package/src/scripts/stream.ts +122 -0
  385. package/src/scripts/thinking.ts +150 -0
  386. package/src/scripts/tools.ts +155 -0
  387. package/src/specs/anthropic.simple.test.ts +317 -0
  388. package/src/specs/azure.simple.test.ts +316 -0
  389. package/src/specs/openai.simple.test.ts +316 -0
  390. package/src/specs/prune.test.ts +763 -0
  391. package/src/specs/reasoning.test.ts +165 -0
  392. package/src/specs/spec.utils.ts +3 -0
  393. package/src/specs/thinking-prune.test.ts +703 -0
  394. package/src/specs/token-distribution-edge-case.test.ts +316 -0
  395. package/src/specs/tool-error.test.ts +193 -0
  396. package/src/splitStream.test.ts +691 -0
  397. package/src/splitStream.ts +234 -0
  398. package/src/stream.test.ts +94 -0
  399. package/src/stream.ts +651 -0
  400. package/src/tools/CodeExecutor.ts +220 -0
  401. package/src/tools/ToolNode.ts +170 -0
  402. package/src/tools/example.ts +129 -0
  403. package/src/tools/handlers.ts +336 -0
  404. package/src/tools/search/anthropic.ts +51 -0
  405. package/src/tools/search/content.test.ts +173 -0
  406. package/src/tools/search/content.ts +147 -0
  407. package/src/tools/search/firecrawl.ts +210 -0
  408. package/src/tools/search/format.ts +250 -0
  409. package/src/tools/search/highlights.ts +320 -0
  410. package/src/tools/search/index.ts +2 -0
  411. package/src/tools/search/jina-reranker.test.ts +126 -0
  412. package/src/tools/search/output.md +2775 -0
  413. package/src/tools/search/rerankers.ts +242 -0
  414. package/src/tools/search/schema.ts +63 -0
  415. package/src/tools/search/search.ts +759 -0
  416. package/src/tools/search/serper-scraper.ts +155 -0
  417. package/src/tools/search/test.html +884 -0
  418. package/src/tools/search/test.md +643 -0
  419. package/src/tools/search/test.ts +159 -0
  420. package/src/tools/search/tool.ts +471 -0
  421. package/src/tools/search/types.ts +687 -0
  422. package/src/tools/search/utils.ts +79 -0
  423. package/src/types/graph.ts +185 -0
  424. package/src/types/index.ts +6 -0
  425. package/src/types/llm.ts +140 -0
  426. package/src/types/run.ts +89 -0
  427. package/src/types/stream.ts +400 -0
  428. package/src/types/tools.ts +80 -0
  429. package/src/utils/graph.ts +11 -0
  430. package/src/utils/index.ts +5 -0
  431. package/src/utils/llm.ts +27 -0
  432. package/src/utils/llmConfig.ts +183 -0
  433. package/src/utils/logging.ts +48 -0
  434. package/src/utils/misc.ts +57 -0
  435. package/src/utils/run.ts +101 -0
  436. package/src/utils/title.ts +165 -0
  437. package/src/utils/tokens.ts +70 -0
package/src/run.ts ADDED
@@ -0,0 +1,381 @@
1
+ // src/run.ts
2
+ import './instrumentation';
3
+ import { zodToJsonSchema } from 'zod-to-json-schema';
4
+ import { CallbackHandler } from '@langfuse/langchain';
5
+ import { PromptTemplate } from '@langchain/core/prompts';
6
+ import { SystemMessage } from '@langchain/core/messages';
7
+ import { RunnableLambda } from '@langchain/core/runnables';
8
+ import { AzureChatOpenAI, ChatOpenAI } from '@langchain/openai';
9
+ import type {
10
+ MessageContentComplex,
11
+ BaseMessage,
12
+ } from '@langchain/core/messages';
13
+ import type { StringPromptValue } from '@langchain/core/prompt_values';
14
+ import type { RunnableConfig } from '@langchain/core/runnables';
15
+ import type { ClientCallbacks, SystemCallbacks } from '@/graphs/Graph';
16
+ import type * as t from '@/types';
17
+ import { GraphEvents, Providers, Callback, TitleMethod } from '@/common';
18
+ import { manualToolStreamProviders } from '@/llm/providers';
19
+ import { shiftIndexTokenCountMap } from '@/messages/format';
20
+ import {
21
+ createTitleRunnable,
22
+ createCompletionTitleRunnable,
23
+ } from '@/utils/title';
24
+ import { createTokenCounter } from '@/utils/tokens';
25
+ import { StandardGraph } from '@/graphs/Graph';
26
+ import { HandlerRegistry } from '@/events';
27
+ import { isOpenAILike } from '@/utils/llm';
28
+ import { isPresent } from '@/utils/misc';
29
+
30
+ export const defaultOmitOptions = new Set([
31
+ 'stream',
32
+ 'thinking',
33
+ 'streaming',
34
+ 'maxTokens',
35
+ 'clientOptions',
36
+ 'thinkingConfig',
37
+ 'thinkingBudget',
38
+ 'includeThoughts',
39
+ 'maxOutputTokens',
40
+ 'additionalModelRequestFields',
41
+ ]);
42
+
43
+ export class Run<T extends t.BaseGraphState> {
44
+ graphRunnable?: t.CompiledWorkflow<T, Partial<T>, string>;
45
+ // private collab!: CollabGraph;
46
+ // private taskManager!: TaskManager;
47
+ private handlerRegistry: HandlerRegistry;
48
+ id: string;
49
+ Graph: StandardGraph | undefined;
50
+ provider: Providers | undefined;
51
+ returnContent: boolean = false;
52
+
53
+ private constructor(config: Partial<t.RunConfig>) {
54
+ const runId = config.runId ?? '';
55
+ if (!runId) {
56
+ throw new Error('Run ID not provided');
57
+ }
58
+
59
+ this.id = runId;
60
+
61
+ const handlerRegistry = new HandlerRegistry();
62
+
63
+ if (config.customHandlers) {
64
+ for (const [eventType, handler] of Object.entries(
65
+ config.customHandlers
66
+ )) {
67
+ handlerRegistry.register(eventType, handler);
68
+ }
69
+ }
70
+
71
+ this.handlerRegistry = handlerRegistry;
72
+
73
+ if (!config.graphConfig) {
74
+ throw new Error('Graph config not provided');
75
+ }
76
+
77
+ if (config.graphConfig.type === 'standard' || !config.graphConfig.type) {
78
+ this.provider = config.graphConfig.llmConfig.provider;
79
+ this.graphRunnable = this.createStandardGraph(
80
+ config.graphConfig
81
+ ) as unknown as t.CompiledWorkflow<T, Partial<T>, string>;
82
+ if (this.Graph) {
83
+ this.Graph.handlerRegistry = handlerRegistry;
84
+ }
85
+ }
86
+
87
+ this.returnContent = config.returnContent ?? false;
88
+ }
89
+
90
+ private createStandardGraph(
91
+ config: t.StandardGraphConfig
92
+ ): t.CompiledWorkflow<t.IState, Partial<t.IState>, string> {
93
+ const { llmConfig, tools = [], ...graphInput } = config;
94
+ const { provider, ...clientOptions } = llmConfig;
95
+
96
+ const standardGraph = new StandardGraph({
97
+ tools,
98
+ provider,
99
+ clientOptions,
100
+ ...graphInput,
101
+ runId: this.id,
102
+ });
103
+ this.Graph = standardGraph;
104
+ return standardGraph.createWorkflow();
105
+ }
106
+
107
+ static async create<T extends t.BaseGraphState>(
108
+ config: t.RunConfig
109
+ ): Promise<Run<T>> {
110
+ return new Run<T>(config);
111
+ }
112
+
113
+ getRunMessages(): BaseMessage[] | undefined {
114
+ if (!this.Graph) {
115
+ throw new Error(
116
+ 'Graph not initialized. Make sure to use Run.create() to instantiate the Run.'
117
+ );
118
+ }
119
+ return this.Graph.getRunMessages();
120
+ }
121
+
122
+ async processStream(
123
+ inputs: t.IState,
124
+ config: Partial<RunnableConfig> & { version: 'v1' | 'v2'; run_id?: string },
125
+ streamOptions?: t.EventStreamOptions
126
+ ): Promise<MessageContentComplex[] | undefined> {
127
+ if (!this.graphRunnable) {
128
+ throw new Error(
129
+ 'Run not initialized. Make sure to use Run.create() to instantiate the Run.'
130
+ );
131
+ }
132
+ if (!this.Graph) {
133
+ throw new Error(
134
+ 'Graph not initialized. Make sure to use Run.create() to instantiate the Run.'
135
+ );
136
+ }
137
+
138
+ this.Graph.resetValues(streamOptions?.keepContent);
139
+ const provider = this.Graph.provider;
140
+ const hasTools = this.Graph.tools ? this.Graph.tools.length > 0 : false;
141
+ if (streamOptions?.callbacks) {
142
+ /* TODO: conflicts with callback manager */
143
+ const callbacks = (config.callbacks as t.ProvidedCallbacks) ?? [];
144
+ config.callbacks = callbacks.concat(
145
+ this.getCallbacks(streamOptions.callbacks)
146
+ );
147
+ }
148
+
149
+ if (
150
+ isPresent(process.env.LANGFUSE_SECRET_KEY) &&
151
+ isPresent(process.env.LANGFUSE_PUBLIC_KEY) &&
152
+ isPresent(process.env.LANGFUSE_BASE_URL)
153
+ ) {
154
+ const userId = config.configurable?.user_id;
155
+ const sessionId = config.configurable?.thread_id;
156
+ const traceMetadata = {
157
+ messageId: this.id,
158
+ parentMessageId: config.configurable?.requestBody?.parentMessageId,
159
+ };
160
+ const handler = new CallbackHandler({
161
+ userId,
162
+ sessionId,
163
+ traceMetadata,
164
+ });
165
+ config.callbacks = (
166
+ (config.callbacks as t.ProvidedCallbacks) ?? []
167
+ ).concat([handler]);
168
+ }
169
+
170
+ if (!this.id) {
171
+ throw new Error('Run ID not provided');
172
+ }
173
+
174
+ const tokenCounter =
175
+ streamOptions?.tokenCounter ??
176
+ (streamOptions?.indexTokenCountMap
177
+ ? await createTokenCounter()
178
+ : undefined);
179
+ const tools = this.Graph.tools as
180
+ | Array<t.GenericTool | undefined>
181
+ | undefined;
182
+ const toolTokens = tokenCounter
183
+ ? (tools?.reduce((acc, tool) => {
184
+ if (!(tool as Partial<t.GenericTool>).schema) {
185
+ return acc;
186
+ }
187
+
188
+ const jsonSchema = zodToJsonSchema(
189
+ (tool?.schema as t.ZodObjectAny).describe(tool?.description ?? ''),
190
+ tool?.name ?? ''
191
+ );
192
+ return (
193
+ acc + tokenCounter(new SystemMessage(JSON.stringify(jsonSchema)))
194
+ );
195
+ }, 0) ?? 0)
196
+ : 0;
197
+ let instructionTokens = toolTokens;
198
+ if (this.Graph.systemMessage && tokenCounter) {
199
+ instructionTokens += tokenCounter(this.Graph.systemMessage);
200
+ }
201
+ const tokenMap = streamOptions?.indexTokenCountMap ?? {};
202
+ if (this.Graph.systemMessage && instructionTokens > 0) {
203
+ this.Graph.indexTokenCountMap = shiftIndexTokenCountMap(
204
+ tokenMap,
205
+ instructionTokens
206
+ );
207
+ } else if (instructionTokens > 0) {
208
+ tokenMap[0] = tokenMap[0] + instructionTokens;
209
+ this.Graph.indexTokenCountMap = tokenMap;
210
+ } else {
211
+ this.Graph.indexTokenCountMap = tokenMap;
212
+ }
213
+
214
+ this.Graph.maxContextTokens = streamOptions?.maxContextTokens;
215
+ this.Graph.tokenCounter = tokenCounter;
216
+
217
+ config.run_id = this.id;
218
+ config.configurable = Object.assign(config.configurable ?? {}, {
219
+ run_id: this.id,
220
+ provider: this.provider,
221
+ });
222
+
223
+ const stream = this.graphRunnable.streamEvents(inputs, config, {
224
+ raiseError: true,
225
+ });
226
+
227
+ for await (const event of stream) {
228
+ const { data, name, metadata, ...info } = event;
229
+
230
+ let eventName: t.EventName = info.event;
231
+ if (
232
+ hasTools &&
233
+ manualToolStreamProviders.has(provider) &&
234
+ eventName === GraphEvents.CHAT_MODEL_STREAM
235
+ ) {
236
+ /* Skipping CHAT_MODEL_STREAM event due to double-call edge case */
237
+ continue;
238
+ }
239
+
240
+ if (eventName && eventName === GraphEvents.ON_CUSTOM_EVENT) {
241
+ eventName = name;
242
+ }
243
+
244
+ const handler = this.handlerRegistry.getHandler(eventName);
245
+ if (handler) {
246
+ handler.handle(eventName, data, metadata, this.Graph);
247
+ }
248
+ }
249
+
250
+ if (this.returnContent) {
251
+ return this.Graph.getContentParts();
252
+ }
253
+ }
254
+
255
+ private createSystemCallback<K extends keyof ClientCallbacks>(
256
+ clientCallbacks: ClientCallbacks,
257
+ key: K
258
+ ): SystemCallbacks[K] {
259
+ return ((...args: unknown[]) => {
260
+ const clientCallback = clientCallbacks[key];
261
+ if (clientCallback && this.Graph) {
262
+ (clientCallback as (...args: unknown[]) => void)(this.Graph, ...args);
263
+ }
264
+ }) as SystemCallbacks[K];
265
+ }
266
+
267
+ getCallbacks(clientCallbacks: ClientCallbacks): SystemCallbacks {
268
+ return {
269
+ [Callback.TOOL_ERROR]: this.createSystemCallback(
270
+ clientCallbacks,
271
+ Callback.TOOL_ERROR
272
+ ),
273
+ [Callback.TOOL_START]: this.createSystemCallback(
274
+ clientCallbacks,
275
+ Callback.TOOL_START
276
+ ),
277
+ [Callback.TOOL_END]: this.createSystemCallback(
278
+ clientCallbacks,
279
+ Callback.TOOL_END
280
+ ),
281
+ };
282
+ }
283
+
284
+ async generateTitle({
285
+ provider,
286
+ inputText,
287
+ contentParts,
288
+ titlePrompt,
289
+ clientOptions,
290
+ chainOptions,
291
+ skipLanguage,
292
+ omitOptions = defaultOmitOptions,
293
+ titleMethod = TitleMethod.COMPLETION,
294
+ titlePromptTemplate,
295
+ }: t.RunTitleOptions): Promise<{ language?: string; title?: string }> {
296
+ if (
297
+ chainOptions != null &&
298
+ isPresent(process.env.LANGFUSE_SECRET_KEY) &&
299
+ isPresent(process.env.LANGFUSE_PUBLIC_KEY) &&
300
+ isPresent(process.env.LANGFUSE_BASE_URL)
301
+ ) {
302
+ const userId = chainOptions.configurable?.user_id;
303
+ const sessionId = chainOptions.configurable?.thread_id;
304
+ const traceMetadata = {
305
+ messageId: 'title-' + this.id,
306
+ };
307
+ const handler = new CallbackHandler({
308
+ userId,
309
+ sessionId,
310
+ traceMetadata,
311
+ });
312
+ chainOptions.callbacks = (
313
+ (chainOptions.callbacks as t.ProvidedCallbacks) ?? []
314
+ ).concat([handler]);
315
+ }
316
+
317
+ const convoTemplate = PromptTemplate.fromTemplate(
318
+ titlePromptTemplate ?? 'User: {input}\nAI: {output}'
319
+ );
320
+
321
+ const response = contentParts
322
+ .map((part) => {
323
+ if (part?.type === 'text') return part.text;
324
+ return '';
325
+ })
326
+ .join('\n');
327
+
328
+ const model = this.Graph?.getNewModel({
329
+ provider,
330
+ omitOptions,
331
+ clientOptions,
332
+ });
333
+ if (!model) {
334
+ return { language: '', title: '' };
335
+ }
336
+ if (
337
+ isOpenAILike(provider) &&
338
+ (model instanceof ChatOpenAI || model instanceof AzureChatOpenAI)
339
+ ) {
340
+ model.temperature = (clientOptions as t.OpenAIClientOptions | undefined)
341
+ ?.temperature as number;
342
+ model.topP = (clientOptions as t.OpenAIClientOptions | undefined)
343
+ ?.topP as number;
344
+ model.frequencyPenalty = (
345
+ clientOptions as t.OpenAIClientOptions | undefined
346
+ )?.frequencyPenalty as number;
347
+ model.presencePenalty = (
348
+ clientOptions as t.OpenAIClientOptions | undefined
349
+ )?.presencePenalty as number;
350
+ model.n = (clientOptions as t.OpenAIClientOptions | undefined)
351
+ ?.n as number;
352
+ }
353
+
354
+ const convoToTitleInput = new RunnableLambda({
355
+ func: (
356
+ promptValue: StringPromptValue
357
+ ): { convo: string; inputText: string; skipLanguage?: boolean } => ({
358
+ convo: promptValue.value,
359
+ inputText,
360
+ skipLanguage,
361
+ }),
362
+ }).withConfig({ runName: 'ConvoTransform' });
363
+
364
+ const titleChain =
365
+ titleMethod === TitleMethod.COMPLETION
366
+ ? await createCompletionTitleRunnable(model, titlePrompt)
367
+ : await createTitleRunnable(model, titlePrompt);
368
+
369
+ /** Pipes `convoTemplate` -> `transformer` -> `titleChain` */
370
+ const fullChain = convoTemplate
371
+ .withConfig({ runName: 'ConvoTemplate' })
372
+ .pipe(convoToTitleInput)
373
+ .pipe(titleChain)
374
+ .withConfig({ runName: 'TitleChain' });
375
+
376
+ return await fullChain.invoke(
377
+ { input: inputText, output: response },
378
+ chainOptions
379
+ );
380
+ }
381
+ }
@@ -0,0 +1,138 @@
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 { TavilySearchResults } from '@langchain/community/tools/tavily_search';
7
+ import type * as t from '@/types';
8
+ import { ChatModelStreamHandler, createContentAggregator } from '@/stream';
9
+ import { ToolEndHandler } from '@/events';
10
+
11
+ import { getArgs } from '@/scripts/args';
12
+ import { Run } from '@/run';
13
+ import { GraphEvents, Callback } from '@/common';
14
+ import { getLLMConfig } from '@/utils/llmConfig';
15
+
16
+ const conversationHistory: BaseMessage[] = [];
17
+
18
+ async function testStandardStreaming(): Promise<void> {
19
+ const { userName, location, provider, currentDate } = await getArgs();
20
+ const { contentParts, aggregateContent } = createContentAggregator();
21
+ const controller = new AbortController();
22
+
23
+ const customHandlers = {
24
+ [GraphEvents.TOOL_END]: new ToolEndHandler(),
25
+ [GraphEvents.CHAT_MODEL_STREAM]: new ChatModelStreamHandler(),
26
+ [GraphEvents.ON_RUN_STEP_COMPLETED]: {
27
+ handle: (event: GraphEvents.ON_RUN_STEP_COMPLETED, data: t.StreamEventData): void => {
28
+ console.log('====== ON_RUN_STEP_COMPLETED ======');
29
+ aggregateContent({ event, data: data as unknown as { result: t.ToolEndEvent } });
30
+ }
31
+ },
32
+ [GraphEvents.ON_RUN_STEP]: {
33
+ handle: (event: GraphEvents.ON_RUN_STEP, data: t.StreamEventData): void => {
34
+ console.log('====== ON_RUN_STEP ======');
35
+ console.dir(data, { depth: null });
36
+ aggregateContent({ event, data: data as t.RunStep });
37
+ }
38
+ },
39
+ [GraphEvents.ON_RUN_STEP_DELTA]: {
40
+ handle: (event: GraphEvents.ON_RUN_STEP_DELTA, data: t.StreamEventData): void => {
41
+ console.log('====== ON_RUN_STEP_DELTA ======');
42
+ console.dir(data, { depth: null });
43
+ aggregateContent({ event, data: data as t.RunStepDeltaEvent });
44
+ }
45
+ },
46
+ [GraphEvents.ON_MESSAGE_DELTA]: {
47
+ handle: (event: GraphEvents.ON_MESSAGE_DELTA, data: t.StreamEventData): void => {
48
+ console.log('====== ON_MESSAGE_DELTA ======');
49
+ console.dir(data, { depth: null });
50
+ aggregateContent({ event, data: data as t.MessageDeltaEvent });
51
+ }
52
+ },
53
+ [GraphEvents.TOOL_START]: {
54
+ handle: (_event: string, data: t.StreamEventData, metadata?: Record<string, unknown>): void => {
55
+ console.log('====== TOOL_START ======');
56
+ }
57
+ },
58
+ };
59
+
60
+ const llmConfig = getLLMConfig(provider);
61
+ const signal = controller.signal;
62
+ const run = await Run.create<t.IState>({
63
+ runId: 'test-run-id',
64
+ graphConfig: {
65
+ type: 'standard',
66
+ signal,
67
+ llmConfig,
68
+ tools: [new TavilySearchResults()],
69
+ instructions: 'You are a friendly AI assistant. Always address the user by their name.',
70
+ additional_instructions: `The user's name is ${userName} and they are located in ${location}.`,
71
+ },
72
+ customHandlers,
73
+ });
74
+
75
+ const config = {
76
+ configurable: {
77
+ provider,
78
+ thread_id: 'conversation-num-1',
79
+ },
80
+ signal,
81
+ streamMode: 'values',
82
+ version: 'v2' as const,
83
+ };
84
+
85
+ console.log('Test 1: Weather query (content parts test)');
86
+
87
+ const userMessage = `
88
+ Make a search for the weather in ${location} today, which is ${currentDate}.
89
+ Make sure to always refer to me by name, which is ${userName}.
90
+ After giving me a thorough summary, tell me a joke about the weather forecast we went over.
91
+ `;
92
+
93
+ conversationHistory.push(new HumanMessage(userMessage));
94
+
95
+ const inputs = {
96
+ messages: conversationHistory,
97
+ };
98
+
99
+ // Set a timeout to abort the operation after 5 seconds
100
+ setTimeout(() => {
101
+ controller.abort();
102
+ console.log('Operation aborted');
103
+ console.log('Current content parts:');
104
+ console.dir(contentParts, { depth: null });
105
+ }, 4000);
106
+
107
+ try {
108
+ const finalContentParts = await run.processStream(inputs, config);
109
+ const finalMessages = run.getRunMessages();
110
+ if (finalMessages) {
111
+ conversationHistory.push(...finalMessages);
112
+ console.dir(conversationHistory, { depth: null });
113
+ }
114
+ console.dir(finalContentParts, { depth: null });
115
+ } catch (error) {
116
+ if ((error as Error)?.name === 'AbortError') {
117
+ console.log('Operation was aborted');
118
+ } else {
119
+ console.error('An error occurred:', error);
120
+ }
121
+ }
122
+
123
+ console.log('\n\n====================\n\n');
124
+ console.dir(contentParts, { depth: null });
125
+ }
126
+
127
+ process.on('unhandledRejection', (reason, promise) => {
128
+ console.error('Unhandled Rejection at:', promise, 'reason:', reason);
129
+ console.log('Conversation history:');
130
+ process.exit(1);
131
+ });
132
+
133
+ testStandardStreaming().catch((err) => {
134
+ console.error(err);
135
+ console.log('Conversation history:');
136
+ console.dir(conversationHistory, { depth: null });
137
+ process.exit(1);
138
+ });
@@ -0,0 +1,158 @@
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, ModelEndHandler } from '@/events';
9
+
10
+ import { getArgs } from '@/scripts/args';
11
+ import { Run } from '@/run';
12
+ import { GraphEvents, Callback, Providers } from '@/common';
13
+ import { getLLMConfig } from '@/utils/llmConfig';
14
+
15
+ const conversationHistory: BaseMessage[] = [];
16
+ let _contentParts: (t.MessageContentComplex | undefined)[] = [];
17
+ async function testStandardStreaming(): Promise<void> {
18
+ const { userName, location, currentDate } = await getArgs();
19
+ const { contentParts, aggregateContent } = createContentAggregator();
20
+ _contentParts = contentParts;
21
+ const customHandlers = {
22
+ [GraphEvents.TOOL_END]: new ToolEndHandler(),
23
+ [GraphEvents.CHAT_MODEL_END]: new ModelEndHandler(),
24
+ [GraphEvents.CHAT_MODEL_STREAM]: new ChatModelStreamHandler(),
25
+ [GraphEvents.ON_RUN_STEP_COMPLETED]: {
26
+ handle: (
27
+ event: GraphEvents.ON_RUN_STEP_COMPLETED,
28
+ data: t.StreamEventData
29
+ ): void => {
30
+ console.log('====== ON_RUN_STEP_COMPLETED ======');
31
+ // console.dir(data, { depth: null });
32
+ aggregateContent({
33
+ event,
34
+ data: data as unknown as { result: t.ToolEndEvent },
35
+ });
36
+ },
37
+ },
38
+ [GraphEvents.ON_RUN_STEP]: {
39
+ handle: (
40
+ event: GraphEvents.ON_RUN_STEP,
41
+ data: t.StreamEventData
42
+ ): void => {
43
+ console.log('====== ON_RUN_STEP ======');
44
+ console.dir(data, { depth: null });
45
+ aggregateContent({ event, data: data as t.RunStep });
46
+ },
47
+ },
48
+ [GraphEvents.ON_RUN_STEP_DELTA]: {
49
+ handle: (
50
+ event: GraphEvents.ON_RUN_STEP_DELTA,
51
+ data: t.StreamEventData
52
+ ): void => {
53
+ console.log('====== ON_RUN_STEP_DELTA ======');
54
+ console.dir(data, { depth: null });
55
+ aggregateContent({ event, data: data as t.RunStepDeltaEvent });
56
+ },
57
+ },
58
+ [GraphEvents.ON_MESSAGE_DELTA]: {
59
+ handle: (
60
+ event: GraphEvents.ON_MESSAGE_DELTA,
61
+ data: t.StreamEventData
62
+ ): void => {
63
+ console.log('====== ON_MESSAGE_DELTA ======');
64
+ console.dir(data, { depth: null });
65
+ aggregateContent({ event, data: data as t.MessageDeltaEvent });
66
+ },
67
+ },
68
+ [GraphEvents.TOOL_START]: {
69
+ handle: (
70
+ _event: string,
71
+ data: t.StreamEventData,
72
+ metadata?: Record<string, unknown>
73
+ ): void => {
74
+ console.log('====== TOOL_START ======');
75
+ // console.dir(data, { depth: null });
76
+ },
77
+ },
78
+ };
79
+
80
+ const llmConfig = getLLMConfig(
81
+ Providers.ANTHROPIC
82
+ ) as t.AnthropicClientOptions & t.SharedLLMConfig;
83
+ llmConfig.model = 'claude-3-5-sonnet-latest';
84
+
85
+ const run = await Run.create<t.IState>({
86
+ runId: 'test-run-id',
87
+ graphConfig: {
88
+ type: 'standard',
89
+ llmConfig,
90
+ tools: [
91
+ {
92
+ type: 'web_search_20250305',
93
+ name: 'web_search',
94
+ max_uses: 5,
95
+ },
96
+ ],
97
+ instructions: 'You are a friendly AI assistant.',
98
+ // additional_instructions: `Always address the user by their name. The user's name is ${userName} and they are located in ${location}.`,
99
+ },
100
+ returnContent: true,
101
+ customHandlers,
102
+ });
103
+
104
+ const config = {
105
+ configurable: {
106
+ provider: Providers.ANTHROPIC,
107
+ thread_id: 'conversation-num-1',
108
+ },
109
+ streamMode: 'values',
110
+ version: 'v2' as const,
111
+ };
112
+
113
+ console.log('Test 1: Search query (search tool test)');
114
+
115
+ // const userMessage = `
116
+ // Make a search for the weather in ${location} today, which is ${currentDate}.
117
+ // Before making the search, please let me know what you're about to do, then immediately start searching without hesitation.
118
+ // Make sure to always refer to me by name, which is ${userName}.
119
+ // After giving me a thorough summary, tell me a joke about the weather forecast we went over.
120
+ // `;
121
+ // const userMessage = 'Are massage guns good?';
122
+ // const userMessage = 'What is functional programming?';
123
+ const userMessage = "Get me today's trending news.";
124
+ // const userMessage = "search recent italy earthquake volcano activity";
125
+ // const userMessage =
126
+ // "use 'Trump' as the exact search query and tell me what you find.";
127
+
128
+ conversationHistory.push(new HumanMessage(userMessage));
129
+
130
+ const inputs = {
131
+ messages: conversationHistory,
132
+ };
133
+ const finalContentParts = await run.processStream(inputs, config);
134
+ const finalMessages = run.getRunMessages();
135
+ if (finalMessages) {
136
+ conversationHistory.push(...finalMessages);
137
+ console.dir(conversationHistory, { depth: null });
138
+ }
139
+ // console.dir(finalContentParts, { depth: null });
140
+ console.log('\n\n====================\n\n');
141
+ // console.dir(contentParts, { depth: null });
142
+ }
143
+
144
+ process.on('unhandledRejection', (reason, promise) => {
145
+ console.error('Unhandled Rejection at:', promise, 'reason:', reason);
146
+ console.log('Content Parts:');
147
+ console.dir(_contentParts, { depth: null });
148
+ process.exit(1);
149
+ });
150
+
151
+ testStandardStreaming().catch((err) => {
152
+ console.error(err);
153
+ console.log('Conversation history:');
154
+ console.dir(conversationHistory, { depth: null });
155
+ console.log('Content Parts:');
156
+ console.dir(_contentParts, { depth: null });
157
+ process.exit(1);
158
+ });