dtamind-components
Version:
Apps integration for Dtamind. Contain Nodes and Credentials.
282 lines • 10.3 kB
JavaScript
;
Object.defineProperty(exports, "__esModule", { value: true });
const openai_1 = require("@langchain/openai");
const utils_1 = require("../../../src/utils");
const DtamindChatOpenAI_1 = require("./DtamindChatOpenAI");
const modelLoader_1 = require("../../../src/modelLoader");
const https_proxy_agent_1 = require("https-proxy-agent");
class ChatOpenAI_ChatModels {
constructor() {
//@ts-ignore
this.loadMethods = {
async listModels() {
return await (0, modelLoader_1.getModels)(modelLoader_1.MODEL_TYPE.CHAT, 'chatOpenAI');
}
};
this.label = 'ChatOpenAI';
this.name = 'chatOpenAI';
this.version = 8.2;
this.type = 'ChatOpenAI';
this.icon = 'openai.svg';
this.category = 'Chat Models';
this.description = 'Wrapper around OpenAI large language models that use the Chat endpoint';
this.baseClasses = [this.type, ...(0, utils_1.getBaseClasses)(openai_1.ChatOpenAI)];
this.credential = {
label: 'Connect Credential',
name: 'credential',
type: 'credential',
credentialNames: ['openAIApi']
};
this.inputs = [
{
label: 'Cache',
name: 'cache',
type: 'BaseCache',
optional: true
},
{
label: 'Model Name',
name: 'modelName',
type: 'asyncOptions',
loadMethod: 'listModels',
default: 'gpt-4o-mini'
},
{
label: 'Temperature',
name: 'temperature',
type: 'number',
step: 0.1,
default: 0.9,
optional: true
},
{
label: 'Streaming',
name: 'streaming',
type: 'boolean',
default: true,
optional: true,
additionalParams: true
},
{
label: 'Max Tokens',
name: 'maxTokens',
type: 'number',
step: 1,
optional: true,
additionalParams: true
},
{
label: 'Top Probability',
name: 'topP',
type: 'number',
step: 0.1,
optional: true,
additionalParams: true
},
{
label: 'Frequency Penalty',
name: 'frequencyPenalty',
type: 'number',
step: 0.1,
optional: true,
additionalParams: true
},
{
label: 'Presence Penalty',
name: 'presencePenalty',
type: 'number',
step: 0.1,
optional: true,
additionalParams: true
},
{
label: 'Timeout',
name: 'timeout',
type: 'number',
step: 1,
optional: true,
additionalParams: true
},
{
label: 'Strict Tool Calling',
name: 'strictToolCalling',
type: 'boolean',
description: 'Whether the model supports the `strict` argument when passing in tools. If not specified, the `strict` argument will not be passed to OpenAI.',
optional: true,
additionalParams: true
},
{
label: 'Stop Sequence',
name: 'stopSequence',
type: 'string',
rows: 4,
optional: true,
description: 'List of stop words to use when generating. Use comma to separate multiple stop words.',
additionalParams: true
},
{
label: 'BasePath',
name: 'basepath',
type: 'string',
optional: true,
additionalParams: true
},
{
label: 'Proxy Url',
name: 'proxyUrl',
type: 'string',
optional: true,
additionalParams: true
},
{
label: 'BaseOptions',
name: 'baseOptions',
type: 'json',
optional: true,
additionalParams: true
},
{
label: 'Allow Image Uploads',
name: 'allowImageUploads',
type: 'boolean',
description: 'Allow image input. Refer to the <a href="https://docs.dtamindai.com/using-dtamind/uploads#image" target="_blank">docs</a> for more details.',
default: false,
optional: true
},
{
label: 'Image Resolution',
description: 'This parameter controls the resolution in which the model views the image.',
name: 'imageResolution',
type: 'options',
options: [
{
label: 'Low',
name: 'low'
},
{
label: 'High',
name: 'high'
},
{
label: 'Auto',
name: 'auto'
}
],
default: 'low',
optional: false,
show: {
allowImageUploads: true
}
},
{
label: 'Reasoning Effort',
description: 'Constrains effort on reasoning for reasoning models. Only applicable for o1 and o3 models.',
name: 'reasoningEffort',
type: 'options',
options: [
{
label: 'Low',
name: 'low'
},
{
label: 'Medium',
name: 'medium'
},
{
label: 'High',
name: 'high'
}
],
default: 'medium',
optional: false,
additionalParams: true
}
];
}
async init(nodeData, _, options) {
const temperature = nodeData.inputs?.temperature;
const modelName = nodeData.inputs?.modelName;
const maxTokens = nodeData.inputs?.maxTokens;
const topP = nodeData.inputs?.topP;
const frequencyPenalty = nodeData.inputs?.frequencyPenalty;
const presencePenalty = nodeData.inputs?.presencePenalty;
const timeout = nodeData.inputs?.timeout;
const stopSequence = nodeData.inputs?.stopSequence;
const streaming = nodeData.inputs?.streaming;
const strictToolCalling = nodeData.inputs?.strictToolCalling;
const basePath = nodeData.inputs?.basepath;
const proxyUrl = nodeData.inputs?.proxyUrl;
const baseOptions = nodeData.inputs?.baseOptions;
const reasoningEffort = nodeData.inputs?.reasoningEffort;
const allowImageUploads = nodeData.inputs?.allowImageUploads;
const imageResolution = nodeData.inputs?.imageResolution;
if (nodeData.inputs?.credentialId) {
nodeData.credential = nodeData.inputs?.credentialId;
}
const credentialData = await (0, utils_1.getCredentialData)(nodeData.credential ?? '', options);
const openAIApiKey = (0, utils_1.getCredentialParam)('openAIApiKey', credentialData, nodeData);
const cache = nodeData.inputs?.cache;
const obj = {
temperature: parseFloat(temperature),
modelName,
openAIApiKey,
streaming: streaming ?? true
};
if (modelName.includes('o3') || modelName.includes('o1')) {
delete obj.temperature;
}
if ((modelName.includes('o1') || modelName.includes('o3')) && reasoningEffort) {
obj.reasoningEffort = reasoningEffort;
}
if (maxTokens)
obj.maxTokens = parseInt(maxTokens, 10);
if (topP)
obj.topP = parseFloat(topP);
if (frequencyPenalty)
obj.frequencyPenalty = parseFloat(frequencyPenalty);
if (presencePenalty)
obj.presencePenalty = parseFloat(presencePenalty);
if (timeout)
obj.timeout = parseInt(timeout, 10);
if (cache)
obj.cache = cache;
if (stopSequence) {
const stopSequenceArray = stopSequence.split(',').map((item) => item.trim());
obj.stop = stopSequenceArray;
}
if (strictToolCalling)
obj.supportsStrictToolCalling = strictToolCalling;
let parsedBaseOptions = undefined;
if (baseOptions) {
try {
parsedBaseOptions = typeof baseOptions === 'object' ? baseOptions : JSON.parse(baseOptions);
}
catch (exception) {
throw new Error("Invalid JSON in the ChatOpenAI's BaseOptions: " + exception);
}
}
if (basePath || parsedBaseOptions) {
obj.configuration = {
baseURL: basePath,
defaultHeaders: parsedBaseOptions
};
}
if (proxyUrl) {
obj.configuration = {
...obj?.configuration,
httpAgent: new https_proxy_agent_1.HttpsProxyAgent(proxyUrl)
};
}
const multiModalOption = {
image: {
allowImageUploads: allowImageUploads ?? false,
imageResolution
}
};
const model = new DtamindChatOpenAI_1.ChatOpenAI(nodeData.id, obj);
model.setMultiModalOption(multiModalOption);
return model;
}
}
module.exports = { nodeClass: ChatOpenAI_ChatModels };
//# sourceMappingURL=ChatOpenAI.js.map