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,274 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.BaseChatGoogleVertexAI = exports.GoogleVertexAIChatMessage = void 0;
4
- const base_js_1 = require("../base.cjs");
5
- const index_js_1 = require("../../schema/index.cjs");
6
- /**
7
- * Represents a chat message in the Google Vertex AI chat model.
8
- */
9
- class GoogleVertexAIChatMessage {
10
- constructor(fields) {
11
- Object.defineProperty(this, "author", {
12
- enumerable: true,
13
- configurable: true,
14
- writable: true,
15
- value: void 0
16
- });
17
- Object.defineProperty(this, "content", {
18
- enumerable: true,
19
- configurable: true,
20
- writable: true,
21
- value: void 0
22
- });
23
- Object.defineProperty(this, "name", {
24
- enumerable: true,
25
- configurable: true,
26
- writable: true,
27
- value: void 0
28
- });
29
- this.author = fields.author;
30
- this.content = fields.content;
31
- this.name = fields.name;
32
- }
33
- /**
34
- * Extracts the role of a generic message and maps it to a Google Vertex
35
- * AI chat author.
36
- * @param message The chat message to extract the role from.
37
- * @returns The role of the message mapped to a Google Vertex AI chat author.
38
- */
39
- static extractGenericMessageCustomRole(message) {
40
- if (message.role !== "system" &&
41
- message.role !== "bot" &&
42
- message.role !== "user" &&
43
- message.role !== "context") {
44
- console.warn(`Unknown message role: ${message.role}`);
45
- }
46
- return message.role;
47
- }
48
- /**
49
- * Maps a message type to a Google Vertex AI chat author.
50
- * @param message The message to map.
51
- * @param model The model to use for mapping.
52
- * @returns The message type mapped to a Google Vertex AI chat author.
53
- */
54
- static mapMessageTypeToVertexChatAuthor(message, model) {
55
- const type = message._getType();
56
- switch (type) {
57
- case "ai":
58
- return model.startsWith("codechat-") ? "system" : "bot";
59
- case "human":
60
- return "user";
61
- case "system":
62
- throw new Error(`System messages are only supported as the first passed message for Google Vertex AI.`);
63
- case "generic": {
64
- if (!index_js_1.ChatMessage.isInstance(message))
65
- throw new Error("Invalid generic chat message");
66
- return GoogleVertexAIChatMessage.extractGenericMessageCustomRole(message);
67
- }
68
- default:
69
- throw new Error(`Unknown / unsupported message type: ${message}`);
70
- }
71
- }
72
- /**
73
- * Creates a new Google Vertex AI chat message from a base message.
74
- * @param message The base message to convert.
75
- * @param model The model to use for conversion.
76
- * @returns A new Google Vertex AI chat message.
77
- */
78
- static fromChatMessage(message, model) {
79
- if (typeof message.content !== "string") {
80
- throw new Error("ChatGoogleVertexAI does not support non-string message content.");
81
- }
82
- return new GoogleVertexAIChatMessage({
83
- author: GoogleVertexAIChatMessage.mapMessageTypeToVertexChatAuthor(message, model),
84
- content: message.content,
85
- });
86
- }
87
- }
88
- exports.GoogleVertexAIChatMessage = GoogleVertexAIChatMessage;
89
- /**
90
- * Base class for Google Vertex AI chat models.
91
- * Implemented subclasses must provide a GoogleVertexAILLMConnection
92
- * with appropriate auth client.
93
- */
94
- class BaseChatGoogleVertexAI extends base_js_1.BaseChatModel {
95
- get lc_aliases() {
96
- return {
97
- model: "model_name",
98
- };
99
- }
100
- constructor(fields) {
101
- super(fields ?? {});
102
- Object.defineProperty(this, "lc_serializable", {
103
- enumerable: true,
104
- configurable: true,
105
- writable: true,
106
- value: true
107
- });
108
- Object.defineProperty(this, "model", {
109
- enumerable: true,
110
- configurable: true,
111
- writable: true,
112
- value: "chat-bison"
113
- });
114
- Object.defineProperty(this, "temperature", {
115
- enumerable: true,
116
- configurable: true,
117
- writable: true,
118
- value: 0.2
119
- });
120
- Object.defineProperty(this, "maxOutputTokens", {
121
- enumerable: true,
122
- configurable: true,
123
- writable: true,
124
- value: 1024
125
- });
126
- Object.defineProperty(this, "topP", {
127
- enumerable: true,
128
- configurable: true,
129
- writable: true,
130
- value: 0.8
131
- });
132
- Object.defineProperty(this, "topK", {
133
- enumerable: true,
134
- configurable: true,
135
- writable: true,
136
- value: 40
137
- });
138
- Object.defineProperty(this, "examples", {
139
- enumerable: true,
140
- configurable: true,
141
- writable: true,
142
- value: []
143
- });
144
- Object.defineProperty(this, "connection", {
145
- enumerable: true,
146
- configurable: true,
147
- writable: true,
148
- value: void 0
149
- });
150
- Object.defineProperty(this, "streamedConnection", {
151
- enumerable: true,
152
- configurable: true,
153
- writable: true,
154
- value: void 0
155
- });
156
- this.model = fields?.model ?? this.model;
157
- this.temperature = fields?.temperature ?? this.temperature;
158
- this.maxOutputTokens = fields?.maxOutputTokens ?? this.maxOutputTokens;
159
- this.topP = fields?.topP ?? this.topP;
160
- this.topK = fields?.topK ?? this.topK;
161
- this.examples = fields?.examples ?? this.examples;
162
- }
163
- _combineLLMOutput() {
164
- // TODO: Combine the safetyAttributes
165
- return [];
166
- }
167
- async *_streamResponseChunks(_messages, _options, _runManager) {
168
- // Make the call as a streaming request
169
- const instance = this.createInstance(_messages);
170
- const parameters = this.formatParameters();
171
- const result = await this.streamedConnection.request([instance], parameters, _options);
172
- // Get the streaming parser of the response
173
- const stream = result.data;
174
- // Loop until the end of the stream
175
- // During the loop, yield each time we get a chunk from the streaming parser
176
- // that is either available or added to the queue
177
- while (!stream.streamDone) {
178
- const output = await stream.nextChunk();
179
- const chunk = output !== null
180
- ? BaseChatGoogleVertexAI.convertPredictionChunk(output)
181
- : new index_js_1.ChatGenerationChunk({
182
- text: "",
183
- message: new index_js_1.AIMessageChunk(""),
184
- generationInfo: { finishReason: "stop" },
185
- });
186
- yield chunk;
187
- }
188
- }
189
- async _generate(messages, options) {
190
- const instance = this.createInstance(messages);
191
- const parameters = this.formatParameters();
192
- const result = await this.connection.request([instance], parameters, options);
193
- const generations = result?.data?.predictions?.map((prediction) => BaseChatGoogleVertexAI.convertPrediction(prediction)) ?? [];
194
- return {
195
- generations,
196
- };
197
- }
198
- _llmType() {
199
- return "vertexai";
200
- }
201
- /**
202
- * Creates an instance of the Google Vertex AI chat model.
203
- * @param messages The messages for the model instance.
204
- * @returns A new instance of the Google Vertex AI chat model.
205
- */
206
- createInstance(messages) {
207
- let context = "";
208
- let conversationMessages = messages;
209
- if (messages[0]?._getType() === "system") {
210
- if (typeof messages[0].content !== "string") {
211
- throw new Error("ChatGoogleVertexAI does not support non-string message content.");
212
- }
213
- context = messages[0].content;
214
- conversationMessages = messages.slice(1);
215
- }
216
- // https://cloud.google.com/vertex-ai/docs/generative-ai/chat/test-chat-prompts
217
- if (conversationMessages.length % 2 === 0) {
218
- throw new Error(`Google Vertex AI requires an odd number of messages to generate a response.`);
219
- }
220
- const vertexChatMessages = conversationMessages.map((baseMessage, i) => {
221
- const currMessage = GoogleVertexAIChatMessage.fromChatMessage(baseMessage, this.model);
222
- const prevMessage = i > 0
223
- ? GoogleVertexAIChatMessage.fromChatMessage(conversationMessages[i - 1], this.model)
224
- : null;
225
- // https://cloud.google.com/vertex-ai/docs/generative-ai/chat/chat-prompts#messages
226
- if (prevMessage && currMessage.author === prevMessage.author) {
227
- throw new Error(`Google Vertex AI requires AI and human messages to alternate.`);
228
- }
229
- return currMessage;
230
- });
231
- const examples = this.examples.map((example) => ({
232
- input: GoogleVertexAIChatMessage.fromChatMessage(example.input, this.model),
233
- output: GoogleVertexAIChatMessage.fromChatMessage(example.output, this.model),
234
- }));
235
- const instance = {
236
- context,
237
- examples,
238
- messages: vertexChatMessages,
239
- };
240
- return instance;
241
- }
242
- formatParameters() {
243
- return {
244
- temperature: this.temperature,
245
- topK: this.topK,
246
- topP: this.topP,
247
- maxOutputTokens: this.maxOutputTokens,
248
- };
249
- }
250
- /**
251
- * Converts a prediction from the Google Vertex AI chat model to a chat
252
- * generation.
253
- * @param prediction The prediction to convert.
254
- * @returns The converted chat generation.
255
- */
256
- static convertPrediction(prediction) {
257
- const message = prediction?.candidates[0];
258
- return {
259
- text: message?.content,
260
- message: new index_js_1.AIMessage(message.content),
261
- generationInfo: prediction,
262
- };
263
- }
264
- // eslint-disable-next-line @typescript-eslint/no-explicit-any
265
- static convertPredictionChunk(output) {
266
- const generation = BaseChatGoogleVertexAI.convertPrediction(output.outputs[0]);
267
- return new index_js_1.ChatGenerationChunk({
268
- text: generation.text,
269
- message: new index_js_1.AIMessageChunk(generation.message),
270
- generationInfo: generation.generationInfo,
271
- });
272
- }
273
- }
274
- exports.BaseChatGoogleVertexAI = BaseChatGoogleVertexAI;
@@ -1,123 +0,0 @@
1
- import { BaseChatModel } from "../base.js";
2
- import { BaseMessage, ChatGeneration, ChatGenerationChunk, ChatMessage, ChatResult, LLMResult } from "../../schema/index.js";
3
- import { GoogleVertexAILLMConnection } from "../../util/googlevertexai-connection.js";
4
- import { GoogleVertexAIBaseLLMInput, GoogleVertexAIBasePrediction, GoogleVertexAIModelParams } from "../../types/googlevertexai-types.js";
5
- import { BaseLanguageModelCallOptions } from "../../base_language/index.js";
6
- import { CallbackManagerForLLMRun } from "../../callbacks/index.js";
7
- /**
8
- * Represents a single "example" exchange that can be provided to
9
- * help illustrate what a model response should look like.
10
- */
11
- export interface ChatExample {
12
- input: BaseMessage;
13
- output: BaseMessage;
14
- }
15
- /**
16
- * Represents a single example exchange in the Google Vertex AI chat
17
- * model.
18
- */
19
- interface GoogleVertexAIChatExample {
20
- input: GoogleVertexAIChatMessage;
21
- output: GoogleVertexAIChatMessage;
22
- }
23
- /**
24
- * Represents the author of a chat message in the Google Vertex AI chat
25
- * model.
26
- */
27
- export type GoogleVertexAIChatAuthor = "user" | "bot" | "system" | "context";
28
- export type GoogleVertexAIChatMessageFields = {
29
- author?: GoogleVertexAIChatAuthor;
30
- content: string;
31
- name?: string;
32
- };
33
- /**
34
- * Represents a chat message in the Google Vertex AI chat model.
35
- */
36
- export declare class GoogleVertexAIChatMessage {
37
- author?: GoogleVertexAIChatAuthor;
38
- content: string;
39
- name?: string;
40
- constructor(fields: GoogleVertexAIChatMessageFields);
41
- /**
42
- * Extracts the role of a generic message and maps it to a Google Vertex
43
- * AI chat author.
44
- * @param message The chat message to extract the role from.
45
- * @returns The role of the message mapped to a Google Vertex AI chat author.
46
- */
47
- static extractGenericMessageCustomRole(message: ChatMessage): GoogleVertexAIChatAuthor;
48
- /**
49
- * Maps a message type to a Google Vertex AI chat author.
50
- * @param message The message to map.
51
- * @param model The model to use for mapping.
52
- * @returns The message type mapped to a Google Vertex AI chat author.
53
- */
54
- static mapMessageTypeToVertexChatAuthor(message: BaseMessage, model: string): GoogleVertexAIChatAuthor;
55
- /**
56
- * Creates a new Google Vertex AI chat message from a base message.
57
- * @param message The base message to convert.
58
- * @param model The model to use for conversion.
59
- * @returns A new Google Vertex AI chat message.
60
- */
61
- static fromChatMessage(message: BaseMessage, model: string): GoogleVertexAIChatMessage;
62
- }
63
- /**
64
- * Represents an instance of the Google Vertex AI chat model.
65
- */
66
- export interface GoogleVertexAIChatInstance {
67
- context?: string;
68
- examples?: GoogleVertexAIChatExample[];
69
- messages: GoogleVertexAIChatMessage[];
70
- }
71
- /**
72
- * Defines the prediction output of the Google Vertex AI chat model.
73
- */
74
- export interface GoogleVertexAIChatPrediction extends GoogleVertexAIBasePrediction {
75
- candidates: GoogleVertexAIChatMessage[];
76
- }
77
- /**
78
- * Defines the input to the Google Vertex AI chat model.
79
- */
80
- export interface GoogleVertexAIChatInput<AuthOptions> extends GoogleVertexAIBaseLLMInput<AuthOptions> {
81
- /** Instructions how the model should respond */
82
- context?: string;
83
- /** Help the model understand what an appropriate response is */
84
- examples?: ChatExample[];
85
- }
86
- /**
87
- * Base class for Google Vertex AI chat models.
88
- * Implemented subclasses must provide a GoogleVertexAILLMConnection
89
- * with appropriate auth client.
90
- */
91
- export declare class BaseChatGoogleVertexAI<AuthOptions> extends BaseChatModel implements GoogleVertexAIChatInput<AuthOptions> {
92
- lc_serializable: boolean;
93
- model: string;
94
- temperature: number;
95
- maxOutputTokens: number;
96
- topP: number;
97
- topK: number;
98
- examples: ChatExample[];
99
- connection: GoogleVertexAILLMConnection<BaseLanguageModelCallOptions, GoogleVertexAIChatInstance, GoogleVertexAIChatPrediction, AuthOptions>;
100
- streamedConnection: GoogleVertexAILLMConnection<BaseLanguageModelCallOptions, GoogleVertexAIChatInstance, GoogleVertexAIChatPrediction, AuthOptions>;
101
- get lc_aliases(): Record<string, string>;
102
- constructor(fields?: GoogleVertexAIChatInput<AuthOptions>);
103
- _combineLLMOutput(): LLMResult["llmOutput"];
104
- _streamResponseChunks(_messages: BaseMessage[], _options: this["ParsedCallOptions"], _runManager?: CallbackManagerForLLMRun): AsyncGenerator<ChatGenerationChunk>;
105
- _generate(messages: BaseMessage[], options: this["ParsedCallOptions"]): Promise<ChatResult>;
106
- _llmType(): string;
107
- /**
108
- * Creates an instance of the Google Vertex AI chat model.
109
- * @param messages The messages for the model instance.
110
- * @returns A new instance of the Google Vertex AI chat model.
111
- */
112
- createInstance(messages: BaseMessage[]): GoogleVertexAIChatInstance;
113
- formatParameters(): GoogleVertexAIModelParams;
114
- /**
115
- * Converts a prediction from the Google Vertex AI chat model to a chat
116
- * generation.
117
- * @param prediction The prediction to convert.
118
- * @returns The converted chat generation.
119
- */
120
- static convertPrediction(prediction: GoogleVertexAIChatPrediction): ChatGeneration;
121
- static convertPredictionChunk(output: any): ChatGenerationChunk;
122
- }
123
- export {};
@@ -1,269 +0,0 @@
1
- import { BaseChatModel } from "../base.js";
2
- import { AIMessage, AIMessageChunk, ChatGenerationChunk, ChatMessage, } from "../../schema/index.js";
3
- /**
4
- * Represents a chat message in the Google Vertex AI chat model.
5
- */
6
- export class GoogleVertexAIChatMessage {
7
- constructor(fields) {
8
- Object.defineProperty(this, "author", {
9
- enumerable: true,
10
- configurable: true,
11
- writable: true,
12
- value: void 0
13
- });
14
- Object.defineProperty(this, "content", {
15
- enumerable: true,
16
- configurable: true,
17
- writable: true,
18
- value: void 0
19
- });
20
- Object.defineProperty(this, "name", {
21
- enumerable: true,
22
- configurable: true,
23
- writable: true,
24
- value: void 0
25
- });
26
- this.author = fields.author;
27
- this.content = fields.content;
28
- this.name = fields.name;
29
- }
30
- /**
31
- * Extracts the role of a generic message and maps it to a Google Vertex
32
- * AI chat author.
33
- * @param message The chat message to extract the role from.
34
- * @returns The role of the message mapped to a Google Vertex AI chat author.
35
- */
36
- static extractGenericMessageCustomRole(message) {
37
- if (message.role !== "system" &&
38
- message.role !== "bot" &&
39
- message.role !== "user" &&
40
- message.role !== "context") {
41
- console.warn(`Unknown message role: ${message.role}`);
42
- }
43
- return message.role;
44
- }
45
- /**
46
- * Maps a message type to a Google Vertex AI chat author.
47
- * @param message The message to map.
48
- * @param model The model to use for mapping.
49
- * @returns The message type mapped to a Google Vertex AI chat author.
50
- */
51
- static mapMessageTypeToVertexChatAuthor(message, model) {
52
- const type = message._getType();
53
- switch (type) {
54
- case "ai":
55
- return model.startsWith("codechat-") ? "system" : "bot";
56
- case "human":
57
- return "user";
58
- case "system":
59
- throw new Error(`System messages are only supported as the first passed message for Google Vertex AI.`);
60
- case "generic": {
61
- if (!ChatMessage.isInstance(message))
62
- throw new Error("Invalid generic chat message");
63
- return GoogleVertexAIChatMessage.extractGenericMessageCustomRole(message);
64
- }
65
- default:
66
- throw new Error(`Unknown / unsupported message type: ${message}`);
67
- }
68
- }
69
- /**
70
- * Creates a new Google Vertex AI chat message from a base message.
71
- * @param message The base message to convert.
72
- * @param model The model to use for conversion.
73
- * @returns A new Google Vertex AI chat message.
74
- */
75
- static fromChatMessage(message, model) {
76
- if (typeof message.content !== "string") {
77
- throw new Error("ChatGoogleVertexAI does not support non-string message content.");
78
- }
79
- return new GoogleVertexAIChatMessage({
80
- author: GoogleVertexAIChatMessage.mapMessageTypeToVertexChatAuthor(message, model),
81
- content: message.content,
82
- });
83
- }
84
- }
85
- /**
86
- * Base class for Google Vertex AI chat models.
87
- * Implemented subclasses must provide a GoogleVertexAILLMConnection
88
- * with appropriate auth client.
89
- */
90
- export class BaseChatGoogleVertexAI extends BaseChatModel {
91
- get lc_aliases() {
92
- return {
93
- model: "model_name",
94
- };
95
- }
96
- constructor(fields) {
97
- super(fields ?? {});
98
- Object.defineProperty(this, "lc_serializable", {
99
- enumerable: true,
100
- configurable: true,
101
- writable: true,
102
- value: true
103
- });
104
- Object.defineProperty(this, "model", {
105
- enumerable: true,
106
- configurable: true,
107
- writable: true,
108
- value: "chat-bison"
109
- });
110
- Object.defineProperty(this, "temperature", {
111
- enumerable: true,
112
- configurable: true,
113
- writable: true,
114
- value: 0.2
115
- });
116
- Object.defineProperty(this, "maxOutputTokens", {
117
- enumerable: true,
118
- configurable: true,
119
- writable: true,
120
- value: 1024
121
- });
122
- Object.defineProperty(this, "topP", {
123
- enumerable: true,
124
- configurable: true,
125
- writable: true,
126
- value: 0.8
127
- });
128
- Object.defineProperty(this, "topK", {
129
- enumerable: true,
130
- configurable: true,
131
- writable: true,
132
- value: 40
133
- });
134
- Object.defineProperty(this, "examples", {
135
- enumerable: true,
136
- configurable: true,
137
- writable: true,
138
- value: []
139
- });
140
- Object.defineProperty(this, "connection", {
141
- enumerable: true,
142
- configurable: true,
143
- writable: true,
144
- value: void 0
145
- });
146
- Object.defineProperty(this, "streamedConnection", {
147
- enumerable: true,
148
- configurable: true,
149
- writable: true,
150
- value: void 0
151
- });
152
- this.model = fields?.model ?? this.model;
153
- this.temperature = fields?.temperature ?? this.temperature;
154
- this.maxOutputTokens = fields?.maxOutputTokens ?? this.maxOutputTokens;
155
- this.topP = fields?.topP ?? this.topP;
156
- this.topK = fields?.topK ?? this.topK;
157
- this.examples = fields?.examples ?? this.examples;
158
- }
159
- _combineLLMOutput() {
160
- // TODO: Combine the safetyAttributes
161
- return [];
162
- }
163
- async *_streamResponseChunks(_messages, _options, _runManager) {
164
- // Make the call as a streaming request
165
- const instance = this.createInstance(_messages);
166
- const parameters = this.formatParameters();
167
- const result = await this.streamedConnection.request([instance], parameters, _options);
168
- // Get the streaming parser of the response
169
- const stream = result.data;
170
- // Loop until the end of the stream
171
- // During the loop, yield each time we get a chunk from the streaming parser
172
- // that is either available or added to the queue
173
- while (!stream.streamDone) {
174
- const output = await stream.nextChunk();
175
- const chunk = output !== null
176
- ? BaseChatGoogleVertexAI.convertPredictionChunk(output)
177
- : new ChatGenerationChunk({
178
- text: "",
179
- message: new AIMessageChunk(""),
180
- generationInfo: { finishReason: "stop" },
181
- });
182
- yield chunk;
183
- }
184
- }
185
- async _generate(messages, options) {
186
- const instance = this.createInstance(messages);
187
- const parameters = this.formatParameters();
188
- const result = await this.connection.request([instance], parameters, options);
189
- const generations = result?.data?.predictions?.map((prediction) => BaseChatGoogleVertexAI.convertPrediction(prediction)) ?? [];
190
- return {
191
- generations,
192
- };
193
- }
194
- _llmType() {
195
- return "vertexai";
196
- }
197
- /**
198
- * Creates an instance of the Google Vertex AI chat model.
199
- * @param messages The messages for the model instance.
200
- * @returns A new instance of the Google Vertex AI chat model.
201
- */
202
- createInstance(messages) {
203
- let context = "";
204
- let conversationMessages = messages;
205
- if (messages[0]?._getType() === "system") {
206
- if (typeof messages[0].content !== "string") {
207
- throw new Error("ChatGoogleVertexAI does not support non-string message content.");
208
- }
209
- context = messages[0].content;
210
- conversationMessages = messages.slice(1);
211
- }
212
- // https://cloud.google.com/vertex-ai/docs/generative-ai/chat/test-chat-prompts
213
- if (conversationMessages.length % 2 === 0) {
214
- throw new Error(`Google Vertex AI requires an odd number of messages to generate a response.`);
215
- }
216
- const vertexChatMessages = conversationMessages.map((baseMessage, i) => {
217
- const currMessage = GoogleVertexAIChatMessage.fromChatMessage(baseMessage, this.model);
218
- const prevMessage = i > 0
219
- ? GoogleVertexAIChatMessage.fromChatMessage(conversationMessages[i - 1], this.model)
220
- : null;
221
- // https://cloud.google.com/vertex-ai/docs/generative-ai/chat/chat-prompts#messages
222
- if (prevMessage && currMessage.author === prevMessage.author) {
223
- throw new Error(`Google Vertex AI requires AI and human messages to alternate.`);
224
- }
225
- return currMessage;
226
- });
227
- const examples = this.examples.map((example) => ({
228
- input: GoogleVertexAIChatMessage.fromChatMessage(example.input, this.model),
229
- output: GoogleVertexAIChatMessage.fromChatMessage(example.output, this.model),
230
- }));
231
- const instance = {
232
- context,
233
- examples,
234
- messages: vertexChatMessages,
235
- };
236
- return instance;
237
- }
238
- formatParameters() {
239
- return {
240
- temperature: this.temperature,
241
- topK: this.topK,
242
- topP: this.topP,
243
- maxOutputTokens: this.maxOutputTokens,
244
- };
245
- }
246
- /**
247
- * Converts a prediction from the Google Vertex AI chat model to a chat
248
- * generation.
249
- * @param prediction The prediction to convert.
250
- * @returns The converted chat generation.
251
- */
252
- static convertPrediction(prediction) {
253
- const message = prediction?.candidates[0];
254
- return {
255
- text: message?.content,
256
- message: new AIMessage(message.content),
257
- generationInfo: prediction,
258
- };
259
- }
260
- // eslint-disable-next-line @typescript-eslint/no-explicit-any
261
- static convertPredictionChunk(output) {
262
- const generation = BaseChatGoogleVertexAI.convertPrediction(output.outputs[0]);
263
- return new ChatGenerationChunk({
264
- text: generation.text,
265
- message: new AIMessageChunk(generation.message),
266
- generationInfo: generation.generationInfo,
267
- });
268
- }
269
- }