@atom8n/ai-workflow-builder 1.2.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/agents/responder.agent.d.ts +21 -0
- package/dist/agents/responder.agent.js +71 -0
- package/dist/agents/responder.agent.js.map +1 -0
- package/dist/agents/supervisor.agent.d.ts +31 -0
- package/dist/agents/supervisor.agent.js +68 -0
- package/dist/agents/supervisor.agent.js.map +1 -0
- package/dist/ai-workflow-builder-agent.service.d.ts +32 -0
- package/dist/ai-workflow-builder-agent.service.js +236 -0
- package/dist/ai-workflow-builder-agent.service.js.map +1 -0
- package/dist/build.tsbuildinfo +1 -0
- package/dist/chains/conversation-compact.d.ts +7 -0
- package/dist/chains/conversation-compact.js +56 -0
- package/dist/chains/conversation-compact.js.map +1 -0
- package/dist/chains/parameter-updater.d.ts +16 -0
- package/dist/chains/parameter-updater.js +112 -0
- package/dist/chains/parameter-updater.js.map +1 -0
- package/dist/chains/prompt-categorization.d.ts +3 -0
- package/dist/chains/prompt-categorization.js +31 -0
- package/dist/chains/prompt-categorization.js.map +1 -0
- package/dist/chains/test/integration/test-helpers.d.ts +3 -0
- package/dist/chains/test/integration/test-helpers.js +16 -0
- package/dist/chains/test/integration/test-helpers.js.map +1 -0
- package/dist/chains/workflow-name.d.ts +4 -0
- package/dist/chains/workflow-name.js +22 -0
- package/dist/chains/workflow-name.js.map +1 -0
- package/dist/constants.d.ts +14 -0
- package/dist/constants.js +18 -0
- package/dist/constants.js.map +1 -0
- package/dist/errors/index.d.ts +52 -0
- package/dist/errors/index.js +137 -0
- package/dist/errors/index.js.map +1 -0
- package/dist/index.d.ts +4 -0
- package/dist/index.js +22 -0
- package/dist/index.js.map +1 -0
- package/dist/llm-config.d.ts +11 -0
- package/dist/llm-config.js +126 -0
- package/dist/llm-config.js.map +1 -0
- package/dist/multi-agent-workflow-subgraphs.d.ts +122 -0
- package/dist/multi-agent-workflow-subgraphs.js +159 -0
- package/dist/multi-agent-workflow-subgraphs.js.map +1 -0
- package/dist/parent-graph-state.d.ts +27 -0
- package/dist/parent-graph-state.js +47 -0
- package/dist/parent-graph-state.js.map +1 -0
- package/dist/prompts/agents/builder.prompt.d.ts +1 -0
- package/dist/prompts/agents/builder.prompt.js +320 -0
- package/dist/prompts/agents/builder.prompt.js.map +1 -0
- package/dist/prompts/agents/configurator.prompt.d.ts +2 -0
- package/dist/prompts/agents/configurator.prompt.js +143 -0
- package/dist/prompts/agents/configurator.prompt.js.map +1 -0
- package/dist/prompts/agents/discovery.prompt.d.ts +11 -0
- package/dist/prompts/agents/discovery.prompt.js +260 -0
- package/dist/prompts/agents/discovery.prompt.js.map +1 -0
- package/dist/prompts/agents/responder.prompt.d.ts +1 -0
- package/dist/prompts/agents/responder.prompt.js +41 -0
- package/dist/prompts/agents/responder.prompt.js.map +1 -0
- package/dist/prompts/agents/supervisor.prompt.d.ts +1 -0
- package/dist/prompts/agents/supervisor.prompt.js +43 -0
- package/dist/prompts/agents/supervisor.prompt.js.map +1 -0
- package/dist/prompts/builder/index.d.ts +2 -0
- package/dist/prompts/builder/index.js +7 -0
- package/dist/prompts/builder/index.js.map +1 -0
- package/dist/prompts/builder/prompt-builder.d.ts +17 -0
- package/dist/prompts/builder/prompt-builder.js +147 -0
- package/dist/prompts/builder/prompt-builder.js.map +1 -0
- package/dist/prompts/builder/types.d.ts +22 -0
- package/dist/prompts/builder/types.js +3 -0
- package/dist/prompts/builder/types.js.map +1 -0
- package/dist/prompts/chains/categorization.prompt.d.ts +43 -0
- package/dist/prompts/chains/categorization.prompt.js +86 -0
- package/dist/prompts/chains/categorization.prompt.js.map +1 -0
- package/dist/prompts/chains/compact.prompt.d.ts +2 -0
- package/dist/prompts/chains/compact.prompt.js +16 -0
- package/dist/prompts/chains/compact.prompt.js.map +1 -0
- package/dist/prompts/chains/parameter-updater/examples/if-node.d.ts +2 -0
- package/dist/prompts/chains/parameter-updater/examples/if-node.js +141 -0
- package/dist/prompts/chains/parameter-updater/examples/if-node.js.map +1 -0
- package/dist/prompts/chains/parameter-updater/examples/index.d.ts +6 -0
- package/dist/prompts/chains/parameter-updater/examples/index.js +16 -0
- package/dist/prompts/chains/parameter-updater/examples/index.js.map +1 -0
- package/dist/prompts/chains/parameter-updater/examples/resource-locator.d.ts +2 -0
- package/dist/prompts/chains/parameter-updater/examples/resource-locator.js +83 -0
- package/dist/prompts/chains/parameter-updater/examples/resource-locator.js.map +1 -0
- package/dist/prompts/chains/parameter-updater/examples/set-node.d.ts +2 -0
- package/dist/prompts/chains/parameter-updater/examples/set-node.js +151 -0
- package/dist/prompts/chains/parameter-updater/examples/set-node.js.map +1 -0
- package/dist/prompts/chains/parameter-updater/examples/simple-updates.d.ts +2 -0
- package/dist/prompts/chains/parameter-updater/examples/simple-updates.js +54 -0
- package/dist/prompts/chains/parameter-updater/examples/simple-updates.js.map +1 -0
- package/dist/prompts/chains/parameter-updater/examples/switch-node.d.ts +2 -0
- package/dist/prompts/chains/parameter-updater/examples/switch-node.js +131 -0
- package/dist/prompts/chains/parameter-updater/examples/switch-node.js.map +1 -0
- package/dist/prompts/chains/parameter-updater/examples/tool-nodes.d.ts +2 -0
- package/dist/prompts/chains/parameter-updater/examples/tool-nodes.js +74 -0
- package/dist/prompts/chains/parameter-updater/examples/tool-nodes.js.map +1 -0
- package/dist/prompts/chains/parameter-updater/guides/embedding-nodes.d.ts +2 -0
- package/dist/prompts/chains/parameter-updater/guides/embedding-nodes.js +70 -0
- package/dist/prompts/chains/parameter-updater/guides/embedding-nodes.js.map +1 -0
- package/dist/prompts/chains/parameter-updater/guides/gmail.d.ts +2 -0
- package/dist/prompts/chains/parameter-updater/guides/gmail.js +28 -0
- package/dist/prompts/chains/parameter-updater/guides/gmail.js.map +1 -0
- package/dist/prompts/chains/parameter-updater/guides/http-request.d.ts +2 -0
- package/dist/prompts/chains/parameter-updater/guides/http-request.js +139 -0
- package/dist/prompts/chains/parameter-updater/guides/http-request.js.map +1 -0
- package/dist/prompts/chains/parameter-updater/guides/if-node.d.ts +2 -0
- package/dist/prompts/chains/parameter-updater/guides/if-node.js +159 -0
- package/dist/prompts/chains/parameter-updater/guides/if-node.js.map +1 -0
- package/dist/prompts/chains/parameter-updater/guides/index.d.ts +10 -0
- package/dist/prompts/chains/parameter-updater/guides/index.js +24 -0
- package/dist/prompts/chains/parameter-updater/guides/index.js.map +1 -0
- package/dist/prompts/chains/parameter-updater/guides/resource-locator.d.ts +2 -0
- package/dist/prompts/chains/parameter-updater/guides/resource-locator.js +99 -0
- package/dist/prompts/chains/parameter-updater/guides/resource-locator.js.map +1 -0
- package/dist/prompts/chains/parameter-updater/guides/set-node.d.ts +2 -0
- package/dist/prompts/chains/parameter-updater/guides/set-node.js +94 -0
- package/dist/prompts/chains/parameter-updater/guides/set-node.js.map +1 -0
- package/dist/prompts/chains/parameter-updater/guides/switch-node.d.ts +2 -0
- package/dist/prompts/chains/parameter-updater/guides/switch-node.js +75 -0
- package/dist/prompts/chains/parameter-updater/guides/switch-node.js.map +1 -0
- package/dist/prompts/chains/parameter-updater/guides/system-message.d.ts +2 -0
- package/dist/prompts/chains/parameter-updater/guides/system-message.js +96 -0
- package/dist/prompts/chains/parameter-updater/guides/system-message.js.map +1 -0
- package/dist/prompts/chains/parameter-updater/guides/text-fields.d.ts +2 -0
- package/dist/prompts/chains/parameter-updater/guides/text-fields.js +31 -0
- package/dist/prompts/chains/parameter-updater/guides/text-fields.js.map +1 -0
- package/dist/prompts/chains/parameter-updater/guides/tool-nodes.d.ts +2 -0
- package/dist/prompts/chains/parameter-updater/guides/tool-nodes.js +76 -0
- package/dist/prompts/chains/parameter-updater/guides/tool-nodes.js.map +1 -0
- package/dist/prompts/chains/parameter-updater/index.d.ts +8 -0
- package/dist/prompts/chains/parameter-updater/index.js +35 -0
- package/dist/prompts/chains/parameter-updater/index.js.map +1 -0
- package/dist/prompts/chains/parameter-updater/instance-url.d.ts +1 -0
- package/dist/prompts/chains/parameter-updater/instance-url.js +15 -0
- package/dist/prompts/chains/parameter-updater/instance-url.js.map +1 -0
- package/dist/prompts/chains/parameter-updater/parameter-updater.prompt.d.ts +4 -0
- package/dist/prompts/chains/parameter-updater/parameter-updater.prompt.js +52 -0
- package/dist/prompts/chains/parameter-updater/parameter-updater.prompt.js.map +1 -0
- package/dist/prompts/chains/parameter-updater/registry.d.ts +4 -0
- package/dist/prompts/chains/parameter-updater/registry.js +66 -0
- package/dist/prompts/chains/parameter-updater/registry.js.map +1 -0
- package/dist/prompts/chains/parameter-updater/types.d.ts +18 -0
- package/dist/prompts/chains/parameter-updater/types.js +3 -0
- package/dist/prompts/chains/parameter-updater/types.js.map +1 -0
- package/dist/prompts/chains/parameter-updater/utils.d.ts +2 -0
- package/dist/prompts/chains/parameter-updater/utils.js +16 -0
- package/dist/prompts/chains/parameter-updater/utils.js.map +1 -0
- package/dist/prompts/chains/workflow-name.prompt.d.ts +2 -0
- package/dist/prompts/chains/workflow-name.prompt.js +11 -0
- package/dist/prompts/chains/workflow-name.prompt.js.map +1 -0
- package/dist/prompts/index.d.ts +12 -0
- package/dist/prompts/index.js +50 -0
- package/dist/prompts/index.js.map +1 -0
- package/dist/prompts/legacy-agent.prompt.d.ts +6 -0
- package/dist/prompts/legacy-agent.prompt.js +594 -0
- package/dist/prompts/legacy-agent.prompt.js.map +1 -0
- package/dist/session-manager.service.d.ts +16 -0
- package/dist/session-manager.service.js +125 -0
- package/dist/session-manager.service.js.map +1 -0
- package/dist/subgraphs/builder.subgraph.d.ts +132 -0
- package/dist/subgraphs/builder.subgraph.js +173 -0
- package/dist/subgraphs/builder.subgraph.js.map +1 -0
- package/dist/subgraphs/configurator.subgraph.d.ts +142 -0
- package/dist/subgraphs/configurator.subgraph.js +173 -0
- package/dist/subgraphs/configurator.subgraph.js.map +1 -0
- package/dist/subgraphs/discovery.subgraph.d.ts +158 -0
- package/dist/subgraphs/discovery.subgraph.js +221 -0
- package/dist/subgraphs/discovery.subgraph.js.map +1 -0
- package/dist/subgraphs/subgraph-interface.d.ts +23 -0
- package/dist/subgraphs/subgraph-interface.js +7 -0
- package/dist/subgraphs/subgraph-interface.js.map +1 -0
- package/dist/tools/add-node.tool.d.ts +54 -0
- package/dist/tools/add-node.tool.js +176 -0
- package/dist/tools/add-node.tool.js.map +1 -0
- package/dist/tools/best-practices/chatbot.d.ts +7 -0
- package/dist/tools/best-practices/chatbot.js +118 -0
- package/dist/tools/best-practices/chatbot.js.map +1 -0
- package/dist/tools/best-practices/content-generation.d.ts +7 -0
- package/dist/tools/best-practices/content-generation.js +115 -0
- package/dist/tools/best-practices/content-generation.js.map +1 -0
- package/dist/tools/best-practices/data-analysis.d.ts +7 -0
- package/dist/tools/best-practices/data-analysis.js +367 -0
- package/dist/tools/best-practices/data-analysis.js.map +1 -0
- package/dist/tools/best-practices/data-extraction.d.ts +7 -0
- package/dist/tools/best-practices/data-extraction.js +122 -0
- package/dist/tools/best-practices/data-extraction.js.map +1 -0
- package/dist/tools/best-practices/data-transformation.d.ts +7 -0
- package/dist/tools/best-practices/data-transformation.js +162 -0
- package/dist/tools/best-practices/data-transformation.js.map +1 -0
- package/dist/tools/best-practices/document-processing.d.ts +7 -0
- package/dist/tools/best-practices/document-processing.js +335 -0
- package/dist/tools/best-practices/document-processing.js.map +1 -0
- package/dist/tools/best-practices/enrichment.d.ts +7 -0
- package/dist/tools/best-practices/enrichment.js +271 -0
- package/dist/tools/best-practices/enrichment.js.map +1 -0
- package/dist/tools/best-practices/form-input.d.ts +7 -0
- package/dist/tools/best-practices/form-input.js +173 -0
- package/dist/tools/best-practices/form-input.js.map +1 -0
- package/dist/tools/best-practices/human-in-the-loop.d.ts +7 -0
- package/dist/tools/best-practices/human-in-the-loop.js +268 -0
- package/dist/tools/best-practices/human-in-the-loop.js.map +1 -0
- package/dist/tools/best-practices/index.d.ts +3 -0
- package/dist/tools/best-practices/index.js +29 -0
- package/dist/tools/best-practices/index.js.map +1 -0
- package/dist/tools/best-practices/knowledge-base.d.ts +7 -0
- package/dist/tools/best-practices/knowledge-base.js +268 -0
- package/dist/tools/best-practices/knowledge-base.js.map +1 -0
- package/dist/tools/best-practices/monitoring.d.ts +7 -0
- package/dist/tools/best-practices/monitoring.js +178 -0
- package/dist/tools/best-practices/monitoring.js.map +1 -0
- package/dist/tools/best-practices/notification.d.ts +7 -0
- package/dist/tools/best-practices/notification.js +229 -0
- package/dist/tools/best-practices/notification.js.map +1 -0
- package/dist/tools/best-practices/scheduling.d.ts +7 -0
- package/dist/tools/best-practices/scheduling.js +281 -0
- package/dist/tools/best-practices/scheduling.js.map +1 -0
- package/dist/tools/best-practices/scraping-and-research.d.ts +7 -0
- package/dist/tools/best-practices/scraping-and-research.js +161 -0
- package/dist/tools/best-practices/scraping-and-research.js.map +1 -0
- package/dist/tools/best-practices/triage.d.ts +7 -0
- package/dist/tools/best-practices/triage.js +211 -0
- package/dist/tools/best-practices/triage.js.map +1 -0
- package/dist/tools/builder-tools.d.ts +16 -0
- package/dist/tools/builder-tools.js +36 -0
- package/dist/tools/builder-tools.js.map +1 -0
- package/dist/tools/categorize-prompt.tool.d.ts +5 -0
- package/dist/tools/categorize-prompt.tool.js +85 -0
- package/dist/tools/categorize-prompt.tool.js.map +1 -0
- package/dist/tools/connect-nodes.tool.d.ts +22 -0
- package/dist/tools/connect-nodes.tool.js +231 -0
- package/dist/tools/connect-nodes.tool.js.map +1 -0
- package/dist/tools/engines/node-search-engine.d.ts +16 -0
- package/dist/tools/engines/node-search-engine.js +123 -0
- package/dist/tools/engines/node-search-engine.js.map +1 -0
- package/dist/tools/get-best-practices.tool.d.ts +33 -0
- package/dist/tools/get-best-practices.tool.js +94 -0
- package/dist/tools/get-best-practices.tool.js.map +1 -0
- package/dist/tools/get-node-examples.tool.d.ts +119 -0
- package/dist/tools/get-node-examples.tool.js +189 -0
- package/dist/tools/get-node-examples.tool.js.map +1 -0
- package/dist/tools/get-node-parameter.tool.d.ts +4 -0
- package/dist/tools/get-node-parameter.tool.js +114 -0
- package/dist/tools/get-node-parameter.tool.js.map +1 -0
- package/dist/tools/get-workflow-examples.tool.d.ts +34 -0
- package/dist/tools/get-workflow-examples.tool.js +138 -0
- package/dist/tools/get-workflow-examples.tool.js.map +1 -0
- package/dist/tools/helpers/index.d.ts +4 -0
- package/dist/tools/helpers/index.js +21 -0
- package/dist/tools/helpers/index.js.map +1 -0
- package/dist/tools/helpers/progress.d.ts +9 -0
- package/dist/tools/helpers/progress.js +126 -0
- package/dist/tools/helpers/progress.js.map +1 -0
- package/dist/tools/helpers/response.d.ts +7 -0
- package/dist/tools/helpers/response.js +33 -0
- package/dist/tools/helpers/response.js.map +1 -0
- package/dist/tools/helpers/state.d.ts +14 -0
- package/dist/tools/helpers/state.js +85 -0
- package/dist/tools/helpers/state.js.map +1 -0
- package/dist/tools/helpers/validation.d.ts +13 -0
- package/dist/tools/helpers/validation.js +83 -0
- package/dist/tools/helpers/validation.js.map +1 -0
- package/dist/tools/node-details.tool.d.ts +31 -0
- package/dist/tools/node-details.tool.js +201 -0
- package/dist/tools/node-details.tool.js.map +1 -0
- package/dist/tools/node-search.tool.d.ts +62 -0
- package/dist/tools/node-search.tool.js +155 -0
- package/dist/tools/node-search.tool.js.map +1 -0
- package/dist/tools/remove-connection.tool.d.ts +24 -0
- package/dist/tools/remove-connection.tool.js +234 -0
- package/dist/tools/remove-connection.tool.js.map +1 -0
- package/dist/tools/remove-node.tool.d.ts +4 -0
- package/dist/tools/remove-node.tool.js +106 -0
- package/dist/tools/remove-node.tool.js.map +1 -0
- package/dist/tools/update-node-parameters.tool.d.ts +5 -0
- package/dist/tools/update-node-parameters.tool.js +156 -0
- package/dist/tools/update-node-parameters.tool.js.map +1 -0
- package/dist/tools/utils/connection-parameters.utils.d.ts +8 -0
- package/dist/tools/utils/connection-parameters.utils.js +47 -0
- package/dist/tools/utils/connection-parameters.utils.js.map +1 -0
- package/dist/tools/utils/connection.utils.d.ts +15 -0
- package/dist/tools/utils/connection.utils.js +321 -0
- package/dist/tools/utils/connection.utils.js.map +1 -0
- package/dist/tools/utils/mermaid.utils.d.ts +13 -0
- package/dist/tools/utils/mermaid.utils.js +647 -0
- package/dist/tools/utils/mermaid.utils.js.map +1 -0
- package/dist/tools/utils/node-configuration.utils.d.ts +13 -0
- package/dist/tools/utils/node-configuration.utils.js +75 -0
- package/dist/tools/utils/node-configuration.utils.js.map +1 -0
- package/dist/tools/utils/node-creation.utils.d.ts +8 -0
- package/dist/tools/utils/node-creation.utils.js +56 -0
- package/dist/tools/utils/node-creation.utils.js.map +1 -0
- package/dist/tools/utils/node-positioning.utils.d.ts +17 -0
- package/dist/tools/utils/node-positioning.utils.js +87 -0
- package/dist/tools/utils/node-positioning.utils.js.map +1 -0
- package/dist/tools/utils/parameter-update.utils.d.ts +6 -0
- package/dist/tools/utils/parameter-update.utils.js +75 -0
- package/dist/tools/utils/parameter-update.utils.js.map +1 -0
- package/dist/tools/utils/test/workflows/ai-assistant.workflow.d.ts +2 -0
- package/dist/tools/utils/test/workflows/ai-assistant.workflow.js +542 -0
- package/dist/tools/utils/test/workflows/ai-assistant.workflow.js.map +1 -0
- package/dist/tools/validate-configuration.tool.d.ts +4 -0
- package/dist/tools/validate-configuration.tool.js +70 -0
- package/dist/tools/validate-configuration.tool.js.map +1 -0
- package/dist/tools/validate-structure.tool.d.ts +4 -0
- package/dist/tools/validate-structure.tool.js +66 -0
- package/dist/tools/validate-structure.tool.js.map +1 -0
- package/dist/tools/validate-workflow.tool.d.ts +5 -0
- package/dist/tools/validate-workflow.tool.js +73 -0
- package/dist/tools/validate-workflow.tool.js.map +1 -0
- package/dist/tools/web/templates.d.ts +23 -0
- package/dist/tools/web/templates.js +106 -0
- package/dist/tools/web/templates.js.map +1 -0
- package/dist/types/best-practices.d.ts +6 -0
- package/dist/types/best-practices.js +3 -0
- package/dist/types/best-practices.js.map +1 -0
- package/dist/types/categorization.d.ts +23 -0
- package/dist/types/categorization.js +38 -0
- package/dist/types/categorization.js.map +1 -0
- package/dist/types/config.d.ts +55 -0
- package/dist/types/config.js +3 -0
- package/dist/types/config.js.map +1 -0
- package/dist/types/connections.d.ts +30 -0
- package/dist/types/connections.js +3 -0
- package/dist/types/connections.js.map +1 -0
- package/dist/types/coordination.d.ts +42 -0
- package/dist/types/coordination.js +23 -0
- package/dist/types/coordination.js.map +1 -0
- package/dist/types/discovery-types.d.ts +12 -0
- package/dist/types/discovery-types.js +3 -0
- package/dist/types/discovery-types.js.map +1 -0
- package/dist/types/index.d.ts +11 -0
- package/dist/types/index.js +18 -0
- package/dist/types/index.js.map +1 -0
- package/dist/types/langchain.d.ts +3 -0
- package/dist/types/langchain.js +15 -0
- package/dist/types/langchain.js.map +1 -0
- package/dist/types/messages.d.ts +32 -0
- package/dist/types/messages.js +3 -0
- package/dist/types/messages.js.map +1 -0
- package/dist/types/nodes.d.ts +27 -0
- package/dist/types/nodes.js +3 -0
- package/dist/types/nodes.js.map +1 -0
- package/dist/types/sessions.d.ts +8 -0
- package/dist/types/sessions.js +34 -0
- package/dist/types/sessions.js.map +1 -0
- package/dist/types/streaming.d.ts +33 -0
- package/dist/types/streaming.js +3 -0
- package/dist/types/streaming.js.map +1 -0
- package/dist/types/tools.d.ts +120 -0
- package/dist/types/tools.js +3 -0
- package/dist/types/tools.js.map +1 -0
- package/dist/types/utils.d.ts +2 -0
- package/dist/types/utils.js +3 -0
- package/dist/types/utils.js.map +1 -0
- package/dist/types/web/templates.d.ts +45 -0
- package/dist/types/web/templates.js +37 -0
- package/dist/types/web/templates.js.map +1 -0
- package/dist/types/workflow.d.ts +31 -0
- package/dist/types/workflow.js +3 -0
- package/dist/types/workflow.js.map +1 -0
- package/dist/utils/cache-control/helpers.d.ts +5 -0
- package/dist/utils/cache-control/helpers.js +126 -0
- package/dist/utils/cache-control/helpers.js.map +1 -0
- package/dist/utils/cache-control/index.d.ts +1 -0
- package/dist/utils/cache-control/index.js +9 -0
- package/dist/utils/cache-control/index.js.map +1 -0
- package/dist/utils/cleanup-dangling-tool-call-messages.d.ts +3 -0
- package/dist/utils/cleanup-dangling-tool-call-messages.js +10 -0
- package/dist/utils/cleanup-dangling-tool-call-messages.js.map +1 -0
- package/dist/utils/context-builders.d.ts +10 -0
- package/dist/utils/context-builders.js +71 -0
- package/dist/utils/context-builders.js.map +1 -0
- package/dist/utils/coordination-log.d.ts +15 -0
- package/dist/utils/coordination-log.js +75 -0
- package/dist/utils/coordination-log.js.map +1 -0
- package/dist/utils/http-proxy-agent.d.ts +2 -0
- package/dist/utils/http-proxy-agent.js +16 -0
- package/dist/utils/http-proxy-agent.js.map +1 -0
- package/dist/utils/node-helpers.d.ts +2 -0
- package/dist/utils/node-helpers.js +54 -0
- package/dist/utils/node-helpers.js.map +1 -0
- package/dist/utils/operations-processor.d.ts +14 -0
- package/dist/utils/operations-processor.js +196 -0
- package/dist/utils/operations-processor.js.map +1 -0
- package/dist/utils/state-modifier.d.ts +32 -0
- package/dist/utils/state-modifier.js +112 -0
- package/dist/utils/state-modifier.js.map +1 -0
- package/dist/utils/state-reducers.d.ts +3 -0
- package/dist/utils/state-reducers.js +20 -0
- package/dist/utils/state-reducers.js.map +1 -0
- package/dist/utils/stream-processor.d.ts +20 -0
- package/dist/utils/stream-processor.js +277 -0
- package/dist/utils/stream-processor.js.map +1 -0
- package/dist/utils/subgraph-helpers.d.ts +16 -0
- package/dist/utils/subgraph-helpers.js +117 -0
- package/dist/utils/subgraph-helpers.js.map +1 -0
- package/dist/utils/token-usage.d.ts +21 -0
- package/dist/utils/token-usage.js +45 -0
- package/dist/utils/token-usage.js.map +1 -0
- package/dist/utils/tool-executor.d.ts +3 -0
- package/dist/utils/tool-executor.js +108 -0
- package/dist/utils/tool-executor.js.map +1 -0
- package/dist/utils/trim-workflow-context.d.ts +2 -0
- package/dist/utils/trim-workflow-context.js +53 -0
- package/dist/utils/trim-workflow-context.js.map +1 -0
- package/dist/utils/workflow-validation.d.ts +2 -0
- package/dist/utils/workflow-validation.js +37 -0
- package/dist/utils/workflow-validation.js.map +1 -0
- package/dist/validation/checks/agent-prompt.d.ts +3 -0
- package/dist/validation/checks/agent-prompt.js +47 -0
- package/dist/validation/checks/agent-prompt.js.map +1 -0
- package/dist/validation/checks/connections.d.ts +4 -0
- package/dist/validation/checks/connections.js +163 -0
- package/dist/validation/checks/connections.js.map +1 -0
- package/dist/validation/checks/credentials.d.ts +3 -0
- package/dist/validation/checks/credentials.js +125 -0
- package/dist/validation/checks/credentials.js.map +1 -0
- package/dist/validation/checks/from-ai.d.ts +4 -0
- package/dist/validation/checks/from-ai.js +62 -0
- package/dist/validation/checks/from-ai.js.map +1 -0
- package/dist/validation/checks/index.d.ts +7 -0
- package/dist/validation/checks/index.js +18 -0
- package/dist/validation/checks/index.js.map +1 -0
- package/dist/validation/checks/nodes.d.ts +4 -0
- package/dist/validation/checks/nodes.js +44 -0
- package/dist/validation/checks/nodes.js.map +1 -0
- package/dist/validation/checks/tools.d.ts +4 -0
- package/dist/validation/checks/tools.js +38 -0
- package/dist/validation/checks/tools.js.map +1 -0
- package/dist/validation/checks/trigger.d.ts +8 -0
- package/dist/validation/checks/trigger.js +33 -0
- package/dist/validation/checks/trigger.js.map +1 -0
- package/dist/validation/programmatic.d.ts +3 -0
- package/dist/validation/programmatic.js +24 -0
- package/dist/validation/programmatic.js.map +1 -0
- package/dist/validation/types.d.ts +52 -0
- package/dist/validation/types.js +31 -0
- package/dist/validation/types.js.map +1 -0
- package/dist/validation/utils/expressions.d.ts +3 -0
- package/dist/validation/utils/expressions.js +37 -0
- package/dist/validation/utils/expressions.js.map +1 -0
- package/dist/validation/utils/is-tool.d.ts +2 -0
- package/dist/validation/utils/is-tool.js +7 -0
- package/dist/validation/utils/is-tool.js.map +1 -0
- package/dist/validation/utils/node-type-map.d.ts +8 -0
- package/dist/validation/utils/node-type-map.js +50 -0
- package/dist/validation/utils/node-type-map.js.map +1 -0
- package/dist/validation/utils/resolve-connections.d.ts +8 -0
- package/dist/validation/utils/resolve-connections.js +64 -0
- package/dist/validation/utils/resolve-connections.js.map +1 -0
- package/dist/workflow-builder-agent.d.ts +72 -0
- package/dist/workflow-builder-agent.js +401 -0
- package/dist/workflow-builder-agent.js.map +1 -0
- package/dist/workflow-state.d.ts +26 -0
- package/dist/workflow-state.js +79 -0
- package/dist/workflow-state.js.map +1 -0
- package/package.json +77 -0
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.validateNodes = validateNodes;
|
|
4
|
+
const node_type_map_1 = require("../../validation/utils/node-type-map");
|
|
5
|
+
function validateNodes(workflow, nodeTypes) {
|
|
6
|
+
const violations = [];
|
|
7
|
+
if (!workflow.nodes || workflow.nodes.length === 0) {
|
|
8
|
+
violations.push({
|
|
9
|
+
name: 'workflow-has-no-nodes',
|
|
10
|
+
type: 'critical',
|
|
11
|
+
description: 'Workflow has no nodes',
|
|
12
|
+
pointsDeducted: 50,
|
|
13
|
+
});
|
|
14
|
+
return violations;
|
|
15
|
+
}
|
|
16
|
+
const { nodeTypeMap, nodeTypesByName } = (0, node_type_map_1.createNodeTypeMaps)(nodeTypes);
|
|
17
|
+
const nodeCountByType = new Map();
|
|
18
|
+
for (const node of workflow.nodes) {
|
|
19
|
+
const currentCount = nodeCountByType.get(node.type) ?? 0;
|
|
20
|
+
nodeCountByType.set(node.type, currentCount + 1);
|
|
21
|
+
}
|
|
22
|
+
const checkedTypes = new Set();
|
|
23
|
+
for (const node of workflow.nodes) {
|
|
24
|
+
if (checkedTypes.has(node.type)) {
|
|
25
|
+
continue;
|
|
26
|
+
}
|
|
27
|
+
checkedTypes.add(node.type);
|
|
28
|
+
const nodeType = (0, node_type_map_1.getNodeTypeForNode)(node, nodeTypeMap, nodeTypesByName);
|
|
29
|
+
if (!nodeType?.maxNodes) {
|
|
30
|
+
continue;
|
|
31
|
+
}
|
|
32
|
+
const count = nodeCountByType.get(node.type) ?? 0;
|
|
33
|
+
if (count > nodeType.maxNodes) {
|
|
34
|
+
violations.push({
|
|
35
|
+
name: 'workflow-exceeds-max-nodes-limit',
|
|
36
|
+
type: 'critical',
|
|
37
|
+
description: `Workflow can only have ${nodeType.maxNodes} ${nodeType.displayName} node(s), but found ${count}`,
|
|
38
|
+
pointsDeducted: 50,
|
|
39
|
+
});
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
return violations;
|
|
43
|
+
}
|
|
44
|
+
//# sourceMappingURL=nodes.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"nodes.js","sourceRoot":"","sources":["../../../src/validation/checks/nodes.ts"],"names":[],"mappings":";;AAOA,sCAwDC;AA5DD,oEAA0F;AAI1F,SAAgB,aAAa,CAC5B,QAAwB,EACxB,SAAiC;IAEjC,MAAM,UAAU,GAA4B,EAAE,CAAC;IAE/C,IAAI,CAAC,QAAQ,CAAC,KAAK,IAAI,QAAQ,CAAC,KAAK,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QACpD,UAAU,CAAC,IAAI,CAAC;YACf,IAAI,EAAE,uBAAuB;YAC7B,IAAI,EAAE,UAAU;YAChB,WAAW,EAAE,uBAAuB;YACpC,cAAc,EAAE,EAAE;SAClB,CAAC,CAAC;QAEH,OAAO,UAAU,CAAC;IACnB,CAAC;IAED,MAAM,EAAE,WAAW,EAAE,eAAe,EAAE,GAAG,IAAA,kCAAkB,EAAC,SAAS,CAAC,CAAC;IAGvE,MAAM,eAAe,GAAG,IAAI,GAAG,EAAkB,CAAC;IAElD,KAAK,MAAM,IAAI,IAAI,QAAQ,CAAC,KAAK,EAAE,CAAC;QACnC,MAAM,YAAY,GAAG,eAAe,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACzD,eAAe,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,EAAE,YAAY,GAAG,CAAC,CAAC,CAAC;IAClD,CAAC;IAID,MAAM,YAAY,GAAG,IAAI,GAAG,EAAU,CAAC;IAEvC,KAAK,MAAM,IAAI,IAAI,QAAQ,CAAC,KAAK,EAAE,CAAC;QACnC,IAAI,YAAY,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC;YACjC,SAAS;QACV,CAAC;QACD,YAAY,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAE5B,MAAM,QAAQ,GAAG,IAAA,kCAAkB,EAAC,IAAI,EAAE,WAAW,EAAE,eAAe,CAAC,CAAC;QAExE,IAAI,CAAC,QAAQ,EAAE,QAAQ,EAAE,CAAC;YACzB,SAAS;QACV,CAAC;QAED,MAAM,KAAK,GAAG,eAAe,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAElD,IAAI,KAAK,GAAG,QAAQ,CAAC,QAAQ,EAAE,CAAC;YAC/B,UAAU,CAAC,IAAI,CAAC;gBACf,IAAI,EAAE,kCAAkC;gBACxC,IAAI,EAAE,UAAU;gBAChB,WAAW,EAAE,0BAA0B,QAAQ,CAAC,QAAQ,IAAI,QAAQ,CAAC,WAAW,uBAAuB,KAAK,EAAE;gBAC9G,cAAc,EAAE,EAAE;aAClB,CAAC,CAAC;QACJ,CAAC;IACF,CAAC;IAED,OAAO,UAAU,CAAC;AACnB,CAAC"}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import type { INodeTypeDescription } from 'n8n-workflow';
|
|
2
|
+
import type { SimpleWorkflow } from '../../types';
|
|
3
|
+
import type { SingleEvaluatorResult } from '../types';
|
|
4
|
+
export declare function validateTools(workflow: SimpleWorkflow, nodeTypes: INodeTypeDescription[]): SingleEvaluatorResult['violations'];
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.validateTools = validateTools;
|
|
4
|
+
const node_type_map_1 = require("../../validation/utils/node-type-map");
|
|
5
|
+
const is_tool_1 = require("../utils/is-tool");
|
|
6
|
+
const toolsWithoutParameters = [
|
|
7
|
+
'@n8n/n8n-nodes-langchain.toolCalculator',
|
|
8
|
+
'@n8n/n8n-nodes-langchain.toolVectorStore',
|
|
9
|
+
'@n8n/n8n-nodes-langchain.vectorStoreInMemory',
|
|
10
|
+
'@n8n/n8n-nodes-langchain.mcpClientTool',
|
|
11
|
+
'@n8n/n8n-nodes-langchain.toolWikipedia',
|
|
12
|
+
'@n8n/n8n-nodes-langchain.toolSerpApi',
|
|
13
|
+
];
|
|
14
|
+
function validateTools(workflow, nodeTypes) {
|
|
15
|
+
const violations = [];
|
|
16
|
+
if (!workflow.nodes || workflow.nodes.length === 0) {
|
|
17
|
+
return violations;
|
|
18
|
+
}
|
|
19
|
+
const { nodeTypeMap, nodeTypesByName } = (0, node_type_map_1.createNodeTypeMaps)(nodeTypes);
|
|
20
|
+
for (const node of workflow.nodes) {
|
|
21
|
+
const nodeType = (0, node_type_map_1.getNodeTypeForNode)(node, nodeTypeMap, nodeTypesByName);
|
|
22
|
+
if (!nodeType) {
|
|
23
|
+
continue;
|
|
24
|
+
}
|
|
25
|
+
if ((0, is_tool_1.isTool)(nodeType) && !toolsWithoutParameters.includes(node.type)) {
|
|
26
|
+
if (!node.parameters || Object.keys(node.parameters).length === 0) {
|
|
27
|
+
violations.push({
|
|
28
|
+
name: 'tool-node-has-no-parameters',
|
|
29
|
+
type: 'major',
|
|
30
|
+
description: `Tool node "${node.name}" has no parameters set.`,
|
|
31
|
+
pointsDeducted: 20,
|
|
32
|
+
});
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
return violations;
|
|
37
|
+
}
|
|
38
|
+
//# sourceMappingURL=tools.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"tools.js","sourceRoot":"","sources":["../../../src/validation/checks/tools.ts"],"names":[],"mappings":";;AAiBA,sCA+BC;AA7CD,oEAA0F;AAG1F,8CAA0C;AAE1C,MAAM,sBAAsB,GAAG;IAC9B,yCAAyC;IACzC,0CAA0C;IAC1C,8CAA8C;IAC9C,wCAAwC;IACxC,wCAAwC;IACxC,sCAAsC;CACtC,CAAC;AAEF,SAAgB,aAAa,CAC5B,QAAwB,EACxB,SAAiC;IAEjC,MAAM,UAAU,GAAwC,EAAE,CAAC;IAE3D,IAAI,CAAC,QAAQ,CAAC,KAAK,IAAI,QAAQ,CAAC,KAAK,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QACpD,OAAO,UAAU,CAAC;IACnB,CAAC;IAED,MAAM,EAAE,WAAW,EAAE,eAAe,EAAE,GAAG,IAAA,kCAAkB,EAAC,SAAS,CAAC,CAAC;IAEvE,KAAK,MAAM,IAAI,IAAI,QAAQ,CAAC,KAAK,EAAE,CAAC;QACnC,MAAM,QAAQ,GAAG,IAAA,kCAAkB,EAAC,IAAI,EAAE,WAAW,EAAE,eAAe,CAAC,CAAC;QACxE,IAAI,CAAC,QAAQ,EAAE,CAAC;YACf,SAAS;QACV,CAAC;QAED,IAAI,IAAA,gBAAM,EAAC,QAAQ,CAAC,IAAI,CAAC,sBAAsB,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC;YACrE,IAAI,CAAC,IAAI,CAAC,UAAU,IAAI,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;gBACnE,UAAU,CAAC,IAAI,CAAC;oBACf,IAAI,EAAE,6BAA6B;oBACnC,IAAI,EAAE,OAAO;oBACb,WAAW,EAAE,cAAc,IAAI,CAAC,IAAI,0BAA0B;oBAC9D,cAAc,EAAE,EAAE;iBAClB,CAAC,CAAC;YACJ,CAAC;QACF,CAAC;IACF,CAAC;IAED,OAAO,UAAU,CAAC;AACnB,CAAC"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import type { INodeTypeDescription } from 'n8n-workflow';
|
|
2
|
+
import type { SimpleWorkflow } from '../../types';
|
|
3
|
+
import type { ProgrammaticViolation, SingleEvaluatorResult } from '../types';
|
|
4
|
+
export interface TriggerEvaluationResult extends SingleEvaluatorResult {
|
|
5
|
+
hasTrigger: boolean;
|
|
6
|
+
triggerNodes: string[];
|
|
7
|
+
}
|
|
8
|
+
export declare function validateTrigger(workflow: SimpleWorkflow, nodeTypes: INodeTypeDescription[]): ProgrammaticViolation[];
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.validateTrigger = validateTrigger;
|
|
4
|
+
const node_type_map_1 = require("../../validation/utils/node-type-map");
|
|
5
|
+
const isTriggerNode = (nodeType) => nodeType.group.includes('trigger');
|
|
6
|
+
function validateTrigger(workflow, nodeTypes) {
|
|
7
|
+
const violations = [];
|
|
8
|
+
const triggerNodes = [];
|
|
9
|
+
if (!workflow.nodes || workflow.nodes.length === 0) {
|
|
10
|
+
return violations;
|
|
11
|
+
}
|
|
12
|
+
const { nodeTypeMap, nodeTypesByName } = (0, node_type_map_1.createNodeTypeMaps)(nodeTypes);
|
|
13
|
+
for (const node of workflow.nodes) {
|
|
14
|
+
const nodeType = (0, node_type_map_1.getNodeTypeForNode)(node, nodeTypeMap, nodeTypesByName);
|
|
15
|
+
if (!nodeType) {
|
|
16
|
+
continue;
|
|
17
|
+
}
|
|
18
|
+
if (isTriggerNode(nodeType)) {
|
|
19
|
+
triggerNodes.push(node.name);
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
const hasTrigger = triggerNodes.length > 0;
|
|
23
|
+
if (!hasTrigger) {
|
|
24
|
+
violations.push({
|
|
25
|
+
name: 'workflow-has-no-trigger',
|
|
26
|
+
type: 'critical',
|
|
27
|
+
description: 'Workflow must have at least one trigger node to start execution',
|
|
28
|
+
pointsDeducted: 50,
|
|
29
|
+
});
|
|
30
|
+
}
|
|
31
|
+
return violations;
|
|
32
|
+
}
|
|
33
|
+
//# sourceMappingURL=trigger.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"trigger.js","sourceRoot":"","sources":["../../../src/validation/checks/trigger.ts"],"names":[],"mappings":";;AAcA,0CAqCC;AAhDD,oEAA0F;AAS1F,MAAM,aAAa,GAAG,CAAC,QAA8B,EAAE,EAAE,CAAC,QAAQ,CAAC,KAAK,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC;AAE7F,SAAgB,eAAe,CAC9B,QAAwB,EACxB,SAAiC;IAEjC,MAAM,UAAU,GAA4B,EAAE,CAAC;IAC/C,MAAM,YAAY,GAAa,EAAE,CAAC;IAElC,IAAI,CAAC,QAAQ,CAAC,KAAK,IAAI,QAAQ,CAAC,KAAK,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QACpD,OAAO,UAAU,CAAC;IACnB,CAAC;IAED,MAAM,EAAE,WAAW,EAAE,eAAe,EAAE,GAAG,IAAA,kCAAkB,EAAC,SAAS,CAAC,CAAC;IAEvE,KAAK,MAAM,IAAI,IAAI,QAAQ,CAAC,KAAK,EAAE,CAAC;QACnC,MAAM,QAAQ,GAAG,IAAA,kCAAkB,EAAC,IAAI,EAAE,WAAW,EAAE,eAAe,CAAC,CAAC;QAExE,IAAI,CAAC,QAAQ,EAAE,CAAC;YACf,SAAS;QACV,CAAC;QAED,IAAI,aAAa,CAAC,QAAQ,CAAC,EAAE,CAAC;YAC7B,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAC9B,CAAC;IACF,CAAC;IAED,MAAM,UAAU,GAAG,YAAY,CAAC,MAAM,GAAG,CAAC,CAAC;IAE3C,IAAI,CAAC,UAAU,EAAE,CAAC;QACjB,UAAU,CAAC,IAAI,CAAC;YACf,IAAI,EAAE,yBAAyB;YAC/B,IAAI,EAAE,UAAU;YAChB,WAAW,EAAE,iEAAiE;YAC9E,cAAc,EAAE,EAAE;SAClB,CAAC,CAAC;IACJ,CAAC;IAED,OAAO,UAAU,CAAC;AACnB,CAAC"}
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
import type { INodeTypeDescription } from 'n8n-workflow';
|
|
2
|
+
import type { ProgrammaticChecksResult, ProgrammaticEvaluationInput } from './types';
|
|
3
|
+
export declare function programmaticValidation(input: ProgrammaticEvaluationInput, nodeTypes: INodeTypeDescription[]): ProgrammaticChecksResult;
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.programmaticValidation = programmaticValidation;
|
|
4
|
+
const checks_1 = require("../validation/checks");
|
|
5
|
+
function programmaticValidation(input, nodeTypes) {
|
|
6
|
+
const { generatedWorkflow } = input;
|
|
7
|
+
const connectionsValidationResult = (0, checks_1.validateConnections)(generatedWorkflow, nodeTypes);
|
|
8
|
+
const nodesValidationResult = (0, checks_1.validateNodes)(generatedWorkflow, nodeTypes);
|
|
9
|
+
const triggerValidationResult = (0, checks_1.validateTrigger)(generatedWorkflow, nodeTypes);
|
|
10
|
+
const agentPromptValidationResult = (0, checks_1.validateAgentPrompt)(generatedWorkflow);
|
|
11
|
+
const toolsValidationResult = (0, checks_1.validateTools)(generatedWorkflow, nodeTypes);
|
|
12
|
+
const fromAiValidationResult = (0, checks_1.validateFromAi)(generatedWorkflow, nodeTypes);
|
|
13
|
+
const credentialsValidationResult = (0, checks_1.validateCredentials)(generatedWorkflow);
|
|
14
|
+
return {
|
|
15
|
+
connections: connectionsValidationResult,
|
|
16
|
+
nodes: nodesValidationResult,
|
|
17
|
+
trigger: triggerValidationResult,
|
|
18
|
+
agentPrompt: agentPromptValidationResult,
|
|
19
|
+
tools: toolsValidationResult,
|
|
20
|
+
fromAi: fromAiValidationResult,
|
|
21
|
+
credentials: credentialsValidationResult,
|
|
22
|
+
};
|
|
23
|
+
}
|
|
24
|
+
//# sourceMappingURL=programmatic.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"programmatic.js","sourceRoot":"","sources":["../../src/validation/programmatic.ts"],"names":[],"mappings":";;AAcA,wDAuBC;AAnCD,gDAQ6B;AAI7B,SAAgB,sBAAsB,CACrC,KAAkC,EAClC,SAAiC;IAEjC,MAAM,EAAE,iBAAiB,EAAE,GAAG,KAAK,CAAC;IAEpC,MAAM,2BAA2B,GAAG,IAAA,4BAAmB,EAAC,iBAAiB,EAAE,SAAS,CAAC,CAAC;IACtF,MAAM,qBAAqB,GAAG,IAAA,sBAAa,EAAC,iBAAiB,EAAE,SAAS,CAAC,CAAC;IAC1E,MAAM,uBAAuB,GAAG,IAAA,wBAAe,EAAC,iBAAiB,EAAE,SAAS,CAAC,CAAC;IAC9E,MAAM,2BAA2B,GAAG,IAAA,4BAAmB,EAAC,iBAAiB,CAAC,CAAC;IAC3E,MAAM,qBAAqB,GAAG,IAAA,sBAAa,EAAC,iBAAiB,EAAE,SAAS,CAAC,CAAC;IAC1E,MAAM,sBAAsB,GAAG,IAAA,uBAAc,EAAC,iBAAiB,EAAE,SAAS,CAAC,CAAC;IAC5E,MAAM,2BAA2B,GAAG,IAAA,4BAAmB,EAAC,iBAAiB,CAAC,CAAC;IAE3E,OAAO;QACN,WAAW,EAAE,2BAA2B;QACxC,KAAK,EAAE,qBAAqB;QAC5B,OAAO,EAAE,uBAAuB;QAChC,WAAW,EAAE,2BAA2B;QACxC,KAAK,EAAE,qBAAqB;QAC5B,MAAM,EAAE,sBAAsB;QAC9B,WAAW,EAAE,2BAA2B;KACxC,CAAC;AACH,CAAC"}
|
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
import type { INodeTypeDescription, NodeConnectionType } from 'n8n-workflow';
|
|
2
|
+
import type { SimpleWorkflow } from '../types';
|
|
3
|
+
export type ProgrammaticViolationType = 'critical' | 'major' | 'minor';
|
|
4
|
+
export declare const PROGRAMMATIC_VIOLATION_NAMES: readonly ["tool-node-has-no-parameters", "tool-node-static-parameters", "agent-static-prompt", "agent-no-system-prompt", "non-tool-node-uses-fromai", "workflow-has-no-nodes", "workflow-has-no-trigger", "workflow-exceeds-max-nodes-limit", "node-missing-required-input", "node-unsupported-connection-input", "node-merge-single-input", "node-merge-incorrect-num-inputs", "node-merge-missing-input", "sub-node-not-connected", "node-type-not-found", "failed-to-resolve-connections", "workflow-similarity-node-insert", "workflow-similarity-node-delete", "workflow-similarity-node-substitute", "workflow-similarity-edge-insert", "workflow-similarity-edge-delete", "workflow-similarity-edge-substitute", "workflow-similarity-evaluation-failed", "http-request-hardcoded-credentials", "set-node-credential-field"];
|
|
5
|
+
export type ProgrammaticViolationName = (typeof PROGRAMMATIC_VIOLATION_NAMES)[number];
|
|
6
|
+
export type TelemetryValidationStatus = Record<ProgrammaticViolationName, 'pass' | 'fail'>;
|
|
7
|
+
export interface ProgrammaticViolation {
|
|
8
|
+
name: ProgrammaticViolationName;
|
|
9
|
+
type: ProgrammaticViolationType;
|
|
10
|
+
description: string;
|
|
11
|
+
pointsDeducted: number;
|
|
12
|
+
}
|
|
13
|
+
export interface SingleEvaluatorResult {
|
|
14
|
+
violations: ProgrammaticViolation[];
|
|
15
|
+
score: number;
|
|
16
|
+
}
|
|
17
|
+
export interface ProgrammaticChecksResult {
|
|
18
|
+
connections: ProgrammaticViolation[];
|
|
19
|
+
nodes: ProgrammaticViolation[];
|
|
20
|
+
trigger: ProgrammaticViolation[];
|
|
21
|
+
agentPrompt: ProgrammaticViolation[];
|
|
22
|
+
tools: ProgrammaticViolation[];
|
|
23
|
+
fromAi: ProgrammaticViolation[];
|
|
24
|
+
credentials: ProgrammaticViolation[];
|
|
25
|
+
}
|
|
26
|
+
export interface ProgrammaticEvaluationResult {
|
|
27
|
+
overallScore: number;
|
|
28
|
+
connections: SingleEvaluatorResult;
|
|
29
|
+
nodes: SingleEvaluatorResult;
|
|
30
|
+
trigger: SingleEvaluatorResult;
|
|
31
|
+
agentPrompt: SingleEvaluatorResult;
|
|
32
|
+
tools: SingleEvaluatorResult;
|
|
33
|
+
fromAi: SingleEvaluatorResult;
|
|
34
|
+
credentials: SingleEvaluatorResult;
|
|
35
|
+
similarity: SingleEvaluatorResult | null;
|
|
36
|
+
}
|
|
37
|
+
export interface ProgrammaticEvaluationInput {
|
|
38
|
+
generatedWorkflow: SimpleWorkflow;
|
|
39
|
+
userPrompt?: string;
|
|
40
|
+
referenceWorkflow?: SimpleWorkflow;
|
|
41
|
+
referenceWorkflows?: SimpleWorkflow[];
|
|
42
|
+
preset?: 'strict' | 'standard' | 'lenient';
|
|
43
|
+
}
|
|
44
|
+
export interface NodeResolvedConnectionTypesInfo {
|
|
45
|
+
node: SimpleWorkflow['nodes'][0];
|
|
46
|
+
nodeType: INodeTypeDescription;
|
|
47
|
+
resolvedInputs?: Array<{
|
|
48
|
+
type: NodeConnectionType;
|
|
49
|
+
required: boolean;
|
|
50
|
+
}>;
|
|
51
|
+
resolvedOutputs?: Set<NodeConnectionType>;
|
|
52
|
+
}
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.PROGRAMMATIC_VIOLATION_NAMES = void 0;
|
|
4
|
+
exports.PROGRAMMATIC_VIOLATION_NAMES = [
|
|
5
|
+
'tool-node-has-no-parameters',
|
|
6
|
+
'tool-node-static-parameters',
|
|
7
|
+
'agent-static-prompt',
|
|
8
|
+
'agent-no-system-prompt',
|
|
9
|
+
'non-tool-node-uses-fromai',
|
|
10
|
+
'workflow-has-no-nodes',
|
|
11
|
+
'workflow-has-no-trigger',
|
|
12
|
+
'workflow-exceeds-max-nodes-limit',
|
|
13
|
+
'node-missing-required-input',
|
|
14
|
+
'node-unsupported-connection-input',
|
|
15
|
+
'node-merge-single-input',
|
|
16
|
+
'node-merge-incorrect-num-inputs',
|
|
17
|
+
'node-merge-missing-input',
|
|
18
|
+
'sub-node-not-connected',
|
|
19
|
+
'node-type-not-found',
|
|
20
|
+
'failed-to-resolve-connections',
|
|
21
|
+
'workflow-similarity-node-insert',
|
|
22
|
+
'workflow-similarity-node-delete',
|
|
23
|
+
'workflow-similarity-node-substitute',
|
|
24
|
+
'workflow-similarity-edge-insert',
|
|
25
|
+
'workflow-similarity-edge-delete',
|
|
26
|
+
'workflow-similarity-edge-substitute',
|
|
27
|
+
'workflow-similarity-evaluation-failed',
|
|
28
|
+
'http-request-hardcoded-credentials',
|
|
29
|
+
'set-node-credential-field',
|
|
30
|
+
];
|
|
31
|
+
//# sourceMappingURL=types.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../src/validation/types.ts"],"names":[],"mappings":";;;AAMa,QAAA,4BAA4B,GAAG;IAC3C,6BAA6B;IAE7B,6BAA6B;IAC7B,qBAAqB;IACrB,wBAAwB;IACxB,2BAA2B;IAC3B,uBAAuB;IACvB,yBAAyB;IACzB,kCAAkC;IAClC,6BAA6B;IAC7B,mCAAmC;IACnC,yBAAyB;IACzB,iCAAiC;IACjC,0BAA0B;IAC1B,wBAAwB;IACxB,qBAAqB;IACrB,+BAA+B;IAC/B,iCAAiC;IACjC,iCAAiC;IACjC,qCAAqC;IACrC,iCAAiC;IACjC,iCAAiC;IACjC,qCAAqC;IACrC,uCAAuC;IACvC,oCAAoC;IACpC,2BAA2B;CAClB,CAAC"}
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.containsExpression = containsExpression;
|
|
4
|
+
exports.nodeParametersContainExpression = nodeParametersContainExpression;
|
|
5
|
+
const n8n_workflow_1 = require("n8n-workflow");
|
|
6
|
+
function containsExpression(value) {
|
|
7
|
+
if (!(0, n8n_workflow_1.isExpression)(value)) {
|
|
8
|
+
return false;
|
|
9
|
+
}
|
|
10
|
+
return /\{\{.*(\$\(.*?\))|(\$\w+).*}}/.test(value);
|
|
11
|
+
}
|
|
12
|
+
function nodeParametersContainExpression(parameters) {
|
|
13
|
+
for (const value of Object.values(parameters)) {
|
|
14
|
+
if (containsExpression(value)) {
|
|
15
|
+
return true;
|
|
16
|
+
}
|
|
17
|
+
if (value && typeof value === 'object' && !Array.isArray(value)) {
|
|
18
|
+
if (nodeParametersContainExpression(value)) {
|
|
19
|
+
return true;
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
if (Array.isArray(value)) {
|
|
23
|
+
for (const item of value) {
|
|
24
|
+
if (containsExpression(item)) {
|
|
25
|
+
return true;
|
|
26
|
+
}
|
|
27
|
+
if (item && typeof item === 'object') {
|
|
28
|
+
if (nodeParametersContainExpression(item)) {
|
|
29
|
+
return true;
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
return false;
|
|
36
|
+
}
|
|
37
|
+
//# sourceMappingURL=expressions.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"expressions.js","sourceRoot":"","sources":["../../../src/validation/utils/expressions.ts"],"names":[],"mappings":";;AAGA,gDAMC;AAED,0EA4BC;AAtCD,+CAA4C;AAE5C,SAAgB,kBAAkB,CAAC,KAAc;IAChD,IAAI,CAAC,IAAA,2BAAY,EAAC,KAAK,CAAC,EAAE,CAAC;QAC1B,OAAO,KAAK,CAAC;IACd,CAAC;IAED,OAAO,+BAA+B,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;AACpD,CAAC;AAED,SAAgB,+BAA+B,CAAC,UAA2B;IAC1E,KAAK,MAAM,KAAK,IAAI,MAAM,CAAC,MAAM,CAAC,UAAU,CAAC,EAAE,CAAC;QAC/C,IAAI,kBAAkB,CAAC,KAAK,CAAC,EAAE,CAAC;YAC/B,OAAO,IAAI,CAAC;QACb,CAAC;QAED,IAAI,KAAK,IAAI,OAAO,KAAK,KAAK,QAAQ,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE,CAAC;YACjE,IAAI,+BAA+B,CAAC,KAAwB,CAAC,EAAE,CAAC;gBAC/D,OAAO,IAAI,CAAC;YACb,CAAC;QACF,CAAC;QAED,IAAI,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE,CAAC;YAC1B,KAAK,MAAM,IAAI,IAAI,KAAK,EAAE,CAAC;gBAC1B,IAAI,kBAAkB,CAAC,IAAI,CAAC,EAAE,CAAC;oBAC9B,OAAO,IAAI,CAAC;gBACb,CAAC;gBAED,IAAI,IAAI,IAAI,OAAO,IAAI,KAAK,QAAQ,EAAE,CAAC;oBACtC,IAAI,+BAA+B,CAAC,IAAuB,CAAC,EAAE,CAAC;wBAC9D,OAAO,IAAI,CAAC;oBACb,CAAC;gBACF,CAAC;YACF,CAAC;QACF,CAAC;IACF,CAAC;IAED,OAAO,KAAK,CAAC;AACd,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"is-tool.js","sourceRoot":"","sources":["../../../src/validation/utils/is-tool.ts"],"names":[],"mappings":";;AAEA,wBAEC;AAFD,SAAgB,MAAM,CAAC,QAA8B;IACpD,OAAO,QAAQ,CAAC,KAAK,EAAE,aAAa,EAAE,EAAE,EAAE,QAAQ,CAAC,OAAO,CAAC,IAAI,KAAK,CAAC;AACtE,CAAC"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import type { INodeTypeDescription } from 'n8n-workflow';
|
|
2
|
+
import type { SimpleWorkflow } from '../../types';
|
|
3
|
+
export declare function createNodeTypeMap(nodeTypes: INodeTypeDescription[]): Map<string, INodeTypeDescription>;
|
|
4
|
+
export declare function getNodeTypeForNode(node: SimpleWorkflow['nodes'][number], nodeTypeMap: Map<string, INodeTypeDescription>, nodeTypesByName: Map<string, INodeTypeDescription>): INodeTypeDescription | undefined;
|
|
5
|
+
export declare function createNodeTypeMaps(nodeTypes: INodeTypeDescription[]): {
|
|
6
|
+
nodeTypeMap: Map<string, INodeTypeDescription>;
|
|
7
|
+
nodeTypesByName: Map<string, INodeTypeDescription>;
|
|
8
|
+
};
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.createNodeTypeMap = createNodeTypeMap;
|
|
4
|
+
exports.getNodeTypeForNode = getNodeTypeForNode;
|
|
5
|
+
exports.createNodeTypeMaps = createNodeTypeMaps;
|
|
6
|
+
function getNodeTypeVersions(nodeType) {
|
|
7
|
+
const version = nodeType.version;
|
|
8
|
+
if (typeof version === 'number') {
|
|
9
|
+
return [version];
|
|
10
|
+
}
|
|
11
|
+
if (Array.isArray(version) && version.length > 0 && typeof version[0] === 'number') {
|
|
12
|
+
return version;
|
|
13
|
+
}
|
|
14
|
+
return [1];
|
|
15
|
+
}
|
|
16
|
+
function getDefaultVersion(nodeType) {
|
|
17
|
+
const defaultVersion = nodeType.defaultVersion;
|
|
18
|
+
if (typeof defaultVersion === 'number') {
|
|
19
|
+
return defaultVersion;
|
|
20
|
+
}
|
|
21
|
+
const versions = getNodeTypeVersions(nodeType);
|
|
22
|
+
return Math.max(...versions);
|
|
23
|
+
}
|
|
24
|
+
function createNodeTypeMap(nodeTypes) {
|
|
25
|
+
return new Map(nodeTypes.flatMap((nodeType) => {
|
|
26
|
+
const versions = getNodeTypeVersions(nodeType);
|
|
27
|
+
return versions.map((version) => [`${nodeType.name}-${version}`, nodeType]);
|
|
28
|
+
}));
|
|
29
|
+
}
|
|
30
|
+
function resolveNodeVersion(node, nodeTypesByName) {
|
|
31
|
+
if (node.typeVersion !== undefined) {
|
|
32
|
+
return node.typeVersion;
|
|
33
|
+
}
|
|
34
|
+
const nodeType = nodeTypesByName.get(node.type);
|
|
35
|
+
if (nodeType) {
|
|
36
|
+
return getDefaultVersion(nodeType);
|
|
37
|
+
}
|
|
38
|
+
return 1;
|
|
39
|
+
}
|
|
40
|
+
function getNodeTypeForNode(node, nodeTypeMap, nodeTypesByName) {
|
|
41
|
+
const version = resolveNodeVersion(node, nodeTypesByName);
|
|
42
|
+
return nodeTypeMap.get(`${node.type}-${version}`);
|
|
43
|
+
}
|
|
44
|
+
function createNodeTypeMaps(nodeTypes) {
|
|
45
|
+
const nodeTypesArray = Array.from(nodeTypes);
|
|
46
|
+
const nodeTypeMap = createNodeTypeMap(nodeTypesArray);
|
|
47
|
+
const nodeTypesByName = new Map(nodeTypesArray.map((type) => [type.name, type]));
|
|
48
|
+
return { nodeTypeMap, nodeTypesByName };
|
|
49
|
+
}
|
|
50
|
+
//# sourceMappingURL=node-type-map.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"node-type-map.js","sourceRoot":"","sources":["../../../src/validation/utils/node-type-map.ts"],"names":[],"mappings":";;AA+CA,8CASC;AA4BD,gDAOC;AAQD,gDAYC;AArGD,SAAS,mBAAmB,CAAC,QAA8B;IAC1D,MAAM,OAAO,GAAG,QAAQ,CAAC,OAAO,CAAC;IAEjC,IAAI,OAAO,OAAO,KAAK,QAAQ,EAAE,CAAC;QACjC,OAAO,CAAC,OAAO,CAAC,CAAC;IAClB,CAAC;IAED,IAAI,KAAK,CAAC,OAAO,CAAC,OAAO,CAAC,IAAI,OAAO,CAAC,MAAM,GAAG,CAAC,IAAI,OAAO,OAAO,CAAC,CAAC,CAAC,KAAK,QAAQ,EAAE,CAAC;QACpF,OAAO,OAAO,CAAC;IAChB,CAAC;IAGD,OAAO,CAAC,CAAC,CAAC,CAAC;AACZ,CAAC;AAOD,SAAS,iBAAiB,CAAC,QAA8B;IACxD,MAAM,cAAc,GAAG,QAAQ,CAAC,cAAc,CAAC;IAE/C,IAAI,OAAO,cAAc,KAAK,QAAQ,EAAE,CAAC;QACxC,OAAO,cAAc,CAAC;IACvB,CAAC;IAED,MAAM,QAAQ,GAAG,mBAAmB,CAAC,QAAQ,CAAC,CAAC;IAC/C,OAAO,IAAI,CAAC,GAAG,CAAC,GAAG,QAAQ,CAAC,CAAC;AAC9B,CAAC;AAQD,SAAgB,iBAAiB,CAChC,SAAiC;IAEjC,OAAO,IAAI,GAAG,CACb,SAAS,CAAC,OAAO,CAAC,CAAC,QAAQ,EAAE,EAAE;QAC9B,MAAM,QAAQ,GAAG,mBAAmB,CAAC,QAAQ,CAAC,CAAC;QAC/C,OAAO,QAAQ,CAAC,GAAG,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC,GAAG,QAAQ,CAAC,IAAI,IAAI,OAAO,EAAE,EAAE,QAAQ,CAAU,CAAC,CAAC;IACtF,CAAC,CAAC,CACF,CAAC;AACH,CAAC;AAQD,SAAS,kBAAkB,CAC1B,IAAqC,EACrC,eAAkD;IAElD,IAAI,IAAI,CAAC,WAAW,KAAK,SAAS,EAAE,CAAC;QACpC,OAAO,IAAI,CAAC,WAAW,CAAC;IACzB,CAAC;IAED,MAAM,QAAQ,GAAG,eAAe,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAChD,IAAI,QAAQ,EAAE,CAAC;QACd,OAAO,iBAAiB,CAAC,QAAQ,CAAC,CAAC;IACpC,CAAC;IAED,OAAO,CAAC,CAAC;AACV,CAAC;AAMD,SAAgB,kBAAkB,CACjC,IAAqC,EACrC,WAA8C,EAC9C,eAAkD;IAElD,MAAM,OAAO,GAAG,kBAAkB,CAAC,IAAI,EAAE,eAAe,CAAC,CAAC;IAC1D,OAAO,WAAW,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC,IAAI,IAAI,OAAO,EAAE,CAAC,CAAC;AACnD,CAAC;AAQD,SAAgB,kBAAkB,CAAC,SAAiC;IAKnE,MAAM,cAAc,GAAG,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;IAC7C,MAAM,WAAW,GAAG,iBAAiB,CAAC,cAAc,CAAC,CAAC;IACtD,MAAM,eAAe,GAAG,IAAI,GAAG,CAC9B,cAAc,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,CAAU,CAAC,CACxD,CAAC;IAEF,OAAO,EAAE,WAAW,EAAE,eAAe,EAAE,CAAC;AACzC,CAAC"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import type { ExpressionString, INodeInputConfiguration, NodeConnectionType } from 'n8n-workflow';
|
|
2
|
+
import type { NodeResolvedConnectionTypesInfo } from '../types';
|
|
3
|
+
export declare function resolveConnections<T = INodeInputConfiguration>(connections: Array<NodeConnectionType | T> | ExpressionString, parameters: Record<string, unknown>, nodeVersion: number): Array<NodeConnectionType | T>;
|
|
4
|
+
export declare function resolveNodeOutputs(nodeInfo: NodeResolvedConnectionTypesInfo): Set<NodeConnectionType>;
|
|
5
|
+
export declare function resolveNodeInputs(nodeInfo: NodeResolvedConnectionTypesInfo): Array<{
|
|
6
|
+
type: NodeConnectionType;
|
|
7
|
+
required: boolean;
|
|
8
|
+
}>;
|
|
@@ -0,0 +1,64 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.resolveConnections = resolveConnections;
|
|
4
|
+
exports.resolveNodeOutputs = resolveNodeOutputs;
|
|
5
|
+
exports.resolveNodeInputs = resolveNodeInputs;
|
|
6
|
+
const n8n_workflow_1 = require("n8n-workflow");
|
|
7
|
+
function isDynamicConnectionsExpression(connections) {
|
|
8
|
+
return (typeof connections === 'string' && connections.startsWith('={{') && connections.endsWith('}}'));
|
|
9
|
+
}
|
|
10
|
+
function resolveConnections(connections, parameters, nodeVersion) {
|
|
11
|
+
if (Array.isArray(connections)) {
|
|
12
|
+
return connections;
|
|
13
|
+
}
|
|
14
|
+
if (isDynamicConnectionsExpression(connections)) {
|
|
15
|
+
const context = {};
|
|
16
|
+
n8n_workflow_1.Expression.initializeGlobalContext(context);
|
|
17
|
+
Object.assign(context, {
|
|
18
|
+
$parameter: parameters,
|
|
19
|
+
$nodeVersion: nodeVersion,
|
|
20
|
+
});
|
|
21
|
+
const result = n8n_workflow_1.Expression.resolveWithoutWorkflow(connections.substring(1), context);
|
|
22
|
+
if (!Array.isArray(result)) {
|
|
23
|
+
throw new Error('Expression did not resolve to an array');
|
|
24
|
+
}
|
|
25
|
+
return result;
|
|
26
|
+
}
|
|
27
|
+
throw new Error('Unable to resolve connections');
|
|
28
|
+
}
|
|
29
|
+
function resolveNodeOutputs(nodeInfo) {
|
|
30
|
+
const outputTypes = new Set();
|
|
31
|
+
if (!nodeInfo.nodeType.outputs) {
|
|
32
|
+
return outputTypes;
|
|
33
|
+
}
|
|
34
|
+
const resolvedOutputs = resolveConnections(nodeInfo.nodeType.outputs, nodeInfo.node.parameters, nodeInfo.node.typeVersion || 1);
|
|
35
|
+
for (const output of resolvedOutputs) {
|
|
36
|
+
if (typeof output === 'string') {
|
|
37
|
+
outputTypes.add(output);
|
|
38
|
+
}
|
|
39
|
+
else if (typeof output === 'object' && 'type' in output) {
|
|
40
|
+
outputTypes.add(output.type);
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
return outputTypes;
|
|
44
|
+
}
|
|
45
|
+
function resolveNodeInputs(nodeInfo) {
|
|
46
|
+
const requiredInputs = [];
|
|
47
|
+
if (!nodeInfo.nodeType.inputs) {
|
|
48
|
+
return requiredInputs;
|
|
49
|
+
}
|
|
50
|
+
const resolvedInputs = resolveConnections(nodeInfo.nodeType.inputs, nodeInfo.node.parameters, nodeInfo.node.typeVersion || 1);
|
|
51
|
+
for (const input of resolvedInputs) {
|
|
52
|
+
if (typeof input === 'string') {
|
|
53
|
+
requiredInputs.push({ type: input, required: input === 'main' });
|
|
54
|
+
}
|
|
55
|
+
else if (typeof input === 'object' && 'type' in input) {
|
|
56
|
+
requiredInputs.push({
|
|
57
|
+
type: input.type,
|
|
58
|
+
required: input.type === 'main' ? true : (input.required ?? false),
|
|
59
|
+
});
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
return requiredInputs;
|
|
63
|
+
}
|
|
64
|
+
//# sourceMappingURL=resolve-connections.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"resolve-connections.js","sourceRoot":"","sources":["../../../src/validation/utils/resolve-connections.ts"],"names":[],"mappings":";;AAsBA,gDA4BC;AAED,gDAwBC;AAED,8CA2BC;AAnGD,+CAA0C;AAI1C,SAAS,8BAA8B,CACtC,WAAmF;IAEnF,OAAO,CACN,OAAO,WAAW,KAAK,QAAQ,IAAI,WAAW,CAAC,UAAU,CAAC,KAAK,CAAC,IAAI,WAAW,CAAC,QAAQ,CAAC,IAAI,CAAC,CAC9F,CAAC;AACH,CAAC;AAMD,SAAgB,kBAAkB,CACjC,WAA6D,EAC7D,UAAmC,EACnC,WAAmB;IAEnB,IAAI,KAAK,CAAC,OAAO,CAAC,WAAW,CAAC,EAAE,CAAC;QAChC,OAAO,WAAW,CAAC;IACpB,CAAC;IAED,IAAI,8BAA8B,CAAC,WAAW,CAAC,EAAE,CAAC;QACjD,MAAM,OAAO,GAAgB,EAAE,CAAC;QAChC,yBAAU,CAAC,uBAAuB,CAAC,OAAO,CAAC,CAAC;QAE5C,MAAM,CAAC,MAAM,CAAC,OAAO,EAAE;YACtB,UAAU,EAAE,UAAU;YACtB,YAAY,EAAE,WAAW;SACzB,CAAC,CAAC;QAEH,MAAM,MAAM,GAAY,yBAAU,CAAC,sBAAsB,CAAC,WAAW,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,OAAO,CAAC,CAAC;QAE7F,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE,CAAC;YAC5B,MAAM,IAAI,KAAK,CAAC,wCAAwC,CAAC,CAAC;QAC3D,CAAC;QAED,OAAO,MAAuC,CAAC;IAChD,CAAC;IAED,MAAM,IAAI,KAAK,CAAC,+BAA+B,CAAC,CAAC;AAClD,CAAC;AAED,SAAgB,kBAAkB,CACjC,QAAyC;IAEzC,MAAM,WAAW,GAAG,IAAI,GAAG,EAAsB,CAAC;IAElD,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,OAAO,EAAE,CAAC;QAChC,OAAO,WAAW,CAAC;IACpB,CAAC;IAED,MAAM,eAAe,GAAG,kBAAkB,CACzC,QAAQ,CAAC,QAAQ,CAAC,OAAO,EACzB,QAAQ,CAAC,IAAI,CAAC,UAAU,EACxB,QAAQ,CAAC,IAAI,CAAC,WAAW,IAAI,CAAC,CAC9B,CAAC;IAEF,KAAK,MAAM,MAAM,IAAI,eAAe,EAAE,CAAC;QACtC,IAAI,OAAO,MAAM,KAAK,QAAQ,EAAE,CAAC;YAChC,WAAW,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;QACzB,CAAC;aAAM,IAAI,OAAO,MAAM,KAAK,QAAQ,IAAI,MAAM,IAAI,MAAM,EAAE,CAAC;YAC3D,WAAW,CAAC,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;QAC9B,CAAC;IACF,CAAC;IAED,OAAO,WAAW,CAAC;AACpB,CAAC;AAED,SAAgB,iBAAiB,CAChC,QAAyC;IAEzC,MAAM,cAAc,GAA2D,EAAE,CAAC;IAElF,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,MAAM,EAAE,CAAC;QAC/B,OAAO,cAAc,CAAC;IACvB,CAAC;IAED,MAAM,cAAc,GAAG,kBAAkB,CACxC,QAAQ,CAAC,QAAQ,CAAC,MAAM,EACxB,QAAQ,CAAC,IAAI,CAAC,UAAU,EACxB,QAAQ,CAAC,IAAI,CAAC,WAAW,IAAI,CAAC,CAC9B,CAAC;IAEF,KAAK,MAAM,KAAK,IAAI,cAAc,EAAE,CAAC;QACpC,IAAI,OAAO,KAAK,KAAK,QAAQ,EAAE,CAAC;YAC/B,cAAc,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,KAAK,EAAE,QAAQ,EAAE,KAAK,KAAK,MAAM,EAAE,CAAC,CAAC;QAClE,CAAC;aAAM,IAAI,OAAO,KAAK,KAAK,QAAQ,IAAI,MAAM,IAAI,KAAK,EAAE,CAAC;YACzD,cAAc,CAAC,IAAI,CAAC;gBACnB,IAAI,EAAE,KAAK,CAAC,IAAI;gBAChB,QAAQ,EAAE,KAAK,CAAC,IAAI,KAAK,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,QAAQ,IAAI,KAAK,CAAC;aAClE,CAAC,CAAC;QACJ,CAAC;IACF,CAAC;IAED,OAAO,cAAc,CAAC;AACvB,CAAC"}
|
|
@@ -0,0 +1,72 @@
|
|
|
1
|
+
import type { Callbacks } from '@langchain/core/callbacks/manager';
|
|
2
|
+
import type { BaseChatModel } from '@langchain/core/language_models/chat_models';
|
|
3
|
+
import type { LangChainTracer } from '@langchain/core/tracers/tracer_langchain';
|
|
4
|
+
import type { MemorySaver, StateSnapshot } from '@langchain/langgraph';
|
|
5
|
+
import type { Logger } from '@n8n/backend-common';
|
|
6
|
+
import { type INodeTypeDescription, type IRunExecutionData, type IWorkflowBase, type NodeExecutionSchema } from 'n8n-workflow';
|
|
7
|
+
import { WorkflowState } from './workflow-state';
|
|
8
|
+
export type TypedStateSnapshot = Omit<StateSnapshot, 'values'> & {
|
|
9
|
+
values: typeof WorkflowState.State;
|
|
10
|
+
};
|
|
11
|
+
export declare function shouldModifyState(state: typeof WorkflowState.State, autoCompactThresholdTokens: number): 'compact_messages' | 'delete_messages' | 'create_workflow_name' | 'auto_compact_messages' | 'agent';
|
|
12
|
+
export interface WorkflowBuilderAgentConfig {
|
|
13
|
+
parsedNodeTypes: INodeTypeDescription[];
|
|
14
|
+
llmSimpleTask: BaseChatModel;
|
|
15
|
+
llmComplexTask: BaseChatModel;
|
|
16
|
+
logger?: Logger;
|
|
17
|
+
checkpointer: MemorySaver;
|
|
18
|
+
tracer?: LangChainTracer;
|
|
19
|
+
autoCompactThresholdTokens?: number;
|
|
20
|
+
instanceUrl?: string;
|
|
21
|
+
onGenerationSuccess?: () => Promise<void>;
|
|
22
|
+
runMetadata?: Record<string, unknown>;
|
|
23
|
+
featureFlags?: BuilderFeatureFlags;
|
|
24
|
+
}
|
|
25
|
+
export interface ExpressionValue {
|
|
26
|
+
expression: string;
|
|
27
|
+
resolvedValue: unknown;
|
|
28
|
+
nodeType?: string;
|
|
29
|
+
}
|
|
30
|
+
export interface BuilderFeatureFlags {
|
|
31
|
+
templateExamples?: boolean;
|
|
32
|
+
multiAgent?: boolean;
|
|
33
|
+
}
|
|
34
|
+
export interface ChatPayload {
|
|
35
|
+
id: string;
|
|
36
|
+
message: string;
|
|
37
|
+
workflowContext?: {
|
|
38
|
+
executionSchema?: NodeExecutionSchema[];
|
|
39
|
+
currentWorkflow?: Partial<IWorkflowBase>;
|
|
40
|
+
executionData?: IRunExecutionData['resultData'];
|
|
41
|
+
expressionValues?: Record<string, ExpressionValue[]>;
|
|
42
|
+
};
|
|
43
|
+
featureFlags?: BuilderFeatureFlags;
|
|
44
|
+
versionId?: string;
|
|
45
|
+
}
|
|
46
|
+
export declare class WorkflowBuilderAgent {
|
|
47
|
+
private checkpointer;
|
|
48
|
+
private parsedNodeTypes;
|
|
49
|
+
private llmSimpleTask;
|
|
50
|
+
private llmComplexTask;
|
|
51
|
+
private logger?;
|
|
52
|
+
private tracer?;
|
|
53
|
+
private autoCompactThresholdTokens;
|
|
54
|
+
private instanceUrl?;
|
|
55
|
+
private onGenerationSuccess?;
|
|
56
|
+
private runMetadata?;
|
|
57
|
+
constructor(config: WorkflowBuilderAgentConfig);
|
|
58
|
+
private getBuilderTools;
|
|
59
|
+
private createMultiAgentGraph;
|
|
60
|
+
private createLegacyWorkflow;
|
|
61
|
+
private createWorkflow;
|
|
62
|
+
getState(workflowId?: string, userId?: string): Promise<TypedStateSnapshot>;
|
|
63
|
+
private getDefaultWorkflowJSON;
|
|
64
|
+
chat(payload: ChatPayload, userId?: string, abortSignal?: AbortSignal, externalCallbacks?: Callbacks): AsyncGenerator<import("./types").StreamOutput, void, unknown>;
|
|
65
|
+
private validateMessageLength;
|
|
66
|
+
private setupAgentAndConfigs;
|
|
67
|
+
private createAgentStream;
|
|
68
|
+
private handleStreamError;
|
|
69
|
+
private processAgentStream;
|
|
70
|
+
private handleAgentStreamError;
|
|
71
|
+
private getInvalidRequestError;
|
|
72
|
+
}
|