@atom8n/n8n-core 2.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/README.md +13 -0
- package/bin/common.js +19 -0
- package/bin/copy-static-files +24 -0
- package/bin/generate-metadata +75 -0
- package/bin/generate-translations +99 -0
- package/dist/binary-data/binary-data.config.d.ts +15 -0
- package/dist/binary-data/binary-data.config.js +62 -0
- package/dist/binary-data/binary-data.config.js.map +1 -0
- package/dist/binary-data/binary-data.service.d.ts +32 -0
- package/dist/binary-data/binary-data.service.js +243 -0
- package/dist/binary-data/binary-data.service.js.map +1 -0
- package/dist/binary-data/file-system.manager.d.ts +31 -0
- package/dist/binary-data/file-system.manager.js +154 -0
- package/dist/binary-data/file-system.manager.js.map +1 -0
- package/dist/binary-data/index.d.ts +5 -0
- package/dist/binary-data/index.js +27 -0
- package/dist/binary-data/index.js.map +1 -0
- package/dist/binary-data/object-store/object-store.config.d.ts +19 -0
- package/dist/binary-data/object-store/object-store.config.js +83 -0
- package/dist/binary-data/object-store/object-store.config.js.map +1 -0
- package/dist/binary-data/object-store/object-store.service.ee.d.ts +46 -0
- package/dist/binary-data/object-store/object-store.service.ee.js +235 -0
- package/dist/binary-data/object-store/object-store.service.ee.js.map +1 -0
- package/dist/binary-data/object-store/types.d.ts +8 -0
- package/dist/binary-data/object-store/types.js +3 -0
- package/dist/binary-data/object-store/types.js.map +1 -0
- package/dist/binary-data/object-store.manager.d.ts +23 -0
- package/dist/binary-data/object-store.manager.js +86 -0
- package/dist/binary-data/object-store.manager.js.map +1 -0
- package/dist/binary-data/types.d.ts +46 -0
- package/dist/binary-data/types.js +3 -0
- package/dist/binary-data/types.js.map +1 -0
- package/dist/binary-data/utils.d.ts +15 -0
- package/dist/binary-data/utils.js +66 -0
- package/dist/binary-data/utils.js.map +1 -0
- package/dist/build.tsbuildinfo +1 -0
- package/dist/constants.d.ts +19 -0
- package/dist/constants.js +23 -0
- package/dist/constants.js.map +1 -0
- package/dist/credentials.d.ts +12 -0
- package/dist/credentials.js +99 -0
- package/dist/credentials.js.map +1 -0
- package/dist/data-deduplication-service.d.ts +16 -0
- package/dist/data-deduplication-service.js +95 -0
- package/dist/data-deduplication-service.js.map +1 -0
- package/dist/encryption/cipher.d.ts +8 -0
- package/dist/encryption/cipher.js +57 -0
- package/dist/encryption/cipher.js.map +1 -0
- package/dist/encryption/index.d.ts +1 -0
- package/dist/encryption/index.js +6 -0
- package/dist/encryption/index.js.map +1 -0
- package/dist/errors/abstract/binary-data.error.d.ts +3 -0
- package/dist/errors/abstract/binary-data.error.js +8 -0
- package/dist/errors/abstract/binary-data.error.js.map +1 -0
- package/dist/errors/abstract/filesystem.error.d.ts +4 -0
- package/dist/errors/abstract/filesystem.error.js +11 -0
- package/dist/errors/abstract/filesystem.error.js.map +1 -0
- package/dist/errors/binary-data-file-not-found.error.d.ts +4 -0
- package/dist/errors/binary-data-file-not-found.error.js +11 -0
- package/dist/errors/binary-data-file-not-found.error.js.map +1 -0
- package/dist/errors/disallowed-filepath.error.d.ts +4 -0
- package/dist/errors/disallowed-filepath.error.js +11 -0
- package/dist/errors/disallowed-filepath.error.js.map +1 -0
- package/dist/errors/error-reporter.d.ts +35 -0
- package/dist/errors/error-reporter.js +256 -0
- package/dist/errors/error-reporter.js.map +1 -0
- package/dist/errors/file-not-found.error.d.ts +4 -0
- package/dist/errors/file-not-found.error.js +11 -0
- package/dist/errors/file-not-found.error.js.map +1 -0
- package/dist/errors/file-too-large.error.d.ts +9 -0
- package/dist/errors/file-too-large.error.js +13 -0
- package/dist/errors/file-too-large.error.js.map +1 -0
- package/dist/errors/index.d.ts +11 -0
- package/dist/errors/index.js +26 -0
- package/dist/errors/index.js.map +1 -0
- package/dist/errors/invalid-execution-metadata.error.d.ts +5 -0
- package/dist/errors/invalid-execution-metadata.error.js +12 -0
- package/dist/errors/invalid-execution-metadata.error.js.map +1 -0
- package/dist/errors/invalid-manager.error.d.ts +4 -0
- package/dist/errors/invalid-manager.error.js +11 -0
- package/dist/errors/invalid-manager.error.js.map +1 -0
- package/dist/errors/invalid-source-type.error.d.ts +4 -0
- package/dist/errors/invalid-source-type.error.js +11 -0
- package/dist/errors/invalid-source-type.error.js.map +1 -0
- package/dist/errors/missing-source-id.error.d.ts +4 -0
- package/dist/errors/missing-source-id.error.js +11 -0
- package/dist/errors/missing-source-id.error.js.map +1 -0
- package/dist/errors/unrecognized-credential-type.error.d.ts +4 -0
- package/dist/errors/unrecognized-credential-type.error.js +11 -0
- package/dist/errors/unrecognized-credential-type.error.js.map +1 -0
- package/dist/errors/unrecognized-node-type.error.d.ts +4 -0
- package/dist/errors/unrecognized-node-type.error.js +11 -0
- package/dist/errors/unrecognized-node-type.error.js.map +1 -0
- package/dist/errors/workflow-has-issues.error.d.ts +4 -0
- package/dist/errors/workflow-has-issues.error.js +11 -0
- package/dist/errors/workflow-has-issues.error.js.map +1 -0
- package/dist/execution-engine/active-workflows.d.ts +23 -0
- package/dist/execution-engine/active-workflows.js +153 -0
- package/dist/execution-engine/active-workflows.js.map +1 -0
- package/dist/execution-engine/execution-context-hook-registry.service.d.ts +12 -0
- package/dist/execution-engine/execution-context-hook-registry.service.js +69 -0
- package/dist/execution-engine/execution-context-hook-registry.service.js.map +1 -0
- package/dist/execution-engine/execution-context.d.ts +2 -0
- package/dist/execution-engine/execution-context.js +56 -0
- package/dist/execution-engine/execution-context.js.map +1 -0
- package/dist/execution-engine/execution-context.service.d.ts +17 -0
- package/dist/execution-engine/execution-context.service.js +108 -0
- package/dist/execution-engine/execution-context.service.js.map +1 -0
- package/dist/execution-engine/execution-lifecycle-hooks.d.ts +20 -0
- package/dist/execution-engine/execution-lifecycle-hooks.js +31 -0
- package/dist/execution-engine/execution-lifecycle-hooks.js.map +1 -0
- package/dist/execution-engine/external-secrets-proxy.d.ts +18 -0
- package/dist/execution-engine/external-secrets-proxy.js +38 -0
- package/dist/execution-engine/external-secrets-proxy.js.map +1 -0
- package/dist/execution-engine/index.d.ts +26 -0
- package/dist/execution-engine/index.js +31 -0
- package/dist/execution-engine/index.js.map +1 -0
- package/dist/execution-engine/interfaces.d.ts +7 -0
- package/dist/execution-engine/interfaces.js +3 -0
- package/dist/execution-engine/interfaces.js.map +1 -0
- package/dist/execution-engine/node-execution-context/base-execute-context.d.ts +47 -0
- package/dist/execution-engine/node-execution-context/base-execute-context.js +150 -0
- package/dist/execution-engine/node-execution-context/base-execute-context.js.map +1 -0
- package/dist/execution-engine/node-execution-context/credentials-test-context.d.ts +7 -0
- package/dist/execution-engine/node-execution-context/credentials-test-context.js +37 -0
- package/dist/execution-engine/node-execution-context/credentials-test-context.js.map +1 -0
- package/dist/execution-engine/node-execution-context/execute-context.d.ts +24 -0
- package/dist/execution-engine/node-execution-context/execute-context.js +108 -0
- package/dist/execution-engine/node-execution-context/execute-context.js.map +1 -0
- package/dist/execution-engine/node-execution-context/execute-single-context.d.ts +15 -0
- package/dist/execution-engine/node-execution-context/execute-single-context.js +53 -0
- package/dist/execution-engine/node-execution-context/execute-single-context.js.map +1 -0
- package/dist/execution-engine/node-execution-context/hook-context.d.ts +13 -0
- package/dist/execution-engine/node-execution-context/hook-context.js +35 -0
- package/dist/execution-engine/node-execution-context/hook-context.js.map +1 -0
- package/dist/execution-engine/node-execution-context/index.d.ts +17 -0
- package/dist/execution-engine/node-execution-context/index.js +51 -0
- package/dist/execution-engine/node-execution-context/index.js.map +1 -0
- package/dist/execution-engine/node-execution-context/load-options-context.d.ts +10 -0
- package/dist/execution-engine/node-execution-context/load-options-context.js +43 -0
- package/dist/execution-engine/node-execution-context/load-options-context.js.map +1 -0
- package/dist/execution-engine/node-execution-context/local-load-options-context.d.ts +10 -0
- package/dist/execution-engine/node-execution-context/local-load-options-context.js +51 -0
- package/dist/execution-engine/node-execution-context/local-load-options-context.js.map +1 -0
- package/dist/execution-engine/node-execution-context/node-execution-context.d.ts +68 -0
- package/dist/execution-engine/node-execution-context/node-execution-context.js +324 -0
- package/dist/execution-engine/node-execution-context/node-execution-context.js.map +1 -0
- package/dist/execution-engine/node-execution-context/poll-context.d.ts +11 -0
- package/dist/execution-engine/node-execution-context/poll-context.js +38 -0
- package/dist/execution-engine/node-execution-context/poll-context.js.map +1 -0
- package/dist/execution-engine/node-execution-context/supply-data-context.d.ts +26 -0
- package/dist/execution-engine/node-execution-context/supply-data-context.js +181 -0
- package/dist/execution-engine/node-execution-context/supply-data-context.js.map +1 -0
- package/dist/execution-engine/node-execution-context/trigger-context.d.ts +11 -0
- package/dist/execution-engine/node-execution-context/trigger-context.js +40 -0
- package/dist/execution-engine/node-execution-context/trigger-context.js.map +1 -0
- package/dist/execution-engine/node-execution-context/utils/binary-helper-functions.d.ts +10 -0
- package/dist/execution-engine/node-execution-context/utils/binary-helper-functions.js +213 -0
- package/dist/execution-engine/node-execution-context/utils/binary-helper-functions.js.map +1 -0
- package/dist/execution-engine/node-execution-context/utils/cleanup-parameter-data.d.ts +2 -0
- package/dist/execution-engine/node-execution-context/utils/cleanup-parameter-data.js +27 -0
- package/dist/execution-engine/node-execution-context/utils/cleanup-parameter-data.js.map +1 -0
- package/dist/execution-engine/node-execution-context/utils/construct-execution-metadata.d.ts +4 -0
- package/dist/execution-engine/node-execution-context/utils/construct-execution-metadata.js +11 -0
- package/dist/execution-engine/node-execution-context/utils/construct-execution-metadata.js.map +1 -0
- package/dist/execution-engine/node-execution-context/utils/copy-input-items.d.ts +2 -0
- package/dist/execution-engine/node-execution-context/utils/copy-input-items.js +19 -0
- package/dist/execution-engine/node-execution-context/utils/copy-input-items.js.map +1 -0
- package/dist/execution-engine/node-execution-context/utils/create-node-as-tool.d.ts +21 -0
- package/dist/execution-engine/node-execution-context/utils/create-node-as-tool.js +65 -0
- package/dist/execution-engine/node-execution-context/utils/create-node-as-tool.js.map +1 -0
- package/dist/execution-engine/node-execution-context/utils/data-table-helper-functions.d.ts +2 -0
- package/dist/execution-engine/node-execution-context/utils/data-table-helper-functions.js +13 -0
- package/dist/execution-engine/node-execution-context/utils/data-table-helper-functions.js.map +1 -0
- package/dist/execution-engine/node-execution-context/utils/deduplication-helper-functions.d.ts +2 -0
- package/dist/execution-engine/node-execution-context/utils/deduplication-helper-functions.js +38 -0
- package/dist/execution-engine/node-execution-context/utils/deduplication-helper-functions.js.map +1 -0
- package/dist/execution-engine/node-execution-context/utils/ensure-type.d.ts +6 -0
- package/dist/execution-engine/node-execution-context/utils/ensure-type.js +75 -0
- package/dist/execution-engine/node-execution-context/utils/ensure-type.js.map +1 -0
- package/dist/execution-engine/node-execution-context/utils/execution-metadata.d.ts +6 -0
- package/dist/execution-engine/node-execution-context/utils/execution-metadata.js +57 -0
- package/dist/execution-engine/node-execution-context/utils/execution-metadata.js.map +1 -0
- package/dist/execution-engine/node-execution-context/utils/extract-value.d.ts +2 -0
- package/dist/execution-engine/node-execution-context/utils/extract-value.js +135 -0
- package/dist/execution-engine/node-execution-context/utils/extract-value.js.map +1 -0
- package/dist/execution-engine/node-execution-context/utils/file-system-helper-functions.d.ts +2 -0
- package/dist/execution-engine/node-execution-context/utils/file-system-helper-functions.js +144 -0
- package/dist/execution-engine/node-execution-context/utils/file-system-helper-functions.js.map +1 -0
- package/dist/execution-engine/node-execution-context/utils/get-additional-keys.d.ts +4 -0
- package/dist/execution-engine/node-execution-context/utils/get-additional-keys.js +57 -0
- package/dist/execution-engine/node-execution-context/utils/get-additional-keys.js.map +1 -0
- package/dist/execution-engine/node-execution-context/utils/get-input-connection-data.d.ts +5 -0
- package/dist/execution-engine/node-execution-context/utils/get-input-connection-data.js +211 -0
- package/dist/execution-engine/node-execution-context/utils/get-input-connection-data.js.map +1 -0
- package/dist/execution-engine/node-execution-context/utils/get-secrets-proxy.d.ts +2 -0
- package/dist/execution-engine/node-execution-context/utils/get-secrets-proxy.js +68 -0
- package/dist/execution-engine/node-execution-context/utils/get-secrets-proxy.js.map +1 -0
- package/dist/execution-engine/node-execution-context/utils/normalize-items.d.ts +2 -0
- package/dist/execution-engine/node-execution-context/utils/normalize-items.js +36 -0
- package/dist/execution-engine/node-execution-context/utils/normalize-items.js.map +1 -0
- package/dist/execution-engine/node-execution-context/utils/parse-incoming-message.d.ts +16 -0
- package/dist/execution-engine/node-execution-context/utils/parse-incoming-message.js +57 -0
- package/dist/execution-engine/node-execution-context/utils/parse-incoming-message.js.map +1 -0
- package/dist/execution-engine/node-execution-context/utils/request-helper-functions.d.ts +18 -0
- package/dist/execution-engine/node-execution-context/utils/request-helper-functions.js +1213 -0
- package/dist/execution-engine/node-execution-context/utils/request-helper-functions.js.map +1 -0
- package/dist/execution-engine/node-execution-context/utils/return-json-array.d.ts +2 -0
- package/dist/execution-engine/node-execution-context/utils/return-json-array.js +19 -0
- package/dist/execution-engine/node-execution-context/utils/return-json-array.js.map +1 -0
- package/dist/execution-engine/node-execution-context/utils/scheduling-helper-functions.d.ts +2 -0
- package/dist/execution-engine/node-execution-context/utils/scheduling-helper-functions.js +22 -0
- package/dist/execution-engine/node-execution-context/utils/scheduling-helper-functions.js.map +1 -0
- package/dist/execution-engine/node-execution-context/utils/ssh-tunnel-helper-functions.d.ts +2 -0
- package/dist/execution-engine/node-execution-context/utils/ssh-tunnel-helper-functions.js +14 -0
- package/dist/execution-engine/node-execution-context/utils/ssh-tunnel-helper-functions.js.map +1 -0
- package/dist/execution-engine/node-execution-context/utils/validate-value-against-schema.d.ts +2 -0
- package/dist/execution-engine/node-execution-context/utils/validate-value-against-schema.js +132 -0
- package/dist/execution-engine/node-execution-context/utils/validate-value-against-schema.js.map +1 -0
- package/dist/execution-engine/node-execution-context/utils/webhook-helper-functions.d.ts +3 -0
- package/dist/execution-engine/node-execution-context/utils/webhook-helper-functions.js +31 -0
- package/dist/execution-engine/node-execution-context/utils/webhook-helper-functions.js.map +1 -0
- package/dist/execution-engine/node-execution-context/webhook-context.d.ts +21 -0
- package/dist/execution-engine/node-execution-context/webhook-context.js +87 -0
- package/dist/execution-engine/node-execution-context/webhook-context.js.map +1 -0
- package/dist/execution-engine/node-execution-context/workflow-node-context.d.ts +6 -0
- package/dist/execution-engine/node-execution-context/workflow-node-context.js +14 -0
- package/dist/execution-engine/node-execution-context/workflow-node-context.js.map +1 -0
- package/dist/execution-engine/partial-execution-utils/clean-run-data.d.ts +3 -0
- package/dist/execution-engine/partial-execution-utils/clean-run-data.js +28 -0
- package/dist/execution-engine/partial-execution-utils/clean-run-data.js.map +1 -0
- package/dist/execution-engine/partial-execution-utils/directed-graph.d.ts +65 -0
- package/dist/execution-engine/partial-execution-utils/directed-graph.js +370 -0
- package/dist/execution-engine/partial-execution-utils/directed-graph.js.map +1 -0
- package/dist/execution-engine/partial-execution-utils/filter-disabled-nodes.d.ts +2 -0
- package/dist/execution-engine/partial-execution-utils/filter-disabled-nodes.js +17 -0
- package/dist/execution-engine/partial-execution-utils/filter-disabled-nodes.js.map +1 -0
- package/dist/execution-engine/partial-execution-utils/find-start-nodes.d.ts +10 -0
- package/dist/execution-engine/partial-execution-utils/find-start-nodes.js +74 -0
- package/dist/execution-engine/partial-execution-utils/find-start-nodes.js.map +1 -0
- package/dist/execution-engine/partial-execution-utils/find-subgraph.d.ts +7 -0
- package/dist/execution-engine/partial-execution-utils/find-subgraph.js +59 -0
- package/dist/execution-engine/partial-execution-utils/find-subgraph.js.map +1 -0
- package/dist/execution-engine/partial-execution-utils/find-trigger-for-partial-execution.d.ts +4 -0
- package/dist/execution-engine/partial-execution-utils/find-trigger-for-partial-execution.js +102 -0
- package/dist/execution-engine/partial-execution-utils/find-trigger-for-partial-execution.js.map +1 -0
- package/dist/execution-engine/partial-execution-utils/get-incoming-data.d.ts +6 -0
- package/dist/execution-engine/partial-execution-utils/get-incoming-data.js +21 -0
- package/dist/execution-engine/partial-execution-utils/get-incoming-data.js.map +1 -0
- package/dist/execution-engine/partial-execution-utils/get-source-data-groups.d.ts +8 -0
- package/dist/execution-engine/partial-execution-utils/get-source-data-groups.js +65 -0
- package/dist/execution-engine/partial-execution-utils/get-source-data-groups.js.map +1 -0
- package/dist/execution-engine/partial-execution-utils/handle-cycles.d.ts +3 -0
- package/dist/execution-engine/partial-execution-utils/handle-cycles.js +60 -0
- package/dist/execution-engine/partial-execution-utils/handle-cycles.js.map +1 -0
- package/dist/execution-engine/partial-execution-utils/index.d.ts +10 -0
- package/dist/execution-engine/partial-execution-utils/index.js +25 -0
- package/dist/execution-engine/partial-execution-utils/index.js.map +1 -0
- package/dist/execution-engine/partial-execution-utils/recreate-node-execution-stack.d.ts +9 -0
- package/dist/execution-engine/partial-execution-utils/recreate-node-execution-stack.js +146 -0
- package/dist/execution-engine/partial-execution-utils/recreate-node-execution-stack.js.map +1 -0
- package/dist/execution-engine/partial-execution-utils/rewire-graph.d.ts +3 -0
- package/dist/execution-engine/partial-execution-utils/rewire-graph.js +72 -0
- package/dist/execution-engine/partial-execution-utils/rewire-graph.js.map +1 -0
- package/dist/execution-engine/partial-execution-utils/run-data-utils.d.ts +2 -0
- package/dist/execution-engine/partial-execution-utils/run-data-utils.js +15 -0
- package/dist/execution-engine/partial-execution-utils/run-data-utils.js.map +1 -0
- package/dist/execution-engine/requests-response.d.ts +23 -0
- package/dist/execution-engine/requests-response.js +128 -0
- package/dist/execution-engine/requests-response.js.map +1 -0
- package/dist/execution-engine/routing-node.d.ts +17 -0
- package/dist/execution-engine/routing-node.js +571 -0
- package/dist/execution-engine/routing-node.js.map +1 -0
- package/dist/execution-engine/scheduled-task-manager.d.ts +27 -0
- package/dist/execution-engine/scheduled-task-manager.js +140 -0
- package/dist/execution-engine/scheduled-task-manager.js.map +1 -0
- package/dist/execution-engine/ssh-clients-manager.d.ts +27 -0
- package/dist/execution-engine/ssh-clients-manager.js +170 -0
- package/dist/execution-engine/ssh-clients-manager.js.map +1 -0
- package/dist/execution-engine/triggers-and-pollers.d.ts +6 -0
- package/dist/execution-engine/triggers-and-pollers.js +66 -0
- package/dist/execution-engine/triggers-and-pollers.js.map +1 -0
- package/dist/execution-engine/workflow-execute.d.ts +46 -0
- package/dist/execution-engine/workflow-execute.js +1490 -0
- package/dist/execution-engine/workflow-execute.js.map +1 -0
- package/dist/html-sandbox.d.ts +3 -0
- package/dist/html-sandbox.js +19 -0
- package/dist/html-sandbox.js.map +1 -0
- package/dist/http-proxy.d.ts +6 -0
- package/dist/http-proxy.js +109 -0
- package/dist/http-proxy.js.map +1 -0
- package/dist/index.d.ts +17 -0
- package/dist/index.js +57 -0
- package/dist/index.js.map +1 -0
- package/dist/instance-settings/index.d.ts +1 -0
- package/dist/instance-settings/index.js +6 -0
- package/dist/instance-settings/index.js.map +1 -0
- package/dist/instance-settings/instance-settings.d.ts +49 -0
- package/dist/instance-settings/instance-settings.js +210 -0
- package/dist/instance-settings/instance-settings.js.map +1 -0
- package/dist/instance-settings/worker-missing-encryption-key.error.d.ts +4 -0
- package/dist/instance-settings/worker-missing-encryption-key.error.js +15 -0
- package/dist/instance-settings/worker-missing-encryption-key.error.js.map +1 -0
- package/dist/interfaces.d.ts +16 -0
- package/dist/interfaces.js +3 -0
- package/dist/interfaces.js.map +1 -0
- package/dist/node-execute-functions.d.ts +3 -0
- package/dist/node-execute-functions.js +12 -0
- package/dist/node-execute-functions.js.map +1 -0
- package/dist/nodes-loader/constants.d.ts +5 -0
- package/dist/nodes-loader/constants.js +106 -0
- package/dist/nodes-loader/constants.js.map +1 -0
- package/dist/nodes-loader/custom-directory-loader.d.ts +6 -0
- package/dist/nodes-loader/custom-directory-loader.js +34 -0
- package/dist/nodes-loader/custom-directory-loader.js.map +1 -0
- package/dist/nodes-loader/directory-loader.d.ts +41 -0
- package/dist/nodes-loader/directory-loader.js +371 -0
- package/dist/nodes-loader/directory-loader.js.map +1 -0
- package/dist/nodes-loader/index.d.ts +5 -0
- package/dist/nodes-loader/index.js +12 -0
- package/dist/nodes-loader/index.js.map +1 -0
- package/dist/nodes-loader/lazy-package-directory-loader.d.ts +4 -0
- package/dist/nodes-loader/lazy-package-directory-loader.js +42 -0
- package/dist/nodes-loader/lazy-package-directory-loader.js.map +1 -0
- package/dist/nodes-loader/load-class-in-isolation.d.ts +1 -0
- package/dist/nodes-loader/load-class-in-isolation.js +20 -0
- package/dist/nodes-loader/load-class-in-isolation.js.map +1 -0
- package/dist/nodes-loader/package-directory-loader.d.ts +12 -0
- package/dist/nodes-loader/package-directory-loader.js +86 -0
- package/dist/nodes-loader/package-directory-loader.js.map +1 -0
- package/dist/nodes-loader/types.d.ts +14 -0
- package/dist/nodes-loader/types.js +3 -0
- package/dist/nodes-loader/types.js.map +1 -0
- package/dist/utils/assertions.d.ts +2 -0
- package/dist/utils/assertions.js +16 -0
- package/dist/utils/assertions.js.map +1 -0
- package/dist/utils/deep-merge.d.ts +1 -0
- package/dist/utils/deep-merge.js +33 -0
- package/dist/utils/deep-merge.js.map +1 -0
- package/dist/utils/index.d.ts +2 -0
- package/dist/utils/index.js +19 -0
- package/dist/utils/index.js.map +1 -0
- package/dist/utils/is-json-compatible.d.ts +7 -0
- package/dist/utils/is-json-compatible.js +81 -0
- package/dist/utils/is-json-compatible.js.map +1 -0
- package/dist/utils/serialized-buffer.d.ts +6 -0
- package/dist/utils/serialized-buffer.js +16 -0
- package/dist/utils/serialized-buffer.js.map +1 -0
- package/dist/utils/signature-helpers.d.ts +2 -0
- package/dist/utils/signature-helpers.js +16 -0
- package/dist/utils/signature-helpers.js.map +1 -0
- package/package.json +81 -0
|
@@ -0,0 +1,153 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
9
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
10
|
+
};
|
|
11
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
+
exports.ActiveWorkflows = void 0;
|
|
13
|
+
const backend_common_1 = require("@n8n/backend-common");
|
|
14
|
+
const di_1 = require("@n8n/di");
|
|
15
|
+
const n8n_workflow_1 = require("n8n-workflow");
|
|
16
|
+
const error_reporter_1 = require("../errors/error-reporter");
|
|
17
|
+
const scheduled_task_manager_1 = require("./scheduled-task-manager");
|
|
18
|
+
const triggers_and_pollers_1 = require("./triggers-and-pollers");
|
|
19
|
+
let ActiveWorkflows = class ActiveWorkflows {
|
|
20
|
+
constructor(logger, scheduledTaskManager, triggersAndPollers, errorReporter) {
|
|
21
|
+
this.logger = logger;
|
|
22
|
+
this.scheduledTaskManager = scheduledTaskManager;
|
|
23
|
+
this.triggersAndPollers = triggersAndPollers;
|
|
24
|
+
this.errorReporter = errorReporter;
|
|
25
|
+
this.activeWorkflows = {};
|
|
26
|
+
}
|
|
27
|
+
isActive(workflowId) {
|
|
28
|
+
return this.activeWorkflows.hasOwnProperty(workflowId);
|
|
29
|
+
}
|
|
30
|
+
allActiveWorkflows() {
|
|
31
|
+
return Object.keys(this.activeWorkflows);
|
|
32
|
+
}
|
|
33
|
+
get(workflowId) {
|
|
34
|
+
return this.activeWorkflows[workflowId];
|
|
35
|
+
}
|
|
36
|
+
async add(workflowId, workflow, additionalData, mode, activation, getTriggerFunctions, getPollFunctions) {
|
|
37
|
+
const triggerNodes = workflow.getTriggerNodes();
|
|
38
|
+
const triggerResponses = [];
|
|
39
|
+
for (const triggerNode of triggerNodes) {
|
|
40
|
+
try {
|
|
41
|
+
const triggerResponse = await this.triggersAndPollers.runTrigger(workflow, triggerNode, getTriggerFunctions, additionalData, mode, activation);
|
|
42
|
+
if (triggerResponse !== undefined) {
|
|
43
|
+
triggerResponses.push(triggerResponse);
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
catch (e) {
|
|
47
|
+
const error = e instanceof Error ? e : new Error(`${e}`);
|
|
48
|
+
throw new n8n_workflow_1.WorkflowActivationError(`There was a problem activating the workflow: "${error.message}"`, { cause: error, node: triggerNode });
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
this.activeWorkflows[workflowId] = { triggerResponses };
|
|
52
|
+
const pollingNodes = workflow.getPollNodes();
|
|
53
|
+
if (pollingNodes.length === 0)
|
|
54
|
+
return;
|
|
55
|
+
for (const pollNode of pollingNodes) {
|
|
56
|
+
try {
|
|
57
|
+
await this.activatePolling(pollNode, workflow, additionalData, getPollFunctions, mode, activation);
|
|
58
|
+
}
|
|
59
|
+
catch (e) {
|
|
60
|
+
if (triggerResponses.length === 0) {
|
|
61
|
+
delete this.activeWorkflows[workflowId];
|
|
62
|
+
}
|
|
63
|
+
const error = e instanceof Error ? e : new Error(`${e}`);
|
|
64
|
+
throw new n8n_workflow_1.WorkflowActivationError(`There was a problem activating the workflow: "${error.message}"`, { cause: error, node: pollNode });
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
async activatePolling(node, workflow, additionalData, getPollFunctions, mode, activation) {
|
|
69
|
+
const pollFunctions = getPollFunctions(workflow, node, additionalData, mode, activation);
|
|
70
|
+
const pollTimes = pollFunctions.getNodeParameter('pollTimes');
|
|
71
|
+
const cronExpressions = (pollTimes.item || []).map(n8n_workflow_1.toCronExpression);
|
|
72
|
+
const executeTrigger = async (testingTrigger = false) => {
|
|
73
|
+
this.logger.debug(`Polling trigger initiated for workflow "${workflow.name}"`, {
|
|
74
|
+
workflowName: workflow.name,
|
|
75
|
+
workflowId: workflow.id,
|
|
76
|
+
});
|
|
77
|
+
try {
|
|
78
|
+
const pollResponse = await this.triggersAndPollers.runPoll(workflow, node, pollFunctions);
|
|
79
|
+
if (pollResponse !== null) {
|
|
80
|
+
pollFunctions.__emit(pollResponse);
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
catch (error) {
|
|
84
|
+
if (testingTrigger) {
|
|
85
|
+
throw error;
|
|
86
|
+
}
|
|
87
|
+
pollFunctions.__emitError(error);
|
|
88
|
+
}
|
|
89
|
+
};
|
|
90
|
+
await executeTrigger(true);
|
|
91
|
+
for (const expression of cronExpressions) {
|
|
92
|
+
if (expression.split(' ').at(0)?.includes('*')) {
|
|
93
|
+
throw new n8n_workflow_1.UserError('The polling interval is too short. It has to be at least a minute.');
|
|
94
|
+
}
|
|
95
|
+
const ctx = {
|
|
96
|
+
workflowId: workflow.id,
|
|
97
|
+
timezone: workflow.timezone,
|
|
98
|
+
nodeId: node.id,
|
|
99
|
+
expression,
|
|
100
|
+
};
|
|
101
|
+
this.scheduledTaskManager.registerCron(ctx, executeTrigger);
|
|
102
|
+
}
|
|
103
|
+
}
|
|
104
|
+
async remove(workflowId) {
|
|
105
|
+
if (!this.isActive(workflowId)) {
|
|
106
|
+
this.logger.warn(`Cannot deactivate already inactive workflow ID "${workflowId}"`);
|
|
107
|
+
return false;
|
|
108
|
+
}
|
|
109
|
+
this.scheduledTaskManager.deregisterCrons(workflowId);
|
|
110
|
+
const w = this.activeWorkflows[workflowId];
|
|
111
|
+
for (const r of w.triggerResponses ?? []) {
|
|
112
|
+
await this.closeTrigger(r, workflowId);
|
|
113
|
+
}
|
|
114
|
+
delete this.activeWorkflows[workflowId];
|
|
115
|
+
return true;
|
|
116
|
+
}
|
|
117
|
+
async removeAllTriggerAndPollerBasedWorkflows() {
|
|
118
|
+
const activeWorkflowIds = Object.keys(this.activeWorkflows);
|
|
119
|
+
if (activeWorkflowIds.length === 0)
|
|
120
|
+
return;
|
|
121
|
+
for (const workflowId of activeWorkflowIds) {
|
|
122
|
+
await this.remove(workflowId);
|
|
123
|
+
}
|
|
124
|
+
this.logger.debug('Deactivated all trigger- and poller-based workflows', {
|
|
125
|
+
workflowIds: activeWorkflowIds,
|
|
126
|
+
});
|
|
127
|
+
}
|
|
128
|
+
async closeTrigger(response, workflowId) {
|
|
129
|
+
if (!response.closeFunction)
|
|
130
|
+
return;
|
|
131
|
+
try {
|
|
132
|
+
await response.closeFunction();
|
|
133
|
+
}
|
|
134
|
+
catch (e) {
|
|
135
|
+
if (e instanceof n8n_workflow_1.TriggerCloseError) {
|
|
136
|
+
this.logger.error(`There was a problem calling "closeFunction" on "${e.node.name}" in workflow "${workflowId}"`);
|
|
137
|
+
this.errorReporter.error(e, { extra: { workflowId } });
|
|
138
|
+
return;
|
|
139
|
+
}
|
|
140
|
+
const error = e instanceof Error ? e : new Error(`${e}`);
|
|
141
|
+
throw new n8n_workflow_1.WorkflowDeactivationError(`Failed to deactivate trigger of workflow ID "${workflowId}": "${error.message}"`, { cause: error, workflowId });
|
|
142
|
+
}
|
|
143
|
+
}
|
|
144
|
+
};
|
|
145
|
+
exports.ActiveWorkflows = ActiveWorkflows;
|
|
146
|
+
exports.ActiveWorkflows = ActiveWorkflows = __decorate([
|
|
147
|
+
(0, di_1.Service)(),
|
|
148
|
+
__metadata("design:paramtypes", [backend_common_1.Logger,
|
|
149
|
+
scheduled_task_manager_1.ScheduledTaskManager,
|
|
150
|
+
triggers_and_pollers_1.TriggersAndPollers,
|
|
151
|
+
error_reporter_1.ErrorReporter])
|
|
152
|
+
], ActiveWorkflows);
|
|
153
|
+
//# sourceMappingURL=active-workflows.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"active-workflows.js","sourceRoot":"","sources":["../../src/execution-engine/active-workflows.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,wDAA6C;AAC7C,gCAAkC;AAWlC,+CAMsB;AAEtB,4DAAwD;AAIxD,qEAAgE;AAChE,iEAA4D;AAGrD,IAAM,eAAe,GAArB,MAAM,eAAe;IAC3B,YACkB,MAAc,EACd,oBAA0C,EAC1C,kBAAsC,EACtC,aAA4B;QAH5B,WAAM,GAAN,MAAM,CAAQ;QACd,yBAAoB,GAApB,oBAAoB,CAAsB;QAC1C,uBAAkB,GAAlB,kBAAkB,CAAoB;QACtC,kBAAa,GAAb,aAAa,CAAe;QAGtC,oBAAe,GAA4C,EAAE,CAAC;IAFnE,CAAC;IAOJ,QAAQ,CAAC,UAAkB;QAC1B,OAAO,IAAI,CAAC,eAAe,CAAC,cAAc,CAAC,UAAU,CAAC,CAAC;IACxD,CAAC;IAKD,kBAAkB;QACjB,OAAO,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;IAC1C,CAAC;IAKD,GAAG,CAAC,UAAkB;QACrB,OAAO,IAAI,CAAC,eAAe,CAAC,UAAU,CAAC,CAAC;IACzC,CAAC;IASD,KAAK,CAAC,GAAG,CACR,UAAkB,EAClB,QAAkB,EAClB,cAA8C,EAC9C,IAAyB,EACzB,UAAgC,EAChC,mBAAgD,EAChD,gBAA0C;QAE1C,MAAM,YAAY,GAAG,QAAQ,CAAC,eAAe,EAAE,CAAC;QAEhD,MAAM,gBAAgB,GAAuB,EAAE,CAAC;QAEhD,KAAK,MAAM,WAAW,IAAI,YAAY,EAAE,CAAC;YACxC,IAAI,CAAC;gBACJ,MAAM,eAAe,GAAG,MAAM,IAAI,CAAC,kBAAkB,CAAC,UAAU,CAC/D,QAAQ,EACR,WAAW,EACX,mBAAmB,EACnB,cAAc,EACd,IAAI,EACJ,UAAU,CACV,CAAC;gBACF,IAAI,eAAe,KAAK,SAAS,EAAE,CAAC;oBACnC,gBAAgB,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;gBACxC,CAAC;YACF,CAAC;YAAC,OAAO,CAAC,EAAE,CAAC;gBACZ,MAAM,KAAK,GAAG,CAAC,YAAY,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,KAAK,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;gBAEzD,MAAM,IAAI,sCAAuB,CAChC,iDAAiD,KAAK,CAAC,OAAO,GAAG,EACjE,EAAE,KAAK,EAAE,KAAK,EAAE,IAAI,EAAE,WAAW,EAAE,CACnC,CAAC;YACH,CAAC;QACF,CAAC;QAED,IAAI,CAAC,eAAe,CAAC,UAAU,CAAC,GAAG,EAAE,gBAAgB,EAAE,CAAC;QAExD,MAAM,YAAY,GAAG,QAAQ,CAAC,YAAY,EAAE,CAAC;QAE7C,IAAI,YAAY,CAAC,MAAM,KAAK,CAAC;YAAE,OAAO;QAEtC,KAAK,MAAM,QAAQ,IAAI,YAAY,EAAE,CAAC;YACrC,IAAI,CAAC;gBACJ,MAAM,IAAI,CAAC,eAAe,CACzB,QAAQ,EACR,QAAQ,EACR,cAAc,EACd,gBAAgB,EAChB,IAAI,EACJ,UAAU,CACV,CAAC;YACH,CAAC;YAAC,OAAO,CAAC,EAAE,CAAC;gBAEZ,IAAI,gBAAgB,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;oBACnC,OAAO,IAAI,CAAC,eAAe,CAAC,UAAU,CAAC,CAAC;gBACzC,CAAC;gBAED,MAAM,KAAK,GAAG,CAAC,YAAY,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,KAAK,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;gBAEzD,MAAM,IAAI,sCAAuB,CAChC,iDAAiD,KAAK,CAAC,OAAO,GAAG,EACjE,EAAE,KAAK,EAAE,KAAK,EAAE,IAAI,EAAE,QAAQ,EAAE,CAChC,CAAC;YACH,CAAC;QACF,CAAC;IACF,CAAC;IAKO,KAAK,CAAC,eAAe,CAC5B,IAAW,EACX,QAAkB,EAClB,cAA8C,EAC9C,gBAA0C,EAC1C,IAAyB,EACzB,UAAgC;QAEhC,MAAM,aAAa,GAAG,gBAAgB,CAAC,QAAQ,EAAE,IAAI,EAAE,cAAc,EAAE,IAAI,EAAE,UAAU,CAAC,CAAC;QAEzF,MAAM,SAAS,GAAG,aAAa,CAAC,gBAAgB,CAAC,WAAW,CAE3D,CAAC;QAGF,MAAM,eAAe,GAAG,CAAC,SAAS,CAAC,IAAI,IAAI,EAAE,CAAC,CAAC,GAAG,CAAC,+BAAgB,CAAC,CAAC;QAErE,MAAM,cAAc,GAAG,KAAK,EAAE,cAAc,GAAG,KAAK,EAAE,EAAE;YACvD,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,2CAA2C,QAAQ,CAAC,IAAI,GAAG,EAAE;gBAC9E,YAAY,EAAE,QAAQ,CAAC,IAAI;gBAC3B,UAAU,EAAE,QAAQ,CAAC,EAAE;aACvB,CAAC,CAAC;YAEH,IAAI,CAAC;gBACJ,MAAM,YAAY,GAAG,MAAM,IAAI,CAAC,kBAAkB,CAAC,OAAO,CAAC,QAAQ,EAAE,IAAI,EAAE,aAAa,CAAC,CAAC;gBAE1F,IAAI,YAAY,KAAK,IAAI,EAAE,CAAC;oBAC3B,aAAa,CAAC,MAAM,CAAC,YAAY,CAAC,CAAC;gBACpC,CAAC;YACF,CAAC;YAAC,OAAO,KAAK,EAAE,CAAC;gBAIhB,IAAI,cAAc,EAAE,CAAC;oBACpB,MAAM,KAAK,CAAC;gBACb,CAAC;gBACD,aAAa,CAAC,WAAW,CAAC,KAAc,CAAC,CAAC;YAC3C,CAAC;QACF,CAAC,CAAC;QAGF,MAAM,cAAc,CAAC,IAAI,CAAC,CAAC;QAE3B,KAAK,MAAM,UAAU,IAAI,eAAe,EAAE,CAAC;YAC1C,IAAI,UAAU,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,QAAQ,CAAC,GAAG,CAAC,EAAE,CAAC;gBAChD,MAAM,IAAI,wBAAS,CAAC,oEAAoE,CAAC,CAAC;YAC3F,CAAC;YAED,MAAM,GAAG,GAAgB;gBACxB,UAAU,EAAE,QAAQ,CAAC,EAAE;gBACvB,QAAQ,EAAE,QAAQ,CAAC,QAAQ;gBAC3B,MAAM,EAAE,IAAI,CAAC,EAAE;gBACf,UAAU;aACV,CAAC;YAEF,IAAI,CAAC,oBAAoB,CAAC,YAAY,CAAC,GAAG,EAAE,cAAc,CAAC,CAAC;QAC7D,CAAC;IACF,CAAC;IAKD,KAAK,CAAC,MAAM,CAAC,UAAkB;QAC9B,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,UAAU,CAAC,EAAE,CAAC;YAChC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,mDAAmD,UAAU,GAAG,CAAC,CAAC;YACnF,OAAO,KAAK,CAAC;QACd,CAAC;QAED,IAAI,CAAC,oBAAoB,CAAC,eAAe,CAAC,UAAU,CAAC,CAAC;QAEtD,MAAM,CAAC,GAAG,IAAI,CAAC,eAAe,CAAC,UAAU,CAAC,CAAC;QAC3C,KAAK,MAAM,CAAC,IAAI,CAAC,CAAC,gBAAgB,IAAI,EAAE,EAAE,CAAC;YAC1C,MAAM,IAAI,CAAC,YAAY,CAAC,CAAC,EAAE,UAAU,CAAC,CAAC;QACxC,CAAC;QAED,OAAO,IAAI,CAAC,eAAe,CAAC,UAAU,CAAC,CAAC;QAExC,OAAO,IAAI,CAAC;IACb,CAAC;IAED,KAAK,CAAC,uCAAuC;QAC5C,MAAM,iBAAiB,GAAG,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;QAE5D,IAAI,iBAAiB,CAAC,MAAM,KAAK,CAAC;YAAE,OAAO;QAE3C,KAAK,MAAM,UAAU,IAAI,iBAAiB,EAAE,CAAC;YAC5C,MAAM,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC;QAC/B,CAAC;QAED,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,qDAAqD,EAAE;YACxE,WAAW,EAAE,iBAAiB;SAC9B,CAAC,CAAC;IACJ,CAAC;IAEO,KAAK,CAAC,YAAY,CAAC,QAA0B,EAAE,UAAkB;QACxE,IAAI,CAAC,QAAQ,CAAC,aAAa;YAAE,OAAO;QAEpC,IAAI,CAAC;YACJ,MAAM,QAAQ,CAAC,aAAa,EAAE,CAAC;QAChC,CAAC;QAAC,OAAO,CAAC,EAAE,CAAC;YACZ,IAAI,CAAC,YAAY,gCAAiB,EAAE,CAAC;gBACpC,IAAI,CAAC,MAAM,CAAC,KAAK,CAChB,mDAAmD,CAAC,CAAC,IAAI,CAAC,IAAI,kBAAkB,UAAU,GAAG,CAC7F,CAAC;gBACF,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC,EAAE,EAAE,KAAK,EAAE,EAAE,UAAU,EAAE,EAAE,CAAC,CAAC;gBACvD,OAAO;YACR,CAAC;YAED,MAAM,KAAK,GAAG,CAAC,YAAY,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,KAAK,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;YAEzD,MAAM,IAAI,wCAAyB,CAClC,gDAAgD,UAAU,OAAO,KAAK,CAAC,OAAO,GAAG,EACjF,EAAE,KAAK,EAAE,KAAK,EAAE,UAAU,EAAE,CAC5B,CAAC;QACH,CAAC;IACF,CAAC;CACD,CAAA;AAjOY,0CAAe;0BAAf,eAAe;IAD3B,IAAA,YAAO,GAAE;qCAGiB,uBAAM;QACQ,6CAAoB;QACtB,yCAAkB;QACvB,8BAAa;GALlC,eAAe,CAiO3B"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { Logger } from '@n8n/backend-common';
|
|
2
|
+
import { ContextEstablishmentHookMetadata, IContextEstablishmentHook } from '@n8n/decorators';
|
|
3
|
+
export declare class ExecutionContextHookRegistry {
|
|
4
|
+
private readonly executionContextHookMetadata;
|
|
5
|
+
private readonly logger;
|
|
6
|
+
private hookMap;
|
|
7
|
+
constructor(executionContextHookMetadata: ContextEstablishmentHookMetadata, logger: Logger);
|
|
8
|
+
init(): Promise<void>;
|
|
9
|
+
getHookByName(name: string): IContextEstablishmentHook | undefined;
|
|
10
|
+
getAllHooks(): IContextEstablishmentHook[];
|
|
11
|
+
getHookForTriggerType(triggerType: string): IContextEstablishmentHook[];
|
|
12
|
+
}
|
|
@@ -0,0 +1,69 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
9
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
10
|
+
};
|
|
11
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
+
exports.ExecutionContextHookRegistry = void 0;
|
|
13
|
+
const backend_common_1 = require("@n8n/backend-common");
|
|
14
|
+
const decorators_1 = require("@n8n/decorators");
|
|
15
|
+
const di_1 = require("@n8n/di");
|
|
16
|
+
let ExecutionContextHookRegistry = class ExecutionContextHookRegistry {
|
|
17
|
+
constructor(executionContextHookMetadata, logger) {
|
|
18
|
+
this.executionContextHookMetadata = executionContextHookMetadata;
|
|
19
|
+
this.logger = logger;
|
|
20
|
+
this.hookMap = new Map();
|
|
21
|
+
}
|
|
22
|
+
async init() {
|
|
23
|
+
this.hookMap.clear();
|
|
24
|
+
const hookClasses = this.executionContextHookMetadata.getClasses();
|
|
25
|
+
this.logger.debug(`Registering ${hookClasses.length} execution context hooks.`);
|
|
26
|
+
for (const HookClass of hookClasses) {
|
|
27
|
+
let hook;
|
|
28
|
+
try {
|
|
29
|
+
hook = di_1.Container.get(HookClass);
|
|
30
|
+
}
|
|
31
|
+
catch (error) {
|
|
32
|
+
this.logger.error(`Failed to instantiate execution context hook class "${HookClass.name}": ${error.message}`, { error });
|
|
33
|
+
continue;
|
|
34
|
+
}
|
|
35
|
+
if (this.hookMap.has(hook.hookDescription.name)) {
|
|
36
|
+
this.logger.warn(`Execution context hook with name "${hook.hookDescription.name}" is already registered. Conflicting classes are "${this.hookMap.get(hook.hookDescription.name)?.constructor.name}" and "${HookClass.name}". Skipping the latter.`);
|
|
37
|
+
continue;
|
|
38
|
+
}
|
|
39
|
+
if (hook.init) {
|
|
40
|
+
try {
|
|
41
|
+
await hook.init();
|
|
42
|
+
}
|
|
43
|
+
catch (error) {
|
|
44
|
+
this.logger.error(`Failed to initialize execution context hook "${hook.hookDescription.name}": ${error.message}`, { error });
|
|
45
|
+
continue;
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
this.hookMap.set(hook.hookDescription.name, hook);
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
getHookByName(name) {
|
|
52
|
+
return this.hookMap.get(name);
|
|
53
|
+
}
|
|
54
|
+
getAllHooks() {
|
|
55
|
+
return Array.from(this.hookMap.values());
|
|
56
|
+
}
|
|
57
|
+
getHookForTriggerType(triggerType) {
|
|
58
|
+
return Array.from(this.hookMap.values()).filter((hook) => {
|
|
59
|
+
return hook.isApplicableToTriggerNode(triggerType);
|
|
60
|
+
});
|
|
61
|
+
}
|
|
62
|
+
};
|
|
63
|
+
exports.ExecutionContextHookRegistry = ExecutionContextHookRegistry;
|
|
64
|
+
exports.ExecutionContextHookRegistry = ExecutionContextHookRegistry = __decorate([
|
|
65
|
+
(0, di_1.Service)(),
|
|
66
|
+
__metadata("design:paramtypes", [decorators_1.ContextEstablishmentHookMetadata,
|
|
67
|
+
backend_common_1.Logger])
|
|
68
|
+
], ExecutionContextHookRegistry);
|
|
69
|
+
//# sourceMappingURL=execution-context-hook-registry.service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"execution-context-hook-registry.service.js","sourceRoot":"","sources":["../../src/execution-engine/execution-context-hook-registry.service.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,wDAA6C;AAC7C,gDAA8F;AAC9F,gCAA6C;AAUtC,IAAM,4BAA4B,GAAlC,MAAM,4BAA4B;IAGxC,YACkB,4BAA8D,EAC9D,MAAc;QADd,iCAA4B,GAA5B,4BAA4B,CAAkC;QAC9D,WAAM,GAAN,MAAM,CAAQ;QAJxB,YAAO,GAA2C,IAAI,GAAG,EAAE,CAAC;IAKjE,CAAC;IAaJ,KAAK,CAAC,IAAI;QACT,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,CAAC;QAErB,MAAM,WAAW,GAAG,IAAI,CAAC,4BAA4B,CAAC,UAAU,EAAE,CAAC;QACnE,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,eAAe,WAAW,CAAC,MAAM,2BAA2B,CAAC,CAAC;QAEhF,KAAK,MAAM,SAAS,IAAI,WAAW,EAAE,CAAC;YACrC,IAAI,IAA+B,CAAC;YACpC,IAAI,CAAC;gBACJ,IAAI,GAAG,cAAS,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;YACjC,CAAC;YAAC,OAAO,KAAK,EAAE,CAAC;gBAChB,IAAI,CAAC,MAAM,CAAC,KAAK,CAChB,uDAAuD,SAAS,CAAC,IAAI,MAAO,KAAe,CAAC,OAAO,EAAE,EACrG,EAAE,KAAK,EAAE,CACT,CAAC;gBACF,SAAS;YACV,CAAC;YAED,IAAI,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,EAAE,CAAC;gBACjD,IAAI,CAAC,MAAM,CAAC,IAAI,CACf,qCAAqC,IAAI,CAAC,eAAe,CAAC,IAAI,qDAAqD,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,EAAE,WAAW,CAAC,IAAI,UAAU,SAAS,CAAC,IAAI,yBAAyB,CACjO,CAAC;gBACF,SAAS;YACV,CAAC;YACD,IAAI,IAAI,CAAC,IAAI,EAAE,CAAC;gBACf,IAAI,CAAC;oBACJ,MAAM,IAAI,CAAC,IAAI,EAAE,CAAC;gBACnB,CAAC;gBAAC,OAAO,KAAK,EAAE,CAAC;oBAChB,IAAI,CAAC,MAAM,CAAC,KAAK,CAChB,gDAAgD,IAAI,CAAC,eAAe,CAAC,IAAI,MAAO,KAAe,CAAC,OAAO,EAAE,EACzG,EAAE,KAAK,EAAE,CACT,CAAC;oBACF,SAAS;gBACV,CAAC;YACF,CAAC;YACD,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,eAAe,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;QACnD,CAAC;IACF,CAAC;IAQD,aAAa,CAAC,IAAY;QACzB,OAAO,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;IAC/B,CAAC;IAOD,WAAW;QACV,OAAO,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE,CAAC,CAAC;IAC1C,CAAC;IAWD,qBAAqB,CAAC,WAAmB;QACxC,OAAO,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE,CAAC,CAAC,MAAM,CAAC,CAAC,IAAI,EAAE,EAAE;YACxD,OAAO,IAAI,CAAC,yBAAyB,CAAC,WAAW,CAAC,CAAC;QACpD,CAAC,CAAC,CAAC;IACJ,CAAC;CACD,CAAA;AA3FY,oEAA4B;uCAA5B,4BAA4B;IADxC,IAAA,YAAO,GAAE;qCAKuC,6CAAgC;QACtD,uBAAM;GALpB,4BAA4B,CA2FxC"}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
import { type IWorkflowExecuteAdditionalData, type WorkflowExecuteMode, type IRunExecutionData, type Workflow } from 'n8n-workflow';
|
|
2
|
+
export declare const establishExecutionContext: (workflow: Workflow, runExecutionData: IRunExecutionData, additionalData: IWorkflowExecuteAdditionalData, mode: WorkflowExecuteMode) => Promise<void>;
|
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.establishExecutionContext = void 0;
|
|
4
|
+
const backend_common_1 = require("@n8n/backend-common");
|
|
5
|
+
const di_1 = require("@n8n/di");
|
|
6
|
+
const assertions_1 = require("../utils/assertions");
|
|
7
|
+
const execution_context_service_1 = require("./execution-context.service");
|
|
8
|
+
const establishExecutionContext = async (workflow, runExecutionData, additionalData, mode) => {
|
|
9
|
+
(0, assertions_1.assertExecutionDataExists)(runExecutionData.executionData, workflow, additionalData, mode);
|
|
10
|
+
const executionData = runExecutionData.executionData;
|
|
11
|
+
if (executionData.runtimeData) {
|
|
12
|
+
return;
|
|
13
|
+
}
|
|
14
|
+
executionData.runtimeData = {
|
|
15
|
+
version: 1,
|
|
16
|
+
establishedAt: Date.now(),
|
|
17
|
+
source: mode,
|
|
18
|
+
};
|
|
19
|
+
if (runExecutionData.parentExecution) {
|
|
20
|
+
executionData.runtimeData = {
|
|
21
|
+
...(runExecutionData.parentExecution.executionContext ?? {}),
|
|
22
|
+
...executionData.runtimeData,
|
|
23
|
+
parentExecutionId: runExecutionData.parentExecution.executionId,
|
|
24
|
+
};
|
|
25
|
+
return;
|
|
26
|
+
}
|
|
27
|
+
const [startItem] = executionData.nodeExecutionStack;
|
|
28
|
+
if (!startItem) {
|
|
29
|
+
return;
|
|
30
|
+
}
|
|
31
|
+
executionData.runtimeData.triggerNode = {
|
|
32
|
+
name: startItem.node.name,
|
|
33
|
+
type: startItem.node.type,
|
|
34
|
+
};
|
|
35
|
+
if (startItem.metadata?.parentExecution?.executionContext) {
|
|
36
|
+
executionData.runtimeData = {
|
|
37
|
+
...startItem.metadata.parentExecution.executionContext,
|
|
38
|
+
...executionData.runtimeData,
|
|
39
|
+
parentExecutionId: startItem.metadata.parentExecution.executionId,
|
|
40
|
+
};
|
|
41
|
+
return;
|
|
42
|
+
}
|
|
43
|
+
const executionContextService = di_1.Container.get(execution_context_service_1.ExecutionContextService);
|
|
44
|
+
try {
|
|
45
|
+
const { context, triggerItems } = await executionContextService.augmentExecutionContextWithHooks(workflow, startItem, executionData.runtimeData);
|
|
46
|
+
executionData.runtimeData = context;
|
|
47
|
+
if (triggerItems) {
|
|
48
|
+
startItem.data['main'][0] = triggerItems;
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
catch (error) {
|
|
52
|
+
di_1.Container.get(backend_common_1.Logger).error('Failed to augment execution context with hooks.', { error });
|
|
53
|
+
}
|
|
54
|
+
};
|
|
55
|
+
exports.establishExecutionContext = establishExecutionContext;
|
|
56
|
+
//# sourceMappingURL=execution-context.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"execution-context.js","sourceRoot":"","sources":["../../src/execution-engine/execution-context.ts"],"names":[],"mappings":";;;AAAA,wDAA6C;AAC7C,gCAAoC;AAQpC,mDAA+D;AAE/D,2EAAsE;AAiG/D,MAAM,yBAAyB,GAAG,KAAK,EAC7C,QAAkB,EAClB,gBAAmC,EACnC,cAA8C,EAC9C,IAAyB,EACT,EAAE;IAClB,IAAA,sCAAyB,EAAC,gBAAgB,CAAC,aAAa,EAAE,QAAQ,EAAE,cAAc,EAAE,IAAI,CAAC,CAAC;IAE1F,MAAM,aAAa,GAAG,gBAAgB,CAAC,aAAa,CAAC;IAErD,IAAI,aAAa,CAAC,WAAW,EAAE,CAAC;QAG/B,OAAO;IACR,CAAC;IAKD,aAAa,CAAC,WAAW,GAAG;QAC3B,OAAO,EAAE,CAAC;QACV,aAAa,EAAE,IAAI,CAAC,GAAG,EAAE;QACzB,MAAM,EAAE,IAAI;KACZ,CAAC;IAEF,IAAI,gBAAgB,CAAC,eAAe,EAAE,CAAC;QAMtC,aAAa,CAAC,WAAW,GAAG;YAC3B,GAAG,CAAC,gBAAgB,CAAC,eAAe,CAAC,gBAAgB,IAAI,EAAE,CAAC;YAC5D,GAAG,aAAa,CAAC,WAAW;YAC5B,iBAAiB,EAAE,gBAAgB,CAAC,eAAe,CAAC,WAAW;SAC/D,CAAC;QACF,OAAO;IACR,CAAC;IAGD,MAAM,CAAC,SAAS,CAAC,GAAG,aAAa,CAAC,kBAAkB,CAAC;IAYrD,IAAI,CAAC,SAAS,EAAE,CAAC;QAChB,OAAO;IACR,CAAC;IAGD,aAAa,CAAC,WAAW,CAAC,WAAW,GAAG;QACvC,IAAI,EAAE,SAAS,CAAC,IAAI,CAAC,IAAI;QACzB,IAAI,EAAE,SAAS,CAAC,IAAI,CAAC,IAAI;KACzB,CAAC;IAIF,IAAI,SAAS,CAAC,QAAQ,EAAE,eAAe,EAAE,gBAAgB,EAAE,CAAC;QAC3D,aAAa,CAAC,WAAW,GAAG;YAC3B,GAAG,SAAS,CAAC,QAAQ,CAAC,eAAe,CAAC,gBAAgB;YACtD,GAAG,aAAa,CAAC,WAAW;YAC5B,iBAAiB,EAAE,SAAS,CAAC,QAAQ,CAAC,eAAe,CAAC,WAAW;SACjE,CAAC;QACF,OAAO;IACR,CAAC;IAGD,MAAM,uBAAuB,GAAG,cAAS,CAAC,GAAG,CAAC,mDAAuB,CAAC,CAAC;IAEvE,IAAI,CAAC;QACJ,MAAM,EAAE,OAAO,EAAE,YAAY,EAAE,GAC9B,MAAM,uBAAuB,CAAC,gCAAgC,CAC7D,QAAQ,EACR,SAAS,EACT,aAAa,CAAC,WAAW,CACzB,CAAC;QAEH,aAAa,CAAC,WAAW,GAAG,OAAO,CAAC;QAGpC,IAAI,YAAY,EAAE,CAAC;YAClB,SAAS,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,GAAG,YAAY,CAAC;QAC1C,CAAC;IACF,CAAC;IAAC,OAAO,KAAK,EAAE,CAAC;QAEhB,cAAS,CAAC,GAAG,CAAC,uBAAM,CAAC,CAAC,KAAK,CAAC,iDAAiD,EAAE,EAAE,KAAK,EAAE,CAAC,CAAC;IAC3F,CAAC;AACF,CAAC,CAAC;AA9FW,QAAA,yBAAyB,6BA8FpC"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { Logger } from '@n8n/backend-common';
|
|
2
|
+
import { IExecuteData, IExecutionContext, INodeExecutionData, PlaintextExecutionContext, Workflow } from 'n8n-workflow';
|
|
3
|
+
import { Cipher } from '../encryption';
|
|
4
|
+
import { ExecutionContextHookRegistry } from './execution-context-hook-registry.service';
|
|
5
|
+
export declare class ExecutionContextService {
|
|
6
|
+
private readonly logger;
|
|
7
|
+
private readonly executionContextHookRegistry;
|
|
8
|
+
private readonly cipher;
|
|
9
|
+
constructor(logger: Logger, executionContextHookRegistry: ExecutionContextHookRegistry, cipher: Cipher);
|
|
10
|
+
decryptExecutionContext(context: IExecutionContext): PlaintextExecutionContext;
|
|
11
|
+
encryptExecutionContext(context: PlaintextExecutionContext): IExecutionContext;
|
|
12
|
+
mergeExecutionContexts(baseContext: PlaintextExecutionContext, contextToMerge: Partial<PlaintextExecutionContext>): PlaintextExecutionContext;
|
|
13
|
+
augmentExecutionContextWithHooks(workflow: Workflow, startItem: IExecuteData, contextToAugment: IExecutionContext): Promise<{
|
|
14
|
+
context: IExecutionContext;
|
|
15
|
+
triggerItems: INodeExecutionData[] | null;
|
|
16
|
+
}>;
|
|
17
|
+
}
|
|
@@ -0,0 +1,108 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
9
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
10
|
+
};
|
|
11
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
+
exports.ExecutionContextService = void 0;
|
|
13
|
+
const backend_common_1 = require("@n8n/backend-common");
|
|
14
|
+
const di_1 = require("@n8n/di");
|
|
15
|
+
const n8n_workflow_1 = require("n8n-workflow");
|
|
16
|
+
const encryption_1 = require("../encryption");
|
|
17
|
+
const deep_merge_1 = require("../utils/deep-merge");
|
|
18
|
+
const execution_context_hook_registry_service_1 = require("./execution-context-hook-registry.service");
|
|
19
|
+
let ExecutionContextService = class ExecutionContextService {
|
|
20
|
+
constructor(logger, executionContextHookRegistry, cipher) {
|
|
21
|
+
this.logger = logger;
|
|
22
|
+
this.executionContextHookRegistry = executionContextHookRegistry;
|
|
23
|
+
this.cipher = cipher;
|
|
24
|
+
}
|
|
25
|
+
decryptExecutionContext(context) {
|
|
26
|
+
let credentials = undefined;
|
|
27
|
+
if (context.credentials) {
|
|
28
|
+
const decrypted = this.cipher.decrypt(context.credentials);
|
|
29
|
+
credentials = (0, n8n_workflow_1.toCredentialContext)(decrypted);
|
|
30
|
+
}
|
|
31
|
+
return {
|
|
32
|
+
...context,
|
|
33
|
+
credentials,
|
|
34
|
+
};
|
|
35
|
+
}
|
|
36
|
+
encryptExecutionContext(context) {
|
|
37
|
+
let credentials = undefined;
|
|
38
|
+
if (context.credentials) {
|
|
39
|
+
credentials = this.cipher.encrypt(context.credentials);
|
|
40
|
+
}
|
|
41
|
+
return {
|
|
42
|
+
...context,
|
|
43
|
+
credentials,
|
|
44
|
+
};
|
|
45
|
+
}
|
|
46
|
+
mergeExecutionContexts(baseContext, contextToMerge) {
|
|
47
|
+
return (0, deep_merge_1.deepMerge)(baseContext, contextToMerge);
|
|
48
|
+
}
|
|
49
|
+
async augmentExecutionContextWithHooks(workflow, startItem, contextToAugment) {
|
|
50
|
+
let currentTriggerItems = startItem.data['main'][0];
|
|
51
|
+
const contextEstablishmentHookParameters = {
|
|
52
|
+
...(workflow.getNode(startItem.node.name)?.parameters ?? {}),
|
|
53
|
+
...startItem.node.parameters,
|
|
54
|
+
};
|
|
55
|
+
const startNodeParametersResult = (0, n8n_workflow_1.toExecutionContextEstablishmentHookParameter)(contextEstablishmentHookParameters);
|
|
56
|
+
if (!startNodeParametersResult || startNodeParametersResult.error) {
|
|
57
|
+
if (startNodeParametersResult?.error) {
|
|
58
|
+
this.logger.warn(`Failed to parse execution context establishment hook parameters for node ${startItem.node.name}: ${startNodeParametersResult.error.message}`);
|
|
59
|
+
}
|
|
60
|
+
return {
|
|
61
|
+
context: contextToAugment,
|
|
62
|
+
triggerItems: currentTriggerItems,
|
|
63
|
+
};
|
|
64
|
+
}
|
|
65
|
+
const startNodeParameters = startNodeParametersResult.data;
|
|
66
|
+
let context = this.decryptExecutionContext(contextToAugment);
|
|
67
|
+
for (const hookParameters of startNodeParameters.contextEstablishmentHooks.hooks) {
|
|
68
|
+
const hook = this.executionContextHookRegistry.getHookByName(hookParameters.hookName);
|
|
69
|
+
if (!hook) {
|
|
70
|
+
this.logger.warn(`Execution context establishment hook ${hookParameters.hookName} not found, skipping this hook`);
|
|
71
|
+
continue;
|
|
72
|
+
}
|
|
73
|
+
try {
|
|
74
|
+
const result = await hook.execute({
|
|
75
|
+
triggerNode: startItem.node,
|
|
76
|
+
workflow,
|
|
77
|
+
triggerItems: currentTriggerItems,
|
|
78
|
+
context,
|
|
79
|
+
options: hookParameters,
|
|
80
|
+
});
|
|
81
|
+
if (result.triggerItems !== undefined) {
|
|
82
|
+
currentTriggerItems = result.triggerItems;
|
|
83
|
+
}
|
|
84
|
+
if (result.contextUpdate) {
|
|
85
|
+
context = this.mergeExecutionContexts(context, result.contextUpdate);
|
|
86
|
+
}
|
|
87
|
+
}
|
|
88
|
+
catch (error) {
|
|
89
|
+
this.logger.warn(`Failed to execute context establishment hook ${hookParameters.hookName}`, { error });
|
|
90
|
+
if (!hookParameters.isAllowedToFail) {
|
|
91
|
+
throw error;
|
|
92
|
+
}
|
|
93
|
+
}
|
|
94
|
+
}
|
|
95
|
+
return {
|
|
96
|
+
context: this.encryptExecutionContext(context),
|
|
97
|
+
triggerItems: currentTriggerItems,
|
|
98
|
+
};
|
|
99
|
+
}
|
|
100
|
+
};
|
|
101
|
+
exports.ExecutionContextService = ExecutionContextService;
|
|
102
|
+
exports.ExecutionContextService = ExecutionContextService = __decorate([
|
|
103
|
+
(0, di_1.Service)(),
|
|
104
|
+
__metadata("design:paramtypes", [backend_common_1.Logger,
|
|
105
|
+
execution_context_hook_registry_service_1.ExecutionContextHookRegistry,
|
|
106
|
+
encryption_1.Cipher])
|
|
107
|
+
], ExecutionContextService);
|
|
108
|
+
//# sourceMappingURL=execution-context.service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"execution-context.service.js","sourceRoot":"","sources":["../../src/execution-engine/execution-context.service.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import type { IDataObject, IExecuteResponsePromiseData, INode, IRun, IRunExecutionData, ITaskData, ITaskStartedData, IWorkflowBase, StructuredChunk, Workflow, WorkflowExecuteMode } from 'n8n-workflow';
|
|
2
|
+
export type ExecutionLifecycleHookHandlers = {
|
|
3
|
+
nodeExecuteBefore: Array<(this: ExecutionLifecycleHooks, nodeName: string, data: ITaskStartedData) => Promise<void> | void>;
|
|
4
|
+
nodeExecuteAfter: Array<(this: ExecutionLifecycleHooks, nodeName: string, data: ITaskData, executionData: IRunExecutionData) => Promise<void> | void>;
|
|
5
|
+
workflowExecuteBefore: Array<(this: ExecutionLifecycleHooks, workflow: Workflow, data?: IRunExecutionData) => Promise<void> | void>;
|
|
6
|
+
workflowExecuteAfter: Array<(this: ExecutionLifecycleHooks, data: IRun, newStaticData: IDataObject) => Promise<void> | void>;
|
|
7
|
+
sendResponse: Array<(this: ExecutionLifecycleHooks, response: IExecuteResponsePromiseData) => Promise<void> | void>;
|
|
8
|
+
sendChunk: Array<(this: ExecutionLifecycleHooks, chunk: StructuredChunk) => Promise<void> | void>;
|
|
9
|
+
nodeFetchedData: Array<(this: ExecutionLifecycleHooks, workflowId: string, node: INode) => Promise<void> | void>;
|
|
10
|
+
};
|
|
11
|
+
export type ExecutionLifecycleHookName = keyof ExecutionLifecycleHookHandlers;
|
|
12
|
+
export declare class ExecutionLifecycleHooks {
|
|
13
|
+
readonly mode: WorkflowExecuteMode;
|
|
14
|
+
readonly executionId: string;
|
|
15
|
+
readonly workflowData: IWorkflowBase;
|
|
16
|
+
readonly handlers: ExecutionLifecycleHookHandlers;
|
|
17
|
+
constructor(mode: WorkflowExecuteMode, executionId: string, workflowData: IWorkflowBase);
|
|
18
|
+
addHandler<Hook extends keyof ExecutionLifecycleHookHandlers>(hookName: Hook, ...handlers: Array<ExecutionLifecycleHookHandlers[Hook][number]>): void;
|
|
19
|
+
runHook<Hook extends keyof ExecutionLifecycleHookHandlers, Params extends unknown[] = Parameters<Exclude<ExecutionLifecycleHookHandlers[Hook], undefined>[number]>>(hookName: Hook, parameters: Params): Promise<void>;
|
|
20
|
+
}
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.ExecutionLifecycleHooks = void 0;
|
|
4
|
+
class ExecutionLifecycleHooks {
|
|
5
|
+
constructor(mode, executionId, workflowData) {
|
|
6
|
+
this.mode = mode;
|
|
7
|
+
this.executionId = executionId;
|
|
8
|
+
this.workflowData = workflowData;
|
|
9
|
+
this.handlers = {
|
|
10
|
+
nodeExecuteAfter: [],
|
|
11
|
+
nodeExecuteBefore: [],
|
|
12
|
+
nodeFetchedData: [],
|
|
13
|
+
sendResponse: [],
|
|
14
|
+
workflowExecuteAfter: [],
|
|
15
|
+
workflowExecuteBefore: [],
|
|
16
|
+
sendChunk: [],
|
|
17
|
+
};
|
|
18
|
+
}
|
|
19
|
+
addHandler(hookName, ...handlers) {
|
|
20
|
+
this.handlers[hookName].push(...handlers);
|
|
21
|
+
}
|
|
22
|
+
async runHook(hookName, parameters) {
|
|
23
|
+
const hooks = this.handlers[hookName];
|
|
24
|
+
for (const hookFunction of hooks) {
|
|
25
|
+
const typedHookFunction = hookFunction;
|
|
26
|
+
await typedHookFunction.apply(this, parameters);
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
}
|
|
30
|
+
exports.ExecutionLifecycleHooks = ExecutionLifecycleHooks;
|
|
31
|
+
//# sourceMappingURL=execution-lifecycle-hooks.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"execution-lifecycle-hooks.js","sourceRoot":"","sources":["../../src/execution-engine/execution-lifecycle-hooks.ts"],"names":[],"mappings":";;;AAkFA,MAAa,uBAAuB;IAWnC,YACU,IAAyB,EACzB,WAAmB,EACnB,YAA2B;QAF3B,SAAI,GAAJ,IAAI,CAAqB;QACzB,gBAAW,GAAX,WAAW,CAAQ;QACnB,iBAAY,GAAZ,YAAY,CAAe;QAb5B,aAAQ,GAAmC;YACnD,gBAAgB,EAAE,EAAE;YACpB,iBAAiB,EAAE,EAAE;YACrB,eAAe,EAAE,EAAE;YACnB,YAAY,EAAE,EAAE;YAChB,oBAAoB,EAAE,EAAE;YACxB,qBAAqB,EAAE,EAAE;YACzB,SAAS,EAAE,EAAE;SACb,CAAC;IAMC,CAAC;IAEJ,UAAU,CACT,QAAc,EACd,GAAG,QAA6D;QAGhE,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,GAAG,QAAQ,CAAC,CAAC;IAC3C,CAAC;IAED,KAAK,CAAC,OAAO,CAKX,QAAc,EAAE,UAAkB;QACnC,MAAM,KAAK,GAAG,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC;QACtC,KAAK,MAAM,YAAY,IAAI,KAAK,EAAE,CAAC;YAClC,MAAM,iBAAiB,GAAG,YAGR,CAAC;YACnB,MAAM,iBAAiB,CAAC,KAAK,CAAC,IAAI,EAAE,UAAU,CAAC,CAAC;QACjD,CAAC;IACF,CAAC;CACD;AAxCD,0DAwCC"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
export interface IExternalSecretsManager {
|
|
2
|
+
updateSecrets(): Promise<void>;
|
|
3
|
+
hasSecret(provider: string, name: string): boolean;
|
|
4
|
+
getSecret(provider: string, name: string): unknown;
|
|
5
|
+
getSecretNames(provider: string): string[];
|
|
6
|
+
hasProvider(provider: string): boolean;
|
|
7
|
+
getProviderNames(): string[];
|
|
8
|
+
}
|
|
9
|
+
export declare class ExternalSecretsProxy {
|
|
10
|
+
private manager?;
|
|
11
|
+
setManager(manager: IExternalSecretsManager): void;
|
|
12
|
+
update(): Promise<void>;
|
|
13
|
+
getSecret(provider: string, name: string): unknown;
|
|
14
|
+
hasSecret(provider: string, name: string): boolean;
|
|
15
|
+
hasProvider(provider: string): boolean;
|
|
16
|
+
listProviders(): string[];
|
|
17
|
+
listSecrets(provider: string): string[];
|
|
18
|
+
}
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
9
|
+
exports.ExternalSecretsProxy = void 0;
|
|
10
|
+
const di_1 = require("@n8n/di");
|
|
11
|
+
let ExternalSecretsProxy = class ExternalSecretsProxy {
|
|
12
|
+
setManager(manager) {
|
|
13
|
+
this.manager = manager;
|
|
14
|
+
}
|
|
15
|
+
async update() {
|
|
16
|
+
await this.manager?.updateSecrets();
|
|
17
|
+
}
|
|
18
|
+
getSecret(provider, name) {
|
|
19
|
+
return this.manager?.getSecret(provider, name);
|
|
20
|
+
}
|
|
21
|
+
hasSecret(provider, name) {
|
|
22
|
+
return !!this.manager && this.manager.hasSecret(provider, name);
|
|
23
|
+
}
|
|
24
|
+
hasProvider(provider) {
|
|
25
|
+
return !!this.manager && this.manager.hasProvider(provider);
|
|
26
|
+
}
|
|
27
|
+
listProviders() {
|
|
28
|
+
return this.manager?.getProviderNames() ?? [];
|
|
29
|
+
}
|
|
30
|
+
listSecrets(provider) {
|
|
31
|
+
return this.manager?.getSecretNames(provider) ?? [];
|
|
32
|
+
}
|
|
33
|
+
};
|
|
34
|
+
exports.ExternalSecretsProxy = ExternalSecretsProxy;
|
|
35
|
+
exports.ExternalSecretsProxy = ExternalSecretsProxy = __decorate([
|
|
36
|
+
(0, di_1.Service)()
|
|
37
|
+
], ExternalSecretsProxy);
|
|
38
|
+
//# sourceMappingURL=external-secrets-proxy.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"external-secrets-proxy.js","sourceRoot":"","sources":["../../src/execution-engine/external-secrets-proxy.ts"],"names":[],"mappings":";;;;;;;;;AAAA,gCAAkC;AAY3B,IAAM,oBAAoB,GAA1B,MAAM,oBAAoB;IAGhC,UAAU,CAAC,OAAgC;QAC1C,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC;IACxB,CAAC;IAED,KAAK,CAAC,MAAM;QACX,MAAM,IAAI,CAAC,OAAO,EAAE,aAAa,EAAE,CAAC;IACrC,CAAC;IAED,SAAS,CAAC,QAAgB,EAAE,IAAY;QACvC,OAAO,IAAI,CAAC,OAAO,EAAE,SAAS,CAAC,QAAQ,EAAE,IAAI,CAAC,CAAC;IAChD,CAAC;IAED,SAAS,CAAC,QAAgB,EAAE,IAAY;QACvC,OAAO,CAAC,CAAC,IAAI,CAAC,OAAO,IAAI,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,QAAQ,EAAE,IAAI,CAAC,CAAC;IACjE,CAAC;IAED,WAAW,CAAC,QAAgB;QAC3B,OAAO,CAAC,CAAC,IAAI,CAAC,OAAO,IAAI,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC,QAAQ,CAAC,CAAC;IAC7D,CAAC;IAED,aAAa;QACZ,OAAO,IAAI,CAAC,OAAO,EAAE,gBAAgB,EAAE,IAAI,EAAE,CAAC;IAC/C,CAAC;IAED,WAAW,CAAC,QAAgB;QAC3B,OAAO,IAAI,CAAC,OAAO,EAAE,cAAc,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC;IACrD,CAAC;CACD,CAAA;AA9BY,oDAAoB;+BAApB,oBAAoB;IADhC,IAAA,YAAO,GAAE;GACG,oBAAoB,CA8BhC"}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import type { DataTableProxyProvider, IExecutionContext, IWorkflowSettings } from 'n8n-workflow';
|
|
2
|
+
import type { ExecutionLifecycleHooks } from './execution-lifecycle-hooks';
|
|
3
|
+
import type { ExternalSecretsProxy } from './external-secrets-proxy';
|
|
4
|
+
declare module 'n8n-workflow' {
|
|
5
|
+
interface IWorkflowExecuteAdditionalData {
|
|
6
|
+
hooks?: ExecutionLifecycleHooks;
|
|
7
|
+
externalSecretsProxy: ExternalSecretsProxy;
|
|
8
|
+
'data-table'?: {
|
|
9
|
+
dataTableProxyProvider: DataTableProxyProvider;
|
|
10
|
+
};
|
|
11
|
+
dataTableProjectId?: string;
|
|
12
|
+
executionContext?: IExecutionContext;
|
|
13
|
+
workflowSettings?: IWorkflowSettings;
|
|
14
|
+
}
|
|
15
|
+
}
|
|
16
|
+
export * from './active-workflows';
|
|
17
|
+
export type * from './interfaces';
|
|
18
|
+
export * from './routing-node';
|
|
19
|
+
export * from './node-execution-context';
|
|
20
|
+
export * from './partial-execution-utils';
|
|
21
|
+
export * from './node-execution-context/utils/execution-metadata';
|
|
22
|
+
export * from './workflow-execute';
|
|
23
|
+
export * from './execution-context-hook-registry.service';
|
|
24
|
+
export { ExecutionLifecycleHooks } from './execution-lifecycle-hooks';
|
|
25
|
+
export { ExternalSecretsProxy, type IExternalSecretsManager } from './external-secrets-proxy';
|
|
26
|
+
export { isEngineRequest } from './requests-response';
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
+
};
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
exports.isEngineRequest = exports.ExternalSecretsProxy = exports.ExecutionLifecycleHooks = void 0;
|
|
18
|
+
__exportStar(require("./active-workflows"), exports);
|
|
19
|
+
__exportStar(require("./routing-node"), exports);
|
|
20
|
+
__exportStar(require("./node-execution-context"), exports);
|
|
21
|
+
__exportStar(require("./partial-execution-utils"), exports);
|
|
22
|
+
__exportStar(require("./node-execution-context/utils/execution-metadata"), exports);
|
|
23
|
+
__exportStar(require("./workflow-execute"), exports);
|
|
24
|
+
__exportStar(require("./execution-context-hook-registry.service"), exports);
|
|
25
|
+
var execution_lifecycle_hooks_1 = require("./execution-lifecycle-hooks");
|
|
26
|
+
Object.defineProperty(exports, "ExecutionLifecycleHooks", { enumerable: true, get: function () { return execution_lifecycle_hooks_1.ExecutionLifecycleHooks; } });
|
|
27
|
+
var external_secrets_proxy_1 = require("./external-secrets-proxy");
|
|
28
|
+
Object.defineProperty(exports, "ExternalSecretsProxy", { enumerable: true, get: function () { return external_secrets_proxy_1.ExternalSecretsProxy; } });
|
|
29
|
+
var requests_response_1 = require("./requests-response");
|
|
30
|
+
Object.defineProperty(exports, "isEngineRequest", { enumerable: true, get: function () { return requests_response_1.isEngineRequest; } });
|
|
31
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/execution-engine/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;AA2BA,qDAAmC;AAEnC,iDAA+B;AAC/B,2DAAyC;AACzC,4DAA0C;AAC1C,oFAAkE;AAClE,qDAAmC;AACnC,4EAA0D;AAC1D,yEAAsE;AAA7D,oIAAA,uBAAuB,OAAA;AAChC,mEAA8F;AAArF,8HAAA,oBAAoB,OAAA;AAC7B,yDAAsD;AAA7C,oHAAA,eAAe,OAAA"}
|