langchain 0.0.195 → 0.0.197-rc.0

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 (236) hide show
  1. package/LICENSE +21 -0
  2. package/dist/agents/openai/index.cjs +6 -2
  3. package/dist/agents/openai/index.js +6 -2
  4. package/dist/agents/toolkits/conversational_retrieval/token_buffer_memory.d.ts +1 -1
  5. package/dist/base_language/count_tokens.cjs +5 -70
  6. package/dist/base_language/count_tokens.d.ts +1 -10
  7. package/dist/base_language/count_tokens.js +1 -65
  8. package/dist/base_language/index.cjs +6 -196
  9. package/dist/base_language/index.d.ts +1 -111
  10. package/dist/base_language/index.js +1 -191
  11. package/dist/cache/base.cjs +15 -37
  12. package/dist/cache/base.d.ts +1 -20
  13. package/dist/cache/base.js +1 -33
  14. package/dist/cache/index.cjs +2 -46
  15. package/dist/cache/index.d.ts +1 -29
  16. package/dist/cache/index.js +1 -45
  17. package/dist/callbacks/base.cjs +3 -139
  18. package/dist/callbacks/base.d.ts +1 -266
  19. package/dist/callbacks/base.js +1 -126
  20. package/dist/callbacks/handlers/console.cjs +14 -221
  21. package/dist/callbacks/handlers/console.d.ts +1 -117
  22. package/dist/callbacks/handlers/console.js +1 -217
  23. package/dist/callbacks/handlers/initialize.cjs +15 -30
  24. package/dist/callbacks/handlers/initialize.d.ts +1 -16
  25. package/dist/callbacks/handlers/initialize.js +1 -27
  26. package/dist/callbacks/handlers/log_stream.cjs +15 -293
  27. package/dist/callbacks/handlers/log_stream.d.ts +1 -100
  28. package/dist/callbacks/handlers/log_stream.js +1 -289
  29. package/dist/callbacks/handlers/run_collector.cjs +15 -48
  30. package/dist/callbacks/handlers/run_collector.d.ts +1 -26
  31. package/dist/callbacks/handlers/run_collector.js +1 -46
  32. package/dist/callbacks/handlers/tracer.cjs +15 -375
  33. package/dist/callbacks/handlers/tracer.d.ts +1 -70
  34. package/dist/callbacks/handlers/tracer.js +1 -373
  35. package/dist/callbacks/handlers/tracer_langchain.cjs +15 -104
  36. package/dist/callbacks/handlers/tracer_langchain.d.ts +1 -41
  37. package/dist/callbacks/handlers/tracer_langchain.js +1 -102
  38. package/dist/callbacks/handlers/tracer_langchain_v1.cjs +15 -197
  39. package/dist/callbacks/handlers/tracer_langchain_v1.d.ts +1 -57
  40. package/dist/callbacks/handlers/tracer_langchain_v1.js +1 -195
  41. package/dist/callbacks/manager.cjs +15 -676
  42. package/dist/callbacks/manager.d.ts +1 -180
  43. package/dist/callbacks/manager.js +1 -666
  44. package/dist/callbacks/promises.cjs +14 -42
  45. package/dist/callbacks/promises.d.ts +1 -11
  46. package/dist/callbacks/promises.js +1 -37
  47. package/dist/chains/graph_qa/prompts.d.ts +1 -1
  48. package/dist/chains/openai_functions/structured_output.cjs +2 -2
  49. package/dist/chains/openai_functions/structured_output.d.ts +1 -1
  50. package/dist/chains/openai_functions/structured_output.js +1 -1
  51. package/dist/chat_models/anthropic.cjs +15 -348
  52. package/dist/chat_models/anthropic.d.ts +1 -156
  53. package/dist/chat_models/anthropic.js +1 -346
  54. package/dist/chat_models/baiduwenxin.d.ts +1 -1
  55. package/dist/chat_models/base.cjs +15 -296
  56. package/dist/chat_models/base.d.ts +1 -122
  57. package/dist/chat_models/base.js +1 -292
  58. package/dist/chat_models/bedrock/web.cjs +21 -1
  59. package/dist/chat_models/bedrock/web.d.ts +2 -2
  60. package/dist/chat_models/bedrock/web.js +21 -1
  61. package/dist/chat_models/fireworks.d.ts +1 -1
  62. package/dist/document.cjs +2 -24
  63. package/dist/document.d.ts +1 -12
  64. package/dist/document.js +1 -23
  65. package/dist/document_loaders/web/azure_blob_storage_file.d.ts +1 -1
  66. package/dist/document_loaders/web/github.cjs +105 -0
  67. package/dist/document_loaders/web/github.d.ts +26 -0
  68. package/dist/document_loaders/web/github.js +105 -0
  69. package/dist/document_loaders/web/s3.d.ts +1 -1
  70. package/dist/embeddings/base.cjs +15 -22
  71. package/dist/embeddings/base.d.ts +1 -33
  72. package/dist/embeddings/base.js +1 -20
  73. package/dist/embeddings/cache_backed.cjs +2 -2
  74. package/dist/embeddings/cache_backed.js +1 -1
  75. package/dist/evaluation/agents/trajectory.d.ts +1 -1
  76. package/dist/evaluation/criteria/prompt.d.ts +2 -2
  77. package/dist/evaluation/qa/prompt.d.ts +2 -2
  78. package/dist/experimental/hubs/makersuite/googlemakersuitehub.d.ts +1 -1
  79. package/dist/experimental/plan_and_execute/prompt.d.ts +1 -1
  80. package/dist/llms/base.cjs +15 -278
  81. package/dist/llms/base.d.ts +1 -115
  82. package/dist/llms/base.js +1 -275
  83. package/dist/llms/bedrock/web.cjs +21 -1
  84. package/dist/llms/bedrock/web.d.ts +2 -2
  85. package/dist/llms/bedrock/web.js +21 -1
  86. package/dist/llms/fireworks.d.ts +1 -1
  87. package/dist/load/import_map.cjs +2 -1
  88. package/dist/load/import_map.d.ts +1 -0
  89. package/dist/load/import_map.js +1 -0
  90. package/dist/load/index.cjs +7 -148
  91. package/dist/load/index.js +7 -148
  92. package/dist/load/map_keys.cjs +0 -24
  93. package/dist/load/map_keys.d.ts +0 -6
  94. package/dist/load/map_keys.js +1 -17
  95. package/dist/load/serializable.cjs +15 -178
  96. package/dist/load/serializable.d.ts +1 -66
  97. package/dist/load/serializable.js +1 -175
  98. package/dist/memory/base.cjs +17 -92
  99. package/dist/memory/base.d.ts +2 -68
  100. package/dist/memory/base.js +2 -87
  101. package/dist/output_parsers/list.cjs +4 -122
  102. package/dist/output_parsers/list.d.ts +1 -57
  103. package/dist/output_parsers/list.js +1 -119
  104. package/dist/output_parsers/openai_functions.cjs +2 -2
  105. package/dist/output_parsers/openai_functions.d.ts +1 -1
  106. package/dist/output_parsers/openai_functions.js +1 -1
  107. package/dist/output_parsers/regex.d.ts +1 -1
  108. package/dist/output_parsers/structured.d.ts +1 -1
  109. package/dist/prompts/base.cjs +8 -183
  110. package/dist/prompts/base.d.ts +3 -132
  111. package/dist/prompts/base.js +3 -178
  112. package/dist/prompts/chat.cjs +13 -477
  113. package/dist/prompts/chat.d.ts +2 -219
  114. package/dist/prompts/chat.js +2 -466
  115. package/dist/prompts/few_shot.cjs +3 -352
  116. package/dist/prompts/few_shot.d.ts +1 -192
  117. package/dist/prompts/few_shot.js +1 -350
  118. package/dist/prompts/index.cjs +3 -2
  119. package/dist/prompts/index.d.ts +2 -1
  120. package/dist/prompts/index.js +2 -1
  121. package/dist/prompts/pipeline.cjs +2 -141
  122. package/dist/prompts/pipeline.d.ts +1 -98
  123. package/dist/prompts/pipeline.js +1 -140
  124. package/dist/prompts/prompt.cjs +2 -145
  125. package/dist/prompts/prompt.d.ts +1 -92
  126. package/dist/prompts/prompt.js +1 -144
  127. package/dist/prompts/selectors/LengthBasedExampleSelector.cjs +2 -147
  128. package/dist/prompts/selectors/LengthBasedExampleSelector.d.ts +1 -89
  129. package/dist/prompts/selectors/LengthBasedExampleSelector.js +1 -146
  130. package/dist/prompts/selectors/SemanticSimilarityExampleSelector.cjs +15 -137
  131. package/dist/prompts/selectors/SemanticSimilarityExampleSelector.d.ts +1 -91
  132. package/dist/prompts/selectors/SemanticSimilarityExampleSelector.js +1 -135
  133. package/dist/prompts/selectors/conditional.cjs +5 -73
  134. package/dist/prompts/selectors/conditional.d.ts +1 -63
  135. package/dist/prompts/selectors/conditional.js +1 -69
  136. package/dist/prompts/serde.d.ts +1 -43
  137. package/dist/prompts/template.cjs +8 -88
  138. package/dist/prompts/template.d.ts +1 -36
  139. package/dist/prompts/template.js +1 -83
  140. package/dist/{util/@cfworker/json-schema → runnables}/index.cjs +1 -1
  141. package/dist/runnables/index.d.ts +1 -0
  142. package/dist/runnables/index.js +1 -0
  143. package/dist/schema/document.cjs +3 -34
  144. package/dist/schema/document.d.ts +2 -29
  145. package/dist/schema/document.js +2 -32
  146. package/dist/schema/index.cjs +37 -612
  147. package/dist/schema/index.d.ts +11 -311
  148. package/dist/schema/index.js +8 -583
  149. package/dist/schema/output_parser.cjs +15 -309
  150. package/dist/schema/output_parser.d.ts +1 -173
  151. package/dist/schema/output_parser.js +1 -301
  152. package/dist/schema/retriever.cjs +15 -77
  153. package/dist/schema/retriever.d.ts +1 -43
  154. package/dist/schema/retriever.js +1 -75
  155. package/dist/schema/runnable/base.cjs +10 -1072
  156. package/dist/schema/runnable/base.d.ts +1 -356
  157. package/dist/schema/runnable/base.js +1 -1060
  158. package/dist/schema/runnable/branch.cjs +2 -131
  159. package/dist/schema/runnable/branch.d.ts +1 -94
  160. package/dist/schema/runnable/branch.js +1 -130
  161. package/dist/schema/runnable/config.cjs +0 -6
  162. package/dist/schema/runnable/config.d.ts +1 -3
  163. package/dist/schema/runnable/config.js +1 -4
  164. package/dist/schema/runnable/index.cjs +15 -16
  165. package/dist/schema/runnable/index.d.ts +1 -5
  166. package/dist/schema/runnable/index.js +1 -4
  167. package/dist/schema/runnable/passthrough.cjs +3 -113
  168. package/dist/schema/runnable/passthrough.d.ts +1 -72
  169. package/dist/schema/runnable/passthrough.js +1 -111
  170. package/dist/schema/runnable/router.cjs +2 -71
  171. package/dist/schema/runnable/router.d.ts +1 -29
  172. package/dist/schema/runnable/router.js +1 -70
  173. package/dist/schema/storage.cjs +15 -8
  174. package/dist/schema/storage.d.ts +1 -57
  175. package/dist/schema/storage.js +1 -6
  176. package/dist/tools/bingserpapi.d.ts +1 -1
  177. package/dist/tools/searchapi.d.ts +1 -1
  178. package/dist/tools/serpapi.d.ts +1 -1
  179. package/dist/tools/serper.d.ts +1 -1
  180. package/dist/util/async_caller.cjs +14 -128
  181. package/dist/util/async_caller.d.ts +1 -45
  182. package/dist/util/async_caller.js +1 -124
  183. package/dist/vectorstores/momento_vector_index.cjs +39 -0
  184. package/dist/vectorstores/momento_vector_index.d.ts +17 -1
  185. package/dist/vectorstores/momento_vector_index.js +40 -1
  186. package/dist/vectorstores/mongodb_atlas.cjs +22 -2
  187. package/dist/vectorstores/mongodb_atlas.d.ts +13 -0
  188. package/dist/vectorstores/mongodb_atlas.js +22 -2
  189. package/package.json +18 -11
  190. package/runnables.cjs +1 -0
  191. package/runnables.d.ts +1 -0
  192. package/runnables.js +1 -0
  193. package/dist/util/@cfworker/json-schema/index.d.ts +0 -1
  194. package/dist/util/@cfworker/json-schema/index.js +0 -1
  195. package/dist/util/@cfworker/json-schema/src/deep-compare-strict.cjs +0 -43
  196. package/dist/util/@cfworker/json-schema/src/deep-compare-strict.d.ts +0 -1
  197. package/dist/util/@cfworker/json-schema/src/deep-compare-strict.js +0 -39
  198. package/dist/util/@cfworker/json-schema/src/dereference.cjs +0 -169
  199. package/dist/util/@cfworker/json-schema/src/dereference.d.ts +0 -12
  200. package/dist/util/@cfworker/json-schema/src/dereference.js +0 -165
  201. package/dist/util/@cfworker/json-schema/src/format.cjs +0 -139
  202. package/dist/util/@cfworker/json-schema/src/format.d.ts +0 -2
  203. package/dist/util/@cfworker/json-schema/src/format.js +0 -136
  204. package/dist/util/@cfworker/json-schema/src/index.cjs +0 -24
  205. package/dist/util/@cfworker/json-schema/src/index.d.ts +0 -8
  206. package/dist/util/@cfworker/json-schema/src/index.js +0 -8
  207. package/dist/util/@cfworker/json-schema/src/pointer.cjs +0 -11
  208. package/dist/util/@cfworker/json-schema/src/pointer.d.ts +0 -2
  209. package/dist/util/@cfworker/json-schema/src/pointer.js +0 -6
  210. package/dist/util/@cfworker/json-schema/src/types.cjs +0 -2
  211. package/dist/util/@cfworker/json-schema/src/types.d.ts +0 -72
  212. package/dist/util/@cfworker/json-schema/src/types.js +0 -1
  213. package/dist/util/@cfworker/json-schema/src/ucs2-length.cjs +0 -28
  214. package/dist/util/@cfworker/json-schema/src/ucs2-length.d.ts +0 -6
  215. package/dist/util/@cfworker/json-schema/src/ucs2-length.js +0 -24
  216. package/dist/util/@cfworker/json-schema/src/validate.cjs +0 -808
  217. package/dist/util/@cfworker/json-schema/src/validate.d.ts +0 -3
  218. package/dist/util/@cfworker/json-schema/src/validate.js +0 -804
  219. package/dist/util/@cfworker/json-schema/src/validator.cjs +0 -44
  220. package/dist/util/@cfworker/json-schema/src/validator.d.ts +0 -10
  221. package/dist/util/@cfworker/json-schema/src/validator.js +0 -40
  222. package/dist/util/fast-json-patch/index.cjs +0 -49
  223. package/dist/util/fast-json-patch/index.d.ts +0 -22
  224. package/dist/util/fast-json-patch/index.js +0 -16
  225. package/dist/util/fast-json-patch/src/core.cjs +0 -469
  226. package/dist/util/fast-json-patch/src/core.d.ts +0 -111
  227. package/dist/util/fast-json-patch/src/core.js +0 -459
  228. package/dist/util/fast-json-patch/src/duplex.cjs +0 -237
  229. package/dist/util/fast-json-patch/src/duplex.d.ts +0 -23
  230. package/dist/util/fast-json-patch/src/duplex.js +0 -230
  231. package/dist/util/fast-json-patch/src/helpers.cjs +0 -194
  232. package/dist/util/fast-json-patch/src/helpers.d.ts +0 -36
  233. package/dist/util/fast-json-patch/src/helpers.js +0 -181
  234. package/dist/util/js-sha1/hash.cjs +0 -358
  235. package/dist/util/js-sha1/hash.d.ts +0 -1
  236. package/dist/util/js-sha1/hash.js +0 -355
@@ -1,180 +1,17 @@
1
1
  "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __exportStar = (this && this.__exportStar) || function(m, exports) {
14
+ for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
15
+ };
2
16
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.Serializable = exports.get_lc_unique_name = void 0;
4
- const map_keys_js_1 = require("./map_keys.cjs");
5
- function shallowCopy(obj) {
6
- return Array.isArray(obj) ? [...obj] : { ...obj };
7
- }
8
- function replaceSecrets(root, secretsMap) {
9
- const result = shallowCopy(root);
10
- for (const [path, secretId] of Object.entries(secretsMap)) {
11
- const [last, ...partsReverse] = path.split(".").reverse();
12
- // eslint-disable-next-line @typescript-eslint/no-explicit-any
13
- let current = result;
14
- for (const part of partsReverse.reverse()) {
15
- if (current[part] === undefined) {
16
- break;
17
- }
18
- current[part] = shallowCopy(current[part]);
19
- current = current[part];
20
- }
21
- if (current[last] !== undefined) {
22
- current[last] = {
23
- lc: 1,
24
- type: "secret",
25
- id: [secretId],
26
- };
27
- }
28
- }
29
- return result;
30
- }
31
- /**
32
- * Get a unique name for the module, rather than parent class implementations.
33
- * Should not be subclassed, subclass lc_name above instead.
34
- */
35
- function get_lc_unique_name(
36
- // eslint-disable-next-line @typescript-eslint/no-use-before-define
37
- serializableClass) {
38
- // "super" here would refer to the parent class of Serializable,
39
- // when we want the parent class of the module actually calling this method.
40
- const parentClass = Object.getPrototypeOf(serializableClass);
41
- const lcNameIsSubclassed = typeof serializableClass.lc_name === "function" &&
42
- (typeof parentClass.lc_name !== "function" ||
43
- serializableClass.lc_name() !== parentClass.lc_name());
44
- if (lcNameIsSubclassed) {
45
- return serializableClass.lc_name();
46
- }
47
- else {
48
- return serializableClass.name;
49
- }
50
- }
51
- exports.get_lc_unique_name = get_lc_unique_name;
52
- class Serializable {
53
- /**
54
- * The name of the serializable. Override to provide an alias or
55
- * to preserve the serialized module name in minified environments.
56
- *
57
- * Implemented as a static method to support loading logic.
58
- */
59
- static lc_name() {
60
- return this.name;
61
- }
62
- /**
63
- * The final serialized identifier for the module.
64
- */
65
- get lc_id() {
66
- return [
67
- ...this.lc_namespace,
68
- get_lc_unique_name(this.constructor),
69
- ];
70
- }
71
- /**
72
- * A map of secrets, which will be omitted from serialization.
73
- * Keys are paths to the secret in constructor args, e.g. "foo.bar.baz".
74
- * Values are the secret ids, which will be used when deserializing.
75
- */
76
- get lc_secrets() {
77
- return undefined;
78
- }
79
- /**
80
- * A map of additional attributes to merge with constructor args.
81
- * Keys are the attribute names, e.g. "foo".
82
- * Values are the attribute values, which will be serialized.
83
- * These attributes need to be accepted by the constructor as arguments.
84
- */
85
- get lc_attributes() {
86
- return undefined;
87
- }
88
- /**
89
- * A map of aliases for constructor args.
90
- * Keys are the attribute names, e.g. "foo".
91
- * Values are the alias that will replace the key in serialization.
92
- * This is used to eg. make argument names match Python.
93
- */
94
- get lc_aliases() {
95
- return undefined;
96
- }
97
- constructor(kwargs, ..._args) {
98
- Object.defineProperty(this, "lc_serializable", {
99
- enumerable: true,
100
- configurable: true,
101
- writable: true,
102
- value: false
103
- });
104
- Object.defineProperty(this, "lc_kwargs", {
105
- enumerable: true,
106
- configurable: true,
107
- writable: true,
108
- value: void 0
109
- });
110
- this.lc_kwargs = kwargs || {};
111
- }
112
- toJSON() {
113
- if (!this.lc_serializable) {
114
- return this.toJSONNotImplemented();
115
- }
116
- if (
117
- // eslint-disable-next-line no-instanceof/no-instanceof
118
- this.lc_kwargs instanceof Serializable ||
119
- typeof this.lc_kwargs !== "object" ||
120
- Array.isArray(this.lc_kwargs)) {
121
- // We do not support serialization of classes with arg not a POJO
122
- // I'm aware the check above isn't as strict as it could be
123
- return this.toJSONNotImplemented();
124
- }
125
- const aliases = {};
126
- const secrets = {};
127
- const kwargs = Object.keys(this.lc_kwargs).reduce((acc, key) => {
128
- acc[key] = key in this ? this[key] : this.lc_kwargs[key];
129
- return acc;
130
- }, {});
131
- // get secrets, attributes and aliases from all superclasses
132
- for (
133
- // eslint-disable-next-line @typescript-eslint/no-this-alias
134
- let current = Object.getPrototypeOf(this); current; current = Object.getPrototypeOf(current)) {
135
- Object.assign(aliases, Reflect.get(current, "lc_aliases", this));
136
- Object.assign(secrets, Reflect.get(current, "lc_secrets", this));
137
- Object.assign(kwargs, Reflect.get(current, "lc_attributes", this));
138
- }
139
- // include all secrets used, even if not in kwargs,
140
- // will be replaced with sentinel value in replaceSecrets
141
- Object.keys(secrets).forEach((keyPath) => {
142
- // eslint-disable-next-line @typescript-eslint/no-this-alias, @typescript-eslint/no-explicit-any
143
- let read = this;
144
- // eslint-disable-next-line @typescript-eslint/no-explicit-any
145
- let write = kwargs;
146
- const [last, ...partsReverse] = keyPath.split(".").reverse();
147
- for (const key of partsReverse.reverse()) {
148
- if (!(key in read) || read[key] === undefined)
149
- return;
150
- if (!(key in write) || write[key] === undefined) {
151
- if (typeof read[key] === "object" && read[key] != null) {
152
- write[key] = {};
153
- }
154
- else if (Array.isArray(read[key])) {
155
- write[key] = [];
156
- }
157
- }
158
- read = read[key];
159
- write = write[key];
160
- }
161
- if (last in read && read[last] !== undefined) {
162
- write[last] = write[last] || read[last];
163
- }
164
- });
165
- return {
166
- lc: 1,
167
- type: "constructor",
168
- id: this.lc_id,
169
- kwargs: (0, map_keys_js_1.mapKeys)(Object.keys(secrets).length ? replaceSecrets(kwargs, secrets) : kwargs, map_keys_js_1.keyToJson, aliases),
170
- };
171
- }
172
- toJSONNotImplemented() {
173
- return {
174
- lc: 1,
175
- type: "not_implemented",
176
- id: this.lc_id,
177
- };
178
- }
179
- }
180
- exports.Serializable = Serializable;
17
+ __exportStar(require("langchain-core/load/serializable"), exports);
@@ -1,66 +1 @@
1
- import { SerializedFields } from "./map_keys.js";
2
- export interface BaseSerialized<T extends string> {
3
- lc: number;
4
- type: T;
5
- id: string[];
6
- }
7
- export interface SerializedConstructor extends BaseSerialized<"constructor"> {
8
- kwargs: SerializedFields;
9
- }
10
- export interface SerializedSecret extends BaseSerialized<"secret"> {
11
- }
12
- export interface SerializedNotImplemented extends BaseSerialized<"not_implemented"> {
13
- }
14
- export type Serialized = SerializedConstructor | SerializedSecret | SerializedNotImplemented;
15
- /**
16
- * Get a unique name for the module, rather than parent class implementations.
17
- * Should not be subclassed, subclass lc_name above instead.
18
- */
19
- export declare function get_lc_unique_name(serializableClass: typeof Serializable): string;
20
- export declare abstract class Serializable {
21
- lc_serializable: boolean;
22
- lc_kwargs: SerializedFields;
23
- /**
24
- * A path to the module that contains the class, eg. ["langchain", "llms"]
25
- * Usually should be the same as the entrypoint the class is exported from.
26
- */
27
- abstract lc_namespace: string[];
28
- /**
29
- * The name of the serializable. Override to provide an alias or
30
- * to preserve the serialized module name in minified environments.
31
- *
32
- * Implemented as a static method to support loading logic.
33
- */
34
- static lc_name(): string;
35
- /**
36
- * The final serialized identifier for the module.
37
- */
38
- get lc_id(): string[];
39
- /**
40
- * A map of secrets, which will be omitted from serialization.
41
- * Keys are paths to the secret in constructor args, e.g. "foo.bar.baz".
42
- * Values are the secret ids, which will be used when deserializing.
43
- */
44
- get lc_secrets(): {
45
- [key: string]: string;
46
- } | undefined;
47
- /**
48
- * A map of additional attributes to merge with constructor args.
49
- * Keys are the attribute names, e.g. "foo".
50
- * Values are the attribute values, which will be serialized.
51
- * These attributes need to be accepted by the constructor as arguments.
52
- */
53
- get lc_attributes(): SerializedFields | undefined;
54
- /**
55
- * A map of aliases for constructor args.
56
- * Keys are the attribute names, e.g. "foo".
57
- * Values are the alias that will replace the key in serialization.
58
- * This is used to eg. make argument names match Python.
59
- */
60
- get lc_aliases(): {
61
- [key: string]: string;
62
- } | undefined;
63
- constructor(kwargs?: SerializedFields, ..._args: never[]);
64
- toJSON(): Serialized;
65
- toJSONNotImplemented(): SerializedNotImplemented;
66
- }
1
+ export * from "langchain-core/load/serializable";
@@ -1,175 +1 @@
1
- import { keyToJson, mapKeys } from "./map_keys.js";
2
- function shallowCopy(obj) {
3
- return Array.isArray(obj) ? [...obj] : { ...obj };
4
- }
5
- function replaceSecrets(root, secretsMap) {
6
- const result = shallowCopy(root);
7
- for (const [path, secretId] of Object.entries(secretsMap)) {
8
- const [last, ...partsReverse] = path.split(".").reverse();
9
- // eslint-disable-next-line @typescript-eslint/no-explicit-any
10
- let current = result;
11
- for (const part of partsReverse.reverse()) {
12
- if (current[part] === undefined) {
13
- break;
14
- }
15
- current[part] = shallowCopy(current[part]);
16
- current = current[part];
17
- }
18
- if (current[last] !== undefined) {
19
- current[last] = {
20
- lc: 1,
21
- type: "secret",
22
- id: [secretId],
23
- };
24
- }
25
- }
26
- return result;
27
- }
28
- /**
29
- * Get a unique name for the module, rather than parent class implementations.
30
- * Should not be subclassed, subclass lc_name above instead.
31
- */
32
- export function get_lc_unique_name(
33
- // eslint-disable-next-line @typescript-eslint/no-use-before-define
34
- serializableClass) {
35
- // "super" here would refer to the parent class of Serializable,
36
- // when we want the parent class of the module actually calling this method.
37
- const parentClass = Object.getPrototypeOf(serializableClass);
38
- const lcNameIsSubclassed = typeof serializableClass.lc_name === "function" &&
39
- (typeof parentClass.lc_name !== "function" ||
40
- serializableClass.lc_name() !== parentClass.lc_name());
41
- if (lcNameIsSubclassed) {
42
- return serializableClass.lc_name();
43
- }
44
- else {
45
- return serializableClass.name;
46
- }
47
- }
48
- export class Serializable {
49
- /**
50
- * The name of the serializable. Override to provide an alias or
51
- * to preserve the serialized module name in minified environments.
52
- *
53
- * Implemented as a static method to support loading logic.
54
- */
55
- static lc_name() {
56
- return this.name;
57
- }
58
- /**
59
- * The final serialized identifier for the module.
60
- */
61
- get lc_id() {
62
- return [
63
- ...this.lc_namespace,
64
- get_lc_unique_name(this.constructor),
65
- ];
66
- }
67
- /**
68
- * A map of secrets, which will be omitted from serialization.
69
- * Keys are paths to the secret in constructor args, e.g. "foo.bar.baz".
70
- * Values are the secret ids, which will be used when deserializing.
71
- */
72
- get lc_secrets() {
73
- return undefined;
74
- }
75
- /**
76
- * A map of additional attributes to merge with constructor args.
77
- * Keys are the attribute names, e.g. "foo".
78
- * Values are the attribute values, which will be serialized.
79
- * These attributes need to be accepted by the constructor as arguments.
80
- */
81
- get lc_attributes() {
82
- return undefined;
83
- }
84
- /**
85
- * A map of aliases for constructor args.
86
- * Keys are the attribute names, e.g. "foo".
87
- * Values are the alias that will replace the key in serialization.
88
- * This is used to eg. make argument names match Python.
89
- */
90
- get lc_aliases() {
91
- return undefined;
92
- }
93
- constructor(kwargs, ..._args) {
94
- Object.defineProperty(this, "lc_serializable", {
95
- enumerable: true,
96
- configurable: true,
97
- writable: true,
98
- value: false
99
- });
100
- Object.defineProperty(this, "lc_kwargs", {
101
- enumerable: true,
102
- configurable: true,
103
- writable: true,
104
- value: void 0
105
- });
106
- this.lc_kwargs = kwargs || {};
107
- }
108
- toJSON() {
109
- if (!this.lc_serializable) {
110
- return this.toJSONNotImplemented();
111
- }
112
- if (
113
- // eslint-disable-next-line no-instanceof/no-instanceof
114
- this.lc_kwargs instanceof Serializable ||
115
- typeof this.lc_kwargs !== "object" ||
116
- Array.isArray(this.lc_kwargs)) {
117
- // We do not support serialization of classes with arg not a POJO
118
- // I'm aware the check above isn't as strict as it could be
119
- return this.toJSONNotImplemented();
120
- }
121
- const aliases = {};
122
- const secrets = {};
123
- const kwargs = Object.keys(this.lc_kwargs).reduce((acc, key) => {
124
- acc[key] = key in this ? this[key] : this.lc_kwargs[key];
125
- return acc;
126
- }, {});
127
- // get secrets, attributes and aliases from all superclasses
128
- for (
129
- // eslint-disable-next-line @typescript-eslint/no-this-alias
130
- let current = Object.getPrototypeOf(this); current; current = Object.getPrototypeOf(current)) {
131
- Object.assign(aliases, Reflect.get(current, "lc_aliases", this));
132
- Object.assign(secrets, Reflect.get(current, "lc_secrets", this));
133
- Object.assign(kwargs, Reflect.get(current, "lc_attributes", this));
134
- }
135
- // include all secrets used, even if not in kwargs,
136
- // will be replaced with sentinel value in replaceSecrets
137
- Object.keys(secrets).forEach((keyPath) => {
138
- // eslint-disable-next-line @typescript-eslint/no-this-alias, @typescript-eslint/no-explicit-any
139
- let read = this;
140
- // eslint-disable-next-line @typescript-eslint/no-explicit-any
141
- let write = kwargs;
142
- const [last, ...partsReverse] = keyPath.split(".").reverse();
143
- for (const key of partsReverse.reverse()) {
144
- if (!(key in read) || read[key] === undefined)
145
- return;
146
- if (!(key in write) || write[key] === undefined) {
147
- if (typeof read[key] === "object" && read[key] != null) {
148
- write[key] = {};
149
- }
150
- else if (Array.isArray(read[key])) {
151
- write[key] = [];
152
- }
153
- }
154
- read = read[key];
155
- write = write[key];
156
- }
157
- if (last in read && read[last] !== undefined) {
158
- write[last] = write[last] || read[last];
159
- }
160
- });
161
- return {
162
- lc: 1,
163
- type: "constructor",
164
- id: this.lc_id,
165
- kwargs: mapKeys(Object.keys(secrets).length ? replaceSecrets(kwargs, secrets) : kwargs, keyToJson, aliases),
166
- };
167
- }
168
- toJSONNotImplemented() {
169
- return {
170
- lc: 1,
171
- type: "not_implemented",
172
- id: this.lc_id,
173
- };
174
- }
175
- }
1
+ export * from "langchain-core/load/serializable";
@@ -1,95 +1,20 @@
1
1
  "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.getPromptInputKey = exports.getBufferString = exports.getOutputValue = exports.getInputValue = exports.BaseMemory = void 0;
4
- /**
5
- * Abstract base class for memory in LangChain's Chains. Memory refers to
6
- * the state in Chains. It can be used to store information about past
7
- * executions of a Chain and inject that information into the inputs of
8
- * future executions of the Chain.
9
- */
10
- class BaseMemory {
11
- }
12
- exports.BaseMemory = BaseMemory;
13
- const getValue = (values, key) => {
14
- if (key !== undefined) {
15
- return values[key];
16
- }
17
- const keys = Object.keys(values);
18
- if (keys.length === 1) {
19
- return values[keys[0]];
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
20
7
  }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __exportStar = (this && this.__exportStar) || function(m, exports) {
14
+ for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
21
15
  };
22
- /**
23
- * This function is used by memory classes to select the input value
24
- * to use for the memory. If there is only one input value, it is used.
25
- * If there are multiple input values, the inputKey must be specified.
26
- */
27
- const getInputValue = (inputValues, inputKey) => {
28
- const value = getValue(inputValues, inputKey);
29
- if (!value) {
30
- const keys = Object.keys(inputValues);
31
- throw new Error(`input values have ${keys.length} keys, you must specify an input key or pass only 1 key as input`);
32
- }
33
- return value;
34
- };
35
- exports.getInputValue = getInputValue;
36
- /**
37
- * This function is used by memory classes to select the output value
38
- * to use for the memory. If there is only one output value, it is used.
39
- * If there are multiple output values, the outputKey must be specified.
40
- * If no outputKey is specified, an error is thrown.
41
- */
42
- const getOutputValue = (outputValues, outputKey) => {
43
- const value = getValue(outputValues, outputKey);
44
- if (!value) {
45
- const keys = Object.keys(outputValues);
46
- throw new Error(`output values have ${keys.length} keys, you must specify an output key or pass only 1 key as output`);
47
- }
48
- return value;
49
- };
50
- exports.getOutputValue = getOutputValue;
51
- /**
52
- * This function is used by memory classes to get a string representation
53
- * of the chat message history, based on the message content and role.
54
- */
55
- function getBufferString(messages, humanPrefix = "Human", aiPrefix = "AI") {
56
- const string_messages = [];
57
- for (const m of messages) {
58
- let role;
59
- if (m._getType() === "human") {
60
- role = humanPrefix;
61
- }
62
- else if (m._getType() === "ai") {
63
- role = aiPrefix;
64
- }
65
- else if (m._getType() === "system") {
66
- role = "System";
67
- }
68
- else if (m._getType() === "function") {
69
- role = "Function";
70
- }
71
- else if (m._getType() === "generic") {
72
- role = m.role;
73
- }
74
- else {
75
- throw new Error(`Got unsupported message type: ${m}`);
76
- }
77
- const nameStr = m.name ? `${m.name}, ` : "";
78
- string_messages.push(`${role}: ${nameStr}${m.content}`);
79
- }
80
- return string_messages.join("\n");
81
- }
82
- exports.getBufferString = getBufferString;
83
- /**
84
- * Function used by memory classes to get the key of the prompt input,
85
- * excluding any keys that are memory variables or the "stop" key. If
86
- * there is not exactly one prompt input key, an error is thrown.
87
- */
88
- function getPromptInputKey(inputs, memoryVariables) {
89
- const promptInputKeys = Object.keys(inputs).filter((key) => !memoryVariables.includes(key) && key !== "stop");
90
- if (promptInputKeys.length !== 1) {
91
- throw new Error(`One input key expected, but got ${promptInputKeys.length}`);
92
- }
93
- return promptInputKeys[0];
94
- }
95
- exports.getPromptInputKey = getPromptInputKey;
16
+ Object.defineProperty(exports, "__esModule", { value: true });
17
+ exports.getBufferString = void 0;
18
+ __exportStar(require("langchain-core/memory"), exports);
19
+ var messages_1 = require("langchain-core/messages");
20
+ Object.defineProperty(exports, "getBufferString", { enumerable: true, get: function () { return messages_1.getBufferString; } });
@@ -1,68 +1,2 @@
1
- import { BaseMessage } from "../schema/index.js";
2
- /**
3
- * Type alias for a record where the keys are strings and the values can
4
- * be any type. This is used to represent the input values for a Chain.
5
- */
6
- export type InputValues = Record<string, any>;
7
- /**
8
- * Type alias for a record where the keys are strings and the values can
9
- * be any type. This is used to represent the output values from a Chain.
10
- */
11
- export type OutputValues = Record<string, any>;
12
- /**
13
- * Type alias for a record where the keys are strings and the values can
14
- * be any type. This is used to represent the memory variables in a Chain.
15
- */
16
- export type MemoryVariables = Record<string, any>;
17
- /**
18
- * Abstract base class for memory in LangChain's Chains. Memory refers to
19
- * the state in Chains. It can be used to store information about past
20
- * executions of a Chain and inject that information into the inputs of
21
- * future executions of the Chain.
22
- */
23
- export declare abstract class BaseMemory {
24
- abstract get memoryKeys(): string[];
25
- /**
26
- * Abstract method that should take an object of input values and return a
27
- * Promise that resolves with an object of memory variables. The
28
- * implementation of this method should load the memory variables from the
29
- * provided input values.
30
- * @param values An object of input values.
31
- * @returns Promise that resolves with an object of memory variables.
32
- */
33
- abstract loadMemoryVariables(values: InputValues): Promise<MemoryVariables>;
34
- /**
35
- * Abstract method that should take two objects, one of input values and
36
- * one of output values, and return a Promise that resolves when the
37
- * context has been saved. The implementation of this method should save
38
- * the context based on the provided input and output values.
39
- * @param inputValues An object of input values.
40
- * @param outputValues An object of output values.
41
- * @returns Promise that resolves when the context has been saved.
42
- */
43
- abstract saveContext(inputValues: InputValues, outputValues: OutputValues): Promise<void>;
44
- }
45
- /**
46
- * This function is used by memory classes to select the input value
47
- * to use for the memory. If there is only one input value, it is used.
48
- * If there are multiple input values, the inputKey must be specified.
49
- */
50
- export declare const getInputValue: (inputValues: InputValues, inputKey?: string) => any;
51
- /**
52
- * This function is used by memory classes to select the output value
53
- * to use for the memory. If there is only one output value, it is used.
54
- * If there are multiple output values, the outputKey must be specified.
55
- * If no outputKey is specified, an error is thrown.
56
- */
57
- export declare const getOutputValue: (outputValues: OutputValues, outputKey?: string) => any;
58
- /**
59
- * This function is used by memory classes to get a string representation
60
- * of the chat message history, based on the message content and role.
61
- */
62
- export declare function getBufferString(messages: BaseMessage[], humanPrefix?: string, aiPrefix?: string): string;
63
- /**
64
- * Function used by memory classes to get the key of the prompt input,
65
- * excluding any keys that are memory variables or the "stop" key. If
66
- * there is not exactly one prompt input key, an error is thrown.
67
- */
68
- export declare function getPromptInputKey(inputs: Record<string, unknown>, memoryVariables: string[]): string;
1
+ export * from "langchain-core/memory";
2
+ export { getBufferString } from "langchain-core/messages";