2024-03-07 02:46:07 -08:00
|
|
|
import {
|
|
|
|
AGENT_LANGCHAIN_NODE_TYPE,
|
2024-08-14 06:41:35 -07:00
|
|
|
AI_TRANSFORM_NODE_TYPE,
|
2024-03-27 08:16:02 -07:00
|
|
|
CHAIN_LLM_LANGCHAIN_NODE_TYPE,
|
2024-03-07 02:46:07 -08:00
|
|
|
CHAIN_SUMMARIZATION_LANGCHAIN_NODE_TYPE,
|
2024-07-04 05:16:15 -07:00
|
|
|
EXECUTE_WORKFLOW_NODE_TYPE,
|
2024-03-07 02:46:07 -08:00
|
|
|
HTTP_REQUEST_NODE_TYPE,
|
2024-06-19 00:54:13 -07:00
|
|
|
HTTP_REQUEST_TOOL_LANGCHAIN_NODE_TYPE,
|
2024-03-07 02:46:07 -08:00
|
|
|
LANGCHAIN_CUSTOM_TOOLS,
|
2024-07-02 03:47:04 -07:00
|
|
|
MERGE_NODE_TYPE,
|
2024-03-07 02:46:07 -08:00
|
|
|
OPENAI_LANGCHAIN_NODE_TYPE,
|
|
|
|
STICKY_NODE_TYPE,
|
|
|
|
WEBHOOK_NODE_TYPE,
|
2024-07-04 05:16:15 -07:00
|
|
|
WORKFLOW_TOOL_LANGCHAIN_NODE_TYPE,
|
2024-03-07 02:46:07 -08:00
|
|
|
} from './Constants';
|
2024-09-18 00:19:33 -07:00
|
|
|
import { ApplicationError } from './errors/application.error';
|
|
|
|
import type {
|
|
|
|
IConnection,
|
|
|
|
INode,
|
|
|
|
INodeNameIndex,
|
|
|
|
INodesGraph,
|
|
|
|
INodeGraphItem,
|
|
|
|
INodesGraphResult,
|
|
|
|
IWorkflowBase,
|
|
|
|
INodeTypes,
|
|
|
|
IDataObject,
|
2024-10-15 03:38:17 -07:00
|
|
|
IRunData,
|
|
|
|
ITaskData,
|
2024-09-18 00:19:33 -07:00
|
|
|
} from './Interfaces';
|
|
|
|
import { getNodeParameters } from './NodeHelpers';
|
feat(editor): Add Workflow Stickies (Notes) (#3154)
* N8N-3029 Add Node Type for Wokrflow Stickies/Notes
* N8N-3029 Update Content, Update Aliasses
* N8N-3030 Created N8N Sticky Component in Design System
* N8N-3030 Fixed Code spaccing Sticky Component
* N8N-3030 Fixed Code spaccing StickyStories Component
* N8N-3030 Fixed Code spaccing Markdown Component
* N8N-3030 Added Sticky Colors Pallete into Storybook, Update Color Variables for Sticky Component
* N8N-3030 Added Unfocus Event
* N8N-3030 Update Default Placeholder, Markdown Styles, Fixed Edit State, Added Text to EditState, Fixed Height of Area, Turned off Resize of textarea
* N8N-3030 Update Sticky Overflow, Update Hover States, Updated Markdown Overflow
* N8N-3030, N8N-3031 - Add Resize to Sticky, Created N8n-Resize component
* N8N-3031 Fixed Importing Components in Editor-ui
* N8N-3031 Fixed Resize Component, Fixed Gradient
* N8N-3030, N8N-3031 Update Note Description
* N8N-3032 Hotfix Building Storybook
* N8N-3032 - Select Behaviour, Changes in Resize Component, Emit on Width/Height/Top/Left Change
* N8N-3032 Update Resize Component to emmit left/top, Update Dynamic Resize on Selected Background
* N8N-3032 Updated / Dragging vs Resizing, prevent open Modal for stickies
* N8N-3032 Added ID props to n8n-sticky // dynamic id for multi resizing in NodeView
* N8N-3033 Add dynamic size Tooltip on Sticky
* N8N-3033 Updated Z-index for Sticky Component
* N8N-3033 Updated N8N-Resize Component, Fixed SelectedBackround for Sticky Component
* N8N-3033 Refactor
* N8N-3033 Focus/Defocus on TextArea
* N8N-3033 Fixed Resizing on NW Point
* N8N-3030 Save content in vuex on input change
* N8N-3033 Fixed Resizer, Save Width and Height in Vue
* N8N-3033 Hide Sticky Footer on small height/width
* N8N-3033 Fixed Resizer
* N8N-3033 Dynamic Z-index for Stickies
* N8N-3033 Dynamic Z-index for Stickies
* N8N-3033 Removed static z-index for select sticky class
* N8N-3034 Added Telemetry
* N8N-3030 Formatter
* N8N-3030 Format code
* N8N-3030 Fixed Selecting Stickies
* N8N-3033 Fixed Notifications
* N8N-3030 Added new paddings for Default Stickies
* N8N-3033 Prevent Scrolling NodeView when Sticky is in Edit mode and Mouse is Over the TextArea
* N8N-3030 Prevent double clicking to switch state of Sticky component in Edit Mode
* N8N-3033 Fixed Z-index of Stickies
* N8N-3033 Prevent delete node when in EditMode
* N8N-3030 Prevent Delete Button to delete the Sticky while in Edit Mode
* N8N-3030 Change EditMode (emit) on keyboard shortucts, update Markdown Links & Images, Added new props
* N8N-3030 Sticky Component - No padding when hiding footer text
* N8N-3033 Fix Resizing enter into Edit Mode
* N8N-3033 Selecting different nodes - exit the edit mode
* N8N-3033 Auto Select Text in text-area by default - Sticky Component
* N8N-3033 Prevent Default behaviour for CTRL + X, CTRL + A when Sticky is Active && inEditMode
* N8N-3033 Refactor Resizer, Refactor Sticky, Update zIndex inEditMode
* N8N-3033 Updated Default Text // Node-base, Storybook
* N8N-3033 Add Resizing in EditMode - Components update
* N8N-3033 Fixed Footer - Show/Hide on Resize in EditMode
* N8N-3033 Fix ActiveSticky on Init
* N8N-3033 Refactor Sticky in Vuex, Fixed Init Sticky Tweaks, Prevent Modal Openning, Save on Keyboard shortcuts
* Stickies - Update Note node with new props
* N8N-3030 Updated Default Note text, Update the Markdown Link
* N8N-3030 CMD-C does not copy the text fix
* N8N-3030 Fix Max Zoom / Zoom out shortcuts disabled in editState
* N8N-3030 Z-index fixed during Edit Mode typing
* N8N-3030 Prevent Autoselect Text in Stickies if the text is not default
* N8N-3030 Fixed ReadOnly Bugs / Prevent showing Tooltip, Resizing
* N8N-3030 Added Sticky Creator Button
* N8N-3030 Update Icon / Sticky Creator Button
* N8N-3033 Update Sticky Icon / StickyCreator Button
* update package lock
* 🔩 update note props
* 🚿 clean props
* 🔧 linting
* :wrench: fix spacing
* remove resize component
* remove resize component
* ✂ clean up sticky
* revert back to height width
* revert back to height/width
* replace zindex property
* replace default text property
* use i18n to translate
* update package lock
* move resize
* clean up how height/width are set
* fix resize for sticky to support left/top
* clean up resize
* fix lasso/highlight bug
* remove unused props
* fix zoom to fit
* fix padding for demo view
* fix readonly
* remove iseditable, use active state
* clean up keyboard events
* chang button size, no edit on insert
* scale resizing correctly
* make active on resize
* fix select on resize/move
* use outline icon
* allow for multiple line breaks
* fix multi line bug
* fix edit mode outline
* keep edit open as one resizes
* respect multiple spaces
* fix scrolling bug
* clean up hover impl
* clean up references to note
* disable for rename
* fix drifting while drag
* fix mouse cursor on resize
* fix sticky min height
* refactor resize into component
* fix pulling too far bug
* fix delete/cut all bug
* fix padding bottom
* fix active change on resize
* add transition to button
* Fix sticky markdown click
* add solid fa icon
* update node graph, telemetry event
* add snapping
* change alt text
* update package lock
* fix bug in button hover
* add back transition
* clean up resize
* add grid size as param
* remove breaks
* clean up markdown
* lint fixes
* fix spacing
* clean up markdown colors
* clean up classes in resize
* clean up resize
* update sticky story
* fix spacing
* clean up classes
* revert change
* revert change
* revert change
* clean up sticky component
* remove unused component
* remove unnessary data
* remove unnessary data
* clean up actions
* clean up sticky size
* clean up unnessary border style
* fix bug
* replace sticky note name
* update description
* remove support for multi spaces
* update tracking name
* update telemetry reqs
* fix enter bug
* update alt text
* update sticky notes doc url
* fix readonly bug
* update class name
* update quote marks
Co-authored-by: SchnapsterDog <olivertrajceski@yahoo.com>
2022-04-25 03:38:37 -07:00
|
|
|
|
2021-10-18 20:57:49 -07:00
|
|
|
export function getNodeTypeForName(workflow: IWorkflowBase, nodeName: string): INode | undefined {
|
|
|
|
return workflow.nodes.find((node) => node.name === nodeName);
|
|
|
|
}
|
|
|
|
|
feat(editor): Add Workflow Stickies (Notes) (#3154)
* N8N-3029 Add Node Type for Wokrflow Stickies/Notes
* N8N-3029 Update Content, Update Aliasses
* N8N-3030 Created N8N Sticky Component in Design System
* N8N-3030 Fixed Code spaccing Sticky Component
* N8N-3030 Fixed Code spaccing StickyStories Component
* N8N-3030 Fixed Code spaccing Markdown Component
* N8N-3030 Added Sticky Colors Pallete into Storybook, Update Color Variables for Sticky Component
* N8N-3030 Added Unfocus Event
* N8N-3030 Update Default Placeholder, Markdown Styles, Fixed Edit State, Added Text to EditState, Fixed Height of Area, Turned off Resize of textarea
* N8N-3030 Update Sticky Overflow, Update Hover States, Updated Markdown Overflow
* N8N-3030, N8N-3031 - Add Resize to Sticky, Created N8n-Resize component
* N8N-3031 Fixed Importing Components in Editor-ui
* N8N-3031 Fixed Resize Component, Fixed Gradient
* N8N-3030, N8N-3031 Update Note Description
* N8N-3032 Hotfix Building Storybook
* N8N-3032 - Select Behaviour, Changes in Resize Component, Emit on Width/Height/Top/Left Change
* N8N-3032 Update Resize Component to emmit left/top, Update Dynamic Resize on Selected Background
* N8N-3032 Updated / Dragging vs Resizing, prevent open Modal for stickies
* N8N-3032 Added ID props to n8n-sticky // dynamic id for multi resizing in NodeView
* N8N-3033 Add dynamic size Tooltip on Sticky
* N8N-3033 Updated Z-index for Sticky Component
* N8N-3033 Updated N8N-Resize Component, Fixed SelectedBackround for Sticky Component
* N8N-3033 Refactor
* N8N-3033 Focus/Defocus on TextArea
* N8N-3033 Fixed Resizing on NW Point
* N8N-3030 Save content in vuex on input change
* N8N-3033 Fixed Resizer, Save Width and Height in Vue
* N8N-3033 Hide Sticky Footer on small height/width
* N8N-3033 Fixed Resizer
* N8N-3033 Dynamic Z-index for Stickies
* N8N-3033 Dynamic Z-index for Stickies
* N8N-3033 Removed static z-index for select sticky class
* N8N-3034 Added Telemetry
* N8N-3030 Formatter
* N8N-3030 Format code
* N8N-3030 Fixed Selecting Stickies
* N8N-3033 Fixed Notifications
* N8N-3030 Added new paddings for Default Stickies
* N8N-3033 Prevent Scrolling NodeView when Sticky is in Edit mode and Mouse is Over the TextArea
* N8N-3030 Prevent double clicking to switch state of Sticky component in Edit Mode
* N8N-3033 Fixed Z-index of Stickies
* N8N-3033 Prevent delete node when in EditMode
* N8N-3030 Prevent Delete Button to delete the Sticky while in Edit Mode
* N8N-3030 Change EditMode (emit) on keyboard shortucts, update Markdown Links & Images, Added new props
* N8N-3030 Sticky Component - No padding when hiding footer text
* N8N-3033 Fix Resizing enter into Edit Mode
* N8N-3033 Selecting different nodes - exit the edit mode
* N8N-3033 Auto Select Text in text-area by default - Sticky Component
* N8N-3033 Prevent Default behaviour for CTRL + X, CTRL + A when Sticky is Active && inEditMode
* N8N-3033 Refactor Resizer, Refactor Sticky, Update zIndex inEditMode
* N8N-3033 Updated Default Text // Node-base, Storybook
* N8N-3033 Add Resizing in EditMode - Components update
* N8N-3033 Fixed Footer - Show/Hide on Resize in EditMode
* N8N-3033 Fix ActiveSticky on Init
* N8N-3033 Refactor Sticky in Vuex, Fixed Init Sticky Tweaks, Prevent Modal Openning, Save on Keyboard shortcuts
* Stickies - Update Note node with new props
* N8N-3030 Updated Default Note text, Update the Markdown Link
* N8N-3030 CMD-C does not copy the text fix
* N8N-3030 Fix Max Zoom / Zoom out shortcuts disabled in editState
* N8N-3030 Z-index fixed during Edit Mode typing
* N8N-3030 Prevent Autoselect Text in Stickies if the text is not default
* N8N-3030 Fixed ReadOnly Bugs / Prevent showing Tooltip, Resizing
* N8N-3030 Added Sticky Creator Button
* N8N-3030 Update Icon / Sticky Creator Button
* N8N-3033 Update Sticky Icon / StickyCreator Button
* update package lock
* 🔩 update note props
* 🚿 clean props
* 🔧 linting
* :wrench: fix spacing
* remove resize component
* remove resize component
* ✂ clean up sticky
* revert back to height width
* revert back to height/width
* replace zindex property
* replace default text property
* use i18n to translate
* update package lock
* move resize
* clean up how height/width are set
* fix resize for sticky to support left/top
* clean up resize
* fix lasso/highlight bug
* remove unused props
* fix zoom to fit
* fix padding for demo view
* fix readonly
* remove iseditable, use active state
* clean up keyboard events
* chang button size, no edit on insert
* scale resizing correctly
* make active on resize
* fix select on resize/move
* use outline icon
* allow for multiple line breaks
* fix multi line bug
* fix edit mode outline
* keep edit open as one resizes
* respect multiple spaces
* fix scrolling bug
* clean up hover impl
* clean up references to note
* disable for rename
* fix drifting while drag
* fix mouse cursor on resize
* fix sticky min height
* refactor resize into component
* fix pulling too far bug
* fix delete/cut all bug
* fix padding bottom
* fix active change on resize
* add transition to button
* Fix sticky markdown click
* add solid fa icon
* update node graph, telemetry event
* add snapping
* change alt text
* update package lock
* fix bug in button hover
* add back transition
* clean up resize
* add grid size as param
* remove breaks
* clean up markdown
* lint fixes
* fix spacing
* clean up markdown colors
* clean up classes in resize
* clean up resize
* update sticky story
* fix spacing
* clean up classes
* revert change
* revert change
* revert change
* clean up sticky component
* remove unused component
* remove unnessary data
* remove unnessary data
* clean up actions
* clean up sticky size
* clean up unnessary border style
* fix bug
* replace sticky note name
* update description
* remove support for multi spaces
* update tracking name
* update telemetry reqs
* fix enter bug
* update alt text
* update sticky notes doc url
* fix readonly bug
* update class name
* update quote marks
Co-authored-by: SchnapsterDog <olivertrajceski@yahoo.com>
2022-04-25 03:38:37 -07:00
|
|
|
export function isNumber(value: unknown): value is number {
|
|
|
|
return typeof value === 'number';
|
|
|
|
}
|
|
|
|
|
2024-06-19 00:54:13 -07:00
|
|
|
const countPlaceholders = (text: string) => {
|
|
|
|
const placeholder = /(\{[a-zA-Z0-9_]+\})/g;
|
|
|
|
let returnData = 0;
|
|
|
|
|
|
|
|
try {
|
|
|
|
const matches = text.matchAll(placeholder);
|
|
|
|
for (const _ of matches) returnData++;
|
|
|
|
} catch (error) {}
|
|
|
|
|
|
|
|
return returnData;
|
|
|
|
};
|
|
|
|
|
|
|
|
const countPlaceholdersInParameters = (parameters: IDataObject[]) => {
|
|
|
|
let returnData = 0;
|
|
|
|
|
|
|
|
for (const parameter of parameters) {
|
|
|
|
if (!parameter.value) {
|
|
|
|
//count parameters provided by model
|
|
|
|
returnData++;
|
|
|
|
} else {
|
|
|
|
//check if any placeholders in user provided value
|
|
|
|
returnData += countPlaceholders(String(parameter.value));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return returnData;
|
|
|
|
};
|
|
|
|
|
feat(editor): Add Workflow Stickies (Notes) (#3154)
* N8N-3029 Add Node Type for Wokrflow Stickies/Notes
* N8N-3029 Update Content, Update Aliasses
* N8N-3030 Created N8N Sticky Component in Design System
* N8N-3030 Fixed Code spaccing Sticky Component
* N8N-3030 Fixed Code spaccing StickyStories Component
* N8N-3030 Fixed Code spaccing Markdown Component
* N8N-3030 Added Sticky Colors Pallete into Storybook, Update Color Variables for Sticky Component
* N8N-3030 Added Unfocus Event
* N8N-3030 Update Default Placeholder, Markdown Styles, Fixed Edit State, Added Text to EditState, Fixed Height of Area, Turned off Resize of textarea
* N8N-3030 Update Sticky Overflow, Update Hover States, Updated Markdown Overflow
* N8N-3030, N8N-3031 - Add Resize to Sticky, Created N8n-Resize component
* N8N-3031 Fixed Importing Components in Editor-ui
* N8N-3031 Fixed Resize Component, Fixed Gradient
* N8N-3030, N8N-3031 Update Note Description
* N8N-3032 Hotfix Building Storybook
* N8N-3032 - Select Behaviour, Changes in Resize Component, Emit on Width/Height/Top/Left Change
* N8N-3032 Update Resize Component to emmit left/top, Update Dynamic Resize on Selected Background
* N8N-3032 Updated / Dragging vs Resizing, prevent open Modal for stickies
* N8N-3032 Added ID props to n8n-sticky // dynamic id for multi resizing in NodeView
* N8N-3033 Add dynamic size Tooltip on Sticky
* N8N-3033 Updated Z-index for Sticky Component
* N8N-3033 Updated N8N-Resize Component, Fixed SelectedBackround for Sticky Component
* N8N-3033 Refactor
* N8N-3033 Focus/Defocus on TextArea
* N8N-3033 Fixed Resizing on NW Point
* N8N-3030 Save content in vuex on input change
* N8N-3033 Fixed Resizer, Save Width and Height in Vue
* N8N-3033 Hide Sticky Footer on small height/width
* N8N-3033 Fixed Resizer
* N8N-3033 Dynamic Z-index for Stickies
* N8N-3033 Dynamic Z-index for Stickies
* N8N-3033 Removed static z-index for select sticky class
* N8N-3034 Added Telemetry
* N8N-3030 Formatter
* N8N-3030 Format code
* N8N-3030 Fixed Selecting Stickies
* N8N-3033 Fixed Notifications
* N8N-3030 Added new paddings for Default Stickies
* N8N-3033 Prevent Scrolling NodeView when Sticky is in Edit mode and Mouse is Over the TextArea
* N8N-3030 Prevent double clicking to switch state of Sticky component in Edit Mode
* N8N-3033 Fixed Z-index of Stickies
* N8N-3033 Prevent delete node when in EditMode
* N8N-3030 Prevent Delete Button to delete the Sticky while in Edit Mode
* N8N-3030 Change EditMode (emit) on keyboard shortucts, update Markdown Links & Images, Added new props
* N8N-3030 Sticky Component - No padding when hiding footer text
* N8N-3033 Fix Resizing enter into Edit Mode
* N8N-3033 Selecting different nodes - exit the edit mode
* N8N-3033 Auto Select Text in text-area by default - Sticky Component
* N8N-3033 Prevent Default behaviour for CTRL + X, CTRL + A when Sticky is Active && inEditMode
* N8N-3033 Refactor Resizer, Refactor Sticky, Update zIndex inEditMode
* N8N-3033 Updated Default Text // Node-base, Storybook
* N8N-3033 Add Resizing in EditMode - Components update
* N8N-3033 Fixed Footer - Show/Hide on Resize in EditMode
* N8N-3033 Fix ActiveSticky on Init
* N8N-3033 Refactor Sticky in Vuex, Fixed Init Sticky Tweaks, Prevent Modal Openning, Save on Keyboard shortcuts
* Stickies - Update Note node with new props
* N8N-3030 Updated Default Note text, Update the Markdown Link
* N8N-3030 CMD-C does not copy the text fix
* N8N-3030 Fix Max Zoom / Zoom out shortcuts disabled in editState
* N8N-3030 Z-index fixed during Edit Mode typing
* N8N-3030 Prevent Autoselect Text in Stickies if the text is not default
* N8N-3030 Fixed ReadOnly Bugs / Prevent showing Tooltip, Resizing
* N8N-3030 Added Sticky Creator Button
* N8N-3030 Update Icon / Sticky Creator Button
* N8N-3033 Update Sticky Icon / StickyCreator Button
* update package lock
* 🔩 update note props
* 🚿 clean props
* 🔧 linting
* :wrench: fix spacing
* remove resize component
* remove resize component
* ✂ clean up sticky
* revert back to height width
* revert back to height/width
* replace zindex property
* replace default text property
* use i18n to translate
* update package lock
* move resize
* clean up how height/width are set
* fix resize for sticky to support left/top
* clean up resize
* fix lasso/highlight bug
* remove unused props
* fix zoom to fit
* fix padding for demo view
* fix readonly
* remove iseditable, use active state
* clean up keyboard events
* chang button size, no edit on insert
* scale resizing correctly
* make active on resize
* fix select on resize/move
* use outline icon
* allow for multiple line breaks
* fix multi line bug
* fix edit mode outline
* keep edit open as one resizes
* respect multiple spaces
* fix scrolling bug
* clean up hover impl
* clean up references to note
* disable for rename
* fix drifting while drag
* fix mouse cursor on resize
* fix sticky min height
* refactor resize into component
* fix pulling too far bug
* fix delete/cut all bug
* fix padding bottom
* fix active change on resize
* add transition to button
* Fix sticky markdown click
* add solid fa icon
* update node graph, telemetry event
* add snapping
* change alt text
* update package lock
* fix bug in button hover
* add back transition
* clean up resize
* add grid size as param
* remove breaks
* clean up markdown
* lint fixes
* fix spacing
* clean up markdown colors
* clean up classes in resize
* clean up resize
* update sticky story
* fix spacing
* clean up classes
* revert change
* revert change
* revert change
* clean up sticky component
* remove unused component
* remove unnessary data
* remove unnessary data
* clean up actions
* clean up sticky size
* clean up unnessary border style
* fix bug
* replace sticky note name
* update description
* remove support for multi spaces
* update tracking name
* update telemetry reqs
* fix enter bug
* update alt text
* update sticky notes doc url
* fix readonly bug
* update class name
* update quote marks
Co-authored-by: SchnapsterDog <olivertrajceski@yahoo.com>
2022-04-25 03:38:37 -07:00
|
|
|
type XYPosition = [number, number];
|
|
|
|
|
|
|
|
function areOverlapping(
|
|
|
|
topLeft: XYPosition,
|
|
|
|
bottomRight: XYPosition,
|
|
|
|
targetPos: XYPosition,
|
|
|
|
): boolean {
|
|
|
|
return (
|
|
|
|
targetPos[0] > topLeft[0] &&
|
|
|
|
targetPos[1] > topLeft[1] &&
|
|
|
|
targetPos[0] < bottomRight[0] &&
|
|
|
|
targetPos[1] < bottomRight[1]
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2022-05-24 02:36:19 -07:00
|
|
|
const URL_PARTS_REGEX = /(?<protocolPlusDomain>.*?\..*?)(?<pathname>\/.*)/;
|
|
|
|
|
|
|
|
export function getDomainBase(raw: string, urlParts = URL_PARTS_REGEX): string {
|
|
|
|
try {
|
|
|
|
const url = new URL(raw);
|
|
|
|
|
|
|
|
return [url.protocol, url.hostname].join('//');
|
2023-03-03 09:18:49 -08:00
|
|
|
} catch {
|
2022-05-24 02:36:19 -07:00
|
|
|
const match = urlParts.exec(raw);
|
|
|
|
|
|
|
|
if (!match?.groups?.protocolPlusDomain) return '';
|
|
|
|
|
|
|
|
return match.groups.protocolPlusDomain;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
function isSensitive(segment: string) {
|
|
|
|
if (/^v\d+$/.test(segment)) return false;
|
|
|
|
|
|
|
|
return /%40/.test(segment) || /\d/.test(segment) || /^[0-9A-F]{8}/i.test(segment);
|
|
|
|
}
|
|
|
|
|
|
|
|
export const ANONYMIZATION_CHARACTER = '*';
|
|
|
|
|
|
|
|
function sanitizeRoute(raw: string, check = isSensitive, char = ANONYMIZATION_CHARACTER) {
|
|
|
|
return raw
|
|
|
|
.split('/')
|
|
|
|
.map((segment) => (check(segment) ? char.repeat(segment.length) : segment))
|
|
|
|
.join('/');
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Return pathname plus query string from URL, anonymizing IDs in route and query params.
|
|
|
|
*/
|
|
|
|
export function getDomainPath(raw: string, urlParts = URL_PARTS_REGEX): string {
|
|
|
|
try {
|
|
|
|
const url = new URL(raw);
|
|
|
|
|
2023-11-30 03:46:45 -08:00
|
|
|
if (!url.hostname) throw new ApplicationError('Malformed URL');
|
2022-05-24 02:36:19 -07:00
|
|
|
|
|
|
|
return sanitizeRoute(url.pathname);
|
2023-03-03 09:18:49 -08:00
|
|
|
} catch {
|
2022-05-24 02:36:19 -07:00
|
|
|
const match = urlParts.exec(raw);
|
|
|
|
|
|
|
|
if (!match?.groups?.pathname) return '';
|
|
|
|
|
|
|
|
// discard query string
|
|
|
|
const route = match.groups.pathname.split('?').shift() as string;
|
|
|
|
|
|
|
|
return sanitizeRoute(route);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2024-10-15 03:38:17 -07:00
|
|
|
function getNumberOfItemsInRuns(runs: ITaskData[]): number {
|
|
|
|
return runs.reduce((total, run) => {
|
|
|
|
const data = run.data ?? {};
|
|
|
|
let count = 0;
|
|
|
|
Object.keys(data).forEach((type) => {
|
|
|
|
const conn = data[type] ?? [];
|
|
|
|
conn.forEach((branch) => {
|
|
|
|
count += (branch ?? []).length;
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
return total + count;
|
|
|
|
}, 0);
|
|
|
|
}
|
|
|
|
|
2022-01-07 08:14:59 -08:00
|
|
|
export function generateNodesGraph(
|
2024-01-11 04:25:40 -08:00
|
|
|
workflow: Partial<IWorkflowBase>,
|
2022-01-07 08:14:59 -08:00
|
|
|
nodeTypes: INodeTypes,
|
2022-08-03 04:06:53 -07:00
|
|
|
options?: {
|
|
|
|
sourceInstanceId?: string;
|
|
|
|
nodeIdMap?: { [curr: string]: string };
|
2024-03-07 02:46:07 -08:00
|
|
|
isCloudDeployment?: boolean;
|
2024-10-15 03:38:17 -07:00
|
|
|
runData?: IRunData;
|
2022-08-03 04:06:53 -07:00
|
|
|
},
|
2022-01-07 08:14:59 -08:00
|
|
|
): INodesGraphResult {
|
2024-10-15 03:38:17 -07:00
|
|
|
const { runData } = options ?? {};
|
2024-01-11 04:25:40 -08:00
|
|
|
const nodeGraph: INodesGraph = {
|
2021-10-18 20:57:49 -07:00
|
|
|
node_types: [],
|
|
|
|
node_connections: [],
|
|
|
|
nodes: {},
|
feat(editor): Add Workflow Stickies (Notes) (#3154)
* N8N-3029 Add Node Type for Wokrflow Stickies/Notes
* N8N-3029 Update Content, Update Aliasses
* N8N-3030 Created N8N Sticky Component in Design System
* N8N-3030 Fixed Code spaccing Sticky Component
* N8N-3030 Fixed Code spaccing StickyStories Component
* N8N-3030 Fixed Code spaccing Markdown Component
* N8N-3030 Added Sticky Colors Pallete into Storybook, Update Color Variables for Sticky Component
* N8N-3030 Added Unfocus Event
* N8N-3030 Update Default Placeholder, Markdown Styles, Fixed Edit State, Added Text to EditState, Fixed Height of Area, Turned off Resize of textarea
* N8N-3030 Update Sticky Overflow, Update Hover States, Updated Markdown Overflow
* N8N-3030, N8N-3031 - Add Resize to Sticky, Created N8n-Resize component
* N8N-3031 Fixed Importing Components in Editor-ui
* N8N-3031 Fixed Resize Component, Fixed Gradient
* N8N-3030, N8N-3031 Update Note Description
* N8N-3032 Hotfix Building Storybook
* N8N-3032 - Select Behaviour, Changes in Resize Component, Emit on Width/Height/Top/Left Change
* N8N-3032 Update Resize Component to emmit left/top, Update Dynamic Resize on Selected Background
* N8N-3032 Updated / Dragging vs Resizing, prevent open Modal for stickies
* N8N-3032 Added ID props to n8n-sticky // dynamic id for multi resizing in NodeView
* N8N-3033 Add dynamic size Tooltip on Sticky
* N8N-3033 Updated Z-index for Sticky Component
* N8N-3033 Updated N8N-Resize Component, Fixed SelectedBackround for Sticky Component
* N8N-3033 Refactor
* N8N-3033 Focus/Defocus on TextArea
* N8N-3033 Fixed Resizing on NW Point
* N8N-3030 Save content in vuex on input change
* N8N-3033 Fixed Resizer, Save Width and Height in Vue
* N8N-3033 Hide Sticky Footer on small height/width
* N8N-3033 Fixed Resizer
* N8N-3033 Dynamic Z-index for Stickies
* N8N-3033 Dynamic Z-index for Stickies
* N8N-3033 Removed static z-index for select sticky class
* N8N-3034 Added Telemetry
* N8N-3030 Formatter
* N8N-3030 Format code
* N8N-3030 Fixed Selecting Stickies
* N8N-3033 Fixed Notifications
* N8N-3030 Added new paddings for Default Stickies
* N8N-3033 Prevent Scrolling NodeView when Sticky is in Edit mode and Mouse is Over the TextArea
* N8N-3030 Prevent double clicking to switch state of Sticky component in Edit Mode
* N8N-3033 Fixed Z-index of Stickies
* N8N-3033 Prevent delete node when in EditMode
* N8N-3030 Prevent Delete Button to delete the Sticky while in Edit Mode
* N8N-3030 Change EditMode (emit) on keyboard shortucts, update Markdown Links & Images, Added new props
* N8N-3030 Sticky Component - No padding when hiding footer text
* N8N-3033 Fix Resizing enter into Edit Mode
* N8N-3033 Selecting different nodes - exit the edit mode
* N8N-3033 Auto Select Text in text-area by default - Sticky Component
* N8N-3033 Prevent Default behaviour for CTRL + X, CTRL + A when Sticky is Active && inEditMode
* N8N-3033 Refactor Resizer, Refactor Sticky, Update zIndex inEditMode
* N8N-3033 Updated Default Text // Node-base, Storybook
* N8N-3033 Add Resizing in EditMode - Components update
* N8N-3033 Fixed Footer - Show/Hide on Resize in EditMode
* N8N-3033 Fix ActiveSticky on Init
* N8N-3033 Refactor Sticky in Vuex, Fixed Init Sticky Tweaks, Prevent Modal Openning, Save on Keyboard shortcuts
* Stickies - Update Note node with new props
* N8N-3030 Updated Default Note text, Update the Markdown Link
* N8N-3030 CMD-C does not copy the text fix
* N8N-3030 Fix Max Zoom / Zoom out shortcuts disabled in editState
* N8N-3030 Z-index fixed during Edit Mode typing
* N8N-3030 Prevent Autoselect Text in Stickies if the text is not default
* N8N-3030 Fixed ReadOnly Bugs / Prevent showing Tooltip, Resizing
* N8N-3030 Added Sticky Creator Button
* N8N-3030 Update Icon / Sticky Creator Button
* N8N-3033 Update Sticky Icon / StickyCreator Button
* update package lock
* 🔩 update note props
* 🚿 clean props
* 🔧 linting
* :wrench: fix spacing
* remove resize component
* remove resize component
* ✂ clean up sticky
* revert back to height width
* revert back to height/width
* replace zindex property
* replace default text property
* use i18n to translate
* update package lock
* move resize
* clean up how height/width are set
* fix resize for sticky to support left/top
* clean up resize
* fix lasso/highlight bug
* remove unused props
* fix zoom to fit
* fix padding for demo view
* fix readonly
* remove iseditable, use active state
* clean up keyboard events
* chang button size, no edit on insert
* scale resizing correctly
* make active on resize
* fix select on resize/move
* use outline icon
* allow for multiple line breaks
* fix multi line bug
* fix edit mode outline
* keep edit open as one resizes
* respect multiple spaces
* fix scrolling bug
* clean up hover impl
* clean up references to note
* disable for rename
* fix drifting while drag
* fix mouse cursor on resize
* fix sticky min height
* refactor resize into component
* fix pulling too far bug
* fix delete/cut all bug
* fix padding bottom
* fix active change on resize
* add transition to button
* Fix sticky markdown click
* add solid fa icon
* update node graph, telemetry event
* add snapping
* change alt text
* update package lock
* fix bug in button hover
* add back transition
* clean up resize
* add grid size as param
* remove breaks
* clean up markdown
* lint fixes
* fix spacing
* clean up markdown colors
* clean up classes in resize
* clean up resize
* update sticky story
* fix spacing
* clean up classes
* revert change
* revert change
* revert change
* clean up sticky component
* remove unused component
* remove unnessary data
* remove unnessary data
* clean up actions
* clean up sticky size
* clean up unnessary border style
* fix bug
* replace sticky note name
* update description
* remove support for multi spaces
* update tracking name
* update telemetry reqs
* fix enter bug
* update alt text
* update sticky notes doc url
* fix readonly bug
* update class name
* update quote marks
Co-authored-by: SchnapsterDog <olivertrajceski@yahoo.com>
2022-04-25 03:38:37 -07:00
|
|
|
notes: {},
|
2022-07-20 08:50:39 -07:00
|
|
|
is_pinned: Object.keys(workflow.pinData ?? {}).length > 0,
|
2021-10-18 20:57:49 -07:00
|
|
|
};
|
2024-01-11 04:25:40 -08:00
|
|
|
const nameIndices: INodeNameIndex = {};
|
2022-07-09 23:53:04 -07:00
|
|
|
const webhookNodeNames: string[] = [];
|
2021-10-18 20:57:49 -07:00
|
|
|
|
2024-01-11 04:25:40 -08:00
|
|
|
const notes = (workflow.nodes ?? []).filter((node) => node.type === STICKY_NODE_TYPE);
|
|
|
|
const otherNodes = (workflow.nodes ?? []).filter((node) => node.type !== STICKY_NODE_TYPE);
|
|
|
|
|
|
|
|
notes.forEach((stickyNote: INode, index: number) => {
|
|
|
|
const stickyType = nodeTypes.getByNameAndVersion(STICKY_NODE_TYPE, stickyNote.typeVersion);
|
|
|
|
if (!stickyType) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2024-04-30 02:39:24 -07:00
|
|
|
let nodeParameters: IDataObject = {};
|
|
|
|
|
|
|
|
try {
|
|
|
|
nodeParameters =
|
|
|
|
getNodeParameters(
|
|
|
|
stickyType.description.properties,
|
|
|
|
stickyNote.parameters,
|
|
|
|
true,
|
|
|
|
false,
|
|
|
|
stickyNote,
|
|
|
|
) ?? {};
|
|
|
|
} catch {
|
|
|
|
// prevent node param resolution from failing graph generation
|
|
|
|
}
|
2024-01-11 04:25:40 -08:00
|
|
|
|
|
|
|
const height: number = typeof nodeParameters.height === 'number' ? nodeParameters.height : 0;
|
|
|
|
const width: number = typeof nodeParameters.width === 'number' ? nodeParameters.width : 0;
|
|
|
|
|
|
|
|
const topLeft = stickyNote.position;
|
|
|
|
const bottomRight: [number, number] = [topLeft[0] + width, topLeft[1] + height];
|
|
|
|
const overlapping = Boolean(
|
|
|
|
otherNodes.find((node) => areOverlapping(topLeft, bottomRight, node.position)),
|
|
|
|
);
|
|
|
|
nodeGraph.notes[index] = {
|
|
|
|
overlapping,
|
|
|
|
position: topLeft,
|
|
|
|
height,
|
|
|
|
width,
|
|
|
|
};
|
|
|
|
});
|
|
|
|
|
2024-04-10 05:02:02 -07:00
|
|
|
// eslint-disable-next-line complexity
|
2024-01-11 04:25:40 -08:00
|
|
|
otherNodes.forEach((node: INode, index: number) => {
|
|
|
|
nodeGraph.node_types.push(node.type);
|
|
|
|
const nodeItem: INodeGraphItem = {
|
|
|
|
id: node.id,
|
|
|
|
type: node.type,
|
|
|
|
version: node.typeVersion,
|
|
|
|
position: node.position,
|
|
|
|
};
|
feat(editor): Add Workflow Stickies (Notes) (#3154)
* N8N-3029 Add Node Type for Wokrflow Stickies/Notes
* N8N-3029 Update Content, Update Aliasses
* N8N-3030 Created N8N Sticky Component in Design System
* N8N-3030 Fixed Code spaccing Sticky Component
* N8N-3030 Fixed Code spaccing StickyStories Component
* N8N-3030 Fixed Code spaccing Markdown Component
* N8N-3030 Added Sticky Colors Pallete into Storybook, Update Color Variables for Sticky Component
* N8N-3030 Added Unfocus Event
* N8N-3030 Update Default Placeholder, Markdown Styles, Fixed Edit State, Added Text to EditState, Fixed Height of Area, Turned off Resize of textarea
* N8N-3030 Update Sticky Overflow, Update Hover States, Updated Markdown Overflow
* N8N-3030, N8N-3031 - Add Resize to Sticky, Created N8n-Resize component
* N8N-3031 Fixed Importing Components in Editor-ui
* N8N-3031 Fixed Resize Component, Fixed Gradient
* N8N-3030, N8N-3031 Update Note Description
* N8N-3032 Hotfix Building Storybook
* N8N-3032 - Select Behaviour, Changes in Resize Component, Emit on Width/Height/Top/Left Change
* N8N-3032 Update Resize Component to emmit left/top, Update Dynamic Resize on Selected Background
* N8N-3032 Updated / Dragging vs Resizing, prevent open Modal for stickies
* N8N-3032 Added ID props to n8n-sticky // dynamic id for multi resizing in NodeView
* N8N-3033 Add dynamic size Tooltip on Sticky
* N8N-3033 Updated Z-index for Sticky Component
* N8N-3033 Updated N8N-Resize Component, Fixed SelectedBackround for Sticky Component
* N8N-3033 Refactor
* N8N-3033 Focus/Defocus on TextArea
* N8N-3033 Fixed Resizing on NW Point
* N8N-3030 Save content in vuex on input change
* N8N-3033 Fixed Resizer, Save Width and Height in Vue
* N8N-3033 Hide Sticky Footer on small height/width
* N8N-3033 Fixed Resizer
* N8N-3033 Dynamic Z-index for Stickies
* N8N-3033 Dynamic Z-index for Stickies
* N8N-3033 Removed static z-index for select sticky class
* N8N-3034 Added Telemetry
* N8N-3030 Formatter
* N8N-3030 Format code
* N8N-3030 Fixed Selecting Stickies
* N8N-3033 Fixed Notifications
* N8N-3030 Added new paddings for Default Stickies
* N8N-3033 Prevent Scrolling NodeView when Sticky is in Edit mode and Mouse is Over the TextArea
* N8N-3030 Prevent double clicking to switch state of Sticky component in Edit Mode
* N8N-3033 Fixed Z-index of Stickies
* N8N-3033 Prevent delete node when in EditMode
* N8N-3030 Prevent Delete Button to delete the Sticky while in Edit Mode
* N8N-3030 Change EditMode (emit) on keyboard shortucts, update Markdown Links & Images, Added new props
* N8N-3030 Sticky Component - No padding when hiding footer text
* N8N-3033 Fix Resizing enter into Edit Mode
* N8N-3033 Selecting different nodes - exit the edit mode
* N8N-3033 Auto Select Text in text-area by default - Sticky Component
* N8N-3033 Prevent Default behaviour for CTRL + X, CTRL + A when Sticky is Active && inEditMode
* N8N-3033 Refactor Resizer, Refactor Sticky, Update zIndex inEditMode
* N8N-3033 Updated Default Text // Node-base, Storybook
* N8N-3033 Add Resizing in EditMode - Components update
* N8N-3033 Fixed Footer - Show/Hide on Resize in EditMode
* N8N-3033 Fix ActiveSticky on Init
* N8N-3033 Refactor Sticky in Vuex, Fixed Init Sticky Tweaks, Prevent Modal Openning, Save on Keyboard shortcuts
* Stickies - Update Note node with new props
* N8N-3030 Updated Default Note text, Update the Markdown Link
* N8N-3030 CMD-C does not copy the text fix
* N8N-3030 Fix Max Zoom / Zoom out shortcuts disabled in editState
* N8N-3030 Z-index fixed during Edit Mode typing
* N8N-3030 Prevent Autoselect Text in Stickies if the text is not default
* N8N-3030 Fixed ReadOnly Bugs / Prevent showing Tooltip, Resizing
* N8N-3030 Added Sticky Creator Button
* N8N-3030 Update Icon / Sticky Creator Button
* N8N-3033 Update Sticky Icon / StickyCreator Button
* update package lock
* 🔩 update note props
* 🚿 clean props
* 🔧 linting
* :wrench: fix spacing
* remove resize component
* remove resize component
* ✂ clean up sticky
* revert back to height width
* revert back to height/width
* replace zindex property
* replace default text property
* use i18n to translate
* update package lock
* move resize
* clean up how height/width are set
* fix resize for sticky to support left/top
* clean up resize
* fix lasso/highlight bug
* remove unused props
* fix zoom to fit
* fix padding for demo view
* fix readonly
* remove iseditable, use active state
* clean up keyboard events
* chang button size, no edit on insert
* scale resizing correctly
* make active on resize
* fix select on resize/move
* use outline icon
* allow for multiple line breaks
* fix multi line bug
* fix edit mode outline
* keep edit open as one resizes
* respect multiple spaces
* fix scrolling bug
* clean up hover impl
* clean up references to note
* disable for rename
* fix drifting while drag
* fix mouse cursor on resize
* fix sticky min height
* refactor resize into component
* fix pulling too far bug
* fix delete/cut all bug
* fix padding bottom
* fix active change on resize
* add transition to button
* Fix sticky markdown click
* add solid fa icon
* update node graph, telemetry event
* add snapping
* change alt text
* update package lock
* fix bug in button hover
* add back transition
* clean up resize
* add grid size as param
* remove breaks
* clean up markdown
* lint fixes
* fix spacing
* clean up markdown colors
* clean up classes in resize
* clean up resize
* update sticky story
* fix spacing
* clean up classes
* revert change
* revert change
* revert change
* clean up sticky component
* remove unused component
* remove unnessary data
* remove unnessary data
* clean up actions
* clean up sticky size
* clean up unnessary border style
* fix bug
* replace sticky note name
* update description
* remove support for multi spaces
* update tracking name
* update telemetry reqs
* fix enter bug
* update alt text
* update sticky notes doc url
* fix readonly bug
* update class name
* update quote marks
Co-authored-by: SchnapsterDog <olivertrajceski@yahoo.com>
2022-04-25 03:38:37 -07:00
|
|
|
|
2024-10-15 03:38:17 -07:00
|
|
|
if (runData?.[node.name]) {
|
|
|
|
const runs = runData[node.name] ?? [];
|
|
|
|
nodeItem.runs = runs.length;
|
|
|
|
|
|
|
|
nodeItem.items_total = getNumberOfItemsInRuns(runs);
|
|
|
|
}
|
|
|
|
|
2024-01-11 04:25:40 -08:00
|
|
|
if (options?.sourceInstanceId) {
|
|
|
|
nodeItem.src_instance_id = options.sourceInstanceId;
|
|
|
|
}
|
2022-08-03 04:06:53 -07:00
|
|
|
|
2024-01-11 04:25:40 -08:00
|
|
|
if (node.id && options?.nodeIdMap?.[node.id]) {
|
|
|
|
nodeItem.src_node_id = options.nodeIdMap[node.id];
|
|
|
|
}
|
2022-08-03 04:06:53 -07:00
|
|
|
|
2024-08-14 06:41:35 -07:00
|
|
|
if (node.type === AI_TRANSFORM_NODE_TYPE && options?.isCloudDeployment) {
|
|
|
|
nodeItem.prompts = { instructions: node.parameters.instructions as string };
|
|
|
|
} else if (node.type === AGENT_LANGCHAIN_NODE_TYPE) {
|
2024-03-27 08:16:02 -07:00
|
|
|
nodeItem.agent = (node.parameters.agent as string) ?? 'conversationalAgent';
|
2024-07-02 03:47:04 -07:00
|
|
|
} else if (node.type === MERGE_NODE_TYPE) {
|
|
|
|
nodeItem.operation = node.parameters.mode as string;
|
2024-03-07 02:46:07 -08:00
|
|
|
} else if (node.type === HTTP_REQUEST_NODE_TYPE && node.typeVersion === 1) {
|
2024-01-11 04:25:40 -08:00
|
|
|
try {
|
|
|
|
nodeItem.domain = new URL(node.parameters.url as string).hostname;
|
|
|
|
} catch {
|
|
|
|
nodeItem.domain = getDomainBase(node.parameters.url as string);
|
|
|
|
}
|
2024-03-07 02:46:07 -08:00
|
|
|
} else if (node.type === HTTP_REQUEST_NODE_TYPE && node.typeVersion > 1) {
|
2024-01-11 04:25:40 -08:00
|
|
|
const { authentication } = node.parameters as { authentication: string };
|
|
|
|
|
|
|
|
nodeItem.credential_type = {
|
|
|
|
none: 'none',
|
|
|
|
genericCredentialType: node.parameters.genericAuthType as string,
|
|
|
|
predefinedCredentialType: node.parameters.nodeCredentialType as string,
|
|
|
|
}[authentication];
|
|
|
|
|
|
|
|
nodeItem.credential_set = node.credentials ? Object.keys(node.credentials).length > 0 : false;
|
|
|
|
|
|
|
|
const { url } = node.parameters as { url: string };
|
|
|
|
|
|
|
|
nodeItem.domain_base = getDomainBase(url);
|
|
|
|
nodeItem.domain_path = getDomainPath(url);
|
|
|
|
nodeItem.method = node.parameters.requestMethod as string;
|
2024-06-19 00:54:13 -07:00
|
|
|
} else if (HTTP_REQUEST_TOOL_LANGCHAIN_NODE_TYPE === node.type) {
|
|
|
|
if (!nodeItem.toolSettings) nodeItem.toolSettings = {};
|
|
|
|
|
|
|
|
nodeItem.toolSettings.url_type = 'other';
|
|
|
|
nodeItem.toolSettings.uses_auth = false;
|
|
|
|
nodeItem.toolSettings.placeholders = 0;
|
|
|
|
nodeItem.toolSettings.query_from_model_only = false;
|
|
|
|
nodeItem.toolSettings.headers_from_model_only = false;
|
|
|
|
nodeItem.toolSettings.body_from_model_only = false;
|
|
|
|
|
|
|
|
const toolUrl = (node.parameters?.url as string) ?? '';
|
|
|
|
nodeItem.toolSettings.placeholders += countPlaceholders(toolUrl);
|
|
|
|
|
|
|
|
const authType = (node.parameters?.authentication as string) ?? '';
|
|
|
|
|
|
|
|
if (authType && authType !== 'none') {
|
|
|
|
nodeItem.toolSettings.uses_auth = true;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (toolUrl.startsWith('{') && toolUrl.endsWith('}')) {
|
|
|
|
nodeItem.toolSettings.url_type = 'any';
|
|
|
|
} else if (toolUrl.includes('google.com')) {
|
|
|
|
nodeItem.toolSettings.url_type = 'google';
|
|
|
|
}
|
|
|
|
|
|
|
|
if (node.parameters?.sendBody) {
|
|
|
|
if (node.parameters?.specifyBody === 'model') {
|
|
|
|
nodeItem.toolSettings.body_from_model_only = true;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (node.parameters?.jsonBody) {
|
|
|
|
nodeItem.toolSettings.placeholders += countPlaceholders(
|
|
|
|
node.parameters?.jsonBody as string,
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (node.parameters?.parametersBody) {
|
|
|
|
const parameters = (node.parameters?.parametersBody as IDataObject)
|
|
|
|
.values as IDataObject[];
|
|
|
|
|
|
|
|
nodeItem.toolSettings.placeholders += countPlaceholdersInParameters(parameters);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (node.parameters?.sendHeaders) {
|
|
|
|
if (node.parameters?.specifyHeaders === 'model') {
|
|
|
|
nodeItem.toolSettings.headers_from_model_only = true;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (node.parameters?.jsonHeaders) {
|
|
|
|
nodeItem.toolSettings.placeholders += countPlaceholders(
|
|
|
|
node.parameters?.jsonHeaders as string,
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (node.parameters?.parametersHeaders) {
|
|
|
|
const parameters = (node.parameters?.parametersHeaders as IDataObject)
|
|
|
|
.values as IDataObject[];
|
|
|
|
|
|
|
|
nodeItem.toolSettings.placeholders += countPlaceholdersInParameters(parameters);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (node.parameters?.sendQuery) {
|
|
|
|
if (node.parameters?.specifyQuery === 'model') {
|
|
|
|
nodeItem.toolSettings.query_from_model_only = true;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (node.parameters?.jsonQuery) {
|
|
|
|
nodeItem.toolSettings.placeholders += countPlaceholders(
|
|
|
|
node.parameters?.jsonQuery as string,
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (node.parameters?.parametersQuery) {
|
|
|
|
const parameters = (node.parameters?.parametersQuery as IDataObject)
|
|
|
|
.values as IDataObject[];
|
|
|
|
|
|
|
|
nodeItem.toolSettings.placeholders += countPlaceholdersInParameters(parameters);
|
|
|
|
}
|
|
|
|
}
|
2024-03-07 02:46:07 -08:00
|
|
|
} else if (node.type === WEBHOOK_NODE_TYPE) {
|
2024-01-11 04:25:40 -08:00
|
|
|
webhookNodeNames.push(node.name);
|
2024-07-04 05:16:15 -07:00
|
|
|
} else if (
|
|
|
|
node.type === EXECUTE_WORKFLOW_NODE_TYPE ||
|
|
|
|
node.type === WORKFLOW_TOOL_LANGCHAIN_NODE_TYPE
|
|
|
|
) {
|
|
|
|
if (node.parameters?.workflowId) {
|
|
|
|
nodeItem.workflow_id = node.parameters?.workflowId as string;
|
|
|
|
}
|
2024-01-11 04:25:40 -08:00
|
|
|
} else {
|
|
|
|
try {
|
2024-01-26 06:09:50 -08:00
|
|
|
const nodeType = nodeTypes.getByNameAndVersion(node.type, node.typeVersion);
|
2024-01-11 04:25:40 -08:00
|
|
|
if (nodeType) {
|
|
|
|
const nodeParameters = getNodeParameters(
|
|
|
|
nodeType.description.properties,
|
|
|
|
node.parameters,
|
|
|
|
true,
|
|
|
|
false,
|
|
|
|
node,
|
|
|
|
);
|
|
|
|
|
|
|
|
if (nodeParameters) {
|
|
|
|
const keys: Array<'operation' | 'resource' | 'mode'> = [
|
|
|
|
'operation',
|
|
|
|
'resource',
|
|
|
|
'mode',
|
|
|
|
];
|
|
|
|
keys.forEach((key) => {
|
|
|
|
if (nodeParameters.hasOwnProperty(key)) {
|
|
|
|
nodeItem[key] = nodeParameters[key]?.toString();
|
|
|
|
}
|
|
|
|
});
|
2022-02-24 08:15:30 -08:00
|
|
|
}
|
2024-01-11 04:25:40 -08:00
|
|
|
}
|
|
|
|
} catch (e: unknown) {
|
|
|
|
if (!(e instanceof Error && e.message.includes('Unrecognized node type'))) {
|
|
|
|
throw e;
|
|
|
|
}
|
2022-02-24 08:15:30 -08:00
|
|
|
}
|
2024-01-11 04:25:40 -08:00
|
|
|
}
|
2022-02-24 08:15:30 -08:00
|
|
|
|
2024-03-07 02:46:07 -08:00
|
|
|
if (options?.isCloudDeployment === true) {
|
|
|
|
if (node.type === OPENAI_LANGCHAIN_NODE_TYPE) {
|
|
|
|
nodeItem.prompts =
|
2024-03-27 08:16:02 -07:00
|
|
|
(((node.parameters?.messages as IDataObject) ?? {}).values as IDataObject[]) ?? [];
|
2024-03-07 02:46:07 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
if (node.type === AGENT_LANGCHAIN_NODE_TYPE) {
|
|
|
|
const prompts: IDataObject = {};
|
|
|
|
|
|
|
|
if (node.parameters?.text) {
|
|
|
|
prompts.text = node.parameters.text as string;
|
|
|
|
}
|
|
|
|
const nodeOptions = node.parameters?.options as IDataObject;
|
|
|
|
|
|
|
|
if (nodeOptions) {
|
|
|
|
const optionalMessagesKeys = [
|
|
|
|
'humanMessage',
|
|
|
|
'systemMessage',
|
|
|
|
'humanMessageTemplate',
|
|
|
|
'prefix',
|
|
|
|
'suffixChat',
|
|
|
|
'suffix',
|
|
|
|
'prefixPrompt',
|
|
|
|
'suffixPrompt',
|
|
|
|
];
|
|
|
|
|
|
|
|
for (const key of optionalMessagesKeys) {
|
|
|
|
if (nodeOptions[key]) {
|
|
|
|
prompts[key] = nodeOptions[key] as string;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (Object.keys(prompts).length) {
|
|
|
|
nodeItem.prompts = prompts;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (node.type === CHAIN_SUMMARIZATION_LANGCHAIN_NODE_TYPE) {
|
|
|
|
nodeItem.prompts = (
|
2024-03-27 08:16:02 -07:00
|
|
|
(((node.parameters?.options as IDataObject) ?? {})
|
|
|
|
.summarizationMethodAndPrompts as IDataObject) ?? {}
|
2024-03-07 02:46:07 -08:00
|
|
|
).values as IDataObject;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (LANGCHAIN_CUSTOM_TOOLS.includes(node.type)) {
|
|
|
|
nodeItem.prompts = {
|
2024-03-27 08:16:02 -07:00
|
|
|
description: (node.parameters?.description as string) ?? '',
|
2024-03-07 02:46:07 -08:00
|
|
|
};
|
|
|
|
}
|
2024-03-27 08:16:02 -07:00
|
|
|
|
|
|
|
if (node.type === CHAIN_LLM_LANGCHAIN_NODE_TYPE) {
|
|
|
|
nodeItem.prompts =
|
|
|
|
(((node.parameters?.messages as IDataObject) ?? {}).messageValues as IDataObject[]) ?? [];
|
|
|
|
}
|
2024-07-02 03:47:04 -07:00
|
|
|
|
|
|
|
if (node.type === MERGE_NODE_TYPE && node.parameters?.operation === 'combineBySql') {
|
|
|
|
nodeItem.sql = node.parameters?.query as string;
|
|
|
|
}
|
2024-03-07 02:46:07 -08:00
|
|
|
}
|
|
|
|
|
2024-01-11 04:25:40 -08:00
|
|
|
nodeGraph.nodes[index.toString()] = nodeItem;
|
|
|
|
nameIndices[node.name] = index.toString();
|
|
|
|
});
|
|
|
|
|
|
|
|
const getGraphConnectionItem = (startNode: string, connectionItem: IConnection) => {
|
|
|
|
return { start: nameIndices[startNode], end: nameIndices[connectionItem.node] };
|
|
|
|
};
|
|
|
|
|
|
|
|
Object.keys(workflow.connections ?? []).forEach((nodeName) => {
|
|
|
|
const connections = workflow.connections?.[nodeName];
|
|
|
|
if (!connections) {
|
|
|
|
return;
|
|
|
|
}
|
2021-10-18 20:57:49 -07:00
|
|
|
|
2024-01-11 04:25:40 -08:00
|
|
|
Object.keys(connections).forEach((key) => {
|
|
|
|
connections[key].forEach((element) => {
|
2024-01-26 06:09:50 -08:00
|
|
|
(element ?? []).forEach((element2) => {
|
2024-01-11 04:25:40 -08:00
|
|
|
nodeGraph.node_connections.push(getGraphConnectionItem(nodeName, element2));
|
2022-02-24 08:15:30 -08:00
|
|
|
});
|
2021-10-18 20:57:49 -07:00
|
|
|
});
|
|
|
|
});
|
2024-01-11 04:25:40 -08:00
|
|
|
});
|
2021-10-18 20:57:49 -07:00
|
|
|
|
2024-01-11 04:25:40 -08:00
|
|
|
return { nodeGraph, nameIndices, webhookNodeNames };
|
2021-10-18 20:57:49 -07:00
|
|
|
}
|