n8n-nodes-simple 2.2.15 → 2.4.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.
- package/dist/nodes/CoreAgent/description.js +0 -1
- package/dist/nodes/CoreAgent/description.js.map +1 -1
- package/dist/nodes/ModelOverview/ModelOverview.node.d.ts +10 -0
- package/dist/nodes/ModelOverview/ModelOverview.node.js +220 -0
- package/dist/nodes/ModelOverview/ModelOverview.node.js.map +1 -0
- package/dist/nodes/shared/api/openAiApiRequest.js +1 -10
- package/dist/nodes/shared/api/openAiApiRequest.js.map +1 -1
- package/dist/nodes/shared/config/descriptionGenerator.js +3 -3
- package/dist/nodes/shared/config/descriptionGenerator.js.map +1 -1
- package/dist/nodes/shared/config/properties/output.js +1 -6
- package/dist/nodes/shared/config/properties/output.js.map +1 -1
- package/dist/nodes/shared/core/execution/executor.d.ts +3 -3
- package/dist/nodes/shared/core/execution/executor.js +10 -13
- package/dist/nodes/shared/core/execution/executor.js.map +1 -1
- package/dist/nodes/shared/core/execution/messageOperation.d.ts +1 -1
- package/dist/nodes/shared/core/execution/messageOperation.js +5 -5
- package/dist/nodes/shared/core/execution/messageOperation.js.map +1 -1
- package/dist/nodes/shared/core/execution/outputData.d.ts +1 -2
- package/dist/nodes/shared/core/execution/outputData.js +6 -35
- package/dist/nodes/shared/core/execution/outputData.js.map +1 -1
- package/dist/nodes/shared/core/execution/router.d.ts +1 -1
- package/dist/nodes/shared/core/execution/router.js +6 -6
- package/dist/nodes/shared/core/execution/router.js.map +1 -1
- package/dist/nodes/shared/core/memory/index.d.ts +0 -1
- package/dist/nodes/shared/core/memory/index.js +0 -1
- package/dist/nodes/shared/core/memory/index.js.map +1 -1
- package/dist/nodes/shared/core/memory/io.d.ts +4 -5
- package/dist/nodes/shared/core/memory/io.js +48 -81
- package/dist/nodes/shared/core/memory/io.js.map +1 -1
- package/dist/nodes/shared/core/messages/chatHistory.d.ts +2 -1
- package/dist/nodes/shared/core/messages/chatHistory.js +24 -45
- package/dist/nodes/shared/core/messages/chatHistory.js.map +1 -1
- package/dist/nodes/shared/core/messages/converter.d.ts +0 -2
- package/dist/nodes/shared/core/messages/converter.js +6 -67
- package/dist/nodes/shared/core/messages/converter.js.map +1 -1
- package/dist/nodes/shared/core/messages/processor.d.ts +2 -2
- package/dist/nodes/shared/core/messages/processor.js +2 -54
- package/dist/nodes/shared/core/messages/processor.js.map +1 -1
- package/dist/nodes/shared/core/request/body.js +0 -23
- package/dist/nodes/shared/core/request/body.js.map +1 -1
- package/dist/nodes/shared/core/tools/executor.d.ts +1 -1
- package/dist/nodes/shared/core/tools/executor.js +18 -43
- package/dist/nodes/shared/core/tools/executor.js.map +1 -1
- package/dist/nodes/shared/core/tools/manager.d.ts +0 -2
- package/dist/nodes/shared/core/tools/manager.js +0 -49
- package/dist/nodes/shared/core/tools/manager.js.map +1 -1
- package/dist/nodes/shared/core/tools/messageExtractor.js.map +1 -1
- package/dist/nodes/shared/core/tools/subagentTool.d.ts +0 -11
- package/dist/nodes/shared/core/tools/subagentTool.js +0 -58
- package/dist/nodes/shared/core/tools/subagentTool.js.map +1 -1
- package/dist/package.json +3 -2
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/package.json +3 -2
- package/dist/nodes/Subagent/Subagent.node.d.ts +0 -11
- package/dist/nodes/Subagent/Subagent.node.js +0 -23
- package/dist/nodes/Subagent/Subagent.node.js.map +0 -1
- package/dist/nodes/Subagent/description.d.ts +0 -2
- package/dist/nodes/Subagent/description.js +0 -35
- package/dist/nodes/Subagent/description.js.map +0 -1
- package/dist/nodes/shared/actions/executor.d.ts +0 -7
- package/dist/nodes/shared/actions/executor.js +0 -61
- package/dist/nodes/shared/actions/executor.js.map +0 -1
- package/dist/nodes/shared/actions/memory.d.ts +0 -5
- package/dist/nodes/shared/actions/memory.js +0 -93
- package/dist/nodes/shared/actions/memory.js.map +0 -1
- package/dist/nodes/shared/actions/message.operation.d.ts +0 -2
- package/dist/nodes/shared/actions/message.operation.js +0 -14
- package/dist/nodes/shared/actions/message.operation.js.map +0 -1
- package/dist/nodes/shared/actions/messageProcessor.d.ts +0 -4
- package/dist/nodes/shared/actions/messageProcessor.js +0 -23
- package/dist/nodes/shared/actions/messageProcessor.js.map +0 -1
- package/dist/nodes/shared/actions/outputProcessor.d.ts +0 -5
- package/dist/nodes/shared/actions/outputProcessor.js +0 -112
- package/dist/nodes/shared/actions/outputProcessor.js.map +0 -1
- package/dist/nodes/shared/actions/parameterParser.d.ts +0 -9
- package/dist/nodes/shared/actions/parameterParser.js +0 -96
- package/dist/nodes/shared/actions/parameterParser.js.map +0 -1
- package/dist/nodes/shared/actions/parameters.d.ts +0 -26
- package/dist/nodes/shared/actions/parameters.js +0 -35
- package/dist/nodes/shared/actions/parameters.js.map +0 -1
- package/dist/nodes/shared/actions/requestBuilder.d.ts +0 -2
- package/dist/nodes/shared/actions/requestBuilder.js +0 -38
- package/dist/nodes/shared/actions/requestBuilder.js.map +0 -1
- package/dist/nodes/shared/actions/responseConfig.d.ts +0 -3
- package/dist/nodes/shared/actions/responseConfig.js +0 -26
- package/dist/nodes/shared/actions/responseConfig.js.map +0 -1
- package/dist/nodes/shared/actions/router.d.ts +0 -2
- package/dist/nodes/shared/actions/router.js +0 -117
- package/dist/nodes/shared/actions/router.js.map +0 -1
- package/dist/nodes/shared/actions/tool.d.ts +0 -2
- package/dist/nodes/shared/actions/tool.js +0 -51
- package/dist/nodes/shared/actions/tool.js.map +0 -1
- package/dist/nodes/shared/actions/toolExecutor.d.ts +0 -6
- package/dist/nodes/shared/actions/toolExecutor.js +0 -124
- package/dist/nodes/shared/actions/toolExecutor.js.map +0 -1
- package/dist/nodes/shared/actions/toolSetup.d.ts +0 -8
- package/dist/nodes/shared/actions/toolSetup.js +0 -59
- package/dist/nodes/shared/actions/toolSetup.js.map +0 -1
- package/dist/nodes/shared/config/properties/memory.d.ts +0 -2
- package/dist/nodes/shared/config/properties/memory.js +0 -5
- package/dist/nodes/shared/config/properties/memory.js.map +0 -1
- package/dist/nodes/shared/config/properties/toolParameters.d.ts +0 -2
- package/dist/nodes/shared/config/properties/toolParameters.js +0 -101
- package/dist/nodes/shared/config/properties/toolParameters.js.map +0 -1
- package/dist/nodes/shared/config/properties/tools.d.ts +0 -2
- package/dist/nodes/shared/config/properties/tools.js +0 -5
- package/dist/nodes/shared/config/properties/tools.js.map +0 -1
- package/dist/nodes/shared/config/responseConfig.d.ts +0 -3
- package/dist/nodes/shared/config/responseConfig.js +0 -26
- package/dist/nodes/shared/config/responseConfig.js.map +0 -1
- package/dist/nodes/shared/core/memory/optimizer.d.ts +0 -3
- package/dist/nodes/shared/core/memory/optimizer.js +0 -30
- package/dist/nodes/shared/core/memory/optimizer.js.map +0 -1
- package/dist/nodes/shared/core/memory/properties.d.ts +0 -2
- package/dist/nodes/shared/core/memory/properties.js +0 -5
- package/dist/nodes/shared/core/memory/properties.js.map +0 -1
- package/dist/nodes/shared/core/memory/supplier.d.ts +0 -2
- package/dist/nodes/shared/core/memory/supplier.js +0 -53
- package/dist/nodes/shared/core/memory/supplier.js.map +0 -1
- package/dist/nodes/shared/core/messages/memoryOptimizer.d.ts +0 -3
- package/dist/nodes/shared/core/messages/memoryOptimizer.js +0 -30
- package/dist/nodes/shared/core/messages/memoryOptimizer.js.map +0 -1
- package/dist/nodes/shared/core/messages/toolExtractor.d.ts +0 -6
- package/dist/nodes/shared/core/messages/toolExtractor.js +0 -28
- package/dist/nodes/shared/core/messages/toolExtractor.js.map +0 -1
- package/dist/nodes/shared/core/output/processor.d.ts +0 -5
- package/dist/nodes/shared/core/output/processor.js +0 -108
- package/dist/nodes/shared/core/output/processor.js.map +0 -1
- package/dist/nodes/shared/core/request/builder.d.ts +0 -2
- package/dist/nodes/shared/core/request/builder.js +0 -43
- package/dist/nodes/shared/core/request/builder.js.map +0 -1
- package/dist/nodes/shared/core/response/config.d.ts +0 -3
- package/dist/nodes/shared/core/response/config.js +0 -26
- package/dist/nodes/shared/core/response/config.js.map +0 -1
- package/dist/nodes/shared/core/schema/visualEditor.d.ts +0 -32
- package/dist/nodes/shared/core/schema/visualEditor.js +0 -70
- package/dist/nodes/shared/core/schema/visualEditor.js.map +0 -1
- package/dist/nodes/shared/descriptionGenerator.d.ts +0 -2
- package/dist/nodes/shared/descriptionGenerator.js +0 -36
- package/dist/nodes/shared/descriptionGenerator.js.map +0 -1
- package/dist/nodes/shared/gradientRobot.svg +0 -11
- package/dist/nodes/shared/gradientRobotRed.svg +0 -11
- package/dist/nodes/shared/message/chatHistoryProcessor.d.ts +0 -2
- package/dist/nodes/shared/message/chatHistoryProcessor.js +0 -63
- package/dist/nodes/shared/message/chatHistoryProcessor.js.map +0 -1
- package/dist/nodes/shared/message/memoryOptimizer.d.ts +0 -3
- package/dist/nodes/shared/message/memoryOptimizer.js +0 -30
- package/dist/nodes/shared/message/memoryOptimizer.js.map +0 -1
- package/dist/nodes/shared/message/messageConverter.d.ts +0 -4
- package/dist/nodes/shared/message/messageConverter.js +0 -76
- package/dist/nodes/shared/message/messageConverter.js.map +0 -1
- package/dist/nodes/shared/message/processor.d.ts +0 -3
- package/dist/nodes/shared/message/processor.js +0 -11
- package/dist/nodes/shared/message/processor.js.map +0 -1
- package/dist/nodes/shared/message/toolMessageExtractor.d.ts +0 -6
- package/dist/nodes/shared/message/toolMessageExtractor.js +0 -28
- package/dist/nodes/shared/message/toolMessageExtractor.js.map +0 -1
- package/dist/nodes/shared/message/types.d.ts +0 -48
- package/dist/nodes/shared/message/types.js +0 -12
- package/dist/nodes/shared/message/types.js.map +0 -1
- package/dist/nodes/shared/methods/index.d.ts +0 -1
- package/dist/nodes/shared/methods/index.js +0 -38
- package/dist/nodes/shared/methods/index.js.map +0 -1
- package/dist/nodes/shared/processing/memory.d.ts +0 -5
- package/dist/nodes/shared/processing/memory.js +0 -93
- package/dist/nodes/shared/processing/memory.js.map +0 -1
- package/dist/nodes/shared/processing/outputProcessor.d.ts +0 -5
- package/dist/nodes/shared/processing/outputProcessor.js +0 -108
- package/dist/nodes/shared/processing/outputProcessor.js.map +0 -1
- package/dist/nodes/shared/processing/requestBuilder.d.ts +0 -2
- package/dist/nodes/shared/processing/requestBuilder.js +0 -43
- package/dist/nodes/shared/processing/requestBuilder.js.map +0 -1
- package/dist/nodes/shared/processing/visualEditor.d.ts +0 -32
- package/dist/nodes/shared/processing/visualEditor.js +0 -70
- package/dist/nodes/shared/processing/visualEditor.js.map +0 -1
- package/dist/nodes/shared/properties.d.ts +0 -2
- package/dist/nodes/shared/properties.js +0 -550
- package/dist/nodes/shared/properties.js.map +0 -1
- package/dist/nodes/shared/tool/schemaGenerator.d.ts +0 -6
- package/dist/nodes/shared/tool/schemaGenerator.js +0 -23
- package/dist/nodes/shared/tool/schemaGenerator.js.map +0 -1
- package/dist/nodes/shared/tool/subagentTool.d.ts +0 -11
- package/dist/nodes/shared/tool/subagentTool.js +0 -60
- package/dist/nodes/shared/tool/subagentTool.js.map +0 -1
- package/dist/nodes/shared/tool/visualEditor.d.ts +0 -32
- package/dist/nodes/shared/tool/visualEditor.js +0 -70
- package/dist/nodes/shared/tool/visualEditor.js.map +0 -1
- package/dist/nodes/shared/toolManager/getConnectedTools.d.ts +0 -3
- package/dist/nodes/shared/toolManager/getConnectedTools.js +0 -37
- package/dist/nodes/shared/toolManager/getConnectedTools.js.map +0 -1
- package/dist/nodes/shared/toolManager/n8nTool.d.ts +0 -9
- package/dist/nodes/shared/toolManager/n8nTool.js +0 -91
- package/dist/nodes/shared/toolManager/n8nTool.js.map +0 -1
- package/dist/nodes/shared/utils/descriptionGenerator.d.ts +0 -2
- package/dist/nodes/shared/utils/descriptionGenerator.js +0 -36
- package/dist/nodes/shared/utils/descriptionGenerator.js.map +0 -1
- package/dist/nodes/shared/utils/index.d.ts +0 -1
- package/dist/nodes/shared/utils/index.js +0 -18
- package/dist/nodes/shared/utils/index.js.map +0 -1
- package/dist/nodes/shared/utils/listSearch.d.ts +0 -2
- package/dist/nodes/shared/utils/listSearch.js +0 -34
- package/dist/nodes/shared/utils/listSearch.js.map +0 -1
|
@@ -53,8 +53,8 @@ function initializeRouter(executeFunctions) {
|
|
|
53
53
|
execute: messageOperation.execute,
|
|
54
54
|
};
|
|
55
55
|
}
|
|
56
|
-
async function executeItem(execute, executeFunctions, itemIndex
|
|
57
|
-
return await execute.call(executeFunctions, itemIndex
|
|
56
|
+
async function executeItem(execute, executeFunctions, itemIndex) {
|
|
57
|
+
return await execute.call(executeFunctions, itemIndex);
|
|
58
58
|
}
|
|
59
59
|
function handleNodeApiError(error, itemIndex) {
|
|
60
60
|
var _a, _b, _c;
|
|
@@ -92,11 +92,11 @@ function handleError(error, executeFunctions, itemIndex, continueOnFail, returnD
|
|
|
92
92
|
}
|
|
93
93
|
return handleGenericError(normalizedError, executeFunctions, itemIndex);
|
|
94
94
|
}
|
|
95
|
-
async function processItems(config, executeFunctions
|
|
95
|
+
async function processItems(config, executeFunctions) {
|
|
96
96
|
const { returnData, items, execute } = config;
|
|
97
97
|
for (let i = 0; i < items.length; i++) {
|
|
98
98
|
try {
|
|
99
|
-
const responseData = await executeItem(execute, executeFunctions, i
|
|
99
|
+
const responseData = await executeItem(execute, executeFunctions, i);
|
|
100
100
|
returnData.push(...responseData);
|
|
101
101
|
}
|
|
102
102
|
catch (error) {
|
|
@@ -109,9 +109,9 @@ async function processItems(config, executeFunctions, parentMessageContentStr =
|
|
|
109
109
|
}
|
|
110
110
|
return returnData;
|
|
111
111
|
}
|
|
112
|
-
async function router(
|
|
112
|
+
async function router() {
|
|
113
113
|
const config = initializeRouter(this);
|
|
114
|
-
const processedData = await processItems(config, this
|
|
114
|
+
const processedData = await processItems(config, this);
|
|
115
115
|
return [processedData];
|
|
116
116
|
}
|
|
117
117
|
//# sourceMappingURL=router.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"router.js","sourceRoot":"","sources":["../../../../../nodes/shared/core/execution/router.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
1
|
+
{"version":3,"file":"router.js","sourceRoot":"","sources":["../../../../../nodes/shared/core/execution/router.ts"],"names":[],"mappings":"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"}
|
|
@@ -15,5 +15,4 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
|
15
15
|
};
|
|
16
16
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
17
|
__exportStar(require("./io"), exports);
|
|
18
|
-
__exportStar(require("./optimizer"), exports);
|
|
19
18
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../nodes/shared/core/memory/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AACA,uCAAqB
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../nodes/shared/core/memory/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AACA,uCAAqB"}
|
|
@@ -1,5 +1,4 @@
|
|
|
1
|
-
import type { IExecuteFunctions, IDataObject } from 'n8n-workflow';
|
|
2
|
-
import type {
|
|
3
|
-
|
|
4
|
-
export declare function
|
|
5
|
-
export declare function saveToMemory(memory: BaseChatMemory | undefined, messages: IDataObject[], response: ChatCompletion, outputStringified: string, saveToolCallsInChatMemory: boolean, originalMessagesLength?: number): Promise<void>;
|
|
1
|
+
import type { IExecuteFunctions, ISupplyDataFunctions, IDataObject } from 'n8n-workflow';
|
|
2
|
+
import type { BufferWindowMemory } from 'langchain/memory';
|
|
3
|
+
export declare function getOptionalMemory(ctx: IExecuteFunctions | ISupplyDataFunctions): Promise<BufferWindowMemory | undefined>;
|
|
4
|
+
export declare function saveToMemory(messages: IDataObject[], output: any, saveToolCallsInChatMemory: boolean, memory: BufferWindowMemory): Promise<void>;
|
|
@@ -1,96 +1,63 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.
|
|
3
|
+
exports.getOptionalMemory = getOptionalMemory;
|
|
4
4
|
exports.saveToMemory = saveToMemory;
|
|
5
5
|
const messages_1 = require("@langchain/core/messages");
|
|
6
|
-
const
|
|
7
|
-
async function
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
6
|
+
const n8n_workflow_1 = require("n8n-workflow");
|
|
7
|
+
async function getOptionalMemory(ctx) {
|
|
8
|
+
return (await ctx.getInputConnectionData(n8n_workflow_1.NodeConnectionTypes.AiMemory, 0));
|
|
9
|
+
}
|
|
10
|
+
function extractMessages(messages) {
|
|
11
|
+
if (!Array.isArray(messages) || messages.length === 0) {
|
|
12
|
+
return { lastUser: null, messagesAfter: [] };
|
|
13
|
+
}
|
|
14
|
+
let lastUserIndex = -1;
|
|
15
|
+
for (let i = messages.length - 1; i >= 0; i--) {
|
|
16
|
+
if (messages[i].role === "user") {
|
|
17
|
+
lastUserIndex = i;
|
|
18
|
+
break;
|
|
19
|
+
}
|
|
11
20
|
}
|
|
12
|
-
|
|
13
|
-
|
|
21
|
+
if (lastUserIndex === -1) {
|
|
22
|
+
return { lastUser: null, messagesAfter: [] };
|
|
14
23
|
}
|
|
15
|
-
|
|
24
|
+
const messagesAfter = messages.slice(lastUserIndex + 1);
|
|
25
|
+
return {
|
|
26
|
+
lastUser: messages[lastUserIndex],
|
|
27
|
+
messagesAfter
|
|
28
|
+
};
|
|
16
29
|
}
|
|
17
|
-
async function saveToMemory(
|
|
18
|
-
var _a
|
|
19
|
-
|
|
30
|
+
async function saveToMemory(messages, output, saveToolCallsInChatMemory, memory) {
|
|
31
|
+
var _a;
|
|
32
|
+
const extractedMessages = extractMessages(messages);
|
|
33
|
+
const input = (_a = extractedMessages.lastUser) === null || _a === void 0 ? void 0 : _a.content;
|
|
34
|
+
if (!input) {
|
|
35
|
+
console.log('No user message found; no messages will be stored in the Chat Memory sub-node.');
|
|
20
36
|
return;
|
|
21
37
|
}
|
|
38
|
+
const stringifiedOutput = (typeof output === 'string' || typeof output === null) ? output : JSON.stringify(output);
|
|
22
39
|
if (!saveToolCallsInChatMemory) {
|
|
23
|
-
|
|
24
|
-
let assistantContent = outputStringified;
|
|
25
|
-
if (!assistantContent || assistantContent === 'null' || assistantContent === 'undefined') {
|
|
26
|
-
assistantContent = response.choices[0].message.content || '';
|
|
27
|
-
if (!assistantContent && ((_d = response.choices[0].message.tool_calls) === null || _d === void 0 ? void 0 : _d.length)) {
|
|
28
|
-
assistantContent =
|
|
29
|
-
'Used tools: ' +
|
|
30
|
-
response.choices[0].message.tool_calls.map((tc) => tc.function.name).join(', ');
|
|
31
|
-
}
|
|
32
|
-
else if (!assistantContent) {
|
|
33
|
-
assistantContent = '[No response content available]';
|
|
34
|
-
}
|
|
35
|
-
}
|
|
36
|
-
if (typeof assistantContent !== 'string') {
|
|
37
|
-
assistantContent = JSON.stringify(assistantContent);
|
|
38
|
-
}
|
|
39
|
-
try {
|
|
40
|
-
await memory.saveContext({ input: lastUserMessageContent }, { output: assistantContent });
|
|
41
|
-
}
|
|
42
|
-
catch (error) {
|
|
43
|
-
console.error('Error saving messages to memory:', error);
|
|
44
|
-
}
|
|
40
|
+
await memory.saveContext({ input: input }, { output: stringifiedOutput });
|
|
45
41
|
}
|
|
46
42
|
else {
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
}
|
|
66
|
-
}
|
|
67
|
-
let finalContent = outputStringified;
|
|
68
|
-
if (!finalContent || finalContent === 'null' || finalContent === 'undefined') {
|
|
69
|
-
finalContent = response.choices[0].message.content || '';
|
|
70
|
-
if (!finalContent && ((_e = response.choices[0].message.tool_calls) === null || _e === void 0 ? void 0 : _e.length)) {
|
|
71
|
-
finalContent =
|
|
72
|
-
'Used tools: ' +
|
|
73
|
-
response.choices[0].message.tool_calls.map((tc) => tc.function.name).join(', ');
|
|
74
|
-
}
|
|
75
|
-
else if (!finalContent) {
|
|
76
|
-
finalContent = '[No response content available]';
|
|
77
|
-
}
|
|
78
|
-
}
|
|
79
|
-
if (typeof finalContent !== 'string') {
|
|
80
|
-
finalContent = JSON.stringify(finalContent);
|
|
81
|
-
}
|
|
82
|
-
const sanitizedConversationMessages = conversationMessages.map(converter_1.sanitizeMessage);
|
|
83
|
-
const aiMessage = new messages_1.AIMessage({
|
|
84
|
-
content: finalContent,
|
|
85
|
-
...(sanitizedConversationMessages.length > 0 && { tool_calls: sanitizedConversationMessages }),
|
|
86
|
-
additional_kwargs: {},
|
|
87
|
-
response_metadata: {},
|
|
88
|
-
});
|
|
89
|
-
await memory.chatHistory.addMessage(aiMessage);
|
|
90
|
-
}
|
|
91
|
-
catch (error) {
|
|
92
|
-
console.error('Error saving messages with tool calls to memory:', error);
|
|
93
|
-
}
|
|
43
|
+
const humanMessage = new messages_1.HumanMessage(input);
|
|
44
|
+
await memory.chatHistory.addMessage(humanMessage);
|
|
45
|
+
const tool_calls = extractedMessages.messagesAfter
|
|
46
|
+
.filter(msg => msg.role === 'assistant' || msg.role === 'tool')
|
|
47
|
+
.map(msg => ({
|
|
48
|
+
role: msg.role,
|
|
49
|
+
content: msg.content || null,
|
|
50
|
+
...(msg.tool_calls && { tool_calls: msg.tool_calls }),
|
|
51
|
+
...(msg.tool_call_id && { tool_call_id: msg.tool_call_id }),
|
|
52
|
+
...(msg.refusal && { refusal: msg.refusal }),
|
|
53
|
+
}));
|
|
54
|
+
const aiMessage = new messages_1.AIMessage({
|
|
55
|
+
content: stringifiedOutput,
|
|
56
|
+
tool_calls: tool_calls,
|
|
57
|
+
additional_kwargs: {},
|
|
58
|
+
response_metadata: {},
|
|
59
|
+
});
|
|
60
|
+
await memory.chatHistory.addMessage(aiMessage);
|
|
94
61
|
}
|
|
95
62
|
}
|
|
96
63
|
//# sourceMappingURL=io.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"io.js","sourceRoot":"","sources":["../../../../../nodes/shared/core/memory/io.ts"],"names":[],"mappings":";;
|
|
1
|
+
{"version":3,"file":"io.js","sourceRoot":"","sources":["../../../../../nodes/shared/core/memory/io.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,2 +1,3 @@
|
|
|
1
1
|
import { Message, RawMessage } from './types';
|
|
2
|
-
|
|
2
|
+
import type { BufferWindowMemory } from 'langchain/memory';
|
|
3
|
+
export declare function unpackChatHistoryAndMemory(rawMessagesToSend: RawMessage[], loadToolCallsFromChatMemory?: boolean, memory?: BufferWindowMemory): Promise<Message[]>;
|
|
@@ -1,63 +1,42 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.unpackChatHistoryAndMemory = unpackChatHistoryAndMemory;
|
|
4
|
-
const optimizer_1 = require("../memory/optimizer");
|
|
5
4
|
const converter_1 = require("./converter");
|
|
6
|
-
async function
|
|
5
|
+
async function getChatMessages(memory) {
|
|
6
|
+
return (await memory.loadMemoryVariables({}))[memory.memoryKey];
|
|
7
|
+
}
|
|
8
|
+
async function unpackChatHistoryAndMemory(rawMessagesToSend, loadToolCallsFromChatMemory = true, memory) {
|
|
7
9
|
const processedMessages = [];
|
|
8
10
|
for (const rawMessage of rawMessagesToSend) {
|
|
9
|
-
if (rawMessage.role
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
chatHistory = JSON.parse(rawMessage.chatHistoryJson || '[]');
|
|
17
|
-
}
|
|
18
|
-
else {
|
|
19
|
-
chatHistory = rawMessage.chatHistoryJson;
|
|
20
|
-
}
|
|
21
|
-
if (Array.isArray(chatHistory)) {
|
|
22
|
-
processedMessages.push(...chatHistory);
|
|
23
|
-
}
|
|
24
|
-
else {
|
|
25
|
-
processedMessages.push({
|
|
26
|
-
role: 'user',
|
|
27
|
-
content: JSON.stringify(rawMessage.chatHistoryJson),
|
|
28
|
-
});
|
|
29
|
-
}
|
|
11
|
+
if (rawMessage.role === 'chatHistoryRole') {
|
|
12
|
+
let chatHistory;
|
|
13
|
+
if (typeof rawMessage.chatHistoryJson === 'string') {
|
|
14
|
+
chatHistory = JSON.parse(rawMessage.chatHistoryJson || '[]');
|
|
15
|
+
}
|
|
16
|
+
else {
|
|
17
|
+
chatHistory = rawMessage.chatHistoryJson;
|
|
30
18
|
}
|
|
31
|
-
|
|
19
|
+
if (Array.isArray(chatHistory)) {
|
|
20
|
+
processedMessages.push(...chatHistory);
|
|
21
|
+
}
|
|
22
|
+
else {
|
|
32
23
|
processedMessages.push({
|
|
33
24
|
role: 'user',
|
|
34
25
|
content: JSON.stringify(rawMessage.chatHistoryJson),
|
|
35
26
|
});
|
|
36
27
|
}
|
|
37
28
|
}
|
|
38
|
-
else if (rawMessage.role === 'chatMemoryRole' && memory
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
else {
|
|
44
|
-
if (k > 0 && k < 1) {
|
|
45
|
-
k = 1;
|
|
46
|
-
}
|
|
47
|
-
const rawMemoryMessages = await (0, optimizer_1.getLastKMessages)(memory, k);
|
|
48
|
-
if (rawMemoryMessages.length === 0) {
|
|
49
|
-
}
|
|
50
|
-
else {
|
|
51
|
-
const memoryMessages = (0, converter_1.convertMessages)(rawMemoryMessages, loadToolCallsFromChatMemory);
|
|
52
|
-
processedMessages.push(...memoryMessages);
|
|
53
|
-
}
|
|
54
|
-
}
|
|
55
|
-
}
|
|
56
|
-
catch (error) {
|
|
57
|
-
console.error('Error retrieving messages from memory:', error);
|
|
29
|
+
else if (rawMessage.role === 'chatMemoryRole' && memory) {
|
|
30
|
+
const rawMemoryMessages = await getChatMessages(memory);
|
|
31
|
+
if (rawMemoryMessages.length > 0) {
|
|
32
|
+
const memoryMessages = (0, converter_1.convertMessages)(rawMemoryMessages, loadToolCallsFromChatMemory);
|
|
33
|
+
processedMessages.push(...memoryMessages);
|
|
58
34
|
}
|
|
59
35
|
}
|
|
36
|
+
else {
|
|
37
|
+
processedMessages.push(rawMessage);
|
|
38
|
+
}
|
|
60
39
|
}
|
|
61
|
-
return
|
|
40
|
+
return processedMessages;
|
|
62
41
|
}
|
|
63
42
|
//# sourceMappingURL=chatHistory.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"chatHistory.js","sourceRoot":"","sources":["../../../../../nodes/shared/core/messages/chatHistory.ts"],"names":[],"mappings":";;
|
|
1
|
+
{"version":3,"file":"chatHistory.js","sourceRoot":"","sources":["../../../../../nodes/shared/core/messages/chatHistory.ts"],"names":[],"mappings":";;AAgBA,gEAiDC;AA9DD,2CAA8C;AAE9C,KAAK,UAAU,eAAe,CAAC,MAA0B;IACxD,OAAO,CAAC,MAAM,MAAM,CAAC,mBAAmB,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,SAAS,CAAkB,CAAC;AAClF,CAAC;AASM,KAAK,UAAU,0BAA0B,CAC/C,iBAA+B,EAC/B,8BAAuC,IAAI,EAC3C,MAA2B;IAE3B,MAAM,iBAAiB,GAAc,EAAE,CAAC;IAExC,KAAK,MAAM,UAAU,IAAI,iBAAiB,EAAE,CAAC;QAC5C,IAAI,UAAU,CAAC,IAAI,KAAK,iBAAiB,EAAE,CAAC;YAG3C,IAAI,WAAW,CAAC;YAChB,IAAI,OAAO,UAAU,CAAC,eAAe,KAAK,QAAQ,EAAE,CAAC;gBACpD,WAAW,GAAG,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,eAAe,IAAI,IAAI,CAAC,CAAC;YAC9D,CAAC;iBAAM,CAAC;gBACP,WAAW,GAAG,UAAU,CAAC,eAAe,CAAC;YAC1C,CAAC;YAED,IAAI,KAAK,CAAC,OAAO,CAAC,WAAW,CAAC,EAAE,CAAC;gBAEhC,iBAAiB,CAAC,IAAI,CAAC,GAAG,WAAW,CAAC,CAAC;YACxC,CAAC;iBAAM,CAAC;gBAEP,iBAAiB,CAAC,IAAI,CAAC;oBACtB,IAAI,EAAE,MAAM;oBACZ,OAAO,EAAE,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,eAAe,CAAC;iBACnD,CAAC,CAAC;YACJ,CAAC;QAEF,CAAC;aAAM,IAAI,UAAU,CAAC,IAAI,KAAK,gBAAgB,IAAI,MAAM,EAAE,CAAC;YAG3D,MAAM,iBAAiB,GAAkB,MAAM,eAAe,CAAC,MAAM,CAAC,CAAA;YAEtE,IAAI,iBAAiB,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;gBAElC,MAAM,cAAc,GAAc,IAAA,2BAAe,EAChD,iBAAiB,EACjB,2BAA2B,CAC3B,CAAC;gBACF,iBAAiB,CAAC,IAAI,CAAC,GAAG,cAAc,CAAC,CAAC;YAC3C,CAAC;QACF,CAAC;aAAM,CAAC;YAEP,iBAAiB,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QACpC,CAAC;IACF,CAAC;IAED,OAAO,iBAAiB,CAAC;AAC1B,CAAC"}
|
|
@@ -1,5 +1,3 @@
|
|
|
1
1
|
import { Message } from './types';
|
|
2
2
|
import { BaseMessage } from '@langchain/core/dist/messages/base';
|
|
3
3
|
export declare function convertMessages(messages: BaseMessage[], loadToolCalls?: boolean): Message[];
|
|
4
|
-
export declare function expandToolCallsInMessages(messages: Message[], loadToolCalls?: boolean): Message[];
|
|
5
|
-
export declare function sanitizeMessage(message: any): any;
|
|
@@ -1,20 +1,17 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.convertMessages = convertMessages;
|
|
4
|
-
exports.expandToolCallsInMessages = expandToolCallsInMessages;
|
|
5
|
-
exports.sanitizeMessage = sanitizeMessage;
|
|
6
|
-
const n8n_workflow_1 = require("n8n-workflow");
|
|
7
4
|
function convertMessages(messages, loadToolCalls = true) {
|
|
8
5
|
const result = [];
|
|
9
6
|
for (const message of messages) {
|
|
10
7
|
const role = message.constructor.name === 'AIMessage' ? 'assistant' : 'user';
|
|
11
|
-
const content = typeof message.content === 'string' ? message.content
|
|
8
|
+
const content = typeof message.content === 'string' ? message.content
|
|
9
|
+
: typeof message.content === null ? ''
|
|
10
|
+
: JSON.stringify(message.content);
|
|
12
11
|
const toolCalls = message.tool_calls;
|
|
13
|
-
if (
|
|
14
|
-
|
|
15
|
-
Array.isArray(toolCalls)
|
|
16
|
-
toolCalls.length > 0 &&
|
|
17
|
-
loadToolCalls) {
|
|
12
|
+
if (loadToolCalls &&
|
|
13
|
+
role === 'assistant' &&
|
|
14
|
+
Array.isArray(toolCalls)) {
|
|
18
15
|
result.push(...toolCalls);
|
|
19
16
|
result.push({
|
|
20
17
|
role: 'assistant',
|
|
@@ -30,62 +27,4 @@ function convertMessages(messages, loadToolCalls = true) {
|
|
|
30
27
|
}
|
|
31
28
|
return result;
|
|
32
29
|
}
|
|
33
|
-
function expandToolCallsInMessages(messages, loadToolCalls = true) {
|
|
34
|
-
var _a;
|
|
35
|
-
const result = [];
|
|
36
|
-
for (const message of messages) {
|
|
37
|
-
if (message.role !== 'assistant' || !((_a = message.tool_calls) === null || _a === void 0 ? void 0 : _a.length)) {
|
|
38
|
-
const messageCopy = { ...message };
|
|
39
|
-
if (messageCopy.tool_calls)
|
|
40
|
-
delete messageCopy.tool_calls;
|
|
41
|
-
result.push(messageCopy);
|
|
42
|
-
continue;
|
|
43
|
-
}
|
|
44
|
-
if (!loadToolCalls) {
|
|
45
|
-
result.push({
|
|
46
|
-
role: 'assistant',
|
|
47
|
-
content: message.content,
|
|
48
|
-
});
|
|
49
|
-
continue;
|
|
50
|
-
}
|
|
51
|
-
result.push(...message.tool_calls);
|
|
52
|
-
result.push({
|
|
53
|
-
role: 'assistant',
|
|
54
|
-
content: message.content,
|
|
55
|
-
});
|
|
56
|
-
}
|
|
57
|
-
return result;
|
|
58
|
-
}
|
|
59
|
-
function sanitizeMessage(message) {
|
|
60
|
-
const hasToolCalls = message.tool_calls && Array.isArray(message.tool_calls);
|
|
61
|
-
const isEmptyToolCalls = hasToolCalls && message.tool_calls.length === 0;
|
|
62
|
-
n8n_workflow_1.LoggerProxy.debug('Sanitizing message', {
|
|
63
|
-
messageRole: message.role,
|
|
64
|
-
hasToolCalls,
|
|
65
|
-
toolCallsLength: hasToolCalls ? message.tool_calls.length : 'N/A',
|
|
66
|
-
isEmptyToolCalls,
|
|
67
|
-
messageId: message.id || 'no-id'
|
|
68
|
-
});
|
|
69
|
-
const sanitized = { ...message };
|
|
70
|
-
if (sanitized.tool_calls && Array.isArray(sanitized.tool_calls)) {
|
|
71
|
-
sanitized.tool_calls = [...sanitized.tool_calls];
|
|
72
|
-
if (sanitized.tool_calls.length === 0) {
|
|
73
|
-
n8n_workflow_1.LoggerProxy.debug('Removing empty tool_calls array during sanitization', {
|
|
74
|
-
messageRole: sanitized.role,
|
|
75
|
-
originalToolCallsLength: message.tool_calls.length,
|
|
76
|
-
messageId: message.id || 'no-id'
|
|
77
|
-
});
|
|
78
|
-
delete sanitized.tool_calls;
|
|
79
|
-
}
|
|
80
|
-
}
|
|
81
|
-
const sanitizedHasToolCalls = sanitized.tool_calls && Array.isArray(sanitized.tool_calls);
|
|
82
|
-
n8n_workflow_1.LoggerProxy.debug('Message sanitization complete', {
|
|
83
|
-
messageRole: sanitized.role,
|
|
84
|
-
originalHadToolCalls: hasToolCalls,
|
|
85
|
-
sanitizedHasToolCalls,
|
|
86
|
-
removedEmptyToolCalls: hasToolCalls && !sanitizedHasToolCalls,
|
|
87
|
-
messageId: message.id || 'no-id'
|
|
88
|
-
});
|
|
89
|
-
return sanitized;
|
|
90
|
-
}
|
|
91
30
|
//# sourceMappingURL=converter.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"converter.js","sourceRoot":"","sources":["../../../../../nodes/shared/core/messages/converter.ts"],"names":[],"mappings":";;
|
|
1
|
+
{"version":3,"file":"converter.js","sourceRoot":"","sources":["../../../../../nodes/shared/core/messages/converter.ts"],"names":[],"mappings":";;AAeA,0CAkCC;AAlCD,SAAgB,eAAe,CAAC,QAAuB,EAAE,gBAAyB,IAAI;IACrF,MAAM,MAAM,GAAc,EAAE,CAAC;IAE7B,KAAK,MAAM,OAAO,IAAI,QAAQ,EAAE,CAAC;QAChC,MAAM,IAAI,GAAG,OAAO,CAAC,WAAW,CAAC,IAAI,KAAK,WAAW,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,MAAM,CAAC;QAC7E,MAAM,OAAO,GAAG,OAAO,OAAO,CAAC,OAAO,KAAK,QAAQ,CAAC,CAAC,CAAC,OAAO,CAAC,OAAO;YACpE,CAAC,CAAC,OAAO,OAAO,CAAC,OAAO,KAAK,IAAI,CAAC,CAAC,CAAC,EAAE;gBACtC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;QAGnC,MAAM,SAAS,GAAI,OAAe,CAAC,UAAU,CAAC;QAC9C,IACC,aAAa;YACb,IAAI,KAAK,WAAW;YACpB,KAAK,CAAC,OAAO,CAAC,SAAS,CAAC,EACvB,CAAC;YAEF,MAAM,CAAC,IAAI,CAAC,GAAG,SAAS,CAAC,CAAC;YAG1B,MAAM,CAAC,IAAI,CAAC;gBACX,IAAI,EAAE,WAAW;gBACjB,OAAO,EAAE,OAAO;aAChB,CAAC,CAAC;QACJ,CAAC;aAAM,CAAC;YAEP,MAAM,CAAC,IAAI,CAAC;gBACX,IAAI,EAAE,IAAI;gBACV,OAAO,EAAE,OAAO;aAChB,CAAC,CAAC;QACJ,CAAC;IACF,CAAC;IAED,OAAO,MAAM,CAAC;AACf,CAAC"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
1
|
import type { IDataObject } from 'n8n-workflow';
|
|
2
|
-
import type {
|
|
2
|
+
import type { BufferWindowMemory } from 'langchain/memory';
|
|
3
3
|
import { Message } from './types';
|
|
4
|
-
export declare function processMessages(rawMessagesToSend: Message[],
|
|
4
|
+
export declare function processMessages(rawMessagesToSend: Message[], loadToolCallsFromChatMemory?: boolean, memory?: BufferWindowMemory): Promise<IDataObject[]>;
|
|
@@ -1,61 +1,9 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.processMessages = processMessages;
|
|
4
|
-
const n8n_workflow_1 = require("n8n-workflow");
|
|
5
4
|
const chatHistory_1 = require("./chatHistory");
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
n8n_workflow_1.LoggerProxy.debug('Message processor: Starting with raw messages', {
|
|
9
|
-
rawMessageCount: rawMessagesToSend.length,
|
|
10
|
-
rawMessagesWithToolCalls: rawMessagesToSend.filter(m => m.tool_calls).length,
|
|
11
|
-
rawMessagesWithEmptyToolCalls: rawMessagesToSend.filter(m => m.tool_calls && Array.isArray(m.tool_calls) && m.tool_calls.length === 0).length,
|
|
12
|
-
loadToolCallsFromChatMemory,
|
|
13
|
-
});
|
|
14
|
-
let messages = (await (0, chatHistory_1.unpackChatHistoryAndMemory)(rawMessagesToSend, memory, loadToolCallsFromChatMemory));
|
|
15
|
-
n8n_workflow_1.LoggerProxy.debug('Message processor: After unpacking chat history and memory', {
|
|
16
|
-
messageCount: messages.length,
|
|
17
|
-
messagesWithToolCalls: messages.filter(m => m.tool_calls).length,
|
|
18
|
-
messagesWithEmptyToolCalls: messages.filter(m => m.tool_calls && Array.isArray(m.tool_calls) && m.tool_calls.length === 0).length,
|
|
19
|
-
});
|
|
20
|
-
messages = messages
|
|
21
|
-
.map((item) => ({
|
|
22
|
-
...item,
|
|
23
|
-
content: typeof item.content === 'string' ? item.content.trim() : item.content,
|
|
24
|
-
}))
|
|
25
|
-
.filter((item) => {
|
|
26
|
-
var _a;
|
|
27
|
-
return item.content !== '' ||
|
|
28
|
-
(item.role === 'assistant' && ((_a = item.tool_calls) === null || _a === void 0 ? void 0 : _a.length) > 0) ||
|
|
29
|
-
item.role === 'tool';
|
|
30
|
-
});
|
|
31
|
-
n8n_workflow_1.LoggerProxy.debug('Message processor: After filtering and trimming', {
|
|
32
|
-
messageCount: messages.length,
|
|
33
|
-
messagesWithToolCalls: messages.filter(m => m.tool_calls).length,
|
|
34
|
-
messagesWithEmptyToolCalls: messages.filter(m => m.tool_calls && Array.isArray(m.tool_calls) && m.tool_calls.length === 0).length,
|
|
35
|
-
});
|
|
36
|
-
if (parentMessageContentStr !== '') {
|
|
37
|
-
messages.push({ role: 'user', content: parentMessageContentStr });
|
|
38
|
-
}
|
|
39
|
-
else if (Object.keys(parentMessageContentObj).length !== 0) {
|
|
40
|
-
messages.push({ role: 'user', content: JSON.stringify(parentMessageContentObj) });
|
|
41
|
-
}
|
|
42
|
-
n8n_workflow_1.LoggerProxy.debug('Message processor: Before final sanitization', {
|
|
43
|
-
messageCount: messages.length,
|
|
44
|
-
messagesWithToolCalls: messages.filter(m => m.tool_calls).length,
|
|
45
|
-
messagesWithEmptyToolCalls: messages.filter(m => m.tool_calls && Array.isArray(m.tool_calls) && m.tool_calls.length === 0).length,
|
|
46
|
-
});
|
|
47
|
-
messages = messages.map(converter_1.sanitizeMessage);
|
|
48
|
-
n8n_workflow_1.LoggerProxy.debug('Message processor: After final sanitization - FINAL OUTPUT', {
|
|
49
|
-
messageCount: messages.length,
|
|
50
|
-
messagesWithToolCalls: messages.filter(m => m.tool_calls).length,
|
|
51
|
-
messagesWithEmptyToolCalls: messages.filter(m => m.tool_calls && Array.isArray(m.tool_calls) && m.tool_calls.length === 0).length,
|
|
52
|
-
messageStructures: messages.map((m, i) => ({
|
|
53
|
-
index: i,
|
|
54
|
-
role: m.role,
|
|
55
|
-
hasToolCalls: !!m.tool_calls,
|
|
56
|
-
toolCallsLength: Array.isArray(m.tool_calls) ? m.tool_calls.length : 'N/A'
|
|
57
|
-
}))
|
|
58
|
-
});
|
|
5
|
+
async function processMessages(rawMessagesToSend, loadToolCallsFromChatMemory = true, memory) {
|
|
6
|
+
let messages = (await (0, chatHistory_1.unpackChatHistoryAndMemory)(rawMessagesToSend, loadToolCallsFromChatMemory, memory));
|
|
59
7
|
return messages;
|
|
60
8
|
}
|
|
61
9
|
//# sourceMappingURL=processor.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"processor.js","sourceRoot":"","sources":["../../../../../nodes/shared/core/messages/processor.ts"],"names":[],"mappings":";;
|
|
1
|
+
{"version":3,"file":"processor.js","sourceRoot":"","sources":["../../../../../nodes/shared/core/messages/processor.ts"],"names":[],"mappings":";;AAQA,0CAaC;AAlBD,+CAA2D;AAKpD,KAAK,UAAU,eAAe,CACpC,iBAA4B,EAC5B,8BAAuC,IAAI,EAC3C,MAA2B;IAG3B,IAAI,QAAQ,GAAG,CAAC,MAAM,IAAA,wCAA0B,EAC/C,iBAAiB,EACjB,2BAA2B,EAC3B,MAAM,CACN,CAAkB,CAAC;IAEpB,OAAO,QAAQ,CAAC;AACjB,CAAC"}
|
|
@@ -4,10 +4,8 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
|
4
4
|
};
|
|
5
5
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
6
|
exports.prepareRequestBody = prepareRequestBody;
|
|
7
|
-
const n8n_workflow_1 = require("n8n-workflow");
|
|
8
7
|
const omit_1 = __importDefault(require("lodash/omit"));
|
|
9
8
|
const types_1 = require("../messages/types");
|
|
10
|
-
const converter_1 = require("../messages/converter");
|
|
11
9
|
function prepareRequestBody(model, messages, tools, tool_choice, response_format, options, customParameters) {
|
|
12
10
|
let customParamsObj = {};
|
|
13
11
|
if (customParameters) {
|
|
@@ -40,27 +38,6 @@ function prepareRequestBody(model, messages, tools, tool_choice, response_format
|
|
|
40
38
|
if (!Array.isArray(messages) || !messages.every(types_1.isValidMessage)) {
|
|
41
39
|
throw new Error("Invalid or missing 'messages' in the request body.");
|
|
42
40
|
}
|
|
43
|
-
n8n_workflow_1.LoggerProxy.debug('Request body preparation: Before sanitization', {
|
|
44
|
-
messageCount: messages.length,
|
|
45
|
-
messagesWithToolCalls: messages.filter(m => m.tool_calls).length,
|
|
46
|
-
messagesWithEmptyToolCalls: messages.filter(m => m.tool_calls && Array.isArray(m.tool_calls) && m.tool_calls.length === 0).length,
|
|
47
|
-
model,
|
|
48
|
-
toolsCount: tools.length
|
|
49
|
-
});
|
|
50
|
-
body.messages = messages.map(converter_1.sanitizeMessage);
|
|
51
|
-
n8n_workflow_1.LoggerProxy.debug('Request body preparation: After sanitization - FINAL REQUEST BODY', {
|
|
52
|
-
messageCount: body.messages.length,
|
|
53
|
-
messagesWithToolCalls: body.messages.filter((m) => m.tool_calls).length,
|
|
54
|
-
messagesWithEmptyToolCalls: body.messages.filter((m) => m.tool_calls && Array.isArray(m.tool_calls) && m.tool_calls.length === 0).length,
|
|
55
|
-
model,
|
|
56
|
-
toolsCount: tools.length,
|
|
57
|
-
messageStructures: body.messages.map((m, i) => ({
|
|
58
|
-
index: i,
|
|
59
|
-
role: m.role,
|
|
60
|
-
hasToolCalls: !!m.tool_calls,
|
|
61
|
-
toolCallsLength: Array.isArray(m.tool_calls) ? m.tool_calls.length : 'N/A'
|
|
62
|
-
}))
|
|
63
|
-
});
|
|
64
41
|
return body;
|
|
65
42
|
}
|
|
66
43
|
//# sourceMappingURL=body.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"body.js","sourceRoot":"","sources":["../../../../../nodes/shared/core/request/body.ts"],"names":[],"mappings":";;;;;
|
|
1
|
+
{"version":3,"file":"body.js","sourceRoot":"","sources":["../../../../../nodes/shared/core/request/body.ts"],"names":[],"mappings":";;;;;AAOA,gDA6CC;AAnDD,uDAAgC;AAChC,6CAAmD;AAKnD,SAAgB,kBAAkB,CACjC,KAAa,EACb,QAAuB,EACvB,KAAY,EACZ,WAA+B,EAC/B,eAAwC,EACxC,OAAoB,EACpB,gBAAsC;IAEtC,IAAI,eAAe,GAAgB,EAAE,CAAC;IACtC,IAAI,gBAAgB,EAAE,CAAC;QACtB,IAAI,OAAO,gBAAgB,KAAK,QAAQ,IAAI,gBAAgB,CAAC,IAAI,EAAE,EAAE,CAAC;YACrE,IAAI,CAAC;gBACJ,eAAe,GAAG,IAAI,CAAC,KAAK,CAAC,gBAAgB,CAAC,CAAC;YAChD,CAAC;YAAC,OAAO,KAAK,EAAE,CAAC;gBAChB,MAAM,IAAI,KAAK,CAAC,kCAAkC,CAAC,CAAC;YACrD,CAAC;QACF,CAAC;aAAM,IAAI,OAAO,gBAAgB,KAAK,QAAQ,EAAE,CAAC;YACjD,eAAe,GAAG,gBAAgB,CAAC;QACpC,CAAC;IACF,CAAC;IAGD,MAAM,YAAY,GAAG,IAAA,cAAK,EAAC,OAAO,EAAE;QACnC,kBAAkB;QAClB,iBAAiB;QACjB,oBAAoB;KACpB,CAAC,CAAC;IAEH,MAAM,IAAI,GAAgB;QACzB,KAAK;QACL,QAAQ;QACR,GAAG,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,KAAK,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;QACtC,WAAW;QACX,eAAe;QACf,GAAG,YAAY;QACf,GAAG,eAAe;KAClB,CAAC;IAGF,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,sBAAc,CAAC,EAAE,CAAC;QACjE,MAAM,IAAI,KAAK,CAAC,oDAAoD,CAAC,CAAC;IACvE,CAAC;IAED,OAAO,IAAI,CAAC;AACb,CAAC"}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import type { IExecuteFunctions, IDataObject } from 'n8n-workflow';
|
|
2
2
|
import type { ChatCompletion } from '../../api/types';
|
|
3
|
-
export declare function processToolCalls(executeFunctions: IExecuteFunctions, body: IDataObject, messages: IDataObject[], invokableTools: any[],
|
|
3
|
+
export declare function processToolCalls(executeFunctions: IExecuteFunctions, body: IDataObject, messages: IDataObject[], invokableTools: any[], maxToolsIterations: number, responseFormat: string, structuredOutputTool?: IDataObject, abortSignal?: AbortSignal): Promise<{
|
|
4
4
|
response: ChatCompletion;
|
|
5
5
|
output: any;
|
|
6
6
|
}>;
|