langchain 0.0.203 → 0.0.204-rc.1

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 (544) hide show
  1. package/dist/agents/toolkits/aws_sfn.cjs +3 -75
  2. package/dist/agents/toolkits/aws_sfn.d.ts +2 -45
  3. package/dist/agents/toolkits/aws_sfn.js +2 -73
  4. package/dist/agents/toolkits/base.cjs +15 -9
  5. package/dist/agents/toolkits/base.d.ts +1 -9
  6. package/dist/agents/toolkits/base.js +1 -7
  7. package/dist/agents/toolkits/connery/index.cjs +15 -37
  8. package/dist/agents/toolkits/connery/index.d.ts +1 -23
  9. package/dist/agents/toolkits/connery/index.js +1 -35
  10. package/dist/cache/cloudflare_kv.cjs +15 -69
  11. package/dist/cache/cloudflare_kv.d.ts +1 -42
  12. package/dist/cache/cloudflare_kv.js +1 -67
  13. package/dist/cache/ioredis.cjs +15 -77
  14. package/dist/cache/ioredis.d.ts +1 -40
  15. package/dist/cache/ioredis.js +1 -75
  16. package/dist/cache/momento.cjs +15 -135
  17. package/dist/cache/momento.d.ts +1 -91
  18. package/dist/cache/momento.js +1 -133
  19. package/dist/cache/upstash_redis.cjs +15 -72
  20. package/dist/cache/upstash_redis.d.ts +1 -45
  21. package/dist/cache/upstash_redis.js +1 -70
  22. package/dist/callbacks/handlers/llmonitor.cjs +14 -238
  23. package/dist/callbacks/handlers/llmonitor.d.ts +1 -35
  24. package/dist/callbacks/handlers/llmonitor.js +1 -233
  25. package/dist/chains/openai_moderation.cjs +2 -2
  26. package/dist/chains/openai_moderation.d.ts +1 -1
  27. package/dist/chains/openai_moderation.js +1 -1
  28. package/dist/chat_models/anthropic.d.ts +4 -4
  29. package/dist/chat_models/baiduwenxin.cjs +15 -411
  30. package/dist/chat_models/baiduwenxin.d.ts +1 -150
  31. package/dist/chat_models/baiduwenxin.js +1 -409
  32. package/dist/chat_models/bedrock/index.cjs +15 -33
  33. package/dist/chat_models/bedrock/index.d.ts +1 -23
  34. package/dist/chat_models/bedrock/index.js +1 -29
  35. package/dist/chat_models/bedrock/web.cjs +15 -360
  36. package/dist/chat_models/bedrock/web.d.ts +1 -82
  37. package/dist/chat_models/bedrock/web.js +1 -356
  38. package/dist/chat_models/cloudflare_workersai.cjs +15 -216
  39. package/dist/chat_models/cloudflare_workersai.d.ts +1 -68
  40. package/dist/chat_models/cloudflare_workersai.js +1 -214
  41. package/dist/chat_models/fireworks.cjs +15 -89
  42. package/dist/chat_models/fireworks.d.ts +1 -43
  43. package/dist/chat_models/fireworks.js +1 -87
  44. package/dist/chat_models/googlepalm.cjs +15 -235
  45. package/dist/chat_models/googlepalm.d.ts +1 -108
  46. package/dist/chat_models/googlepalm.js +1 -233
  47. package/dist/chat_models/googlevertexai/index.cjs +15 -40
  48. package/dist/chat_models/googlevertexai/index.d.ts +1 -28
  49. package/dist/chat_models/googlevertexai/index.js +1 -38
  50. package/dist/chat_models/googlevertexai/web.cjs +15 -39
  51. package/dist/chat_models/googlevertexai/web.d.ts +1 -28
  52. package/dist/chat_models/googlevertexai/web.js +1 -37
  53. package/dist/chat_models/iflytek_xinghuo/index.cjs +14 -40
  54. package/dist/chat_models/iflytek_xinghuo/index.d.ts +1 -13
  55. package/dist/chat_models/iflytek_xinghuo/index.js +1 -36
  56. package/dist/chat_models/iflytek_xinghuo/web.cjs +15 -36
  57. package/dist/chat_models/iflytek_xinghuo/web.d.ts +1 -13
  58. package/dist/chat_models/iflytek_xinghuo/web.js +1 -34
  59. package/dist/chat_models/llama_cpp.cjs +15 -275
  60. package/dist/chat_models/llama_cpp.d.ts +1 -71
  61. package/dist/chat_models/llama_cpp.js +1 -273
  62. package/dist/chat_models/minimax.cjs +15 -578
  63. package/dist/chat_models/minimax.d.ts +1 -369
  64. package/dist/chat_models/minimax.js +1 -576
  65. package/dist/chat_models/ollama.cjs +15 -394
  66. package/dist/chat_models/ollama.d.ts +1 -127
  67. package/dist/chat_models/ollama.js +1 -392
  68. package/dist/chat_models/openai.cjs +4 -698
  69. package/dist/chat_models/openai.d.ts +4 -137
  70. package/dist/chat_models/openai.js +2 -695
  71. package/dist/chat_models/portkey.cjs +15 -167
  72. package/dist/chat_models/portkey.d.ts +1 -17
  73. package/dist/chat_models/portkey.js +1 -165
  74. package/dist/chat_models/yandex.cjs +15 -132
  75. package/dist/chat_models/yandex.d.ts +1 -30
  76. package/dist/chat_models/yandex.js +1 -130
  77. package/dist/document_loaders/fs/openai_whisper_audio.cjs +2 -2
  78. package/dist/document_loaders/fs/openai_whisper_audio.d.ts +1 -1
  79. package/dist/document_loaders/fs/openai_whisper_audio.js +1 -1
  80. package/dist/document_transformers/html_to_text.cjs +15 -47
  81. package/dist/document_transformers/html_to_text.d.ts +1 -30
  82. package/dist/document_transformers/html_to_text.js +1 -45
  83. package/dist/document_transformers/mozilla_readability.cjs +15 -53
  84. package/dist/document_transformers/mozilla_readability.d.ts +1 -31
  85. package/dist/document_transformers/mozilla_readability.js +1 -51
  86. package/dist/embeddings/bedrock.cjs +15 -109
  87. package/dist/embeddings/bedrock.d.ts +1 -71
  88. package/dist/embeddings/bedrock.js +1 -107
  89. package/dist/embeddings/cloudflare_workersai.cjs +15 -67
  90. package/dist/embeddings/cloudflare_workersai.d.ts +1 -28
  91. package/dist/embeddings/cloudflare_workersai.js +1 -65
  92. package/dist/embeddings/cohere.cjs +15 -124
  93. package/dist/embeddings/cohere.d.ts +1 -66
  94. package/dist/embeddings/cohere.js +1 -122
  95. package/dist/embeddings/googlepalm.cjs +15 -88
  96. package/dist/embeddings/googlepalm.d.ts +1 -61
  97. package/dist/embeddings/googlepalm.js +1 -86
  98. package/dist/embeddings/googlevertexai.cjs +15 -81
  99. package/dist/embeddings/googlevertexai.d.ts +1 -54
  100. package/dist/embeddings/googlevertexai.js +1 -79
  101. package/dist/embeddings/gradient_ai.cjs +15 -101
  102. package/dist/embeddings/gradient_ai.d.ts +1 -48
  103. package/dist/embeddings/gradient_ai.js +1 -99
  104. package/dist/embeddings/hf.cjs +15 -75
  105. package/dist/embeddings/hf.d.ts +1 -41
  106. package/dist/embeddings/hf.js +1 -73
  107. package/dist/embeddings/hf_transformers.cjs +15 -87
  108. package/dist/embeddings/hf_transformers.d.ts +1 -47
  109. package/dist/embeddings/hf_transformers.js +1 -85
  110. package/dist/embeddings/llama_cpp.cjs +15 -81
  111. package/dist/embeddings/llama_cpp.d.ts +1 -42
  112. package/dist/embeddings/llama_cpp.js +1 -79
  113. package/dist/embeddings/minimax.cjs +15 -165
  114. package/dist/embeddings/minimax.d.ts +1 -119
  115. package/dist/embeddings/minimax.js +1 -163
  116. package/dist/embeddings/ollama.cjs +15 -118
  117. package/dist/embeddings/ollama.d.ts +1 -34
  118. package/dist/embeddings/ollama.js +1 -116
  119. package/dist/embeddings/openai.cjs +2 -240
  120. package/dist/embeddings/openai.d.ts +1 -82
  121. package/dist/embeddings/openai.js +1 -239
  122. package/dist/embeddings/tensorflow.cjs +3 -96
  123. package/dist/embeddings/tensorflow.d.ts +1 -59
  124. package/dist/embeddings/tensorflow.js +1 -83
  125. package/dist/embeddings/voyage.cjs +15 -118
  126. package/dist/embeddings/voyage.d.ts +1 -66
  127. package/dist/embeddings/voyage.js +1 -116
  128. package/dist/experimental/chat_models/ollama_functions.d.ts +1 -1
  129. package/dist/experimental/openai_assistant/index.cjs +3 -3
  130. package/dist/experimental/openai_assistant/index.d.ts +1 -1
  131. package/dist/experimental/openai_assistant/index.js +1 -1
  132. package/dist/experimental/openai_assistant/schema.d.ts +1 -1
  133. package/dist/experimental/openai_files/index.cjs +2 -2
  134. package/dist/experimental/openai_files/index.d.ts +1 -1
  135. package/dist/experimental/openai_files/index.js +1 -1
  136. package/dist/graphs/neo4j_graph.cjs +3 -254
  137. package/dist/graphs/neo4j_graph.d.ts +1 -63
  138. package/dist/graphs/neo4j_graph.js +1 -241
  139. package/dist/llms/ai21.cjs +15 -200
  140. package/dist/llms/ai21.d.ts +1 -100
  141. package/dist/llms/ai21.js +1 -198
  142. package/dist/llms/aleph_alpha.cjs +15 -374
  143. package/dist/llms/aleph_alpha.d.ts +1 -161
  144. package/dist/llms/aleph_alpha.js +1 -372
  145. package/dist/llms/bedrock/web.cjs +15 -310
  146. package/dist/llms/bedrock/web.d.ts +1 -66
  147. package/dist/llms/bedrock/web.js +1 -308
  148. package/dist/llms/cloudflare_workersai.cjs +15 -168
  149. package/dist/llms/cloudflare_workersai.d.ts +1 -55
  150. package/dist/llms/cloudflare_workersai.js +1 -166
  151. package/dist/llms/cohere.cjs +15 -110
  152. package/dist/llms/cohere.d.ts +1 -54
  153. package/dist/llms/cohere.js +1 -108
  154. package/dist/llms/fireworks.cjs +15 -90
  155. package/dist/llms/fireworks.d.ts +1 -33
  156. package/dist/llms/fireworks.js +1 -88
  157. package/dist/llms/googlepalm.cjs +15 -134
  158. package/dist/llms/googlepalm.d.ts +1 -92
  159. package/dist/llms/googlepalm.js +1 -132
  160. package/dist/llms/googlevertexai/index.cjs +15 -45
  161. package/dist/llms/googlevertexai/index.d.ts +1 -38
  162. package/dist/llms/googlevertexai/index.js +1 -43
  163. package/dist/llms/googlevertexai/web.cjs +15 -42
  164. package/dist/llms/googlevertexai/web.d.ts +1 -36
  165. package/dist/llms/googlevertexai/web.js +1 -40
  166. package/dist/llms/gradient_ai.cjs +15 -110
  167. package/dist/llms/gradient_ai.d.ts +1 -55
  168. package/dist/llms/gradient_ai.js +1 -108
  169. package/dist/llms/hf.cjs +15 -136
  170. package/dist/llms/hf.d.ts +1 -68
  171. package/dist/llms/hf.js +1 -134
  172. package/dist/llms/llama_cpp.cjs +15 -111
  173. package/dist/llms/llama_cpp.d.ts +1 -41
  174. package/dist/llms/llama_cpp.js +1 -109
  175. package/dist/llms/ollama.cjs +15 -353
  176. package/dist/llms/ollama.d.ts +1 -106
  177. package/dist/llms/ollama.js +1 -351
  178. package/dist/llms/openai-chat.cjs +3 -445
  179. package/dist/llms/openai-chat.d.ts +4 -123
  180. package/dist/llms/openai-chat.js +2 -443
  181. package/dist/llms/openai.cjs +6 -530
  182. package/dist/llms/openai.d.ts +4 -123
  183. package/dist/llms/openai.js +2 -525
  184. package/dist/llms/portkey.cjs +14 -168
  185. package/dist/llms/portkey.d.ts +1 -57
  186. package/dist/llms/portkey.js +1 -162
  187. package/dist/llms/raycast.cjs +15 -94
  188. package/dist/llms/raycast.d.ts +1 -50
  189. package/dist/llms/raycast.js +1 -92
  190. package/dist/llms/replicate.cjs +15 -132
  191. package/dist/llms/replicate.d.ts +1 -51
  192. package/dist/llms/replicate.js +1 -130
  193. package/dist/llms/sagemaker_endpoint.cjs +15 -203
  194. package/dist/llms/sagemaker_endpoint.d.ts +1 -121
  195. package/dist/llms/sagemaker_endpoint.js +1 -200
  196. package/dist/llms/watsonx_ai.cjs +15 -152
  197. package/dist/llms/watsonx_ai.d.ts +1 -72
  198. package/dist/llms/watsonx_ai.js +1 -150
  199. package/dist/llms/writer.cjs +15 -165
  200. package/dist/llms/writer.d.ts +1 -60
  201. package/dist/llms/writer.js +1 -163
  202. package/dist/llms/yandex.cjs +15 -98
  203. package/dist/llms/yandex.d.ts +1 -40
  204. package/dist/llms/yandex.js +1 -96
  205. package/dist/load/index.cjs +3 -1
  206. package/dist/load/index.d.ts +1 -1
  207. package/dist/load/index.js +3 -1
  208. package/dist/memory/chat_memory.cjs +15 -61
  209. package/dist/memory/chat_memory.d.ts +1 -36
  210. package/dist/memory/chat_memory.js +1 -59
  211. package/dist/memory/motorhead_memory.cjs +15 -161
  212. package/dist/memory/motorhead_memory.d.ts +1 -63
  213. package/dist/memory/motorhead_memory.js +1 -159
  214. package/dist/memory/zep.cjs +15 -222
  215. package/dist/memory/zep.d.ts +1 -86
  216. package/dist/memory/zep.js +1 -220
  217. package/dist/retrievers/amazon_kendra.cjs +15 -273
  218. package/dist/retrievers/amazon_kendra.d.ts +1 -142
  219. package/dist/retrievers/amazon_kendra.js +1 -271
  220. package/dist/retrievers/chaindesk.cjs +15 -88
  221. package/dist/retrievers/chaindesk.d.ts +1 -31
  222. package/dist/retrievers/chaindesk.js +1 -86
  223. package/dist/retrievers/databerry.cjs +15 -82
  224. package/dist/retrievers/databerry.d.ts +1 -34
  225. package/dist/retrievers/databerry.js +1 -80
  226. package/dist/retrievers/metal.cjs +15 -51
  227. package/dist/retrievers/metal.d.ts +1 -36
  228. package/dist/retrievers/metal.js +1 -49
  229. package/dist/retrievers/supabase.cjs +15 -167
  230. package/dist/retrievers/supabase.d.ts +1 -82
  231. package/dist/retrievers/supabase.js +1 -165
  232. package/dist/retrievers/tavily_search_api.cjs +15 -142
  233. package/dist/retrievers/tavily_search_api.d.ts +1 -38
  234. package/dist/retrievers/tavily_search_api.js +1 -140
  235. package/dist/retrievers/zep.cjs +15 -150
  236. package/dist/retrievers/zep.d.ts +1 -76
  237. package/dist/retrievers/zep.js +1 -148
  238. package/dist/schema/document.cjs +2 -16
  239. package/dist/schema/document.d.ts +1 -11
  240. package/dist/schema/document.js +1 -16
  241. package/dist/schema/index.cjs +2 -7
  242. package/dist/schema/index.d.ts +2 -10
  243. package/dist/schema/index.js +1 -6
  244. package/dist/storage/convex.cjs +15 -143
  245. package/dist/storage/convex.d.ts +1 -106
  246. package/dist/storage/convex.js +1 -141
  247. package/dist/storage/ioredis.cjs +15 -158
  248. package/dist/storage/ioredis.d.ts +1 -71
  249. package/dist/storage/ioredis.js +1 -156
  250. package/dist/storage/upstash_redis.cjs +15 -172
  251. package/dist/storage/upstash_redis.d.ts +1 -78
  252. package/dist/storage/upstash_redis.js +1 -170
  253. package/dist/storage/vercel_kv.cjs +15 -161
  254. package/dist/storage/vercel_kv.d.ts +1 -62
  255. package/dist/storage/vercel_kv.js +1 -159
  256. package/dist/stores/doc/in_memory.cjs +15 -105
  257. package/dist/stores/doc/in_memory.d.ts +1 -46
  258. package/dist/stores/doc/in_memory.js +1 -102
  259. package/dist/stores/message/cassandra.cjs +15 -158
  260. package/dist/stores/message/cassandra.d.ts +1 -69
  261. package/dist/stores/message/cassandra.js +1 -156
  262. package/dist/stores/message/cloudflare_d1.cjs +15 -150
  263. package/dist/stores/message/cloudflare_d1.d.ts +1 -67
  264. package/dist/stores/message/cloudflare_d1.js +1 -148
  265. package/dist/stores/message/convex.cjs +15 -118
  266. package/dist/stores/message/convex.d.ts +1 -81
  267. package/dist/stores/message/convex.js +1 -116
  268. package/dist/stores/message/dynamodb.cjs +15 -159
  269. package/dist/stores/message/dynamodb.d.ts +1 -51
  270. package/dist/stores/message/dynamodb.js +1 -157
  271. package/dist/stores/message/firestore.cjs +15 -185
  272. package/dist/stores/message/firestore.d.ts +1 -68
  273. package/dist/stores/message/firestore.js +1 -183
  274. package/dist/stores/message/in_memory.cjs +15 -49
  275. package/dist/stores/message/in_memory.d.ts +1 -28
  276. package/dist/stores/message/in_memory.js +1 -47
  277. package/dist/stores/message/ioredis.cjs +15 -98
  278. package/dist/stores/message/ioredis.d.ts +1 -64
  279. package/dist/stores/message/ioredis.js +1 -96
  280. package/dist/stores/message/momento.cjs +15 -160
  281. package/dist/stores/message/momento.d.ts +1 -97
  282. package/dist/stores/message/momento.js +1 -158
  283. package/dist/stores/message/mongodb.cjs +15 -57
  284. package/dist/stores/message/mongodb.d.ts +1 -26
  285. package/dist/stores/message/mongodb.js +1 -55
  286. package/dist/stores/message/planetscale.cjs +15 -170
  287. package/dist/stores/message/planetscale.d.ts +1 -75
  288. package/dist/stores/message/planetscale.js +1 -168
  289. package/dist/stores/message/redis.cjs +15 -114
  290. package/dist/stores/message/redis.d.ts +1 -69
  291. package/dist/stores/message/redis.js +1 -112
  292. package/dist/stores/message/upstash_redis.cjs +15 -85
  293. package/dist/stores/message/upstash_redis.d.ts +1 -43
  294. package/dist/stores/message/upstash_redis.js +1 -83
  295. package/dist/stores/message/utils.cjs +3 -23
  296. package/dist/stores/message/utils.d.ts +1 -17
  297. package/dist/stores/message/utils.js +1 -21
  298. package/dist/stores/message/xata.cjs +15 -216
  299. package/dist/stores/message/xata.d.ts +1 -76
  300. package/dist/stores/message/xata.js +1 -214
  301. package/dist/tools/IFTTTWebhook.cjs +15 -87
  302. package/dist/tools/IFTTTWebhook.d.ts +1 -50
  303. package/dist/tools/IFTTTWebhook.js +1 -85
  304. package/dist/tools/aiplugin.cjs +15 -73
  305. package/dist/tools/aiplugin.d.ts +1 -34
  306. package/dist/tools/aiplugin.js +1 -71
  307. package/dist/tools/aws_lambda.cjs +15 -83
  308. package/dist/tools/aws_lambda.d.ts +1 -25
  309. package/dist/tools/aws_lambda.js +1 -82
  310. package/dist/tools/aws_sfn.cjs +15 -201
  311. package/dist/tools/aws_sfn.d.ts +1 -57
  312. package/dist/tools/aws_sfn.js +1 -197
  313. package/dist/tools/bingserpapi.cjs +15 -76
  314. package/dist/tools/bingserpapi.d.ts +1 -23
  315. package/dist/tools/bingserpapi.js +1 -75
  316. package/dist/tools/brave_search.cjs +15 -64
  317. package/dist/tools/brave_search.d.ts +1 -23
  318. package/dist/tools/brave_search.js +1 -62
  319. package/dist/tools/connery.cjs +15 -277
  320. package/dist/tools/connery.d.ts +1 -145
  321. package/dist/tools/connery.js +1 -274
  322. package/dist/tools/convert_to_openai.d.ts +1 -1
  323. package/dist/tools/dadjokeapi.cjs +15 -46
  324. package/dist/tools/dadjokeapi.d.ts +1 -15
  325. package/dist/tools/dadjokeapi.js +1 -45
  326. package/dist/tools/dataforseo_api_search.cjs +15 -280
  327. package/dist/tools/dataforseo_api_search.d.ts +1 -170
  328. package/dist/tools/dataforseo_api_search.js +1 -278
  329. package/dist/tools/dynamic.cjs +15 -87
  330. package/dist/tools/dynamic.d.ts +1 -48
  331. package/dist/tools/dynamic.js +1 -84
  332. package/dist/tools/gmail/index.cjs +15 -11
  333. package/dist/tools/gmail/index.d.ts +1 -11
  334. package/dist/tools/gmail/index.js +1 -5
  335. package/dist/tools/google_custom_search.cjs +15 -70
  336. package/dist/tools/google_custom_search.d.ts +1 -25
  337. package/dist/tools/google_custom_search.js +1 -68
  338. package/dist/tools/google_places.cjs +15 -79
  339. package/dist/tools/google_places.d.ts +1 -21
  340. package/dist/tools/google_places.js +1 -77
  341. package/dist/tools/searchapi.cjs +15 -164
  342. package/dist/tools/searchapi.d.ts +1 -91
  343. package/dist/tools/searchapi.js +1 -162
  344. package/dist/tools/searxng_search.cjs +15 -156
  345. package/dist/tools/searxng_search.d.ts +1 -114
  346. package/dist/tools/searxng_search.js +1 -154
  347. package/dist/tools/serpapi.cjs +15 -199
  348. package/dist/tools/serpapi.d.ts +1 -302
  349. package/dist/tools/serpapi.js +1 -197
  350. package/dist/tools/serper.cjs +15 -94
  351. package/dist/tools/serper.d.ts +1 -32
  352. package/dist/tools/serper.js +1 -92
  353. package/dist/tools/wikipedia_query_run.cjs +15 -133
  354. package/dist/tools/wikipedia_query_run.d.ts +1 -54
  355. package/dist/tools/wikipedia_query_run.js +1 -131
  356. package/dist/tools/wolframalpha.cjs +15 -47
  357. package/dist/tools/wolframalpha.d.ts +1 -21
  358. package/dist/tools/wolframalpha.js +1 -45
  359. package/dist/types/openai-types.d.ts +1 -1
  360. package/dist/util/convex.cjs +15 -75
  361. package/dist/util/convex.d.ts +1 -26
  362. package/dist/util/convex.js +1 -74
  363. package/dist/util/event-source-parse.cjs +15 -224
  364. package/dist/util/event-source-parse.d.ts +1 -39
  365. package/dist/util/event-source-parse.js +1 -219
  366. package/dist/util/math.cjs +15 -123
  367. package/dist/util/math.d.ts +1 -40
  368. package/dist/util/math.js +1 -116
  369. package/dist/util/openapi.d.ts +2 -2
  370. package/dist/vectorstores/analyticdb.cjs +3 -333
  371. package/dist/vectorstores/analyticdb.d.ts +1 -110
  372. package/dist/vectorstores/analyticdb.js +1 -317
  373. package/dist/vectorstores/base.cjs +15 -165
  374. package/dist/vectorstores/base.d.ts +1 -104
  375. package/dist/vectorstores/base.js +1 -161
  376. package/dist/vectorstores/cassandra.cjs +15 -478
  377. package/dist/vectorstores/cassandra.d.ts +1 -162
  378. package/dist/vectorstores/cassandra.js +1 -476
  379. package/dist/vectorstores/chroma.cjs +3 -312
  380. package/dist/vectorstores/chroma.d.ts +1 -133
  381. package/dist/vectorstores/chroma.js +1 -299
  382. package/dist/vectorstores/clickhouse.cjs +3 -272
  383. package/dist/vectorstores/clickhouse.d.ts +1 -126
  384. package/dist/vectorstores/clickhouse.js +1 -259
  385. package/dist/vectorstores/closevector/node.cjs +15 -107
  386. package/dist/vectorstores/closevector/node.d.ts +1 -83
  387. package/dist/vectorstores/closevector/node.js +1 -105
  388. package/dist/vectorstores/closevector/web.cjs +15 -107
  389. package/dist/vectorstores/closevector/web.d.ts +1 -80
  390. package/dist/vectorstores/closevector/web.js +1 -105
  391. package/dist/vectorstores/cloudflare_vectorize.cjs +3 -186
  392. package/dist/vectorstores/cloudflare_vectorize.d.ts +1 -90
  393. package/dist/vectorstores/cloudflare_vectorize.js +1 -173
  394. package/dist/vectorstores/convex.cjs +15 -175
  395. package/dist/vectorstores/convex.d.ts +1 -134
  396. package/dist/vectorstores/convex.js +1 -173
  397. package/dist/vectorstores/elasticsearch.cjs +3 -287
  398. package/dist/vectorstores/elasticsearch.d.ts +1 -143
  399. package/dist/vectorstores/elasticsearch.js +1 -274
  400. package/dist/vectorstores/faiss.cjs +3 -378
  401. package/dist/vectorstores/faiss.d.ts +1 -127
  402. package/dist/vectorstores/faiss.js +1 -365
  403. package/dist/vectorstores/googlevertexai.cjs +3 -538
  404. package/dist/vectorstores/googlevertexai.d.ts +1 -181
  405. package/dist/vectorstores/googlevertexai.js +1 -521
  406. package/dist/vectorstores/hnswlib.cjs +15 -273
  407. package/dist/vectorstores/hnswlib.d.ts +1 -122
  408. package/dist/vectorstores/hnswlib.js +1 -271
  409. package/dist/vectorstores/lancedb.cjs +15 -126
  410. package/dist/vectorstores/lancedb.d.ts +1 -61
  411. package/dist/vectorstores/lancedb.js +1 -124
  412. package/dist/vectorstores/memory.cjs +6 -6
  413. package/dist/vectorstores/memory.d.ts +3 -3
  414. package/dist/vectorstores/memory.js +2 -2
  415. package/dist/vectorstores/milvus.cjs +3 -592
  416. package/dist/vectorstores/milvus.d.ts +1 -139
  417. package/dist/vectorstores/milvus.js +1 -579
  418. package/dist/vectorstores/momento_vector_index.cjs +3 -305
  419. package/dist/vectorstores/momento_vector_index.d.ts +1 -143
  420. package/dist/vectorstores/momento_vector_index.js +1 -292
  421. package/dist/vectorstores/mongodb_atlas.cjs +15 -218
  422. package/dist/vectorstores/mongodb_atlas.d.ts +1 -118
  423. package/dist/vectorstores/mongodb_atlas.js +1 -216
  424. package/dist/vectorstores/myscale.cjs +3 -263
  425. package/dist/vectorstores/myscale.d.ts +1 -129
  426. package/dist/vectorstores/myscale.js +1 -250
  427. package/dist/vectorstores/neo4j_vector.cjs +3 -578
  428. package/dist/vectorstores/neo4j_vector.d.ts +1 -75
  429. package/dist/vectorstores/neo4j_vector.js +1 -562
  430. package/dist/vectorstores/opensearch.cjs +3 -274
  431. package/dist/vectorstores/opensearch.d.ts +1 -119
  432. package/dist/vectorstores/opensearch.js +1 -261
  433. package/dist/vectorstores/pgvector.cjs +14 -404
  434. package/dist/vectorstores/pgvector.d.ts +1 -160
  435. package/dist/vectorstores/pgvector.js +1 -400
  436. package/dist/vectorstores/pinecone.cjs +3 -280
  437. package/dist/vectorstores/pinecone.d.ts +1 -120
  438. package/dist/vectorstores/pinecone.js +1 -264
  439. package/dist/vectorstores/prisma.cjs +15 -305
  440. package/dist/vectorstores/prisma.d.ts +1 -180
  441. package/dist/vectorstores/prisma.js +1 -303
  442. package/dist/vectorstores/qdrant.cjs +15 -195
  443. package/dist/vectorstores/qdrant.d.ts +1 -95
  444. package/dist/vectorstores/qdrant.js +1 -193
  445. package/dist/vectorstores/redis.cjs +15 -333
  446. package/dist/vectorstores/redis.d.ts +1 -186
  447. package/dist/vectorstores/redis.js +1 -331
  448. package/dist/vectorstores/rockset.cjs +15 -351
  449. package/dist/vectorstores/rockset.d.ts +1 -202
  450. package/dist/vectorstores/rockset.js +1 -347
  451. package/dist/vectorstores/singlestore.cjs +15 -220
  452. package/dist/vectorstores/singlestore.d.ts +1 -88
  453. package/dist/vectorstores/singlestore.js +1 -218
  454. package/dist/vectorstores/supabase.cjs +15 -217
  455. package/dist/vectorstores/supabase.d.ts +1 -118
  456. package/dist/vectorstores/supabase.js +1 -215
  457. package/dist/vectorstores/tigris.cjs +3 -143
  458. package/dist/vectorstores/tigris.d.ts +1 -74
  459. package/dist/vectorstores/tigris.js +1 -130
  460. package/dist/vectorstores/typeorm.cjs +15 -259
  461. package/dist/vectorstores/typeorm.d.ts +1 -109
  462. package/dist/vectorstores/typeorm.js +1 -256
  463. package/dist/vectorstores/typesense.cjs +15 -223
  464. package/dist/vectorstores/typesense.d.ts +1 -131
  465. package/dist/vectorstores/typesense.js +1 -221
  466. package/dist/vectorstores/usearch.cjs +3 -203
  467. package/dist/vectorstores/usearch.d.ts +1 -85
  468. package/dist/vectorstores/usearch.js +1 -187
  469. package/dist/vectorstores/vectara.cjs +3 -409
  470. package/dist/vectorstores/vectara.d.ts +1 -148
  471. package/dist/vectorstores/vectara.js +1 -396
  472. package/dist/vectorstores/vercel_postgres.cjs +15 -320
  473. package/dist/vectorstores/vercel_postgres.d.ts +1 -145
  474. package/dist/vectorstores/vercel_postgres.js +1 -318
  475. package/dist/vectorstores/voy.cjs +15 -156
  476. package/dist/vectorstores/voy.d.ts +1 -73
  477. package/dist/vectorstores/voy.js +1 -154
  478. package/dist/vectorstores/weaviate.cjs +3 -347
  479. package/dist/vectorstores/weaviate.d.ts +1 -140
  480. package/dist/vectorstores/weaviate.js +1 -333
  481. package/dist/vectorstores/xata.cjs +15 -108
  482. package/dist/vectorstores/xata.d.ts +1 -70
  483. package/dist/vectorstores/xata.js +1 -106
  484. package/dist/vectorstores/zep.cjs +15 -313
  485. package/dist/vectorstores/zep.d.ts +1 -146
  486. package/dist/vectorstores/zep.js +1 -311
  487. package/package.json +4 -265
  488. package/dist/chat_models/googlevertexai/common.cjs +0 -274
  489. package/dist/chat_models/googlevertexai/common.d.ts +0 -123
  490. package/dist/chat_models/googlevertexai/common.js +0 -269
  491. package/dist/chat_models/iflytek_xinghuo/common.cjs +0 -340
  492. package/dist/chat_models/iflytek_xinghuo/common.d.ts +0 -165
  493. package/dist/chat_models/iflytek_xinghuo/common.js +0 -336
  494. package/dist/llms/googlevertexai/common.cjs +0 -168
  495. package/dist/llms/googlevertexai/common.d.ts +0 -82
  496. package/dist/llms/googlevertexai/common.js +0 -164
  497. package/dist/tools/gmail/base.cjs +0 -69
  498. package/dist/tools/gmail/base.d.ts +0 -19
  499. package/dist/tools/gmail/base.js +0 -65
  500. package/dist/tools/gmail/create_draft.cjs +0 -62
  501. package/dist/tools/gmail/create_draft.d.ts +0 -35
  502. package/dist/tools/gmail/create_draft.js +0 -58
  503. package/dist/tools/gmail/descriptions.cjs +0 -118
  504. package/dist/tools/gmail/descriptions.d.ts +0 -5
  505. package/dist/tools/gmail/descriptions.js +0 -115
  506. package/dist/tools/gmail/get_message.cjs +0 -83
  507. package/dist/tools/gmail/get_message.d.ts +0 -18
  508. package/dist/tools/gmail/get_message.js +0 -79
  509. package/dist/tools/gmail/get_thread.cjs +0 -89
  510. package/dist/tools/gmail/get_thread.d.ts +0 -18
  511. package/dist/tools/gmail/get_thread.js +0 -85
  512. package/dist/tools/gmail/search.cjs +0 -118
  513. package/dist/tools/gmail/search.d.ts +0 -29
  514. package/dist/tools/gmail/search.js +0 -114
  515. package/dist/tools/gmail/send_message.cjs +0 -74
  516. package/dist/tools/gmail/send_message.d.ts +0 -35
  517. package/dist/tools/gmail/send_message.js +0 -70
  518. package/dist/util/chunk.cjs +0 -11
  519. package/dist/util/chunk.d.ts +0 -1
  520. package/dist/util/chunk.js +0 -7
  521. package/dist/util/googlevertexai-gauth.cjs +0 -36
  522. package/dist/util/googlevertexai-gauth.d.ts +0 -8
  523. package/dist/util/googlevertexai-gauth.js +0 -32
  524. package/dist/util/googlevertexai-webauth.cjs +0 -96
  525. package/dist/util/googlevertexai-webauth.d.ts +0 -22
  526. package/dist/util/googlevertexai-webauth.js +0 -92
  527. package/dist/util/iflytek_websocket_stream.cjs +0 -81
  528. package/dist/util/iflytek_websocket_stream.d.ts +0 -27
  529. package/dist/util/iflytek_websocket_stream.js +0 -77
  530. package/dist/util/llama_cpp.cjs +0 -34
  531. package/dist/util/llama_cpp.d.ts +0 -46
  532. package/dist/util/llama_cpp.js +0 -28
  533. package/dist/util/momento.cjs +0 -26
  534. package/dist/util/momento.d.ts +0 -9
  535. package/dist/util/momento.js +0 -22
  536. package/dist/util/openai-format-fndef.cjs +0 -81
  537. package/dist/util/openai-format-fndef.d.ts +0 -44
  538. package/dist/util/openai-format-fndef.js +0 -77
  539. package/dist/util/openai.cjs +0 -21
  540. package/dist/util/openai.d.ts +0 -1
  541. package/dist/util/openai.js +0 -17
  542. package/dist/vectorstores/closevector/common.cjs +0 -128
  543. package/dist/vectorstores/closevector/common.d.ts +0 -82
  544. package/dist/vectorstores/closevector/common.js +0 -124
@@ -1,162 +1 @@
1
- import { DseClientOptions } from "cassandra-driver";
2
- import { AsyncCaller, AsyncCallerParams } from "../util/async_caller.js";
3
- import { Embeddings } from "../embeddings/base.js";
4
- import { VectorStore } from "./base.js";
5
- import { Document } from "../document.js";
6
- export interface Column {
7
- type: string;
8
- name: string;
9
- partition?: boolean;
10
- }
11
- export interface Index {
12
- name: string;
13
- value: string;
14
- }
15
- export interface Filter {
16
- name: string;
17
- value: unknown;
18
- operator?: string;
19
- }
20
- export type WhereClause = Filter[] | Filter | Record<string, unknown>;
21
- export type SupportedVectorTypes = "cosine" | "dot_product" | "euclidean";
22
- export interface CassandraLibArgs extends DseClientOptions, AsyncCallerParams {
23
- table: string;
24
- keyspace: string;
25
- vectorType?: SupportedVectorTypes;
26
- dimensions: number;
27
- primaryKey: Column | Column[];
28
- metadataColumns: Column[];
29
- withClause?: string;
30
- indices?: Index[];
31
- batchSize?: number;
32
- }
33
- /**
34
- * Class for interacting with the Cassandra database. It extends the
35
- * VectorStore class and provides methods for adding vectors and
36
- * documents, searching for similar vectors, and creating instances from
37
- * texts or documents.
38
- */
39
- export declare class CassandraStore extends VectorStore {
40
- FilterType: WhereClause;
41
- private client;
42
- private readonly vectorType;
43
- private readonly dimensions;
44
- private readonly keyspace;
45
- private primaryKey;
46
- private metadataColumns;
47
- private withClause;
48
- private selectColumns;
49
- private readonly table;
50
- private indices;
51
- private isInitialized;
52
- asyncCaller: AsyncCaller;
53
- private readonly batchSize;
54
- _vectorstoreType(): string;
55
- constructor(embeddings: Embeddings, args: CassandraLibArgs);
56
- /**
57
- * Method to save vectors to the Cassandra database.
58
- * @param vectors Vectors to save.
59
- * @param documents The documents associated with the vectors.
60
- * @returns Promise that resolves when the vectors have been added.
61
- */
62
- addVectors(vectors: number[][], documents: Document[]): Promise<void>;
63
- /**
64
- * Method to add documents to the Cassandra database.
65
- * @param documents The documents to add.
66
- * @returns Promise that resolves when the documents have been added.
67
- */
68
- addDocuments(documents: Document[]): Promise<void>;
69
- /**
70
- * Method to search for vectors that are similar to a given query vector.
71
- * @param query The query vector.
72
- * @param k The number of similar vectors to return.
73
- * @param filter
74
- * @returns Promise that resolves with an array of tuples, each containing a Document and a score.
75
- */
76
- similaritySearchVectorWithScore(query: number[], k: number, filter?: WhereClause): Promise<[Document, number][]>;
77
- /**
78
- * Static method to create an instance of CassandraStore from texts.
79
- * @param texts The texts to use.
80
- * @param metadatas The metadata associated with the texts.
81
- * @param embeddings The embeddings to use.
82
- * @param args The arguments for the CassandraStore.
83
- * @returns Promise that resolves with a new instance of CassandraStore.
84
- */
85
- static fromTexts(texts: string[], metadatas: object | object[], embeddings: Embeddings, args: CassandraLibArgs): Promise<CassandraStore>;
86
- /**
87
- * Static method to create an instance of CassandraStore from documents.
88
- * @param docs The documents to use.
89
- * @param embeddings The embeddings to use.
90
- * @param args The arguments for the CassandraStore.
91
- * @returns Promise that resolves with a new instance of CassandraStore.
92
- */
93
- static fromDocuments(docs: Document[], embeddings: Embeddings, args: CassandraLibArgs): Promise<CassandraStore>;
94
- /**
95
- * Static method to create an instance of CassandraStore from an existing
96
- * index.
97
- * @param embeddings The embeddings to use.
98
- * @param args The arguments for the CassandraStore.
99
- * @returns Promise that resolves with a new instance of CassandraStore.
100
- */
101
- static fromExistingIndex(embeddings: Embeddings, args: CassandraLibArgs): Promise<CassandraStore>;
102
- /**
103
- * Method to initialize the Cassandra database.
104
- * @returns Promise that resolves when the database has been initialized.
105
- */
106
- private initialize;
107
- /**
108
- * Method to build the PRIMARY KEY clause for CREATE TABLE.
109
- * @param columns: list of Column to include in the key
110
- * @returns The clause, including PRIMARY KEY
111
- */
112
- private buildPrimaryKey;
113
- /**
114
- * Type guard to check if an object is a Filter.
115
- * @param obj: the object to check
116
- * @returns boolean indicating if the object is a Filter
117
- */
118
- private isFilter;
119
- /**
120
- * Helper to convert Record<string,unknown> to a Filter[]
121
- * @param record: a key-value Record collection
122
- * @returns Record as a Filter[]
123
- */
124
- private convertToFilters;
125
- /**
126
- * Input santisation method for filters, as FilterType is not required to be
127
- * Filter[], but we want to use Filter[] internally.
128
- * @param record: the proposed filter
129
- * @returns A Filter[], which may be empty
130
- */
131
- private asFilters;
132
- /**
133
- * Method to build the WHERE clause of a CQL query, using bind variable ?
134
- * @param filters list of filters to include in the WHERE clause
135
- * @returns The WHERE clause
136
- */
137
- private buildWhereClause;
138
- /**
139
- * Method to build an CQL query for searching for similar vectors in the
140
- * Cassandra database.
141
- * @param query The query vector.
142
- * @param k The number of similar vectors to return.
143
- * @param filters
144
- * @returns The CQL query string.
145
- */
146
- private buildSearchQuery;
147
- /**
148
- * Method for inserting vectors and documents into the Cassandra database in a batch.
149
- * @param batchVectors The list of vectors to insert.
150
- * @param batchDocuments The list of documents to insert.
151
- * @returns Promise that resolves when the batch has been inserted.
152
- */
153
- private executeInsert;
154
- /**
155
- * Method for inserting vectors and documents into the Cassandra database in
156
- * parallel, keeping within maxConcurrency number of active insert statements.
157
- * @param vectors The vectors to insert.
158
- * @param documents The documents to insert.
159
- * @returns Promise that resolves when the documents have been added.
160
- */
161
- private insertAll;
162
- }
1
+ export * from "@langchain/community/vectorstores/cassandra";
@@ -1,476 +1 @@
1
- /* eslint-disable prefer-template */
2
- import { Client as CassandraClient } from "cassandra-driver";
3
- import { AsyncCaller } from "../util/async_caller.js";
4
- import { VectorStore } from "./base.js";
5
- import { Document } from "../document.js";
6
- /**
7
- * Class for interacting with the Cassandra database. It extends the
8
- * VectorStore class and provides methods for adding vectors and
9
- * documents, searching for similar vectors, and creating instances from
10
- * texts or documents.
11
- */
12
- export class CassandraStore extends VectorStore {
13
- _vectorstoreType() {
14
- return "cassandra";
15
- }
16
- constructor(embeddings, args) {
17
- super(embeddings, args);
18
- Object.defineProperty(this, "client", {
19
- enumerable: true,
20
- configurable: true,
21
- writable: true,
22
- value: void 0
23
- });
24
- Object.defineProperty(this, "vectorType", {
25
- enumerable: true,
26
- configurable: true,
27
- writable: true,
28
- value: void 0
29
- });
30
- Object.defineProperty(this, "dimensions", {
31
- enumerable: true,
32
- configurable: true,
33
- writable: true,
34
- value: void 0
35
- });
36
- Object.defineProperty(this, "keyspace", {
37
- enumerable: true,
38
- configurable: true,
39
- writable: true,
40
- value: void 0
41
- });
42
- Object.defineProperty(this, "primaryKey", {
43
- enumerable: true,
44
- configurable: true,
45
- writable: true,
46
- value: void 0
47
- });
48
- Object.defineProperty(this, "metadataColumns", {
49
- enumerable: true,
50
- configurable: true,
51
- writable: true,
52
- value: void 0
53
- });
54
- Object.defineProperty(this, "withClause", {
55
- enumerable: true,
56
- configurable: true,
57
- writable: true,
58
- value: void 0
59
- });
60
- Object.defineProperty(this, "selectColumns", {
61
- enumerable: true,
62
- configurable: true,
63
- writable: true,
64
- value: void 0
65
- });
66
- Object.defineProperty(this, "table", {
67
- enumerable: true,
68
- configurable: true,
69
- writable: true,
70
- value: void 0
71
- });
72
- Object.defineProperty(this, "indices", {
73
- enumerable: true,
74
- configurable: true,
75
- writable: true,
76
- value: void 0
77
- });
78
- Object.defineProperty(this, "isInitialized", {
79
- enumerable: true,
80
- configurable: true,
81
- writable: true,
82
- value: false
83
- });
84
- Object.defineProperty(this, "asyncCaller", {
85
- enumerable: true,
86
- configurable: true,
87
- writable: true,
88
- value: void 0
89
- });
90
- Object.defineProperty(this, "batchSize", {
91
- enumerable: true,
92
- configurable: true,
93
- writable: true,
94
- value: void 0
95
- });
96
- const { indices = [], maxConcurrency = 25, withClause = "", batchSize = 1, vectorType = "cosine", dimensions, keyspace, table, primaryKey, metadataColumns, } = args;
97
- const argsWithDefaults = {
98
- ...args,
99
- indices,
100
- maxConcurrency,
101
- withClause,
102
- batchSize,
103
- vectorType,
104
- };
105
- this.asyncCaller = new AsyncCaller(argsWithDefaults);
106
- this.client = new CassandraClient(argsWithDefaults);
107
- // Assign properties
108
- this.vectorType = vectorType;
109
- this.dimensions = dimensions;
110
- this.keyspace = keyspace;
111
- this.table = table;
112
- this.primaryKey = Array.isArray(primaryKey) ? primaryKey : [primaryKey];
113
- this.metadataColumns = metadataColumns;
114
- this.withClause = withClause.trim().replace(/^with\s*/i, "");
115
- this.indices = indices;
116
- this.batchSize = batchSize >= 1 ? batchSize : 1;
117
- }
118
- /**
119
- * Method to save vectors to the Cassandra database.
120
- * @param vectors Vectors to save.
121
- * @param documents The documents associated with the vectors.
122
- * @returns Promise that resolves when the vectors have been added.
123
- */
124
- async addVectors(vectors, documents) {
125
- if (vectors.length === 0) {
126
- return;
127
- }
128
- if (!this.isInitialized) {
129
- await this.initialize();
130
- }
131
- await this.insertAll(vectors, documents);
132
- }
133
- /**
134
- * Method to add documents to the Cassandra database.
135
- * @param documents The documents to add.
136
- * @returns Promise that resolves when the documents have been added.
137
- */
138
- async addDocuments(documents) {
139
- return this.addVectors(await this.embeddings.embedDocuments(documents.map((d) => d.pageContent)), documents);
140
- }
141
- /**
142
- * Method to search for vectors that are similar to a given query vector.
143
- * @param query The query vector.
144
- * @param k The number of similar vectors to return.
145
- * @param filter
146
- * @returns Promise that resolves with an array of tuples, each containing a Document and a score.
147
- */
148
- async similaritySearchVectorWithScore(query, k, filter) {
149
- if (!this.isInitialized) {
150
- await this.initialize();
151
- }
152
- // Ensure we have an array of Filter from the public interface
153
- const filters = this.asFilters(filter);
154
- const queryStr = this.buildSearchQuery(filters);
155
- // Search query will be of format:
156
- // SELECT ..., text, similarity_x(?) AS similarity_score
157
- // FROM ...
158
- // <WHERE ...>
159
- // ORDER BY vector ANN OF ?
160
- // LIMIT ?
161
- // If any filter values are specified, they will be in the WHERE clause as
162
- // filter.name filter.operator ?
163
- // queryParams is a list of bind variables sent with the prepared statement
164
- const queryParams = [];
165
- const vectorAsFloat32Array = new Float32Array(query);
166
- queryParams.push(vectorAsFloat32Array);
167
- if (filters) {
168
- const values = filters.map(({ value }) => value);
169
- queryParams.push(...values);
170
- }
171
- queryParams.push(vectorAsFloat32Array);
172
- queryParams.push(k);
173
- const queryResultSet = await this.client.execute(queryStr, queryParams, {
174
- prepare: true,
175
- });
176
- return queryResultSet?.rows.map((row) => {
177
- const textContent = row.text;
178
- const sanitizedRow = { ...row };
179
- delete sanitizedRow.text;
180
- delete sanitizedRow.similarity_score;
181
- // A null value in Cassandra evaluates to a deleted column
182
- // as this is treated as a tombstone record for the cell.
183
- Object.keys(sanitizedRow).forEach((key) => {
184
- if (sanitizedRow[key] === null) {
185
- delete sanitizedRow[key];
186
- }
187
- });
188
- return [
189
- new Document({ pageContent: textContent, metadata: sanitizedRow }),
190
- row.similarity_score,
191
- ];
192
- });
193
- }
194
- /**
195
- * Static method to create an instance of CassandraStore from texts.
196
- * @param texts The texts to use.
197
- * @param metadatas The metadata associated with the texts.
198
- * @param embeddings The embeddings to use.
199
- * @param args The arguments for the CassandraStore.
200
- * @returns Promise that resolves with a new instance of CassandraStore.
201
- */
202
- static async fromTexts(texts, metadatas, embeddings, args) {
203
- const docs = [];
204
- for (let index = 0; index < texts.length; index += 1) {
205
- const metadata = Array.isArray(metadatas) ? metadatas[index] : metadatas;
206
- const doc = new Document({
207
- pageContent: texts[index],
208
- metadata,
209
- });
210
- docs.push(doc);
211
- }
212
- return CassandraStore.fromDocuments(docs, embeddings, args);
213
- }
214
- /**
215
- * Static method to create an instance of CassandraStore from documents.
216
- * @param docs The documents to use.
217
- * @param embeddings The embeddings to use.
218
- * @param args The arguments for the CassandraStore.
219
- * @returns Promise that resolves with a new instance of CassandraStore.
220
- */
221
- static async fromDocuments(docs, embeddings, args) {
222
- const instance = new this(embeddings, args);
223
- await instance.addDocuments(docs);
224
- return instance;
225
- }
226
- /**
227
- * Static method to create an instance of CassandraStore from an existing
228
- * index.
229
- * @param embeddings The embeddings to use.
230
- * @param args The arguments for the CassandraStore.
231
- * @returns Promise that resolves with a new instance of CassandraStore.
232
- */
233
- static async fromExistingIndex(embeddings, args) {
234
- const instance = new this(embeddings, args);
235
- await instance.initialize();
236
- return instance;
237
- }
238
- /**
239
- * Method to initialize the Cassandra database.
240
- * @returns Promise that resolves when the database has been initialized.
241
- */
242
- async initialize() {
243
- let cql = "";
244
- cql = `CREATE TABLE IF NOT EXISTS ${this.keyspace}.${this.table} (
245
- ${this.primaryKey.map((col) => `${col.name} ${col.type}`).join(", ")}
246
- , text TEXT
247
- ${this.metadataColumns.length > 0
248
- ? ", " +
249
- this.metadataColumns
250
- .map((col) => `${col.name} ${col.type}`)
251
- .join(", ")
252
- : ""}
253
- , vector VECTOR<FLOAT, ${this.dimensions}>
254
- , ${this.buildPrimaryKey(this.primaryKey)}
255
- ) ${this.withClause ? `WITH ${this.withClause}` : ""};`;
256
- await this.client.execute(cql);
257
- this.selectColumns = `${this.primaryKey
258
- .map((col) => `${col.name}`)
259
- .join(", ")}
260
- ${this.metadataColumns.length > 0
261
- ? ", " +
262
- this.metadataColumns
263
- .map((col) => `${col.name}`)
264
- .join(", ")
265
- : ""}`;
266
- cql = `CREATE CUSTOM INDEX IF NOT EXISTS idx_vector_${this.table}
267
- ON ${this.keyspace}.${this.table}(vector) USING 'StorageAttachedIndex' WITH OPTIONS = {'similarity_function': '${this.vectorType.toUpperCase()}'};`;
268
- await this.client.execute(cql);
269
- for await (const { name, value } of this.indices) {
270
- cql = `CREATE CUSTOM INDEX IF NOT EXISTS idx_${this.table}_${name}
271
- ON ${this.keyspace}.${this.table} ${value} USING 'StorageAttachedIndex';`;
272
- await this.client.execute(cql);
273
- }
274
- this.isInitialized = true;
275
- }
276
- /**
277
- * Method to build the PRIMARY KEY clause for CREATE TABLE.
278
- * @param columns: list of Column to include in the key
279
- * @returns The clause, including PRIMARY KEY
280
- */
281
- buildPrimaryKey(columns) {
282
- // Partition columns may be specified with optional attribute col.partition
283
- const partitionColumns = columns
284
- .filter((col) => col.partition)
285
- .map((col) => col.name)
286
- .join(", ");
287
- // All columns not part of the partition key are clustering columns
288
- const clusteringColumns = columns
289
- .filter((col) => !col.partition)
290
- .map((col) => col.name)
291
- .join(", ");
292
- let primaryKey = "";
293
- // If partition columns are specified, they are included in a () wrapper
294
- // If not, the clustering columns are used, and the first clustering column
295
- // is the partition key per normal Cassandra behaviour.
296
- if (partitionColumns) {
297
- primaryKey = `PRIMARY KEY ((${partitionColumns}), ${clusteringColumns})`;
298
- }
299
- else {
300
- primaryKey = `PRIMARY KEY (${clusteringColumns})`;
301
- }
302
- return primaryKey;
303
- }
304
- /**
305
- * Type guard to check if an object is a Filter.
306
- * @param obj: the object to check
307
- * @returns boolean indicating if the object is a Filter
308
- */
309
- isFilter(obj) {
310
- return (typeof obj === "object" && obj !== null && "name" in obj && "value" in obj);
311
- }
312
- /**
313
- * Helper to convert Record<string,unknown> to a Filter[]
314
- * @param record: a key-value Record collection
315
- * @returns Record as a Filter[]
316
- */
317
- convertToFilters(record) {
318
- return Object.entries(record).map(([name, value]) => ({
319
- name,
320
- value,
321
- operator: "=",
322
- }));
323
- }
324
- /**
325
- * Input santisation method for filters, as FilterType is not required to be
326
- * Filter[], but we want to use Filter[] internally.
327
- * @param record: the proposed filter
328
- * @returns A Filter[], which may be empty
329
- */
330
- asFilters(record) {
331
- if (!record) {
332
- return [];
333
- }
334
- // If record is already an array
335
- if (Array.isArray(record)) {
336
- return record.flatMap((item) => {
337
- // Check if item is a Filter before passing it to convertToFilters
338
- if (this.isFilter(item)) {
339
- return [item];
340
- }
341
- else {
342
- // Here item is treated as Record<string, unknown>
343
- return this.convertToFilters(item);
344
- }
345
- });
346
- }
347
- // If record is a single Filter object, return it in an array
348
- if (this.isFilter(record)) {
349
- return [record];
350
- }
351
- // If record is a Record<string, unknown>, convert it to an array of Filter
352
- return this.convertToFilters(record);
353
- }
354
- /**
355
- * Method to build the WHERE clause of a CQL query, using bind variable ?
356
- * @param filters list of filters to include in the WHERE clause
357
- * @returns The WHERE clause
358
- */
359
- buildWhereClause(filters) {
360
- if (!filters || filters.length === 0) {
361
- return "";
362
- }
363
- const whereConditions = filters.map(({ name, operator = "=" }) => `${name} ${operator} ?`);
364
- return `WHERE ${whereConditions.join(" AND ")}`;
365
- }
366
- /**
367
- * Method to build an CQL query for searching for similar vectors in the
368
- * Cassandra database.
369
- * @param query The query vector.
370
- * @param k The number of similar vectors to return.
371
- * @param filters
372
- * @returns The CQL query string.
373
- */
374
- buildSearchQuery(filters) {
375
- const whereClause = filters ? this.buildWhereClause(filters) : "";
376
- const cqlQuery = `SELECT ${this.selectColumns}, text, similarity_${this.vectorType}(vector, ?) AS similarity_score
377
- FROM ${this.keyspace}.${this.table} ${whereClause} ORDER BY vector ANN OF ? LIMIT ?`;
378
- return cqlQuery;
379
- }
380
- /**
381
- * Method for inserting vectors and documents into the Cassandra database in a batch.
382
- * @param batchVectors The list of vectors to insert.
383
- * @param batchDocuments The list of documents to insert.
384
- * @returns Promise that resolves when the batch has been inserted.
385
- */
386
- async executeInsert(batchVectors, batchDocuments) {
387
- // Input validation: Check if the lengths of batchVectors and batchDocuments are the same
388
- if (batchVectors.length !== batchDocuments.length) {
389
- throw new Error(`The lengths of vectors (${batchVectors.length}) and documents (${batchDocuments.length}) must be the same.`);
390
- }
391
- // Initialize an array to hold query objects
392
- const queries = [];
393
- // Loop through each vector and document in the batch
394
- for (let i = 0; i < batchVectors.length; i += 1) {
395
- // Convert the list of numbers to a Float32Array, the driver's expected format of a vector
396
- const preparedVector = new Float32Array(batchVectors[i]);
397
- // Retrieve the corresponding document
398
- const document = batchDocuments[i];
399
- // Extract metadata column names and values from the document
400
- const metadataColNames = Object.keys(document.metadata);
401
- const metadataVals = Object.values(document.metadata);
402
- // Prepare the metadata columns string for the query, if metadata exists
403
- const metadataInsert = metadataColNames.length > 0 ? ", " + metadataColNames.join(", ") : "";
404
- // Construct the query string and parameters
405
- const query = {
406
- query: `INSERT INTO ${this.keyspace}.${this.table} (vector, text${metadataInsert})
407
- VALUES (?, ?${", ?".repeat(metadataColNames.length)})`,
408
- params: [preparedVector, document.pageContent, ...metadataVals],
409
- };
410
- // Add the query to the list
411
- queries.push(query);
412
- }
413
- // Execute the queries: use a batch if multiple, otherwise execute a single query
414
- if (queries.length === 1) {
415
- await this.client.execute(queries[0].query, queries[0].params, {
416
- prepare: true,
417
- });
418
- }
419
- else {
420
- await this.client.batch(queries, { prepare: true, logged: false });
421
- }
422
- }
423
- /**
424
- * Method for inserting vectors and documents into the Cassandra database in
425
- * parallel, keeping within maxConcurrency number of active insert statements.
426
- * @param vectors The vectors to insert.
427
- * @param documents The documents to insert.
428
- * @returns Promise that resolves when the documents have been added.
429
- */
430
- async insertAll(vectors, documents) {
431
- // Input validation: Check if the lengths of vectors and documents are the same
432
- if (vectors.length !== documents.length) {
433
- throw new Error(`The lengths of vectors (${vectors.length}) and documents (${documents.length}) must be the same.`);
434
- }
435
- // Early exit: If there are no vectors or documents to insert, return immediately
436
- if (vectors.length === 0) {
437
- return;
438
- }
439
- // Ensure the store is initialized before proceeding
440
- if (!this.isInitialized) {
441
- await this.initialize();
442
- }
443
- // Initialize an array to hold promises for each batch insert
444
- const insertPromises = [];
445
- // Buffers to hold the current batch of vectors and documents
446
- let currentBatchVectors = [];
447
- let currentBatchDocuments = [];
448
- // Loop through each vector/document pair to insert; we use
449
- // <= vectors.length to ensure the last batch is inserted
450
- for (let i = 0; i <= vectors.length; i += 1) {
451
- // Check if we're still within the array boundaries
452
- if (i < vectors.length) {
453
- // Add the current vector and document to the batch
454
- currentBatchVectors.push(vectors[i]);
455
- currentBatchDocuments.push(documents[i]);
456
- }
457
- // Check if we've reached the batch size or end of the array
458
- if (currentBatchVectors.length >= this.batchSize ||
459
- i === vectors.length) {
460
- // Only proceed if there are items in the current batch
461
- if (currentBatchVectors.length > 0) {
462
- // Create copies of the current batch arrays to use in the async insert operation
463
- const batchVectors = [...currentBatchVectors];
464
- const batchDocuments = [...currentBatchDocuments];
465
- // Execute the insert using the AsyncCaller - it will handle concurrency and queueing.
466
- insertPromises.push(this.asyncCaller.call(() => this.executeInsert(batchVectors, batchDocuments)));
467
- // Clear the current buffers for the next iteration
468
- currentBatchVectors = [];
469
- currentBatchDocuments = [];
470
- }
471
- }
472
- }
473
- // Wait for all insert operations to complete.
474
- await Promise.all(insertPromises);
475
- }
476
- }
1
+ export * from "@langchain/community/vectorstores/cassandra";