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
@@ -0,0 +1,455 @@
1
+ 'use strict';
2
+
3
+ var messages = require('@langchain/core/messages');
4
+ var _enum = require('../common/enum.cjs');
5
+
6
+ /* eslint-disable @typescript-eslint/no-explicit-any */
7
+ /**
8
+ * Formats a message with media content (images, documents, videos, audios) to API payload format.
9
+ *
10
+ * @param params - The parameters for formatting.
11
+ * @returns - The formatted message.
12
+ */
13
+ const formatMediaMessage = ({ message, endpoint, mediaParts, }) => {
14
+ // Create a new object to avoid mutating the input
15
+ const result = {
16
+ ...message,
17
+ content: [],
18
+ };
19
+ if (endpoint === _enum.Providers.ANTHROPIC) {
20
+ result.content = [
21
+ ...mediaParts,
22
+ { type: _enum.ContentTypes.TEXT, text: message.content },
23
+ ];
24
+ return result;
25
+ }
26
+ result.content = [
27
+ { type: _enum.ContentTypes.TEXT, text: message.content },
28
+ ...mediaParts,
29
+ ];
30
+ return result;
31
+ };
32
+ /**
33
+ * Formats a message to OpenAI payload format based on the provided options.
34
+ *
35
+ * @param params - The parameters for formatting.
36
+ * @returns - The formatted message.
37
+ */
38
+ const formatMessage = ({ message, userName, endpoint, assistantName, langChain = false, }) => {
39
+ // eslint-disable-next-line prefer-const
40
+ let { role: _role, _name, sender, text, content: _content, lc_id } = message;
41
+ if (lc_id && lc_id[2] && !langChain) {
42
+ const roleMapping = {
43
+ SystemMessage: 'system',
44
+ HumanMessage: 'user',
45
+ AIMessage: 'assistant',
46
+ };
47
+ _role = roleMapping[lc_id[2]] || _role;
48
+ }
49
+ const role = _role ??
50
+ (sender != null && sender && sender.toLowerCase() === 'user'
51
+ ? 'user'
52
+ : 'assistant');
53
+ const content = _content ?? text ?? '';
54
+ const formattedMessage = {
55
+ role,
56
+ content,
57
+ };
58
+ // Set name fields first
59
+ if (_name != null && _name) {
60
+ formattedMessage.name = _name;
61
+ }
62
+ if (userName != null && userName && formattedMessage.role === 'user') {
63
+ formattedMessage.name = userName;
64
+ }
65
+ if (assistantName != null &&
66
+ assistantName &&
67
+ formattedMessage.role === 'assistant') {
68
+ formattedMessage.name = assistantName;
69
+ }
70
+ if (formattedMessage.name != null && formattedMessage.name) {
71
+ // Conform to API regex: ^[a-zA-Z0-9_-]{1,64}$
72
+ // https://community.openai.com/t/the-format-of-the-name-field-in-the-documentation-is-incorrect/175684/2
73
+ formattedMessage.name = formattedMessage.name.replace(/[^a-zA-Z0-9_-]/g, '_');
74
+ if (formattedMessage.name.length > 64) {
75
+ formattedMessage.name = formattedMessage.name.substring(0, 64);
76
+ }
77
+ }
78
+ const { image_urls, documents, videos, audios } = message;
79
+ const mediaParts = [];
80
+ if (Array.isArray(documents) && documents.length > 0) {
81
+ mediaParts.push(...documents);
82
+ }
83
+ if (Array.isArray(videos) && videos.length > 0) {
84
+ mediaParts.push(...videos);
85
+ }
86
+ if (Array.isArray(audios) && audios.length > 0) {
87
+ mediaParts.push(...audios);
88
+ }
89
+ if (Array.isArray(image_urls) && image_urls.length > 0) {
90
+ mediaParts.push(...image_urls);
91
+ }
92
+ if (mediaParts.length > 0 && role === 'user') {
93
+ const mediaMessage = formatMediaMessage({
94
+ message: {
95
+ ...formattedMessage,
96
+ content: typeof formattedMessage.content === 'string'
97
+ ? formattedMessage.content
98
+ : '',
99
+ },
100
+ mediaParts,
101
+ endpoint,
102
+ });
103
+ if (!langChain) {
104
+ return mediaMessage;
105
+ }
106
+ return new messages.HumanMessage(mediaMessage);
107
+ }
108
+ if (!langChain) {
109
+ return formattedMessage;
110
+ }
111
+ if (role === 'user') {
112
+ return new messages.HumanMessage(formattedMessage);
113
+ }
114
+ else if (role === 'assistant') {
115
+ return new messages.AIMessage(formattedMessage);
116
+ }
117
+ else {
118
+ return new messages.SystemMessage(formattedMessage);
119
+ }
120
+ };
121
+ /**
122
+ * Formats an array of messages for LangChain.
123
+ *
124
+ * @param messages - The array of messages to format.
125
+ * @param formatOptions - The options for formatting each message.
126
+ * @returns - The array of formatted LangChain messages.
127
+ */
128
+ const formatLangChainMessages = (messages, formatOptions) => {
129
+ return messages.map((msg) => {
130
+ const formatted = formatMessage({
131
+ ...formatOptions,
132
+ message: msg,
133
+ langChain: true,
134
+ });
135
+ return formatted;
136
+ });
137
+ };
138
+ /**
139
+ * Formats a LangChain message object by merging properties from `lc_kwargs` or `kwargs` and `additional_kwargs`.
140
+ *
141
+ * @param message - The message object to format.
142
+ * @returns - The formatted LangChain message.
143
+ */
144
+ const formatFromLangChain = (message) => {
145
+ const kwargs = message.lc_kwargs ?? message.kwargs ?? {};
146
+ const { additional_kwargs = {}, ...message_kwargs } = kwargs;
147
+ return {
148
+ ...message_kwargs,
149
+ ...additional_kwargs,
150
+ };
151
+ };
152
+ /**
153
+ * Helper function to format an assistant message
154
+ * @param message The message to format
155
+ * @returns Array of formatted messages
156
+ */
157
+ function formatAssistantMessage(message) {
158
+ const formattedMessages = [];
159
+ let currentContent = [];
160
+ let lastAIMessage = null;
161
+ let hasReasoning = false;
162
+ if (Array.isArray(message.content)) {
163
+ for (const part of message.content) {
164
+ if (part.type === _enum.ContentTypes.TEXT && part.tool_call_ids) {
165
+ /*
166
+ If there's pending content, it needs to be aggregated as a single string to prepare for tool calls.
167
+ For Anthropic models, the "tool_calls" field on a message is only respected if content is a string.
168
+ */
169
+ if (currentContent.length > 0) {
170
+ let content = currentContent.reduce((acc, curr) => {
171
+ if (curr.type === _enum.ContentTypes.TEXT) {
172
+ return `${acc}${curr[_enum.ContentTypes.TEXT] || ''}\n`;
173
+ }
174
+ return acc;
175
+ }, '');
176
+ content =
177
+ `${content}\n${part[_enum.ContentTypes.TEXT] ?? part.text ?? ''}`.trim();
178
+ lastAIMessage = new messages.AIMessage({ content });
179
+ formattedMessages.push(lastAIMessage);
180
+ currentContent = [];
181
+ continue;
182
+ }
183
+ // Create a new AIMessage with this text and prepare for tool calls
184
+ lastAIMessage = new messages.AIMessage({
185
+ content: part.text || '',
186
+ });
187
+ formattedMessages.push(lastAIMessage);
188
+ }
189
+ else if (part.type === _enum.ContentTypes.TOOL_CALL) {
190
+ if (!lastAIMessage) {
191
+ // "Heal" the payload by creating an AIMessage to precede the tool call
192
+ lastAIMessage = new messages.AIMessage({ content: '' });
193
+ formattedMessages.push(lastAIMessage);
194
+ }
195
+ // Note: `tool_calls` list is defined when constructed by `AIMessage` class, and outputs should be excluded from it
196
+ const { output, args: _args, ..._tool_call } = part.tool_call;
197
+ const tool_call = _tool_call;
198
+ // TODO: investigate; args as dictionary may need to be providers-or-tool-specific
199
+ let args = _args;
200
+ try {
201
+ if (typeof _args === 'string') {
202
+ args = JSON.parse(_args);
203
+ }
204
+ }
205
+ catch {
206
+ if (typeof _args === 'string') {
207
+ args = { input: _args };
208
+ }
209
+ }
210
+ tool_call.args = args;
211
+ if (!lastAIMessage.tool_calls) {
212
+ lastAIMessage.tool_calls = [];
213
+ }
214
+ lastAIMessage.tool_calls.push(tool_call);
215
+ formattedMessages.push(new messages.ToolMessage({
216
+ tool_call_id: tool_call.id ?? '',
217
+ name: tool_call.name,
218
+ content: output || '',
219
+ }));
220
+ }
221
+ else if (part.type === _enum.ContentTypes.THINK) {
222
+ hasReasoning = true;
223
+ continue;
224
+ }
225
+ else if (part.type === _enum.ContentTypes.ERROR ||
226
+ part.type === _enum.ContentTypes.AGENT_UPDATE) {
227
+ continue;
228
+ }
229
+ else {
230
+ currentContent.push(part);
231
+ }
232
+ }
233
+ }
234
+ if (hasReasoning && currentContent.length > 0) {
235
+ const content = currentContent
236
+ .reduce((acc, curr) => {
237
+ if (curr.type === _enum.ContentTypes.TEXT) {
238
+ return `${acc}${curr[_enum.ContentTypes.TEXT] || ''}\n`;
239
+ }
240
+ return acc;
241
+ }, '')
242
+ .trim();
243
+ if (content) {
244
+ formattedMessages.push(new messages.AIMessage({ content }));
245
+ }
246
+ }
247
+ else if (currentContent.length > 0) {
248
+ formattedMessages.push(new messages.AIMessage({ content: currentContent }));
249
+ }
250
+ return formattedMessages;
251
+ }
252
+ /**
253
+ * Formats an array of messages for LangChain, handling tool calls and creating ToolMessage instances.
254
+ *
255
+ * @param payload - The array of messages to format.
256
+ * @param indexTokenCountMap - Optional map of message indices to token counts.
257
+ * @param tools - Optional set of tool names that are allowed in the request.
258
+ * @returns - Object containing formatted messages and updated indexTokenCountMap if provided.
259
+ */
260
+ const formatAgentMessages = (payload, indexTokenCountMap, tools) => {
261
+ const messages$1 = [];
262
+ // If indexTokenCountMap is provided, create a new map to track the updated indices
263
+ const updatedIndexTokenCountMap = {};
264
+ // Keep track of the mapping from original payload indices to result indices
265
+ const indexMapping = {};
266
+ // Process messages with tool conversion if tools set is provided
267
+ for (let i = 0; i < payload.length; i++) {
268
+ const message = payload[i];
269
+ // Q: Store the current length of messages to track where this payload message starts in the result?
270
+ // const startIndex = messages.length;
271
+ if (typeof message.content === 'string') {
272
+ message.content = [
273
+ { type: _enum.ContentTypes.TEXT, [_enum.ContentTypes.TEXT]: message.content },
274
+ ];
275
+ }
276
+ if (message.role !== 'assistant') {
277
+ messages$1.push(formatMessage({
278
+ message: message,
279
+ langChain: true,
280
+ }));
281
+ // Update the index mapping for this message
282
+ indexMapping[i] = [messages$1.length - 1];
283
+ continue;
284
+ }
285
+ // For assistant messages, track the starting index before processing
286
+ const startMessageIndex = messages$1.length;
287
+ // If tools set is provided, we need to check if we need to convert tool messages to a string
288
+ if (tools) {
289
+ // First, check if this message contains tool calls
290
+ let hasToolCalls = false;
291
+ let hasInvalidTool = false;
292
+ const content = message.content;
293
+ if (content && Array.isArray(content)) {
294
+ for (const part of content) {
295
+ if (part.type === _enum.ContentTypes.TOOL_CALL) {
296
+ hasToolCalls = true;
297
+ if (tools.size === 0) {
298
+ hasInvalidTool = true;
299
+ break;
300
+ }
301
+ const toolName = part.tool_call.name;
302
+ if (!tools.has(toolName)) {
303
+ hasInvalidTool = true;
304
+ }
305
+ }
306
+ }
307
+ }
308
+ // If this message has tool calls and at least one is invalid, we need to convert it
309
+ if (hasToolCalls && hasInvalidTool) {
310
+ // We need to collect all related messages (this message and any subsequent tool messages)
311
+ const toolSequence = [];
312
+ let sequenceEndIndex = i;
313
+ // Process the current assistant message to get the AIMessage with tool calls
314
+ const formattedMessages = formatAssistantMessage(message);
315
+ toolSequence.push(...formattedMessages);
316
+ // Look ahead for any subsequent assistant messages that might be part of this tool sequence
317
+ let j = i + 1;
318
+ while (j < payload.length && payload[j].role === 'assistant') {
319
+ // Check if this is a continuation of the tool sequence
320
+ let isToolResponse = false;
321
+ const content = payload[j].content;
322
+ if (content && Array.isArray(content)) {
323
+ for (const part of content) {
324
+ if (part.type === _enum.ContentTypes.TOOL_CALL) {
325
+ isToolResponse = true;
326
+ break;
327
+ }
328
+ }
329
+ }
330
+ if (isToolResponse) {
331
+ // This is part of the tool sequence, add it
332
+ const nextMessages = formatAssistantMessage(payload[j]);
333
+ toolSequence.push(...nextMessages);
334
+ sequenceEndIndex = j;
335
+ j++;
336
+ }
337
+ else {
338
+ // This is not part of the tool sequence, stop looking
339
+ break;
340
+ }
341
+ }
342
+ // Convert the sequence to a string
343
+ const bufferString = messages.getBufferString(toolSequence);
344
+ messages$1.push(new messages.AIMessage({ content: bufferString }));
345
+ // Skip the messages we've already processed
346
+ i = sequenceEndIndex;
347
+ // Update the index mapping for this sequence
348
+ const resultIndices = [messages$1.length - 1];
349
+ for (let k = i; k >= i && k <= sequenceEndIndex; k++) {
350
+ indexMapping[k] = resultIndices;
351
+ }
352
+ continue;
353
+ }
354
+ }
355
+ // Process the assistant message using the helper function
356
+ const formattedMessages = formatAssistantMessage(message);
357
+ messages$1.push(...formattedMessages);
358
+ // Update the index mapping for this assistant message
359
+ // Store all indices that were created from this original message
360
+ const endMessageIndex = messages$1.length;
361
+ const resultIndices = [];
362
+ for (let j = startMessageIndex; j < endMessageIndex; j++) {
363
+ resultIndices.push(j);
364
+ }
365
+ indexMapping[i] = resultIndices;
366
+ }
367
+ // Update the token count map if it was provided
368
+ if (indexTokenCountMap) {
369
+ for (let originalIndex = 0; originalIndex < payload.length; originalIndex++) {
370
+ const resultIndices = indexMapping[originalIndex] || [];
371
+ const tokenCount = indexTokenCountMap[originalIndex];
372
+ if (tokenCount !== undefined) {
373
+ if (resultIndices.length === 1) {
374
+ // Simple 1:1 mapping
375
+ updatedIndexTokenCountMap[resultIndices[0]] = tokenCount;
376
+ }
377
+ else if (resultIndices.length > 1) {
378
+ // If one message was split into multiple, distribute the token count
379
+ // This is a simplification - in reality, you might want a more sophisticated distribution
380
+ const countPerMessage = Math.floor(tokenCount / resultIndices.length);
381
+ resultIndices.forEach((resultIndex, idx) => {
382
+ if (idx === resultIndices.length - 1) {
383
+ // Give any remainder to the last message
384
+ updatedIndexTokenCountMap[resultIndex] =
385
+ tokenCount - countPerMessage * (resultIndices.length - 1);
386
+ }
387
+ else {
388
+ updatedIndexTokenCountMap[resultIndex] = countPerMessage;
389
+ }
390
+ });
391
+ }
392
+ }
393
+ }
394
+ }
395
+ return {
396
+ messages: messages$1,
397
+ indexTokenCountMap: indexTokenCountMap
398
+ ? updatedIndexTokenCountMap
399
+ : undefined,
400
+ };
401
+ };
402
+ /**
403
+ * Formats an array of messages for LangChain, making sure all content fields are strings
404
+ * @param payload - The array of messages to format.
405
+ * @returns - The array of formatted LangChain messages, including ToolMessages for tool calls.
406
+ */
407
+ const formatContentStrings = (payload) => {
408
+ // Create a copy of the payload to avoid modifying the original
409
+ const result = [...payload];
410
+ for (const message of result) {
411
+ if (typeof message.content === 'string') {
412
+ continue;
413
+ }
414
+ if (!Array.isArray(message.content)) {
415
+ continue;
416
+ }
417
+ // Reduce text types to a single string, ignore all other types
418
+ const content = message.content.reduce((acc, curr) => {
419
+ if (curr.type === _enum.ContentTypes.TEXT) {
420
+ return `${acc}${curr[_enum.ContentTypes.TEXT] || ''}\n`;
421
+ }
422
+ return acc;
423
+ }, '');
424
+ message.content = content.trim();
425
+ }
426
+ return result;
427
+ };
428
+ /**
429
+ * Adds a value at key 0 for system messages and shifts all key indices by one in an indexTokenCountMap.
430
+ * This is useful when adding a system message at the beginning of a conversation.
431
+ *
432
+ * @param indexTokenCountMap - The original map of message indices to token counts
433
+ * @param instructionsTokenCount - The token count for the system message to add at index 0
434
+ * @returns A new map with the system message at index 0 and all other indices shifted by 1
435
+ */
436
+ function shiftIndexTokenCountMap(indexTokenCountMap, instructionsTokenCount) {
437
+ // Create a new map to avoid modifying the original
438
+ const shiftedMap = {};
439
+ shiftedMap[0] = instructionsTokenCount;
440
+ // Shift all existing indices by 1
441
+ for (const [indexStr, tokenCount] of Object.entries(indexTokenCountMap)) {
442
+ const index = Number(indexStr);
443
+ shiftedMap[index + 1] = tokenCount;
444
+ }
445
+ return shiftedMap;
446
+ }
447
+
448
+ exports.formatAgentMessages = formatAgentMessages;
449
+ exports.formatContentStrings = formatContentStrings;
450
+ exports.formatFromLangChain = formatFromLangChain;
451
+ exports.formatLangChainMessages = formatLangChainMessages;
452
+ exports.formatMediaMessage = formatMediaMessage;
453
+ exports.formatMessage = formatMessage;
454
+ exports.shiftIndexTokenCountMap = shiftIndexTokenCountMap;
455
+ //# sourceMappingURL=format.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"format.cjs","sources":["../../../src/messages/format.ts"],"sourcesContent":["/* eslint-disable @typescript-eslint/no-explicit-any */\r\nimport {\r\n AIMessage,\r\n ToolMessage,\r\n BaseMessage,\r\n HumanMessage,\r\n SystemMessage,\r\n getBufferString,\r\n} from '@langchain/core/messages';\r\nimport type { MessageContentImageUrl } from '@langchain/core/messages';\r\nimport type { ToolCall } from '@langchain/core/messages/tool';\r\nimport type {\r\n MessageContentComplex,\r\n ToolCallPart,\r\n TPayload,\r\n TMessage,\r\n} from '@/types';\r\nimport { Providers, ContentTypes } from '@/common';\r\n\r\ninterface MediaMessageParams {\r\n message: {\r\n role: string;\r\n content: string;\r\n name?: string;\r\n [key: string]: any;\r\n };\r\n mediaParts: MessageContentComplex[];\r\n endpoint?: Providers;\r\n}\r\n\r\n/**\r\n * Formats a message with media content (images, documents, videos, audios) to API payload format.\r\n *\r\n * @param params - The parameters for formatting.\r\n * @returns - The formatted message.\r\n */\r\nexport const formatMediaMessage = ({\r\n message,\r\n endpoint,\r\n mediaParts,\r\n}: MediaMessageParams): {\r\n role: string;\r\n content: MessageContentComplex[];\r\n name?: string;\r\n [key: string]: any;\r\n} => {\r\n // Create a new object to avoid mutating the input\r\n const result: {\r\n role: string;\r\n content: MessageContentComplex[];\r\n name?: string;\r\n [key: string]: any;\r\n } = {\r\n ...message,\r\n content: [] as MessageContentComplex[],\r\n };\r\n\r\n if (endpoint === Providers.ANTHROPIC) {\r\n result.content = [\r\n ...mediaParts,\r\n { type: ContentTypes.TEXT, text: message.content },\r\n ] as MessageContentComplex[];\r\n return result;\r\n }\r\n\r\n result.content = [\r\n { type: ContentTypes.TEXT, text: message.content },\r\n ...mediaParts,\r\n ] as MessageContentComplex[];\r\n\r\n return result;\r\n};\r\n\r\ninterface MessageInput {\r\n role?: string;\r\n _name?: string;\r\n sender?: string;\r\n text?: string;\r\n content?: string | MessageContentComplex[];\r\n image_urls?: MessageContentImageUrl[];\r\n documents?: MessageContentComplex[];\r\n videos?: MessageContentComplex[];\r\n audios?: MessageContentComplex[];\r\n lc_id?: string[];\r\n [key: string]: any;\r\n}\r\n\r\ninterface FormatMessageParams {\r\n message: MessageInput;\r\n userName?: string;\r\n assistantName?: string;\r\n endpoint?: Providers;\r\n langChain?: boolean;\r\n}\r\n\r\ninterface FormattedMessage {\r\n role: string;\r\n content: string | MessageContentComplex[];\r\n name?: string;\r\n [key: string]: any;\r\n}\r\n\r\n/**\r\n * Formats a message to OpenAI payload format based on the provided options.\r\n *\r\n * @param params - The parameters for formatting.\r\n * @returns - The formatted message.\r\n */\r\nexport const formatMessage = ({\r\n message,\r\n userName,\r\n endpoint,\r\n assistantName,\r\n langChain = false,\r\n}: FormatMessageParams):\r\n | FormattedMessage\r\n | HumanMessage\r\n | AIMessage\r\n | SystemMessage => {\r\n // eslint-disable-next-line prefer-const\r\n let { role: _role, _name, sender, text, content: _content, lc_id } = message;\r\n if (lc_id && lc_id[2] && !langChain) {\r\n const roleMapping: Record<string, string> = {\r\n SystemMessage: 'system',\r\n HumanMessage: 'user',\r\n AIMessage: 'assistant',\r\n };\r\n _role = roleMapping[lc_id[2]] || _role;\r\n }\r\n const role =\r\n _role ??\r\n (sender != null && sender && sender.toLowerCase() === 'user'\r\n ? 'user'\r\n : 'assistant');\r\n const content = _content ?? text ?? '';\r\n const formattedMessage: FormattedMessage = {\r\n role,\r\n content,\r\n };\r\n\r\n // Set name fields first\r\n if (_name != null && _name) {\r\n formattedMessage.name = _name;\r\n }\r\n\r\n if (userName != null && userName && formattedMessage.role === 'user') {\r\n formattedMessage.name = userName;\r\n }\r\n\r\n if (\r\n assistantName != null &&\r\n assistantName &&\r\n formattedMessage.role === 'assistant'\r\n ) {\r\n formattedMessage.name = assistantName;\r\n }\r\n\r\n if (formattedMessage.name != null && formattedMessage.name) {\r\n // Conform to API regex: ^[a-zA-Z0-9_-]{1,64}$\r\n // https://community.openai.com/t/the-format-of-the-name-field-in-the-documentation-is-incorrect/175684/2\r\n formattedMessage.name = formattedMessage.name.replace(\r\n /[^a-zA-Z0-9_-]/g,\r\n '_'\r\n );\r\n\r\n if (formattedMessage.name.length > 64) {\r\n formattedMessage.name = formattedMessage.name.substring(0, 64);\r\n }\r\n }\r\n\r\n const { image_urls, documents, videos, audios } = message;\r\n const mediaParts: MessageContentComplex[] = [];\r\n\r\n if (Array.isArray(documents) && documents.length > 0) {\r\n mediaParts.push(...documents);\r\n }\r\n\r\n if (Array.isArray(videos) && videos.length > 0) {\r\n mediaParts.push(...videos);\r\n }\r\n\r\n if (Array.isArray(audios) && audios.length > 0) {\r\n mediaParts.push(...audios);\r\n }\r\n\r\n if (Array.isArray(image_urls) && image_urls.length > 0) {\r\n mediaParts.push(...image_urls);\r\n }\r\n\r\n if (mediaParts.length > 0 && role === 'user') {\r\n const mediaMessage = formatMediaMessage({\r\n message: {\r\n ...formattedMessage,\r\n content:\r\n typeof formattedMessage.content === 'string'\r\n ? formattedMessage.content\r\n : '',\r\n },\r\n mediaParts,\r\n endpoint,\r\n });\r\n\r\n if (!langChain) {\r\n return mediaMessage;\r\n }\r\n\r\n return new HumanMessage(mediaMessage);\r\n }\r\n\r\n if (!langChain) {\r\n return formattedMessage;\r\n }\r\n\r\n if (role === 'user') {\r\n return new HumanMessage(formattedMessage);\r\n } else if (role === 'assistant') {\r\n return new AIMessage(formattedMessage);\r\n } else {\r\n return new SystemMessage(formattedMessage);\r\n }\r\n};\r\n\r\n/**\r\n * Formats an array of messages for LangChain.\r\n *\r\n * @param messages - The array of messages to format.\r\n * @param formatOptions - The options for formatting each message.\r\n * @returns - The array of formatted LangChain messages.\r\n */\r\nexport const formatLangChainMessages = (\r\n messages: Array<MessageInput>,\r\n formatOptions: Omit<FormatMessageParams, 'message' | 'langChain'>\r\n): Array<HumanMessage | AIMessage | SystemMessage> => {\r\n return messages.map((msg) => {\r\n const formatted = formatMessage({\r\n ...formatOptions,\r\n message: msg,\r\n langChain: true,\r\n });\r\n return formatted as HumanMessage | AIMessage | SystemMessage;\r\n });\r\n};\r\n\r\ninterface LangChainMessage {\r\n lc_kwargs?: {\r\n additional_kwargs?: Record<string, any>;\r\n [key: string]: any;\r\n };\r\n kwargs?: {\r\n additional_kwargs?: Record<string, any>;\r\n [key: string]: any;\r\n };\r\n [key: string]: any;\r\n}\r\n\r\n/**\r\n * Formats a LangChain message object by merging properties from `lc_kwargs` or `kwargs` and `additional_kwargs`.\r\n *\r\n * @param message - The message object to format.\r\n * @returns - The formatted LangChain message.\r\n */\r\nexport const formatFromLangChain = (\r\n message: LangChainMessage\r\n): Record<string, any> => {\r\n const kwargs = message.lc_kwargs ?? message.kwargs ?? {};\r\n const { additional_kwargs = {}, ...message_kwargs } = kwargs;\r\n return {\r\n ...message_kwargs,\r\n ...additional_kwargs,\r\n };\r\n};\r\n\r\n/**\r\n * Helper function to format an assistant message\r\n * @param message The message to format\r\n * @returns Array of formatted messages\r\n */\r\nfunction formatAssistantMessage(\r\n message: Partial<TMessage>\r\n): Array<AIMessage | ToolMessage> {\r\n const formattedMessages: Array<AIMessage | ToolMessage> = [];\r\n let currentContent: MessageContentComplex[] = [];\r\n let lastAIMessage: AIMessage | null = null;\r\n let hasReasoning = false;\r\n\r\n if (Array.isArray(message.content)) {\r\n for (const part of message.content) {\r\n if (part.type === ContentTypes.TEXT && part.tool_call_ids) {\r\n /*\r\n If there's pending content, it needs to be aggregated as a single string to prepare for tool calls.\r\n For Anthropic models, the \"tool_calls\" field on a message is only respected if content is a string.\r\n */\r\n if (currentContent.length > 0) {\r\n let content = currentContent.reduce((acc, curr) => {\r\n if (curr.type === ContentTypes.TEXT) {\r\n return `${acc}${curr[ContentTypes.TEXT] || ''}\\n`;\r\n }\r\n return acc;\r\n }, '');\r\n content =\r\n `${content}\\n${part[ContentTypes.TEXT] ?? part.text ?? ''}`.trim();\r\n lastAIMessage = new AIMessage({ content });\r\n formattedMessages.push(lastAIMessage);\r\n currentContent = [];\r\n continue;\r\n }\r\n // Create a new AIMessage with this text and prepare for tool calls\r\n lastAIMessage = new AIMessage({\r\n content: part.text || '',\r\n });\r\n formattedMessages.push(lastAIMessage);\r\n } else if (part.type === ContentTypes.TOOL_CALL) {\r\n if (!lastAIMessage) {\r\n // \"Heal\" the payload by creating an AIMessage to precede the tool call\r\n lastAIMessage = new AIMessage({ content: '' });\r\n formattedMessages.push(lastAIMessage);\r\n }\r\n\r\n // Note: `tool_calls` list is defined when constructed by `AIMessage` class, and outputs should be excluded from it\r\n const {\r\n output,\r\n args: _args,\r\n ..._tool_call\r\n } = part.tool_call as ToolCallPart;\r\n const tool_call: ToolCallPart = _tool_call;\r\n // TODO: investigate; args as dictionary may need to be providers-or-tool-specific\r\n let args: any = _args;\r\n try {\r\n if (typeof _args === 'string') {\r\n args = JSON.parse(_args);\r\n }\r\n } catch {\r\n if (typeof _args === 'string') {\r\n args = { input: _args };\r\n }\r\n }\r\n\r\n tool_call.args = args;\r\n if (!lastAIMessage.tool_calls) {\r\n lastAIMessage.tool_calls = [];\r\n }\r\n lastAIMessage.tool_calls.push(tool_call as ToolCall);\r\n\r\n formattedMessages.push(\r\n new ToolMessage({\r\n tool_call_id: tool_call.id ?? '',\r\n name: tool_call.name,\r\n content: output || '',\r\n })\r\n );\r\n } else if (part.type === ContentTypes.THINK) {\r\n hasReasoning = true;\r\n continue;\r\n } else if (\r\n part.type === ContentTypes.ERROR ||\r\n part.type === ContentTypes.AGENT_UPDATE\r\n ) {\r\n continue;\r\n } else {\r\n currentContent.push(part);\r\n }\r\n }\r\n }\r\n\r\n if (hasReasoning && currentContent.length > 0) {\r\n const content = currentContent\r\n .reduce((acc, curr) => {\r\n if (curr.type === ContentTypes.TEXT) {\r\n return `${acc}${curr[ContentTypes.TEXT] || ''}\\n`;\r\n }\r\n return acc;\r\n }, '')\r\n .trim();\r\n\r\n if (content) {\r\n formattedMessages.push(new AIMessage({ content }));\r\n }\r\n } else if (currentContent.length > 0) {\r\n formattedMessages.push(new AIMessage({ content: currentContent }));\r\n }\r\n\r\n return formattedMessages;\r\n}\r\n\r\n/**\r\n * Formats an array of messages for LangChain, handling tool calls and creating ToolMessage instances.\r\n *\r\n * @param payload - The array of messages to format.\r\n * @param indexTokenCountMap - Optional map of message indices to token counts.\r\n * @param tools - Optional set of tool names that are allowed in the request.\r\n * @returns - Object containing formatted messages and updated indexTokenCountMap if provided.\r\n */\r\nexport const formatAgentMessages = (\r\n payload: TPayload,\r\n indexTokenCountMap?: Record<number, number>,\r\n tools?: Set<string>\r\n): {\r\n messages: Array<HumanMessage | AIMessage | SystemMessage | ToolMessage>;\r\n indexTokenCountMap?: Record<number, number>;\r\n} => {\r\n const messages: Array<\r\n HumanMessage | AIMessage | SystemMessage | ToolMessage\r\n > = [];\r\n // If indexTokenCountMap is provided, create a new map to track the updated indices\r\n const updatedIndexTokenCountMap: Record<number, number> = {};\r\n // Keep track of the mapping from original payload indices to result indices\r\n const indexMapping: Record<number, number[]> = {};\r\n\r\n // Process messages with tool conversion if tools set is provided\r\n for (let i = 0; i < payload.length; i++) {\r\n const message = payload[i];\r\n // Q: Store the current length of messages to track where this payload message starts in the result?\r\n // const startIndex = messages.length;\r\n if (typeof message.content === 'string') {\r\n message.content = [\r\n { type: ContentTypes.TEXT, [ContentTypes.TEXT]: message.content },\r\n ];\r\n }\r\n if (message.role !== 'assistant') {\r\n messages.push(\r\n formatMessage({\r\n message: message as MessageInput,\r\n langChain: true,\r\n }) as HumanMessage | AIMessage | SystemMessage\r\n );\r\n\r\n // Update the index mapping for this message\r\n indexMapping[i] = [messages.length - 1];\r\n continue;\r\n }\r\n\r\n // For assistant messages, track the starting index before processing\r\n const startMessageIndex = messages.length;\r\n\r\n // If tools set is provided, we need to check if we need to convert tool messages to a string\r\n if (tools) {\r\n // First, check if this message contains tool calls\r\n let hasToolCalls = false;\r\n let hasInvalidTool = false;\r\n const toolNames: string[] = [];\r\n\r\n const content = message.content;\r\n if (content && Array.isArray(content)) {\r\n for (const part of content) {\r\n if (part.type === ContentTypes.TOOL_CALL) {\r\n hasToolCalls = true;\r\n if (tools.size === 0) {\r\n hasInvalidTool = true;\r\n break;\r\n }\r\n const toolName = part.tool_call.name;\r\n toolNames.push(toolName);\r\n if (!tools.has(toolName)) {\r\n hasInvalidTool = true;\r\n }\r\n }\r\n }\r\n }\r\n\r\n // If this message has tool calls and at least one is invalid, we need to convert it\r\n if (hasToolCalls && hasInvalidTool) {\r\n // We need to collect all related messages (this message and any subsequent tool messages)\r\n const toolSequence: BaseMessage[] = [];\r\n let sequenceEndIndex = i;\r\n\r\n // Process the current assistant message to get the AIMessage with tool calls\r\n const formattedMessages = formatAssistantMessage(message);\r\n toolSequence.push(...formattedMessages);\r\n\r\n // Look ahead for any subsequent assistant messages that might be part of this tool sequence\r\n let j = i + 1;\r\n while (j < payload.length && payload[j].role === 'assistant') {\r\n // Check if this is a continuation of the tool sequence\r\n let isToolResponse = false;\r\n const content = payload[j].content;\r\n if (content && Array.isArray(content)) {\r\n for (const part of content) {\r\n if (part.type === ContentTypes.TOOL_CALL) {\r\n isToolResponse = true;\r\n break;\r\n }\r\n }\r\n }\r\n\r\n if (isToolResponse) {\r\n // This is part of the tool sequence, add it\r\n const nextMessages = formatAssistantMessage(payload[j]);\r\n toolSequence.push(...nextMessages);\r\n sequenceEndIndex = j;\r\n j++;\r\n } else {\r\n // This is not part of the tool sequence, stop looking\r\n break;\r\n }\r\n }\r\n\r\n // Convert the sequence to a string\r\n const bufferString = getBufferString(toolSequence);\r\n messages.push(new AIMessage({ content: bufferString }));\r\n\r\n // Skip the messages we've already processed\r\n i = sequenceEndIndex;\r\n\r\n // Update the index mapping for this sequence\r\n const resultIndices = [messages.length - 1];\r\n for (let k = i; k >= i && k <= sequenceEndIndex; k++) {\r\n indexMapping[k] = resultIndices;\r\n }\r\n\r\n continue;\r\n }\r\n }\r\n\r\n // Process the assistant message using the helper function\r\n const formattedMessages = formatAssistantMessage(message);\r\n messages.push(...formattedMessages);\r\n\r\n // Update the index mapping for this assistant message\r\n // Store all indices that were created from this original message\r\n const endMessageIndex = messages.length;\r\n const resultIndices = [];\r\n for (let j = startMessageIndex; j < endMessageIndex; j++) {\r\n resultIndices.push(j);\r\n }\r\n indexMapping[i] = resultIndices;\r\n }\r\n\r\n // Update the token count map if it was provided\r\n if (indexTokenCountMap) {\r\n for (\r\n let originalIndex = 0;\r\n originalIndex < payload.length;\r\n originalIndex++\r\n ) {\r\n const resultIndices = indexMapping[originalIndex] || [];\r\n const tokenCount = indexTokenCountMap[originalIndex];\r\n\r\n if (tokenCount !== undefined) {\r\n if (resultIndices.length === 1) {\r\n // Simple 1:1 mapping\r\n updatedIndexTokenCountMap[resultIndices[0]] = tokenCount;\r\n } else if (resultIndices.length > 1) {\r\n // If one message was split into multiple, distribute the token count\r\n // This is a simplification - in reality, you might want a more sophisticated distribution\r\n const countPerMessage = Math.floor(tokenCount / resultIndices.length);\r\n resultIndices.forEach((resultIndex, idx) => {\r\n if (idx === resultIndices.length - 1) {\r\n // Give any remainder to the last message\r\n updatedIndexTokenCountMap[resultIndex] =\r\n tokenCount - countPerMessage * (resultIndices.length - 1);\r\n } else {\r\n updatedIndexTokenCountMap[resultIndex] = countPerMessage;\r\n }\r\n });\r\n }\r\n }\r\n }\r\n }\r\n\r\n return {\r\n messages,\r\n indexTokenCountMap: indexTokenCountMap\r\n ? updatedIndexTokenCountMap\r\n : undefined,\r\n };\r\n};\r\n\r\n/**\r\n * Formats an array of messages for LangChain, making sure all content fields are strings\r\n * @param payload - The array of messages to format.\r\n * @returns - The array of formatted LangChain messages, including ToolMessages for tool calls.\r\n */\r\nexport const formatContentStrings = (\r\n payload: Array<BaseMessage>\r\n): Array<BaseMessage> => {\r\n // Create a copy of the payload to avoid modifying the original\r\n const result = [...payload];\r\n\r\n for (const message of result) {\r\n if (typeof message.content === 'string') {\r\n continue;\r\n }\r\n\r\n if (!Array.isArray(message.content)) {\r\n continue;\r\n }\r\n\r\n // Reduce text types to a single string, ignore all other types\r\n const content = message.content.reduce((acc, curr) => {\r\n if (curr.type === ContentTypes.TEXT) {\r\n return `${acc}${curr[ContentTypes.TEXT] || ''}\\n`;\r\n }\r\n return acc;\r\n }, '');\r\n\r\n message.content = content.trim();\r\n }\r\n\r\n return result;\r\n};\r\n\r\n/**\r\n * Adds a value at key 0 for system messages and shifts all key indices by one in an indexTokenCountMap.\r\n * This is useful when adding a system message at the beginning of a conversation.\r\n *\r\n * @param indexTokenCountMap - The original map of message indices to token counts\r\n * @param instructionsTokenCount - The token count for the system message to add at index 0\r\n * @returns A new map with the system message at index 0 and all other indices shifted by 1\r\n */\r\nexport function shiftIndexTokenCountMap(\r\n indexTokenCountMap: Record<number, number>,\r\n instructionsTokenCount: number\r\n): Record<number, number> {\r\n // Create a new map to avoid modifying the original\r\n const shiftedMap: Record<number, number> = {};\r\n shiftedMap[0] = instructionsTokenCount;\r\n\r\n // Shift all existing indices by 1\r\n for (const [indexStr, tokenCount] of Object.entries(indexTokenCountMap)) {\r\n const index = Number(indexStr);\r\n shiftedMap[index + 1] = tokenCount;\r\n }\r\n\r\n return shiftedMap;\r\n}\r\n"],"names":["Providers","ContentTypes","HumanMessage","AIMessage","SystemMessage","ToolMessage","messages","getBufferString"],"mappings":"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"}
@@ -0,0 +1,23 @@
1
+ 'use strict';
2
+
3
+ var nanoid = require('nanoid');
4
+
5
+ // src/stream.ts
6
+ const getMessageId = (stepKey, graph, returnExistingId = false) => {
7
+ const messageId = graph.messageIdsByStepKey.get(stepKey);
8
+ if (messageId != null && messageId) {
9
+ return returnExistingId ? messageId : undefined;
10
+ }
11
+ const prelimMessageId = graph.prelimMessageIdsByStepKey.get(stepKey);
12
+ if (prelimMessageId != null && prelimMessageId) {
13
+ graph.prelimMessageIdsByStepKey.delete(stepKey);
14
+ graph.messageIdsByStepKey.set(stepKey, prelimMessageId);
15
+ return prelimMessageId;
16
+ }
17
+ const message_id = `msg_${nanoid.nanoid()}`;
18
+ graph.messageIdsByStepKey.set(stepKey, message_id);
19
+ return message_id;
20
+ };
21
+
22
+ exports.getMessageId = getMessageId;
23
+ //# sourceMappingURL=ids.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ids.cjs","sources":["../../../src/messages/ids.ts"],"sourcesContent":["// src/stream.ts\r\nimport { nanoid } from 'nanoid';\r\nimport type { Graph } from '@/graphs';\r\nimport type * as t from '@/types';\r\n\r\nexport const getMessageId = (\r\n stepKey: string,\r\n graph: Graph<t.BaseGraphState>,\r\n returnExistingId = false\r\n): string | undefined => {\r\n const messageId = graph.messageIdsByStepKey.get(stepKey);\r\n if (messageId != null && messageId) {\r\n return returnExistingId ? messageId : undefined;\r\n }\r\n\r\n const prelimMessageId = graph.prelimMessageIdsByStepKey.get(stepKey);\r\n if (prelimMessageId != null && prelimMessageId) {\r\n graph.prelimMessageIdsByStepKey.delete(stepKey);\r\n graph.messageIdsByStepKey.set(stepKey, prelimMessageId);\r\n return prelimMessageId;\r\n }\r\n\r\n const message_id = `msg_${nanoid()}`;\r\n graph.messageIdsByStepKey.set(stepKey, message_id);\r\n return message_id;\r\n};\r\n"],"names":["nanoid"],"mappings":";;;;AAAA;AAKO,MAAM,YAAY,GAAG,CAC1B,OAAe,EACf,KAA8B,EAC9B,gBAAgB,GAAG,KAAK,KACF;IACtB,MAAM,SAAS,GAAG,KAAK,CAAC,mBAAmB,CAAC,GAAG,CAAC,OAAO,CAAC;AACxD,IAAA,IAAI,SAAS,IAAI,IAAI,IAAI,SAAS,EAAE;QAClC,OAAO,gBAAgB,GAAG,SAAS,GAAG,SAAS;;IAGjD,MAAM,eAAe,GAAG,KAAK,CAAC,yBAAyB,CAAC,GAAG,CAAC,OAAO,CAAC;AACpE,IAAA,IAAI,eAAe,IAAI,IAAI,IAAI,eAAe,EAAE;AAC9C,QAAA,KAAK,CAAC,yBAAyB,CAAC,MAAM,CAAC,OAAO,CAAC;QAC/C,KAAK,CAAC,mBAAmB,CAAC,GAAG,CAAC,OAAO,EAAE,eAAe,CAAC;AACvD,QAAA,OAAO,eAAe;;AAGxB,IAAA,MAAM,UAAU,GAAG,CAAA,IAAA,EAAOA,aAAM,EAAE,EAAE;IACpC,KAAK,CAAC,mBAAmB,CAAC,GAAG,CAAC,OAAO,EAAE,UAAU,CAAC;AAClD,IAAA,OAAO,UAAU;AACnB;;;;"}