langchain 0.0.197-rc.1 → 0.0.198
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.
- package/dist/chains/openai_moderation.cjs +2 -2
- package/dist/chains/openai_moderation.d.ts +1 -1
- package/dist/chains/openai_moderation.js +1 -1
- package/dist/chat_models/anthropic.cjs +351 -15
- package/dist/chat_models/anthropic.d.ts +157 -1
- package/dist/chat_models/anthropic.js +348 -1
- package/dist/chat_models/cloudflare_workersai.cjs +5 -0
- package/dist/chat_models/cloudflare_workersai.d.ts +3 -0
- package/dist/chat_models/cloudflare_workersai.js +5 -0
- package/dist/chat_models/fireworks.d.ts +1 -1
- package/dist/chat_models/iflytek_xinghuo/common.d.ts +1 -1
- package/dist/chat_models/llama_cpp.cjs +24 -0
- package/dist/chat_models/llama_cpp.d.ts +3 -1
- package/dist/chat_models/llama_cpp.js +24 -0
- package/dist/chat_models/minimax.d.ts +1 -1
- package/dist/chat_models/openai.cjs +698 -4
- package/dist/chat_models/openai.d.ts +137 -4
- package/dist/chat_models/openai.js +695 -2
- package/dist/document_loaders/fs/openai_whisper_audio.cjs +2 -2
- package/dist/document_loaders/fs/openai_whisper_audio.d.ts +1 -1
- package/dist/document_loaders/fs/openai_whisper_audio.js +1 -1
- package/dist/document_loaders/fs/pptx.cjs +39 -0
- package/dist/document_loaders/fs/pptx.d.ts +23 -0
- package/dist/document_loaders/fs/pptx.js +35 -0
- package/dist/embeddings/openai.cjs +240 -2
- package/dist/embeddings/openai.d.ts +82 -1
- package/dist/embeddings/openai.js +239 -1
- package/dist/experimental/openai_assistant/index.cjs +35 -3
- package/dist/experimental/openai_assistant/index.d.ts +27 -1
- package/dist/experimental/openai_assistant/index.js +33 -1
- package/dist/experimental/openai_assistant/schema.d.ts +1 -1
- package/dist/experimental/openai_files/index.cjs +2 -2
- package/dist/experimental/openai_files/index.d.ts +1 -1
- package/dist/experimental/openai_files/index.js +1 -1
- package/dist/experimental/tools/pyinterpreter.cjs +248 -0
- package/dist/experimental/tools/pyinterpreter.d.ts +18 -0
- package/dist/experimental/tools/pyinterpreter.js +244 -0
- package/dist/graphs/neo4j_graph.cjs +49 -14
- package/dist/graphs/neo4j_graph.d.ts +30 -0
- package/dist/graphs/neo4j_graph.js +49 -14
- package/dist/llms/fireworks.d.ts +1 -1
- package/dist/llms/hf.cjs +13 -2
- package/dist/llms/hf.d.ts +5 -0
- package/dist/llms/hf.js +13 -2
- package/dist/llms/llama_cpp.cjs +17 -3
- package/dist/llms/llama_cpp.d.ts +4 -1
- package/dist/llms/llama_cpp.js +17 -3
- package/dist/llms/openai-chat.cjs +445 -3
- package/dist/llms/openai-chat.d.ts +123 -4
- package/dist/llms/openai-chat.js +443 -2
- package/dist/llms/openai.cjs +530 -6
- package/dist/llms/openai.d.ts +123 -4
- package/dist/llms/openai.js +525 -2
- package/dist/load/import_constants.cjs +3 -0
- package/dist/load/import_constants.js +3 -0
- package/dist/output_parsers/json.cjs +4 -0
- package/dist/output_parsers/json.js +4 -0
- package/dist/schema/index.d.ts +1 -1
- package/dist/tools/convert_to_openai.cjs +38 -4
- package/dist/tools/convert_to_openai.d.ts +11 -1
- package/dist/tools/convert_to_openai.js +35 -1
- package/dist/types/openai-types.d.ts +133 -1
- package/dist/util/env.cjs +9 -70
- package/dist/util/env.d.ts +1 -21
- package/dist/util/env.js +1 -62
- package/dist/util/openai-format-fndef.cjs +81 -0
- package/dist/util/openai-format-fndef.d.ts +44 -0
- package/dist/util/openai-format-fndef.js +77 -0
- package/dist/util/openai.cjs +18 -2
- package/dist/util/openai.d.ts +1 -1
- package/dist/util/openai.js +17 -1
- package/dist/util/openapi.d.ts +2 -2
- package/dist/util/prompt-layer.d.ts +1 -1
- package/dist/vectorstores/clickhouse.cjs +286 -0
- package/dist/vectorstores/clickhouse.d.ts +126 -0
- package/dist/vectorstores/clickhouse.js +259 -0
- package/dist/vectorstores/pgvector.cjs +142 -18
- package/dist/vectorstores/pgvector.d.ts +21 -0
- package/dist/vectorstores/pgvector.js +142 -18
- package/dist/vectorstores/weaviate.cjs +45 -2
- package/dist/vectorstores/weaviate.d.ts +27 -1
- package/dist/vectorstores/weaviate.js +45 -2
- package/document_loaders/fs/pptx.cjs +1 -0
- package/document_loaders/fs/pptx.d.ts +1 -0
- package/document_loaders/fs/pptx.js +1 -0
- package/experimental/tools/pyinterpreter.cjs +1 -0
- package/experimental/tools/pyinterpreter.d.ts +1 -0
- package/experimental/tools/pyinterpreter.js +1 -0
- package/package.json +41 -9
- package/vectorstores/clickhouse.cjs +1 -0
- package/vectorstores/clickhouse.d.ts +1 -0
- package/vectorstores/clickhouse.js +1 -0
|
@@ -1,14 +1,456 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.PromptLayerOpenAIChat = exports.OpenAIChat = void 0;
|
|
4
|
-
const openai_1 = require("
|
|
5
|
-
|
|
4
|
+
const openai_1 = require("openai");
|
|
5
|
+
const index_js_1 = require("../schema/index.cjs");
|
|
6
|
+
const azure_js_1 = require("../util/azure.cjs");
|
|
6
7
|
const env_js_1 = require("../util/env.cjs");
|
|
7
8
|
const prompt_layer_js_1 = require("../util/prompt-layer.cjs");
|
|
9
|
+
const base_js_1 = require("./base.cjs");
|
|
10
|
+
const openai_js_1 = require("../util/openai.cjs");
|
|
11
|
+
/**
|
|
12
|
+
* Wrapper around OpenAI large language models that use the Chat endpoint.
|
|
13
|
+
*
|
|
14
|
+
* To use you should have the `openai` package installed, with the
|
|
15
|
+
* `OPENAI_API_KEY` environment variable set.
|
|
16
|
+
*
|
|
17
|
+
* To use with Azure you should have the `openai` package installed, with the
|
|
18
|
+
* `AZURE_OPENAI_API_KEY`,
|
|
19
|
+
* `AZURE_OPENAI_API_INSTANCE_NAME`,
|
|
20
|
+
* `AZURE_OPENAI_API_DEPLOYMENT_NAME`
|
|
21
|
+
* and `AZURE_OPENAI_API_VERSION` environment variable set.
|
|
22
|
+
*
|
|
23
|
+
* @remarks
|
|
24
|
+
* Any parameters that are valid to be passed to {@link
|
|
25
|
+
* https://platform.openai.com/docs/api-reference/chat/create |
|
|
26
|
+
* `openai.createCompletion`} can be passed through {@link modelKwargs}, even
|
|
27
|
+
* if not explicitly available on this class.
|
|
28
|
+
*
|
|
29
|
+
* @augments BaseLLM
|
|
30
|
+
* @augments OpenAIInput
|
|
31
|
+
* @augments AzureOpenAIChatInput
|
|
32
|
+
* @example
|
|
33
|
+
* ```typescript
|
|
34
|
+
* const model = new OpenAIChat({
|
|
35
|
+
* prefixMessages: [
|
|
36
|
+
* {
|
|
37
|
+
* role: "system",
|
|
38
|
+
* content: "You are a helpful assistant that answers in pirate language",
|
|
39
|
+
* },
|
|
40
|
+
* ],
|
|
41
|
+
* maxTokens: 50,
|
|
42
|
+
* });
|
|
43
|
+
*
|
|
44
|
+
* const res = await model.call(
|
|
45
|
+
* "What would be a good company name for a company that makes colorful socks?"
|
|
46
|
+
* );
|
|
47
|
+
* console.log({ res });
|
|
48
|
+
* ```
|
|
49
|
+
*/
|
|
50
|
+
class OpenAIChat extends base_js_1.LLM {
|
|
51
|
+
static lc_name() {
|
|
52
|
+
return "OpenAIChat";
|
|
53
|
+
}
|
|
54
|
+
get callKeys() {
|
|
55
|
+
return [...super.callKeys, "options", "promptIndex"];
|
|
56
|
+
}
|
|
57
|
+
get lc_secrets() {
|
|
58
|
+
return {
|
|
59
|
+
openAIApiKey: "OPENAI_API_KEY",
|
|
60
|
+
azureOpenAIApiKey: "AZURE_OPENAI_API_KEY",
|
|
61
|
+
organization: "OPENAI_ORGANIZATION",
|
|
62
|
+
};
|
|
63
|
+
}
|
|
64
|
+
get lc_aliases() {
|
|
65
|
+
return {
|
|
66
|
+
modelName: "model",
|
|
67
|
+
openAIApiKey: "openai_api_key",
|
|
68
|
+
azureOpenAIApiVersion: "azure_openai_api_version",
|
|
69
|
+
azureOpenAIApiKey: "azure_openai_api_key",
|
|
70
|
+
azureOpenAIApiInstanceName: "azure_openai_api_instance_name",
|
|
71
|
+
azureOpenAIApiDeploymentName: "azure_openai_api_deployment_name",
|
|
72
|
+
};
|
|
73
|
+
}
|
|
74
|
+
constructor(fields,
|
|
75
|
+
/** @deprecated */
|
|
76
|
+
configuration) {
|
|
77
|
+
super(fields ?? {});
|
|
78
|
+
Object.defineProperty(this, "lc_serializable", {
|
|
79
|
+
enumerable: true,
|
|
80
|
+
configurable: true,
|
|
81
|
+
writable: true,
|
|
82
|
+
value: true
|
|
83
|
+
});
|
|
84
|
+
Object.defineProperty(this, "temperature", {
|
|
85
|
+
enumerable: true,
|
|
86
|
+
configurable: true,
|
|
87
|
+
writable: true,
|
|
88
|
+
value: 1
|
|
89
|
+
});
|
|
90
|
+
Object.defineProperty(this, "topP", {
|
|
91
|
+
enumerable: true,
|
|
92
|
+
configurable: true,
|
|
93
|
+
writable: true,
|
|
94
|
+
value: 1
|
|
95
|
+
});
|
|
96
|
+
Object.defineProperty(this, "frequencyPenalty", {
|
|
97
|
+
enumerable: true,
|
|
98
|
+
configurable: true,
|
|
99
|
+
writable: true,
|
|
100
|
+
value: 0
|
|
101
|
+
});
|
|
102
|
+
Object.defineProperty(this, "presencePenalty", {
|
|
103
|
+
enumerable: true,
|
|
104
|
+
configurable: true,
|
|
105
|
+
writable: true,
|
|
106
|
+
value: 0
|
|
107
|
+
});
|
|
108
|
+
Object.defineProperty(this, "n", {
|
|
109
|
+
enumerable: true,
|
|
110
|
+
configurable: true,
|
|
111
|
+
writable: true,
|
|
112
|
+
value: 1
|
|
113
|
+
});
|
|
114
|
+
Object.defineProperty(this, "logitBias", {
|
|
115
|
+
enumerable: true,
|
|
116
|
+
configurable: true,
|
|
117
|
+
writable: true,
|
|
118
|
+
value: void 0
|
|
119
|
+
});
|
|
120
|
+
Object.defineProperty(this, "maxTokens", {
|
|
121
|
+
enumerable: true,
|
|
122
|
+
configurable: true,
|
|
123
|
+
writable: true,
|
|
124
|
+
value: void 0
|
|
125
|
+
});
|
|
126
|
+
Object.defineProperty(this, "modelName", {
|
|
127
|
+
enumerable: true,
|
|
128
|
+
configurable: true,
|
|
129
|
+
writable: true,
|
|
130
|
+
value: "gpt-3.5-turbo"
|
|
131
|
+
});
|
|
132
|
+
Object.defineProperty(this, "prefixMessages", {
|
|
133
|
+
enumerable: true,
|
|
134
|
+
configurable: true,
|
|
135
|
+
writable: true,
|
|
136
|
+
value: void 0
|
|
137
|
+
});
|
|
138
|
+
Object.defineProperty(this, "modelKwargs", {
|
|
139
|
+
enumerable: true,
|
|
140
|
+
configurable: true,
|
|
141
|
+
writable: true,
|
|
142
|
+
value: void 0
|
|
143
|
+
});
|
|
144
|
+
Object.defineProperty(this, "timeout", {
|
|
145
|
+
enumerable: true,
|
|
146
|
+
configurable: true,
|
|
147
|
+
writable: true,
|
|
148
|
+
value: void 0
|
|
149
|
+
});
|
|
150
|
+
Object.defineProperty(this, "stop", {
|
|
151
|
+
enumerable: true,
|
|
152
|
+
configurable: true,
|
|
153
|
+
writable: true,
|
|
154
|
+
value: void 0
|
|
155
|
+
});
|
|
156
|
+
Object.defineProperty(this, "user", {
|
|
157
|
+
enumerable: true,
|
|
158
|
+
configurable: true,
|
|
159
|
+
writable: true,
|
|
160
|
+
value: void 0
|
|
161
|
+
});
|
|
162
|
+
Object.defineProperty(this, "streaming", {
|
|
163
|
+
enumerable: true,
|
|
164
|
+
configurable: true,
|
|
165
|
+
writable: true,
|
|
166
|
+
value: false
|
|
167
|
+
});
|
|
168
|
+
Object.defineProperty(this, "openAIApiKey", {
|
|
169
|
+
enumerable: true,
|
|
170
|
+
configurable: true,
|
|
171
|
+
writable: true,
|
|
172
|
+
value: void 0
|
|
173
|
+
});
|
|
174
|
+
Object.defineProperty(this, "azureOpenAIApiVersion", {
|
|
175
|
+
enumerable: true,
|
|
176
|
+
configurable: true,
|
|
177
|
+
writable: true,
|
|
178
|
+
value: void 0
|
|
179
|
+
});
|
|
180
|
+
Object.defineProperty(this, "azureOpenAIApiKey", {
|
|
181
|
+
enumerable: true,
|
|
182
|
+
configurable: true,
|
|
183
|
+
writable: true,
|
|
184
|
+
value: void 0
|
|
185
|
+
});
|
|
186
|
+
Object.defineProperty(this, "azureOpenAIApiInstanceName", {
|
|
187
|
+
enumerable: true,
|
|
188
|
+
configurable: true,
|
|
189
|
+
writable: true,
|
|
190
|
+
value: void 0
|
|
191
|
+
});
|
|
192
|
+
Object.defineProperty(this, "azureOpenAIApiDeploymentName", {
|
|
193
|
+
enumerable: true,
|
|
194
|
+
configurable: true,
|
|
195
|
+
writable: true,
|
|
196
|
+
value: void 0
|
|
197
|
+
});
|
|
198
|
+
Object.defineProperty(this, "azureOpenAIBasePath", {
|
|
199
|
+
enumerable: true,
|
|
200
|
+
configurable: true,
|
|
201
|
+
writable: true,
|
|
202
|
+
value: void 0
|
|
203
|
+
});
|
|
204
|
+
Object.defineProperty(this, "organization", {
|
|
205
|
+
enumerable: true,
|
|
206
|
+
configurable: true,
|
|
207
|
+
writable: true,
|
|
208
|
+
value: void 0
|
|
209
|
+
});
|
|
210
|
+
Object.defineProperty(this, "client", {
|
|
211
|
+
enumerable: true,
|
|
212
|
+
configurable: true,
|
|
213
|
+
writable: true,
|
|
214
|
+
value: void 0
|
|
215
|
+
});
|
|
216
|
+
Object.defineProperty(this, "clientConfig", {
|
|
217
|
+
enumerable: true,
|
|
218
|
+
configurable: true,
|
|
219
|
+
writable: true,
|
|
220
|
+
value: void 0
|
|
221
|
+
});
|
|
222
|
+
this.openAIApiKey =
|
|
223
|
+
fields?.openAIApiKey ?? (0, env_js_1.getEnvironmentVariable)("OPENAI_API_KEY");
|
|
224
|
+
this.azureOpenAIApiKey =
|
|
225
|
+
fields?.azureOpenAIApiKey ??
|
|
226
|
+
(0, env_js_1.getEnvironmentVariable)("AZURE_OPENAI_API_KEY");
|
|
227
|
+
if (!this.azureOpenAIApiKey && !this.openAIApiKey) {
|
|
228
|
+
throw new Error("OpenAI or Azure OpenAI API key not found");
|
|
229
|
+
}
|
|
230
|
+
this.azureOpenAIApiInstanceName =
|
|
231
|
+
fields?.azureOpenAIApiInstanceName ??
|
|
232
|
+
(0, env_js_1.getEnvironmentVariable)("AZURE_OPENAI_API_INSTANCE_NAME");
|
|
233
|
+
this.azureOpenAIApiDeploymentName =
|
|
234
|
+
(fields?.azureOpenAIApiCompletionsDeploymentName ||
|
|
235
|
+
fields?.azureOpenAIApiDeploymentName) ??
|
|
236
|
+
((0, env_js_1.getEnvironmentVariable)("AZURE_OPENAI_API_COMPLETIONS_DEPLOYMENT_NAME") ||
|
|
237
|
+
(0, env_js_1.getEnvironmentVariable)("AZURE_OPENAI_API_DEPLOYMENT_NAME"));
|
|
238
|
+
this.azureOpenAIApiVersion =
|
|
239
|
+
fields?.azureOpenAIApiVersion ??
|
|
240
|
+
(0, env_js_1.getEnvironmentVariable)("AZURE_OPENAI_API_VERSION");
|
|
241
|
+
this.azureOpenAIBasePath =
|
|
242
|
+
fields?.azureOpenAIBasePath ??
|
|
243
|
+
(0, env_js_1.getEnvironmentVariable)("AZURE_OPENAI_BASE_PATH");
|
|
244
|
+
this.organization =
|
|
245
|
+
fields?.configuration?.organization ??
|
|
246
|
+
(0, env_js_1.getEnvironmentVariable)("OPENAI_ORGANIZATION");
|
|
247
|
+
this.modelName = fields?.modelName ?? this.modelName;
|
|
248
|
+
this.prefixMessages = fields?.prefixMessages ?? this.prefixMessages;
|
|
249
|
+
this.modelKwargs = fields?.modelKwargs ?? {};
|
|
250
|
+
this.timeout = fields?.timeout;
|
|
251
|
+
this.temperature = fields?.temperature ?? this.temperature;
|
|
252
|
+
this.topP = fields?.topP ?? this.topP;
|
|
253
|
+
this.frequencyPenalty = fields?.frequencyPenalty ?? this.frequencyPenalty;
|
|
254
|
+
this.presencePenalty = fields?.presencePenalty ?? this.presencePenalty;
|
|
255
|
+
this.n = fields?.n ?? this.n;
|
|
256
|
+
this.logitBias = fields?.logitBias;
|
|
257
|
+
this.maxTokens = fields?.maxTokens;
|
|
258
|
+
this.stop = fields?.stop;
|
|
259
|
+
this.user = fields?.user;
|
|
260
|
+
this.streaming = fields?.streaming ?? false;
|
|
261
|
+
if (this.n > 1) {
|
|
262
|
+
throw new Error("Cannot use n > 1 in OpenAIChat LLM. Use ChatOpenAI Chat Model instead.");
|
|
263
|
+
}
|
|
264
|
+
if (this.azureOpenAIApiKey) {
|
|
265
|
+
if (!this.azureOpenAIApiInstanceName && !this.azureOpenAIBasePath) {
|
|
266
|
+
throw new Error("Azure OpenAI API instance name not found");
|
|
267
|
+
}
|
|
268
|
+
if (!this.azureOpenAIApiDeploymentName) {
|
|
269
|
+
throw new Error("Azure OpenAI API deployment name not found");
|
|
270
|
+
}
|
|
271
|
+
if (!this.azureOpenAIApiVersion) {
|
|
272
|
+
throw new Error("Azure OpenAI API version not found");
|
|
273
|
+
}
|
|
274
|
+
this.openAIApiKey = this.openAIApiKey ?? "";
|
|
275
|
+
}
|
|
276
|
+
this.clientConfig = {
|
|
277
|
+
apiKey: this.openAIApiKey,
|
|
278
|
+
organization: this.organization,
|
|
279
|
+
baseURL: configuration?.basePath ?? fields?.configuration?.basePath,
|
|
280
|
+
dangerouslyAllowBrowser: true,
|
|
281
|
+
defaultHeaders: configuration?.baseOptions?.headers ??
|
|
282
|
+
fields?.configuration?.baseOptions?.headers,
|
|
283
|
+
defaultQuery: configuration?.baseOptions?.params ??
|
|
284
|
+
fields?.configuration?.baseOptions?.params,
|
|
285
|
+
...configuration,
|
|
286
|
+
...fields?.configuration,
|
|
287
|
+
};
|
|
288
|
+
}
|
|
289
|
+
/**
|
|
290
|
+
* Get the parameters used to invoke the model
|
|
291
|
+
*/
|
|
292
|
+
invocationParams(options) {
|
|
293
|
+
return {
|
|
294
|
+
model: this.modelName,
|
|
295
|
+
temperature: this.temperature,
|
|
296
|
+
top_p: this.topP,
|
|
297
|
+
frequency_penalty: this.frequencyPenalty,
|
|
298
|
+
presence_penalty: this.presencePenalty,
|
|
299
|
+
n: this.n,
|
|
300
|
+
logit_bias: this.logitBias,
|
|
301
|
+
max_tokens: this.maxTokens === -1 ? undefined : this.maxTokens,
|
|
302
|
+
stop: options?.stop ?? this.stop,
|
|
303
|
+
user: this.user,
|
|
304
|
+
stream: this.streaming,
|
|
305
|
+
...this.modelKwargs,
|
|
306
|
+
};
|
|
307
|
+
}
|
|
308
|
+
/** @ignore */
|
|
309
|
+
_identifyingParams() {
|
|
310
|
+
return {
|
|
311
|
+
model_name: this.modelName,
|
|
312
|
+
...this.invocationParams(),
|
|
313
|
+
...this.clientConfig,
|
|
314
|
+
};
|
|
315
|
+
}
|
|
316
|
+
/**
|
|
317
|
+
* Get the identifying parameters for the model
|
|
318
|
+
*/
|
|
319
|
+
identifyingParams() {
|
|
320
|
+
return {
|
|
321
|
+
model_name: this.modelName,
|
|
322
|
+
...this.invocationParams(),
|
|
323
|
+
...this.clientConfig,
|
|
324
|
+
};
|
|
325
|
+
}
|
|
326
|
+
/**
|
|
327
|
+
* Formats the messages for the OpenAI API.
|
|
328
|
+
* @param prompt The prompt to be formatted.
|
|
329
|
+
* @returns Array of formatted messages.
|
|
330
|
+
*/
|
|
331
|
+
formatMessages(prompt) {
|
|
332
|
+
const message = {
|
|
333
|
+
role: "user",
|
|
334
|
+
content: prompt,
|
|
335
|
+
};
|
|
336
|
+
return this.prefixMessages ? [...this.prefixMessages, message] : [message];
|
|
337
|
+
}
|
|
338
|
+
async *_streamResponseChunks(prompt, options, runManager) {
|
|
339
|
+
const params = {
|
|
340
|
+
...this.invocationParams(options),
|
|
341
|
+
messages: this.formatMessages(prompt),
|
|
342
|
+
stream: true,
|
|
343
|
+
};
|
|
344
|
+
const stream = await this.completionWithRetry(params, options);
|
|
345
|
+
for await (const data of stream) {
|
|
346
|
+
const choice = data?.choices[0];
|
|
347
|
+
if (!choice) {
|
|
348
|
+
continue;
|
|
349
|
+
}
|
|
350
|
+
const { delta } = choice;
|
|
351
|
+
const generationChunk = new index_js_1.GenerationChunk({
|
|
352
|
+
text: delta.content ?? "",
|
|
353
|
+
});
|
|
354
|
+
yield generationChunk;
|
|
355
|
+
const newTokenIndices = {
|
|
356
|
+
prompt: options.promptIndex ?? 0,
|
|
357
|
+
completion: choice.index ?? 0,
|
|
358
|
+
};
|
|
359
|
+
// eslint-disable-next-line no-void
|
|
360
|
+
void runManager?.handleLLMNewToken(generationChunk.text ?? "", newTokenIndices);
|
|
361
|
+
}
|
|
362
|
+
if (options.signal?.aborted) {
|
|
363
|
+
throw new Error("AbortError");
|
|
364
|
+
}
|
|
365
|
+
}
|
|
366
|
+
/** @ignore */
|
|
367
|
+
async _call(prompt, options, runManager) {
|
|
368
|
+
const params = this.invocationParams(options);
|
|
369
|
+
if (params.stream) {
|
|
370
|
+
const stream = await this._streamResponseChunks(prompt, options, runManager);
|
|
371
|
+
let finalChunk;
|
|
372
|
+
for await (const chunk of stream) {
|
|
373
|
+
if (finalChunk === undefined) {
|
|
374
|
+
finalChunk = chunk;
|
|
375
|
+
}
|
|
376
|
+
else {
|
|
377
|
+
finalChunk = finalChunk.concat(chunk);
|
|
378
|
+
}
|
|
379
|
+
}
|
|
380
|
+
return finalChunk?.text ?? "";
|
|
381
|
+
}
|
|
382
|
+
else {
|
|
383
|
+
const response = await this.completionWithRetry({
|
|
384
|
+
...params,
|
|
385
|
+
stream: false,
|
|
386
|
+
messages: this.formatMessages(prompt),
|
|
387
|
+
}, {
|
|
388
|
+
signal: options.signal,
|
|
389
|
+
...options.options,
|
|
390
|
+
});
|
|
391
|
+
return response?.choices[0]?.message?.content ?? "";
|
|
392
|
+
}
|
|
393
|
+
}
|
|
394
|
+
async completionWithRetry(request, options) {
|
|
395
|
+
const requestOptions = this._getClientOptions(options);
|
|
396
|
+
return this.caller.call(async () => {
|
|
397
|
+
try {
|
|
398
|
+
const res = await this.client.chat.completions.create(request, requestOptions);
|
|
399
|
+
return res;
|
|
400
|
+
}
|
|
401
|
+
catch (e) {
|
|
402
|
+
const error = (0, openai_js_1.wrapOpenAIClientError)(e);
|
|
403
|
+
throw error;
|
|
404
|
+
}
|
|
405
|
+
});
|
|
406
|
+
}
|
|
407
|
+
/** @ignore */
|
|
408
|
+
_getClientOptions(options) {
|
|
409
|
+
if (!this.client) {
|
|
410
|
+
const openAIEndpointConfig = {
|
|
411
|
+
azureOpenAIApiDeploymentName: this.azureOpenAIApiDeploymentName,
|
|
412
|
+
azureOpenAIApiInstanceName: this.azureOpenAIApiInstanceName,
|
|
413
|
+
azureOpenAIApiKey: this.azureOpenAIApiKey,
|
|
414
|
+
azureOpenAIBasePath: this.azureOpenAIBasePath,
|
|
415
|
+
baseURL: this.clientConfig.baseURL,
|
|
416
|
+
};
|
|
417
|
+
const endpoint = (0, azure_js_1.getEndpoint)(openAIEndpointConfig);
|
|
418
|
+
const params = {
|
|
419
|
+
...this.clientConfig,
|
|
420
|
+
baseURL: endpoint,
|
|
421
|
+
timeout: this.timeout,
|
|
422
|
+
maxRetries: 0,
|
|
423
|
+
};
|
|
424
|
+
if (!params.baseURL) {
|
|
425
|
+
delete params.baseURL;
|
|
426
|
+
}
|
|
427
|
+
this.client = new openai_1.OpenAI(params);
|
|
428
|
+
}
|
|
429
|
+
const requestOptions = {
|
|
430
|
+
...this.clientConfig,
|
|
431
|
+
...options,
|
|
432
|
+
};
|
|
433
|
+
if (this.azureOpenAIApiKey) {
|
|
434
|
+
requestOptions.headers = {
|
|
435
|
+
"api-key": this.azureOpenAIApiKey,
|
|
436
|
+
...requestOptions.headers,
|
|
437
|
+
};
|
|
438
|
+
requestOptions.query = {
|
|
439
|
+
"api-version": this.azureOpenAIApiVersion,
|
|
440
|
+
...requestOptions.query,
|
|
441
|
+
};
|
|
442
|
+
}
|
|
443
|
+
return requestOptions;
|
|
444
|
+
}
|
|
445
|
+
_llmType() {
|
|
446
|
+
return "openai";
|
|
447
|
+
}
|
|
448
|
+
}
|
|
449
|
+
exports.OpenAIChat = OpenAIChat;
|
|
8
450
|
/**
|
|
9
451
|
* PromptLayer wrapper to OpenAIChat
|
|
10
452
|
*/
|
|
11
|
-
class PromptLayerOpenAIChat extends
|
|
453
|
+
class PromptLayerOpenAIChat extends OpenAIChat {
|
|
12
454
|
get lc_secrets() {
|
|
13
455
|
return {
|
|
14
456
|
promptLayerApiKey: "PROMPTLAYER_API_KEY",
|
|
@@ -1,8 +1,127 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { type ClientOptions, OpenAI as OpenAIClient } from "openai";
|
|
2
2
|
import { CallbackManagerForLLMRun } from "../callbacks/manager.js";
|
|
3
|
-
import
|
|
4
|
-
|
|
5
|
-
|
|
3
|
+
import { GenerationChunk, LLMResult } from "../schema/index.js";
|
|
4
|
+
import { AzureOpenAIInput, OpenAICallOptions, OpenAIChatInput, OpenAICoreRequestOptions, LegacyOpenAIInput } from "../types/openai-types.js";
|
|
5
|
+
import { BaseLLMParams, LLM } from "./base.js";
|
|
6
|
+
export { type AzureOpenAIInput, type OpenAIChatInput };
|
|
7
|
+
/**
|
|
8
|
+
* Interface that extends the OpenAICallOptions interface and includes an
|
|
9
|
+
* optional promptIndex property. It represents the options that can be
|
|
10
|
+
* passed when making a call to the OpenAI Chat API.
|
|
11
|
+
*/
|
|
12
|
+
export interface OpenAIChatCallOptions extends OpenAICallOptions {
|
|
13
|
+
promptIndex?: number;
|
|
14
|
+
}
|
|
15
|
+
/**
|
|
16
|
+
* Wrapper around OpenAI large language models that use the Chat endpoint.
|
|
17
|
+
*
|
|
18
|
+
* To use you should have the `openai` package installed, with the
|
|
19
|
+
* `OPENAI_API_KEY` environment variable set.
|
|
20
|
+
*
|
|
21
|
+
* To use with Azure you should have the `openai` package installed, with the
|
|
22
|
+
* `AZURE_OPENAI_API_KEY`,
|
|
23
|
+
* `AZURE_OPENAI_API_INSTANCE_NAME`,
|
|
24
|
+
* `AZURE_OPENAI_API_DEPLOYMENT_NAME`
|
|
25
|
+
* and `AZURE_OPENAI_API_VERSION` environment variable set.
|
|
26
|
+
*
|
|
27
|
+
* @remarks
|
|
28
|
+
* Any parameters that are valid to be passed to {@link
|
|
29
|
+
* https://platform.openai.com/docs/api-reference/chat/create |
|
|
30
|
+
* `openai.createCompletion`} can be passed through {@link modelKwargs}, even
|
|
31
|
+
* if not explicitly available on this class.
|
|
32
|
+
*
|
|
33
|
+
* @augments BaseLLM
|
|
34
|
+
* @augments OpenAIInput
|
|
35
|
+
* @augments AzureOpenAIChatInput
|
|
36
|
+
* @example
|
|
37
|
+
* ```typescript
|
|
38
|
+
* const model = new OpenAIChat({
|
|
39
|
+
* prefixMessages: [
|
|
40
|
+
* {
|
|
41
|
+
* role: "system",
|
|
42
|
+
* content: "You are a helpful assistant that answers in pirate language",
|
|
43
|
+
* },
|
|
44
|
+
* ],
|
|
45
|
+
* maxTokens: 50,
|
|
46
|
+
* });
|
|
47
|
+
*
|
|
48
|
+
* const res = await model.call(
|
|
49
|
+
* "What would be a good company name for a company that makes colorful socks?"
|
|
50
|
+
* );
|
|
51
|
+
* console.log({ res });
|
|
52
|
+
* ```
|
|
53
|
+
*/
|
|
54
|
+
export declare class OpenAIChat extends LLM<OpenAIChatCallOptions> implements OpenAIChatInput, AzureOpenAIInput {
|
|
55
|
+
static lc_name(): string;
|
|
56
|
+
get callKeys(): string[];
|
|
57
|
+
lc_serializable: boolean;
|
|
58
|
+
get lc_secrets(): {
|
|
59
|
+
[key: string]: string;
|
|
60
|
+
} | undefined;
|
|
61
|
+
get lc_aliases(): Record<string, string>;
|
|
62
|
+
temperature: number;
|
|
63
|
+
topP: number;
|
|
64
|
+
frequencyPenalty: number;
|
|
65
|
+
presencePenalty: number;
|
|
66
|
+
n: number;
|
|
67
|
+
logitBias?: Record<string, number>;
|
|
68
|
+
maxTokens?: number;
|
|
69
|
+
modelName: string;
|
|
70
|
+
prefixMessages?: OpenAIClient.Chat.ChatCompletionMessageParam[];
|
|
71
|
+
modelKwargs?: OpenAIChatInput["modelKwargs"];
|
|
72
|
+
timeout?: number;
|
|
73
|
+
stop?: string[];
|
|
74
|
+
user?: string;
|
|
75
|
+
streaming: boolean;
|
|
76
|
+
openAIApiKey?: string;
|
|
77
|
+
azureOpenAIApiVersion?: string;
|
|
78
|
+
azureOpenAIApiKey?: string;
|
|
79
|
+
azureOpenAIApiInstanceName?: string;
|
|
80
|
+
azureOpenAIApiDeploymentName?: string;
|
|
81
|
+
azureOpenAIBasePath?: string;
|
|
82
|
+
organization?: string;
|
|
83
|
+
private client;
|
|
84
|
+
private clientConfig;
|
|
85
|
+
constructor(fields?: Partial<OpenAIChatInput> & Partial<AzureOpenAIInput> & BaseLLMParams & {
|
|
86
|
+
configuration?: ClientOptions & LegacyOpenAIInput;
|
|
87
|
+
},
|
|
88
|
+
/** @deprecated */
|
|
89
|
+
configuration?: ClientOptions & LegacyOpenAIInput);
|
|
90
|
+
/**
|
|
91
|
+
* Get the parameters used to invoke the model
|
|
92
|
+
*/
|
|
93
|
+
invocationParams(options?: this["ParsedCallOptions"]): Omit<OpenAIClient.Chat.ChatCompletionCreateParams, "messages">;
|
|
94
|
+
/** @ignore */
|
|
95
|
+
_identifyingParams(): Omit<OpenAIClient.Chat.ChatCompletionCreateParams, "messages"> & {
|
|
96
|
+
model_name: string;
|
|
97
|
+
} & ClientOptions;
|
|
98
|
+
/**
|
|
99
|
+
* Get the identifying parameters for the model
|
|
100
|
+
*/
|
|
101
|
+
identifyingParams(): Omit<OpenAIClient.Chat.ChatCompletionCreateParams, "messages"> & {
|
|
102
|
+
model_name: string;
|
|
103
|
+
} & ClientOptions;
|
|
104
|
+
/**
|
|
105
|
+
* Formats the messages for the OpenAI API.
|
|
106
|
+
* @param prompt The prompt to be formatted.
|
|
107
|
+
* @returns Array of formatted messages.
|
|
108
|
+
*/
|
|
109
|
+
private formatMessages;
|
|
110
|
+
_streamResponseChunks(prompt: string, options: this["ParsedCallOptions"], runManager?: CallbackManagerForLLMRun): AsyncGenerator<GenerationChunk>;
|
|
111
|
+
/** @ignore */
|
|
112
|
+
_call(prompt: string, options: this["ParsedCallOptions"], runManager?: CallbackManagerForLLMRun): Promise<string>;
|
|
113
|
+
/**
|
|
114
|
+
* Calls the OpenAI API with retry logic in case of failures.
|
|
115
|
+
* @param request The request to send to the OpenAI API.
|
|
116
|
+
* @param options Optional configuration for the API call.
|
|
117
|
+
* @returns The response from the OpenAI API.
|
|
118
|
+
*/
|
|
119
|
+
completionWithRetry(request: OpenAIClient.Chat.ChatCompletionCreateParamsStreaming, options?: OpenAICoreRequestOptions): Promise<AsyncIterable<OpenAIClient.Chat.Completions.ChatCompletionChunk>>;
|
|
120
|
+
completionWithRetry(request: OpenAIClient.Chat.ChatCompletionCreateParamsNonStreaming, options?: OpenAICoreRequestOptions): Promise<OpenAIClient.Chat.Completions.ChatCompletion>;
|
|
121
|
+
/** @ignore */
|
|
122
|
+
private _getClientOptions;
|
|
123
|
+
_llmType(): string;
|
|
124
|
+
}
|
|
6
125
|
/**
|
|
7
126
|
* PromptLayer wrapper to OpenAIChat
|
|
8
127
|
*/
|