@langchain/core 1.1.3 → 1.1.5-dev-1765431816670

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 (605) hide show
  1. package/CHANGELOG.md +8 -0
  2. package/README.md +1 -1
  3. package/dist/agents.d.cts.map +1 -0
  4. package/dist/agents.d.ts.map +1 -0
  5. package/dist/caches/index.d.cts.map +1 -0
  6. package/dist/caches/index.d.ts.map +1 -0
  7. package/dist/callbacks/base.cjs +1 -1
  8. package/dist/callbacks/base.cjs.map +1 -1
  9. package/dist/callbacks/base.d.cts.map +1 -0
  10. package/dist/callbacks/base.d.ts.map +1 -0
  11. package/dist/callbacks/base.js +1 -1
  12. package/dist/callbacks/base.js.map +1 -1
  13. package/dist/callbacks/dispatch/index.d.cts.map +1 -0
  14. package/dist/callbacks/dispatch/index.d.ts.map +1 -0
  15. package/dist/callbacks/dispatch/web.d.cts.map +1 -0
  16. package/dist/callbacks/dispatch/web.d.ts.map +1 -0
  17. package/dist/callbacks/manager.cjs +6 -6
  18. package/dist/callbacks/manager.cjs.map +1 -1
  19. package/dist/callbacks/manager.d.cts.map +1 -0
  20. package/dist/callbacks/manager.d.ts.map +1 -0
  21. package/dist/callbacks/manager.js +7 -7
  22. package/dist/callbacks/manager.js.map +1 -1
  23. package/dist/chat_history.d.cts.map +1 -0
  24. package/dist/chat_history.d.ts.map +1 -0
  25. package/dist/context.d.cts.map +1 -0
  26. package/dist/context.d.ts.map +1 -0
  27. package/dist/document_loaders/base.d.cts.map +1 -0
  28. package/dist/document_loaders/base.d.ts.map +1 -0
  29. package/dist/document_loaders/langsmith.d.cts.map +1 -0
  30. package/dist/document_loaders/langsmith.d.ts.map +1 -0
  31. package/dist/documents/document.d.cts.map +1 -0
  32. package/dist/documents/document.d.ts.map +1 -0
  33. package/dist/documents/transformers.d.cts.map +1 -0
  34. package/dist/documents/transformers.d.ts.map +1 -0
  35. package/dist/embeddings.d.cts.map +1 -0
  36. package/dist/embeddings.d.ts.map +1 -0
  37. package/dist/example_selectors/base.d.cts.map +1 -0
  38. package/dist/example_selectors/base.d.ts.map +1 -0
  39. package/dist/example_selectors/conditional.d.cts.map +1 -0
  40. package/dist/example_selectors/conditional.d.ts.map +1 -0
  41. package/dist/example_selectors/length_based.d.cts.map +1 -0
  42. package/dist/example_selectors/length_based.d.ts.map +1 -0
  43. package/dist/example_selectors/semantic_similarity.d.cts.map +1 -0
  44. package/dist/example_selectors/semantic_similarity.d.ts.map +1 -0
  45. package/dist/indexing/base.d.cts.map +1 -0
  46. package/dist/indexing/base.d.ts.map +1 -0
  47. package/dist/indexing/record_manager.d.cts.map +1 -0
  48. package/dist/indexing/record_manager.d.ts.map +1 -0
  49. package/dist/language_models/base.d.cts.map +1 -0
  50. package/dist/language_models/base.d.ts.map +1 -0
  51. package/dist/language_models/chat_models.d.cts.map +1 -0
  52. package/dist/language_models/chat_models.d.ts.map +1 -0
  53. package/dist/language_models/llms.d.cts.map +1 -0
  54. package/dist/language_models/llms.d.ts.map +1 -0
  55. package/dist/language_models/profile.d.cts.map +1 -0
  56. package/dist/language_models/profile.d.ts.map +1 -0
  57. package/dist/load/import_type.d.cts.map +1 -0
  58. package/dist/load/import_type.d.ts.map +1 -0
  59. package/dist/load/index.d.cts.map +1 -0
  60. package/dist/load/index.d.ts.map +1 -0
  61. package/dist/load/map_keys.cjs +5 -4
  62. package/dist/load/map_keys.cjs.map +1 -1
  63. package/dist/load/map_keys.d.cts.map +1 -0
  64. package/dist/load/map_keys.d.ts.map +1 -0
  65. package/dist/load/map_keys.js +3 -3
  66. package/dist/load/map_keys.js.map +1 -1
  67. package/dist/load/serializable.d.cts.map +1 -0
  68. package/dist/load/serializable.d.ts.map +1 -0
  69. package/dist/memory.d.cts.map +1 -0
  70. package/dist/memory.d.ts.map +1 -0
  71. package/dist/messages/ai.d.cts.map +1 -0
  72. package/dist/messages/ai.d.ts.map +1 -0
  73. package/dist/messages/base.d.cts.map +1 -0
  74. package/dist/messages/base.d.ts.map +1 -0
  75. package/dist/messages/chat.d.cts.map +1 -0
  76. package/dist/messages/chat.d.ts.map +1 -0
  77. package/dist/messages/content/base.d.cts.map +1 -0
  78. package/dist/messages/content/base.d.ts.map +1 -0
  79. package/dist/messages/content/data.d.cts.map +1 -0
  80. package/dist/messages/content/data.d.ts.map +1 -0
  81. package/dist/messages/content/index.d.cts.map +1 -0
  82. package/dist/messages/content/index.d.ts.map +1 -0
  83. package/dist/messages/content/multimodal.d.cts.map +1 -0
  84. package/dist/messages/content/multimodal.d.ts.map +1 -0
  85. package/dist/messages/content/tools.d.cts.map +1 -0
  86. package/dist/messages/content/tools.d.ts.map +1 -0
  87. package/dist/messages/format.d.cts.map +1 -0
  88. package/dist/messages/format.d.ts.map +1 -0
  89. package/dist/messages/function.d.cts.map +1 -0
  90. package/dist/messages/function.d.ts.map +1 -0
  91. package/dist/messages/human.d.cts.map +1 -0
  92. package/dist/messages/human.d.ts.map +1 -0
  93. package/dist/messages/message.d.cts.map +1 -0
  94. package/dist/messages/message.d.ts.map +1 -0
  95. package/dist/messages/metadata.d.cts.map +1 -0
  96. package/dist/messages/metadata.d.ts.map +1 -0
  97. package/dist/messages/modifier.d.cts.map +1 -0
  98. package/dist/messages/modifier.d.ts.map +1 -0
  99. package/dist/messages/system.d.cts.map +1 -0
  100. package/dist/messages/system.d.ts.map +1 -0
  101. package/dist/messages/tool.d.cts.map +1 -0
  102. package/dist/messages/tool.d.ts.map +1 -0
  103. package/dist/messages/transformers.d.cts.map +1 -0
  104. package/dist/messages/transformers.d.ts.map +1 -0
  105. package/dist/messages/utils.d.cts.map +1 -0
  106. package/dist/messages/utils.d.ts.map +1 -0
  107. package/dist/output_parsers/base.d.cts.map +1 -0
  108. package/dist/output_parsers/base.d.ts.map +1 -0
  109. package/dist/output_parsers/bytes.d.cts.map +1 -0
  110. package/dist/output_parsers/bytes.d.ts.map +1 -0
  111. package/dist/output_parsers/json.d.cts.map +1 -0
  112. package/dist/output_parsers/json.d.ts.map +1 -0
  113. package/dist/output_parsers/list.d.cts.map +1 -0
  114. package/dist/output_parsers/list.d.ts.map +1 -0
  115. package/dist/output_parsers/openai_functions/json_output_functions_parsers.d.cts.map +1 -0
  116. package/dist/output_parsers/openai_functions/json_output_functions_parsers.d.ts.map +1 -0
  117. package/dist/output_parsers/openai_tools/json_output_tools_parsers.d.cts.map +1 -0
  118. package/dist/output_parsers/openai_tools/json_output_tools_parsers.d.ts.map +1 -0
  119. package/dist/output_parsers/string.d.cts.map +1 -0
  120. package/dist/output_parsers/string.d.ts.map +1 -0
  121. package/dist/output_parsers/structured.d.cts.map +1 -0
  122. package/dist/output_parsers/structured.d.ts.map +1 -0
  123. package/dist/output_parsers/transform.d.cts.map +1 -0
  124. package/dist/output_parsers/transform.d.ts.map +1 -0
  125. package/dist/output_parsers/xml.d.cts.map +1 -0
  126. package/dist/output_parsers/xml.d.ts.map +1 -0
  127. package/dist/outputs.d.cts.map +1 -0
  128. package/dist/outputs.d.ts.map +1 -0
  129. package/dist/prompt_values.d.cts.map +1 -0
  130. package/dist/prompt_values.d.ts.map +1 -0
  131. package/dist/prompts/base.d.cts.map +1 -0
  132. package/dist/prompts/base.d.ts.map +1 -0
  133. package/dist/prompts/chat.d.cts.map +1 -0
  134. package/dist/prompts/chat.d.ts.map +1 -0
  135. package/dist/prompts/dict.d.cts.map +1 -0
  136. package/dist/prompts/dict.d.ts.map +1 -0
  137. package/dist/prompts/few_shot.d.cts.map +1 -0
  138. package/dist/prompts/few_shot.d.ts.map +1 -0
  139. package/dist/prompts/image.d.cts.map +1 -0
  140. package/dist/prompts/image.d.ts.map +1 -0
  141. package/dist/prompts/pipeline.d.cts.map +1 -0
  142. package/dist/prompts/pipeline.d.ts.map +1 -0
  143. package/dist/prompts/prompt.d.cts.map +1 -0
  144. package/dist/prompts/prompt.d.ts.map +1 -0
  145. package/dist/prompts/serde.d.cts.map +1 -0
  146. package/dist/prompts/serde.d.ts.map +1 -0
  147. package/dist/prompts/string.d.cts.map +1 -0
  148. package/dist/prompts/string.d.ts.map +1 -0
  149. package/dist/prompts/structured.d.cts.map +1 -0
  150. package/dist/prompts/structured.d.ts.map +1 -0
  151. package/dist/prompts/template.d.cts.map +1 -0
  152. package/dist/prompts/template.d.ts.map +1 -0
  153. package/dist/retrievers/document_compressors/index.d.cts.map +1 -0
  154. package/dist/retrievers/document_compressors/index.d.ts.map +1 -0
  155. package/dist/retrievers/index.d.cts.map +1 -0
  156. package/dist/retrievers/index.d.ts.map +1 -0
  157. package/dist/runnables/base.cjs +7 -7
  158. package/dist/runnables/base.cjs.map +1 -1
  159. package/dist/runnables/base.d.cts.map +1 -0
  160. package/dist/runnables/base.d.ts.map +1 -0
  161. package/dist/runnables/base.js +1 -1
  162. package/dist/runnables/base.js.map +1 -1
  163. package/dist/runnables/branch.d.cts.map +1 -0
  164. package/dist/runnables/branch.d.ts.map +1 -0
  165. package/dist/runnables/config.cjs +15 -1
  166. package/dist/runnables/config.cjs.map +1 -1
  167. package/dist/runnables/config.d.cts.map +1 -0
  168. package/dist/runnables/config.d.ts.map +1 -0
  169. package/dist/runnables/config.js +15 -1
  170. package/dist/runnables/config.js.map +1 -1
  171. package/dist/runnables/graph.d.cts.map +1 -0
  172. package/dist/runnables/graph.d.ts.map +1 -0
  173. package/dist/runnables/history.d.cts.map +1 -0
  174. package/dist/runnables/history.d.ts.map +1 -0
  175. package/dist/runnables/passthrough.d.cts.map +1 -0
  176. package/dist/runnables/passthrough.d.ts.map +1 -0
  177. package/dist/runnables/router.d.cts.map +1 -0
  178. package/dist/runnables/router.d.ts.map +1 -0
  179. package/dist/runnables/types.d.cts.map +1 -0
  180. package/dist/runnables/types.d.ts.map +1 -0
  181. package/dist/singletons/async_local_storage/context.d.cts.map +1 -0
  182. package/dist/singletons/async_local_storage/context.d.ts.map +1 -0
  183. package/dist/singletons/async_local_storage/globals.d.cts.map +1 -0
  184. package/dist/singletons/async_local_storage/globals.d.ts.map +1 -0
  185. package/dist/singletons/async_local_storage/index.d.cts.map +1 -0
  186. package/dist/singletons/async_local_storage/index.d.ts.map +1 -0
  187. package/dist/singletons/callbacks.cjs.map +1 -1
  188. package/dist/singletons/callbacks.d.cts.map +1 -0
  189. package/dist/singletons/callbacks.d.ts.map +1 -0
  190. package/dist/singletons/callbacks.js.map +1 -1
  191. package/dist/stores.d.cts.map +1 -0
  192. package/dist/stores.d.ts.map +1 -0
  193. package/dist/structured_query/base.d.cts.map +1 -0
  194. package/dist/structured_query/base.d.ts.map +1 -0
  195. package/dist/structured_query/functional.d.cts.map +1 -0
  196. package/dist/structured_query/functional.d.ts.map +1 -0
  197. package/dist/structured_query/ir.d.cts.map +1 -0
  198. package/dist/structured_query/ir.d.ts.map +1 -0
  199. package/dist/structured_query/utils.d.cts.map +1 -0
  200. package/dist/structured_query/utils.d.ts.map +1 -0
  201. package/dist/tools/index.d.cts.map +1 -0
  202. package/dist/tools/index.d.ts.map +1 -0
  203. package/dist/tools/types.d.cts.map +1 -0
  204. package/dist/tools/types.d.ts.map +1 -0
  205. package/dist/tools/utils.d.cts.map +1 -0
  206. package/dist/tools/utils.d.ts.map +1 -0
  207. package/dist/tracers/base.d.cts.map +1 -0
  208. package/dist/tracers/base.d.ts.map +1 -0
  209. package/dist/tracers/console.cjs +3 -3
  210. package/dist/tracers/console.cjs.map +1 -1
  211. package/dist/tracers/console.d.cts.map +1 -0
  212. package/dist/tracers/console.d.ts.map +1 -0
  213. package/dist/tracers/console.js +3 -3
  214. package/dist/tracers/console.js.map +1 -1
  215. package/dist/tracers/event_stream.d.cts.map +1 -0
  216. package/dist/tracers/event_stream.d.ts.map +1 -0
  217. package/dist/tracers/log_stream.d.cts.map +1 -0
  218. package/dist/tracers/log_stream.d.ts.map +1 -0
  219. package/dist/tracers/run_collector.d.cts.map +1 -0
  220. package/dist/tracers/run_collector.d.ts.map +1 -0
  221. package/dist/tracers/tracer_langchain.d.cts.map +1 -0
  222. package/dist/tracers/tracer_langchain.d.ts.map +1 -0
  223. package/dist/types/_internal.d.cts.map +1 -0
  224. package/dist/types/_internal.d.ts.map +1 -0
  225. package/dist/types/type-utils.d.cts.map +1 -0
  226. package/dist/types/type-utils.d.ts.map +1 -0
  227. package/dist/utils/async_caller.cjs +1 -1
  228. package/dist/utils/async_caller.cjs.map +1 -1
  229. package/dist/utils/async_caller.d.cts.map +1 -0
  230. package/dist/utils/async_caller.d.ts.map +1 -0
  231. package/dist/utils/async_caller.js +1 -1
  232. package/dist/utils/async_caller.js.map +1 -1
  233. package/dist/utils/chunk_array.d.cts.map +1 -0
  234. package/dist/utils/chunk_array.d.ts.map +1 -0
  235. package/dist/utils/env.d.cts.map +1 -0
  236. package/dist/utils/env.d.ts.map +1 -0
  237. package/dist/utils/event_source_parse.d.cts.map +1 -0
  238. package/dist/utils/event_source_parse.d.ts.map +1 -0
  239. package/dist/utils/fast-json-patch/src/core.d.cts.map +1 -0
  240. package/dist/utils/fast-json-patch/src/core.d.ts.map +1 -0
  241. package/dist/utils/fast-json-patch/src/duplex.d.cts.map +1 -0
  242. package/dist/utils/fast-json-patch/src/duplex.d.ts.map +1 -0
  243. package/dist/utils/format.d.cts.map +1 -0
  244. package/dist/utils/format.d.ts.map +1 -0
  245. package/dist/utils/function_calling.d.cts.map +1 -0
  246. package/dist/utils/function_calling.d.ts.map +1 -0
  247. package/dist/utils/hash.d.cts.map +1 -0
  248. package/dist/utils/hash.d.ts.map +1 -0
  249. package/dist/{node_modules/.pnpm/is-network-error@1.3.0/node_modules → utils}/is-network-error/index.cjs +1 -1
  250. package/dist/utils/is-network-error/index.cjs.map +1 -0
  251. package/dist/{node_modules/.pnpm/is-network-error@1.3.0/node_modules → utils}/is-network-error/index.js +1 -1
  252. package/dist/utils/is-network-error/index.js.map +1 -0
  253. package/dist/utils/js-sha256/hash.d.cts.map +1 -0
  254. package/dist/utils/js-sha256/hash.d.ts.map +1 -0
  255. package/dist/utils/json.d.cts.map +1 -0
  256. package/dist/utils/json.d.ts.map +1 -0
  257. package/dist/utils/json_schema.d.cts.map +1 -0
  258. package/dist/utils/json_schema.d.ts.map +1 -0
  259. package/dist/utils/math.d.cts.map +1 -0
  260. package/dist/utils/math.d.ts.map +1 -0
  261. package/dist/utils/ml-distance/similarities.d.cts.map +1 -0
  262. package/dist/utils/ml-distance/similarities.d.ts.map +1 -0
  263. package/dist/{node_modules/.pnpm/p-retry@7.1.0/node_modules → utils}/p-retry/index.cjs +2 -2
  264. package/dist/utils/p-retry/index.cjs.map +1 -0
  265. package/dist/{node_modules/.pnpm/p-retry@7.1.0/node_modules → utils}/p-retry/index.js +2 -2
  266. package/dist/utils/p-retry/index.js.map +1 -0
  267. package/dist/utils/signal.d.cts.map +1 -0
  268. package/dist/utils/signal.d.ts.map +1 -0
  269. package/dist/utils/stream.d.cts.map +1 -0
  270. package/dist/utils/stream.d.ts.map +1 -0
  271. package/dist/utils/testing/chat_models.cjs +11 -5
  272. package/dist/utils/testing/chat_models.cjs.map +1 -1
  273. package/dist/utils/testing/chat_models.d.cts +8 -1
  274. package/dist/utils/testing/chat_models.d.cts.map +1 -0
  275. package/dist/utils/testing/chat_models.d.ts +8 -1
  276. package/dist/utils/testing/chat_models.d.ts.map +1 -0
  277. package/dist/utils/testing/chat_models.js +11 -5
  278. package/dist/utils/testing/chat_models.js.map +1 -1
  279. package/dist/utils/testing/embeddings.d.cts.map +1 -0
  280. package/dist/utils/testing/embeddings.d.ts.map +1 -0
  281. package/dist/utils/testing/llms.d.cts.map +1 -0
  282. package/dist/utils/testing/llms.d.ts.map +1 -0
  283. package/dist/utils/testing/message_history.d.cts.map +1 -0
  284. package/dist/utils/testing/message_history.d.ts.map +1 -0
  285. package/dist/utils/testing/output_parsers.d.cts.map +1 -0
  286. package/dist/utils/testing/output_parsers.d.ts.map +1 -0
  287. package/dist/utils/testing/retrievers.d.cts.map +1 -0
  288. package/dist/utils/testing/retrievers.d.ts.map +1 -0
  289. package/dist/utils/testing/runnables.d.cts.map +1 -0
  290. package/dist/utils/testing/runnables.d.ts.map +1 -0
  291. package/dist/utils/testing/tools.d.cts.map +1 -0
  292. package/dist/utils/testing/tools.d.ts.map +1 -0
  293. package/dist/utils/testing/tracers.d.cts.map +1 -0
  294. package/dist/utils/testing/tracers.d.ts.map +1 -0
  295. package/dist/utils/testing/vectorstores.d.cts.map +1 -0
  296. package/dist/utils/testing/vectorstores.d.ts.map +1 -0
  297. package/dist/utils/tiktoken.d.cts.map +1 -0
  298. package/dist/utils/tiktoken.d.ts.map +1 -0
  299. package/dist/utils/types/index.d.cts.map +1 -0
  300. package/dist/utils/types/index.d.ts.map +1 -0
  301. package/dist/utils/types/zod.d.cts.map +1 -0
  302. package/dist/utils/types/zod.d.ts.map +1 -0
  303. package/dist/utils/zod-to-json-schema/errorMessages.d.cts.map +1 -0
  304. package/dist/utils/zod-to-json-schema/errorMessages.d.ts.map +1 -0
  305. package/dist/utils/zod-to-json-schema/parseTypes.d.cts.map +1 -0
  306. package/dist/utils/zod-to-json-schema/parseTypes.d.ts.map +1 -0
  307. package/dist/utils/zod-to-json-schema/parsers/any.d.cts.map +1 -0
  308. package/dist/utils/zod-to-json-schema/parsers/any.d.ts.map +1 -0
  309. package/dist/utils/zod-to-json-schema/parsers/array.d.cts.map +1 -0
  310. package/dist/utils/zod-to-json-schema/parsers/array.d.ts.map +1 -0
  311. package/dist/utils/zod-to-json-schema/parsers/bigint.d.cts.map +1 -0
  312. package/dist/utils/zod-to-json-schema/parsers/bigint.d.ts.map +1 -0
  313. package/dist/utils/zod-to-json-schema/parsers/boolean.d.cts.map +1 -0
  314. package/dist/utils/zod-to-json-schema/parsers/boolean.d.ts.map +1 -0
  315. package/dist/utils/zod-to-json-schema/parsers/date.d.cts.map +1 -0
  316. package/dist/utils/zod-to-json-schema/parsers/date.d.ts.map +1 -0
  317. package/dist/utils/zod-to-json-schema/parsers/enum.d.cts.map +1 -0
  318. package/dist/utils/zod-to-json-schema/parsers/enum.d.ts.map +1 -0
  319. package/dist/utils/zod-to-json-schema/parsers/intersection.d.cts.map +1 -0
  320. package/dist/utils/zod-to-json-schema/parsers/intersection.d.ts.map +1 -0
  321. package/dist/utils/zod-to-json-schema/parsers/literal.d.cts.map +1 -0
  322. package/dist/utils/zod-to-json-schema/parsers/literal.d.ts.map +1 -0
  323. package/dist/utils/zod-to-json-schema/parsers/map.d.cts.map +1 -0
  324. package/dist/utils/zod-to-json-schema/parsers/map.d.ts.map +1 -0
  325. package/dist/utils/zod-to-json-schema/parsers/nativeEnum.d.cts.map +1 -0
  326. package/dist/utils/zod-to-json-schema/parsers/nativeEnum.d.ts.map +1 -0
  327. package/dist/utils/zod-to-json-schema/parsers/never.d.cts.map +1 -0
  328. package/dist/utils/zod-to-json-schema/parsers/never.d.ts.map +1 -0
  329. package/dist/utils/zod-to-json-schema/parsers/null.d.cts.map +1 -0
  330. package/dist/utils/zod-to-json-schema/parsers/null.d.ts.map +1 -0
  331. package/dist/utils/zod-to-json-schema/parsers/nullable.d.cts.map +1 -0
  332. package/dist/utils/zod-to-json-schema/parsers/nullable.d.ts.map +1 -0
  333. package/dist/utils/zod-to-json-schema/parsers/number.d.cts.map +1 -0
  334. package/dist/utils/zod-to-json-schema/parsers/number.d.ts.map +1 -0
  335. package/dist/utils/zod-to-json-schema/parsers/object.d.cts.map +1 -0
  336. package/dist/utils/zod-to-json-schema/parsers/object.d.ts.map +1 -0
  337. package/dist/utils/zod-to-json-schema/parsers/record.d.cts.map +1 -0
  338. package/dist/utils/zod-to-json-schema/parsers/record.d.ts.map +1 -0
  339. package/dist/utils/zod-to-json-schema/parsers/set.d.cts.map +1 -0
  340. package/dist/utils/zod-to-json-schema/parsers/set.d.ts.map +1 -0
  341. package/dist/utils/zod-to-json-schema/parsers/string.d.cts.map +1 -0
  342. package/dist/utils/zod-to-json-schema/parsers/string.d.ts.map +1 -0
  343. package/dist/utils/zod-to-json-schema/parsers/tuple.d.cts.map +1 -0
  344. package/dist/utils/zod-to-json-schema/parsers/tuple.d.ts.map +1 -0
  345. package/dist/utils/zod-to-json-schema/parsers/undefined.d.cts.map +1 -0
  346. package/dist/utils/zod-to-json-schema/parsers/undefined.d.ts.map +1 -0
  347. package/dist/utils/zod-to-json-schema/parsers/union.d.cts.map +1 -0
  348. package/dist/utils/zod-to-json-schema/parsers/union.d.ts.map +1 -0
  349. package/dist/utils/zod-to-json-schema/parsers/unknown.d.cts.map +1 -0
  350. package/dist/utils/zod-to-json-schema/parsers/unknown.d.ts.map +1 -0
  351. package/dist/vectorstores.d.cts.map +1 -0
  352. package/dist/vectorstores.d.ts.map +1 -0
  353. package/package.json +10 -10
  354. package/agents.cjs +0 -1
  355. package/agents.d.cts +0 -1
  356. package/agents.d.ts +0 -1
  357. package/agents.js +0 -1
  358. package/caches.cjs +0 -1
  359. package/caches.d.cts +0 -1
  360. package/caches.d.ts +0 -1
  361. package/caches.js +0 -1
  362. package/callbacks/base.cjs +0 -1
  363. package/callbacks/base.d.cts +0 -1
  364. package/callbacks/base.d.ts +0 -1
  365. package/callbacks/base.js +0 -1
  366. package/callbacks/dispatch/web.cjs +0 -1
  367. package/callbacks/dispatch/web.d.cts +0 -1
  368. package/callbacks/dispatch/web.d.ts +0 -1
  369. package/callbacks/dispatch/web.js +0 -1
  370. package/callbacks/dispatch.cjs +0 -1
  371. package/callbacks/dispatch.d.cts +0 -1
  372. package/callbacks/dispatch.d.ts +0 -1
  373. package/callbacks/dispatch.js +0 -1
  374. package/callbacks/manager.cjs +0 -1
  375. package/callbacks/manager.d.cts +0 -1
  376. package/callbacks/manager.d.ts +0 -1
  377. package/callbacks/manager.js +0 -1
  378. package/callbacks/promises.cjs +0 -1
  379. package/callbacks/promises.d.cts +0 -1
  380. package/callbacks/promises.d.ts +0 -1
  381. package/callbacks/promises.js +0 -1
  382. package/chat_history.cjs +0 -1
  383. package/chat_history.d.cts +0 -1
  384. package/chat_history.d.ts +0 -1
  385. package/chat_history.js +0 -1
  386. package/context.cjs +0 -1
  387. package/context.d.cts +0 -1
  388. package/context.d.ts +0 -1
  389. package/context.js +0 -1
  390. package/dist/node_modules/.pnpm/ansi-styles@6.2.3/node_modules/ansi-styles/index.cjs +0 -169
  391. package/dist/node_modules/.pnpm/ansi-styles@6.2.3/node_modules/ansi-styles/index.cjs.map +0 -1
  392. package/dist/node_modules/.pnpm/ansi-styles@6.2.3/node_modules/ansi-styles/index.js +0 -168
  393. package/dist/node_modules/.pnpm/ansi-styles@6.2.3/node_modules/ansi-styles/index.js.map +0 -1
  394. package/dist/node_modules/.pnpm/camelcase@9.0.0/node_modules/camelcase/index.cjs +0 -122
  395. package/dist/node_modules/.pnpm/camelcase@9.0.0/node_modules/camelcase/index.cjs.map +0 -1
  396. package/dist/node_modules/.pnpm/camelcase@9.0.0/node_modules/camelcase/index.js +0 -121
  397. package/dist/node_modules/.pnpm/camelcase@9.0.0/node_modules/camelcase/index.js.map +0 -1
  398. package/dist/node_modules/.pnpm/decamelize@6.0.1/node_modules/decamelize/index.cjs +0 -18
  399. package/dist/node_modules/.pnpm/decamelize@6.0.1/node_modules/decamelize/index.cjs.map +0 -1
  400. package/dist/node_modules/.pnpm/decamelize@6.0.1/node_modules/decamelize/index.js +0 -17
  401. package/dist/node_modules/.pnpm/decamelize@6.0.1/node_modules/decamelize/index.js.map +0 -1
  402. package/dist/node_modules/.pnpm/is-network-error@1.3.0/node_modules/is-network-error/index.cjs.map +0 -1
  403. package/dist/node_modules/.pnpm/is-network-error@1.3.0/node_modules/is-network-error/index.js.map +0 -1
  404. package/dist/node_modules/.pnpm/p-retry@7.1.0/node_modules/p-retry/index.cjs.map +0 -1
  405. package/dist/node_modules/.pnpm/p-retry@7.1.0/node_modules/p-retry/index.js.map +0 -1
  406. package/document_loaders/base.cjs +0 -1
  407. package/document_loaders/base.d.cts +0 -1
  408. package/document_loaders/base.d.ts +0 -1
  409. package/document_loaders/base.js +0 -1
  410. package/document_loaders/langsmith.cjs +0 -1
  411. package/document_loaders/langsmith.d.cts +0 -1
  412. package/document_loaders/langsmith.d.ts +0 -1
  413. package/document_loaders/langsmith.js +0 -1
  414. package/documents.cjs +0 -1
  415. package/documents.d.cts +0 -1
  416. package/documents.d.ts +0 -1
  417. package/documents.js +0 -1
  418. package/embeddings.cjs +0 -1
  419. package/embeddings.d.cts +0 -1
  420. package/embeddings.d.ts +0 -1
  421. package/embeddings.js +0 -1
  422. package/example_selectors.cjs +0 -1
  423. package/example_selectors.d.cts +0 -1
  424. package/example_selectors.d.ts +0 -1
  425. package/example_selectors.js +0 -1
  426. package/indexing.cjs +0 -1
  427. package/indexing.d.cts +0 -1
  428. package/indexing.d.ts +0 -1
  429. package/indexing.js +0 -1
  430. package/language_models/base.cjs +0 -1
  431. package/language_models/base.d.cts +0 -1
  432. package/language_models/base.d.ts +0 -1
  433. package/language_models/base.js +0 -1
  434. package/language_models/chat_models.cjs +0 -1
  435. package/language_models/chat_models.d.cts +0 -1
  436. package/language_models/chat_models.d.ts +0 -1
  437. package/language_models/chat_models.js +0 -1
  438. package/language_models/llms.cjs +0 -1
  439. package/language_models/llms.d.cts +0 -1
  440. package/language_models/llms.d.ts +0 -1
  441. package/language_models/llms.js +0 -1
  442. package/language_models/profile.cjs +0 -1
  443. package/language_models/profile.d.cts +0 -1
  444. package/language_models/profile.d.ts +0 -1
  445. package/language_models/profile.js +0 -1
  446. package/load/serializable.cjs +0 -1
  447. package/load/serializable.d.cts +0 -1
  448. package/load/serializable.d.ts +0 -1
  449. package/load/serializable.js +0 -1
  450. package/load.cjs +0 -1
  451. package/load.d.cts +0 -1
  452. package/load.d.ts +0 -1
  453. package/load.js +0 -1
  454. package/memory.cjs +0 -1
  455. package/memory.d.cts +0 -1
  456. package/memory.d.ts +0 -1
  457. package/memory.js +0 -1
  458. package/messages/tool.cjs +0 -1
  459. package/messages/tool.d.cts +0 -1
  460. package/messages/tool.d.ts +0 -1
  461. package/messages/tool.js +0 -1
  462. package/messages.cjs +0 -1
  463. package/messages.d.cts +0 -1
  464. package/messages.d.ts +0 -1
  465. package/messages.js +0 -1
  466. package/output_parsers/openai_functions.cjs +0 -1
  467. package/output_parsers/openai_functions.d.cts +0 -1
  468. package/output_parsers/openai_functions.d.ts +0 -1
  469. package/output_parsers/openai_functions.js +0 -1
  470. package/output_parsers/openai_tools.cjs +0 -1
  471. package/output_parsers/openai_tools.d.cts +0 -1
  472. package/output_parsers/openai_tools.d.ts +0 -1
  473. package/output_parsers/openai_tools.js +0 -1
  474. package/output_parsers.cjs +0 -1
  475. package/output_parsers.d.cts +0 -1
  476. package/output_parsers.d.ts +0 -1
  477. package/output_parsers.js +0 -1
  478. package/outputs.cjs +0 -1
  479. package/outputs.d.cts +0 -1
  480. package/outputs.d.ts +0 -1
  481. package/outputs.js +0 -1
  482. package/prompt_values.cjs +0 -1
  483. package/prompt_values.d.cts +0 -1
  484. package/prompt_values.d.ts +0 -1
  485. package/prompt_values.js +0 -1
  486. package/prompts.cjs +0 -1
  487. package/prompts.d.cts +0 -1
  488. package/prompts.d.ts +0 -1
  489. package/prompts.js +0 -1
  490. package/retrievers/document_compressors.cjs +0 -1
  491. package/retrievers/document_compressors.d.cts +0 -1
  492. package/retrievers/document_compressors.d.ts +0 -1
  493. package/retrievers/document_compressors.js +0 -1
  494. package/retrievers.cjs +0 -1
  495. package/retrievers.d.cts +0 -1
  496. package/retrievers.d.ts +0 -1
  497. package/retrievers.js +0 -1
  498. package/runnables/graph.cjs +0 -1
  499. package/runnables/graph.d.cts +0 -1
  500. package/runnables/graph.d.ts +0 -1
  501. package/runnables/graph.js +0 -1
  502. package/runnables.cjs +0 -1
  503. package/runnables.d.cts +0 -1
  504. package/runnables.d.ts +0 -1
  505. package/runnables.js +0 -1
  506. package/singletons.cjs +0 -1
  507. package/singletons.d.cts +0 -1
  508. package/singletons.d.ts +0 -1
  509. package/singletons.js +0 -1
  510. package/stores.cjs +0 -1
  511. package/stores.d.cts +0 -1
  512. package/stores.d.ts +0 -1
  513. package/stores.js +0 -1
  514. package/structured_query.cjs +0 -1
  515. package/structured_query.d.cts +0 -1
  516. package/structured_query.d.ts +0 -1
  517. package/structured_query.js +0 -1
  518. package/tools.cjs +0 -1
  519. package/tools.d.cts +0 -1
  520. package/tools.d.ts +0 -1
  521. package/tools.js +0 -1
  522. package/tracers/base.cjs +0 -1
  523. package/tracers/base.d.cts +0 -1
  524. package/tracers/base.d.ts +0 -1
  525. package/tracers/base.js +0 -1
  526. package/tracers/console.cjs +0 -1
  527. package/tracers/console.d.cts +0 -1
  528. package/tracers/console.d.ts +0 -1
  529. package/tracers/console.js +0 -1
  530. package/tracers/log_stream.cjs +0 -1
  531. package/tracers/log_stream.d.cts +0 -1
  532. package/tracers/log_stream.d.ts +0 -1
  533. package/tracers/log_stream.js +0 -1
  534. package/tracers/run_collector.cjs +0 -1
  535. package/tracers/run_collector.d.cts +0 -1
  536. package/tracers/run_collector.d.ts +0 -1
  537. package/tracers/run_collector.js +0 -1
  538. package/tracers/tracer_langchain.cjs +0 -1
  539. package/tracers/tracer_langchain.d.cts +0 -1
  540. package/tracers/tracer_langchain.d.ts +0 -1
  541. package/tracers/tracer_langchain.js +0 -1
  542. package/types/stream.cjs +0 -1
  543. package/types/stream.d.cts +0 -1
  544. package/types/stream.d.ts +0 -1
  545. package/types/stream.js +0 -1
  546. package/utils/async_caller.cjs +0 -1
  547. package/utils/async_caller.d.cts +0 -1
  548. package/utils/async_caller.d.ts +0 -1
  549. package/utils/async_caller.js +0 -1
  550. package/utils/chunk_array.cjs +0 -1
  551. package/utils/chunk_array.d.cts +0 -1
  552. package/utils/chunk_array.d.ts +0 -1
  553. package/utils/chunk_array.js +0 -1
  554. package/utils/env.cjs +0 -1
  555. package/utils/env.d.cts +0 -1
  556. package/utils/env.d.ts +0 -1
  557. package/utils/env.js +0 -1
  558. package/utils/event_source_parse.cjs +0 -1
  559. package/utils/event_source_parse.d.cts +0 -1
  560. package/utils/event_source_parse.d.ts +0 -1
  561. package/utils/event_source_parse.js +0 -1
  562. package/utils/format.cjs +0 -1
  563. package/utils/format.d.cts +0 -1
  564. package/utils/format.d.ts +0 -1
  565. package/utils/format.js +0 -1
  566. package/utils/function_calling.cjs +0 -1
  567. package/utils/function_calling.d.cts +0 -1
  568. package/utils/function_calling.d.ts +0 -1
  569. package/utils/function_calling.js +0 -1
  570. package/utils/hash.cjs +0 -1
  571. package/utils/hash.d.cts +0 -1
  572. package/utils/hash.d.ts +0 -1
  573. package/utils/hash.js +0 -1
  574. package/utils/json_patch.cjs +0 -1
  575. package/utils/json_patch.d.cts +0 -1
  576. package/utils/json_patch.d.ts +0 -1
  577. package/utils/json_patch.js +0 -1
  578. package/utils/json_schema.cjs +0 -1
  579. package/utils/json_schema.d.cts +0 -1
  580. package/utils/json_schema.d.ts +0 -1
  581. package/utils/json_schema.js +0 -1
  582. package/utils/math.cjs +0 -1
  583. package/utils/math.d.cts +0 -1
  584. package/utils/math.d.ts +0 -1
  585. package/utils/math.js +0 -1
  586. package/utils/stream.cjs +0 -1
  587. package/utils/stream.d.cts +0 -1
  588. package/utils/stream.d.ts +0 -1
  589. package/utils/stream.js +0 -1
  590. package/utils/testing.cjs +0 -1
  591. package/utils/testing.d.cts +0 -1
  592. package/utils/testing.d.ts +0 -1
  593. package/utils/testing.js +0 -1
  594. package/utils/tiktoken.cjs +0 -1
  595. package/utils/tiktoken.d.cts +0 -1
  596. package/utils/tiktoken.d.ts +0 -1
  597. package/utils/tiktoken.js +0 -1
  598. package/utils/types.cjs +0 -1
  599. package/utils/types.d.cts +0 -1
  600. package/utils/types.d.ts +0 -1
  601. package/utils/types.js +0 -1
  602. package/vectorstores.cjs +0 -1
  603. package/vectorstores.d.cts +0 -1
  604. package/vectorstores.d.ts +0 -1
  605. package/vectorstores.js +0 -1
@@ -1 +1 @@
1
- {"version":3,"file":"manager.js","names":["arg: Callbacks | BaseCallbackConfig | undefined","handler: BaseCallbackHandler","runId: string","handlers: BaseCallbackHandler[]","inheritableHandlers: BaseCallbackHandler[]","tags: string[]","inheritableTags: string[]","metadata: Record<string, unknown>","inheritableMetadata: Record<string, unknown>","_parentRunId?: string","text: string","eventName: string","data: any","_runId?: string","_tags?: string[]","_metadata?: Record<string, any>","tag?: string","documents: DocumentInterface[]","err: Error | unknown","token: string","idx?: NewTokenIndices","fields?: HandleLLMNewTokenCallbackFields","extraParams?: Record<string, unknown>","err","output: LLMResult","kwargs?: { inputs?: Record<string, unknown> }","output: ChainValues","action: AgentAction","action: AgentFinish","output: any","parentRunId?: string","options?: {\n handlers?: BaseCallbackHandler[];\n inheritableHandlers?: BaseCallbackHandler[];\n tags?: string[];\n inheritableTags?: string[];\n metadata?: Record<string, unknown>;\n inheritableMetadata?: Record<string, unknown>;\n }","llm: Serialized","prompts: string[]","runId: string | undefined","_parentRunId: string | undefined","extraParams: Record<string, unknown> | undefined","_tags: string[] | undefined","_metadata: Record<string, unknown> | undefined","runName: string | undefined","uuidv4","messages: BaseMessage[][]","chain: Serialized","inputs: ChainValues","runType: string | undefined","tool: Serialized","input: string","retriever: Serialized","query: string","additionalHandlers: BaseCallbackHandler[]","handlers: CallbackHandlerMethods","inheritableHandlers?: Callbacks","localHandlers?: Callbacks","inheritableTags?: string[]","localTags?: string[]","inheritableMetadata?: Record<string, unknown>","localMetadata?: Record<string, unknown>","options?: CallbackManagerOptions","callbackManager: CallbackManager | undefined","handler: BaseCallbackHandler | undefined","handler: BaseCallbackHandler | CallbackHandlerMethods"],"sources":["../../src/callbacks/manager.ts"],"sourcesContent":["import { v4 as uuidv4 } from \"uuid\";\nimport { AgentAction, AgentFinish } from \"../agents.js\";\nimport type { ChainValues } from \"../utils/types/index.js\";\nimport { LLMResult } from \"../outputs.js\";\nimport {\n BaseCallbackHandler,\n CallbackHandlerMethods,\n HandleLLMNewTokenCallbackFields,\n isBaseCallbackHandler,\n NewTokenIndices,\n} from \"./base.js\";\nimport { ConsoleCallbackHandler } from \"../tracers/console.js\";\nimport { type BaseMessage } from \"../messages/base.js\";\nimport { getBufferString } from \"../messages/utils.js\";\nimport { getEnvironmentVariable } from \"../utils/env.js\";\nimport { LangChainTracer } from \"../tracers/tracer_langchain.js\";\nimport { consumeCallback } from \"./promises.js\";\nimport { Serialized } from \"../load/serializable.js\";\nimport type { DocumentInterface } from \"../documents/document.js\";\nimport { isTracingEnabled } from \"../utils/callbacks.js\";\nimport { isBaseTracer } from \"../tracers/base.js\";\nimport {\n getContextVariable,\n _getConfigureHooks,\n} from \"../singletons/async_local_storage/context.js\";\n\ntype BaseCallbackManagerMethods = {\n [K in keyof CallbackHandlerMethods]?: (\n ...args: Parameters<Required<CallbackHandlerMethods>[K]>\n ) => Promise<unknown>;\n};\n\nexport interface CallbackManagerOptions {\n verbose?: boolean;\n tracing?: boolean;\n}\n\nexport type Callbacks =\n | CallbackManager\n | (BaseCallbackHandler | CallbackHandlerMethods)[];\n\nexport interface BaseCallbackConfig {\n /**\n * Name for the tracer run for this call. Defaults to the name of the class.\n */\n runName?: string;\n\n /**\n * Tags for this call and any sub-calls (eg. a Chain calling an LLM).\n * You can use these to filter calls.\n */\n tags?: string[];\n\n /**\n * Metadata for this call and any sub-calls (eg. a Chain calling an LLM).\n * Keys should be strings, values should be JSON-serializable.\n */\n metadata?: Record<string, unknown>;\n\n /**\n * Callbacks for this call and any sub-calls (eg. a Chain calling an LLM).\n * Tags are passed to all callbacks, metadata is passed to handle*Start callbacks.\n */\n callbacks?: Callbacks;\n\n /**\n * Unique identifier for the tracer run for this call. If not provided, a new UUID\n * will be generated.\n */\n runId?: string;\n}\n\nexport function parseCallbackConfigArg(\n arg: Callbacks | BaseCallbackConfig | undefined\n): BaseCallbackConfig {\n if (!arg) {\n return {};\n } else if (Array.isArray(arg) || \"name\" in arg) {\n return { callbacks: arg };\n } else {\n return arg;\n }\n}\n\n/**\n * Manage callbacks from different components of LangChain.\n */\nexport abstract class BaseCallbackManager {\n abstract addHandler(handler: BaseCallbackHandler): void;\n\n abstract removeHandler(handler: BaseCallbackHandler): void;\n\n abstract setHandlers(handlers: BaseCallbackHandler[]): void;\n\n setHandler(handler: BaseCallbackHandler): void {\n return this.setHandlers([handler]);\n }\n}\n\n/**\n * Base class for run manager in LangChain.\n */\nexport class BaseRunManager {\n constructor(\n public readonly runId: string,\n public readonly handlers: BaseCallbackHandler[],\n protected readonly inheritableHandlers: BaseCallbackHandler[],\n protected readonly tags: string[],\n protected readonly inheritableTags: string[],\n protected readonly metadata: Record<string, unknown>,\n protected readonly inheritableMetadata: Record<string, unknown>,\n protected readonly _parentRunId?: string\n ) {}\n\n get parentRunId() {\n return this._parentRunId;\n }\n\n async handleText(text: string): Promise<void> {\n await Promise.all(\n this.handlers.map((handler) =>\n consumeCallback(async () => {\n try {\n await handler.handleText?.(\n text,\n this.runId,\n this._parentRunId,\n this.tags\n );\n } catch (err) {\n const logFunction = handler.raiseError\n ? console.error\n : console.warn;\n logFunction(\n `Error in handler ${handler.constructor.name}, handleText: ${err}`\n );\n if (handler.raiseError) {\n throw err;\n }\n }\n }, handler.awaitHandlers)\n )\n );\n }\n\n async handleCustomEvent(\n eventName: string,\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n data: any,\n _runId?: string,\n _tags?: string[],\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n _metadata?: Record<string, any>\n ): Promise<void> {\n await Promise.all(\n this.handlers.map((handler) =>\n consumeCallback(async () => {\n try {\n await handler.handleCustomEvent?.(\n eventName,\n data,\n this.runId,\n this.tags,\n this.metadata\n );\n } catch (err) {\n const logFunction = handler.raiseError\n ? console.error\n : console.warn;\n logFunction(\n `Error in handler ${handler.constructor.name}, handleCustomEvent: ${err}`\n );\n if (handler.raiseError) {\n throw err;\n }\n }\n }, handler.awaitHandlers)\n )\n );\n }\n}\n\n/**\n * Manages callbacks for retriever runs.\n */\nexport class CallbackManagerForRetrieverRun\n extends BaseRunManager\n implements BaseCallbackManagerMethods\n{\n getChild(tag?: string): CallbackManager {\n // eslint-disable-next-line @typescript-eslint/no-use-before-define\n const manager = new CallbackManager(this.runId);\n manager.setHandlers(this.inheritableHandlers);\n manager.addTags(this.inheritableTags);\n manager.addMetadata(this.inheritableMetadata);\n if (tag) {\n manager.addTags([tag], false);\n }\n return manager;\n }\n\n async handleRetrieverEnd(documents: DocumentInterface[]): Promise<void> {\n await Promise.all(\n this.handlers.map((handler) =>\n consumeCallback(async () => {\n if (!handler.ignoreRetriever) {\n try {\n await handler.handleRetrieverEnd?.(\n documents,\n this.runId,\n this._parentRunId,\n this.tags\n );\n } catch (err) {\n const logFunction = handler.raiseError\n ? console.error\n : console.warn;\n logFunction(\n `Error in handler ${handler.constructor.name}, handleRetriever`\n );\n if (handler.raiseError) {\n throw err;\n }\n }\n }\n }, handler.awaitHandlers)\n )\n );\n }\n\n async handleRetrieverError(err: Error | unknown): Promise<void> {\n await Promise.all(\n this.handlers.map((handler) =>\n consumeCallback(async () => {\n if (!handler.ignoreRetriever) {\n try {\n await handler.handleRetrieverError?.(\n err,\n this.runId,\n this._parentRunId,\n this.tags\n );\n } catch (error) {\n const logFunction = handler.raiseError\n ? console.error\n : console.warn;\n logFunction(\n `Error in handler ${handler.constructor.name}, handleRetrieverError: ${error}`\n );\n if (handler.raiseError) {\n throw err;\n }\n }\n }\n }, handler.awaitHandlers)\n )\n );\n }\n}\n\nexport class CallbackManagerForLLMRun\n extends BaseRunManager\n implements BaseCallbackManagerMethods\n{\n async handleLLMNewToken(\n token: string,\n idx?: NewTokenIndices,\n _runId?: string,\n _parentRunId?: string,\n _tags?: string[],\n fields?: HandleLLMNewTokenCallbackFields\n ): Promise<void> {\n await Promise.all(\n this.handlers.map((handler) =>\n consumeCallback(async () => {\n if (!handler.ignoreLLM) {\n try {\n await handler.handleLLMNewToken?.(\n token,\n idx ?? { prompt: 0, completion: 0 },\n this.runId,\n this._parentRunId,\n this.tags,\n fields\n );\n } catch (err) {\n const logFunction = handler.raiseError\n ? console.error\n : console.warn;\n logFunction(\n `Error in handler ${handler.constructor.name}, handleLLMNewToken: ${err}`\n );\n if (handler.raiseError) {\n throw err;\n }\n }\n }\n }, handler.awaitHandlers)\n )\n );\n }\n\n async handleLLMError(\n err: Error | unknown,\n _runId?: string,\n _parentRunId?: string,\n _tags?: string[],\n extraParams?: Record<string, unknown>\n ): Promise<void> {\n await Promise.all(\n this.handlers.map((handler) =>\n consumeCallback(async () => {\n if (!handler.ignoreLLM) {\n try {\n await handler.handleLLMError?.(\n err,\n this.runId,\n this._parentRunId,\n this.tags,\n extraParams\n );\n } catch (err) {\n const logFunction = handler.raiseError\n ? console.error\n : console.warn;\n logFunction(\n `Error in handler ${handler.constructor.name}, handleLLMError: ${err}`\n );\n if (handler.raiseError) {\n throw err;\n }\n }\n }\n }, handler.awaitHandlers)\n )\n );\n }\n\n async handleLLMEnd(\n output: LLMResult,\n _runId?: string,\n _parentRunId?: string,\n _tags?: string[],\n extraParams?: Record<string, unknown>\n ): Promise<void> {\n await Promise.all(\n this.handlers.map((handler) =>\n consumeCallback(async () => {\n if (!handler.ignoreLLM) {\n try {\n await handler.handleLLMEnd?.(\n output,\n this.runId,\n this._parentRunId,\n this.tags,\n extraParams\n );\n } catch (err) {\n const logFunction = handler.raiseError\n ? console.error\n : console.warn;\n logFunction(\n `Error in handler ${handler.constructor.name}, handleLLMEnd: ${err}`\n );\n if (handler.raiseError) {\n throw err;\n }\n }\n }\n }, handler.awaitHandlers)\n )\n );\n }\n}\n\nexport class CallbackManagerForChainRun\n extends BaseRunManager\n implements BaseCallbackManagerMethods\n{\n getChild(tag?: string): CallbackManager {\n // eslint-disable-next-line @typescript-eslint/no-use-before-define\n const manager = new CallbackManager(this.runId);\n manager.setHandlers(this.inheritableHandlers);\n manager.addTags(this.inheritableTags);\n manager.addMetadata(this.inheritableMetadata);\n if (tag) {\n manager.addTags([tag], false);\n }\n return manager;\n }\n\n async handleChainError(\n err: Error | unknown,\n _runId?: string,\n _parentRunId?: string,\n _tags?: string[],\n kwargs?: { inputs?: Record<string, unknown> }\n ): Promise<void> {\n await Promise.all(\n this.handlers.map((handler) =>\n consumeCallback(async () => {\n if (!handler.ignoreChain) {\n try {\n await handler.handleChainError?.(\n err,\n this.runId,\n this._parentRunId,\n this.tags,\n kwargs\n );\n } catch (err) {\n const logFunction = handler.raiseError\n ? console.error\n : console.warn;\n logFunction(\n `Error in handler ${handler.constructor.name}, handleChainError: ${err}`\n );\n if (handler.raiseError) {\n throw err;\n }\n }\n }\n }, handler.awaitHandlers)\n )\n );\n }\n\n async handleChainEnd(\n output: ChainValues,\n _runId?: string,\n _parentRunId?: string,\n _tags?: string[],\n kwargs?: { inputs?: Record<string, unknown> }\n ): Promise<void> {\n await Promise.all(\n this.handlers.map((handler) =>\n consumeCallback(async () => {\n if (!handler.ignoreChain) {\n try {\n await handler.handleChainEnd?.(\n output,\n this.runId,\n this._parentRunId,\n this.tags,\n kwargs\n );\n } catch (err) {\n const logFunction = handler.raiseError\n ? console.error\n : console.warn;\n logFunction(\n `Error in handler ${handler.constructor.name}, handleChainEnd: ${err}`\n );\n if (handler.raiseError) {\n throw err;\n }\n }\n }\n }, handler.awaitHandlers)\n )\n );\n }\n\n async handleAgentAction(action: AgentAction): Promise<void> {\n await Promise.all(\n this.handlers.map((handler) =>\n consumeCallback(async () => {\n if (!handler.ignoreAgent) {\n try {\n await handler.handleAgentAction?.(\n action,\n this.runId,\n this._parentRunId,\n this.tags\n );\n } catch (err) {\n const logFunction = handler.raiseError\n ? console.error\n : console.warn;\n logFunction(\n `Error in handler ${handler.constructor.name}, handleAgentAction: ${err}`\n );\n if (handler.raiseError) {\n throw err;\n }\n }\n }\n }, handler.awaitHandlers)\n )\n );\n }\n\n async handleAgentEnd(action: AgentFinish): Promise<void> {\n await Promise.all(\n this.handlers.map((handler) =>\n consumeCallback(async () => {\n if (!handler.ignoreAgent) {\n try {\n await handler.handleAgentEnd?.(\n action,\n this.runId,\n this._parentRunId,\n this.tags\n );\n } catch (err) {\n const logFunction = handler.raiseError\n ? console.error\n : console.warn;\n logFunction(\n `Error in handler ${handler.constructor.name}, handleAgentEnd: ${err}`\n );\n if (handler.raiseError) {\n throw err;\n }\n }\n }\n }, handler.awaitHandlers)\n )\n );\n }\n}\n\nexport class CallbackManagerForToolRun\n extends BaseRunManager\n implements BaseCallbackManagerMethods\n{\n getChild(tag?: string): CallbackManager {\n // eslint-disable-next-line @typescript-eslint/no-use-before-define\n const manager = new CallbackManager(this.runId);\n manager.setHandlers(this.inheritableHandlers);\n manager.addTags(this.inheritableTags);\n manager.addMetadata(this.inheritableMetadata);\n if (tag) {\n manager.addTags([tag], false);\n }\n return manager;\n }\n\n async handleToolError(err: Error | unknown): Promise<void> {\n await Promise.all(\n this.handlers.map((handler) =>\n consumeCallback(async () => {\n if (!handler.ignoreAgent) {\n try {\n await handler.handleToolError?.(\n err,\n this.runId,\n this._parentRunId,\n this.tags\n );\n } catch (err) {\n const logFunction = handler.raiseError\n ? console.error\n : console.warn;\n logFunction(\n `Error in handler ${handler.constructor.name}, handleToolError: ${err}`\n );\n if (handler.raiseError) {\n throw err;\n }\n }\n }\n }, handler.awaitHandlers)\n )\n );\n }\n\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n async handleToolEnd(output: any): Promise<void> {\n await Promise.all(\n this.handlers.map((handler) =>\n consumeCallback(async () => {\n if (!handler.ignoreAgent) {\n try {\n await handler.handleToolEnd?.(\n output,\n this.runId,\n this._parentRunId,\n this.tags\n );\n } catch (err) {\n const logFunction = handler.raiseError\n ? console.error\n : console.warn;\n logFunction(\n `Error in handler ${handler.constructor.name}, handleToolEnd: ${err}`\n );\n if (handler.raiseError) {\n throw err;\n }\n }\n }\n }, handler.awaitHandlers)\n )\n );\n }\n}\n\n/**\n * @example\n * ```typescript\n * const prompt = PromptTemplate.fromTemplate(\"What is the answer to {question}?\");\n *\n * // Example of using LLMChain with OpenAI and a simple prompt\n * const chain = new LLMChain({\n * llm: new ChatOpenAI({ model: \"gpt-4o-mini\", temperature: 0.9 }),\n * prompt,\n * });\n *\n * // Running the chain with a single question\n * const result = await chain.call({\n * question: \"What is the airspeed velocity of an unladen swallow?\",\n * });\n * console.log(\"The answer is:\", result);\n * ```\n */\nexport class CallbackManager\n extends BaseCallbackManager\n implements BaseCallbackManagerMethods\n{\n handlers: BaseCallbackHandler[] = [];\n\n inheritableHandlers: BaseCallbackHandler[] = [];\n\n tags: string[] = [];\n\n inheritableTags: string[] = [];\n\n metadata: Record<string, unknown> = {};\n\n inheritableMetadata: Record<string, unknown> = {};\n\n name = \"callback_manager\";\n\n public _parentRunId?: string;\n\n constructor(\n parentRunId?: string,\n options?: {\n handlers?: BaseCallbackHandler[];\n inheritableHandlers?: BaseCallbackHandler[];\n tags?: string[];\n inheritableTags?: string[];\n metadata?: Record<string, unknown>;\n inheritableMetadata?: Record<string, unknown>;\n }\n ) {\n super();\n this.handlers = options?.handlers ?? this.handlers;\n this.inheritableHandlers =\n options?.inheritableHandlers ?? this.inheritableHandlers;\n this.tags = options?.tags ?? this.tags;\n this.inheritableTags = options?.inheritableTags ?? this.inheritableTags;\n this.metadata = options?.metadata ?? this.metadata;\n this.inheritableMetadata =\n options?.inheritableMetadata ?? this.inheritableMetadata;\n this._parentRunId = parentRunId;\n }\n\n /**\n * Gets the parent run ID, if any.\n *\n * @returns The parent run ID.\n */\n getParentRunId() {\n return this._parentRunId;\n }\n\n async handleLLMStart(\n llm: Serialized,\n prompts: string[],\n runId: string | undefined = undefined,\n _parentRunId: string | undefined = undefined,\n extraParams: Record<string, unknown> | undefined = undefined,\n _tags: string[] | undefined = undefined,\n _metadata: Record<string, unknown> | undefined = undefined,\n runName: string | undefined = undefined\n ): Promise<CallbackManagerForLLMRun[]> {\n return Promise.all(\n prompts.map(async (prompt, idx) => {\n // Can't have duplicate runs with the same run ID (if provided)\n const runId_ = idx === 0 && runId ? runId : uuidv4();\n\n await Promise.all(\n this.handlers.map((handler) => {\n if (handler.ignoreLLM) {\n return;\n }\n if (isBaseTracer(handler)) {\n // Create and add run to the run map.\n // We do this synchronously to avoid race conditions\n // when callbacks are backgrounded.\n handler._createRunForLLMStart(\n llm,\n [prompt],\n runId_,\n this._parentRunId,\n extraParams,\n this.tags,\n this.metadata,\n runName\n );\n }\n return consumeCallback(async () => {\n try {\n await handler.handleLLMStart?.(\n llm,\n [prompt],\n runId_,\n this._parentRunId,\n extraParams,\n this.tags,\n this.metadata,\n runName\n );\n } catch (err) {\n const logFunction = handler.raiseError\n ? console.error\n : console.warn;\n logFunction(\n `Error in handler ${handler.constructor.name}, handleLLMStart: ${err}`\n );\n if (handler.raiseError) {\n throw err;\n }\n }\n }, handler.awaitHandlers);\n })\n );\n\n return new CallbackManagerForLLMRun(\n runId_,\n this.handlers,\n this.inheritableHandlers,\n this.tags,\n this.inheritableTags,\n this.metadata,\n this.inheritableMetadata,\n this._parentRunId\n );\n })\n );\n }\n\n async handleChatModelStart(\n llm: Serialized,\n messages: BaseMessage[][],\n runId: string | undefined = undefined,\n _parentRunId: string | undefined = undefined,\n extraParams: Record<string, unknown> | undefined = undefined,\n _tags: string[] | undefined = undefined,\n _metadata: Record<string, unknown> | undefined = undefined,\n runName: string | undefined = undefined\n ): Promise<CallbackManagerForLLMRun[]> {\n return Promise.all(\n messages.map(async (messageGroup, idx) => {\n // Can't have duplicate runs with the same run ID (if provided)\n const runId_ = idx === 0 && runId ? runId : uuidv4();\n\n await Promise.all(\n this.handlers.map((handler) => {\n if (handler.ignoreLLM) {\n return;\n }\n if (isBaseTracer(handler)) {\n // Create and add run to the run map.\n // We do this synchronously to avoid race conditions\n // when callbacks are backgrounded.\n handler._createRunForChatModelStart(\n llm,\n [messageGroup],\n runId_,\n this._parentRunId,\n extraParams,\n this.tags,\n this.metadata,\n runName\n );\n }\n return consumeCallback(async () => {\n try {\n if (handler.handleChatModelStart) {\n await handler.handleChatModelStart?.(\n llm,\n [messageGroup],\n runId_,\n this._parentRunId,\n extraParams,\n this.tags,\n this.metadata,\n runName\n );\n } else if (handler.handleLLMStart) {\n const messageString = getBufferString(messageGroup);\n await handler.handleLLMStart?.(\n llm,\n [messageString],\n runId_,\n this._parentRunId,\n extraParams,\n this.tags,\n this.metadata,\n runName\n );\n }\n } catch (err) {\n const logFunction = handler.raiseError\n ? console.error\n : console.warn;\n logFunction(\n `Error in handler ${handler.constructor.name}, handleLLMStart: ${err}`\n );\n if (handler.raiseError) {\n throw err;\n }\n }\n }, handler.awaitHandlers);\n })\n );\n\n return new CallbackManagerForLLMRun(\n runId_,\n this.handlers,\n this.inheritableHandlers,\n this.tags,\n this.inheritableTags,\n this.metadata,\n this.inheritableMetadata,\n this._parentRunId\n );\n })\n );\n }\n\n async handleChainStart(\n chain: Serialized,\n inputs: ChainValues,\n runId = uuidv4(),\n runType: string | undefined = undefined,\n _tags: string[] | undefined = undefined,\n _metadata: Record<string, unknown> | undefined = undefined,\n runName: string | undefined = undefined\n ): Promise<CallbackManagerForChainRun> {\n await Promise.all(\n this.handlers.map((handler) => {\n if (handler.ignoreChain) {\n return;\n }\n if (isBaseTracer(handler)) {\n // Create and add run to the run map.\n // We do this synchronously to avoid race conditions\n // when callbacks are backgrounded.\n handler._createRunForChainStart(\n chain,\n inputs,\n runId,\n this._parentRunId,\n this.tags,\n this.metadata,\n runType,\n runName\n );\n }\n return consumeCallback(async () => {\n try {\n await handler.handleChainStart?.(\n chain,\n inputs,\n runId,\n this._parentRunId,\n this.tags,\n this.metadata,\n runType,\n runName\n );\n } catch (err) {\n const logFunction = handler.raiseError\n ? console.error\n : console.warn;\n logFunction(\n `Error in handler ${handler.constructor.name}, handleChainStart: ${err}`\n );\n if (handler.raiseError) {\n throw err;\n }\n }\n }, handler.awaitHandlers);\n })\n );\n return new CallbackManagerForChainRun(\n runId,\n this.handlers,\n this.inheritableHandlers,\n this.tags,\n this.inheritableTags,\n this.metadata,\n this.inheritableMetadata,\n this._parentRunId\n );\n }\n\n async handleToolStart(\n tool: Serialized,\n input: string,\n runId = uuidv4(),\n _parentRunId: string | undefined = undefined,\n _tags: string[] | undefined = undefined,\n _metadata: Record<string, unknown> | undefined = undefined,\n runName: string | undefined = undefined\n ): Promise<CallbackManagerForToolRun> {\n await Promise.all(\n this.handlers.map((handler) => {\n if (handler.ignoreAgent) {\n return;\n }\n if (isBaseTracer(handler)) {\n // Create and add run to the run map.\n // We do this synchronously to avoid race conditions\n // when callbacks are backgrounded.\n handler._createRunForToolStart(\n tool,\n input,\n runId,\n this._parentRunId,\n this.tags,\n this.metadata,\n runName\n );\n }\n return consumeCallback(async () => {\n try {\n await handler.handleToolStart?.(\n tool,\n input,\n runId,\n this._parentRunId,\n this.tags,\n this.metadata,\n runName\n );\n } catch (err) {\n const logFunction = handler.raiseError\n ? console.error\n : console.warn;\n logFunction(\n `Error in handler ${handler.constructor.name}, handleToolStart: ${err}`\n );\n if (handler.raiseError) {\n throw err;\n }\n }\n }, handler.awaitHandlers);\n })\n );\n return new CallbackManagerForToolRun(\n runId,\n this.handlers,\n this.inheritableHandlers,\n this.tags,\n this.inheritableTags,\n this.metadata,\n this.inheritableMetadata,\n this._parentRunId\n );\n }\n\n async handleRetrieverStart(\n retriever: Serialized,\n query: string,\n runId: string = uuidv4(),\n _parentRunId: string | undefined = undefined,\n _tags: string[] | undefined = undefined,\n _metadata: Record<string, unknown> | undefined = undefined,\n runName: string | undefined = undefined\n ): Promise<CallbackManagerForRetrieverRun> {\n await Promise.all(\n this.handlers.map((handler) => {\n if (handler.ignoreRetriever) {\n return;\n }\n if (isBaseTracer(handler)) {\n // Create and add run to the run map.\n // We do this synchronously to avoid race conditions\n // when callbacks are backgrounded.\n handler._createRunForRetrieverStart(\n retriever,\n query,\n runId,\n this._parentRunId,\n this.tags,\n this.metadata,\n runName\n );\n }\n return consumeCallback(async () => {\n try {\n await handler.handleRetrieverStart?.(\n retriever,\n query,\n runId,\n this._parentRunId,\n this.tags,\n this.metadata,\n runName\n );\n } catch (err) {\n const logFunction = handler.raiseError\n ? console.error\n : console.warn;\n logFunction(\n `Error in handler ${handler.constructor.name}, handleRetrieverStart: ${err}`\n );\n if (handler.raiseError) {\n throw err;\n }\n }\n }, handler.awaitHandlers);\n })\n );\n return new CallbackManagerForRetrieverRun(\n runId,\n this.handlers,\n this.inheritableHandlers,\n this.tags,\n this.inheritableTags,\n this.metadata,\n this.inheritableMetadata,\n this._parentRunId\n );\n }\n\n async handleCustomEvent?(\n eventName: string,\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n data: any,\n runId: string,\n _tags?: string[],\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n _metadata?: Record<string, any>\n ): // eslint-disable-next-line @typescript-eslint/no-explicit-any\n Promise<any> {\n await Promise.all(\n this.handlers.map((handler) =>\n consumeCallback(async () => {\n if (!handler.ignoreCustomEvent) {\n try {\n await handler.handleCustomEvent?.(\n eventName,\n data,\n runId,\n this.tags,\n this.metadata\n );\n } catch (err) {\n const logFunction = handler.raiseError\n ? console.error\n : console.warn;\n logFunction(\n `Error in handler ${handler.constructor.name}, handleCustomEvent: ${err}`\n );\n if (handler.raiseError) {\n throw err;\n }\n }\n }\n }, handler.awaitHandlers)\n )\n );\n }\n\n addHandler(handler: BaseCallbackHandler, inherit = true): void {\n this.handlers.push(handler);\n if (inherit) {\n this.inheritableHandlers.push(handler);\n }\n }\n\n removeHandler(handler: BaseCallbackHandler): void {\n this.handlers = this.handlers.filter((_handler) => _handler !== handler);\n this.inheritableHandlers = this.inheritableHandlers.filter(\n (_handler) => _handler !== handler\n );\n }\n\n setHandlers(handlers: BaseCallbackHandler[], inherit = true): void {\n this.handlers = [];\n this.inheritableHandlers = [];\n for (const handler of handlers) {\n this.addHandler(handler, inherit);\n }\n }\n\n addTags(tags: string[], inherit = true): void {\n this.removeTags(tags); // Remove duplicates\n this.tags.push(...tags);\n if (inherit) {\n this.inheritableTags.push(...tags);\n }\n }\n\n removeTags(tags: string[]): void {\n this.tags = this.tags.filter((tag) => !tags.includes(tag));\n this.inheritableTags = this.inheritableTags.filter(\n (tag) => !tags.includes(tag)\n );\n }\n\n addMetadata(metadata: Record<string, unknown>, inherit = true): void {\n this.metadata = { ...this.metadata, ...metadata };\n if (inherit) {\n this.inheritableMetadata = { ...this.inheritableMetadata, ...metadata };\n }\n }\n\n removeMetadata(metadata: Record<string, unknown>): void {\n for (const key of Object.keys(metadata)) {\n delete this.metadata[key];\n delete this.inheritableMetadata[key];\n }\n }\n\n copy(\n additionalHandlers: BaseCallbackHandler[] = [],\n inherit = true\n ): CallbackManager {\n const manager = new CallbackManager(this._parentRunId);\n for (const handler of this.handlers) {\n const inheritable = this.inheritableHandlers.includes(handler);\n manager.addHandler(handler, inheritable);\n }\n for (const tag of this.tags) {\n const inheritable = this.inheritableTags.includes(tag);\n manager.addTags([tag], inheritable);\n }\n for (const key of Object.keys(this.metadata)) {\n const inheritable = Object.keys(this.inheritableMetadata).includes(key);\n manager.addMetadata({ [key]: this.metadata[key] }, inheritable);\n }\n for (const handler of additionalHandlers) {\n if (\n // Prevent multiple copies of console_callback_handler\n manager.handlers\n .filter((h) => h.name === \"console_callback_handler\")\n .some((h) => h.name === handler.name)\n ) {\n continue;\n }\n manager.addHandler(handler, inherit);\n }\n return manager;\n }\n\n static fromHandlers(handlers: CallbackHandlerMethods) {\n class Handler extends BaseCallbackHandler {\n name = uuidv4();\n\n constructor() {\n super();\n Object.assign(this, handlers);\n }\n }\n\n const manager = new this();\n manager.addHandler(new Handler());\n return manager;\n }\n\n static configure(\n inheritableHandlers?: Callbacks,\n localHandlers?: Callbacks,\n inheritableTags?: string[],\n localTags?: string[],\n inheritableMetadata?: Record<string, unknown>,\n localMetadata?: Record<string, unknown>,\n options?: CallbackManagerOptions\n ): CallbackManager | undefined {\n return this._configureSync(\n inheritableHandlers,\n localHandlers,\n inheritableTags,\n localTags,\n inheritableMetadata,\n localMetadata,\n options\n );\n }\n\n // TODO: Deprecate async method in favor of this one.\n static _configureSync(\n inheritableHandlers?: Callbacks,\n localHandlers?: Callbacks,\n inheritableTags?: string[],\n localTags?: string[],\n inheritableMetadata?: Record<string, unknown>,\n localMetadata?: Record<string, unknown>,\n options?: CallbackManagerOptions\n ) {\n let callbackManager: CallbackManager | undefined;\n if (inheritableHandlers || localHandlers) {\n if (Array.isArray(inheritableHandlers) || !inheritableHandlers) {\n callbackManager = new CallbackManager();\n callbackManager.setHandlers(\n inheritableHandlers?.map(ensureHandler) ?? [],\n true\n );\n } else {\n callbackManager = inheritableHandlers;\n }\n\n callbackManager = callbackManager.copy(\n Array.isArray(localHandlers)\n ? localHandlers.map(ensureHandler)\n : localHandlers?.handlers,\n false\n );\n }\n\n const verboseEnabled =\n getEnvironmentVariable(\"LANGCHAIN_VERBOSE\") === \"true\" ||\n options?.verbose;\n\n const tracingV2Enabled =\n LangChainTracer.getTraceableRunTree()?.tracingEnabled ||\n isTracingEnabled();\n\n const tracingEnabled =\n tracingV2Enabled ||\n (getEnvironmentVariable(\"LANGCHAIN_TRACING\") ?? false);\n if (verboseEnabled || tracingEnabled) {\n if (!callbackManager) {\n callbackManager = new CallbackManager();\n }\n if (\n verboseEnabled &&\n !callbackManager.handlers.some(\n (handler) => handler.name === ConsoleCallbackHandler.prototype.name\n )\n ) {\n const consoleHandler = new ConsoleCallbackHandler();\n callbackManager.addHandler(consoleHandler, true);\n }\n if (\n tracingEnabled &&\n !callbackManager.handlers.some(\n (handler) => handler.name === \"langchain_tracer\"\n )\n ) {\n if (tracingV2Enabled) {\n const tracerV2 = new LangChainTracer();\n callbackManager.addHandler(tracerV2, true);\n }\n }\n if (tracingV2Enabled) {\n // handoff between langchain and langsmith/traceable\n // override the parent run ID\n const implicitRunTree = LangChainTracer.getTraceableRunTree();\n if (implicitRunTree && callbackManager._parentRunId === undefined) {\n callbackManager._parentRunId = implicitRunTree.id;\n const tracerV2 = callbackManager.handlers.find(\n (handler) => handler.name === \"langchain_tracer\"\n ) as LangChainTracer | undefined;\n tracerV2?.updateFromRunTree(implicitRunTree);\n }\n }\n }\n\n for (const {\n contextVar,\n inheritable = true,\n handlerClass,\n envVar,\n } of _getConfigureHooks()) {\n const createIfNotInContext =\n envVar && getEnvironmentVariable(envVar) === \"true\" && handlerClass;\n let handler: BaseCallbackHandler | undefined;\n const contextVarValue =\n contextVar !== undefined ? getContextVariable(contextVar) : undefined;\n if (contextVarValue && isBaseCallbackHandler(contextVarValue)) {\n handler = contextVarValue;\n } else if (createIfNotInContext) {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n handler = new (handlerClass as any)({});\n }\n if (handler !== undefined) {\n if (!callbackManager) {\n callbackManager = new CallbackManager();\n }\n\n if (!callbackManager.handlers.some((h) => h.name === handler!.name)) {\n callbackManager.addHandler(handler, inheritable);\n }\n }\n }\n\n if (inheritableTags || localTags) {\n if (callbackManager) {\n callbackManager.addTags(inheritableTags ?? []);\n callbackManager.addTags(localTags ?? [], false);\n }\n }\n if (inheritableMetadata || localMetadata) {\n if (callbackManager) {\n callbackManager.addMetadata(inheritableMetadata ?? {});\n callbackManager.addMetadata(localMetadata ?? {}, false);\n }\n }\n\n return callbackManager;\n }\n}\n\nexport function ensureHandler(\n handler: BaseCallbackHandler | CallbackHandlerMethods\n): BaseCallbackHandler {\n if (\"name\" in handler) {\n return handler;\n }\n\n return BaseCallbackHandler.fromMethods(handler);\n}\n"],"mappings":"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"}
1
+ {"version":3,"file":"manager.js","names":["arg: Callbacks | BaseCallbackConfig | undefined","handler: BaseCallbackHandler","runId: string","handlers: BaseCallbackHandler[]","inheritableHandlers: BaseCallbackHandler[]","tags: string[]","inheritableTags: string[]","metadata: Record<string, unknown>","inheritableMetadata: Record<string, unknown>","_parentRunId?: string","text: string","eventName: string","data: any","_runId?: string","_tags?: string[]","_metadata?: Record<string, any>","tag?: string","documents: DocumentInterface[]","err: Error | unknown","token: string","idx?: NewTokenIndices","fields?: HandleLLMNewTokenCallbackFields","extraParams?: Record<string, unknown>","err","output: LLMResult","kwargs?: { inputs?: Record<string, unknown> }","output: ChainValues","action: AgentAction","action: AgentFinish","output: any","parentRunId?: string","options?: {\n handlers?: BaseCallbackHandler[];\n inheritableHandlers?: BaseCallbackHandler[];\n tags?: string[];\n inheritableTags?: string[];\n metadata?: Record<string, unknown>;\n inheritableMetadata?: Record<string, unknown>;\n }","llm: Serialized","prompts: string[]","runId: string | undefined","_parentRunId: string | undefined","extraParams: Record<string, unknown> | undefined","_tags: string[] | undefined","_metadata: Record<string, unknown> | undefined","runName: string | undefined","uuidv7","messages: BaseMessage[][]","chain: Serialized","inputs: ChainValues","runType: string | undefined","tool: Serialized","input: string","retriever: Serialized","query: string","additionalHandlers: BaseCallbackHandler[]","handlers: CallbackHandlerMethods","inheritableHandlers?: Callbacks","localHandlers?: Callbacks","inheritableTags?: string[]","localTags?: string[]","inheritableMetadata?: Record<string, unknown>","localMetadata?: Record<string, unknown>","options?: CallbackManagerOptions","callbackManager: CallbackManager | undefined","handler: BaseCallbackHandler | undefined","handler: BaseCallbackHandler | CallbackHandlerMethods"],"sources":["../../src/callbacks/manager.ts"],"sourcesContent":["import { v7 as uuidv7 } from \"uuid\";\nimport { AgentAction, AgentFinish } from \"../agents.js\";\nimport type { ChainValues } from \"../utils/types/index.js\";\nimport { LLMResult } from \"../outputs.js\";\nimport {\n BaseCallbackHandler,\n CallbackHandlerMethods,\n HandleLLMNewTokenCallbackFields,\n isBaseCallbackHandler,\n NewTokenIndices,\n} from \"./base.js\";\nimport { ConsoleCallbackHandler } from \"../tracers/console.js\";\nimport { type BaseMessage } from \"../messages/base.js\";\nimport { getBufferString } from \"../messages/utils.js\";\nimport { getEnvironmentVariable } from \"../utils/env.js\";\nimport { LangChainTracer } from \"../tracers/tracer_langchain.js\";\nimport { consumeCallback } from \"./promises.js\";\nimport { Serialized } from \"../load/serializable.js\";\nimport type { DocumentInterface } from \"../documents/document.js\";\nimport { isTracingEnabled } from \"../utils/callbacks.js\";\nimport { isBaseTracer } from \"../tracers/base.js\";\nimport {\n getContextVariable,\n _getConfigureHooks,\n} from \"../singletons/async_local_storage/context.js\";\n\ntype BaseCallbackManagerMethods = {\n [K in keyof CallbackHandlerMethods]?: (\n ...args: Parameters<Required<CallbackHandlerMethods>[K]>\n ) => Promise<unknown>;\n};\n\nexport interface CallbackManagerOptions {\n verbose?: boolean;\n tracing?: boolean;\n}\n\nexport type Callbacks =\n | CallbackManager\n | (BaseCallbackHandler | CallbackHandlerMethods)[];\n\nexport interface BaseCallbackConfig {\n /**\n * Name for the tracer run for this call. Defaults to the name of the class.\n */\n runName?: string;\n\n /**\n * Tags for this call and any sub-calls (eg. a Chain calling an LLM).\n * You can use these to filter calls.\n */\n tags?: string[];\n\n /**\n * Metadata for this call and any sub-calls (eg. a Chain calling an LLM).\n * Keys should be strings, values should be JSON-serializable.\n */\n metadata?: Record<string, unknown>;\n\n /**\n * Callbacks for this call and any sub-calls (eg. a Chain calling an LLM).\n * Tags are passed to all callbacks, metadata is passed to handle*Start callbacks.\n */\n callbacks?: Callbacks;\n\n /**\n * Unique identifier for the tracer run for this call. If not provided, a new UUID\n * will be generated.\n */\n runId?: string;\n}\n\nexport function parseCallbackConfigArg(\n arg: Callbacks | BaseCallbackConfig | undefined\n): BaseCallbackConfig {\n if (!arg) {\n return {};\n } else if (Array.isArray(arg) || \"name\" in arg) {\n return { callbacks: arg };\n } else {\n return arg;\n }\n}\n\n/**\n * Manage callbacks from different components of LangChain.\n */\nexport abstract class BaseCallbackManager {\n abstract addHandler(handler: BaseCallbackHandler): void;\n\n abstract removeHandler(handler: BaseCallbackHandler): void;\n\n abstract setHandlers(handlers: BaseCallbackHandler[]): void;\n\n setHandler(handler: BaseCallbackHandler): void {\n return this.setHandlers([handler]);\n }\n}\n\n/**\n * Base class for run manager in LangChain.\n */\nexport class BaseRunManager {\n constructor(\n public readonly runId: string,\n public readonly handlers: BaseCallbackHandler[],\n protected readonly inheritableHandlers: BaseCallbackHandler[],\n protected readonly tags: string[],\n protected readonly inheritableTags: string[],\n protected readonly metadata: Record<string, unknown>,\n protected readonly inheritableMetadata: Record<string, unknown>,\n protected readonly _parentRunId?: string\n ) {}\n\n get parentRunId() {\n return this._parentRunId;\n }\n\n async handleText(text: string): Promise<void> {\n await Promise.all(\n this.handlers.map((handler) =>\n consumeCallback(async () => {\n try {\n await handler.handleText?.(\n text,\n this.runId,\n this._parentRunId,\n this.tags\n );\n } catch (err) {\n const logFunction = handler.raiseError\n ? console.error\n : console.warn;\n logFunction(\n `Error in handler ${handler.constructor.name}, handleText: ${err}`\n );\n if (handler.raiseError) {\n throw err;\n }\n }\n }, handler.awaitHandlers)\n )\n );\n }\n\n async handleCustomEvent(\n eventName: string,\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n data: any,\n _runId?: string,\n _tags?: string[],\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n _metadata?: Record<string, any>\n ): Promise<void> {\n await Promise.all(\n this.handlers.map((handler) =>\n consumeCallback(async () => {\n try {\n await handler.handleCustomEvent?.(\n eventName,\n data,\n this.runId,\n this.tags,\n this.metadata\n );\n } catch (err) {\n const logFunction = handler.raiseError\n ? console.error\n : console.warn;\n logFunction(\n `Error in handler ${handler.constructor.name}, handleCustomEvent: ${err}`\n );\n if (handler.raiseError) {\n throw err;\n }\n }\n }, handler.awaitHandlers)\n )\n );\n }\n}\n\n/**\n * Manages callbacks for retriever runs.\n */\nexport class CallbackManagerForRetrieverRun\n extends BaseRunManager\n implements BaseCallbackManagerMethods\n{\n getChild(tag?: string): CallbackManager {\n // eslint-disable-next-line @typescript-eslint/no-use-before-define\n const manager = new CallbackManager(this.runId);\n manager.setHandlers(this.inheritableHandlers);\n manager.addTags(this.inheritableTags);\n manager.addMetadata(this.inheritableMetadata);\n if (tag) {\n manager.addTags([tag], false);\n }\n return manager;\n }\n\n async handleRetrieverEnd(documents: DocumentInterface[]): Promise<void> {\n await Promise.all(\n this.handlers.map((handler) =>\n consumeCallback(async () => {\n if (!handler.ignoreRetriever) {\n try {\n await handler.handleRetrieverEnd?.(\n documents,\n this.runId,\n this._parentRunId,\n this.tags\n );\n } catch (err) {\n const logFunction = handler.raiseError\n ? console.error\n : console.warn;\n logFunction(\n `Error in handler ${handler.constructor.name}, handleRetriever`\n );\n if (handler.raiseError) {\n throw err;\n }\n }\n }\n }, handler.awaitHandlers)\n )\n );\n }\n\n async handleRetrieverError(err: Error | unknown): Promise<void> {\n await Promise.all(\n this.handlers.map((handler) =>\n consumeCallback(async () => {\n if (!handler.ignoreRetriever) {\n try {\n await handler.handleRetrieverError?.(\n err,\n this.runId,\n this._parentRunId,\n this.tags\n );\n } catch (error) {\n const logFunction = handler.raiseError\n ? console.error\n : console.warn;\n logFunction(\n `Error in handler ${handler.constructor.name}, handleRetrieverError: ${error}`\n );\n if (handler.raiseError) {\n throw err;\n }\n }\n }\n }, handler.awaitHandlers)\n )\n );\n }\n}\n\nexport class CallbackManagerForLLMRun\n extends BaseRunManager\n implements BaseCallbackManagerMethods\n{\n async handleLLMNewToken(\n token: string,\n idx?: NewTokenIndices,\n _runId?: string,\n _parentRunId?: string,\n _tags?: string[],\n fields?: HandleLLMNewTokenCallbackFields\n ): Promise<void> {\n await Promise.all(\n this.handlers.map((handler) =>\n consumeCallback(async () => {\n if (!handler.ignoreLLM) {\n try {\n await handler.handleLLMNewToken?.(\n token,\n idx ?? { prompt: 0, completion: 0 },\n this.runId,\n this._parentRunId,\n this.tags,\n fields\n );\n } catch (err) {\n const logFunction = handler.raiseError\n ? console.error\n : console.warn;\n logFunction(\n `Error in handler ${handler.constructor.name}, handleLLMNewToken: ${err}`\n );\n if (handler.raiseError) {\n throw err;\n }\n }\n }\n }, handler.awaitHandlers)\n )\n );\n }\n\n async handleLLMError(\n err: Error | unknown,\n _runId?: string,\n _parentRunId?: string,\n _tags?: string[],\n extraParams?: Record<string, unknown>\n ): Promise<void> {\n await Promise.all(\n this.handlers.map((handler) =>\n consumeCallback(async () => {\n if (!handler.ignoreLLM) {\n try {\n await handler.handleLLMError?.(\n err,\n this.runId,\n this._parentRunId,\n this.tags,\n extraParams\n );\n } catch (err) {\n const logFunction = handler.raiseError\n ? console.error\n : console.warn;\n logFunction(\n `Error in handler ${handler.constructor.name}, handleLLMError: ${err}`\n );\n if (handler.raiseError) {\n throw err;\n }\n }\n }\n }, handler.awaitHandlers)\n )\n );\n }\n\n async handleLLMEnd(\n output: LLMResult,\n _runId?: string,\n _parentRunId?: string,\n _tags?: string[],\n extraParams?: Record<string, unknown>\n ): Promise<void> {\n await Promise.all(\n this.handlers.map((handler) =>\n consumeCallback(async () => {\n if (!handler.ignoreLLM) {\n try {\n await handler.handleLLMEnd?.(\n output,\n this.runId,\n this._parentRunId,\n this.tags,\n extraParams\n );\n } catch (err) {\n const logFunction = handler.raiseError\n ? console.error\n : console.warn;\n logFunction(\n `Error in handler ${handler.constructor.name}, handleLLMEnd: ${err}`\n );\n if (handler.raiseError) {\n throw err;\n }\n }\n }\n }, handler.awaitHandlers)\n )\n );\n }\n}\n\nexport class CallbackManagerForChainRun\n extends BaseRunManager\n implements BaseCallbackManagerMethods\n{\n getChild(tag?: string): CallbackManager {\n // eslint-disable-next-line @typescript-eslint/no-use-before-define\n const manager = new CallbackManager(this.runId);\n manager.setHandlers(this.inheritableHandlers);\n manager.addTags(this.inheritableTags);\n manager.addMetadata(this.inheritableMetadata);\n if (tag) {\n manager.addTags([tag], false);\n }\n return manager;\n }\n\n async handleChainError(\n err: Error | unknown,\n _runId?: string,\n _parentRunId?: string,\n _tags?: string[],\n kwargs?: { inputs?: Record<string, unknown> }\n ): Promise<void> {\n await Promise.all(\n this.handlers.map((handler) =>\n consumeCallback(async () => {\n if (!handler.ignoreChain) {\n try {\n await handler.handleChainError?.(\n err,\n this.runId,\n this._parentRunId,\n this.tags,\n kwargs\n );\n } catch (err) {\n const logFunction = handler.raiseError\n ? console.error\n : console.warn;\n logFunction(\n `Error in handler ${handler.constructor.name}, handleChainError: ${err}`\n );\n if (handler.raiseError) {\n throw err;\n }\n }\n }\n }, handler.awaitHandlers)\n )\n );\n }\n\n async handleChainEnd(\n output: ChainValues,\n _runId?: string,\n _parentRunId?: string,\n _tags?: string[],\n kwargs?: { inputs?: Record<string, unknown> }\n ): Promise<void> {\n await Promise.all(\n this.handlers.map((handler) =>\n consumeCallback(async () => {\n if (!handler.ignoreChain) {\n try {\n await handler.handleChainEnd?.(\n output,\n this.runId,\n this._parentRunId,\n this.tags,\n kwargs\n );\n } catch (err) {\n const logFunction = handler.raiseError\n ? console.error\n : console.warn;\n logFunction(\n `Error in handler ${handler.constructor.name}, handleChainEnd: ${err}`\n );\n if (handler.raiseError) {\n throw err;\n }\n }\n }\n }, handler.awaitHandlers)\n )\n );\n }\n\n async handleAgentAction(action: AgentAction): Promise<void> {\n await Promise.all(\n this.handlers.map((handler) =>\n consumeCallback(async () => {\n if (!handler.ignoreAgent) {\n try {\n await handler.handleAgentAction?.(\n action,\n this.runId,\n this._parentRunId,\n this.tags\n );\n } catch (err) {\n const logFunction = handler.raiseError\n ? console.error\n : console.warn;\n logFunction(\n `Error in handler ${handler.constructor.name}, handleAgentAction: ${err}`\n );\n if (handler.raiseError) {\n throw err;\n }\n }\n }\n }, handler.awaitHandlers)\n )\n );\n }\n\n async handleAgentEnd(action: AgentFinish): Promise<void> {\n await Promise.all(\n this.handlers.map((handler) =>\n consumeCallback(async () => {\n if (!handler.ignoreAgent) {\n try {\n await handler.handleAgentEnd?.(\n action,\n this.runId,\n this._parentRunId,\n this.tags\n );\n } catch (err) {\n const logFunction = handler.raiseError\n ? console.error\n : console.warn;\n logFunction(\n `Error in handler ${handler.constructor.name}, handleAgentEnd: ${err}`\n );\n if (handler.raiseError) {\n throw err;\n }\n }\n }\n }, handler.awaitHandlers)\n )\n );\n }\n}\n\nexport class CallbackManagerForToolRun\n extends BaseRunManager\n implements BaseCallbackManagerMethods\n{\n getChild(tag?: string): CallbackManager {\n // eslint-disable-next-line @typescript-eslint/no-use-before-define\n const manager = new CallbackManager(this.runId);\n manager.setHandlers(this.inheritableHandlers);\n manager.addTags(this.inheritableTags);\n manager.addMetadata(this.inheritableMetadata);\n if (tag) {\n manager.addTags([tag], false);\n }\n return manager;\n }\n\n async handleToolError(err: Error | unknown): Promise<void> {\n await Promise.all(\n this.handlers.map((handler) =>\n consumeCallback(async () => {\n if (!handler.ignoreAgent) {\n try {\n await handler.handleToolError?.(\n err,\n this.runId,\n this._parentRunId,\n this.tags\n );\n } catch (err) {\n const logFunction = handler.raiseError\n ? console.error\n : console.warn;\n logFunction(\n `Error in handler ${handler.constructor.name}, handleToolError: ${err}`\n );\n if (handler.raiseError) {\n throw err;\n }\n }\n }\n }, handler.awaitHandlers)\n )\n );\n }\n\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n async handleToolEnd(output: any): Promise<void> {\n await Promise.all(\n this.handlers.map((handler) =>\n consumeCallback(async () => {\n if (!handler.ignoreAgent) {\n try {\n await handler.handleToolEnd?.(\n output,\n this.runId,\n this._parentRunId,\n this.tags\n );\n } catch (err) {\n const logFunction = handler.raiseError\n ? console.error\n : console.warn;\n logFunction(\n `Error in handler ${handler.constructor.name}, handleToolEnd: ${err}`\n );\n if (handler.raiseError) {\n throw err;\n }\n }\n }\n }, handler.awaitHandlers)\n )\n );\n }\n}\n\n/**\n * @example\n * ```typescript\n * const prompt = PromptTemplate.fromTemplate(\"What is the answer to {question}?\");\n *\n * // Example of using LLMChain with OpenAI and a simple prompt\n * const chain = new LLMChain({\n * llm: new ChatOpenAI({ model: \"gpt-4o-mini\", temperature: 0.9 }),\n * prompt,\n * });\n *\n * // Running the chain with a single question\n * const result = await chain.call({\n * question: \"What is the airspeed velocity of an unladen swallow?\",\n * });\n * console.log(\"The answer is:\", result);\n * ```\n */\nexport class CallbackManager\n extends BaseCallbackManager\n implements BaseCallbackManagerMethods\n{\n handlers: BaseCallbackHandler[] = [];\n\n inheritableHandlers: BaseCallbackHandler[] = [];\n\n tags: string[] = [];\n\n inheritableTags: string[] = [];\n\n metadata: Record<string, unknown> = {};\n\n inheritableMetadata: Record<string, unknown> = {};\n\n name = \"callback_manager\";\n\n public _parentRunId?: string;\n\n constructor(\n parentRunId?: string,\n options?: {\n handlers?: BaseCallbackHandler[];\n inheritableHandlers?: BaseCallbackHandler[];\n tags?: string[];\n inheritableTags?: string[];\n metadata?: Record<string, unknown>;\n inheritableMetadata?: Record<string, unknown>;\n }\n ) {\n super();\n this.handlers = options?.handlers ?? this.handlers;\n this.inheritableHandlers =\n options?.inheritableHandlers ?? this.inheritableHandlers;\n this.tags = options?.tags ?? this.tags;\n this.inheritableTags = options?.inheritableTags ?? this.inheritableTags;\n this.metadata = options?.metadata ?? this.metadata;\n this.inheritableMetadata =\n options?.inheritableMetadata ?? this.inheritableMetadata;\n this._parentRunId = parentRunId;\n }\n\n /**\n * Gets the parent run ID, if any.\n *\n * @returns The parent run ID.\n */\n getParentRunId() {\n return this._parentRunId;\n }\n\n async handleLLMStart(\n llm: Serialized,\n prompts: string[],\n runId: string | undefined = undefined,\n _parentRunId: string | undefined = undefined,\n extraParams: Record<string, unknown> | undefined = undefined,\n _tags: string[] | undefined = undefined,\n _metadata: Record<string, unknown> | undefined = undefined,\n runName: string | undefined = undefined\n ): Promise<CallbackManagerForLLMRun[]> {\n return Promise.all(\n prompts.map(async (prompt, idx) => {\n // Can't have duplicate runs with the same run ID (if provided)\n const runId_ = idx === 0 && runId ? runId : uuidv7();\n\n await Promise.all(\n this.handlers.map((handler) => {\n if (handler.ignoreLLM) {\n return;\n }\n if (isBaseTracer(handler)) {\n // Create and add run to the run map.\n // We do this synchronously to avoid race conditions\n // when callbacks are backgrounded.\n handler._createRunForLLMStart(\n llm,\n [prompt],\n runId_,\n this._parentRunId,\n extraParams,\n this.tags,\n this.metadata,\n runName\n );\n }\n return consumeCallback(async () => {\n try {\n await handler.handleLLMStart?.(\n llm,\n [prompt],\n runId_,\n this._parentRunId,\n extraParams,\n this.tags,\n this.metadata,\n runName\n );\n } catch (err) {\n const logFunction = handler.raiseError\n ? console.error\n : console.warn;\n logFunction(\n `Error in handler ${handler.constructor.name}, handleLLMStart: ${err}`\n );\n if (handler.raiseError) {\n throw err;\n }\n }\n }, handler.awaitHandlers);\n })\n );\n\n return new CallbackManagerForLLMRun(\n runId_,\n this.handlers,\n this.inheritableHandlers,\n this.tags,\n this.inheritableTags,\n this.metadata,\n this.inheritableMetadata,\n this._parentRunId\n );\n })\n );\n }\n\n async handleChatModelStart(\n llm: Serialized,\n messages: BaseMessage[][],\n runId: string | undefined = undefined,\n _parentRunId: string | undefined = undefined,\n extraParams: Record<string, unknown> | undefined = undefined,\n _tags: string[] | undefined = undefined,\n _metadata: Record<string, unknown> | undefined = undefined,\n runName: string | undefined = undefined\n ): Promise<CallbackManagerForLLMRun[]> {\n return Promise.all(\n messages.map(async (messageGroup, idx) => {\n // Can't have duplicate runs with the same run ID (if provided)\n const runId_ = idx === 0 && runId ? runId : uuidv7();\n\n await Promise.all(\n this.handlers.map((handler) => {\n if (handler.ignoreLLM) {\n return;\n }\n if (isBaseTracer(handler)) {\n // Create and add run to the run map.\n // We do this synchronously to avoid race conditions\n // when callbacks are backgrounded.\n handler._createRunForChatModelStart(\n llm,\n [messageGroup],\n runId_,\n this._parentRunId,\n extraParams,\n this.tags,\n this.metadata,\n runName\n );\n }\n return consumeCallback(async () => {\n try {\n if (handler.handleChatModelStart) {\n await handler.handleChatModelStart?.(\n llm,\n [messageGroup],\n runId_,\n this._parentRunId,\n extraParams,\n this.tags,\n this.metadata,\n runName\n );\n } else if (handler.handleLLMStart) {\n const messageString = getBufferString(messageGroup);\n await handler.handleLLMStart?.(\n llm,\n [messageString],\n runId_,\n this._parentRunId,\n extraParams,\n this.tags,\n this.metadata,\n runName\n );\n }\n } catch (err) {\n const logFunction = handler.raiseError\n ? console.error\n : console.warn;\n logFunction(\n `Error in handler ${handler.constructor.name}, handleLLMStart: ${err}`\n );\n if (handler.raiseError) {\n throw err;\n }\n }\n }, handler.awaitHandlers);\n })\n );\n\n return new CallbackManagerForLLMRun(\n runId_,\n this.handlers,\n this.inheritableHandlers,\n this.tags,\n this.inheritableTags,\n this.metadata,\n this.inheritableMetadata,\n this._parentRunId\n );\n })\n );\n }\n\n async handleChainStart(\n chain: Serialized,\n inputs: ChainValues,\n runId = uuidv7(),\n runType: string | undefined = undefined,\n _tags: string[] | undefined = undefined,\n _metadata: Record<string, unknown> | undefined = undefined,\n runName: string | undefined = undefined\n ): Promise<CallbackManagerForChainRun> {\n await Promise.all(\n this.handlers.map((handler) => {\n if (handler.ignoreChain) {\n return;\n }\n if (isBaseTracer(handler)) {\n // Create and add run to the run map.\n // We do this synchronously to avoid race conditions\n // when callbacks are backgrounded.\n handler._createRunForChainStart(\n chain,\n inputs,\n runId,\n this._parentRunId,\n this.tags,\n this.metadata,\n runType,\n runName\n );\n }\n return consumeCallback(async () => {\n try {\n await handler.handleChainStart?.(\n chain,\n inputs,\n runId,\n this._parentRunId,\n this.tags,\n this.metadata,\n runType,\n runName\n );\n } catch (err) {\n const logFunction = handler.raiseError\n ? console.error\n : console.warn;\n logFunction(\n `Error in handler ${handler.constructor.name}, handleChainStart: ${err}`\n );\n if (handler.raiseError) {\n throw err;\n }\n }\n }, handler.awaitHandlers);\n })\n );\n return new CallbackManagerForChainRun(\n runId,\n this.handlers,\n this.inheritableHandlers,\n this.tags,\n this.inheritableTags,\n this.metadata,\n this.inheritableMetadata,\n this._parentRunId\n );\n }\n\n async handleToolStart(\n tool: Serialized,\n input: string,\n runId = uuidv7(),\n _parentRunId: string | undefined = undefined,\n _tags: string[] | undefined = undefined,\n _metadata: Record<string, unknown> | undefined = undefined,\n runName: string | undefined = undefined\n ): Promise<CallbackManagerForToolRun> {\n await Promise.all(\n this.handlers.map((handler) => {\n if (handler.ignoreAgent) {\n return;\n }\n if (isBaseTracer(handler)) {\n // Create and add run to the run map.\n // We do this synchronously to avoid race conditions\n // when callbacks are backgrounded.\n handler._createRunForToolStart(\n tool,\n input,\n runId,\n this._parentRunId,\n this.tags,\n this.metadata,\n runName\n );\n }\n return consumeCallback(async () => {\n try {\n await handler.handleToolStart?.(\n tool,\n input,\n runId,\n this._parentRunId,\n this.tags,\n this.metadata,\n runName\n );\n } catch (err) {\n const logFunction = handler.raiseError\n ? console.error\n : console.warn;\n logFunction(\n `Error in handler ${handler.constructor.name}, handleToolStart: ${err}`\n );\n if (handler.raiseError) {\n throw err;\n }\n }\n }, handler.awaitHandlers);\n })\n );\n return new CallbackManagerForToolRun(\n runId,\n this.handlers,\n this.inheritableHandlers,\n this.tags,\n this.inheritableTags,\n this.metadata,\n this.inheritableMetadata,\n this._parentRunId\n );\n }\n\n async handleRetrieverStart(\n retriever: Serialized,\n query: string,\n runId: string = uuidv7(),\n _parentRunId: string | undefined = undefined,\n _tags: string[] | undefined = undefined,\n _metadata: Record<string, unknown> | undefined = undefined,\n runName: string | undefined = undefined\n ): Promise<CallbackManagerForRetrieverRun> {\n await Promise.all(\n this.handlers.map((handler) => {\n if (handler.ignoreRetriever) {\n return;\n }\n if (isBaseTracer(handler)) {\n // Create and add run to the run map.\n // We do this synchronously to avoid race conditions\n // when callbacks are backgrounded.\n handler._createRunForRetrieverStart(\n retriever,\n query,\n runId,\n this._parentRunId,\n this.tags,\n this.metadata,\n runName\n );\n }\n return consumeCallback(async () => {\n try {\n await handler.handleRetrieverStart?.(\n retriever,\n query,\n runId,\n this._parentRunId,\n this.tags,\n this.metadata,\n runName\n );\n } catch (err) {\n const logFunction = handler.raiseError\n ? console.error\n : console.warn;\n logFunction(\n `Error in handler ${handler.constructor.name}, handleRetrieverStart: ${err}`\n );\n if (handler.raiseError) {\n throw err;\n }\n }\n }, handler.awaitHandlers);\n })\n );\n return new CallbackManagerForRetrieverRun(\n runId,\n this.handlers,\n this.inheritableHandlers,\n this.tags,\n this.inheritableTags,\n this.metadata,\n this.inheritableMetadata,\n this._parentRunId\n );\n }\n\n async handleCustomEvent?(\n eventName: string,\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n data: any,\n runId: string,\n _tags?: string[],\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n _metadata?: Record<string, any>\n ): // eslint-disable-next-line @typescript-eslint/no-explicit-any\n Promise<any> {\n await Promise.all(\n this.handlers.map((handler) =>\n consumeCallback(async () => {\n if (!handler.ignoreCustomEvent) {\n try {\n await handler.handleCustomEvent?.(\n eventName,\n data,\n runId,\n this.tags,\n this.metadata\n );\n } catch (err) {\n const logFunction = handler.raiseError\n ? console.error\n : console.warn;\n logFunction(\n `Error in handler ${handler.constructor.name}, handleCustomEvent: ${err}`\n );\n if (handler.raiseError) {\n throw err;\n }\n }\n }\n }, handler.awaitHandlers)\n )\n );\n }\n\n addHandler(handler: BaseCallbackHandler, inherit = true): void {\n this.handlers.push(handler);\n if (inherit) {\n this.inheritableHandlers.push(handler);\n }\n }\n\n removeHandler(handler: BaseCallbackHandler): void {\n this.handlers = this.handlers.filter((_handler) => _handler !== handler);\n this.inheritableHandlers = this.inheritableHandlers.filter(\n (_handler) => _handler !== handler\n );\n }\n\n setHandlers(handlers: BaseCallbackHandler[], inherit = true): void {\n this.handlers = [];\n this.inheritableHandlers = [];\n for (const handler of handlers) {\n this.addHandler(handler, inherit);\n }\n }\n\n addTags(tags: string[], inherit = true): void {\n this.removeTags(tags); // Remove duplicates\n this.tags.push(...tags);\n if (inherit) {\n this.inheritableTags.push(...tags);\n }\n }\n\n removeTags(tags: string[]): void {\n this.tags = this.tags.filter((tag) => !tags.includes(tag));\n this.inheritableTags = this.inheritableTags.filter(\n (tag) => !tags.includes(tag)\n );\n }\n\n addMetadata(metadata: Record<string, unknown>, inherit = true): void {\n this.metadata = { ...this.metadata, ...metadata };\n if (inherit) {\n this.inheritableMetadata = { ...this.inheritableMetadata, ...metadata };\n }\n }\n\n removeMetadata(metadata: Record<string, unknown>): void {\n for (const key of Object.keys(metadata)) {\n delete this.metadata[key];\n delete this.inheritableMetadata[key];\n }\n }\n\n copy(\n additionalHandlers: BaseCallbackHandler[] = [],\n inherit = true\n ): CallbackManager {\n const manager = new CallbackManager(this._parentRunId);\n for (const handler of this.handlers) {\n const inheritable = this.inheritableHandlers.includes(handler);\n manager.addHandler(handler, inheritable);\n }\n for (const tag of this.tags) {\n const inheritable = this.inheritableTags.includes(tag);\n manager.addTags([tag], inheritable);\n }\n for (const key of Object.keys(this.metadata)) {\n const inheritable = Object.keys(this.inheritableMetadata).includes(key);\n manager.addMetadata({ [key]: this.metadata[key] }, inheritable);\n }\n for (const handler of additionalHandlers) {\n if (\n // Prevent multiple copies of console_callback_handler\n manager.handlers\n .filter((h) => h.name === \"console_callback_handler\")\n .some((h) => h.name === handler.name)\n ) {\n continue;\n }\n manager.addHandler(handler, inherit);\n }\n return manager;\n }\n\n static fromHandlers(handlers: CallbackHandlerMethods) {\n class Handler extends BaseCallbackHandler {\n name = uuidv7();\n\n constructor() {\n super();\n Object.assign(this, handlers);\n }\n }\n\n const manager = new this();\n manager.addHandler(new Handler());\n return manager;\n }\n\n static configure(\n inheritableHandlers?: Callbacks,\n localHandlers?: Callbacks,\n inheritableTags?: string[],\n localTags?: string[],\n inheritableMetadata?: Record<string, unknown>,\n localMetadata?: Record<string, unknown>,\n options?: CallbackManagerOptions\n ): CallbackManager | undefined {\n return this._configureSync(\n inheritableHandlers,\n localHandlers,\n inheritableTags,\n localTags,\n inheritableMetadata,\n localMetadata,\n options\n );\n }\n\n // TODO: Deprecate async method in favor of this one.\n static _configureSync(\n inheritableHandlers?: Callbacks,\n localHandlers?: Callbacks,\n inheritableTags?: string[],\n localTags?: string[],\n inheritableMetadata?: Record<string, unknown>,\n localMetadata?: Record<string, unknown>,\n options?: CallbackManagerOptions\n ) {\n let callbackManager: CallbackManager | undefined;\n if (inheritableHandlers || localHandlers) {\n if (Array.isArray(inheritableHandlers) || !inheritableHandlers) {\n callbackManager = new CallbackManager();\n callbackManager.setHandlers(\n inheritableHandlers?.map(ensureHandler) ?? [],\n true\n );\n } else {\n callbackManager = inheritableHandlers;\n }\n\n callbackManager = callbackManager.copy(\n Array.isArray(localHandlers)\n ? localHandlers.map(ensureHandler)\n : localHandlers?.handlers,\n false\n );\n }\n\n const verboseEnabled =\n getEnvironmentVariable(\"LANGCHAIN_VERBOSE\") === \"true\" ||\n options?.verbose;\n\n const tracingV2Enabled =\n LangChainTracer.getTraceableRunTree()?.tracingEnabled ||\n isTracingEnabled();\n\n const tracingEnabled =\n tracingV2Enabled ||\n (getEnvironmentVariable(\"LANGCHAIN_TRACING\") ?? false);\n if (verboseEnabled || tracingEnabled) {\n if (!callbackManager) {\n callbackManager = new CallbackManager();\n }\n if (\n verboseEnabled &&\n !callbackManager.handlers.some(\n (handler) => handler.name === ConsoleCallbackHandler.prototype.name\n )\n ) {\n const consoleHandler = new ConsoleCallbackHandler();\n callbackManager.addHandler(consoleHandler, true);\n }\n if (\n tracingEnabled &&\n !callbackManager.handlers.some(\n (handler) => handler.name === \"langchain_tracer\"\n )\n ) {\n if (tracingV2Enabled) {\n const tracerV2 = new LangChainTracer();\n callbackManager.addHandler(tracerV2, true);\n }\n }\n if (tracingV2Enabled) {\n // handoff between langchain and langsmith/traceable\n // override the parent run ID\n const implicitRunTree = LangChainTracer.getTraceableRunTree();\n if (implicitRunTree && callbackManager._parentRunId === undefined) {\n callbackManager._parentRunId = implicitRunTree.id;\n const tracerV2 = callbackManager.handlers.find(\n (handler) => handler.name === \"langchain_tracer\"\n ) as LangChainTracer | undefined;\n tracerV2?.updateFromRunTree(implicitRunTree);\n }\n }\n }\n\n for (const {\n contextVar,\n inheritable = true,\n handlerClass,\n envVar,\n } of _getConfigureHooks()) {\n const createIfNotInContext =\n envVar && getEnvironmentVariable(envVar) === \"true\" && handlerClass;\n let handler: BaseCallbackHandler | undefined;\n const contextVarValue =\n contextVar !== undefined ? getContextVariable(contextVar) : undefined;\n if (contextVarValue && isBaseCallbackHandler(contextVarValue)) {\n handler = contextVarValue;\n } else if (createIfNotInContext) {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n handler = new (handlerClass as any)({});\n }\n if (handler !== undefined) {\n if (!callbackManager) {\n callbackManager = new CallbackManager();\n }\n\n if (!callbackManager.handlers.some((h) => h.name === handler!.name)) {\n callbackManager.addHandler(handler, inheritable);\n }\n }\n }\n\n if (inheritableTags || localTags) {\n if (callbackManager) {\n callbackManager.addTags(inheritableTags ?? []);\n callbackManager.addTags(localTags ?? [], false);\n }\n }\n if (inheritableMetadata || localMetadata) {\n if (callbackManager) {\n callbackManager.addMetadata(inheritableMetadata ?? {});\n callbackManager.addMetadata(localMetadata ?? {}, false);\n }\n }\n\n return callbackManager;\n }\n}\n\nexport function ensureHandler(\n handler: BaseCallbackHandler | CallbackHandlerMethods\n): BaseCallbackHandler {\n if (\"name\" in handler) {\n return handler;\n }\n\n return BaseCallbackHandler.fromMethods(handler);\n}\n"],"mappings":"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"}
@@ -0,0 +1 @@
1
+ {"version":3,"file":"chat_history.d.cts","names":["Serializable","BaseMessage","BaseChatMessageHistory","Promise","BaseListChatMessageHistory","InMemoryChatMessageHistory"],"sources":["../src/chat_history.d.ts"],"sourcesContent":["import { Serializable } from \"./load/serializable.js\";\nimport { type BaseMessage } from \"./messages/index.js\";\n/**\n * Base class for all chat message histories. All chat message histories\n * should extend this class.\n */\nexport declare abstract class BaseChatMessageHistory extends Serializable {\n abstract getMessages(): Promise<BaseMessage[]>;\n abstract addMessage(message: BaseMessage): Promise<void>;\n abstract addUserMessage(message: string): Promise<void>;\n abstract addAIMessage(message: string): Promise<void>;\n /**\n * Add a list of messages.\n *\n * Implementations should override this method to handle bulk addition of messages\n * in an efficient manner to avoid unnecessary round-trips to the underlying store.\n *\n * @param messages - A list of BaseMessage objects to store.\n */\n addMessages(messages: BaseMessage[]): Promise<void>;\n abstract clear(): Promise<void>;\n}\n/**\n * Base class for all list chat message histories. All list chat message\n * histories should extend this class.\n */\nexport declare abstract class BaseListChatMessageHistory extends Serializable {\n /** Returns a list of messages stored in the store. */\n abstract getMessages(): Promise<BaseMessage[]>;\n /**\n * Add a message object to the store.\n */\n abstract addMessage(message: BaseMessage): Promise<void>;\n /**\n * This is a convenience method for adding a human message string to the store.\n * Please note that this is a convenience method. Code should favor the\n * bulk addMessages interface instead to save on round-trips to the underlying\n * persistence layer.\n * This method may be deprecated in a future release.\n */\n addUserMessage(message: string): Promise<void>;\n /**\n * This is a convenience method for adding an AI message string to the store.\n * Please note that this is a convenience method. Code should favor the bulk\n * addMessages interface instead to save on round-trips to the underlying\n * persistence layer.\n * This method may be deprecated in a future release.\n */\n addAIMessage(message: string): Promise<void>;\n /**\n * Add a list of messages.\n *\n * Implementations should override this method to handle bulk addition of messages\n * in an efficient manner to avoid unnecessary round-trips to the underlying store.\n *\n * @param messages - A list of BaseMessage objects to store.\n */\n addMessages(messages: BaseMessage[]): Promise<void>;\n /**\n * Remove all messages from the store.\n */\n clear(): Promise<void>;\n}\n/**\n * Class for storing chat message history in-memory. It extends the\n * BaseListChatMessageHistory class and provides methods to get, add, and\n * clear messages.\n */\nexport declare class InMemoryChatMessageHistory extends BaseListChatMessageHistory {\n lc_namespace: string[];\n private messages;\n constructor(messages?: BaseMessage[]);\n /**\n * Method to get all the messages stored in the ChatMessageHistory\n * instance.\n * @returns Array of stored BaseMessage instances.\n */\n getMessages(): Promise<BaseMessage[]>;\n /**\n * Method to add a new message to the ChatMessageHistory instance.\n * @param message The BaseMessage instance to add.\n * @returns A promise that resolves when the message has been added.\n */\n addMessage(message: BaseMessage): Promise<void>;\n /**\n * Method to clear all the messages from the ChatMessageHistory instance.\n * @returns A promise that resolves when all messages have been cleared.\n */\n clear(): Promise<void>;\n}\n//# sourceMappingURL=chat_history.d.ts.map"],"mappings":";;;;;;;AAMA;;AAC4BG,uBADED,sBAAAA,SAA+BF,YAAAA,CACjCG;EACKF,SAAAA,WAAAA,CAAAA,CAAAA,EADLE,OACKF,CADGA,WACHA,EAAAA,CAAAA;EAAcE,SAAAA,UAAAA,CAAAA,OAAAA,EAAdF,WAAcE,CAAAA,EAAAA,OAAAA,CAAAA,IAAAA,CAAAA;EACDA,SAAAA,cAAAA,CAAAA,OAAAA,EAAAA,MAAAA,CAAAA,EAAAA,OAAAA,CAAAA,IAAAA,CAAAA;EACFA,SAAAA,YAAAA,CAAAA,OAAAA,EAAAA,MAAAA,CAAAA,EAAAA,OAAAA,CAAAA,IAAAA,CAAAA;EASlBF;;;;AAb+C;AAoBzE;;;EAMiCA,WAAAA,CAAAA,QAAAA,EAbPA,WAaOA,EAAAA,CAAAA,EAbSE,OAaTF,CAAAA,IAAAA,CAAAA;EAAcE,SAAAA,KAAAA,CAAAA,CAAAA,EAZzBA,OAYyBA,CAAAA,IAAAA,CAAAA;;;;;;AANkBH,uBAAnCI,0BAAAA,SAAmCJ,YAAAA,CAAAA;EAAY;EA0CxDK,SAAAA,WAAAA,CAAAA,CAAAA,EAxCOF,OAwCmB,CAxCXF,WAwCW,EAAA,CAAA;EAGpBA;;;EAYHA,SAAAA,UAAAA,CAAAA,OAAAA,EAnDSA,WAmDTA,CAAAA,EAnDuBE,OAmDvBF,CAAAA,IAAAA,CAAAA;EAAcE;;;AAf4C;;;;mCA5B7CA;;;;;;;;iCAQFA;;;;;;;;;wBASTF,gBAAgBE;;;;WAI7BA;;;;;;;cAOQE,0BAAAA,SAAmCD,0BAAAA;;;yBAG7BH;;;;;;iBAMRE,QAAQF;;;;;;sBAMHA,cAAcE;;;;;WAKzBA"}
@@ -0,0 +1 @@
1
+ {"version":3,"file":"chat_history.d.ts","names":["Serializable","BaseMessage","BaseChatMessageHistory","Promise","BaseListChatMessageHistory","InMemoryChatMessageHistory"],"sources":["../src/chat_history.d.ts"],"sourcesContent":["import { Serializable } from \"./load/serializable.js\";\nimport { type BaseMessage } from \"./messages/index.js\";\n/**\n * Base class for all chat message histories. All chat message histories\n * should extend this class.\n */\nexport declare abstract class BaseChatMessageHistory extends Serializable {\n abstract getMessages(): Promise<BaseMessage[]>;\n abstract addMessage(message: BaseMessage): Promise<void>;\n abstract addUserMessage(message: string): Promise<void>;\n abstract addAIMessage(message: string): Promise<void>;\n /**\n * Add a list of messages.\n *\n * Implementations should override this method to handle bulk addition of messages\n * in an efficient manner to avoid unnecessary round-trips to the underlying store.\n *\n * @param messages - A list of BaseMessage objects to store.\n */\n addMessages(messages: BaseMessage[]): Promise<void>;\n abstract clear(): Promise<void>;\n}\n/**\n * Base class for all list chat message histories. All list chat message\n * histories should extend this class.\n */\nexport declare abstract class BaseListChatMessageHistory extends Serializable {\n /** Returns a list of messages stored in the store. */\n abstract getMessages(): Promise<BaseMessage[]>;\n /**\n * Add a message object to the store.\n */\n abstract addMessage(message: BaseMessage): Promise<void>;\n /**\n * This is a convenience method for adding a human message string to the store.\n * Please note that this is a convenience method. Code should favor the\n * bulk addMessages interface instead to save on round-trips to the underlying\n * persistence layer.\n * This method may be deprecated in a future release.\n */\n addUserMessage(message: string): Promise<void>;\n /**\n * This is a convenience method for adding an AI message string to the store.\n * Please note that this is a convenience method. Code should favor the bulk\n * addMessages interface instead to save on round-trips to the underlying\n * persistence layer.\n * This method may be deprecated in a future release.\n */\n addAIMessage(message: string): Promise<void>;\n /**\n * Add a list of messages.\n *\n * Implementations should override this method to handle bulk addition of messages\n * in an efficient manner to avoid unnecessary round-trips to the underlying store.\n *\n * @param messages - A list of BaseMessage objects to store.\n */\n addMessages(messages: BaseMessage[]): Promise<void>;\n /**\n * Remove all messages from the store.\n */\n clear(): Promise<void>;\n}\n/**\n * Class for storing chat message history in-memory. It extends the\n * BaseListChatMessageHistory class and provides methods to get, add, and\n * clear messages.\n */\nexport declare class InMemoryChatMessageHistory extends BaseListChatMessageHistory {\n lc_namespace: string[];\n private messages;\n constructor(messages?: BaseMessage[]);\n /**\n * Method to get all the messages stored in the ChatMessageHistory\n * instance.\n * @returns Array of stored BaseMessage instances.\n */\n getMessages(): Promise<BaseMessage[]>;\n /**\n * Method to add a new message to the ChatMessageHistory instance.\n * @param message The BaseMessage instance to add.\n * @returns A promise that resolves when the message has been added.\n */\n addMessage(message: BaseMessage): Promise<void>;\n /**\n * Method to clear all the messages from the ChatMessageHistory instance.\n * @returns A promise that resolves when all messages have been cleared.\n */\n clear(): Promise<void>;\n}\n//# sourceMappingURL=chat_history.d.ts.map"],"mappings":";;;;;;;;;AAMA;AACoCC,uBADNC,sBAAAA,SAA+BF,YAAAA,CACzBC;EAARE,SAAAA,WAAAA,CAAAA,CAAAA,EAAAA,OAAAA,CAAQF,WAARE,EAAAA,CAAAA;EACKF,SAAAA,UAAAA,CAAAA,OAAAA,EAAAA,WAAAA,CAAAA,EAAcE,OAAdF,CAAAA,IAAAA,CAAAA;EAAcE,SAAAA,cAAAA,CAAAA,OAAAA,EAAAA,MAAAA,CAAAA,EACDA,OADCA,CAAAA,IAAAA,CAAAA;EACDA,SAAAA,YAAAA,CAAAA,OAAAA,EAAAA,MAAAA,CAAAA,EACFA,OADEA,CAAAA,IAAAA,CAAAA;EACFA;;;;;AAJ6B;AAoBzE;;EAE4BA,WAAAA,CAAAA,QAAAA,EATFF,WASEE,EAAAA,CAAAA,EATcA,OASdA,CAAAA,IAAAA,CAAAA;EAIKF,SAAAA,KAAAA,CAAAA,CAAAA,EAZXE,OAYWF,CAAAA,IAAAA,CAAAA;;;;;;AA6BpBE,uBAnCiBC,0BAAAA,SAAmCJ,YAAAA,CAmCpDG;EAnCoDH;EAAY,SAAA,WAAA,CAAA,CAAA,EAEjDG,OAFiD,CAEzCF,WAFyC,EAAA,CAAA;EA0CxDI;;;EASFF,SAAAA,UAAAA,CAAAA,OAAAA,EA7CcF,WA6CdE,CAAAA,EA7C4BA,OA6C5BA,CAAAA,IAAAA,CAAAA;EAMKF;;;;AAf0D;;;mCA5B7CE;;;;;;;;iCAQFA;;;;;;;;;wBASTF,gBAAgBE;;;;WAI7BA;;;;;;;cAOQE,0BAAAA,SAAmCD,0BAAAA;;;yBAG7BH;;;;;;iBAMRE,QAAQF;;;;;;sBAMHA,cAAcE;;;;;WAKzBA"}
@@ -0,0 +1 @@
1
+ {"version":3,"file":"context.d.cts","names":["getContextVariable","setContextVariable","ConfigureHook","registerConfigureHook","foo"],"sources":["../src/context.d.ts"],"sourcesContent":["import { getContextVariable, setContextVariable, type ConfigureHook, registerConfigureHook } from \"./singletons/async_local_storage/context.js\";\nexport { getContextVariable, setContextVariable, registerConfigureHook, type ConfigureHook, };\nexport declare const foo = \"bar\";\n//# sourceMappingURL=context.d.ts.map"],"mappings":";;;cAEqBI,GAAAA"}
@@ -0,0 +1 @@
1
+ {"version":3,"file":"context.d.ts","names":["getContextVariable","setContextVariable","ConfigureHook","registerConfigureHook","foo"],"sources":["../src/context.d.ts"],"sourcesContent":["import { getContextVariable, setContextVariable, type ConfigureHook, registerConfigureHook } from \"./singletons/async_local_storage/context.js\";\nexport { getContextVariable, setContextVariable, registerConfigureHook, type ConfigureHook, };\nexport declare const foo = \"bar\";\n//# sourceMappingURL=context.d.ts.map"],"mappings":";;;cAEqBI,GAAAA"}
@@ -0,0 +1 @@
1
+ {"version":3,"file":"base.d.cts","names":["Document","DocumentLoader","Promise","BaseDocumentLoader"],"sources":["../../src/document_loaders/base.d.ts"],"sourcesContent":["import { Document } from \"../documents/document.js\";\n/**\n * Interface that defines the methods for loading and splitting documents.\n */\nexport interface DocumentLoader {\n load(): Promise<Document[]>;\n}\n/**\n * Abstract class that provides a default implementation for the\n * loadAndSplit() method from the DocumentLoader interface. The load()\n * method is left abstract and needs to be implemented by subclasses.\n */\nexport declare abstract class BaseDocumentLoader implements DocumentLoader {\n /**\n * Loads the documents.\n * @returns A Promise that resolves with an array of Document instances.\n */\n abstract load(): Promise<Document[]>;\n}\n//# sourceMappingURL=base.d.ts.map"],"mappings":";;;;;;AAIA;AAQ8BG,UARbF,cAAAA,CAQ+B;EAKnBD,IAAAA,EAAAA,EAZjBE,OAYiBF,CAZTA,QAYSA,EAAAA,CAAAA;;;AAL6C;;;;uBAA5CG,kBAAAA,YAA8BF;;;;;mBAKvCC,QAAQF"}
@@ -0,0 +1 @@
1
+ {"version":3,"file":"base.d.ts","names":["Document","DocumentLoader","Promise","BaseDocumentLoader"],"sources":["../../src/document_loaders/base.d.ts"],"sourcesContent":["import { Document } from \"../documents/document.js\";\n/**\n * Interface that defines the methods for loading and splitting documents.\n */\nexport interface DocumentLoader {\n load(): Promise<Document[]>;\n}\n/**\n * Abstract class that provides a default implementation for the\n * loadAndSplit() method from the DocumentLoader interface. The load()\n * method is left abstract and needs to be implemented by subclasses.\n */\nexport declare abstract class BaseDocumentLoader implements DocumentLoader {\n /**\n * Loads the documents.\n * @returns A Promise that resolves with an array of Document instances.\n */\n abstract load(): Promise<Document[]>;\n}\n//# sourceMappingURL=base.d.ts.map"],"mappings":";;;;;;AAIA;AAQ8BG,UARbF,cAAAA,CAQ+B;EAKnBD,IAAAA,EAAAA,EAZjBE,OAYiBF,CAZTA,QAYSA,EAAAA,CAAAA;;;AAL6C;;;;uBAA5CG,kBAAAA,YAA8BF;;;;;mBAKvCC,QAAQF"}
@@ -0,0 +1 @@
1
+ {"version":3,"file":"langsmith.d.cts","names":["KVMap","Client","Document","AsyncCallerParams","BaseDocumentLoader","ClientConfig","RequestInit","LangSmithLoaderFields","Array","Date","LangSmithLoader","Promise"],"sources":["../../src/document_loaders/langsmith.d.ts"],"sourcesContent":["import { KVMap } from \"langsmith/schemas\";\nimport { Client } from \"langsmith\";\nimport { Document } from \"../documents/document.js\";\nimport { AsyncCallerParams } from \"../utils/async_caller.js\";\nimport { BaseDocumentLoader } from \"./base.js\";\ninterface ClientConfig {\n apiUrl?: string;\n apiKey?: string;\n callerOptions?: AsyncCallerParams;\n timeout_ms?: number;\n webUrl?: string;\n anonymizer?: (values: KVMap) => KVMap;\n hideInputs?: boolean | ((inputs: KVMap) => KVMap);\n hideOutputs?: boolean | ((outputs: KVMap) => KVMap);\n autoBatchTracing?: boolean;\n pendingAutoBatchedRunLimit?: number;\n fetchOptions?: RequestInit;\n}\nexport interface LangSmithLoaderFields {\n datasetId?: string;\n datasetName?: string;\n exampleIds?: Array<string>;\n asOf?: Date | string;\n splits?: string[];\n inlineS3Urls?: boolean;\n offset?: number;\n limit?: number;\n metadata?: KVMap;\n filter?: string;\n contentKey?: string;\n formatContent?: (content: any) => string;\n client?: Client;\n clientConfig?: ClientConfig;\n}\n/**\n * Document loader integration with LangSmith.\n *\n * ## [Constructor args](https://api.js.langchain.com/interfaces/_langchain_core.document_loaders_langsmith.LangSmithLoaderFields.html)\n *\n * <details open>\n * <summary><strong>Load</strong></summary>\n *\n * ```typescript\n * import { LangSmithLoader } from '@langchain/core/document_loaders/langsmith';\n * import { Client } from 'langsmith';\n *\n * const langSmithClient = new Client({\n * apiKey: process.env.LANGSMITH_API_KEY,\n * })\n *\n * const loader = new LangSmithLoader({\n * datasetId: \"9a3b36f7-b308-40a5-9b46-6613853b6330\",\n * limit: 1,\n * });\n *\n * const docs = await loader.load();\n * ```\n *\n * ```txt\n * [\n * {\n * pageContent: '{\\n \"input_key_str\": \"string\",\\n \"input_key_bool\": true\\n}',\n * metadata: {\n * id: '8523d9e9-c123-4b23-9b46-21021nds289e',\n * created_at: '2024-08-19T17:09:14.806441+00:00',\n * modified_at: '2024-08-19T17:09:14.806441+00:00',\n * name: '#8517 @ brace-test-dataset',\n * dataset_id: '9a3b36f7-b308-40a5-9b46-6613853b6330',\n * source_run_id: null,\n * metadata: [Object],\n * inputs: [Object],\n * outputs: [Object]\n * }\n * }\n * ]\n * ```\n * </details>\n */\nexport declare class LangSmithLoader extends BaseDocumentLoader {\n datasetId?: string;\n datasetName?: string;\n exampleIds?: Array<string>;\n asOf?: Date | string;\n splits?: string[];\n inlineS3Urls?: boolean;\n offset?: number;\n limit?: number;\n metadata?: KVMap;\n filter?: string;\n contentKey: string[];\n formatContent: (content: any) => string;\n client: Client;\n constructor(fields: LangSmithLoaderFields);\n load(): Promise<Document[]>;\n}\nexport {};\n//# sourceMappingURL=langsmith.d.ts.map"],"mappings":";;;;;;;UAKUK,YAAAA;;EAAAA,MAAAA,CAAAA,EAAAA,MAAY;EAGFF,aAAAA,CAAAA,EAAAA,iBAAAA;EAGMH,UAAAA,CAAAA,EAAAA,MAAAA;EAAUA,MAAAA,CAAAA,EAAAA,MAAAA;EACCA,UAAAA,CAAAA,EAAAA,CAAAA,MAAAA,EADXA,KACWA,EAAAA,GADDA,KACCA;EAAUA,UAAAA,CAAAA,EAAAA,OAAAA,GAAAA,CAAAA,CAAAA,MAAAA,EAAVA,KAAUA,EAAAA,GAAAA,KAAAA,CAAAA;EACRA,WAAAA,CAAAA,EAAAA,OAAAA,GAAAA,CAAAA,CAAAA,OAAAA,EAAAA,KAAAA,EAAAA,GAAUA,KAAVA,CAAAA;EAAUA,gBAAAA,CAAAA,EAAAA,OAAAA;EAG9BM,0BAAAA,CAAAA,EAAAA,MAAAA;EAAW,YAAA,CAAA,EAAXA,WAAW;AAE9B;AAGiBE,UAHAD,qBAAAA,CAGAC;EACNC,SAAAA,CAAAA,EAAAA,MAAAA;EAKIT,WAAAA,CAAAA,EAAAA,MAAAA;EAIFC,UAAAA,CAAAA,EAVIO,KAUJP,CAAAA,MAAAA,CAAAA;EACMI,IAAAA,CAAAA,EAVRI,IAUQJ,GAAAA,MAAAA;EAAY,MAAA,CAAA,EAAA,MAAA,EAAA;EA8CVK,YAAAA,CAAAA,EAAAA,OAAe;EAGnBF,MAAAA,CAAAA,EAAAA,MAAAA;EACNC,KAAAA,CAAAA,EAAAA,MAAAA;EAKIT,QAAAA,CAAAA,EA5DAA,KA4DAA;EAIHC,MAAAA,CAAAA,EAAAA,MAAAA;EACYM,UAAAA,CAAAA,EAAAA,MAAAA;EACJL,aAAAA,CAAAA,EAAAA,CAAAA,OAAAA,EAAAA,GAAAA,EAAAA,GAAAA,MAAAA;EAARS,MAAAA,CAAAA,EA9DCV,MA8DDU;EAfiCP,YAAAA,CAAAA,EA9C1BC,YA8C0BD;AAAkB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;cAA1CM,eAAAA,SAAwBN,kBAAAA;;;eAG5BI;SACNC;;;;;aAKIT;;;;UAIHC;sBACYM;UACZI,QAAQT"}
@@ -0,0 +1 @@
1
+ {"version":3,"file":"langsmith.d.ts","names":["KVMap","Client","Document","AsyncCallerParams","BaseDocumentLoader","ClientConfig","RequestInit","LangSmithLoaderFields","Array","Date","LangSmithLoader","Promise"],"sources":["../../src/document_loaders/langsmith.d.ts"],"sourcesContent":["import { KVMap } from \"langsmith/schemas\";\nimport { Client } from \"langsmith\";\nimport { Document } from \"../documents/document.js\";\nimport { AsyncCallerParams } from \"../utils/async_caller.js\";\nimport { BaseDocumentLoader } from \"./base.js\";\ninterface ClientConfig {\n apiUrl?: string;\n apiKey?: string;\n callerOptions?: AsyncCallerParams;\n timeout_ms?: number;\n webUrl?: string;\n anonymizer?: (values: KVMap) => KVMap;\n hideInputs?: boolean | ((inputs: KVMap) => KVMap);\n hideOutputs?: boolean | ((outputs: KVMap) => KVMap);\n autoBatchTracing?: boolean;\n pendingAutoBatchedRunLimit?: number;\n fetchOptions?: RequestInit;\n}\nexport interface LangSmithLoaderFields {\n datasetId?: string;\n datasetName?: string;\n exampleIds?: Array<string>;\n asOf?: Date | string;\n splits?: string[];\n inlineS3Urls?: boolean;\n offset?: number;\n limit?: number;\n metadata?: KVMap;\n filter?: string;\n contentKey?: string;\n formatContent?: (content: any) => string;\n client?: Client;\n clientConfig?: ClientConfig;\n}\n/**\n * Document loader integration with LangSmith.\n *\n * ## [Constructor args](https://api.js.langchain.com/interfaces/_langchain_core.document_loaders_langsmith.LangSmithLoaderFields.html)\n *\n * <details open>\n * <summary><strong>Load</strong></summary>\n *\n * ```typescript\n * import { LangSmithLoader } from '@langchain/core/document_loaders/langsmith';\n * import { Client } from 'langsmith';\n *\n * const langSmithClient = new Client({\n * apiKey: process.env.LANGSMITH_API_KEY,\n * })\n *\n * const loader = new LangSmithLoader({\n * datasetId: \"9a3b36f7-b308-40a5-9b46-6613853b6330\",\n * limit: 1,\n * });\n *\n * const docs = await loader.load();\n * ```\n *\n * ```txt\n * [\n * {\n * pageContent: '{\\n \"input_key_str\": \"string\",\\n \"input_key_bool\": true\\n}',\n * metadata: {\n * id: '8523d9e9-c123-4b23-9b46-21021nds289e',\n * created_at: '2024-08-19T17:09:14.806441+00:00',\n * modified_at: '2024-08-19T17:09:14.806441+00:00',\n * name: '#8517 @ brace-test-dataset',\n * dataset_id: '9a3b36f7-b308-40a5-9b46-6613853b6330',\n * source_run_id: null,\n * metadata: [Object],\n * inputs: [Object],\n * outputs: [Object]\n * }\n * }\n * ]\n * ```\n * </details>\n */\nexport declare class LangSmithLoader extends BaseDocumentLoader {\n datasetId?: string;\n datasetName?: string;\n exampleIds?: Array<string>;\n asOf?: Date | string;\n splits?: string[];\n inlineS3Urls?: boolean;\n offset?: number;\n limit?: number;\n metadata?: KVMap;\n filter?: string;\n contentKey: string[];\n formatContent: (content: any) => string;\n client: Client;\n constructor(fields: LangSmithLoaderFields);\n load(): Promise<Document[]>;\n}\nexport {};\n//# sourceMappingURL=langsmith.d.ts.map"],"mappings":";;;;;;;UAKUK,YAAAA;;EAAAA,MAAAA,CAAAA,EAAAA,MAAY;EAGFF,aAAAA,CAAAA,EAAAA,iBAAAA;EAGMH,UAAAA,CAAAA,EAAAA,MAAAA;EAAUA,MAAAA,CAAAA,EAAAA,MAAAA;EACCA,UAAAA,CAAAA,EAAAA,CAAAA,MAAAA,EADXA,KACWA,EAAAA,GADDA,KACCA;EAAUA,UAAAA,CAAAA,EAAAA,OAAAA,GAAAA,CAAAA,CAAAA,MAAAA,EAAVA,KAAUA,EAAAA,GAAAA,KAAAA,CAAAA;EACRA,WAAAA,CAAAA,EAAAA,OAAAA,GAAAA,CAAAA,CAAAA,OAAAA,EAAAA,KAAAA,EAAAA,GAAUA,KAAVA,CAAAA;EAAUA,gBAAAA,CAAAA,EAAAA,OAAAA;EAG9BM,0BAAAA,CAAAA,EAAAA,MAAAA;EAAW,YAAA,CAAA,EAAXA,WAAW;AAE9B;AAGiBE,UAHAD,qBAAAA,CAGAC;EACNC,SAAAA,CAAAA,EAAAA,MAAAA;EAKIT,WAAAA,CAAAA,EAAAA,MAAAA;EAIFC,UAAAA,CAAAA,EAVIO,KAUJP,CAAAA,MAAAA,CAAAA;EACMI,IAAAA,CAAAA,EAVRI,IAUQJ,GAAAA,MAAAA;EAAY,MAAA,CAAA,EAAA,MAAA,EAAA;EA8CVK,YAAAA,CAAAA,EAAAA,OAAe;EAGnBF,MAAAA,CAAAA,EAAAA,MAAAA;EACNC,KAAAA,CAAAA,EAAAA,MAAAA;EAKIT,QAAAA,CAAAA,EA5DAA,KA4DAA;EAIHC,MAAAA,CAAAA,EAAAA,MAAAA;EACYM,UAAAA,CAAAA,EAAAA,MAAAA;EACJL,aAAAA,CAAAA,EAAAA,CAAAA,OAAAA,EAAAA,GAAAA,EAAAA,GAAAA,MAAAA;EAARS,MAAAA,CAAAA,EA9DCV,MA8DDU;EAfiCP,YAAAA,CAAAA,EA9C1BC,YA8C0BD;AAAkB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;cAA1CM,eAAAA,SAAwBN,kBAAAA;;;eAG5BI;SACNC;;;;;aAKIT;;;;UAIHC;sBACYM;UACZI,QAAQT"}
@@ -0,0 +1 @@
1
+ {"version":3,"file":"document.d.cts","names":["DocumentInput","Metadata","Record","DocumentInterface","Document"],"sources":["../../src/documents/document.d.ts"],"sourcesContent":["export interface DocumentInput<Metadata extends Record<string, any> = Record<string, any>> {\n pageContent: string;\n metadata?: Metadata;\n /**\n * An optional identifier for the document.\n *\n * Ideally this should be unique across the document collection and formatted\n * as a UUID, but this will not be enforced.\n */\n id?: string;\n}\nexport interface DocumentInterface<Metadata extends Record<string, any> = Record<string, any>> {\n pageContent: string;\n metadata: Metadata;\n /**\n * An optional identifier for the document.\n *\n * Ideally this should be unique across the document collection and formatted\n * as a UUID, but this will not be enforced.\n */\n id?: string;\n}\n/**\n * Interface for interacting with a document.\n */\nexport declare class Document<Metadata extends Record<string, any> = Record<string, any>> implements DocumentInput, DocumentInterface {\n pageContent: string;\n metadata: Metadata;\n /**\n * An optional identifier for the document.\n *\n * Ideally this should be unique across the document collection and formatted\n * as a UUID, but this will not be enforced.\n */\n id?: string;\n constructor(fields: DocumentInput<Metadata>);\n}\n//# sourceMappingURL=document.d.ts.map"],"mappings":";UAAiBA,+BAA+BE,sBAAsBA;EAArDF,WAAAA,EAAAA,MAAa;EAAkBE,QAAAA,CAAAA,EAEjCD,QAFiCC;EAAsBA;;AAE/C;AASvB;;;EAEcD,EAAAA,CAAAA,EAAAA,MAAAA;AAAQ;AAYDG,UAdJD,iBAcYF,CAAA,iBAduBC,MAcvB,CAAA,MAAA,EAAA,GAAA,CAAA,GAd6CA,MAc7C,CAAA,MAAA,EAAA,GAAA,CAAA,CAAA,CAAA;EAAkBA,WAAAA,EAAAA,MAAAA;EAAsBA,QAAAA,EAZvDD,QAYuDC;EAEvDD;;;;;AAFuH;;;;;;cAAhHG,0BAA0BF,sBAAsBA,gCAAgCF,eAAeG;;YAEtGF;;;;;;;;sBAQUD,cAAcC"}
@@ -0,0 +1 @@
1
+ {"version":3,"file":"document.d.ts","names":["DocumentInput","Metadata","Record","DocumentInterface","Document"],"sources":["../../src/documents/document.d.ts"],"sourcesContent":["export interface DocumentInput<Metadata extends Record<string, any> = Record<string, any>> {\n pageContent: string;\n metadata?: Metadata;\n /**\n * An optional identifier for the document.\n *\n * Ideally this should be unique across the document collection and formatted\n * as a UUID, but this will not be enforced.\n */\n id?: string;\n}\nexport interface DocumentInterface<Metadata extends Record<string, any> = Record<string, any>> {\n pageContent: string;\n metadata: Metadata;\n /**\n * An optional identifier for the document.\n *\n * Ideally this should be unique across the document collection and formatted\n * as a UUID, but this will not be enforced.\n */\n id?: string;\n}\n/**\n * Interface for interacting with a document.\n */\nexport declare class Document<Metadata extends Record<string, any> = Record<string, any>> implements DocumentInput, DocumentInterface {\n pageContent: string;\n metadata: Metadata;\n /**\n * An optional identifier for the document.\n *\n * Ideally this should be unique across the document collection and formatted\n * as a UUID, but this will not be enforced.\n */\n id?: string;\n constructor(fields: DocumentInput<Metadata>);\n}\n//# sourceMappingURL=document.d.ts.map"],"mappings":";UAAiBA,+BAA+BE,sBAAsBA;EAArDF,WAAAA,EAAAA,MAAa;EAAkBE,QAAAA,CAAAA,EAEjCD,QAFiCC;EAAsBA;;AAE/C;AASvB;;;EAEcD,EAAAA,CAAAA,EAAAA,MAAAA;AAAQ;AAYDG,UAdJD,iBAcYF,CAAA,iBAduBC,MAcvB,CAAA,MAAA,EAAA,GAAA,CAAA,GAd6CA,MAc7C,CAAA,MAAA,EAAA,GAAA,CAAA,CAAA,CAAA;EAAkBA,WAAAA,EAAAA,MAAAA;EAAsBA,QAAAA,EAZvDD,QAYuDC;EAEvDD;;;;;AAFuH;;;;;;cAAhHG,0BAA0BF,sBAAsBA,gCAAgCF,eAAeG;;YAEtGF;;;;;;;;sBAQUD,cAAcC"}
@@ -0,0 +1 @@
1
+ {"version":3,"file":"transformers.d.cts","names":["Runnable","BaseCallbackConfig","DocumentInterface","BaseDocumentTransformer","RunInput","RunOutput","Promise","MappingDocumentTransformer"],"sources":["../../src/documents/transformers.d.ts"],"sourcesContent":["import { Runnable } from \"../runnables/base.js\";\nimport type { BaseCallbackConfig } from \"../callbacks/manager.js\";\nimport type { DocumentInterface } from \"./document.js\";\n/**\n * Abstract base class for document transformation systems.\n *\n * A document transformation system takes an array of Documents and returns an\n * array of transformed Documents. These arrays do not necessarily have to have\n * the same length.\n *\n * One example of this is a text splitter that splits a large document into\n * many smaller documents.\n */\nexport declare abstract class BaseDocumentTransformer<RunInput extends DocumentInterface[] = DocumentInterface[], RunOutput extends DocumentInterface[] = DocumentInterface[]> extends Runnable<RunInput, RunOutput> {\n lc_namespace: string[];\n /**\n * Transform a list of documents.\n * @param documents A sequence of documents to be transformed.\n * @returns A list of transformed documents.\n */\n abstract transformDocuments(documents: RunInput): Promise<RunOutput>;\n /**\n * Method to invoke the document transformation. This method calls the\n * transformDocuments method with the provided input.\n * @param input The input documents to be transformed.\n * @param _options Optional configuration object to customize the behavior of callbacks.\n * @returns A Promise that resolves to the transformed documents.\n */\n invoke(input: RunInput, _options?: BaseCallbackConfig): Promise<RunOutput>;\n}\n/**\n * Class for document transformers that return exactly one transformed document\n * for each input document.\n */\nexport declare abstract class MappingDocumentTransformer extends BaseDocumentTransformer {\n transformDocuments(documents: DocumentInterface[]): Promise<DocumentInterface[]>;\n abstract _transformDocument(document: DocumentInterface): Promise<DocumentInterface>;\n}\n//# sourceMappingURL=transformers.d.ts.map"],"mappings":";;;;;;;;AAaA;;;;;;;;AAO8DK,uBAPhCF,uBAOgCE,CAAAA,iBAPSH,iBAOTG,EAAAA,GAP+BH,iBAO/BG,EAAAA,EAAAA,kBAPsEH,iBAOtEG,EAAAA,GAP4FH,iBAO5FG,EAAAA,CAAAA,SAPyHL,QAOzHK,CAPkID,QAOlIC,EAP4IA,SAO5IA,CAAAA,CAAAA;EAARC,YAAAA,EAAAA,MAAAA,EAAAA;EAQpCF;;;;;EAf6K,SAAA,kBAAA,CAAA,SAAA,EAOpJA,QAPoJ,CAAA,EAOzIE,OAPyI,CAOjID,SAPiI,CAAA;EAqBjKE;;;;;;;EAAmCJ,MAAAA,CAAAA,KAAAA,EAN/CC,QAM+CD,EAAAA,QAAAA,CAAAA,EAN1BF,kBAM0BE,CAAAA,EANLG,OAMKH,CANGE,SAMHF,CAAAA;AAAuB;;;;;uBAA1DI,0BAAAA,SAAmCJ,uBAAAA;gCAC/BD,sBAAsBI,QAAQJ;wCACtBA,oBAAoBI,QAAQJ"}
@@ -0,0 +1 @@
1
+ {"version":3,"file":"transformers.d.ts","names":["Runnable","BaseCallbackConfig","DocumentInterface","BaseDocumentTransformer","RunInput","RunOutput","Promise","MappingDocumentTransformer"],"sources":["../../src/documents/transformers.d.ts"],"sourcesContent":["import { Runnable } from \"../runnables/base.js\";\nimport type { BaseCallbackConfig } from \"../callbacks/manager.js\";\nimport type { DocumentInterface } from \"./document.js\";\n/**\n * Abstract base class for document transformation systems.\n *\n * A document transformation system takes an array of Documents and returns an\n * array of transformed Documents. These arrays do not necessarily have to have\n * the same length.\n *\n * One example of this is a text splitter that splits a large document into\n * many smaller documents.\n */\nexport declare abstract class BaseDocumentTransformer<RunInput extends DocumentInterface[] = DocumentInterface[], RunOutput extends DocumentInterface[] = DocumentInterface[]> extends Runnable<RunInput, RunOutput> {\n lc_namespace: string[];\n /**\n * Transform a list of documents.\n * @param documents A sequence of documents to be transformed.\n * @returns A list of transformed documents.\n */\n abstract transformDocuments(documents: RunInput): Promise<RunOutput>;\n /**\n * Method to invoke the document transformation. This method calls the\n * transformDocuments method with the provided input.\n * @param input The input documents to be transformed.\n * @param _options Optional configuration object to customize the behavior of callbacks.\n * @returns A Promise that resolves to the transformed documents.\n */\n invoke(input: RunInput, _options?: BaseCallbackConfig): Promise<RunOutput>;\n}\n/**\n * Class for document transformers that return exactly one transformed document\n * for each input document.\n */\nexport declare abstract class MappingDocumentTransformer extends BaseDocumentTransformer {\n transformDocuments(documents: DocumentInterface[]): Promise<DocumentInterface[]>;\n abstract _transformDocument(document: DocumentInterface): Promise<DocumentInterface>;\n}\n//# sourceMappingURL=transformers.d.ts.map"],"mappings":";;;;;;;;AAaA;;;;;;;;AAO8DK,uBAPhCF,uBAOgCE,CAAAA,iBAPSH,iBAOTG,EAAAA,GAP+BH,iBAO/BG,EAAAA,EAAAA,kBAPsEH,iBAOtEG,EAAAA,GAP4FH,iBAO5FG,EAAAA,CAAAA,SAPyHL,QAOzHK,CAPkID,QAOlIC,EAP4IA,SAO5IA,CAAAA,CAAAA;EAARC,YAAAA,EAAAA,MAAAA,EAAAA;EAQpCF;;;;;EAf6K,SAAA,kBAAA,CAAA,SAAA,EAOpJA,QAPoJ,CAAA,EAOzIE,OAPyI,CAOjID,SAPiI,CAAA;EAqBjKE;;;;;;;EAAmCJ,MAAAA,CAAAA,KAAAA,EAN/CC,QAM+CD,EAAAA,QAAAA,CAAAA,EAN1BF,kBAM0BE,CAAAA,EANLG,OAMKH,CANGE,SAMHF,CAAAA;AAAuB;;;;;uBAA1DI,0BAAAA,SAAmCJ,uBAAAA;gCAC/BD,sBAAsBI,QAAQJ;wCACtBA,oBAAoBI,QAAQJ"}
@@ -0,0 +1 @@
1
+ {"version":3,"file":"embeddings.d.cts","names":["AsyncCaller","AsyncCallerParams","EmbeddingsParams","EmbeddingsInterface","TOutput","Promise","Embeddings"],"sources":["../src/embeddings.d.ts"],"sourcesContent":["import { AsyncCaller, AsyncCallerParams } from \"./utils/async_caller.js\";\n/**\n * The parameters required to initialize an instance of the Embeddings\n * class.\n */\nexport type EmbeddingsParams = AsyncCallerParams;\nexport interface EmbeddingsInterface<TOutput = number[]> {\n /**\n * An abstract method that takes an array of documents as input and\n * returns a promise that resolves to an array of vectors for each\n * document.\n * @param documents An array of documents to be embedded.\n * @returns A promise that resolves to an array of vectors for each document.\n */\n embedDocuments(documents: string[]): Promise<TOutput[]>;\n /**\n * An abstract method that takes a single document as input and returns a\n * promise that resolves to a vector for the query document.\n * @param document A single document to be embedded.\n * @returns A promise that resolves to a vector for the query document.\n */\n embedQuery(document: string): Promise<TOutput>;\n}\n/**\n * An abstract class that provides methods for embedding documents and\n * queries using LangChain.\n */\nexport declare abstract class Embeddings<TOutput = number[]> implements EmbeddingsInterface<TOutput> {\n /**\n * The async caller should be used by subclasses to make any async calls,\n * which will thus benefit from the concurrency and retry logic.\n */\n caller: AsyncCaller;\n constructor(params: EmbeddingsParams);\n /**\n * An abstract method that takes an array of documents as input and\n * returns a promise that resolves to an array of vectors for each\n * document.\n * @param documents An array of documents to be embedded.\n * @returns A promise that resolves to an array of vectors for each document.\n */\n abstract embedDocuments(documents: string[]): Promise<TOutput[]>;\n /**\n * An abstract method that takes a single document as input and returns a\n * promise that resolves to a vector for the query document.\n * @param document A single document to be embedded.\n * @returns A promise that resolves to a vector for the query document.\n */\n abstract embedQuery(document: string): Promise<TOutput>;\n}\n//# sourceMappingURL=embeddings.d.ts.map"],"mappings":";;;;;;AAKA;AACA;AAQiDI,KATrCF,gBAAAA,GAAmBD,iBASkBG;AAARC,UARxBF,mBAQwBE,CAAAA,UAAAA,MAAAA,EAAAA,CAAAA,CAAAA;EAOCD;;AAAD;AAMzC;;;;EAc0DA,cAAAA,CAAAA,SAAAA,EAAAA,MAAAA,EAAAA,CAAAA,EA3BjBC,OA2BiBD,CA3BTA,OA2BSA,EAAAA,CAAAA;EAARC;;;;AAdyC;;gCANzDA,QAAQD;;;;;;uBAMZE,0CAA0CH,oBAAoBC;;;;;UAKhFJ;sBACYE;;;;;;;;gDAQ0BG,QAAQD;;;;;;;yCAOfC,QAAQD"}
@@ -0,0 +1 @@
1
+ {"version":3,"file":"embeddings.d.ts","names":["AsyncCaller","AsyncCallerParams","EmbeddingsParams","EmbeddingsInterface","TOutput","Promise","Embeddings"],"sources":["../src/embeddings.d.ts"],"sourcesContent":["import { AsyncCaller, AsyncCallerParams } from \"./utils/async_caller.js\";\n/**\n * The parameters required to initialize an instance of the Embeddings\n * class.\n */\nexport type EmbeddingsParams = AsyncCallerParams;\nexport interface EmbeddingsInterface<TOutput = number[]> {\n /**\n * An abstract method that takes an array of documents as input and\n * returns a promise that resolves to an array of vectors for each\n * document.\n * @param documents An array of documents to be embedded.\n * @returns A promise that resolves to an array of vectors for each document.\n */\n embedDocuments(documents: string[]): Promise<TOutput[]>;\n /**\n * An abstract method that takes a single document as input and returns a\n * promise that resolves to a vector for the query document.\n * @param document A single document to be embedded.\n * @returns A promise that resolves to a vector for the query document.\n */\n embedQuery(document: string): Promise<TOutput>;\n}\n/**\n * An abstract class that provides methods for embedding documents and\n * queries using LangChain.\n */\nexport declare abstract class Embeddings<TOutput = number[]> implements EmbeddingsInterface<TOutput> {\n /**\n * The async caller should be used by subclasses to make any async calls,\n * which will thus benefit from the concurrency and retry logic.\n */\n caller: AsyncCaller;\n constructor(params: EmbeddingsParams);\n /**\n * An abstract method that takes an array of documents as input and\n * returns a promise that resolves to an array of vectors for each\n * document.\n * @param documents An array of documents to be embedded.\n * @returns A promise that resolves to an array of vectors for each document.\n */\n abstract embedDocuments(documents: string[]): Promise<TOutput[]>;\n /**\n * An abstract method that takes a single document as input and returns a\n * promise that resolves to a vector for the query document.\n * @param document A single document to be embedded.\n * @returns A promise that resolves to a vector for the query document.\n */\n abstract embedQuery(document: string): Promise<TOutput>;\n}\n//# sourceMappingURL=embeddings.d.ts.map"],"mappings":";;;;;;AAKA;AACA;AAQiDI,KATrCF,gBAAAA,GAAmBD,iBASkBG;AAARC,UARxBF,mBAQwBE,CAAAA,UAAAA,MAAAA,EAAAA,CAAAA,CAAAA;EAOCD;;AAAD;AAMzC;;;;EAc0DA,cAAAA,CAAAA,SAAAA,EAAAA,MAAAA,EAAAA,CAAAA,EA3BjBC,OA2BiBD,CA3BTA,OA2BSA,EAAAA,CAAAA;EAARC;;;;AAdyC;;gCANzDA,QAAQD;;;;;;uBAMZE,0CAA0CH,oBAAoBC;;;;;UAKhFJ;sBACYE;;;;;;;;gDAQ0BG,QAAQD;;;;;;;yCAOfC,QAAQD"}
@@ -0,0 +1 @@
1
+ {"version":3,"file":"base.d.cts","names":["Serializable","Example","BaseExampleSelector","Promise"],"sources":["../../src/example_selectors/base.d.ts"],"sourcesContent":["import { Serializable } from \"../load/serializable.js\";\nimport type { Example } from \"../prompts/base.js\";\n/**\n * Base class for example selectors.\n */\nexport declare abstract class BaseExampleSelector extends Serializable {\n lc_namespace: string[];\n /**\n * Adds an example to the example selector.\n * @param example The example to add to the example selector.\n * @returns A Promise that resolves to void or a string.\n */\n abstract addExample(example: Example): Promise<void | string>;\n /**\n * Selects examples from the example selector given the input variables.\n * @param input_variables The input variables to select examples with.\n * @returns A Promise that resolves to an array of selected examples.\n */\n abstract selectExamples(input_variables: Example): Promise<Example[]>;\n}\n//# sourceMappingURL=base.d.ts.map"],"mappings":";;;;;;;AAKA;AAOiCC,uBAPHC,mBAAAA,SAA4BF,YAAAA,CAOzBC;EAAUE,YAAAA,EAAAA,MAAAA,EAAAA;EAMEF;;;;AAbyB;+BAOrCA,UAAUE;;;;;;2CAMEF,UAAUE,QAAQF"}
@@ -0,0 +1 @@
1
+ {"version":3,"file":"base.d.ts","names":["Serializable","Example","BaseExampleSelector","Promise"],"sources":["../../src/example_selectors/base.d.ts"],"sourcesContent":["import { Serializable } from \"../load/serializable.js\";\nimport type { Example } from \"../prompts/base.js\";\n/**\n * Base class for example selectors.\n */\nexport declare abstract class BaseExampleSelector extends Serializable {\n lc_namespace: string[];\n /**\n * Adds an example to the example selector.\n * @param example The example to add to the example selector.\n * @returns A Promise that resolves to void or a string.\n */\n abstract addExample(example: Example): Promise<void | string>;\n /**\n * Selects examples from the example selector given the input variables.\n * @param input_variables The input variables to select examples with.\n * @returns A Promise that resolves to an array of selected examples.\n */\n abstract selectExamples(input_variables: Example): Promise<Example[]>;\n}\n//# sourceMappingURL=base.d.ts.map"],"mappings":";;;;;;;AAKA;AAOiCC,uBAPHC,mBAAAA,SAA4BF,YAAAA,CAOzBC;EAAUE,YAAAA,EAAAA,MAAAA,EAAAA;EAMEF;;;;AAbyB;+BAOrCA,UAAUE;;;;;;2CAMEF,UAAUE,QAAQF"}
@@ -0,0 +1 @@
1
+ {"version":3,"file":"conditional.d.cts","names":["BaseChatModel","BasePromptTemplate","BaseLanguageModelInterface","BaseLLM","PartialValues","BaseGetPromptAsyncOptions","BasePromptSelector","Promise","ConditionalPromptSelector","Array","isLLM","isChatModel"],"sources":["../../src/example_selectors/conditional.d.ts"],"sourcesContent":["import type { BaseChatModel } from \"../language_models/chat_models.js\";\nimport type { BasePromptTemplate } from \"../prompts/base.js\";\nimport type { BaseLanguageModelInterface } from \"../language_models/base.js\";\nimport type { BaseLLM } from \"../language_models/llms.js\";\nimport type { PartialValues } from \"../utils/types/index.js\";\nexport type BaseGetPromptAsyncOptions = {\n partialVariables?: PartialValues;\n};\n/**\n * Abstract class that defines the interface for selecting a prompt for a\n * given language model.\n */\nexport declare abstract class BasePromptSelector {\n /**\n * Abstract method that must be implemented by any class that extends\n * `BasePromptSelector`. It takes a language model as an argument and\n * returns a prompt template.\n * @param llm The language model for which to get a prompt.\n * @returns A prompt template.\n */\n abstract getPrompt(llm: BaseLanguageModelInterface): BasePromptTemplate;\n /**\n * Asynchronous version of `getPrompt` that also accepts an options object\n * for partial variables.\n * @param llm The language model for which to get a prompt.\n * @param options Optional object for partial variables.\n * @returns A Promise that resolves to a prompt template.\n */\n getPromptAsync(llm: BaseLanguageModelInterface, options?: BaseGetPromptAsyncOptions): Promise<BasePromptTemplate>;\n}\n/**\n * Concrete implementation of `BasePromptSelector` that selects a prompt\n * based on a set of conditions. It has a default prompt that it returns\n * if none of the conditions are met.\n */\nexport declare class ConditionalPromptSelector extends BasePromptSelector {\n defaultPrompt: BasePromptTemplate;\n conditionals: Array<[\n condition: (llm: BaseLanguageModelInterface) => boolean,\n prompt: BasePromptTemplate\n ]>;\n constructor(default_prompt: BasePromptTemplate, conditionals?: Array<[\n condition: (llm: BaseLanguageModelInterface) => boolean,\n prompt: BasePromptTemplate\n ]>);\n /**\n * Method that selects a prompt based on a set of conditions. If none of\n * the conditions are met, it returns the default prompt.\n * @param llm The language model for which to get a prompt.\n * @returns A prompt template.\n */\n getPrompt(llm: BaseLanguageModelInterface): BasePromptTemplate;\n}\n/**\n * Type guard function that checks if a given language model is of type\n * `BaseLLM`.\n */\nexport declare function isLLM(llm: BaseLanguageModelInterface): llm is BaseLLM;\n/**\n * Type guard function that checks if a given language model is of type\n * `BaseChatModel`.\n */\nexport declare function isChatModel(llm: BaseLanguageModelInterface): llm is BaseChatModel;\n//# sourceMappingURL=conditional.d.ts.map"],"mappings":";;;;;;;KAKYK,yBAAAA;qBACWD;AADvB,CAAA;AAOA;;;;AAgB8DC,uBAhBhCC,kBAAAA,CAgBgCD;EAAoCJ;;AAAD;AAOjG;;;;EAEkBQ,SAAAA,SAAAA,CAAAA,GAAAA,EAjBUP,0BAiBVO,CAAAA,EAjBuCR,kBAiBvCQ;EAIcR;;;;;;;EANyC,cAAA,CAAA,GAAA,EAPjDC,0BAOiD,EAAA,OAAA,CAAA,EAPXG,yBAOW,CAAA,EAPiBE,OAOjB,CAPyBN,kBAOzB,CAAA;AAsBzE;AAKA;;;;;cA3BqBO,yBAAAA,SAAkCF,kBAAAA;iBACpCL;gBACDQ,wBACOP,gDACTD;8BAEgBA,mCAAmCQ,wBAC1CP,gDACTD;;;;;;;iBAQGC,6BAA6BD;;;;;;iBAMxBS,KAAAA,MAAWR,oCAAoCC;;;;;iBAK/CQ,WAAAA,MAAiBT,oCAAoCF"}
@@ -0,0 +1 @@
1
+ {"version":3,"file":"conditional.d.ts","names":["BaseChatModel","BasePromptTemplate","BaseLanguageModelInterface","BaseLLM","PartialValues","BaseGetPromptAsyncOptions","BasePromptSelector","Promise","ConditionalPromptSelector","Array","isLLM","isChatModel"],"sources":["../../src/example_selectors/conditional.d.ts"],"sourcesContent":["import type { BaseChatModel } from \"../language_models/chat_models.js\";\nimport type { BasePromptTemplate } from \"../prompts/base.js\";\nimport type { BaseLanguageModelInterface } from \"../language_models/base.js\";\nimport type { BaseLLM } from \"../language_models/llms.js\";\nimport type { PartialValues } from \"../utils/types/index.js\";\nexport type BaseGetPromptAsyncOptions = {\n partialVariables?: PartialValues;\n};\n/**\n * Abstract class that defines the interface for selecting a prompt for a\n * given language model.\n */\nexport declare abstract class BasePromptSelector {\n /**\n * Abstract method that must be implemented by any class that extends\n * `BasePromptSelector`. It takes a language model as an argument and\n * returns a prompt template.\n * @param llm The language model for which to get a prompt.\n * @returns A prompt template.\n */\n abstract getPrompt(llm: BaseLanguageModelInterface): BasePromptTemplate;\n /**\n * Asynchronous version of `getPrompt` that also accepts an options object\n * for partial variables.\n * @param llm The language model for which to get a prompt.\n * @param options Optional object for partial variables.\n * @returns A Promise that resolves to a prompt template.\n */\n getPromptAsync(llm: BaseLanguageModelInterface, options?: BaseGetPromptAsyncOptions): Promise<BasePromptTemplate>;\n}\n/**\n * Concrete implementation of `BasePromptSelector` that selects a prompt\n * based on a set of conditions. It has a default prompt that it returns\n * if none of the conditions are met.\n */\nexport declare class ConditionalPromptSelector extends BasePromptSelector {\n defaultPrompt: BasePromptTemplate;\n conditionals: Array<[\n condition: (llm: BaseLanguageModelInterface) => boolean,\n prompt: BasePromptTemplate\n ]>;\n constructor(default_prompt: BasePromptTemplate, conditionals?: Array<[\n condition: (llm: BaseLanguageModelInterface) => boolean,\n prompt: BasePromptTemplate\n ]>);\n /**\n * Method that selects a prompt based on a set of conditions. If none of\n * the conditions are met, it returns the default prompt.\n * @param llm The language model for which to get a prompt.\n * @returns A prompt template.\n */\n getPrompt(llm: BaseLanguageModelInterface): BasePromptTemplate;\n}\n/**\n * Type guard function that checks if a given language model is of type\n * `BaseLLM`.\n */\nexport declare function isLLM(llm: BaseLanguageModelInterface): llm is BaseLLM;\n/**\n * Type guard function that checks if a given language model is of type\n * `BaseChatModel`.\n */\nexport declare function isChatModel(llm: BaseLanguageModelInterface): llm is BaseChatModel;\n//# sourceMappingURL=conditional.d.ts.map"],"mappings":";;;;;;;KAKYK,yBAAAA;qBACWD;AADvB,CAAA;AAOA;;;;AAgB8DC,uBAhBhCC,kBAAAA,CAgBgCD;EAAoCJ;;AAAD;AAOjG;;;;EAEkBQ,SAAAA,SAAAA,CAAAA,GAAAA,EAjBUP,0BAiBVO,CAAAA,EAjBuCR,kBAiBvCQ;EAIcR;;;;;;;EANyC,cAAA,CAAA,GAAA,EAPjDC,0BAOiD,EAAA,OAAA,CAAA,EAPXG,yBAOW,CAAA,EAPiBE,OAOjB,CAPyBN,kBAOzB,CAAA;AAsBzE;AAKA;;;;;cA3BqBO,yBAAAA,SAAkCF,kBAAAA;iBACpCL;gBACDQ,wBACOP,gDACTD;8BAEgBA,mCAAmCQ,wBAC1CP,gDACTD;;;;;;;iBAQGC,6BAA6BD;;;;;;iBAMxBS,KAAAA,MAAWR,oCAAoCC;;;;;iBAK/CQ,WAAAA,MAAiBT,oCAAoCF"}
@@ -0,0 +1 @@
1
+ {"version":3,"file":"length_based.d.cts","names":["Example","BaseExampleSelector","PromptTemplate","LengthBasedExampleSelectorInput","LengthBasedExampleSelector","Promise"],"sources":["../../src/example_selectors/length_based.d.ts"],"sourcesContent":["import { Example } from \"../prompts/base.js\";\nimport { BaseExampleSelector } from \"./base.js\";\nimport { PromptTemplate } from \"../prompts/prompt.js\";\n/**\n * Interface for the input parameters of the LengthBasedExampleSelector\n * class.\n */\nexport interface LengthBasedExampleSelectorInput {\n examplePrompt: PromptTemplate;\n maxLength?: number;\n getTextLength?: (text: string) => number;\n}\n/**\n * A specialized example selector that selects examples based on their\n * length, ensuring that the total length of the selected examples does\n * not exceed a specified maximum length.\n * @example\n * ```typescript\n * const exampleSelector = new LengthBasedExampleSelector(\n * [\n * { input: \"happy\", output: \"sad\" },\n * { input: \"tall\", output: \"short\" },\n * { input: \"energetic\", output: \"lethargic\" },\n * { input: \"sunny\", output: \"gloomy\" },\n * { input: \"windy\", output: \"calm\" },\n * ],\n * {\n * examplePrompt: new PromptTemplate({\n * inputVariables: [\"input\", \"output\"],\n * template: \"Input: {input}\\nOutput: {output}\",\n * }),\n * maxLength: 25,\n * },\n * );\n * const dynamicPrompt = new FewShotPromptTemplate({\n * exampleSelector,\n * examplePrompt: new PromptTemplate({\n * inputVariables: [\"input\", \"output\"],\n * template: \"Input: {input}\\nOutput: {output}\",\n * }),\n * prefix: \"Give the antonym of every input\",\n * suffix: \"Input: {adjective}\\nOutput:\",\n * inputVariables: [\"adjective\"],\n * });\n * console.log(dynamicPrompt.format({ adjective: \"big\" }));\n * console.log(\n * dynamicPrompt.format({\n * adjective:\n * \"big and huge and massive and large and gigantic and tall and much much much much much bigger than everything else\",\n * }),\n * );\n * ```\n */\nexport declare class LengthBasedExampleSelector extends BaseExampleSelector {\n protected examples: Example[];\n examplePrompt: PromptTemplate;\n getTextLength: (text: string) => number;\n maxLength: number;\n exampleTextLengths: number[];\n constructor(data: LengthBasedExampleSelectorInput);\n /**\n * Adds an example to the list of examples and calculates its length.\n * @param example The example to be added.\n * @returns Promise that resolves when the example has been added and its length calculated.\n */\n addExample(example: Example): Promise<void>;\n /**\n * Calculates the lengths of the examples.\n * @param v Array of lengths of the examples.\n * @param values Instance of LengthBasedExampleSelector.\n * @returns Promise that resolves with an array of lengths of the examples.\n */\n calculateExampleTextLengths(v: number[], values: LengthBasedExampleSelector): Promise<number[]>;\n /**\n * Selects examples until the total length of the selected examples\n * reaches the maxLength.\n * @param inputVariables The input variables for the examples.\n * @returns Promise that resolves with an array of selected examples.\n */\n selectExamples(inputVariables: Example): Promise<Example[]>;\n /**\n * Creates a new instance of LengthBasedExampleSelector and adds a list of\n * examples to it.\n * @param examples Array of examples to be added.\n * @param args Input parameters for the LengthBasedExampleSelector.\n * @returns Promise that resolves with a new instance of LengthBasedExampleSelector with the examples added.\n */\n static fromExamples(examples: Example[], args: LengthBasedExampleSelectorInput): Promise<LengthBasedExampleSelector>;\n}\n//# sourceMappingURL=length_based.d.ts.map"],"mappings":";;;;;;;;AAOA;AA8CA;AACwBA,UA/CPG,+BAAAA,CA+COH;EACLE,aAAAA,EA/CAA,cA+CAA;EAIGC,SAAAA,CAAAA,EAAAA,MAAAA;EAMEH,aAAAA,CAAAA,EAAAA,CAAAA,IAAAA,EAAAA,MAAAA,EAAAA,GAAAA,MAAAA;;;;;;;;;;;;AAZmD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;cAAtDI,0BAAAA,SAAmCH,mBAAAA;sBAChCD;iBACLE;;;;oBAIGC;;;;;;sBAMEH,UAAUK;;;;;;;mDAOmBD,6BAA6BC;;;;;;;iCAO/CL,UAAUK,QAAQL;;;;;;;;gCAQnBA,iBAAiBG,kCAAkCE,QAAQD"}
@@ -0,0 +1 @@
1
+ {"version":3,"file":"length_based.d.ts","names":["Example","BaseExampleSelector","PromptTemplate","LengthBasedExampleSelectorInput","LengthBasedExampleSelector","Promise"],"sources":["../../src/example_selectors/length_based.d.ts"],"sourcesContent":["import { Example } from \"../prompts/base.js\";\nimport { BaseExampleSelector } from \"./base.js\";\nimport { PromptTemplate } from \"../prompts/prompt.js\";\n/**\n * Interface for the input parameters of the LengthBasedExampleSelector\n * class.\n */\nexport interface LengthBasedExampleSelectorInput {\n examplePrompt: PromptTemplate;\n maxLength?: number;\n getTextLength?: (text: string) => number;\n}\n/**\n * A specialized example selector that selects examples based on their\n * length, ensuring that the total length of the selected examples does\n * not exceed a specified maximum length.\n * @example\n * ```typescript\n * const exampleSelector = new LengthBasedExampleSelector(\n * [\n * { input: \"happy\", output: \"sad\" },\n * { input: \"tall\", output: \"short\" },\n * { input: \"energetic\", output: \"lethargic\" },\n * { input: \"sunny\", output: \"gloomy\" },\n * { input: \"windy\", output: \"calm\" },\n * ],\n * {\n * examplePrompt: new PromptTemplate({\n * inputVariables: [\"input\", \"output\"],\n * template: \"Input: {input}\\nOutput: {output}\",\n * }),\n * maxLength: 25,\n * },\n * );\n * const dynamicPrompt = new FewShotPromptTemplate({\n * exampleSelector,\n * examplePrompt: new PromptTemplate({\n * inputVariables: [\"input\", \"output\"],\n * template: \"Input: {input}\\nOutput: {output}\",\n * }),\n * prefix: \"Give the antonym of every input\",\n * suffix: \"Input: {adjective}\\nOutput:\",\n * inputVariables: [\"adjective\"],\n * });\n * console.log(dynamicPrompt.format({ adjective: \"big\" }));\n * console.log(\n * dynamicPrompt.format({\n * adjective:\n * \"big and huge and massive and large and gigantic and tall and much much much much much bigger than everything else\",\n * }),\n * );\n * ```\n */\nexport declare class LengthBasedExampleSelector extends BaseExampleSelector {\n protected examples: Example[];\n examplePrompt: PromptTemplate;\n getTextLength: (text: string) => number;\n maxLength: number;\n exampleTextLengths: number[];\n constructor(data: LengthBasedExampleSelectorInput);\n /**\n * Adds an example to the list of examples and calculates its length.\n * @param example The example to be added.\n * @returns Promise that resolves when the example has been added and its length calculated.\n */\n addExample(example: Example): Promise<void>;\n /**\n * Calculates the lengths of the examples.\n * @param v Array of lengths of the examples.\n * @param values Instance of LengthBasedExampleSelector.\n * @returns Promise that resolves with an array of lengths of the examples.\n */\n calculateExampleTextLengths(v: number[], values: LengthBasedExampleSelector): Promise<number[]>;\n /**\n * Selects examples until the total length of the selected examples\n * reaches the maxLength.\n * @param inputVariables The input variables for the examples.\n * @returns Promise that resolves with an array of selected examples.\n */\n selectExamples(inputVariables: Example): Promise<Example[]>;\n /**\n * Creates a new instance of LengthBasedExampleSelector and adds a list of\n * examples to it.\n * @param examples Array of examples to be added.\n * @param args Input parameters for the LengthBasedExampleSelector.\n * @returns Promise that resolves with a new instance of LengthBasedExampleSelector with the examples added.\n */\n static fromExamples(examples: Example[], args: LengthBasedExampleSelectorInput): Promise<LengthBasedExampleSelector>;\n}\n//# sourceMappingURL=length_based.d.ts.map"],"mappings":";;;;;;;;AAOA;AA8CA;AACwBA,UA/CPG,+BAAAA,CA+COH;EACLE,aAAAA,EA/CAA,cA+CAA;EAIGC,SAAAA,CAAAA,EAAAA,MAAAA;EAMEH,aAAAA,CAAAA,EAAAA,CAAAA,IAAAA,EAAAA,MAAAA,EAAAA,GAAAA,MAAAA;;;;;;;;;;;;AAZmD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;cAAtDI,0BAAAA,SAAmCH,mBAAAA;sBAChCD;iBACLE;;;;oBAIGC;;;;;;sBAMEH,UAAUK;;;;;;;mDAOmBD,6BAA6BC;;;;;;;iCAO/CL,UAAUK,QAAQL;;;;;;;;gCAQnBA,iBAAiBG,kCAAkCE,QAAQD"}
@@ -0,0 +1 @@
1
+ {"version":3,"file":"semantic_similarity.d.cts","names":["Embeddings","VectorStoreInterface","VectorStoreRetrieverInterface","VectorStore","Example","BaseExampleSelector","SemanticSimilarityExampleSelectorInput","V","SemanticSimilarityExampleSelector","T","C","Promise","Record","Parameters"],"sources":["../../src/example_selectors/semantic_similarity.d.ts"],"sourcesContent":["import type { Embeddings } from \"../embeddings.js\";\nimport type { VectorStoreInterface, VectorStoreRetrieverInterface, VectorStore } from \"../vectorstores.js\";\nimport type { Example } from \"../prompts/base.js\";\nimport { BaseExampleSelector } from \"./base.js\";\n/**\n * Interface for the input data of the SemanticSimilarityExampleSelector\n * class.\n */\nexport type SemanticSimilarityExampleSelectorInput<V extends VectorStoreInterface = VectorStoreInterface> = {\n vectorStore: V;\n k?: number;\n filter?: V[\"FilterType\"];\n exampleKeys?: string[];\n inputKeys?: string[];\n vectorStoreRetriever?: never;\n} | {\n vectorStoreRetriever: VectorStoreRetrieverInterface<V>;\n exampleKeys?: string[];\n inputKeys?: string[];\n vectorStore?: never;\n k?: never;\n filter?: never;\n};\n/**\n * Class that selects examples based on semantic similarity. It extends\n * the BaseExampleSelector class.\n * @example\n * ```typescript\n * const exampleSelector = await SemanticSimilarityExampleSelector.fromExamples(\n * [\n * { input: \"happy\", output: \"sad\" },\n * { input: \"tall\", output: \"short\" },\n * { input: \"energetic\", output: \"lethargic\" },\n * { input: \"sunny\", output: \"gloomy\" },\n * { input: \"windy\", output: \"calm\" },\n * ],\n * new OpenAIEmbeddings(),\n * HNSWLib,\n * { k: 1 },\n * );\n * const dynamicPrompt = new FewShotPromptTemplate({\n * exampleSelector,\n * examplePrompt: PromptTemplate.fromTemplate(\n * \"Input: {input}\\nOutput: {output}\",\n * ),\n * prefix: \"Give the antonym of every input\",\n * suffix: \"Input: {adjective}\\nOutput:\",\n * inputVariables: [\"adjective\"],\n * });\n * console.log(await dynamicPrompt.format({ adjective: \"rainy\" }));\n * ```\n */\nexport declare class SemanticSimilarityExampleSelector<V extends VectorStoreInterface = VectorStoreInterface> extends BaseExampleSelector {\n vectorStoreRetriever: VectorStoreRetrieverInterface<V>;\n exampleKeys?: string[];\n inputKeys?: string[];\n constructor(data: SemanticSimilarityExampleSelectorInput<V>);\n /**\n * Method that adds a new example to the vectorStore. The example is\n * converted to a string and added to the vectorStore as a document.\n * @param example The example to be added to the vectorStore.\n * @returns Promise that resolves when the example has been added to the vectorStore.\n */\n addExample(example: Example): Promise<void>;\n /**\n * Method that selects which examples to use based on semantic similarity.\n * It performs a similarity search in the vectorStore using the input\n * variables and returns the examples with the highest similarity.\n * @param inputVariables The input variables used for the similarity search.\n * @returns Promise that resolves with an array of the selected examples.\n */\n selectExamples<T>(inputVariables: Record<string, T>): Promise<Example[]>;\n /**\n * Static method that creates a new instance of\n * SemanticSimilarityExampleSelector. It takes a list of examples, an\n * instance of Embeddings, a VectorStore class, and an options object as\n * parameters. It converts the examples to strings, creates a VectorStore\n * from the strings and the embeddings, and returns a new\n * SemanticSimilarityExampleSelector with the created VectorStore and the\n * options provided.\n * @param examples The list of examples to be used.\n * @param embeddings The instance of Embeddings to be used.\n * @param vectorStoreCls The VectorStore class to be used.\n * @param options The options object for the SemanticSimilarityExampleSelector.\n * @returns Promise that resolves with a new instance of SemanticSimilarityExampleSelector.\n */\n static fromExamples<C extends typeof VectorStore>(examples: Record<string, string>[], embeddings: Embeddings, vectorStoreCls: C, options?: {\n k?: number;\n inputKeys?: string[];\n } & Parameters<C[\"fromTexts\"]>[3]): Promise<SemanticSimilarityExampleSelector>;\n}\n//# sourceMappingURL=semantic_similarity.d.ts.map"],"mappings":";;;;;;;;;AAQA;;AAAoFC,KAAxEK,sCAAwEL,CAAAA,UAAvBA,oBAAuBA,GAAAA,oBAAAA,CAAAA,GAAAA;EACnEM,WAAAA,EAAAA,CAAAA;EAEJA,CAAAA,CAAAA,EAAAA,MAAAA;EAK2CA,MAAAA,CAAAA,EAL3CA,CAK2CA,CAAAA,YAAAA,CAAAA;EAA9BL,WAAAA,CAAAA,EAAAA,MAAAA,EAAAA;EAA6B,SAAA,CAAA,EAAA,MAAA,EAAA;EAoClCM,oBAAAA,CAAAA,EAAAA,KAAAA;CAA4CP,GAAAA;EAAuBA,oBAAAA,EApC9DC,6BAoC8DD,CApChCM,CAoCgCN,CAAAA;EAChCM,WAAAA,CAAAA,EAAAA,MAAAA,EAAAA;EAA9BL,SAAAA,CAAAA,EAAAA,MAAAA,EAAAA;EAGmCK,WAAAA,CAAAA,EAAAA,KAAAA;EAAvCD,CAAAA,CAAAA,EAAAA,KAAAA;EAOEF,MAAAA,CAAAA,EAAAA,KAAAA;CAAUO;;;;;;;;;;;;;;AAXuG;;;;;;;;;;;;;;;;cAApHH,4CAA4CP,uBAAuBA,8BAA8BI,mBAAAA;wBAC5FH,8BAA8BK;;;oBAGlCD,uCAAuCC;;;;;;;sBAOrCH,UAAUO;;;;;;;;oCAQIC,eAAeH,KAAKE,QAAQP;;;;;;;;;;;;;;;uCAezBD,uBAAuBS,sCAAsCZ,4BAA4BU;;;MAG1HG,WAAWH,qBAAqBC,QAAQH"}
@@ -0,0 +1 @@
1
+ {"version":3,"file":"semantic_similarity.d.ts","names":["Embeddings","VectorStoreInterface","VectorStoreRetrieverInterface","VectorStore","Example","BaseExampleSelector","SemanticSimilarityExampleSelectorInput","V","SemanticSimilarityExampleSelector","T","C","Promise","Record","Parameters"],"sources":["../../src/example_selectors/semantic_similarity.d.ts"],"sourcesContent":["import type { Embeddings } from \"../embeddings.js\";\nimport type { VectorStoreInterface, VectorStoreRetrieverInterface, VectorStore } from \"../vectorstores.js\";\nimport type { Example } from \"../prompts/base.js\";\nimport { BaseExampleSelector } from \"./base.js\";\n/**\n * Interface for the input data of the SemanticSimilarityExampleSelector\n * class.\n */\nexport type SemanticSimilarityExampleSelectorInput<V extends VectorStoreInterface = VectorStoreInterface> = {\n vectorStore: V;\n k?: number;\n filter?: V[\"FilterType\"];\n exampleKeys?: string[];\n inputKeys?: string[];\n vectorStoreRetriever?: never;\n} | {\n vectorStoreRetriever: VectorStoreRetrieverInterface<V>;\n exampleKeys?: string[];\n inputKeys?: string[];\n vectorStore?: never;\n k?: never;\n filter?: never;\n};\n/**\n * Class that selects examples based on semantic similarity. It extends\n * the BaseExampleSelector class.\n * @example\n * ```typescript\n * const exampleSelector = await SemanticSimilarityExampleSelector.fromExamples(\n * [\n * { input: \"happy\", output: \"sad\" },\n * { input: \"tall\", output: \"short\" },\n * { input: \"energetic\", output: \"lethargic\" },\n * { input: \"sunny\", output: \"gloomy\" },\n * { input: \"windy\", output: \"calm\" },\n * ],\n * new OpenAIEmbeddings(),\n * HNSWLib,\n * { k: 1 },\n * );\n * const dynamicPrompt = new FewShotPromptTemplate({\n * exampleSelector,\n * examplePrompt: PromptTemplate.fromTemplate(\n * \"Input: {input}\\nOutput: {output}\",\n * ),\n * prefix: \"Give the antonym of every input\",\n * suffix: \"Input: {adjective}\\nOutput:\",\n * inputVariables: [\"adjective\"],\n * });\n * console.log(await dynamicPrompt.format({ adjective: \"rainy\" }));\n * ```\n */\nexport declare class SemanticSimilarityExampleSelector<V extends VectorStoreInterface = VectorStoreInterface> extends BaseExampleSelector {\n vectorStoreRetriever: VectorStoreRetrieverInterface<V>;\n exampleKeys?: string[];\n inputKeys?: string[];\n constructor(data: SemanticSimilarityExampleSelectorInput<V>);\n /**\n * Method that adds a new example to the vectorStore. The example is\n * converted to a string and added to the vectorStore as a document.\n * @param example The example to be added to the vectorStore.\n * @returns Promise that resolves when the example has been added to the vectorStore.\n */\n addExample(example: Example): Promise<void>;\n /**\n * Method that selects which examples to use based on semantic similarity.\n * It performs a similarity search in the vectorStore using the input\n * variables and returns the examples with the highest similarity.\n * @param inputVariables The input variables used for the similarity search.\n * @returns Promise that resolves with an array of the selected examples.\n */\n selectExamples<T>(inputVariables: Record<string, T>): Promise<Example[]>;\n /**\n * Static method that creates a new instance of\n * SemanticSimilarityExampleSelector. It takes a list of examples, an\n * instance of Embeddings, a VectorStore class, and an options object as\n * parameters. It converts the examples to strings, creates a VectorStore\n * from the strings and the embeddings, and returns a new\n * SemanticSimilarityExampleSelector with the created VectorStore and the\n * options provided.\n * @param examples The list of examples to be used.\n * @param embeddings The instance of Embeddings to be used.\n * @param vectorStoreCls The VectorStore class to be used.\n * @param options The options object for the SemanticSimilarityExampleSelector.\n * @returns Promise that resolves with a new instance of SemanticSimilarityExampleSelector.\n */\n static fromExamples<C extends typeof VectorStore>(examples: Record<string, string>[], embeddings: Embeddings, vectorStoreCls: C, options?: {\n k?: number;\n inputKeys?: string[];\n } & Parameters<C[\"fromTexts\"]>[3]): Promise<SemanticSimilarityExampleSelector>;\n}\n//# sourceMappingURL=semantic_similarity.d.ts.map"],"mappings":";;;;;;;;;AAQA;;AAAoFC,KAAxEK,sCAAwEL,CAAAA,UAAvBA,oBAAuBA,GAAAA,oBAAAA,CAAAA,GAAAA;EACnEM,WAAAA,EAAAA,CAAAA;EAEJA,CAAAA,CAAAA,EAAAA,MAAAA;EAK2CA,MAAAA,CAAAA,EAL3CA,CAK2CA,CAAAA,YAAAA,CAAAA;EAA9BL,WAAAA,CAAAA,EAAAA,MAAAA,EAAAA;EAA6B,SAAA,CAAA,EAAA,MAAA,EAAA;EAoClCM,oBAAAA,CAAAA,EAAAA,KAAAA;CAA4CP,GAAAA;EAAuBA,oBAAAA,EApC9DC,6BAoC8DD,CApChCM,CAoCgCN,CAAAA;EAChCM,WAAAA,CAAAA,EAAAA,MAAAA,EAAAA;EAA9BL,SAAAA,CAAAA,EAAAA,MAAAA,EAAAA;EAGmCK,WAAAA,CAAAA,EAAAA,KAAAA;EAAvCD,CAAAA,CAAAA,EAAAA,KAAAA;EAOEF,MAAAA,CAAAA,EAAAA,KAAAA;CAAUO;;;;;;;;;;;;;;AAXuG;;;;;;;;;;;;;;;;cAApHH,4CAA4CP,uBAAuBA,8BAA8BI,mBAAAA;wBAC5FH,8BAA8BK;;;oBAGlCD,uCAAuCC;;;;;;;sBAOrCH,UAAUO;;;;;;;;oCAQIC,eAAeH,KAAKE,QAAQP;;;;;;;;;;;;;;;uCAezBD,uBAAuBS,sCAAsCZ,4BAA4BU;;;MAG1HG,WAAWH,qBAAqBC,QAAQH"}
@@ -0,0 +1 @@
1
+ {"version":3,"file":"base.d.cts","names":["VectorStore","RecordManagerInterface","HashKeyEncoder","DocumentInterface","BaseDocumentLoader","Metadata","Record","IndexingResult","StringOrDocFunc","HashedDocumentInterface","HashedDocumentArgs","_HashedDocument","CleanupMode","IndexOptions","_batch","T","_deduplicateInOrder","_getSourceIdAssigner","_isBaseDocumentLoader","IndexArgs","index","Promise"],"sources":["../../src/indexing/base.d.ts"],"sourcesContent":["import { VectorStore } from \"../vectorstores.js\";\nimport { RecordManagerInterface } from \"./record_manager.js\";\nimport { type HashKeyEncoder } from \"../utils/hash.js\";\nimport { DocumentInterface } from \"../documents/document.js\";\nimport { BaseDocumentLoader } from \"../document_loaders/base.js\";\ntype Metadata = Record<string, unknown>;\ntype IndexingResult = {\n numAdded: number;\n numDeleted: number;\n numUpdated: number;\n numSkipped: number;\n};\ntype StringOrDocFunc = string | ((doc: DocumentInterface) => string);\nexport interface HashedDocumentInterface extends DocumentInterface {\n uid: string;\n hash_?: string;\n contentHash?: string;\n metadataHash?: string;\n pageContent: string;\n metadata: Metadata;\n calculateHashes(): void;\n toDocument(): DocumentInterface;\n}\ninterface HashedDocumentArgs {\n pageContent: string;\n metadata: Metadata;\n uid: string;\n}\n/**\n * HashedDocument is a Document with hashes calculated.\n * Hashes are calculated based on page content and metadata.\n * It is used for indexing.\n */\nexport declare class _HashedDocument implements HashedDocumentInterface {\n uid: string;\n hash_?: string;\n contentHash?: string;\n metadataHash?: string;\n pageContent: string;\n metadata: Metadata;\n private keyEncoder;\n constructor(fields: HashedDocumentArgs);\n makeDefaultKeyEncoder(keyEncoderFn: HashKeyEncoder): void;\n calculateHashes(): void;\n toDocument(): DocumentInterface;\n static fromDocument(document: DocumentInterface, uid?: string): _HashedDocument;\n private _hashStringToUUID;\n private _hashNestedDictToUUID;\n}\nexport type CleanupMode = \"full\" | \"incremental\";\nexport type IndexOptions = {\n /**\n * The number of documents to index in one batch.\n */\n batchSize?: number;\n /**\n * The cleanup mode to use. Can be \"full\", \"incremental\" or undefined.\n * - **Incremental**: Cleans up all documents that haven't been updated AND\n * that are associated with source ids that were seen\n * during indexing.\n * Clean up is done continuously during indexing helping\n * to minimize the probability of users seeing duplicated\n * content.\n * - **Full**: Delete all documents that haven to been returned by the loader.\n * Clean up runs after all documents have been indexed.\n * This means that users may see duplicated content during indexing.\n * - **undefined**: Do not delete any documents.\n */\n cleanup?: CleanupMode;\n /**\n * Optional key that helps identify the original source of the document.\n * Must either be a string representing the key of the source in the metadata\n * or a function that takes a document and returns a string representing the source.\n * **Required when cleanup is incremental**.\n */\n sourceIdKey?: StringOrDocFunc;\n /**\n * Batch size to use when cleaning up documents.\n */\n cleanupBatchSize?: number;\n /**\n * Force update documents even if they are present in the\n * record manager. Useful if you are re-indexing with updated embeddings.\n */\n forceUpdate?: boolean;\n};\nexport declare function _batch<T>(size: number, iterable: T[]): T[][];\nexport declare function _deduplicateInOrder(hashedDocuments: HashedDocumentInterface[]): HashedDocumentInterface[];\nexport declare function _getSourceIdAssigner(sourceIdKey: StringOrDocFunc | null): (doc: DocumentInterface) => string | null;\nexport declare const _isBaseDocumentLoader: (arg: any) => arg is BaseDocumentLoader;\ninterface IndexArgs {\n docsSource: BaseDocumentLoader | DocumentInterface[];\n recordManager: RecordManagerInterface;\n vectorStore: VectorStore;\n options?: IndexOptions;\n}\n/**\n * Index data from the doc source into the vector store.\n *\n * Indexing functionality uses a manager to keep track of which documents\n * are in the vector store.\n *\n * This allows us to keep track of which documents were updated, and which\n * documents were deleted, which documents should be skipped.\n *\n * For the time being, documents are indexed using their hashes, and users\n * are not able to specify the uid of the document.\n *\n * @param {IndexArgs} args\n * @param {BaseDocumentLoader | DocumentInterface[]} args.docsSource The source of documents to index. Can be a DocumentLoader or a list of Documents.\n * @param {RecordManagerInterface} args.recordManager The record manager to use for keeping track of indexed documents.\n * @param {VectorStore} args.vectorStore The vector store to use for storing the documents.\n * @param {IndexOptions | undefined} args.options Options for indexing.\n * @returns {Promise<IndexingResult>}\n */\nexport declare function index(args: IndexArgs): Promise<IndexingResult>;\nexport {};\n//# sourceMappingURL=base.d.ts.map"],"mappings":";;;;;;;KAKKK,QAAAA,GAAWC;KACXC,cAAAA;EADAF,QAAAA,EAAAA,MAAQ;EACRE,UAAAA,EAAAA,MAAc;EAMdC,UAAAA,EAAAA,MAAe;EACHC,UAAAA,EAAAA,MAAAA;CAMHJ;KAPTG,eAAAA,GASaL,MAAAA,GAAAA,CAAAA,CAAAA,GAAAA,EATqBA,iBASrBA,EAAAA,GAAAA,MAAAA,CAAAA;AAR+BA,UAAhCM,uBAAAA,SAAgCN,iBAAAA,CAAAA;EAAiB,GAAA,EAAA,MAAA;EAUxDO,KAAAA,CAAAA,EAAAA,MAAAA;EAUWC,WAAAA,CAAAA,EAAAA,MAAe;EAMtBN,YAAAA,CAAAA,EAAAA,MAAAA;EAEUK,WAAAA,EAAAA,MAAAA;EACgBR,QAAAA,EAvB1BG,QAuB0BH;EAEtBC,eAAAA,EAAAA,EAAAA,IAAAA;EACgBA,UAAAA,EAAAA,EAxBhBA,iBAwBgBA;;UAtBxBO,kBAAAA,CAUsCD;EAAuB,WAAA,EAAA,MAAA;EAgB3DG,QAAAA,EAxBEP,QAwBS;EACXQ,GAAAA,EAAAA,MAAAA;AAoCZ;AACA;AACA;AACA;AAAoF;;AAE/CV,cA1DhBQ,eAAAA,YAA2BF,uBA0DXN,CAAAA;EAClBF,GAAAA,EAAAA,MAAAA;EACFD,KAAAA,CAAAA,EAAAA,MAAAA;EACHa,WAAAA,CAAAA,EAAAA,MAAAA;EAAY,YAAA,CAAA,EAAA,MAAA;EAqBFO,WAAK,EAAA,MAAA;EAAOD,QAAAA,EA5EtBd,QA4EsBc;EAAoBZ,QAAAA,UAAAA;EAARc,WAAAA,CAAAA,MAAAA,EA1ExBX,kBA0EwBW;EAAO,qBAAA,CAAA,YAAA,EAzEfnB,cAyEe,CAAA,EAAA,IAAA;;gBAvErCC;gCACgBA,kCAAkCQ;;;;KAIxDC,WAAAA;KACAC,YAAAA;;;;;;;;;;;;;;;;;;YAkBED;;;;;;;gBAOIJ;;;;;;;;;;;iBAWMM,kCAAkCC,MAAMA;iBACxCC,mBAAAA,kBAAqCP,4BAA4BA;iBACjEQ,oBAAAA,cAAkCT,+BAA+BL;cACpEe,4CAA4Cd;UACvDe,SAAAA;cACMf,qBAAqBD;iBAClBF;eACFD;YACHa;;;;;;;;;;;;;;;;;;;;;iBAqBUO,KAAAA,OAAYD,YAAYE,QAAQd"}
@@ -0,0 +1 @@
1
+ {"version":3,"file":"base.d.ts","names":["VectorStore","RecordManagerInterface","HashKeyEncoder","DocumentInterface","BaseDocumentLoader","Metadata","Record","IndexingResult","StringOrDocFunc","HashedDocumentInterface","HashedDocumentArgs","_HashedDocument","CleanupMode","IndexOptions","_batch","T","_deduplicateInOrder","_getSourceIdAssigner","_isBaseDocumentLoader","IndexArgs","index","Promise"],"sources":["../../src/indexing/base.d.ts"],"sourcesContent":["import { VectorStore } from \"../vectorstores.js\";\nimport { RecordManagerInterface } from \"./record_manager.js\";\nimport { type HashKeyEncoder } from \"../utils/hash.js\";\nimport { DocumentInterface } from \"../documents/document.js\";\nimport { BaseDocumentLoader } from \"../document_loaders/base.js\";\ntype Metadata = Record<string, unknown>;\ntype IndexingResult = {\n numAdded: number;\n numDeleted: number;\n numUpdated: number;\n numSkipped: number;\n};\ntype StringOrDocFunc = string | ((doc: DocumentInterface) => string);\nexport interface HashedDocumentInterface extends DocumentInterface {\n uid: string;\n hash_?: string;\n contentHash?: string;\n metadataHash?: string;\n pageContent: string;\n metadata: Metadata;\n calculateHashes(): void;\n toDocument(): DocumentInterface;\n}\ninterface HashedDocumentArgs {\n pageContent: string;\n metadata: Metadata;\n uid: string;\n}\n/**\n * HashedDocument is a Document with hashes calculated.\n * Hashes are calculated based on page content and metadata.\n * It is used for indexing.\n */\nexport declare class _HashedDocument implements HashedDocumentInterface {\n uid: string;\n hash_?: string;\n contentHash?: string;\n metadataHash?: string;\n pageContent: string;\n metadata: Metadata;\n private keyEncoder;\n constructor(fields: HashedDocumentArgs);\n makeDefaultKeyEncoder(keyEncoderFn: HashKeyEncoder): void;\n calculateHashes(): void;\n toDocument(): DocumentInterface;\n static fromDocument(document: DocumentInterface, uid?: string): _HashedDocument;\n private _hashStringToUUID;\n private _hashNestedDictToUUID;\n}\nexport type CleanupMode = \"full\" | \"incremental\";\nexport type IndexOptions = {\n /**\n * The number of documents to index in one batch.\n */\n batchSize?: number;\n /**\n * The cleanup mode to use. Can be \"full\", \"incremental\" or undefined.\n * - **Incremental**: Cleans up all documents that haven't been updated AND\n * that are associated with source ids that were seen\n * during indexing.\n * Clean up is done continuously during indexing helping\n * to minimize the probability of users seeing duplicated\n * content.\n * - **Full**: Delete all documents that haven to been returned by the loader.\n * Clean up runs after all documents have been indexed.\n * This means that users may see duplicated content during indexing.\n * - **undefined**: Do not delete any documents.\n */\n cleanup?: CleanupMode;\n /**\n * Optional key that helps identify the original source of the document.\n * Must either be a string representing the key of the source in the metadata\n * or a function that takes a document and returns a string representing the source.\n * **Required when cleanup is incremental**.\n */\n sourceIdKey?: StringOrDocFunc;\n /**\n * Batch size to use when cleaning up documents.\n */\n cleanupBatchSize?: number;\n /**\n * Force update documents even if they are present in the\n * record manager. Useful if you are re-indexing with updated embeddings.\n */\n forceUpdate?: boolean;\n};\nexport declare function _batch<T>(size: number, iterable: T[]): T[][];\nexport declare function _deduplicateInOrder(hashedDocuments: HashedDocumentInterface[]): HashedDocumentInterface[];\nexport declare function _getSourceIdAssigner(sourceIdKey: StringOrDocFunc | null): (doc: DocumentInterface) => string | null;\nexport declare const _isBaseDocumentLoader: (arg: any) => arg is BaseDocumentLoader;\ninterface IndexArgs {\n docsSource: BaseDocumentLoader | DocumentInterface[];\n recordManager: RecordManagerInterface;\n vectorStore: VectorStore;\n options?: IndexOptions;\n}\n/**\n * Index data from the doc source into the vector store.\n *\n * Indexing functionality uses a manager to keep track of which documents\n * are in the vector store.\n *\n * This allows us to keep track of which documents were updated, and which\n * documents were deleted, which documents should be skipped.\n *\n * For the time being, documents are indexed using their hashes, and users\n * are not able to specify the uid of the document.\n *\n * @param {IndexArgs} args\n * @param {BaseDocumentLoader | DocumentInterface[]} args.docsSource The source of documents to index. Can be a DocumentLoader or a list of Documents.\n * @param {RecordManagerInterface} args.recordManager The record manager to use for keeping track of indexed documents.\n * @param {VectorStore} args.vectorStore The vector store to use for storing the documents.\n * @param {IndexOptions | undefined} args.options Options for indexing.\n * @returns {Promise<IndexingResult>}\n */\nexport declare function index(args: IndexArgs): Promise<IndexingResult>;\nexport {};\n//# sourceMappingURL=base.d.ts.map"],"mappings":";;;;;;;KAKKK,QAAAA,GAAWC;KACXC,cAAAA;EADAF,QAAAA,EAAAA,MAAQ;EACRE,UAAAA,EAAAA,MAAc;EAMdC,UAAAA,EAAAA,MAAe;EACHC,UAAAA,EAAAA,MAAAA;CAMHJ;KAPTG,eAAAA,GASaL,MAAAA,GAAAA,CAAAA,CAAAA,GAAAA,EATqBA,iBASrBA,EAAAA,GAAAA,MAAAA,CAAAA;AAR+BA,UAAhCM,uBAAAA,SAAgCN,iBAAAA,CAAAA;EAAiB,GAAA,EAAA,MAAA;EAUxDO,KAAAA,CAAAA,EAAAA,MAAAA;EAUWC,WAAAA,CAAAA,EAAAA,MAAe;EAMtBN,YAAAA,CAAAA,EAAAA,MAAAA;EAEUK,WAAAA,EAAAA,MAAAA;EACgBR,QAAAA,EAvB1BG,QAuB0BH;EAEtBC,eAAAA,EAAAA,EAAAA,IAAAA;EACgBA,UAAAA,EAAAA,EAxBhBA,iBAwBgBA;;UAtBxBO,kBAAAA,CAUsCD;EAAuB,WAAA,EAAA,MAAA;EAgB3DG,QAAAA,EAxBEP,QAwBS;EACXQ,GAAAA,EAAAA,MAAAA;AAoCZ;AACA;AACA;AACA;AAAoF;;AAE/CV,cA1DhBQ,eAAAA,YAA2BF,uBA0DXN,CAAAA;EAClBF,GAAAA,EAAAA,MAAAA;EACFD,KAAAA,CAAAA,EAAAA,MAAAA;EACHa,WAAAA,CAAAA,EAAAA,MAAAA;EAAY,YAAA,CAAA,EAAA,MAAA;EAqBFO,WAAK,EAAA,MAAA;EAAOD,QAAAA,EA5EtBd,QA4EsBc;EAAoBZ,QAAAA,UAAAA;EAARc,WAAAA,CAAAA,MAAAA,EA1ExBX,kBA0EwBW;EAAO,qBAAA,CAAA,YAAA,EAzEfnB,cAyEe,CAAA,EAAA,IAAA;;gBAvErCC;gCACgBA,kCAAkCQ;;;;KAIxDC,WAAAA;KACAC,YAAAA;;;;;;;;;;;;;;;;;;YAkBED;;;;;;;gBAOIJ;;;;;;;;;;;iBAWMM,kCAAkCC,MAAMA;iBACxCC,mBAAAA,kBAAqCP,4BAA4BA;iBACjEQ,oBAAAA,cAAkCT,+BAA+BL;cACpEe,4CAA4Cd;UACvDe,SAAAA;cACMf,qBAAqBD;iBAClBF;eACFD;YACHa;;;;;;;;;;;;;;;;;;;;;iBAqBUO,KAAAA,OAAYD,YAAYE,QAAQd"}
@@ -0,0 +1 @@
1
+ {"version":3,"file":"record_manager.d.cts","names":["Serializable","UUIDV5_NAMESPACE","UpdateOptions","ListKeyOptions","RecordManagerInterface","Promise","RecordManager"],"sources":["../../src/indexing/record_manager.d.ts"],"sourcesContent":["import { Serializable } from \"../load/serializable.js\";\nexport declare const UUIDV5_NAMESPACE = \"10f90ea3-90a4-4962-bf75-83a0f3c1c62a\";\nexport type UpdateOptions = {\n groupIds?: (string | null)[];\n timeAtLeast?: number;\n};\nexport type ListKeyOptions = {\n before?: number;\n after?: number;\n groupIds?: (string | null)[];\n limit?: number;\n};\nexport interface RecordManagerInterface {\n /**\n * Creates schema in the record manager.\n * @returns Promise\n */\n createSchema(): Promise<void>;\n /**\n * Returns current time from the record manager.\n * @returns Current time\n */\n getTime(): Promise<number>;\n /**\n * Updates keys in the record manager.\n * @param keys List of keys to update\n * @param groupIds List of groupIds to update\n * @param timeAtLeast Update only if current time is at least this value\n * @returns Promise\n * @throws Error if timeAtLeast is provided and current time is less than timeAtLeast\n * @throws Error if number of keys does not match number of groupIds\n */\n update(keys: string[], updateOptions: UpdateOptions): Promise<void>;\n /**\n * Checks if keys exist in the record manager.\n * @param keys List of keys to check\n * @returns List of booleans indicating if key exists in same order as provided keys\n */\n exists(keys: string[]): Promise<boolean[]>;\n /**\n * Lists keys from the record manager.\n * @param before List keys before this timestamp\n * @param after List keys after this timestamp\n * @param groupIds List keys with these groupIds\n * @param limit Limit the number of keys returned\n * @returns List of keys\n *\n */\n listKeys(options: ListKeyOptions): Promise<string[]>;\n /**\n * Deletes keys from the record manager.\n * @param keys List of keys to delete\n */\n deleteKeys(keys: string[]): Promise<void>;\n}\nexport declare abstract class RecordManager extends Serializable implements RecordManagerInterface {\n lc_namespace: string[];\n abstract createSchema(): Promise<void>;\n abstract getTime(): Promise<number>;\n abstract update(keys: string[], updateOptions?: UpdateOptions): Promise<void>;\n abstract exists(keys: string[]): Promise<boolean[]>;\n abstract listKeys(options?: ListKeyOptions): Promise<string[]>;\n abstract deleteKeys(keys: string[]): Promise<void>;\n}\n//# sourceMappingURL=record_manager.d.ts.map"],"mappings":";;;cACqBC,gBAAAA;KACTC,aAAAA;EADSD,QAAAA,CAAAA,EAAAA,CAAAA,MAAAA,GAAgB,IAAA,CAAA,EAAA;EACzBC,WAAAA,CAAAA,EAAAA,MAAa;AAIzB,CAAA;AAMiBE,KANLD,cAAAA,GAM2B;EAKnBE,MAAAA,CAAAA,EAAAA,MAAAA;EAKLA,KAAAA,CAAAA,EAAAA,MAAAA;EAU2BH,QAAAA,CAAAA,EAAAA,CAAAA,MAAAA,GAAAA,IAAAA,CAAAA,EAAAA;EAAgBG,KAAAA,CAAAA,EAAAA,MAAAA;CAM9BA;AAUNF,UApCLC,sBAAAA,CAoCKD;EAAiBE;;AAKA;AAEvC;EAE6BA,YAAAA,EAAAA,EAxCTA,OAwCSA,CAAAA,IAAAA,CAAAA;EACLA;;;;EAGQF,OAAAA,EAAAA,EAvCjBE,OAuCiBF,CAAAA,MAAAA,CAAAA;EAAiBE;;;;AANiD;;;;;wCAvBxDH,gBAAgBG;;;;;;0BAM9BA;;;;;;;;;;oBAUNF,iBAAiBE;;;;;8BAKPA;;uBAEFC,aAAAA,SAAsBN,YAAAA,YAAwBI;;2BAE/CC;sBACLA;kDAC4BH,gBAAgBG;mCAC/BA;8BACLF,iBAAiBE;uCACRA"}
@@ -0,0 +1 @@
1
+ {"version":3,"file":"record_manager.d.ts","names":["Serializable","UUIDV5_NAMESPACE","UpdateOptions","ListKeyOptions","RecordManagerInterface","Promise","RecordManager"],"sources":["../../src/indexing/record_manager.d.ts"],"sourcesContent":["import { Serializable } from \"../load/serializable.js\";\nexport declare const UUIDV5_NAMESPACE = \"10f90ea3-90a4-4962-bf75-83a0f3c1c62a\";\nexport type UpdateOptions = {\n groupIds?: (string | null)[];\n timeAtLeast?: number;\n};\nexport type ListKeyOptions = {\n before?: number;\n after?: number;\n groupIds?: (string | null)[];\n limit?: number;\n};\nexport interface RecordManagerInterface {\n /**\n * Creates schema in the record manager.\n * @returns Promise\n */\n createSchema(): Promise<void>;\n /**\n * Returns current time from the record manager.\n * @returns Current time\n */\n getTime(): Promise<number>;\n /**\n * Updates keys in the record manager.\n * @param keys List of keys to update\n * @param groupIds List of groupIds to update\n * @param timeAtLeast Update only if current time is at least this value\n * @returns Promise\n * @throws Error if timeAtLeast is provided and current time is less than timeAtLeast\n * @throws Error if number of keys does not match number of groupIds\n */\n update(keys: string[], updateOptions: UpdateOptions): Promise<void>;\n /**\n * Checks if keys exist in the record manager.\n * @param keys List of keys to check\n * @returns List of booleans indicating if key exists in same order as provided keys\n */\n exists(keys: string[]): Promise<boolean[]>;\n /**\n * Lists keys from the record manager.\n * @param before List keys before this timestamp\n * @param after List keys after this timestamp\n * @param groupIds List keys with these groupIds\n * @param limit Limit the number of keys returned\n * @returns List of keys\n *\n */\n listKeys(options: ListKeyOptions): Promise<string[]>;\n /**\n * Deletes keys from the record manager.\n * @param keys List of keys to delete\n */\n deleteKeys(keys: string[]): Promise<void>;\n}\nexport declare abstract class RecordManager extends Serializable implements RecordManagerInterface {\n lc_namespace: string[];\n abstract createSchema(): Promise<void>;\n abstract getTime(): Promise<number>;\n abstract update(keys: string[], updateOptions?: UpdateOptions): Promise<void>;\n abstract exists(keys: string[]): Promise<boolean[]>;\n abstract listKeys(options?: ListKeyOptions): Promise<string[]>;\n abstract deleteKeys(keys: string[]): Promise<void>;\n}\n//# sourceMappingURL=record_manager.d.ts.map"],"mappings":";;;cACqBC,gBAAAA;KACTC,aAAAA;EADSD,QAAAA,CAAAA,EAAAA,CAAAA,MAAAA,GAAgB,IAAA,CAAA,EAAA;EACzBC,WAAAA,CAAAA,EAAAA,MAAa;AAIzB,CAAA;AAMiBE,KANLD,cAAAA,GAM2B;EAKnBE,MAAAA,CAAAA,EAAAA,MAAAA;EAKLA,KAAAA,CAAAA,EAAAA,MAAAA;EAU2BH,QAAAA,CAAAA,EAAAA,CAAAA,MAAAA,GAAAA,IAAAA,CAAAA,EAAAA;EAAgBG,KAAAA,CAAAA,EAAAA,MAAAA;CAM9BA;AAUNF,UApCLC,sBAAAA,CAoCKD;EAAiBE;;AAKA;AAEvC;EAE6BA,YAAAA,EAAAA,EAxCTA,OAwCSA,CAAAA,IAAAA,CAAAA;EACLA;;;;EAGQF,OAAAA,EAAAA,EAvCjBE,OAuCiBF,CAAAA,MAAAA,CAAAA;EAAiBE;;;;AANiD;;;;;wCAvBxDH,gBAAgBG;;;;;;0BAM9BA;;;;;;;;;;oBAUNF,iBAAiBE;;;;;8BAKPA;;uBAEFC,aAAAA,SAAsBN,YAAAA,YAAwBI;;2BAE/CC;sBACLA;kDAC4BH,gBAAgBG;mCAC/BA;8BACLF,iBAAiBE;uCACRA"}