n8n 2.19.2 → 2.20.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/build.tsbuildinfo +1 -1
- package/dist/chat/chat-execution-manager.js +7 -1
- package/dist/chat/chat-execution-manager.js.map +1 -1
- package/dist/collaboration/collaboration.service.d.ts +1 -0
- package/dist/collaboration/collaboration.service.js +31 -0
- package/dist/collaboration/collaboration.service.js.map +1 -1
- package/dist/commands/execute.d.ts +2 -2
- package/dist/commands/export/credentials.d.ts +2 -2
- package/dist/commands/export/credentials.js +1 -1
- package/dist/commands/export/credentials.js.map +1 -1
- package/dist/commands/export/workflow.d.ts +4 -4
- package/dist/commands/import/credentials.d.ts +12 -2
- package/dist/commands/import/credentials.js +89 -11
- package/dist/commands/import/credentials.js.map +1 -1
- package/dist/commands/import/workflow.d.ts +2 -2
- package/dist/commands/ttwf/generate.d.ts +3 -3
- package/dist/controllers/e2e.controller.js +1 -1
- package/dist/controllers/e2e.controller.js.map +1 -1
- package/dist/controllers/oauth/oauth2-credential.controller.d.ts +6 -4
- package/dist/controllers/oauth/oauth2-credential.controller.js +12 -5
- package/dist/controllers/oauth/oauth2-credential.controller.js.map +1 -1
- package/dist/credentials/credentials.controller.js +1 -1
- package/dist/credentials/credentials.controller.js.map +1 -1
- package/dist/credentials/credentials.service.d.ts +2 -2
- package/dist/credentials/credentials.service.ee.js +2 -2
- package/dist/credentials/credentials.service.ee.js.map +1 -1
- package/dist/credentials/credentials.service.js +13 -16
- package/dist/credentials/credentials.service.js.map +1 -1
- package/dist/credentials/dynamic-credentials-proxy.js +1 -1
- package/dist/credentials/dynamic-credentials-proxy.js.map +1 -1
- package/dist/credentials-helper.d.ts +1 -0
- package/dist/credentials-helper.js +12 -4
- package/dist/credentials-helper.js.map +1 -1
- package/dist/credentials-overwrites.js +2 -2
- package/dist/credentials-overwrites.js.map +1 -1
- package/dist/evaluation.ee/test-runner/evaluation-metrics.ee.d.ts +5 -0
- package/dist/evaluation.ee/test-runner/evaluation-metrics.ee.js +22 -12
- package/dist/evaluation.ee/test-runner/evaluation-metrics.ee.js.map +1 -1
- package/dist/evaluation.ee/test-runner/test-runner.service.ee.d.ts +4 -2
- package/dist/evaluation.ee/test-runner/test-runner.service.ee.js +152 -89
- package/dist/evaluation.ee/test-runner/test-runner.service.ee.js.map +1 -1
- package/dist/evaluation.ee/test-runs.controller.ee.d.ts +8 -2
- package/dist/evaluation.ee/test-runs.controller.ee.js +31 -5
- package/dist/evaluation.ee/test-runs.controller.ee.js.map +1 -1
- package/dist/eventbus/event-message-classes/index.d.ts +3 -2
- package/dist/eventbus/event-message-classes/index.js +11 -1
- package/dist/eventbus/event-message-classes/index.js.map +1 -1
- package/dist/eventbus/message-event-bus/message-event-bus.d.ts +5 -2
- package/dist/eventbus/message-event-bus/message-event-bus.js +101 -73
- package/dist/eventbus/message-event-bus/message-event-bus.js.map +1 -1
- package/dist/eventbus/message-event-bus-writer/message-event-bus-log-writer.d.ts +3 -0
- package/dist/eventbus/message-event-bus-writer/message-event-bus-log-writer.js +3 -1
- package/dist/eventbus/message-event-bus-writer/message-event-bus-log-writer.js.map +1 -1
- package/dist/eventbus/message-event-bus-writer/resolve-event-log-path.d.ts +12 -0
- package/dist/eventbus/message-event-bus-writer/resolve-event-log-path.js +34 -0
- package/dist/eventbus/message-event-bus-writer/resolve-event-log-path.js.map +1 -0
- package/dist/execution-lifecycle/execute-error-workflow.js +1 -1
- package/dist/execution-lifecycle/execute-error-workflow.js.map +1 -1
- package/dist/executions/execution-recovery.service.d.ts +1 -1
- package/dist/executions/execution-recovery.service.js +11 -6
- package/dist/executions/execution-recovery.service.js.map +1 -1
- package/dist/executions/execution.service.d.ts +7 -2
- package/dist/executions/execution.service.js +18 -1
- package/dist/executions/execution.service.js.map +1 -1
- package/dist/executions/executions.controller.d.ts +1 -3
- package/dist/executions/executions.controller.js +3 -17
- package/dist/executions/executions.controller.js.map +1 -1
- package/dist/instance-settings-loader/instance-settings-loader.service.d.ts +3 -1
- package/dist/instance-settings-loader/instance-settings-loader.service.js +6 -2
- package/dist/instance-settings-loader/instance-settings-loader.service.js.map +1 -1
- package/dist/instance-settings-loader/loaders/mcp-settings.loader.d.ts +10 -0
- package/dist/instance-settings-loader/loaders/mcp-settings.loader.js +42 -0
- package/dist/instance-settings-loader/loaders/mcp-settings.loader.js.map +1 -0
- package/dist/instance-settings-loader/loaders/sso.instance-settings-loader.js +9 -4
- package/dist/instance-settings-loader/loaders/sso.instance-settings-loader.js.map +1 -1
- package/dist/mfa/mfa.service.d.ts +2 -2
- package/dist/mfa/mfa.service.js +11 -10
- package/dist/mfa/mfa.service.js.map +1 -1
- package/dist/modules/chat-hub/chat-hub-extractor.js +1 -1
- package/dist/modules/chat-hub/chat-hub-extractor.js.map +1 -1
- package/dist/modules/chat-hub/chat-hub-workflow.service.d.ts +1 -1
- package/dist/modules/chat-hub/chat-hub-workflow.service.js +4 -4
- package/dist/modules/chat-hub/chat-hub-workflow.service.js.map +1 -1
- package/dist/modules/community-packages/community-node-types.service.js +3 -1
- package/dist/modules/community-packages/community-node-types.service.js.map +1 -1
- package/dist/modules/dynamic-credentials.ee/credential-resolvers/n8n-credential-resolver.js +2 -2
- package/dist/modules/dynamic-credentials.ee/credential-resolvers/n8n-credential-resolver.js.map +1 -1
- package/dist/modules/dynamic-credentials.ee/credential-resolvers/oauth-credential-resolver.js +2 -2
- package/dist/modules/dynamic-credentials.ee/credential-resolvers/oauth-credential-resolver.js.map +1 -1
- package/dist/modules/dynamic-credentials.ee/credential-resolvers/slack-credential-resolver.js +2 -2
- package/dist/modules/dynamic-credentials.ee/credential-resolvers/slack-credential-resolver.js.map +1 -1
- package/dist/modules/dynamic-credentials.ee/dynamic-credentials.controller.js +2 -2
- package/dist/modules/dynamic-credentials.ee/dynamic-credentials.controller.js.map +1 -1
- package/dist/modules/dynamic-credentials.ee/services/credential-check-proxy.service.js +1 -1
- package/dist/modules/dynamic-credentials.ee/services/credential-check-proxy.service.js.map +1 -1
- package/dist/modules/dynamic-credentials.ee/services/credential-resolver-workflow.service.js +1 -1
- package/dist/modules/dynamic-credentials.ee/services/credential-resolver-workflow.service.js.map +1 -1
- package/dist/modules/dynamic-credentials.ee/services/credential-resolver.service.js +14 -14
- package/dist/modules/dynamic-credentials.ee/services/credential-resolver.service.js.map +1 -1
- package/dist/modules/dynamic-credentials.ee/services/dynamic-credential-storage.service.js +1 -1
- package/dist/modules/dynamic-credentials.ee/services/dynamic-credential-storage.service.js.map +1 -1
- package/dist/modules/dynamic-credentials.ee/services/dynamic-credential.service.js +4 -4
- package/dist/modules/dynamic-credentials.ee/services/dynamic-credential.service.js.map +1 -1
- package/dist/modules/encryption-key-manager/encryption-bootstrap.service.d.ts +6 -1
- package/dist/modules/encryption-key-manager/encryption-bootstrap.service.js +14 -2
- package/dist/modules/encryption-key-manager/encryption-bootstrap.service.js.map +1 -1
- package/dist/modules/encryption-key-manager/encryption-key.controller.js +1 -0
- package/dist/modules/encryption-key-manager/encryption-key.controller.js.map +1 -1
- package/dist/modules/encryption-key-manager/key-manager.service.d.ts +2 -1
- package/dist/modules/encryption-key-manager/key-manager.service.js +24 -5
- package/dist/modules/encryption-key-manager/key-manager.service.js.map +1 -1
- package/dist/modules/external-secrets.ee/constants.d.ts +1 -0
- package/dist/modules/external-secrets.ee/constants.js +2 -1
- package/dist/modules/external-secrets.ee/constants.js.map +1 -1
- package/dist/modules/external-secrets.ee/external-secrets-manager.ee.js +4 -4
- package/dist/modules/external-secrets.ee/external-secrets-manager.ee.js.map +1 -1
- package/dist/modules/external-secrets.ee/secrets-cache.service.d.ts +1 -0
- package/dist/modules/external-secrets.ee/secrets-cache.service.js +18 -1
- package/dist/modules/external-secrets.ee/secrets-cache.service.js.map +1 -1
- package/dist/modules/external-secrets.ee/secrets-providers-connections.controller.ee.js +3 -3
- package/dist/modules/external-secrets.ee/secrets-providers-connections.controller.ee.js.map +1 -1
- package/dist/modules/external-secrets.ee/secrets-providers-connections.service.ee.d.ts +1 -1
- package/dist/modules/external-secrets.ee/secrets-providers-connections.service.ee.js +15 -13
- package/dist/modules/external-secrets.ee/secrets-providers-connections.service.ee.js.map +1 -1
- package/dist/modules/external-secrets.ee/secrets-providers-project.controller.ee.js +3 -3
- package/dist/modules/external-secrets.ee/secrets-providers-project.controller.ee.js.map +1 -1
- package/dist/modules/external-secrets.ee/settings-store.service.js +6 -6
- package/dist/modules/external-secrets.ee/settings-store.service.js.map +1 -1
- package/dist/modules/insights/insights-collection.service.js +7 -1
- package/dist/modules/insights/insights-collection.service.js.map +1 -1
- package/dist/modules/insights/insights-pruning.service.d.ts +2 -4
- package/dist/modules/insights/insights-pruning.service.js +13 -10
- package/dist/modules/insights/insights-pruning.service.js.map +1 -1
- package/dist/modules/insights/insights.config.js +2 -1
- package/dist/modules/insights/insights.config.js.map +1 -1
- package/dist/modules/insights/insights.constants.d.ts +2 -0
- package/dist/modules/insights/insights.constants.js +3 -1
- package/dist/modules/insights/insights.constants.js.map +1 -1
- package/dist/modules/insights/insights.service.js +1 -3
- package/dist/modules/insights/insights.service.js.map +1 -1
- package/dist/modules/instance-ai/compaction.service.d.ts +7 -2
- package/dist/modules/instance-ai/compaction.service.js +17 -17
- package/dist/modules/instance-ai/compaction.service.js.map +1 -1
- package/dist/modules/instance-ai/instance-ai-settings.service.js +4 -4
- package/dist/modules/instance-ai/instance-ai-settings.service.js.map +1 -1
- package/dist/modules/instance-ai/instance-ai.adapter.service.d.ts +38 -1
- package/dist/modules/instance-ai/instance-ai.adapter.service.js +179 -60
- package/dist/modules/instance-ai/instance-ai.adapter.service.js.map +1 -1
- package/dist/modules/instance-ai/instance-ai.controller.d.ts +2 -2
- package/dist/modules/instance-ai/instance-ai.controller.js +7 -17
- package/dist/modules/instance-ai/instance-ai.controller.js.map +1 -1
- package/dist/modules/instance-ai/instance-ai.service.d.ts +15 -4
- package/dist/modules/instance-ai/instance-ai.service.js +489 -76
- package/dist/modules/instance-ai/instance-ai.service.js.map +1 -1
- package/dist/modules/instance-ai/storage/typeorm-memory-storage.js +11 -1
- package/dist/modules/instance-ai/storage/typeorm-memory-storage.js.map +1 -1
- package/dist/modules/instance-ai/web-research/fetch-and-extract.d.ts +3 -1
- package/dist/modules/instance-ai/web-research/fetch-and-extract.js +13 -11
- package/dist/modules/instance-ai/web-research/fetch-and-extract.js.map +1 -1
- package/dist/modules/instance-ai/web-research/index.d.ts +0 -1
- package/dist/modules/instance-ai/web-research/index.js +1 -3
- package/dist/modules/instance-ai/web-research/index.js.map +1 -1
- package/dist/modules/instance-registry/checks/check.service.d.ts +43 -0
- package/dist/modules/instance-registry/checks/check.service.js +248 -0
- package/dist/modules/instance-registry/checks/check.service.js.map +1 -0
- package/dist/modules/instance-registry/checks/hostid-clash.check.d.ts +8 -0
- package/dist/modules/instance-registry/checks/hostid-clash.check.js +68 -0
- package/dist/modules/instance-registry/checks/hostid-clash.check.js.map +1 -0
- package/dist/modules/instance-registry/checks/index.d.ts +4 -0
- package/dist/modules/instance-registry/checks/index.js +7 -0
- package/dist/modules/instance-registry/checks/index.js.map +1 -0
- package/dist/modules/instance-registry/checks/lifecycle.check.d.ts +8 -0
- package/dist/modules/instance-registry/checks/lifecycle.check.js +52 -0
- package/dist/modules/instance-registry/checks/lifecycle.check.js.map +1 -0
- package/dist/modules/instance-registry/checks/split-brain.check.d.ts +8 -0
- package/dist/modules/instance-registry/checks/split-brain.check.js +67 -0
- package/dist/modules/instance-registry/checks/split-brain.check.js.map +1 -0
- package/dist/modules/instance-registry/checks/version-mismatch.check.d.ts +8 -0
- package/dist/modules/instance-registry/checks/version-mismatch.check.js +55 -0
- package/dist/modules/instance-registry/checks/version-mismatch.check.js.map +1 -0
- package/dist/modules/instance-registry/instance-registry.controller.d.ts +3 -1
- package/dist/modules/instance-registry/instance-registry.controller.js +41 -5
- package/dist/modules/instance-registry/instance-registry.controller.js.map +1 -1
- package/dist/modules/instance-registry/instance-registry.module.js +3 -9
- package/dist/modules/instance-registry/instance-registry.module.js.map +1 -1
- package/dist/modules/ldap.ee/helpers.ee.js +1 -1
- package/dist/modules/ldap.ee/helpers.ee.js.map +1 -1
- package/dist/modules/ldap.ee/ldap.service.ee.js +2 -2
- package/dist/modules/ldap.ee/ldap.service.ee.js.map +1 -1
- package/dist/modules/mcp/dto/update-workflows-availability.dto.d.ts +15 -0
- package/dist/modules/mcp/dto/update-workflows-availability.dto.js +14 -0
- package/dist/modules/mcp/dto/update-workflows-availability.dto.js.map +1 -0
- package/dist/modules/mcp/mcp-oauth-service.d.ts +6 -0
- package/dist/modules/mcp/mcp-oauth-service.js +15 -3
- package/dist/modules/mcp/mcp-oauth-service.js.map +1 -1
- package/dist/modules/mcp/mcp-oauth-token.service.d.ts +1 -0
- package/dist/modules/mcp/mcp-oauth-token.service.js +3 -0
- package/dist/modules/mcp/mcp-oauth-token.service.js.map +1 -1
- package/dist/modules/mcp/mcp.controller.d.ts +2 -0
- package/dist/modules/mcp/mcp.controller.js +49 -11
- package/dist/modules/mcp/mcp.controller.js.map +1 -1
- package/dist/modules/mcp/mcp.errors.d.ts +6 -0
- package/dist/modules/mcp/mcp.errors.js +12 -1
- package/dist/modules/mcp/mcp.errors.js.map +1 -1
- package/dist/modules/mcp/mcp.module.d.ts +1 -0
- package/dist/modules/mcp/mcp.module.js +3 -1
- package/dist/modules/mcp/mcp.module.js.map +1 -1
- package/dist/modules/mcp/mcp.oauth-clients.controller.d.ts +2 -1
- package/dist/modules/mcp/mcp.oauth-clients.controller.js +10 -0
- package/dist/modules/mcp/mcp.oauth-clients.controller.js.map +1 -1
- package/dist/modules/mcp/mcp.oauth.controller.js +20 -1
- package/dist/modules/mcp/mcp.oauth.controller.js.map +1 -1
- package/dist/modules/mcp/mcp.service.js +3 -0
- package/dist/modules/mcp/mcp.service.js.map +1 -1
- package/dist/modules/mcp/mcp.settings.controller.d.ts +11 -12
- package/dist/modules/mcp/mcp.settings.controller.js +19 -50
- package/dist/modules/mcp/mcp.settings.controller.js.map +1 -1
- package/dist/modules/mcp/mcp.settings.service.d.ts +30 -2
- package/dist/modules/mcp/mcp.settings.service.js +165 -2
- package/dist/modules/mcp/mcp.settings.service.js.map +1 -1
- package/dist/modules/mcp/tools/search-executions.tool.d.ts +16 -0
- package/dist/modules/mcp/tools/search-executions.tool.js +140 -0
- package/dist/modules/mcp/tools/search-executions.tool.js.map +1 -0
- package/dist/modules/mcp/tools/workflow-builder/get-workflow-node-types.tool.d.ts +2 -2
- package/dist/modules/oauth-jwe/oauth-jwe-decrypt.service.d.ts +7 -0
- package/dist/modules/oauth-jwe/oauth-jwe-decrypt.service.js +48 -0
- package/dist/modules/oauth-jwe/oauth-jwe-decrypt.service.js.map +1 -0
- package/dist/modules/oauth-jwe/oauth-jwe-key.service.d.ts +31 -0
- package/dist/modules/oauth-jwe/oauth-jwe-key.service.js +174 -0
- package/dist/modules/oauth-jwe/oauth-jwe-key.service.js.map +1 -0
- package/dist/modules/oauth-jwe/oauth-jwe.config.d.ts +3 -0
- package/dist/modules/oauth-jwe/oauth-jwe.config.js +27 -0
- package/dist/modules/oauth-jwe/oauth-jwe.config.js.map +1 -0
- package/dist/modules/oauth-jwe/oauth-jwe.constants.d.ts +9 -0
- package/dist/modules/oauth-jwe/oauth-jwe.constants.js +15 -0
- package/dist/modules/oauth-jwe/oauth-jwe.constants.js.map +1 -0
- package/dist/modules/oauth-jwe/oauth-jwe.controller.d.ts +10 -0
- package/dist/modules/oauth-jwe/oauth-jwe.controller.js +60 -0
- package/dist/modules/oauth-jwe/oauth-jwe.controller.js.map +1 -0
- package/dist/modules/oauth-jwe/oauth-jwe.module.d.ts +8 -0
- package/dist/modules/oauth-jwe/oauth-jwe.module.js +70 -0
- package/dist/modules/oauth-jwe/oauth-jwe.module.js.map +1 -0
- package/dist/modules/oauth-jwe/oauth-jwe.schemas.d.ts +131 -0
- package/dist/modules/oauth-jwe/oauth-jwe.schemas.js +34 -0
- package/dist/modules/oauth-jwe/oauth-jwe.schemas.js.map +1 -0
- package/dist/modules/oauth-jwe/oauth-jwe.utils.d.ts +4 -0
- package/dist/modules/oauth-jwe/oauth-jwe.utils.js +27 -0
- package/dist/modules/oauth-jwe/oauth-jwe.utils.js.map +1 -0
- package/dist/modules/source-control.ee/source-control-export.service.ee.js +1 -1
- package/dist/modules/source-control.ee/source-control-export.service.ee.js.map +1 -1
- package/dist/modules/source-control.ee/source-control-import.service.ee.js +6 -6
- package/dist/modules/source-control.ee/source-control-import.service.ee.js.map +1 -1
- package/dist/modules/source-control.ee/source-control-preferences.service.ee.js +6 -6
- package/dist/modules/source-control.ee/source-control-preferences.service.ee.js.map +1 -1
- package/dist/modules/sso-oidc/oidc.service.ee.js +2 -2
- package/dist/modules/sso-oidc/oidc.service.ee.js.map +1 -1
- package/dist/modules/sso-saml/saml.service.ee.js +6 -6
- package/dist/modules/sso-saml/saml.service.ee.js.map +1 -1
- package/dist/oauth/oauth-jwe-service.proxy.d.ts +9 -0
- package/dist/oauth/oauth-jwe-service.proxy.js +27 -0
- package/dist/oauth/oauth-jwe-service.proxy.js.map +1 -0
- package/dist/oauth/oauth.service.d.ts +2 -2
- package/dist/oauth/oauth.service.js +13 -12
- package/dist/oauth/oauth.service.js.map +1 -1
- package/dist/posthog/index.d.ts +2 -0
- package/dist/posthog/index.js +16 -0
- package/dist/posthog/index.js.map +1 -1
- package/dist/public-api/v1/handlers/credentials/credentials.service.js +2 -2
- package/dist/public-api/v1/handlers/credentials/credentials.service.js.map +1 -1
- package/dist/services/dynamic-node-parameters.service.d.ts +1 -0
- package/dist/services/dynamic-node-parameters.service.js +29 -12
- package/dist/services/dynamic-node-parameters.service.js.map +1 -1
- package/dist/services/export.service.js +2 -2
- package/dist/services/export.service.js.map +1 -1
- package/dist/services/frontend.service.js +18 -0
- package/dist/services/frontend.service.js.map +1 -1
- package/dist/services/import.service.d.ts +5 -1
- package/dist/services/import.service.js +62 -5
- package/dist/services/import.service.js.map +1 -1
- package/dist/services/redis-client.service.d.ts +6 -5
- package/dist/services/redis-client.service.js +19 -12
- package/dist/services/redis-client.service.js.map +1 -1
- package/dist/services/user.service.js +0 -9
- package/dist/services/user.service.js.map +1 -1
- package/dist/task-runners/task-broker/auth/task-broker-auth.service.d.ts +4 -4
- package/dist/task-runners/task-broker/auth/task-broker-auth.service.js +9 -8
- package/dist/task-runners/task-broker/auth/task-broker-auth.service.js.map +1 -1
- package/dist/task-runners/task-broker/task-broker-server.js +1 -1
- package/dist/task-runners/task-broker/task-broker-server.js.map +1 -1
- package/dist/webhooks/test-webhooks.js +16 -2
- package/dist/webhooks/test-webhooks.js.map +1 -1
- package/dist/workflow-execute-additional-data.js +4 -2
- package/dist/workflow-execute-additional-data.js.map +1 -1
- package/dist/workflows/workflow-finder.service.d.ts +2 -0
- package/dist/workflows/workflow-finder.service.js +12 -1
- package/dist/workflows/workflow-finder.service.js.map +1 -1
- package/dist/workflows/workflows.controller.d.ts +7 -2
- package/dist/workflows/workflows.controller.js +43 -10
- package/dist/workflows/workflows.controller.js.map +1 -1
- package/package.json +30 -28
- package/dist/modules/instance-ai/web-research/ssrf-guard.d.ts +0 -1
- package/dist/modules/instance-ai/web-research/ssrf-guard.js +0 -85
- package/dist/modules/instance-ai/web-research/ssrf-guard.js.map +0 -1
- package/dist/modules/mcp/dto/update-workflow-availability.dto.d.ts +0 -9
- package/dist/modules/mcp/dto/update-workflow-availability.dto.js +0 -11
- package/dist/modules/mcp/dto/update-workflow-availability.dto.js.map +0 -1
|
@@ -37,26 +37,29 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
|
37
37
|
};
|
|
38
38
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
39
39
|
exports.fetchAndExtract = fetchAndExtract;
|
|
40
|
+
const turndown_plugin_gfm_1 = require("@joplin/turndown-plugin-gfm");
|
|
40
41
|
const readability_1 = require("@mozilla/readability");
|
|
41
42
|
const linkedom_1 = require("linkedom");
|
|
42
43
|
const turndown_1 = __importDefault(require("turndown"));
|
|
43
|
-
const
|
|
44
|
-
const ssrf_guard_1 = require("./ssrf-guard");
|
|
44
|
+
const undici_1 = require("undici");
|
|
45
45
|
const DEFAULT_TIMEOUT_MS = 30_000;
|
|
46
46
|
const MAX_TIMEOUT_MS = 120_000;
|
|
47
47
|
const MAX_RESPONSE_BYTES = 5 * 1024 * 1024;
|
|
48
48
|
const DEFAULT_MAX_CONTENT_LENGTH = 30_000;
|
|
49
49
|
const MAX_REDIRECTS = 10;
|
|
50
50
|
async function fetchAndExtract(url, options) {
|
|
51
|
-
const maxContentLength = options
|
|
52
|
-
const maxResponseBytes = options
|
|
53
|
-
const timeoutMs = Math.min(options
|
|
54
|
-
const authorizeUrl = options
|
|
51
|
+
const maxContentLength = options.maxContentLength ?? DEFAULT_MAX_CONTENT_LENGTH;
|
|
52
|
+
const maxResponseBytes = options.maxResponseBytes ?? MAX_RESPONSE_BYTES;
|
|
53
|
+
const timeoutMs = Math.min(options.timeoutMs ?? DEFAULT_TIMEOUT_MS, MAX_TIMEOUT_MS);
|
|
54
|
+
const { authorizeUrl, ssrf } = options;
|
|
55
55
|
let currentUrl = url;
|
|
56
56
|
let response;
|
|
57
57
|
let redirectCount = 0;
|
|
58
58
|
while (redirectCount <= MAX_REDIRECTS) {
|
|
59
|
-
await
|
|
59
|
+
const validation = await ssrf.validateUrl(currentUrl);
|
|
60
|
+
if (!validation.ok)
|
|
61
|
+
throw validation.error;
|
|
62
|
+
const dispatcher = new undici_1.Agent({ connect: { lookup: ssrf.createSecureLookup() } });
|
|
60
63
|
const controller = new AbortController();
|
|
61
64
|
const timeout = setTimeout(() => controller.abort(), timeoutMs);
|
|
62
65
|
try {
|
|
@@ -67,10 +70,12 @@ async function fetchAndExtract(url, options) {
|
|
|
67
70
|
Accept: 'text/html,application/xhtml+xml,application/xml;q=0.9,text/plain;q=0.8,application/pdf;q=0.7,*/*;q=0.5',
|
|
68
71
|
},
|
|
69
72
|
redirect: 'manual',
|
|
73
|
+
dispatcher,
|
|
70
74
|
});
|
|
71
75
|
}
|
|
72
76
|
finally {
|
|
73
77
|
clearTimeout(timeout);
|
|
78
|
+
await dispatcher.close();
|
|
74
79
|
}
|
|
75
80
|
if (response.status >= 300 && response.status < 400) {
|
|
76
81
|
const location = response.headers.get('location');
|
|
@@ -81,15 +86,12 @@ async function fetchAndExtract(url, options) {
|
|
|
81
86
|
throw new Error(`Too many redirects (max ${MAX_REDIRECTS})`);
|
|
82
87
|
}
|
|
83
88
|
currentUrl = new URL(location, currentUrl).href;
|
|
89
|
+
ssrf.validateRedirectSync(currentUrl);
|
|
84
90
|
if (authorizeUrl) {
|
|
85
91
|
await authorizeUrl(currentUrl);
|
|
86
92
|
}
|
|
87
93
|
continue;
|
|
88
94
|
}
|
|
89
|
-
if (response.url && response.url !== currentUrl) {
|
|
90
|
-
await (0, ssrf_guard_1.assertPublicUrl)(response.url);
|
|
91
|
-
currentUrl = response.url;
|
|
92
|
-
}
|
|
93
95
|
break;
|
|
94
96
|
}
|
|
95
97
|
const finalUrl = currentUrl;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"fetch-and-extract.js","sourceRoot":"","sources":["../../../../src/modules/instance-ai/web-research/fetch-and-extract.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
1
|
+
{"version":3,"file":"fetch-and-extract.js","sourceRoot":"","sources":["../../../../src/modules/instance-ai/web-research/fetch-and-extract.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,8 +1,6 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.searxngSearch = exports.braveSearch = exports.LRUCache = exports.maybeSummarize = exports.fetchAndExtract =
|
|
4
|
-
var ssrf_guard_1 = require("./ssrf-guard");
|
|
5
|
-
Object.defineProperty(exports, "assertPublicUrl", { enumerable: true, get: function () { return ssrf_guard_1.assertPublicUrl; } });
|
|
3
|
+
exports.searxngSearch = exports.braveSearch = exports.LRUCache = exports.maybeSummarize = exports.fetchAndExtract = void 0;
|
|
6
4
|
var fetch_and_extract_1 = require("./fetch-and-extract");
|
|
7
5
|
Object.defineProperty(exports, "fetchAndExtract", { enumerable: true, get: function () { return fetch_and_extract_1.fetchAndExtract; } });
|
|
8
6
|
var summarize_content_1 = require("./summarize-content");
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/modules/instance-ai/web-research/index.ts"],"names":[],"mappings":";;;AAAA,
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/modules/instance-ai/web-research/index.ts"],"names":[],"mappings":";;;AAAA,yDAAsD;AAA7C,oHAAA,eAAe,OAAA;AAExB,yDAAqD;AAA5C,mHAAA,cAAc,OAAA;AACvB,iCAAmC;AAA1B,iGAAA,QAAQ,OAAA;AACjB,+CAA6C;AAApC,2GAAA,WAAW,OAAA;AACpB,mDAAiD;AAAxC,+GAAA,aAAa,OAAA"}
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
import type { InstanceRegistration } from '@n8n/api-types';
|
|
2
|
+
import { Logger } from '@n8n/backend-common';
|
|
3
|
+
import type { ClusterCheckResult, ClusterStateDiff } from '@n8n/decorators';
|
|
4
|
+
import { ClusterCheckMetadata } from '@n8n/decorators';
|
|
5
|
+
import { InstanceSettings } from 'n8n-core';
|
|
6
|
+
import { MessageEventBus } from '../../../eventbus/message-event-bus/message-event-bus';
|
|
7
|
+
import { Push } from '../../../push';
|
|
8
|
+
import { InstanceRegistryService } from '../instance-registry.service';
|
|
9
|
+
export declare class CheckService {
|
|
10
|
+
private readonly instanceSettings;
|
|
11
|
+
private readonly instanceRegistryService;
|
|
12
|
+
private readonly clusterCheckMetadata;
|
|
13
|
+
private readonly messageEventBus;
|
|
14
|
+
private readonly push;
|
|
15
|
+
private reconcileController?;
|
|
16
|
+
private reconcileTimer;
|
|
17
|
+
private isShuttingDown;
|
|
18
|
+
private readonly checks;
|
|
19
|
+
private readonly logger;
|
|
20
|
+
constructor(logger: Logger, instanceSettings: InstanceSettings, instanceRegistryService: InstanceRegistryService, clusterCheckMetadata: ClusterCheckMetadata, messageEventBus: MessageEventBus, push: Push);
|
|
21
|
+
init(): void;
|
|
22
|
+
startReconciliation(): void;
|
|
23
|
+
stopReconciliation(): void;
|
|
24
|
+
shutdown(): void;
|
|
25
|
+
private scheduleNextReconcile;
|
|
26
|
+
private discoverChecks;
|
|
27
|
+
private runReconcileSafely;
|
|
28
|
+
runChecks(): Promise<{
|
|
29
|
+
currentState: Map<string, InstanceRegistration>;
|
|
30
|
+
results: Array<{
|
|
31
|
+
checkName: string;
|
|
32
|
+
checkDisplayName?: string;
|
|
33
|
+
result?: ClusterCheckResult;
|
|
34
|
+
failed?: true;
|
|
35
|
+
}>;
|
|
36
|
+
}>;
|
|
37
|
+
private reconcile;
|
|
38
|
+
private processResult;
|
|
39
|
+
private logWarning;
|
|
40
|
+
private emitAuditEvent;
|
|
41
|
+
private broadcastPush;
|
|
42
|
+
}
|
|
43
|
+
export declare function computeDiff(previousState: ReadonlyMap<string, InstanceRegistration>, currentState: ReadonlyMap<string, InstanceRegistration>): ClusterStateDiff;
|
|
@@ -0,0 +1,248 @@
|
|
|
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.CheckService = void 0;
|
|
13
|
+
exports.computeDiff = computeDiff;
|
|
14
|
+
const backend_common_1 = require("@n8n/backend-common");
|
|
15
|
+
const decorators_1 = require("@n8n/decorators");
|
|
16
|
+
const di_1 = require("@n8n/di");
|
|
17
|
+
const n8n_core_1 = require("n8n-core");
|
|
18
|
+
const message_event_bus_1 = require("../../../eventbus/message-event-bus/message-event-bus");
|
|
19
|
+
const push_1 = require("../../../push");
|
|
20
|
+
const instance_registry_service_1 = require("../instance-registry.service");
|
|
21
|
+
const instance_registry_types_1 = require("../instance-registry.types");
|
|
22
|
+
let CheckService = class CheckService {
|
|
23
|
+
constructor(logger, instanceSettings, instanceRegistryService, clusterCheckMetadata, messageEventBus, push) {
|
|
24
|
+
this.instanceSettings = instanceSettings;
|
|
25
|
+
this.instanceRegistryService = instanceRegistryService;
|
|
26
|
+
this.clusterCheckMetadata = clusterCheckMetadata;
|
|
27
|
+
this.messageEventBus = messageEventBus;
|
|
28
|
+
this.push = push;
|
|
29
|
+
this.isShuttingDown = false;
|
|
30
|
+
this.checks = [];
|
|
31
|
+
this.logger = logger.scoped('instance-registry');
|
|
32
|
+
}
|
|
33
|
+
init() {
|
|
34
|
+
this.discoverChecks();
|
|
35
|
+
if (this.instanceSettings.isLeader)
|
|
36
|
+
this.startReconciliation();
|
|
37
|
+
}
|
|
38
|
+
startReconciliation() {
|
|
39
|
+
if (this.isShuttingDown || this.reconcileController)
|
|
40
|
+
return;
|
|
41
|
+
this.reconcileController = new AbortController();
|
|
42
|
+
const { signal } = this.reconcileController;
|
|
43
|
+
void this.runReconcileSafely(signal);
|
|
44
|
+
this.scheduleNextReconcile(signal);
|
|
45
|
+
this.logger.debug('Cluster check reconciliation scheduled');
|
|
46
|
+
}
|
|
47
|
+
stopReconciliation() {
|
|
48
|
+
this.reconcileController?.abort();
|
|
49
|
+
this.reconcileController = undefined;
|
|
50
|
+
clearTimeout(this.reconcileTimer);
|
|
51
|
+
this.reconcileTimer = undefined;
|
|
52
|
+
}
|
|
53
|
+
shutdown() {
|
|
54
|
+
this.isShuttingDown = true;
|
|
55
|
+
this.stopReconciliation();
|
|
56
|
+
}
|
|
57
|
+
scheduleNextReconcile(signal) {
|
|
58
|
+
if (signal.aborted)
|
|
59
|
+
return;
|
|
60
|
+
this.reconcileTimer = setTimeout(async () => {
|
|
61
|
+
await this.runReconcileSafely(signal);
|
|
62
|
+
this.scheduleNextReconcile(signal);
|
|
63
|
+
}, instance_registry_types_1.REGISTRY_CONSTANTS.RECONCILIATION_INTERVAL_MS);
|
|
64
|
+
}
|
|
65
|
+
discoverChecks() {
|
|
66
|
+
const checkClasses = this.clusterCheckMetadata.getClasses();
|
|
67
|
+
for (const CheckClass of checkClasses) {
|
|
68
|
+
try {
|
|
69
|
+
const check = di_1.Container.get(CheckClass);
|
|
70
|
+
this.checks.push(check);
|
|
71
|
+
}
|
|
72
|
+
catch (error) {
|
|
73
|
+
this.logger.error(`Failed to instantiate cluster check "${CheckClass.name}"`, {
|
|
74
|
+
error,
|
|
75
|
+
});
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
this.logger.info(`Discovered ${this.checks.length} cluster checks`, {
|
|
79
|
+
names: this.checks.map((c) => c.checkDescription.name),
|
|
80
|
+
});
|
|
81
|
+
}
|
|
82
|
+
async runReconcileSafely(signal) {
|
|
83
|
+
try {
|
|
84
|
+
await this.reconcile(signal);
|
|
85
|
+
}
|
|
86
|
+
catch (error) {
|
|
87
|
+
this.logger.warn('Reconciliation cycle failed', { error });
|
|
88
|
+
}
|
|
89
|
+
}
|
|
90
|
+
async runChecks() {
|
|
91
|
+
if (this.checks.length === 0) {
|
|
92
|
+
return { currentState: new Map(), results: [] };
|
|
93
|
+
}
|
|
94
|
+
const instances = await this.instanceRegistryService.getAllInstances();
|
|
95
|
+
const currentState = new Map(instances.map((i) => [i.instanceKey, i]));
|
|
96
|
+
const previousState = await this.instanceRegistryService.getLastKnownState();
|
|
97
|
+
const diff = computeDiff(previousState, currentState);
|
|
98
|
+
const context = { currentState, previousState, diff };
|
|
99
|
+
const settled = await Promise.allSettled(this.checks.map(async (check) => await check.run(context)));
|
|
100
|
+
const results = [];
|
|
101
|
+
for (let i = 0; i < settled.length; i++) {
|
|
102
|
+
const outcome = settled[i];
|
|
103
|
+
const check = this.checks[i];
|
|
104
|
+
const checkResult = {
|
|
105
|
+
checkName: check.checkDescription.name,
|
|
106
|
+
checkDisplayName: check.checkDescription.displayName,
|
|
107
|
+
};
|
|
108
|
+
if (outcome.status === 'fulfilled') {
|
|
109
|
+
checkResult.result = outcome.value;
|
|
110
|
+
}
|
|
111
|
+
else {
|
|
112
|
+
this.logger.error('Cluster check failed', {
|
|
113
|
+
...checkResult,
|
|
114
|
+
error: outcome.reason,
|
|
115
|
+
});
|
|
116
|
+
checkResult.failed = true;
|
|
117
|
+
}
|
|
118
|
+
results.push(checkResult);
|
|
119
|
+
}
|
|
120
|
+
return { currentState, results };
|
|
121
|
+
}
|
|
122
|
+
async reconcile(signal) {
|
|
123
|
+
if (this.checks.length === 0)
|
|
124
|
+
return;
|
|
125
|
+
if (signal.aborted)
|
|
126
|
+
return;
|
|
127
|
+
const { currentState, results } = await this.runChecks();
|
|
128
|
+
if (signal.aborted)
|
|
129
|
+
return;
|
|
130
|
+
for (const { checkName, result } of results) {
|
|
131
|
+
this.processResult(checkName, result);
|
|
132
|
+
}
|
|
133
|
+
try {
|
|
134
|
+
if (signal.aborted)
|
|
135
|
+
return;
|
|
136
|
+
await this.instanceRegistryService.saveLastKnownState(currentState);
|
|
137
|
+
}
|
|
138
|
+
catch (error) {
|
|
139
|
+
this.logger.warn('Failed to persist last known cluster state', { error });
|
|
140
|
+
}
|
|
141
|
+
}
|
|
142
|
+
processResult(checkName, result) {
|
|
143
|
+
for (const warning of result?.warnings ?? []) {
|
|
144
|
+
this.logWarning(checkName, warning);
|
|
145
|
+
}
|
|
146
|
+
for (const event of result?.auditEvents ?? []) {
|
|
147
|
+
this.emitAuditEvent(checkName, event);
|
|
148
|
+
}
|
|
149
|
+
for (const notification of result?.pushNotifications ?? []) {
|
|
150
|
+
this.broadcastPush(checkName, notification);
|
|
151
|
+
}
|
|
152
|
+
}
|
|
153
|
+
logWarning(checkName, warning) {
|
|
154
|
+
const severity = warning.severity ?? 'warning';
|
|
155
|
+
const method = severity === 'info' ? 'info' : severity === 'error' ? 'error' : 'warn';
|
|
156
|
+
this.logger[method]('Cluster check warning', {
|
|
157
|
+
check: checkName,
|
|
158
|
+
code: warning.code,
|
|
159
|
+
message: warning.message,
|
|
160
|
+
context: warning.context,
|
|
161
|
+
});
|
|
162
|
+
}
|
|
163
|
+
emitAuditEvent(checkName, event) {
|
|
164
|
+
void this.messageEventBus
|
|
165
|
+
.sendAuditEvent({
|
|
166
|
+
eventName: event.eventName,
|
|
167
|
+
payload: event.payload,
|
|
168
|
+
})
|
|
169
|
+
.catch((error) => {
|
|
170
|
+
this.logger.warn('Failed to emit cluster check audit event', {
|
|
171
|
+
check: checkName,
|
|
172
|
+
eventName: event.eventName,
|
|
173
|
+
error,
|
|
174
|
+
});
|
|
175
|
+
});
|
|
176
|
+
}
|
|
177
|
+
broadcastPush(checkName, notification) {
|
|
178
|
+
try {
|
|
179
|
+
this.push.broadcast({
|
|
180
|
+
type: notification.type,
|
|
181
|
+
data: notification.data,
|
|
182
|
+
});
|
|
183
|
+
}
|
|
184
|
+
catch (error) {
|
|
185
|
+
this.logger.warn('Failed to broadcast cluster check push notification', {
|
|
186
|
+
check: checkName,
|
|
187
|
+
type: notification.type,
|
|
188
|
+
error,
|
|
189
|
+
});
|
|
190
|
+
}
|
|
191
|
+
}
|
|
192
|
+
};
|
|
193
|
+
exports.CheckService = CheckService;
|
|
194
|
+
__decorate([
|
|
195
|
+
(0, decorators_1.OnLeaderTakeover)(),
|
|
196
|
+
__metadata("design:type", Function),
|
|
197
|
+
__metadata("design:paramtypes", []),
|
|
198
|
+
__metadata("design:returntype", void 0)
|
|
199
|
+
], CheckService.prototype, "startReconciliation", null);
|
|
200
|
+
__decorate([
|
|
201
|
+
(0, decorators_1.OnLeaderStepdown)(),
|
|
202
|
+
__metadata("design:type", Function),
|
|
203
|
+
__metadata("design:paramtypes", []),
|
|
204
|
+
__metadata("design:returntype", void 0)
|
|
205
|
+
], CheckService.prototype, "stopReconciliation", null);
|
|
206
|
+
__decorate([
|
|
207
|
+
(0, decorators_1.OnShutdown)(),
|
|
208
|
+
__metadata("design:type", Function),
|
|
209
|
+
__metadata("design:paramtypes", []),
|
|
210
|
+
__metadata("design:returntype", void 0)
|
|
211
|
+
], CheckService.prototype, "shutdown", null);
|
|
212
|
+
exports.CheckService = CheckService = __decorate([
|
|
213
|
+
(0, di_1.Service)(),
|
|
214
|
+
__metadata("design:paramtypes", [backend_common_1.Logger,
|
|
215
|
+
n8n_core_1.InstanceSettings,
|
|
216
|
+
instance_registry_service_1.InstanceRegistryService,
|
|
217
|
+
decorators_1.ClusterCheckMetadata,
|
|
218
|
+
message_event_bus_1.MessageEventBus,
|
|
219
|
+
push_1.Push])
|
|
220
|
+
], CheckService);
|
|
221
|
+
function computeDiff(previousState, currentState) {
|
|
222
|
+
const added = [];
|
|
223
|
+
const removed = [];
|
|
224
|
+
const changed = [];
|
|
225
|
+
for (const [key, current] of currentState) {
|
|
226
|
+
const previous = previousState.get(key);
|
|
227
|
+
if (!previous) {
|
|
228
|
+
added.push(current);
|
|
229
|
+
}
|
|
230
|
+
else if (!isEquivalent(previous, current)) {
|
|
231
|
+
changed.push({ previous, current });
|
|
232
|
+
}
|
|
233
|
+
}
|
|
234
|
+
for (const [key, previous] of previousState) {
|
|
235
|
+
if (!currentState.has(key))
|
|
236
|
+
removed.push(previous);
|
|
237
|
+
}
|
|
238
|
+
return { added, removed, changed };
|
|
239
|
+
}
|
|
240
|
+
function isEquivalent(a, b) {
|
|
241
|
+
return (a.schemaVersion === b.schemaVersion &&
|
|
242
|
+
a.instanceKey === b.instanceKey &&
|
|
243
|
+
a.hostId === b.hostId &&
|
|
244
|
+
a.instanceType === b.instanceType &&
|
|
245
|
+
a.instanceRole === b.instanceRole &&
|
|
246
|
+
a.version === b.version);
|
|
247
|
+
}
|
|
248
|
+
//# sourceMappingURL=check.service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"check.service.js","sourceRoot":"","sources":["../../../../src/modules/instance-registry/checks/check.service.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { type ClusterCheckContext, type ClusterCheckResult, type IClusterCheck } from '@n8n/decorators';
|
|
2
|
+
export declare class HostIdClashCheck implements IClusterCheck {
|
|
3
|
+
checkDescription: {
|
|
4
|
+
name: string;
|
|
5
|
+
displayName: string;
|
|
6
|
+
};
|
|
7
|
+
run(context: ClusterCheckContext): Promise<ClusterCheckResult>;
|
|
8
|
+
}
|
|
@@ -0,0 +1,68 @@
|
|
|
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.HostIdClashCheck = void 0;
|
|
10
|
+
const decorators_1 = require("@n8n/decorators");
|
|
11
|
+
const CHECK_CODE = 'cluster.hostid-clash';
|
|
12
|
+
const AUDIT_DETECTED = 'n8n.audit.cluster.hostid-clash.detected';
|
|
13
|
+
const AUDIT_RESOLVED = 'n8n.audit.cluster.hostid-clash.resolved';
|
|
14
|
+
function computeFingerprint(instances) {
|
|
15
|
+
const byHost = new Map();
|
|
16
|
+
for (const instance of instances) {
|
|
17
|
+
const keys = byHost.get(instance.hostId) ?? [];
|
|
18
|
+
keys.push(instance.instanceKey);
|
|
19
|
+
byHost.set(instance.hostId, keys);
|
|
20
|
+
}
|
|
21
|
+
const clashing = Array.from(byHost.entries())
|
|
22
|
+
.filter(([, keys]) => keys.length > 1)
|
|
23
|
+
.map(([hostId, keys]) => ({ hostId, instanceKeys: [...keys].sort() }))
|
|
24
|
+
.sort((a, b) => a.hostId.localeCompare(b.hostId));
|
|
25
|
+
return {
|
|
26
|
+
hasClash: clashing.length > 0,
|
|
27
|
+
fingerprint: clashing.map((c) => c.hostId).join('|'),
|
|
28
|
+
clashing,
|
|
29
|
+
};
|
|
30
|
+
}
|
|
31
|
+
let HostIdClashCheck = class HostIdClashCheck {
|
|
32
|
+
constructor() {
|
|
33
|
+
this.checkDescription = {
|
|
34
|
+
name: 'hostid-clash',
|
|
35
|
+
displayName: 'Host ID clash',
|
|
36
|
+
};
|
|
37
|
+
}
|
|
38
|
+
async run(context) {
|
|
39
|
+
const current = computeFingerprint(context.currentState.values());
|
|
40
|
+
const previous = computeFingerprint(context.previousState.values());
|
|
41
|
+
if (!current.hasClash) {
|
|
42
|
+
if (previous.hasClash) {
|
|
43
|
+
return { auditEvents: [{ eventName: AUDIT_RESOLVED, payload: {} }] };
|
|
44
|
+
}
|
|
45
|
+
return {};
|
|
46
|
+
}
|
|
47
|
+
const hostIds = current.clashing.map((c) => c.hostId);
|
|
48
|
+
const result = {
|
|
49
|
+
warnings: [
|
|
50
|
+
{
|
|
51
|
+
code: CHECK_CODE,
|
|
52
|
+
message: `Detected multiple instances sharing the same hostId: ${hostIds.join(', ')}`,
|
|
53
|
+
severity: 'warning',
|
|
54
|
+
context: { clashing: current.clashing },
|
|
55
|
+
},
|
|
56
|
+
],
|
|
57
|
+
};
|
|
58
|
+
if (current.fingerprint !== previous.fingerprint) {
|
|
59
|
+
result.auditEvents = [{ eventName: AUDIT_DETECTED, payload: { clashing: current.clashing } }];
|
|
60
|
+
}
|
|
61
|
+
return result;
|
|
62
|
+
}
|
|
63
|
+
};
|
|
64
|
+
exports.HostIdClashCheck = HostIdClashCheck;
|
|
65
|
+
exports.HostIdClashCheck = HostIdClashCheck = __decorate([
|
|
66
|
+
(0, decorators_1.ClusterCheck)()
|
|
67
|
+
], HostIdClashCheck);
|
|
68
|
+
//# sourceMappingURL=hostid-clash.check.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"hostid-clash.check.js","sourceRoot":"","sources":["../../../../src/modules/instance-registry/checks/hostid-clash.check.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/modules/instance-registry/checks/index.ts"],"names":[],"mappings":";;AAAA,oCAAkC;AAClC,gCAA8B;AAC9B,+BAA6B;AAC7B,6BAA2B"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { type ClusterCheckContext, type ClusterCheckResult, type IClusterCheck } from '@n8n/decorators';
|
|
2
|
+
export declare class LifecycleCheck implements IClusterCheck {
|
|
3
|
+
checkDescription: {
|
|
4
|
+
name: string;
|
|
5
|
+
displayName: string;
|
|
6
|
+
};
|
|
7
|
+
run(context: ClusterCheckContext): Promise<ClusterCheckResult>;
|
|
8
|
+
}
|
|
@@ -0,0 +1,52 @@
|
|
|
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.LifecycleCheck = void 0;
|
|
10
|
+
const decorators_1 = require("@n8n/decorators");
|
|
11
|
+
const AUDIT_JOINED = 'n8n.audit.cluster.instance-joined';
|
|
12
|
+
const AUDIT_LEFT = 'n8n.audit.cluster.instance-left';
|
|
13
|
+
function membershipPayload(instance) {
|
|
14
|
+
return {
|
|
15
|
+
instanceKey: instance.instanceKey,
|
|
16
|
+
hostId: instance.hostId,
|
|
17
|
+
instanceType: instance.instanceType,
|
|
18
|
+
instanceRole: instance.instanceRole,
|
|
19
|
+
version: instance.version,
|
|
20
|
+
};
|
|
21
|
+
}
|
|
22
|
+
let LifecycleCheck = class LifecycleCheck {
|
|
23
|
+
constructor() {
|
|
24
|
+
this.checkDescription = {
|
|
25
|
+
name: 'lifecycle',
|
|
26
|
+
displayName: 'Cluster membership',
|
|
27
|
+
};
|
|
28
|
+
}
|
|
29
|
+
async run(context) {
|
|
30
|
+
const auditEvents = [];
|
|
31
|
+
for (const joined of context.diff.added) {
|
|
32
|
+
auditEvents.push({
|
|
33
|
+
eventName: AUDIT_JOINED,
|
|
34
|
+
payload: membershipPayload(joined),
|
|
35
|
+
});
|
|
36
|
+
}
|
|
37
|
+
for (const left of context.diff.removed) {
|
|
38
|
+
auditEvents.push({
|
|
39
|
+
eventName: AUDIT_LEFT,
|
|
40
|
+
payload: membershipPayload(left),
|
|
41
|
+
});
|
|
42
|
+
}
|
|
43
|
+
if (auditEvents.length === 0)
|
|
44
|
+
return {};
|
|
45
|
+
return { auditEvents };
|
|
46
|
+
}
|
|
47
|
+
};
|
|
48
|
+
exports.LifecycleCheck = LifecycleCheck;
|
|
49
|
+
exports.LifecycleCheck = LifecycleCheck = __decorate([
|
|
50
|
+
(0, decorators_1.ClusterCheck)()
|
|
51
|
+
], LifecycleCheck);
|
|
52
|
+
//# sourceMappingURL=lifecycle.check.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"lifecycle.check.js","sourceRoot":"","sources":["../../../../src/modules/instance-registry/checks/lifecycle.check.ts"],"names":[],"mappings":";;;;;;;;;AACA,gDAMyB;AAEzB,MAAM,YAAY,GAAG,mCAAmC,CAAC;AACzD,MAAM,UAAU,GAAG,iCAAiC,CAAC;AAErD,SAAS,iBAAiB,CAAC,QAA8B;IACxD,OAAO;QACN,WAAW,EAAE,QAAQ,CAAC,WAAW;QACjC,MAAM,EAAE,QAAQ,CAAC,MAAM;QACvB,YAAY,EAAE,QAAQ,CAAC,YAAY;QACnC,YAAY,EAAE,QAAQ,CAAC,YAAY;QACnC,OAAO,EAAE,QAAQ,CAAC,OAAO;KACzB,CAAC;AACH,CAAC;AAUM,IAAM,cAAc,GAApB,MAAM,cAAc;IAApB;QACN,qBAAgB,GAAG;YAClB,IAAI,EAAE,WAAW;YACjB,WAAW,EAAE,oBAAoB;SACjC,CAAC;IAuBH,CAAC;IArBA,KAAK,CAAC,GAAG,CAAC,OAA4B;QACrC,MAAM,WAAW,GAA6B,EAAE,CAAC;QAEjD,KAAK,MAAM,MAAM,IAAI,OAAO,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC;YACzC,WAAW,CAAC,IAAI,CAAC;gBAChB,SAAS,EAAE,YAAY;gBACvB,OAAO,EAAE,iBAAiB,CAAC,MAAM,CAAC;aAClC,CAAC,CAAC;QACJ,CAAC;QAED,KAAK,MAAM,IAAI,IAAI,OAAO,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC;YACzC,WAAW,CAAC,IAAI,CAAC;gBAChB,SAAS,EAAE,UAAU;gBACrB,OAAO,EAAE,iBAAiB,CAAC,IAAI,CAAC;aAChC,CAAC,CAAC;QACJ,CAAC;QAED,IAAI,WAAW,CAAC,MAAM,KAAK,CAAC;YAAE,OAAO,EAAE,CAAC;QAExC,OAAO,EAAE,WAAW,EAAE,CAAC;IACxB,CAAC;CACD,CAAA;AA3BY,wCAAc;yBAAd,cAAc;IAD1B,IAAA,yBAAY,GAAE;GACF,cAAc,CA2B1B"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { type ClusterCheckContext, type ClusterCheckResult, type IClusterCheck } from '@n8n/decorators';
|
|
2
|
+
export declare class SplitBrainCheck implements IClusterCheck {
|
|
3
|
+
checkDescription: {
|
|
4
|
+
name: string;
|
|
5
|
+
displayName: string;
|
|
6
|
+
};
|
|
7
|
+
run(context: ClusterCheckContext): Promise<ClusterCheckResult>;
|
|
8
|
+
}
|