@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 @@
|
|
|
1
|
+
{"version":3,"file":"tool-executor.js","sourceRoot":"","sources":["../../src/utils/tool-executor.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.trimWorkflowJSON = trimWorkflowJSON;
|
|
4
|
+
const constants_1 = require("../constants");
|
|
5
|
+
const token_usage_1 = require("../utils/token-usage");
|
|
6
|
+
const MAX_PARAMETER_VALUE_LENGTH_THRESHOLDS = [10000, 5000, 2000, 1000];
|
|
7
|
+
function trimParameterValue(value, threshold) {
|
|
8
|
+
if (value === undefined || value === null) {
|
|
9
|
+
return value;
|
|
10
|
+
}
|
|
11
|
+
const valueStr = JSON.stringify(value);
|
|
12
|
+
if (valueStr.length > threshold) {
|
|
13
|
+
if (typeof value === 'string') {
|
|
14
|
+
return '[Large value omitted]';
|
|
15
|
+
}
|
|
16
|
+
else if (Array.isArray(value)) {
|
|
17
|
+
return '[Large array omitted]';
|
|
18
|
+
}
|
|
19
|
+
else if (typeof value === 'object' && value !== null) {
|
|
20
|
+
return '[Large object omitted]';
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
return value;
|
|
24
|
+
}
|
|
25
|
+
function trimWorkflowJsonWithThreshold(workflow, threshold) {
|
|
26
|
+
const simplifiedWorkflow = { ...workflow };
|
|
27
|
+
if (simplifiedWorkflow.nodes) {
|
|
28
|
+
simplifiedWorkflow.nodes = simplifiedWorkflow.nodes.map((node) => {
|
|
29
|
+
const simplifiedNode = { ...node };
|
|
30
|
+
if (simplifiedNode.parameters) {
|
|
31
|
+
const simplifiedParameters = {};
|
|
32
|
+
for (const [key, value] of Object.entries(simplifiedNode.parameters)) {
|
|
33
|
+
simplifiedParameters[key] = trimParameterValue(value, threshold);
|
|
34
|
+
}
|
|
35
|
+
simplifiedNode.parameters = simplifiedParameters;
|
|
36
|
+
}
|
|
37
|
+
return simplifiedNode;
|
|
38
|
+
});
|
|
39
|
+
}
|
|
40
|
+
return simplifiedWorkflow;
|
|
41
|
+
}
|
|
42
|
+
function trimWorkflowJSON(workflow) {
|
|
43
|
+
for (const threshold of MAX_PARAMETER_VALUE_LENGTH_THRESHOLDS) {
|
|
44
|
+
const simplified = trimWorkflowJsonWithThreshold(workflow, threshold);
|
|
45
|
+
const workflowStr = JSON.stringify(simplified);
|
|
46
|
+
const estimatedTokens = (0, token_usage_1.estimateTokenCountFromString)(workflowStr);
|
|
47
|
+
if (estimatedTokens <= constants_1.MAX_WORKFLOW_LENGTH_TOKENS) {
|
|
48
|
+
return simplified;
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
return trimWorkflowJsonWithThreshold(workflow, MAX_PARAMETER_VALUE_LENGTH_THRESHOLDS[MAX_PARAMETER_VALUE_LENGTH_THRESHOLDS.length - 1]);
|
|
52
|
+
}
|
|
53
|
+
//# sourceMappingURL=trim-workflow-context.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"trim-workflow-context.js","sourceRoot":"","sources":["../../src/utils/trim-workflow-context.ts"],"names":[],"mappings":";;AAoFA,4CAmBC;AArGD,2CAAyD;AAEzD,qDAAmE;AAMnE,MAAM,qCAAqC,GAAG,CAAC,KAAK,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC;AAUxE,SAAS,kBAAkB,CAC1B,KAA6B,EAC7B,SAAiB;IAGjB,IAAI,KAAK,KAAK,SAAS,IAAI,KAAK,KAAK,IAAI,EAAE,CAAC;QAC3C,OAAO,KAAK,CAAC;IACd,CAAC;IAED,MAAM,QAAQ,GAAG,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;IACvC,IAAI,QAAQ,CAAC,MAAM,GAAG,SAAS,EAAE,CAAC;QAEjC,IAAI,OAAO,KAAK,KAAK,QAAQ,EAAE,CAAC;YAC/B,OAAO,uBAAuB,CAAC;QAChC,CAAC;aAAM,IAAI,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE,CAAC;YACjC,OAAO,uBAAuB,CAAC;QAChC,CAAC;aAAM,IAAI,OAAO,KAAK,KAAK,QAAQ,IAAI,KAAK,KAAK,IAAI,EAAE,CAAC;YACxD,OAAO,wBAAwB,CAAC;QACjC,CAAC;IACF,CAAC;IAED,OAAO,KAAK,CAAC;AACd,CAAC;AAUD,SAAS,6BAA6B,CACrC,QAAwB,EACxB,SAAiB;IAEjB,MAAM,kBAAkB,GAAG,EAAE,GAAG,QAAQ,EAAE,CAAC;IAC3C,IAAI,kBAAkB,CAAC,KAAK,EAAE,CAAC;QAC9B,kBAAkB,CAAC,KAAK,GAAG,kBAAkB,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE;YAChE,MAAM,cAAc,GAAG,EAAE,GAAG,IAAI,EAAE,CAAC;YAGnC,IAAI,cAAc,CAAC,UAAU,EAAE,CAAC;gBAC/B,MAAM,oBAAoB,GAAoB,EAAE,CAAC;gBACjD,KAAK,MAAM,CAAC,GAAG,EAAE,KAAK,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,cAAc,CAAC,UAAU,CAAC,EAAE,CAAC;oBACtE,oBAAoB,CAAC,GAAG,CAAC,GAAG,kBAAkB,CAAC,KAAK,EAAE,SAAS,CAAC,CAAC;gBAClE,CAAC;gBACD,cAAc,CAAC,UAAU,GAAG,oBAAoB,CAAC;YAClD,CAAC;YAED,OAAO,cAAc,CAAC;QACvB,CAAC,CAAC,CAAC;IACJ,CAAC;IAED,OAAO,kBAAkB,CAAC;AAC3B,CAAC;AASD,SAAgB,gBAAgB,CAAC,QAAwB;IAExD,KAAK,MAAM,SAAS,IAAI,qCAAqC,EAAE,CAAC;QAC/D,MAAM,UAAU,GAAG,6BAA6B,CAAC,QAAQ,EAAE,SAAS,CAAC,CAAC;QACtE,MAAM,WAAW,GAAG,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,CAAC;QAC/C,MAAM,eAAe,GAAG,IAAA,0CAA4B,EAAC,WAAW,CAAC,CAAC;QAGlE,IAAI,eAAe,IAAI,sCAA0B,EAAE,CAAC;YACnD,OAAO,UAAU,CAAC;QACnB,CAAC;IACF,CAAC;IAID,OAAO,6BAA6B,CACnC,QAAQ,EACR,qCAAqC,CAAC,qCAAqC,CAAC,MAAM,GAAG,CAAC,CAAC,CACvF,CAAC;AACH,CAAC"}
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.formatWorkflowValidation = formatWorkflowValidation;
|
|
4
|
+
function formatViolationsByCategory(categories) {
|
|
5
|
+
const lines = [];
|
|
6
|
+
for (const [name, violations] of categories) {
|
|
7
|
+
if (!violations.length)
|
|
8
|
+
continue;
|
|
9
|
+
lines.push(`${name}:`);
|
|
10
|
+
for (const violation of violations) {
|
|
11
|
+
lines.push(`- (${violation.type}) ${violation.description}`);
|
|
12
|
+
}
|
|
13
|
+
}
|
|
14
|
+
return lines;
|
|
15
|
+
}
|
|
16
|
+
function formatWorkflowValidation(validation) {
|
|
17
|
+
if (!validation) {
|
|
18
|
+
return 'Workflow validation not yet run. Call the validate_workflow tool to analyze the current workflow.';
|
|
19
|
+
}
|
|
20
|
+
const lines = ['Workflow Validation Summary:'];
|
|
21
|
+
const violationLines = formatViolationsByCategory([
|
|
22
|
+
['Connections', validation.connections],
|
|
23
|
+
['Trigger', validation.trigger],
|
|
24
|
+
['Nodes', validation.nodes],
|
|
25
|
+
['Agent Prompt', validation.agentPrompt],
|
|
26
|
+
['Tools', validation.tools],
|
|
27
|
+
['From AI', validation.fromAi],
|
|
28
|
+
]);
|
|
29
|
+
if (violationLines.length === 0) {
|
|
30
|
+
lines.push('No validation violations detected.');
|
|
31
|
+
}
|
|
32
|
+
else {
|
|
33
|
+
lines.push(...violationLines);
|
|
34
|
+
}
|
|
35
|
+
return lines.join('\n');
|
|
36
|
+
}
|
|
37
|
+
//# sourceMappingURL=workflow-validation.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"workflow-validation.js","sourceRoot":"","sources":["../../src/utils/workflow-validation.ts"],"names":[],"mappings":";;AAmBA,4DAuBC;AAxCD,SAAS,0BAA0B,CAClC,UAAoD;IAEpD,MAAM,KAAK,GAAa,EAAE,CAAC;IAE3B,KAAK,MAAM,CAAC,IAAI,EAAE,UAAU,CAAC,IAAI,UAAU,EAAE,CAAC;QAC7C,IAAI,CAAC,UAAU,CAAC,MAAM;YAAE,SAAS;QAEjC,KAAK,CAAC,IAAI,CAAC,GAAG,IAAI,GAAG,CAAC,CAAC;QACvB,KAAK,MAAM,SAAS,IAAI,UAAU,EAAE,CAAC;YACpC,KAAK,CAAC,IAAI,CAAC,MAAM,SAAS,CAAC,IAAI,KAAK,SAAS,CAAC,WAAW,EAAE,CAAC,CAAC;QAC9D,CAAC;IACF,CAAC;IAED,OAAO,KAAK,CAAC;AACd,CAAC;AAED,SAAgB,wBAAwB,CAAC,UAA2C;IACnF,IAAI,CAAC,UAAU,EAAE,CAAC;QACjB,OAAO,mGAAmG,CAAC;IAC5G,CAAC;IAED,MAAM,KAAK,GAAa,CAAC,8BAA8B,CAAC,CAAC;IAEzD,MAAM,cAAc,GAAG,0BAA0B,CAAC;QACjD,CAAC,aAAa,EAAE,UAAU,CAAC,WAAW,CAAC;QACvC,CAAC,SAAS,EAAE,UAAU,CAAC,OAAO,CAAC;QAC/B,CAAC,OAAO,EAAE,UAAU,CAAC,KAAK,CAAC;QAC3B,CAAC,cAAc,EAAE,UAAU,CAAC,WAAW,CAAC;QACxC,CAAC,OAAO,EAAE,UAAU,CAAC,KAAK,CAAC;QAC3B,CAAC,SAAS,EAAE,UAAU,CAAC,MAAM,CAAC;KAC9B,CAAC,CAAC;IAEH,IAAI,cAAc,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QACjC,KAAK,CAAC,IAAI,CAAC,oCAAoC,CAAC,CAAC;IAClD,CAAC;SAAM,CAAC;QACP,KAAK,CAAC,IAAI,CAAC,GAAG,cAAc,CAAC,CAAC;IAC/B,CAAC;IAED,OAAO,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;AACzB,CAAC"}
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.validateAgentPrompt = validateAgentPrompt;
|
|
4
|
+
const expressions_1 = require("../utils/expressions");
|
|
5
|
+
function isOptionsWithSystemMessage(value) {
|
|
6
|
+
return (typeof value === 'object' &&
|
|
7
|
+
value !== null &&
|
|
8
|
+
!Array.isArray(value) &&
|
|
9
|
+
('systemMessage' in value || Object.keys(value).length === 0));
|
|
10
|
+
}
|
|
11
|
+
function validateAgentPrompt(workflow) {
|
|
12
|
+
const violations = [];
|
|
13
|
+
if (!workflow.nodes || workflow.nodes.length === 0) {
|
|
14
|
+
return [];
|
|
15
|
+
}
|
|
16
|
+
for (const node of workflow.nodes) {
|
|
17
|
+
if (node.type === '@n8n/n8n-nodes-langchain.agent') {
|
|
18
|
+
const textParam = node.parameters?.text;
|
|
19
|
+
const promptType = node.parameters?.promptType;
|
|
20
|
+
const options = node.parameters?.options;
|
|
21
|
+
let systemMessage;
|
|
22
|
+
if (isOptionsWithSystemMessage(options)) {
|
|
23
|
+
systemMessage = options.systemMessage;
|
|
24
|
+
}
|
|
25
|
+
if (promptType !== 'auto' && promptType !== 'guardrails') {
|
|
26
|
+
if (!textParam || !(0, expressions_1.containsExpression)(textParam)) {
|
|
27
|
+
violations.push({
|
|
28
|
+
name: 'agent-static-prompt',
|
|
29
|
+
type: 'major',
|
|
30
|
+
description: `Agent node "${node.name}" has no expression in its prompt field. This likely means it failed to use chatInput or dynamic context`,
|
|
31
|
+
pointsDeducted: 20,
|
|
32
|
+
});
|
|
33
|
+
}
|
|
34
|
+
if (!systemMessage || systemMessage.trim().length === 0) {
|
|
35
|
+
violations.push({
|
|
36
|
+
name: 'agent-no-system-prompt',
|
|
37
|
+
type: 'major',
|
|
38
|
+
description: `Agent node "${node.name}" has no system message. System-level instructions (role, tasks, behavior) should be in the system message field, not the text field`,
|
|
39
|
+
pointsDeducted: 25,
|
|
40
|
+
});
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
return violations;
|
|
46
|
+
}
|
|
47
|
+
//# sourceMappingURL=agent-prompt.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"agent-prompt.js","sourceRoot":"","sources":["../../../src/validation/checks/agent-prompt.ts"],"names":[],"mappings":";;AA4BA,kDAmDC;AA1ED,sDAA0D;AAK1D,SAAS,0BAA0B,CAClC,KAAc;IAEd,OAAO,CACN,OAAO,KAAK,KAAK,QAAQ;QACzB,KAAK,KAAK,IAAI;QACd,CAAC,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC;QACrB,CAAC,eAAe,IAAI,KAAK,IAAI,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,MAAM,KAAK,CAAC,CAAC,CAC7D,CAAC;AACH,CAAC;AASD,SAAgB,mBAAmB,CAAC,QAAwB;IAC3D,MAAM,UAAU,GAA4B,EAAE,CAAC;IAG/C,IAAI,CAAC,QAAQ,CAAC,KAAK,IAAI,QAAQ,CAAC,KAAK,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QACpD,OAAO,EAAE,CAAC;IACX,CAAC;IAGD,KAAK,MAAM,IAAI,IAAI,QAAQ,CAAC,KAAK,EAAE,CAAC;QAEnC,IAAI,IAAI,CAAC,IAAI,KAAK,gCAAgC,EAAE,CAAC;YAEpD,MAAM,SAAS,GAAG,IAAI,CAAC,UAAU,EAAE,IAAI,CAAC;YACxC,MAAM,UAAU,GAAG,IAAI,CAAC,UAAU,EAAE,UAAU,CAAC;YAC/C,MAAM,OAAO,GAAG,IAAI,CAAC,UAAU,EAAE,OAAO,CAAC;YAGzC,IAAI,aAAiC,CAAC;YACtC,IAAI,0BAA0B,CAAC,OAAO,CAAC,EAAE,CAAC;gBACzC,aAAa,GAAG,OAAO,CAAC,aAAa,CAAC;YACvC,CAAC;YAID,IAAI,UAAU,KAAK,MAAM,IAAI,UAAU,KAAK,YAAY,EAAE,CAAC;gBAE1D,IAAI,CAAC,SAAS,IAAI,CAAC,IAAA,gCAAkB,EAAC,SAAS,CAAC,EAAE,CAAC;oBAClD,UAAU,CAAC,IAAI,CAAC;wBACf,IAAI,EAAE,qBAAqB;wBAC3B,IAAI,EAAE,OAAO;wBACb,WAAW,EAAE,eAAe,IAAI,CAAC,IAAI,0GAA0G;wBAC/I,cAAc,EAAE,EAAE;qBAClB,CAAC,CAAC;gBACJ,CAAC;gBAID,IAAI,CAAC,aAAa,IAAI,aAAa,CAAC,IAAI,EAAE,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;oBACzD,UAAU,CAAC,IAAI,CAAC;wBACf,IAAI,EAAE,wBAAwB;wBAC9B,IAAI,EAAE,OAAO;wBACb,WAAW,EAAE,eAAe,IAAI,CAAC,IAAI,sIAAsI;wBAC3K,cAAc,EAAE,EAAE;qBAClB,CAAC,CAAC;gBACJ,CAAC;YACF,CAAC;QACF,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 { ProgrammaticViolation } from '../types';
|
|
4
|
+
export declare function validateConnections(workflow: SimpleWorkflow, nodeTypes: INodeTypeDescription[]): ProgrammaticViolation[];
|
|
@@ -0,0 +1,163 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.validateConnections = validateConnections;
|
|
4
|
+
const n8n_workflow_1 = require("n8n-workflow");
|
|
5
|
+
const node_helpers_1 = require("../../utils/node-helpers");
|
|
6
|
+
const node_type_map_1 = require("../../validation/utils/node-type-map");
|
|
7
|
+
const resolve_connections_1 = require("../../validation/utils/resolve-connections");
|
|
8
|
+
function getProvidedInputTypes(nodeConnections) {
|
|
9
|
+
const providedInputTypes = new Map();
|
|
10
|
+
if (!nodeConnections)
|
|
11
|
+
return providedInputTypes;
|
|
12
|
+
for (const [connectionType, connections] of Object.entries(nodeConnections)) {
|
|
13
|
+
let totalConnections = 0;
|
|
14
|
+
for (const connectionSet of connections) {
|
|
15
|
+
if (!connectionSet)
|
|
16
|
+
continue;
|
|
17
|
+
totalConnections += connectionSet.length;
|
|
18
|
+
}
|
|
19
|
+
if (totalConnections > 0) {
|
|
20
|
+
providedInputTypes.set(connectionType, totalConnections);
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
return providedInputTypes;
|
|
24
|
+
}
|
|
25
|
+
function checkMissingRequiredInputs(nodeInfo, providedInputTypes) {
|
|
26
|
+
const issues = [];
|
|
27
|
+
if (!nodeInfo.resolvedInputs)
|
|
28
|
+
return issues;
|
|
29
|
+
for (const input of nodeInfo.resolvedInputs) {
|
|
30
|
+
const providedCount = providedInputTypes.get(input.type) ?? 0;
|
|
31
|
+
if (input.required && providedCount === 0) {
|
|
32
|
+
issues.push({
|
|
33
|
+
name: 'node-missing-required-input',
|
|
34
|
+
type: 'critical',
|
|
35
|
+
description: `Node ${nodeInfo.node.name} (${nodeInfo.node.type}) is missing required input of type ${input.type}`,
|
|
36
|
+
pointsDeducted: 50,
|
|
37
|
+
});
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
return issues;
|
|
41
|
+
}
|
|
42
|
+
function checkUnsupportedConnections(nodeInfo, providedInputTypes) {
|
|
43
|
+
const issues = [];
|
|
44
|
+
if (!nodeInfo.resolvedInputs)
|
|
45
|
+
return issues;
|
|
46
|
+
const supportedTypes = new Set(nodeInfo.resolvedInputs.map((input) => input.type));
|
|
47
|
+
for (const [type] of providedInputTypes) {
|
|
48
|
+
if (!supportedTypes.has(type)) {
|
|
49
|
+
issues.push({
|
|
50
|
+
name: 'node-unsupported-connection-input',
|
|
51
|
+
type: 'critical',
|
|
52
|
+
description: `Node ${nodeInfo.node.name} (${nodeInfo.node.type}) received unsupported connection type ${type}`,
|
|
53
|
+
pointsDeducted: 50,
|
|
54
|
+
});
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
return issues;
|
|
58
|
+
}
|
|
59
|
+
function checkMergeNodeConnections(nodeInfo, nodeConnections) {
|
|
60
|
+
const issues = [];
|
|
61
|
+
if (/\.merge$/.test(nodeInfo.node.type)) {
|
|
62
|
+
const numberInputsParam = nodeInfo.node.parameters?.numberInputs;
|
|
63
|
+
const expectedInputs = typeof numberInputsParam === 'number' ? numberInputsParam : 2;
|
|
64
|
+
const mainConnections = nodeConnections?.main ?? [];
|
|
65
|
+
const connectedSlots = mainConnections.filter((slot) => Array.isArray(slot) && slot.length > 0).length;
|
|
66
|
+
if (connectedSlots < 2) {
|
|
67
|
+
issues.push({
|
|
68
|
+
name: 'node-merge-single-input',
|
|
69
|
+
type: 'major',
|
|
70
|
+
description: `Merge node ${nodeInfo.node.name} has only ${connectedSlots} input connection(s). Merge nodes require at least 2 inputs to function properly.`,
|
|
71
|
+
pointsDeducted: 20,
|
|
72
|
+
});
|
|
73
|
+
}
|
|
74
|
+
const missingIndexes = [];
|
|
75
|
+
for (let inputIndex = 0; inputIndex < expectedInputs; inputIndex++) {
|
|
76
|
+
const connectionsForIndex = mainConnections[inputIndex];
|
|
77
|
+
const hasConnections = Array.isArray(connectionsForIndex) && connectionsForIndex.length > 0;
|
|
78
|
+
if (!hasConnections) {
|
|
79
|
+
missingIndexes.push(inputIndex + 1);
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
if (missingIndexes.length > 0) {
|
|
83
|
+
issues.push({
|
|
84
|
+
name: 'node-merge-missing-input',
|
|
85
|
+
type: 'major',
|
|
86
|
+
description: `Merge node ${nodeInfo.node.name} is missing connections for input(s) ${missingIndexes.join(', ')}.`,
|
|
87
|
+
pointsDeducted: 20,
|
|
88
|
+
});
|
|
89
|
+
}
|
|
90
|
+
}
|
|
91
|
+
return issues;
|
|
92
|
+
}
|
|
93
|
+
function checkSubNodeRootConnections(workflow, nodeInfo, nodesByName) {
|
|
94
|
+
const issues = [];
|
|
95
|
+
const { node, nodeType, resolvedOutputs } = nodeInfo;
|
|
96
|
+
if (!resolvedOutputs || resolvedOutputs.size === 0) {
|
|
97
|
+
return issues;
|
|
98
|
+
}
|
|
99
|
+
if (!(0, node_helpers_1.isSubNode)(nodeType, node)) {
|
|
100
|
+
return issues;
|
|
101
|
+
}
|
|
102
|
+
const aiOutputs = Array.from(resolvedOutputs).filter((output) => output.startsWith('ai_'));
|
|
103
|
+
if (aiOutputs.length === 0) {
|
|
104
|
+
return issues;
|
|
105
|
+
}
|
|
106
|
+
const nodeConnections = workflow.connections?.[node.name];
|
|
107
|
+
for (const outputType of aiOutputs) {
|
|
108
|
+
const connectionsForType = nodeConnections?.[outputType];
|
|
109
|
+
const hasRootConnection = connectionsForType?.some((connectionGroup) => connectionGroup?.some((connection) => connection?.node && nodesByName.has(connection.node)));
|
|
110
|
+
if (!hasRootConnection) {
|
|
111
|
+
issues.push({
|
|
112
|
+
name: 'sub-node-not-connected',
|
|
113
|
+
type: 'critical',
|
|
114
|
+
description: `Sub-node ${node.name} (${node.type}) provides ${outputType} but is not connected to a root node.`,
|
|
115
|
+
pointsDeducted: 50,
|
|
116
|
+
});
|
|
117
|
+
}
|
|
118
|
+
}
|
|
119
|
+
return issues;
|
|
120
|
+
}
|
|
121
|
+
function validateConnections(workflow, nodeTypes) {
|
|
122
|
+
const violations = [];
|
|
123
|
+
if (!workflow.connections) {
|
|
124
|
+
workflow.connections = {};
|
|
125
|
+
}
|
|
126
|
+
const connectionsByDestination = (0, n8n_workflow_1.mapConnectionsByDestination)(workflow.connections);
|
|
127
|
+
const nodesByName = new Map(workflow.nodes.map((node) => [node.name, node]));
|
|
128
|
+
const { nodeTypeMap, nodeTypesByName } = (0, node_type_map_1.createNodeTypeMaps)(nodeTypes);
|
|
129
|
+
for (const node of workflow.nodes) {
|
|
130
|
+
const nodeType = (0, node_type_map_1.getNodeTypeForNode)(node, nodeTypeMap, nodeTypesByName);
|
|
131
|
+
if (!nodeType) {
|
|
132
|
+
violations.push({
|
|
133
|
+
name: 'node-type-not-found',
|
|
134
|
+
type: 'critical',
|
|
135
|
+
description: `Node type ${node.type} not found for node ${node.name}`,
|
|
136
|
+
pointsDeducted: 50,
|
|
137
|
+
});
|
|
138
|
+
continue;
|
|
139
|
+
}
|
|
140
|
+
const nodeInfo = { node, nodeType };
|
|
141
|
+
try {
|
|
142
|
+
nodeInfo.resolvedInputs = (0, resolve_connections_1.resolveNodeInputs)(nodeInfo);
|
|
143
|
+
nodeInfo.resolvedOutputs = (0, resolve_connections_1.resolveNodeOutputs)(nodeInfo);
|
|
144
|
+
}
|
|
145
|
+
catch (error) {
|
|
146
|
+
violations.push({
|
|
147
|
+
name: 'failed-to-resolve-connections',
|
|
148
|
+
type: 'critical',
|
|
149
|
+
description: `Failed to resolve connections for node ${node.name} (${node.type}): ${error instanceof Error ? error.message : String(error)}`,
|
|
150
|
+
pointsDeducted: 50,
|
|
151
|
+
});
|
|
152
|
+
continue;
|
|
153
|
+
}
|
|
154
|
+
const nodeConnections = connectionsByDestination[node.name];
|
|
155
|
+
const providedInputTypes = getProvidedInputTypes(nodeConnections);
|
|
156
|
+
violations.push(...checkMissingRequiredInputs(nodeInfo, providedInputTypes));
|
|
157
|
+
violations.push(...checkUnsupportedConnections(nodeInfo, providedInputTypes));
|
|
158
|
+
violations.push(...checkMergeNodeConnections(nodeInfo, nodeConnections));
|
|
159
|
+
violations.push(...checkSubNodeRootConnections(workflow, nodeInfo, nodesByName));
|
|
160
|
+
}
|
|
161
|
+
return violations;
|
|
162
|
+
}
|
|
163
|
+
//# sourceMappingURL=connections.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"connections.js","sourceRoot":"","sources":["../../../src/validation/checks/connections.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,125 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.validateCredentials = validateCredentials;
|
|
4
|
+
const CREDENTIAL_FIELD_PATTERNS = [
|
|
5
|
+
/api[_-]?key/i,
|
|
6
|
+
/access[_-]?token/i,
|
|
7
|
+
/auth[_-]?token/i,
|
|
8
|
+
/bearer[_-]?token/i,
|
|
9
|
+
/secret[_-]?key/i,
|
|
10
|
+
/private[_-]?key/i,
|
|
11
|
+
/client[_-]?secret/i,
|
|
12
|
+
/password/i,
|
|
13
|
+
/credentials?/i,
|
|
14
|
+
/^token$/i,
|
|
15
|
+
/^secret$/i,
|
|
16
|
+
/^auth$/i,
|
|
17
|
+
];
|
|
18
|
+
const SENSITIVE_HEADERS = new Set([
|
|
19
|
+
'authorization',
|
|
20
|
+
'x-api-key',
|
|
21
|
+
'x-auth-token',
|
|
22
|
+
'x-access-token',
|
|
23
|
+
'api-key',
|
|
24
|
+
'apikey',
|
|
25
|
+
]);
|
|
26
|
+
function isCredentialFieldName(name) {
|
|
27
|
+
return CREDENTIAL_FIELD_PATTERNS.some((pattern) => pattern.test(name));
|
|
28
|
+
}
|
|
29
|
+
function isSensitiveHeader(headerName) {
|
|
30
|
+
return SENSITIVE_HEADERS.has(headerName.toLowerCase());
|
|
31
|
+
}
|
|
32
|
+
function isExpression(value) {
|
|
33
|
+
if (typeof value !== 'string')
|
|
34
|
+
return false;
|
|
35
|
+
return value.startsWith('={{') || value.startsWith('=');
|
|
36
|
+
}
|
|
37
|
+
function isParameterArray(arr) {
|
|
38
|
+
return (Array.isArray(arr) &&
|
|
39
|
+
arr.every((item) => typeof item === 'object' && item !== null && !Array.isArray(item)));
|
|
40
|
+
}
|
|
41
|
+
function isParametersContainer(value) {
|
|
42
|
+
if (typeof value !== 'object' || value === null)
|
|
43
|
+
return false;
|
|
44
|
+
const obj = value;
|
|
45
|
+
return !('parameters' in obj) || isParameterArray(obj.parameters);
|
|
46
|
+
}
|
|
47
|
+
function isAssignmentsContainer(value) {
|
|
48
|
+
if (typeof value !== 'object' || value === null)
|
|
49
|
+
return false;
|
|
50
|
+
const obj = value;
|
|
51
|
+
return !('assignments' in obj) || isParameterArray(obj.assignments);
|
|
52
|
+
}
|
|
53
|
+
function getHeaderParameters(parameters) {
|
|
54
|
+
const headerParams = parameters.headerParameters;
|
|
55
|
+
if (!isParametersContainer(headerParams))
|
|
56
|
+
return [];
|
|
57
|
+
return headerParams.parameters ?? [];
|
|
58
|
+
}
|
|
59
|
+
function getQueryParameters(parameters) {
|
|
60
|
+
const queryParams = parameters.queryParameters;
|
|
61
|
+
if (!isParametersContainer(queryParams))
|
|
62
|
+
return [];
|
|
63
|
+
return queryParams.parameters ?? [];
|
|
64
|
+
}
|
|
65
|
+
function getSetNodeAssignments(parameters) {
|
|
66
|
+
const assignments = parameters.assignments;
|
|
67
|
+
if (!isAssignmentsContainer(assignments))
|
|
68
|
+
return [];
|
|
69
|
+
return assignments.assignments ?? [];
|
|
70
|
+
}
|
|
71
|
+
function hasHardcodedCredentialValue(param) {
|
|
72
|
+
return Boolean(param.value) && !isExpression(param.value);
|
|
73
|
+
}
|
|
74
|
+
function validateHttpRequestNode(node, violations) {
|
|
75
|
+
const params = node.parameters ?? {};
|
|
76
|
+
for (const header of getHeaderParameters(params)) {
|
|
77
|
+
if (header.name && isSensitiveHeader(header.name) && hasHardcodedCredentialValue(header)) {
|
|
78
|
+
violations.push({
|
|
79
|
+
name: 'http-request-hardcoded-credentials',
|
|
80
|
+
type: 'major',
|
|
81
|
+
description: `HTTP Request node "${node.name}" has a hardcoded value for sensitive header "${header.name}". Use n8n credentials instead (e.g., httpHeaderAuth, httpBearerAuth).`,
|
|
82
|
+
pointsDeducted: 20,
|
|
83
|
+
});
|
|
84
|
+
}
|
|
85
|
+
}
|
|
86
|
+
for (const param of getQueryParameters(params)) {
|
|
87
|
+
if (param.name && isCredentialFieldName(param.name) && hasHardcodedCredentialValue(param)) {
|
|
88
|
+
violations.push({
|
|
89
|
+
name: 'http-request-hardcoded-credentials',
|
|
90
|
+
type: 'major',
|
|
91
|
+
description: `HTTP Request node "${node.name}" has a hardcoded value for credential-like query parameter "${param.name}". Use n8n credentials instead (e.g., httpQueryAuth).`,
|
|
92
|
+
pointsDeducted: 20,
|
|
93
|
+
});
|
|
94
|
+
}
|
|
95
|
+
}
|
|
96
|
+
}
|
|
97
|
+
function validateSetNode(node, violations) {
|
|
98
|
+
const params = node.parameters ?? {};
|
|
99
|
+
for (const assignment of getSetNodeAssignments(params)) {
|
|
100
|
+
if (assignment.name && isCredentialFieldName(assignment.name)) {
|
|
101
|
+
violations.push({
|
|
102
|
+
name: 'set-node-credential-field',
|
|
103
|
+
type: 'major',
|
|
104
|
+
description: `Set node "${node.name}" has a field named "${assignment.name}" which appears to be storing credentials. Credentials should be stored securely using n8n's credential system, not in workflow data.`,
|
|
105
|
+
pointsDeducted: 20,
|
|
106
|
+
});
|
|
107
|
+
}
|
|
108
|
+
}
|
|
109
|
+
}
|
|
110
|
+
function validateCredentials(workflow) {
|
|
111
|
+
const violations = [];
|
|
112
|
+
if (!workflow.nodes || workflow.nodes.length === 0) {
|
|
113
|
+
return violations;
|
|
114
|
+
}
|
|
115
|
+
for (const node of workflow.nodes) {
|
|
116
|
+
if (node.type === 'n8n-nodes-base.httpRequest') {
|
|
117
|
+
validateHttpRequestNode(node, violations);
|
|
118
|
+
}
|
|
119
|
+
else if (node.type === 'n8n-nodes-base.set') {
|
|
120
|
+
validateSetNode(node, violations);
|
|
121
|
+
}
|
|
122
|
+
}
|
|
123
|
+
return violations;
|
|
124
|
+
}
|
|
125
|
+
//# sourceMappingURL=credentials.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"credentials.js","sourceRoot":"","sources":["../../../src/validation/checks/credentials.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import type { INodeTypeDescription } from 'n8n-workflow';
|
|
2
|
+
import type { SimpleWorkflow } from '../../types';
|
|
3
|
+
import type { ProgrammaticViolation } from '../types';
|
|
4
|
+
export declare function validateFromAi(workflow: SimpleWorkflow, nodeTypes: INodeTypeDescription[]): ProgrammaticViolation[];
|
|
@@ -0,0 +1,62 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.validateFromAi = validateFromAi;
|
|
4
|
+
const node_type_map_1 = require("../../validation/utils/node-type-map");
|
|
5
|
+
const is_tool_1 = require("../utils/is-tool");
|
|
6
|
+
function containsFromAi(value) {
|
|
7
|
+
if (typeof value !== 'string') {
|
|
8
|
+
return false;
|
|
9
|
+
}
|
|
10
|
+
return /\$from[Aa][Ii]\(.+\)/.test(value);
|
|
11
|
+
}
|
|
12
|
+
function parametersContainFromAi(parameters) {
|
|
13
|
+
for (const value of Object.values(parameters)) {
|
|
14
|
+
if (containsFromAi(value)) {
|
|
15
|
+
return true;
|
|
16
|
+
}
|
|
17
|
+
if (value && typeof value === 'object' && !Array.isArray(value)) {
|
|
18
|
+
if (parametersContainFromAi(value)) {
|
|
19
|
+
return true;
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
if (Array.isArray(value)) {
|
|
23
|
+
for (const item of value) {
|
|
24
|
+
if (containsFromAi(item)) {
|
|
25
|
+
return true;
|
|
26
|
+
}
|
|
27
|
+
if (item && typeof item === 'object' && !Array.isArray(value)) {
|
|
28
|
+
if (parametersContainFromAi(value)) {
|
|
29
|
+
return true;
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
return false;
|
|
36
|
+
}
|
|
37
|
+
function validateFromAi(workflow, nodeTypes) {
|
|
38
|
+
const violations = [];
|
|
39
|
+
if (!workflow.nodes || workflow.nodes.length === 0) {
|
|
40
|
+
return violations;
|
|
41
|
+
}
|
|
42
|
+
const { nodeTypeMap, nodeTypesByName } = (0, node_type_map_1.createNodeTypeMaps)(nodeTypes);
|
|
43
|
+
for (const node of workflow.nodes) {
|
|
44
|
+
const nodeType = (0, node_type_map_1.getNodeTypeForNode)(node, nodeTypeMap, nodeTypesByName);
|
|
45
|
+
if (!nodeType) {
|
|
46
|
+
continue;
|
|
47
|
+
}
|
|
48
|
+
if ((0, is_tool_1.isTool)(nodeType)) {
|
|
49
|
+
continue;
|
|
50
|
+
}
|
|
51
|
+
if (node.parameters && parametersContainFromAi(node.parameters)) {
|
|
52
|
+
violations.push({
|
|
53
|
+
name: 'non-tool-node-uses-fromai',
|
|
54
|
+
type: 'major',
|
|
55
|
+
description: `Non-tool node "${node.name}" (${node.type}) uses $fromAI in its parameters. $fromAI is only for tool nodes connected to AI agents.`,
|
|
56
|
+
pointsDeducted: 20,
|
|
57
|
+
});
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
return violations;
|
|
61
|
+
}
|
|
62
|
+
//# sourceMappingURL=from-ai.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"from-ai.js","sourceRoot":"","sources":["../../../src/validation/checks/from-ai.ts"],"names":[],"mappings":";;AA8CA,wCAiCC;AA5ED,oEAA0F;AAG1F,8CAA0C;AAE1C,SAAS,cAAc,CAAC,KAAc;IACrC,IAAI,OAAO,KAAK,KAAK,QAAQ,EAAE,CAAC;QAC/B,OAAO,KAAK,CAAC;IACd,CAAC;IAED,OAAO,sBAAsB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;AAC3C,CAAC;AAED,SAAS,uBAAuB,CAAC,UAA2B;IAC3D,KAAK,MAAM,KAAK,IAAI,MAAM,CAAC,MAAM,CAAC,UAAU,CAAC,EAAE,CAAC;QAC/C,IAAI,cAAc,CAAC,KAAK,CAAC,EAAE,CAAC;YAC3B,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,uBAAuB,CAAC,KAAwB,CAAC,EAAE,CAAC;gBACvD,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,cAAc,CAAC,IAAI,CAAC,EAAE,CAAC;oBAC1B,OAAO,IAAI,CAAC;gBACb,CAAC;gBAED,IAAI,IAAI,IAAI,OAAO,IAAI,KAAK,QAAQ,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE,CAAC;oBAC/D,IAAI,uBAAuB,CAAC,KAAwB,CAAC,EAAE,CAAC;wBACvD,OAAO,IAAI,CAAC;oBACb,CAAC;gBACF,CAAC;YACF,CAAC;QACF,CAAC;IACF,CAAC;IAED,OAAO,KAAK,CAAC;AACd,CAAC;AAED,SAAgB,cAAc,CAC7B,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,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,EAAE,CAAC;YACtB,SAAS;QACV,CAAC;QAED,IAAI,IAAI,CAAC,UAAU,IAAI,uBAAuB,CAAC,IAAI,CAAC,UAAU,CAAC,EAAE,CAAC;YACjE,UAAU,CAAC,IAAI,CAAC;gBACf,IAAI,EAAE,2BAA2B;gBACjC,IAAI,EAAE,OAAO;gBACb,WAAW,EAAE,kBAAkB,IAAI,CAAC,IAAI,MAAM,IAAI,CAAC,IAAI,0FAA0F;gBACjJ,cAAc,EAAE,EAAE;aAClB,CAAC,CAAC;QACJ,CAAC;IACF,CAAC;IAED,OAAO,UAAU,CAAC;AACnB,CAAC"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
export { validateAgentPrompt } from './agent-prompt';
|
|
2
|
+
export { validateConnections } from './connections';
|
|
3
|
+
export { validateCredentials } from './credentials';
|
|
4
|
+
export { validateFromAi } from './from-ai';
|
|
5
|
+
export { validateNodes } from './nodes';
|
|
6
|
+
export { validateTools } from './tools';
|
|
7
|
+
export { validateTrigger, type TriggerEvaluationResult } from './trigger';
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.validateTrigger = exports.validateTools = exports.validateNodes = exports.validateFromAi = exports.validateCredentials = exports.validateConnections = exports.validateAgentPrompt = void 0;
|
|
4
|
+
var agent_prompt_1 = require("./agent-prompt");
|
|
5
|
+
Object.defineProperty(exports, "validateAgentPrompt", { enumerable: true, get: function () { return agent_prompt_1.validateAgentPrompt; } });
|
|
6
|
+
var connections_1 = require("./connections");
|
|
7
|
+
Object.defineProperty(exports, "validateConnections", { enumerable: true, get: function () { return connections_1.validateConnections; } });
|
|
8
|
+
var credentials_1 = require("./credentials");
|
|
9
|
+
Object.defineProperty(exports, "validateCredentials", { enumerable: true, get: function () { return credentials_1.validateCredentials; } });
|
|
10
|
+
var from_ai_1 = require("./from-ai");
|
|
11
|
+
Object.defineProperty(exports, "validateFromAi", { enumerable: true, get: function () { return from_ai_1.validateFromAi; } });
|
|
12
|
+
var nodes_1 = require("./nodes");
|
|
13
|
+
Object.defineProperty(exports, "validateNodes", { enumerable: true, get: function () { return nodes_1.validateNodes; } });
|
|
14
|
+
var tools_1 = require("./tools");
|
|
15
|
+
Object.defineProperty(exports, "validateTools", { enumerable: true, get: function () { return tools_1.validateTools; } });
|
|
16
|
+
var trigger_1 = require("./trigger");
|
|
17
|
+
Object.defineProperty(exports, "validateTrigger", { enumerable: true, get: function () { return trigger_1.validateTrigger; } });
|
|
18
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/validation/checks/index.ts"],"names":[],"mappings":";;;AAAA,+CAAqD;AAA5C,mHAAA,mBAAmB,OAAA;AAC5B,6CAAoD;AAA3C,kHAAA,mBAAmB,OAAA;AAC5B,6CAAoD;AAA3C,kHAAA,mBAAmB,OAAA;AAC5B,qCAA2C;AAAlC,yGAAA,cAAc,OAAA;AACvB,iCAAwC;AAA/B,sGAAA,aAAa,OAAA;AACtB,iCAAwC;AAA/B,sGAAA,aAAa,OAAA;AACtB,qCAA0E;AAAjE,0GAAA,eAAe,OAAA"}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import type { INodeTypeDescription } from 'n8n-workflow';
|
|
2
|
+
import type { SimpleWorkflow } from '../../types';
|
|
3
|
+
import type { ProgrammaticViolation } from '../types';
|
|
4
|
+
export declare function validateNodes(workflow: SimpleWorkflow, nodeTypes: INodeTypeDescription[]): ProgrammaticViolation[];
|