78 lines
3.1 KiB
JavaScript
78 lines
3.1 KiB
JavaScript
|
import { AzureOpenAI as AzureOpenAIClient, } from "openai";
|
||
|
import { OpenAIEmbeddings } from "../embeddings.js";
|
||
|
import { getEndpoint } from "../utils/azure.js";
|
||
|
import { wrapOpenAIClientError } from "../utils/openai.js";
|
||
|
export class AzureOpenAIEmbeddings extends OpenAIEmbeddings {
|
||
|
constructor(fields, configuration) {
|
||
|
const newFields = { ...fields };
|
||
|
if (Object.entries(newFields).length) {
|
||
|
// don't rewrite the fields if they are already set
|
||
|
newFields.azureOpenAIApiDeploymentName =
|
||
|
newFields.azureOpenAIApiDeploymentName ?? newFields.deploymentName;
|
||
|
newFields.azureOpenAIApiKey =
|
||
|
newFields.azureOpenAIApiKey ?? newFields.apiKey;
|
||
|
newFields.azureOpenAIApiVersion =
|
||
|
newFields.azureOpenAIApiVersion ?? newFields.openAIApiVersion;
|
||
|
}
|
||
|
super(newFields, configuration);
|
||
|
}
|
||
|
async embeddingWithRetry(request) {
|
||
|
if (!this.client) {
|
||
|
const openAIEndpointConfig = {
|
||
|
azureOpenAIApiDeploymentName: this.azureOpenAIApiDeploymentName,
|
||
|
azureOpenAIApiInstanceName: this.azureOpenAIApiInstanceName,
|
||
|
azureOpenAIApiKey: this.azureOpenAIApiKey,
|
||
|
azureOpenAIBasePath: this.azureOpenAIBasePath,
|
||
|
azureADTokenProvider: this.azureADTokenProvider,
|
||
|
baseURL: this.clientConfig.baseURL,
|
||
|
};
|
||
|
const endpoint = getEndpoint(openAIEndpointConfig);
|
||
|
const params = {
|
||
|
...this.clientConfig,
|
||
|
baseURL: endpoint,
|
||
|
timeout: this.timeout,
|
||
|
maxRetries: 0,
|
||
|
};
|
||
|
if (!this.azureADTokenProvider) {
|
||
|
params.apiKey = openAIEndpointConfig.azureOpenAIApiKey;
|
||
|
}
|
||
|
if (!params.baseURL) {
|
||
|
delete params.baseURL;
|
||
|
}
|
||
|
params.defaultHeaders = {
|
||
|
...params.defaultHeaders,
|
||
|
"User-Agent": params.defaultHeaders?.["User-Agent"]
|
||
|
? `${params.defaultHeaders["User-Agent"]}: langchainjs-azure-openai-v2`
|
||
|
: `langchainjs-azure-openai-v2`,
|
||
|
};
|
||
|
this.client = new AzureOpenAIClient({
|
||
|
apiVersion: this.azureOpenAIApiVersion,
|
||
|
azureADTokenProvider: this.azureADTokenProvider,
|
||
|
deployment: this.azureOpenAIApiDeploymentName,
|
||
|
...params,
|
||
|
});
|
||
|
}
|
||
|
const requestOptions = {};
|
||
|
if (this.azureOpenAIApiKey) {
|
||
|
requestOptions.headers = {
|
||
|
"api-key": this.azureOpenAIApiKey,
|
||
|
...requestOptions.headers,
|
||
|
};
|
||
|
requestOptions.query = {
|
||
|
"api-version": this.azureOpenAIApiVersion,
|
||
|
...requestOptions.query,
|
||
|
};
|
||
|
}
|
||
|
return this.caller.call(async () => {
|
||
|
try {
|
||
|
const res = await this.client.embeddings.create(request, requestOptions);
|
||
|
return res;
|
||
|
}
|
||
|
catch (e) {
|
||
|
const error = wrapOpenAIClientError(e);
|
||
|
throw error;
|
||
|
}
|
||
|
});
|
||
|
}
|
||
|
}
|