n8n 2.0.1 → 2.1.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/active-executions.js +7 -1
- package/dist/active-executions.js.map +1 -1
- package/dist/active-workflow-manager.d.ts +0 -1
- package/dist/active-workflow-manager.js +5 -8
- package/dist/active-workflow-manager.js.map +1 -1
- package/dist/auth/auth.service.js +1 -7
- package/dist/auth/auth.service.js.map +1 -1
- package/dist/build.tsbuildinfo +1 -1
- package/dist/commands/base-command.js +1 -2
- package/dist/commands/base-command.js.map +1 -1
- package/dist/commands/start.js +3 -0
- package/dist/commands/start.js.map +1 -1
- package/dist/commands/user-management/reset.js +1 -1
- package/dist/commands/user-management/reset.js.map +1 -1
- package/dist/commands/worker.js +3 -0
- package/dist/commands/worker.js.map +1 -1
- package/dist/concurrency/concurrency-control.service.js +2 -1
- package/dist/concurrency/concurrency-control.service.js.map +1 -1
- package/dist/config/schema.js.map +1 -1
- package/dist/config/types.d.ts +0 -1
- package/dist/controllers/ai.controller.d.ts +3 -0
- package/dist/controllers/ai.controller.js +2 -1
- package/dist/controllers/ai.controller.js.map +1 -1
- package/dist/controllers/api-keys.controller.js +5 -0
- package/dist/controllers/api-keys.controller.js.map +1 -1
- package/dist/controllers/e2e.controller.d.ts +1 -0
- package/dist/controllers/e2e.controller.js +10 -11
- package/dist/controllers/e2e.controller.js.map +1 -1
- package/dist/controllers/invitation.controller.d.ts +3 -1
- package/dist/controllers/invitation.controller.js +6 -7
- package/dist/controllers/invitation.controller.js.map +1 -1
- package/dist/controllers/oauth/oauth1-credential.controller.d.ts +6 -3
- package/dist/controllers/oauth/oauth1-credential.controller.js +39 -57
- package/dist/controllers/oauth/oauth1-credential.controller.js.map +1 -1
- package/dist/controllers/oauth/oauth2-credential.controller.d.ts +8 -5
- package/dist/controllers/oauth/oauth2-credential.controller.js +41 -179
- package/dist/controllers/oauth/oauth2-credential.controller.js.map +1 -1
- package/dist/controllers/owner.controller.d.ts +4 -10
- package/dist/controllers/owner.controller.js +6 -42
- package/dist/controllers/owner.controller.js.map +1 -1
- package/dist/controllers/project.controller.d.ts +4 -0
- package/dist/credentials/credential-resolution-provider.interface.d.ts +12 -0
- package/dist/credentials/credential-resolution-provider.interface.js +3 -0
- package/dist/credentials/credential-resolution-provider.interface.js.map +1 -0
- package/dist/credentials/credentials-finder.service.d.ts +4 -0
- package/dist/credentials/credentials-finder.service.js +3 -0
- package/dist/credentials/credentials-finder.service.js.map +1 -1
- package/dist/credentials/credentials.controller.d.ts +12 -4
- package/dist/credentials/credentials.controller.js +9 -6
- package/dist/credentials/credentials.controller.js.map +1 -1
- package/dist/credentials/credentials.service.d.ts +13 -0
- package/dist/credentials/credentials.service.ee.d.ts +9 -2
- package/dist/credentials/credentials.service.ee.js +4 -1
- package/dist/credentials/credentials.service.ee.js.map +1 -1
- package/dist/credentials/credentials.service.js +10 -6
- package/dist/credentials/credentials.service.js.map +1 -1
- package/dist/credentials/dynamic-credential-storage.interface.d.ts +11 -0
- package/dist/credentials/dynamic-credential-storage.interface.js +3 -0
- package/dist/credentials/dynamic-credential-storage.interface.js.map +1 -0
- package/dist/credentials/dynamic-credentials-proxy.d.ts +14 -0
- package/dist/credentials/dynamic-credentials-proxy.js +50 -0
- package/dist/credentials/dynamic-credentials-proxy.js.map +1 -0
- package/dist/credentials-helper.d.ts +5 -2
- package/dist/credentials-helper.js +25 -7
- package/dist/credentials-helper.js.map +1 -1
- package/dist/environments.ee/source-control/source-control-import.service.ee.js.map +1 -1
- package/dist/environments.ee/source-control/source-control-status.service.ee.d.ts +2 -2
- package/dist/environments.ee/source-control/source-control.controller.ee.d.ts +4 -4
- package/dist/environments.ee/source-control/source-control.service.ee.d.ts +2 -2
- package/dist/environments.ee/source-control/source-control.service.ee.js +67 -39
- package/dist/environments.ee/source-control/source-control.service.ee.js.map +1 -1
- package/dist/errors/single-webhook-trigger.error.d.ts +4 -0
- package/dist/errors/single-webhook-trigger.error.js +11 -0
- package/dist/errors/single-webhook-trigger.error.js.map +1 -0
- package/dist/eventbus/event-message-classes/index.d.ts +2 -2
- package/dist/eventbus/event-message-classes/index.js +1 -0
- package/dist/eventbus/event-message-classes/index.js.map +1 -1
- package/dist/events/maps/relay.event-map.d.ts +6 -1
- package/dist/events/relays/log-streaming.event-relay.d.ts +1 -0
- package/dist/events/relays/log-streaming.event-relay.js +12 -0
- package/dist/events/relays/log-streaming.event-relay.js.map +1 -1
- package/dist/events/relays/telemetry.event-relay.js +14 -3
- package/dist/events/relays/telemetry.event-relay.js.map +1 -1
- package/dist/execution-lifecycle/execution-lifecycle-hooks.d.ts +2 -2
- package/dist/execution-lifecycle/execution-lifecycle-hooks.js +15 -3
- package/dist/execution-lifecycle/execution-lifecycle-hooks.js.map +1 -1
- package/dist/license.d.ts +6 -0
- package/dist/license.js +27 -0
- package/dist/license.js.map +1 -1
- package/dist/load-nodes-and-credentials.d.ts +2 -0
- package/dist/load-nodes-and-credentials.js +97 -86
- package/dist/load-nodes-and-credentials.js.map +1 -1
- package/dist/modules/breaking-changes/rules/index.d.ts +1 -1
- package/dist/modules/breaking-changes/rules/v2/index.d.ts +2 -1
- package/dist/modules/breaking-changes/rules/v2/index.js +2 -0
- package/dist/modules/breaking-changes/rules/v2/index.js.map +1 -1
- package/dist/modules/breaking-changes/rules/v2/pyodide-removed.rule.js +2 -1
- package/dist/modules/breaking-changes/rules/v2/pyodide-removed.rule.js.map +1 -1
- package/dist/modules/breaking-changes/rules/v2/settings-file-permissions.rule.d.ts +3 -3
- package/dist/modules/breaking-changes/rules/v2/settings-file-permissions.rule.js +11 -4
- package/dist/modules/breaking-changes/rules/v2/settings-file-permissions.rule.js.map +1 -1
- package/dist/modules/breaking-changes/rules/v2/start-node-removed.rule.d.ts +11 -0
- package/dist/modules/breaking-changes/rules/v2/start-node-removed.rule.js +63 -0
- package/dist/modules/breaking-changes/rules/v2/start-node-removed.rule.js.map +1 -0
- package/dist/modules/breaking-changes/rules/v2/task-runner-docker-image.rule.d.ts +3 -0
- package/dist/modules/breaking-changes/rules/v2/task-runner-docker-image.rule.js +15 -2
- package/dist/modules/breaking-changes/rules/v2/task-runner-docker-image.rule.js.map +1 -1
- package/dist/modules/breaking-changes/rules/v2/task-runners.rule.d.ts +3 -2
- package/dist/modules/breaking-changes/rules/v2/task-runners.rule.js +11 -2
- package/dist/modules/breaking-changes/rules/v2/task-runners.rule.js.map +1 -1
- package/dist/modules/chat-hub/chat-hub-agent.entity.d.ts +4 -3
- package/dist/modules/chat-hub/chat-hub-agent.entity.js +4 -0
- package/dist/modules/chat-hub/chat-hub-agent.entity.js.map +1 -1
- package/dist/modules/chat-hub/chat-hub-agent.service.d.ts +5 -21
- package/dist/modules/chat-hub/chat-hub-agent.service.js +17 -11
- package/dist/modules/chat-hub/chat-hub-agent.service.js.map +1 -1
- package/dist/modules/chat-hub/chat-hub-credentials.service.js +4 -2
- package/dist/modules/chat-hub/chat-hub-credentials.service.js.map +1 -1
- package/dist/modules/chat-hub/chat-hub-message.entity.js +1 -1
- package/dist/modules/chat-hub/chat-hub-message.entity.js.map +1 -1
- package/dist/modules/chat-hub/chat-hub-session.entity.d.ts +2 -0
- package/dist/modules/chat-hub/chat-hub-session.entity.js +6 -1
- package/dist/modules/chat-hub/chat-hub-session.entity.js.map +1 -1
- package/dist/modules/chat-hub/chat-hub-workflow.service.d.ts +17 -4
- package/dist/modules/chat-hub/chat-hub-workflow.service.js +161 -31
- package/dist/modules/chat-hub/chat-hub-workflow.service.js.map +1 -1
- package/dist/modules/chat-hub/chat-hub.attachment.service.d.ts +2 -0
- package/dist/modules/chat-hub/chat-hub.attachment.service.js +12 -0
- package/dist/modules/chat-hub/chat-hub.attachment.service.js.map +1 -1
- package/dist/modules/chat-hub/chat-hub.constants.d.ts +7 -3
- package/dist/modules/chat-hub/chat-hub.constants.js +468 -10
- package/dist/modules/chat-hub/chat-hub.constants.js.map +1 -1
- package/dist/modules/chat-hub/chat-hub.controller.d.ts +3 -1
- package/dist/modules/chat-hub/chat-hub.controller.js +7 -14
- package/dist/modules/chat-hub/chat-hub.controller.js.map +1 -1
- package/dist/modules/chat-hub/chat-hub.models.service.d.ts +35 -0
- package/dist/modules/chat-hub/chat-hub.models.service.js +640 -0
- package/dist/modules/chat-hub/chat-hub.models.service.js.map +1 -0
- package/dist/modules/chat-hub/chat-hub.module.js +0 -8
- package/dist/modules/chat-hub/chat-hub.module.js.map +1 -1
- package/dist/modules/chat-hub/chat-hub.service.d.ts +13 -26
- package/dist/modules/chat-hub/chat-hub.service.js +162 -760
- package/dist/modules/chat-hub/chat-hub.service.js.map +1 -1
- package/dist/modules/chat-hub/chat-hub.types.d.ts +27 -6
- package/dist/modules/chat-hub/chat-hub.types.js +11 -3
- package/dist/modules/chat-hub/chat-hub.types.js.map +1 -1
- package/dist/modules/chat-hub/chat-session.repository.js +17 -2
- package/dist/modules/chat-hub/chat-session.repository.js.map +1 -1
- package/dist/modules/chat-hub/context-limits.js +62 -5
- package/dist/modules/chat-hub/context-limits.js.map +1 -1
- package/dist/modules/data-table/data-table-column.repository.d.ts +15 -0
- package/dist/modules/data-table/data-table-column.repository.js +33 -17
- package/dist/modules/data-table/data-table-column.repository.js.map +1 -1
- package/dist/modules/data-table/data-table-ddl.service.d.ts +1 -0
- package/dist/modules/data-table/data-table-ddl.service.js +5 -0
- package/dist/modules/data-table/data-table-ddl.service.js.map +1 -1
- package/dist/modules/data-table/data-table-rows.repository.js +1 -1
- package/dist/modules/data-table/data-table-rows.repository.js.map +1 -1
- package/dist/modules/data-table/data-table.controller.d.ts +16 -1
- package/dist/modules/data-table/data-table.controller.js +39 -35
- package/dist/modules/data-table/data-table.controller.js.map +1 -1
- package/dist/modules/data-table/data-table.repository.d.ts +4 -1
- package/dist/modules/data-table/data-table.repository.js +12 -2
- package/dist/modules/data-table/data-table.repository.js.map +1 -1
- package/dist/modules/data-table/data-table.service.d.ts +13 -1
- package/dist/modules/data-table/data-table.service.js +13 -1
- package/dist/modules/data-table/data-table.service.js.map +1 -1
- package/dist/modules/data-table/errors/data-table-column-not-found.error.d.ts +2 -2
- package/dist/modules/data-table/errors/data-table-column-not-found.error.js +3 -5
- package/dist/modules/data-table/errors/data-table-column-not-found.error.js.map +1 -1
- package/dist/modules/data-table/errors/data-table-not-found.error.d.ts +2 -2
- package/dist/modules/data-table/errors/data-table-not-found.error.js +3 -5
- package/dist/modules/data-table/errors/data-table-not-found.error.js.map +1 -1
- package/dist/modules/data-table/utils/sql-utils.d.ts +1 -0
- package/dist/modules/data-table/utils/sql-utils.js +10 -0
- package/dist/modules/data-table/utils/sql-utils.js.map +1 -1
- package/dist/modules/dynamic-credentials.ee/context-establishment-hooks/bearer-token-extractor.d.ts +9 -0
- package/dist/modules/dynamic-credentials.ee/context-establishment-hooks/bearer-token-extractor.js +42 -0
- package/dist/modules/dynamic-credentials.ee/context-establishment-hooks/bearer-token-extractor.js.map +1 -0
- package/dist/modules/dynamic-credentials.ee/context-establishment-hooks/http-header-extractor.d.ts +9 -0
- package/dist/modules/dynamic-credentials.ee/context-establishment-hooks/http-header-extractor.js +141 -0
- package/dist/modules/dynamic-credentials.ee/context-establishment-hooks/http-header-extractor.js.map +1 -0
- package/dist/modules/dynamic-credentials.ee/context-establishment-hooks/index.d.ts +2 -0
- package/dist/modules/dynamic-credentials.ee/context-establishment-hooks/index.js +5 -0
- package/dist/modules/dynamic-credentials.ee/context-establishment-hooks/index.js.map +1 -0
- package/dist/modules/dynamic-credentials.ee/credential-resolvers/identifiers/identifier-interface.d.ts +7 -0
- package/dist/modules/dynamic-credentials.ee/credential-resolvers/identifiers/identifier-interface.js +7 -0
- package/dist/modules/dynamic-credentials.ee/credential-resolvers/identifiers/identifier-interface.js.map +1 -0
- package/dist/modules/dynamic-credentials.ee/credential-resolvers/identifiers/oauth2-introspection-identifier.d.ts +78 -0
- package/dist/modules/dynamic-credentials.ee/credential-resolvers/identifiers/oauth2-introspection-identifier.js +223 -0
- package/dist/modules/dynamic-credentials.ee/credential-resolvers/identifiers/oauth2-introspection-identifier.js.map +1 -0
- package/dist/modules/dynamic-credentials.ee/credential-resolvers/identifiers/oauth2-userinfo-identifier.d.ts +37 -0
- package/dist/modules/dynamic-credentials.ee/credential-resolvers/identifiers/oauth2-userinfo-identifier.js +160 -0
- package/dist/modules/dynamic-credentials.ee/credential-resolvers/identifiers/oauth2-userinfo-identifier.js.map +1 -0
- package/dist/modules/dynamic-credentials.ee/credential-resolvers/identifiers/oauth2-utils.d.ts +13 -0
- package/dist/modules/dynamic-credentials.ee/credential-resolvers/identifiers/oauth2-utils.js +17 -0
- package/dist/modules/dynamic-credentials.ee/credential-resolvers/identifiers/oauth2-utils.js.map +1 -0
- package/dist/modules/dynamic-credentials.ee/credential-resolvers/index.d.ts +2 -0
- package/dist/modules/dynamic-credentials.ee/credential-resolvers/index.js +5 -0
- package/dist/modules/dynamic-credentials.ee/credential-resolvers/index.js.map +1 -0
- package/dist/modules/dynamic-credentials.ee/credential-resolvers/oauth-credential-resolver.d.ts +103 -0
- package/dist/modules/dynamic-credentials.ee/credential-resolvers/oauth-credential-resolver.js +174 -0
- package/dist/modules/dynamic-credentials.ee/credential-resolvers/oauth-credential-resolver.js.map +1 -0
- package/dist/modules/dynamic-credentials.ee/credential-resolvers/storage/dynamic-credential-entry-storage.d.ts +9 -0
- package/dist/modules/dynamic-credentials.ee/credential-resolvers/storage/dynamic-credential-entry-storage.js +56 -0
- package/dist/modules/dynamic-credentials.ee/credential-resolvers/storage/dynamic-credential-entry-storage.js.map +1 -0
- package/dist/modules/dynamic-credentials.ee/credential-resolvers/storage/storage-interface.d.ts +5 -0
- package/dist/modules/dynamic-credentials.ee/credential-resolvers/storage/storage-interface.js +3 -0
- package/dist/modules/dynamic-credentials.ee/credential-resolvers/storage/storage-interface.js.map +1 -0
- package/dist/modules/dynamic-credentials.ee/credential-resolvers/stub-credential-resolver.d.ts +28 -0
- package/dist/modules/dynamic-credentials.ee/credential-resolvers/stub-credential-resolver.js +86 -0
- package/dist/modules/dynamic-credentials.ee/credential-resolvers/stub-credential-resolver.js.map +1 -0
- package/dist/modules/dynamic-credentials.ee/credential-resolvers.controller.d.ts +16 -0
- package/dist/modules/dynamic-credentials.ee/credential-resolvers.controller.js +172 -0
- package/dist/modules/dynamic-credentials.ee/credential-resolvers.controller.js.map +1 -0
- package/dist/modules/dynamic-credentials.ee/database/entities/credential-resolver.d.ts +8 -0
- package/dist/modules/dynamic-credentials.ee/database/entities/credential-resolver.js +33 -0
- package/dist/modules/dynamic-credentials.ee/database/entities/credential-resolver.js.map +1 -0
- package/dist/modules/dynamic-credentials.ee/database/entities/dynamic-credential-entry.d.ts +11 -0
- package/dist/modules/dynamic-credentials.ee/database/entities/dynamic-credential-entry.js +60 -0
- package/dist/modules/dynamic-credentials.ee/database/entities/dynamic-credential-entry.js.map +1 -0
- package/dist/modules/dynamic-credentials.ee/database/repositories/credential-resolver.repository.d.ts +5 -0
- package/dist/modules/dynamic-credentials.ee/database/repositories/credential-resolver.repository.js +26 -0
- package/dist/modules/dynamic-credentials.ee/database/repositories/credential-resolver.repository.js.map +1 -0
- package/dist/modules/dynamic-credentials.ee/database/repositories/dynamic-credential-entry.repository.d.ts +5 -0
- package/dist/modules/dynamic-credentials.ee/database/repositories/dynamic-credential-entry.repository.js +26 -0
- package/dist/modules/dynamic-credentials.ee/database/repositories/dynamic-credential-entry.repository.js.map +1 -0
- package/dist/modules/dynamic-credentials.ee/dynamic-credentials.controller.d.ts +9 -0
- package/dist/modules/dynamic-credentials.ee/dynamic-credentials.controller.js +61 -0
- package/dist/modules/dynamic-credentials.ee/dynamic-credentials.controller.js.map +1 -0
- package/dist/modules/dynamic-credentials.ee/dynamic-credentials.module.d.ts +6 -0
- package/dist/modules/dynamic-credentials.ee/dynamic-credentials.module.js +91 -0
- package/dist/modules/dynamic-credentials.ee/dynamic-credentials.module.js.map +1 -0
- package/dist/modules/dynamic-credentials.ee/errors/credential-resolution.error.d.ts +6 -0
- package/dist/modules/dynamic-credentials.ee/errors/credential-resolution.error.js +12 -0
- package/dist/modules/dynamic-credentials.ee/errors/credential-resolution.error.js.map +1 -0
- package/dist/modules/dynamic-credentials.ee/errors/credential-resolver-not-found.error.d.ts +4 -0
- package/dist/modules/dynamic-credentials.ee/errors/credential-resolver-not-found.error.js +11 -0
- package/dist/modules/dynamic-credentials.ee/errors/credential-resolver-not-found.error.js.map +1 -0
- package/dist/modules/dynamic-credentials.ee/errors/credential-storage.error.d.ts +6 -0
- package/dist/modules/dynamic-credentials.ee/errors/credential-storage.error.js +12 -0
- package/dist/modules/dynamic-credentials.ee/errors/credential-storage.error.js.map +1 -0
- package/dist/modules/dynamic-credentials.ee/services/credential-resolver-registry.service.d.ts +11 -0
- package/dist/modules/dynamic-credentials.ee/services/credential-resolver-registry.service.js +64 -0
- package/dist/modules/dynamic-credentials.ee/services/credential-resolver-registry.service.js.map +1 -0
- package/dist/modules/dynamic-credentials.ee/services/credential-resolver-workflow.service.d.ts +22 -0
- package/dist/modules/dynamic-credentials.ee/services/credential-resolver-workflow.service.js +150 -0
- package/dist/modules/dynamic-credentials.ee/services/credential-resolver-workflow.service.js.map +1 -0
- package/dist/modules/dynamic-credentials.ee/services/credential-resolver.service.d.ts +33 -0
- package/dist/modules/dynamic-credentials.ee/services/credential-resolver.service.js +118 -0
- package/dist/modules/dynamic-credentials.ee/services/credential-resolver.service.js.map +1 -0
- package/dist/modules/dynamic-credentials.ee/services/dynamic-credential-storage.service.d.ts +18 -0
- package/dist/modules/dynamic-credentials.ee/services/dynamic-credential-storage.service.js +94 -0
- package/dist/modules/dynamic-credentials.ee/services/dynamic-credential-storage.service.js.map +1 -0
- package/dist/modules/dynamic-credentials.ee/services/dynamic-credential.service.d.ts +20 -0
- package/dist/modules/dynamic-credentials.ee/services/dynamic-credential.service.js +146 -0
- package/dist/modules/dynamic-credentials.ee/services/dynamic-credential.service.js.map +1 -0
- package/dist/modules/dynamic-credentials.ee/services/index.d.ts +5 -0
- package/dist/modules/dynamic-credentials.ee/services/index.js +22 -0
- package/dist/modules/dynamic-credentials.ee/services/index.js.map +1 -0
- package/dist/modules/dynamic-credentials.ee/services/shared-fields.d.ts +2 -0
- package/dist/modules/dynamic-credentials.ee/services/shared-fields.js +13 -0
- package/dist/modules/dynamic-credentials.ee/services/shared-fields.js.map +1 -0
- package/dist/modules/dynamic-credentials.ee/workflow-status.controller.d.ts +8 -0
- package/dist/modules/dynamic-credentials.ee/workflow-status.controller.js +62 -0
- package/dist/modules/dynamic-credentials.ee/workflow-status.controller.js.map +1 -0
- package/dist/modules/external-secrets.ee/external-secrets-manager.ee.js +40 -24
- package/dist/modules/external-secrets.ee/external-secrets-manager.ee.js.map +1 -1
- package/dist/modules/insights/database/repositories/insights-by-period.repository.d.ts +2 -2
- package/dist/modules/insights/insights-collection.service.d.ts +2 -0
- package/dist/modules/insights/insights-collection.service.js +30 -6
- package/dist/modules/insights/insights-collection.service.js.map +1 -1
- package/dist/modules/insights/insights.service.d.ts +1 -1
- package/dist/modules/workflow-index/workflow-index.service.js +17 -10
- package/dist/modules/workflow-index/workflow-index.service.js.map +1 -1
- package/dist/oauth/oauth.service.d.ts +52 -0
- package/dist/oauth/oauth.service.js +416 -0
- package/dist/oauth/oauth.service.js.map +1 -0
- package/dist/oauth/types.d.ts +28 -0
- package/dist/oauth/types.js +16 -0
- package/dist/oauth/types.js.map +1 -0
- package/dist/public-api/v1/handlers/credentials/credentials.service.js +6 -8
- package/dist/public-api/v1/handlers/credentials/credentials.service.js.map +1 -1
- package/dist/public-api/v1/handlers/workflows/workflows.handler.js +2 -1
- package/dist/public-api/v1/handlers/workflows/workflows.handler.js.map +1 -1
- package/dist/public-api/v1/openapi.yml +4 -0
- package/dist/requests.d.ts +1 -0
- package/dist/scaling/job-processor.js +8 -2
- package/dist/scaling/job-processor.js.map +1 -1
- package/dist/scaling/worker-status.service.ee.js +20 -2
- package/dist/scaling/worker-status.service.ee.js.map +1 -1
- package/dist/server.js +5 -3
- package/dist/server.js.map +1 -1
- package/dist/services/ai-workflow-builder.service.d.ts +1 -0
- package/dist/services/ai-workflow-builder.service.js +5 -3
- package/dist/services/ai-workflow-builder.service.js.map +1 -1
- package/dist/services/ai.service.js +3 -0
- package/dist/services/ai.service.js.map +1 -1
- package/dist/services/cache/cache.service.d.ts +1 -0
- package/dist/services/cache/cache.service.js +4 -0
- package/dist/services/cache/cache.service.js.map +1 -1
- package/dist/services/frontend.service.d.ts +6 -4
- package/dist/services/frontend.service.js +14 -9
- package/dist/services/frontend.service.js.map +1 -1
- package/dist/services/ownership.service.d.ts +13 -3
- package/dist/services/ownership.service.js +59 -4
- package/dist/services/ownership.service.js.map +1 -1
- package/dist/services/project.service.ee.js +1 -1
- package/dist/services/project.service.ee.js.map +1 -1
- package/dist/services/public-api-key.service.d.ts +1 -0
- package/dist/services/public-api-key.service.js +8 -0
- package/dist/services/public-api-key.service.js.map +1 -1
- package/dist/services/user.service.d.ts +4 -3
- package/dist/services/user.service.js +50 -4
- package/dist/services/user.service.js.map +1 -1
- package/dist/telemetry/index.js +1 -0
- package/dist/telemetry/index.js.map +1 -1
- package/dist/webhooks/test-webhook-registrations.service.d.ts +5 -3
- package/dist/webhooks/test-webhook-registrations.service.js +25 -6
- package/dist/webhooks/test-webhook-registrations.service.js.map +1 -1
- package/dist/webhooks/test-webhooks.d.ts +1 -0
- package/dist/webhooks/test-webhooks.js +17 -10
- package/dist/webhooks/test-webhooks.js.map +1 -1
- package/dist/webhooks/waiting-forms.js +2 -0
- package/dist/webhooks/waiting-forms.js.map +1 -1
- package/dist/webhooks/webhook-helpers.js +12 -3
- package/dist/webhooks/webhook-helpers.js.map +1 -1
- package/dist/workflow-execute-additional-data.d.ts +2 -1
- package/dist/workflow-execute-additional-data.js +5 -3
- package/dist/workflow-execute-additional-data.js.map +1 -1
- package/dist/workflow-runner.js +1 -0
- package/dist/workflow-runner.js.map +1 -1
- package/dist/workflows/workflow-execution.service.js +3 -0
- package/dist/workflows/workflow-execution.service.js.map +1 -1
- package/dist/workflows/workflow-history/workflow-history.service.d.ts +1 -1
- package/dist/workflows/workflow-history/workflow-history.service.js +2 -1
- package/dist/workflows/workflow-history/workflow-history.service.js.map +1 -1
- package/dist/workflows/workflow.request.d.ts +2 -0
- package/dist/workflows/workflow.service.d.ts +2 -0
- package/dist/workflows/workflow.service.js +4 -2
- package/dist/workflows/workflow.service.js.map +1 -1
- package/dist/workflows/workflows.controller.js +15 -17
- package/dist/workflows/workflows.controller.js.map +1 -1
- package/package.json +18 -18
- package/templates/form-trigger-completion.handlebars +1 -4
- package/templates/form-trigger.handlebars +1 -2
- package/dist/controllers/oauth/abstract-oauth.controller.d.ts +0 -47
- package/dist/controllers/oauth/abstract-oauth.controller.js +0 -185
- package/dist/controllers/oauth/abstract-oauth.controller.js.map +0 -1
|
@@ -0,0 +1,150 @@
|
|
|
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.CredentialResolverWorkflowService = void 0;
|
|
13
|
+
const db_1 = require("@n8n/db");
|
|
14
|
+
const credential_resolver_registry_service_1 = require("./credential-resolver-registry.service");
|
|
15
|
+
const credential_resolver_repository_1 = require("../database/repositories/credential-resolver.repository");
|
|
16
|
+
const n8n_core_1 = require("n8n-core");
|
|
17
|
+
const n8n_workflow_1 = require("n8n-workflow");
|
|
18
|
+
const di_1 = require("@n8n/di");
|
|
19
|
+
function isCredentialStatus(obj) {
|
|
20
|
+
if (typeof obj !== 'object' || obj === null) {
|
|
21
|
+
return false;
|
|
22
|
+
}
|
|
23
|
+
return ('credentialId' in obj &&
|
|
24
|
+
typeof obj.credentialId === 'string' &&
|
|
25
|
+
'resolverId' in obj &&
|
|
26
|
+
typeof obj.resolverId === 'string' &&
|
|
27
|
+
'credentialType' in obj &&
|
|
28
|
+
typeof obj.credentialType === 'string' &&
|
|
29
|
+
'status' in obj &&
|
|
30
|
+
(obj.status === 'missing' || obj.status === 'configured'));
|
|
31
|
+
}
|
|
32
|
+
let CredentialResolverWorkflowService = class CredentialResolverWorkflowService {
|
|
33
|
+
constructor(workflowRepository, credentialRepository, resolverRegistry, resolverRepository, cipher) {
|
|
34
|
+
this.workflowRepository = workflowRepository;
|
|
35
|
+
this.credentialRepository = credentialRepository;
|
|
36
|
+
this.resolverRegistry = resolverRegistry;
|
|
37
|
+
this.resolverRepository = resolverRepository;
|
|
38
|
+
this.cipher = cipher;
|
|
39
|
+
}
|
|
40
|
+
async getResolver(resolverId) {
|
|
41
|
+
const resolver = await this.resolverRepository.findOneBy({ id: resolverId });
|
|
42
|
+
if (!resolver) {
|
|
43
|
+
throw new Error('Credential resolver not found');
|
|
44
|
+
}
|
|
45
|
+
const resolverInstance = this.resolverRegistry.getResolverByTypename(resolver.type);
|
|
46
|
+
if (!resolverInstance) {
|
|
47
|
+
throw new Error('Credential resolver implementation not found');
|
|
48
|
+
}
|
|
49
|
+
try {
|
|
50
|
+
const decryptedConfig = this.cipher.decrypt(resolver.config);
|
|
51
|
+
const resolverConfig = (0, n8n_workflow_1.jsonParse)(decryptedConfig);
|
|
52
|
+
return {
|
|
53
|
+
resolverInstance,
|
|
54
|
+
resolverConfig,
|
|
55
|
+
};
|
|
56
|
+
}
|
|
57
|
+
catch (error) {
|
|
58
|
+
throw new Error('Failed to decrypt or parse resolver configuration');
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
async getWorkflowStatus(workflowId, identityToken) {
|
|
62
|
+
const workflow = await this.workflowRepository.get({
|
|
63
|
+
id: workflowId,
|
|
64
|
+
});
|
|
65
|
+
if (!workflow) {
|
|
66
|
+
throw new Error('Workflow not found');
|
|
67
|
+
}
|
|
68
|
+
const resolverId = workflow.settings?.credentialResolverId;
|
|
69
|
+
let workflowResolverInstance = null;
|
|
70
|
+
let workflowResolverConfig = null;
|
|
71
|
+
if (resolverId) {
|
|
72
|
+
const { resolverInstance, resolverConfig } = await this.getResolver(resolverId);
|
|
73
|
+
workflowResolverInstance = resolverInstance;
|
|
74
|
+
workflowResolverConfig = resolverConfig;
|
|
75
|
+
}
|
|
76
|
+
const credentialsToCheck = [];
|
|
77
|
+
for (const node of workflow.nodes ?? []) {
|
|
78
|
+
for (const credentialName in node.credentials ?? {}) {
|
|
79
|
+
const credentialData = node.credentials?.[credentialName];
|
|
80
|
+
if (credentialData?.id) {
|
|
81
|
+
credentialsToCheck.push(credentialData.id);
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
if (credentialsToCheck.length === 0) {
|
|
86
|
+
return [];
|
|
87
|
+
}
|
|
88
|
+
const credentials = await this.credentialRepository.find({
|
|
89
|
+
where: {
|
|
90
|
+
id: (0, db_1.In)(credentialsToCheck),
|
|
91
|
+
isResolvable: true,
|
|
92
|
+
},
|
|
93
|
+
});
|
|
94
|
+
const credentialStatusPromises = credentials.map(async (credential) => {
|
|
95
|
+
return await this.checkCredentialStatus(credential, {
|
|
96
|
+
workflowResolverInstance,
|
|
97
|
+
workflowResolverConfig,
|
|
98
|
+
resolverId,
|
|
99
|
+
identityToken,
|
|
100
|
+
});
|
|
101
|
+
});
|
|
102
|
+
return (await Promise.all(credentialStatusPromises)).filter(isCredentialStatus);
|
|
103
|
+
}
|
|
104
|
+
async checkCredentialStatus(credential, options) {
|
|
105
|
+
let resolverInstance = options.workflowResolverInstance;
|
|
106
|
+
let resolverConfig = options.workflowResolverConfig;
|
|
107
|
+
const credentialResolverId = credential.resolverId ?? options.resolverId;
|
|
108
|
+
if (credentialResolverId) {
|
|
109
|
+
if (credentialResolverId !== options.resolverId) {
|
|
110
|
+
const { resolverInstance: credentialResolverInstance, resolverConfig: credentialResolverConfig, } = await this.getResolver(credentialResolverId);
|
|
111
|
+
resolverInstance = credentialResolverInstance;
|
|
112
|
+
resolverConfig = credentialResolverConfig;
|
|
113
|
+
}
|
|
114
|
+
if (resolverConfig && resolverInstance) {
|
|
115
|
+
try {
|
|
116
|
+
await resolverInstance.getSecret(credential.id, { identity: options.identityToken, version: 1 }, {
|
|
117
|
+
configuration: resolverConfig,
|
|
118
|
+
resolverName: resolverInstance.metadata.name,
|
|
119
|
+
resolverId: credentialResolverId,
|
|
120
|
+
});
|
|
121
|
+
return {
|
|
122
|
+
credentialId: credential.id,
|
|
123
|
+
resolverId: credentialResolverId,
|
|
124
|
+
status: 'configured',
|
|
125
|
+
credentialType: credential.type,
|
|
126
|
+
};
|
|
127
|
+
}
|
|
128
|
+
catch (error) {
|
|
129
|
+
return {
|
|
130
|
+
credentialId: credential.id,
|
|
131
|
+
resolverId: credentialResolverId,
|
|
132
|
+
status: 'missing',
|
|
133
|
+
credentialType: credential.type,
|
|
134
|
+
};
|
|
135
|
+
}
|
|
136
|
+
}
|
|
137
|
+
}
|
|
138
|
+
return null;
|
|
139
|
+
}
|
|
140
|
+
};
|
|
141
|
+
exports.CredentialResolverWorkflowService = CredentialResolverWorkflowService;
|
|
142
|
+
exports.CredentialResolverWorkflowService = CredentialResolverWorkflowService = __decorate([
|
|
143
|
+
(0, di_1.Service)(),
|
|
144
|
+
__metadata("design:paramtypes", [db_1.WorkflowRepository,
|
|
145
|
+
db_1.CredentialsRepository,
|
|
146
|
+
credential_resolver_registry_service_1.DynamicCredentialResolverRegistry,
|
|
147
|
+
credential_resolver_repository_1.DynamicCredentialResolverRepository,
|
|
148
|
+
n8n_core_1.Cipher])
|
|
149
|
+
], CredentialResolverWorkflowService);
|
|
150
|
+
//# sourceMappingURL=credential-resolver-workflow.service.js.map
|
package/dist/modules/dynamic-credentials.ee/services/credential-resolver-workflow.service.js.map
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"credential-resolver-workflow.service.js","sourceRoot":"","sources":["../../../../src/modules/dynamic-credentials.ee/services/credential-resolver-workflow.service.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
import { Logger } from '@n8n/backend-common';
|
|
2
|
+
import { CredentialResolverConfiguration, ICredentialResolver } from '@n8n/decorators';
|
|
3
|
+
import { Cipher } from 'n8n-core';
|
|
4
|
+
import { DynamicCredentialResolverRegistry } from './credential-resolver-registry.service';
|
|
5
|
+
import { DynamicCredentialResolver } from '../database/entities/credential-resolver';
|
|
6
|
+
import { DynamicCredentialResolverRepository } from '../database/repositories/credential-resolver.repository';
|
|
7
|
+
export interface CreateResolverParams {
|
|
8
|
+
name: string;
|
|
9
|
+
type: string;
|
|
10
|
+
config: CredentialResolverConfiguration;
|
|
11
|
+
}
|
|
12
|
+
export interface UpdateResolverParams {
|
|
13
|
+
name?: string;
|
|
14
|
+
type?: string;
|
|
15
|
+
config?: CredentialResolverConfiguration;
|
|
16
|
+
}
|
|
17
|
+
export declare class DynamicCredentialResolverService {
|
|
18
|
+
private readonly logger;
|
|
19
|
+
private readonly repository;
|
|
20
|
+
private readonly registry;
|
|
21
|
+
private readonly cipher;
|
|
22
|
+
constructor(logger: Logger, repository: DynamicCredentialResolverRepository, registry: DynamicCredentialResolverRegistry, cipher: Cipher);
|
|
23
|
+
create(params: CreateResolverParams): Promise<DynamicCredentialResolver>;
|
|
24
|
+
findAll(): Promise<DynamicCredentialResolver[]>;
|
|
25
|
+
getAvailableTypes(): ICredentialResolver[];
|
|
26
|
+
findById(id: string): Promise<DynamicCredentialResolver>;
|
|
27
|
+
update(id: string, params: UpdateResolverParams): Promise<DynamicCredentialResolver>;
|
|
28
|
+
delete(id: string): Promise<void>;
|
|
29
|
+
private validateConfig;
|
|
30
|
+
private encryptConfig;
|
|
31
|
+
private decryptConfig;
|
|
32
|
+
private withDecryptedConfig;
|
|
33
|
+
}
|
|
@@ -0,0 +1,118 @@
|
|
|
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.DynamicCredentialResolverService = 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
|
+
const n8n_core_1 = require("n8n-core");
|
|
17
|
+
const n8n_workflow_1 = require("n8n-workflow");
|
|
18
|
+
const credential_resolver_registry_service_1 = require("./credential-resolver-registry.service");
|
|
19
|
+
const credential_resolver_repository_1 = require("../database/repositories/credential-resolver.repository");
|
|
20
|
+
const credential_resolver_not_found_error_1 = require("../errors/credential-resolver-not-found.error");
|
|
21
|
+
let DynamicCredentialResolverService = class DynamicCredentialResolverService {
|
|
22
|
+
constructor(logger, repository, registry, cipher) {
|
|
23
|
+
this.logger = logger;
|
|
24
|
+
this.repository = repository;
|
|
25
|
+
this.registry = registry;
|
|
26
|
+
this.cipher = cipher;
|
|
27
|
+
this.logger = this.logger.scoped('dynamic-credentials');
|
|
28
|
+
}
|
|
29
|
+
async create(params) {
|
|
30
|
+
await this.validateConfig(params.type, params.config);
|
|
31
|
+
const encryptedConfig = this.encryptConfig(params.config);
|
|
32
|
+
const resolver = this.repository.create({
|
|
33
|
+
name: params.name,
|
|
34
|
+
type: params.type,
|
|
35
|
+
config: encryptedConfig,
|
|
36
|
+
});
|
|
37
|
+
const saved = await this.repository.save(resolver);
|
|
38
|
+
this.logger.debug(`Created credential resolver "${saved.name}" (${saved.id})`);
|
|
39
|
+
return this.withDecryptedConfig(saved);
|
|
40
|
+
}
|
|
41
|
+
async findAll() {
|
|
42
|
+
const resolvers = await this.repository.find();
|
|
43
|
+
return resolvers.map((resolver) => this.withDecryptedConfig(resolver));
|
|
44
|
+
}
|
|
45
|
+
getAvailableTypes() {
|
|
46
|
+
return this.registry.getAllResolvers();
|
|
47
|
+
}
|
|
48
|
+
async findById(id) {
|
|
49
|
+
const resolver = await this.repository.findOneBy({ id });
|
|
50
|
+
if (!resolver) {
|
|
51
|
+
throw new credential_resolver_not_found_error_1.DynamicCredentialResolverNotFoundError(id);
|
|
52
|
+
}
|
|
53
|
+
return this.withDecryptedConfig(resolver);
|
|
54
|
+
}
|
|
55
|
+
async update(id, params) {
|
|
56
|
+
const existing = await this.repository.findOneBy({ id });
|
|
57
|
+
if (!existing) {
|
|
58
|
+
throw new credential_resolver_not_found_error_1.DynamicCredentialResolverNotFoundError(id);
|
|
59
|
+
}
|
|
60
|
+
if (params.type !== undefined) {
|
|
61
|
+
existing.type = params.type;
|
|
62
|
+
if (params.config === undefined) {
|
|
63
|
+
const existingConfig = this.decryptConfig(existing.config);
|
|
64
|
+
await this.validateConfig(existing.type, existingConfig);
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
if (params.config !== undefined) {
|
|
68
|
+
await this.validateConfig(existing.type, params.config);
|
|
69
|
+
existing.config = this.encryptConfig(params.config);
|
|
70
|
+
}
|
|
71
|
+
if (params.name !== undefined) {
|
|
72
|
+
existing.name = params.name;
|
|
73
|
+
}
|
|
74
|
+
const saved = await this.repository.save(existing);
|
|
75
|
+
this.logger.debug(`Updated credential resolver "${saved.name}" (${saved.id})`);
|
|
76
|
+
return this.withDecryptedConfig(saved);
|
|
77
|
+
}
|
|
78
|
+
async delete(id) {
|
|
79
|
+
const existing = await this.repository.findOneBy({ id });
|
|
80
|
+
if (!existing) {
|
|
81
|
+
throw new credential_resolver_not_found_error_1.DynamicCredentialResolverNotFoundError(id);
|
|
82
|
+
}
|
|
83
|
+
await this.repository.remove(existing);
|
|
84
|
+
this.logger.debug(`Deleted credential resolver "${existing.name}" (${id})`);
|
|
85
|
+
}
|
|
86
|
+
async validateConfig(type, config) {
|
|
87
|
+
const resolverImplementation = this.registry.getResolverByTypename(type);
|
|
88
|
+
if (!resolverImplementation) {
|
|
89
|
+
throw new decorators_1.CredentialResolverValidationError(`Unknown resolver type: ${type}`);
|
|
90
|
+
}
|
|
91
|
+
await resolverImplementation.validateOptions(config);
|
|
92
|
+
}
|
|
93
|
+
encryptConfig(config) {
|
|
94
|
+
return this.cipher.encrypt(config);
|
|
95
|
+
}
|
|
96
|
+
decryptConfig(encryptedConfig) {
|
|
97
|
+
const decryptedData = this.cipher.decrypt(encryptedConfig);
|
|
98
|
+
try {
|
|
99
|
+
return (0, n8n_workflow_1.jsonParse)(decryptedData);
|
|
100
|
+
}
|
|
101
|
+
catch {
|
|
102
|
+
throw new n8n_workflow_1.UnexpectedError('Credential resolver config could not be decrypted. The likely reason is that a different "encryptionKey" was used to encrypt the data.');
|
|
103
|
+
}
|
|
104
|
+
}
|
|
105
|
+
withDecryptedConfig(resolver) {
|
|
106
|
+
resolver.decryptedConfig = this.decryptConfig(resolver.config);
|
|
107
|
+
return resolver;
|
|
108
|
+
}
|
|
109
|
+
};
|
|
110
|
+
exports.DynamicCredentialResolverService = DynamicCredentialResolverService;
|
|
111
|
+
exports.DynamicCredentialResolverService = DynamicCredentialResolverService = __decorate([
|
|
112
|
+
(0, di_1.Service)(),
|
|
113
|
+
__metadata("design:paramtypes", [backend_common_1.Logger,
|
|
114
|
+
credential_resolver_repository_1.DynamicCredentialResolverRepository,
|
|
115
|
+
credential_resolver_registry_service_1.DynamicCredentialResolverRegistry,
|
|
116
|
+
n8n_core_1.Cipher])
|
|
117
|
+
], DynamicCredentialResolverService);
|
|
118
|
+
//# sourceMappingURL=credential-resolver.service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"credential-resolver.service.js","sourceRoot":"","sources":["../../../../src/modules/dynamic-credentials.ee/services/credential-resolver.service.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import type { CredentialStoreMetadata, IDynamicCredentialStorageProvider } from '../../../credentials/dynamic-credential-storage.interface';
|
|
2
|
+
import { type ICredentialContext, type ICredentialDataDecryptedObject, type IWorkflowSettings } from 'n8n-workflow';
|
|
3
|
+
import { DynamicCredentialResolverRegistry } from './credential-resolver-registry.service';
|
|
4
|
+
import { DynamicCredentialResolverRepository } from '../database/repositories/credential-resolver.repository';
|
|
5
|
+
import { Cipher } from 'n8n-core';
|
|
6
|
+
import { LoadNodesAndCredentials } from '../../../load-nodes-and-credentials';
|
|
7
|
+
import { Logger } from '@n8n/backend-common';
|
|
8
|
+
export declare class DynamicCredentialStorageService implements IDynamicCredentialStorageProvider {
|
|
9
|
+
private readonly resolverRegistry;
|
|
10
|
+
private readonly resolverRepository;
|
|
11
|
+
private readonly loadNodesAndCredentials;
|
|
12
|
+
private readonly cipher;
|
|
13
|
+
private readonly logger;
|
|
14
|
+
constructor(resolverRegistry: DynamicCredentialResolverRegistry, resolverRepository: DynamicCredentialResolverRepository, loadNodesAndCredentials: LoadNodesAndCredentials, cipher: Cipher, logger: Logger);
|
|
15
|
+
storeIfNeeded(credentialStoreMetadata: CredentialStoreMetadata, dynamicData: ICredentialDataDecryptedObject, credentialContext: ICredentialContext, staticData?: ICredentialDataDecryptedObject, workflowSettings?: IWorkflowSettings): Promise<void>;
|
|
16
|
+
private handleNoResolver;
|
|
17
|
+
private handleMissingResolver;
|
|
18
|
+
}
|
|
@@ -0,0 +1,94 @@
|
|
|
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.DynamicCredentialStorageService = void 0;
|
|
13
|
+
const n8n_workflow_1 = require("n8n-workflow");
|
|
14
|
+
const credential_resolver_registry_service_1 = require("./credential-resolver-registry.service");
|
|
15
|
+
const credential_resolver_repository_1 = require("../database/repositories/credential-resolver.repository");
|
|
16
|
+
const n8n_core_1 = require("n8n-core");
|
|
17
|
+
const credential_storage_error_1 = require("../errors/credential-storage.error");
|
|
18
|
+
const load_nodes_and_credentials_1 = require("../../../load-nodes-and-credentials");
|
|
19
|
+
const backend_common_1 = require("@n8n/backend-common");
|
|
20
|
+
const di_1 = require("@n8n/di");
|
|
21
|
+
const shared_fields_1 = require("./shared-fields");
|
|
22
|
+
let DynamicCredentialStorageService = class DynamicCredentialStorageService {
|
|
23
|
+
constructor(resolverRegistry, resolverRepository, loadNodesAndCredentials, cipher, logger) {
|
|
24
|
+
this.resolverRegistry = resolverRegistry;
|
|
25
|
+
this.resolverRepository = resolverRepository;
|
|
26
|
+
this.loadNodesAndCredentials = loadNodesAndCredentials;
|
|
27
|
+
this.cipher = cipher;
|
|
28
|
+
this.logger = logger;
|
|
29
|
+
}
|
|
30
|
+
async storeIfNeeded(credentialStoreMetadata, dynamicData, credentialContext, staticData, workflowSettings) {
|
|
31
|
+
try {
|
|
32
|
+
if (!credentialStoreMetadata.isResolvable) {
|
|
33
|
+
return;
|
|
34
|
+
}
|
|
35
|
+
const resolverId = credentialStoreMetadata.resolverId ?? workflowSettings?.credentialResolverId;
|
|
36
|
+
if (!resolverId) {
|
|
37
|
+
return this.handleNoResolver(credentialStoreMetadata);
|
|
38
|
+
}
|
|
39
|
+
const resolverEntity = await this.resolverRepository.findOneBy({
|
|
40
|
+
id: resolverId,
|
|
41
|
+
});
|
|
42
|
+
if (!resolverEntity) {
|
|
43
|
+
return this.handleMissingResolver(credentialStoreMetadata, resolverId);
|
|
44
|
+
}
|
|
45
|
+
const resolver = this.resolverRegistry.getResolverByTypename(resolverEntity.type);
|
|
46
|
+
if (!resolver) {
|
|
47
|
+
return this.handleMissingResolver(credentialStoreMetadata, resolverId);
|
|
48
|
+
}
|
|
49
|
+
const decryptedConfig = this.cipher.decrypt(resolverEntity.config);
|
|
50
|
+
const resolverConfig = (0, n8n_workflow_1.jsonParse)(decryptedConfig);
|
|
51
|
+
const credentialType = this.loadNodesAndCredentials.getCredential(credentialStoreMetadata.type);
|
|
52
|
+
const sharedFields = (0, shared_fields_1.extractSharedFields)(credentialType.type);
|
|
53
|
+
const mergedDynamicData = {
|
|
54
|
+
...(staticData ?? {}),
|
|
55
|
+
...dynamicData,
|
|
56
|
+
};
|
|
57
|
+
for (const field of sharedFields) {
|
|
58
|
+
if (field in mergedDynamicData) {
|
|
59
|
+
delete mergedDynamicData[field];
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
await resolver.setSecret(credentialStoreMetadata.id, credentialContext, mergedDynamicData, {
|
|
63
|
+
configuration: resolverConfig,
|
|
64
|
+
resolverName: resolverEntity.name,
|
|
65
|
+
resolverId: resolverEntity.id,
|
|
66
|
+
});
|
|
67
|
+
this.logger.debug('Successfully stored dynamic credentials', {
|
|
68
|
+
credentialId: credentialStoreMetadata.id,
|
|
69
|
+
resolverId,
|
|
70
|
+
resolverSource: credentialStoreMetadata.resolverId ? 'credential' : 'workflow',
|
|
71
|
+
identity: credentialContext.identity,
|
|
72
|
+
});
|
|
73
|
+
}
|
|
74
|
+
catch (error) {
|
|
75
|
+
throw new credential_storage_error_1.CredentialStorageError(`Failed to store dynamic credentials data for "${credentialStoreMetadata.name}"`, { cause: error });
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
handleNoResolver(credentialStoreMetadata) {
|
|
79
|
+
throw new credential_storage_error_1.CredentialStorageError(`No resolver found for credential "${credentialStoreMetadata.name}"`);
|
|
80
|
+
}
|
|
81
|
+
handleMissingResolver(credentialStoreMetadata, resolverId) {
|
|
82
|
+
throw new credential_storage_error_1.CredentialStorageError(`Resolver "${resolverId}" not found for credential "${credentialStoreMetadata.name}"`);
|
|
83
|
+
}
|
|
84
|
+
};
|
|
85
|
+
exports.DynamicCredentialStorageService = DynamicCredentialStorageService;
|
|
86
|
+
exports.DynamicCredentialStorageService = DynamicCredentialStorageService = __decorate([
|
|
87
|
+
(0, di_1.Service)(),
|
|
88
|
+
__metadata("design:paramtypes", [credential_resolver_registry_service_1.DynamicCredentialResolverRegistry,
|
|
89
|
+
credential_resolver_repository_1.DynamicCredentialResolverRepository,
|
|
90
|
+
load_nodes_and_credentials_1.LoadNodesAndCredentials,
|
|
91
|
+
n8n_core_1.Cipher,
|
|
92
|
+
backend_common_1.Logger])
|
|
93
|
+
], DynamicCredentialStorageService);
|
|
94
|
+
//# sourceMappingURL=dynamic-credential-storage.service.js.map
|
package/dist/modules/dynamic-credentials.ee/services/dynamic-credential-storage.service.js.map
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"dynamic-credential-storage.service.js","sourceRoot":"","sources":["../../../../src/modules/dynamic-credentials.ee/services/dynamic-credential-storage.service.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { Logger } from '@n8n/backend-common';
|
|
2
|
+
import { Cipher } from 'n8n-core';
|
|
3
|
+
import type { ICredentialDataDecryptedObject, IExecutionContext, IWorkflowSettings } from 'n8n-workflow';
|
|
4
|
+
import { LoadNodesAndCredentials } from '../../../load-nodes-and-credentials';
|
|
5
|
+
import { DynamicCredentialResolverRegistry } from './credential-resolver-registry.service';
|
|
6
|
+
import type { CredentialResolveMetadata, ICredentialResolutionProvider } from '../../../credentials/credential-resolution-provider.interface';
|
|
7
|
+
import { DynamicCredentialResolverRepository } from '../database/repositories/credential-resolver.repository';
|
|
8
|
+
export declare class DynamicCredentialService implements ICredentialResolutionProvider {
|
|
9
|
+
private readonly resolverRegistry;
|
|
10
|
+
private readonly resolverRepository;
|
|
11
|
+
private readonly loadNodesAndCredentials;
|
|
12
|
+
private readonly cipher;
|
|
13
|
+
private readonly logger;
|
|
14
|
+
constructor(resolverRegistry: DynamicCredentialResolverRegistry, resolverRepository: DynamicCredentialResolverRepository, loadNodesAndCredentials: LoadNodesAndCredentials, cipher: Cipher, logger: Logger);
|
|
15
|
+
resolveIfNeeded(credentialsResolveMetadata: CredentialResolveMetadata, staticData: ICredentialDataDecryptedObject, executionContext?: IExecutionContext, workflowSettings?: IWorkflowSettings): Promise<ICredentialDataDecryptedObject>;
|
|
16
|
+
private buildCredentialContext;
|
|
17
|
+
private handleResolutionError;
|
|
18
|
+
private handleMissingResolver;
|
|
19
|
+
private handleMissingContext;
|
|
20
|
+
}
|
|
@@ -0,0 +1,146 @@
|
|
|
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.DynamicCredentialService = 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
|
+
const n8n_core_1 = require("n8n-core");
|
|
17
|
+
const n8n_workflow_1 = require("n8n-workflow");
|
|
18
|
+
const load_nodes_and_credentials_1 = require("../../../load-nodes-and-credentials");
|
|
19
|
+
const credential_resolver_registry_service_1 = require("./credential-resolver-registry.service");
|
|
20
|
+
const shared_fields_1 = require("./shared-fields");
|
|
21
|
+
const credential_resolver_repository_1 = require("../database/repositories/credential-resolver.repository");
|
|
22
|
+
const credential_resolution_error_1 = require("../errors/credential-resolution.error");
|
|
23
|
+
let DynamicCredentialService = class DynamicCredentialService {
|
|
24
|
+
constructor(resolverRegistry, resolverRepository, loadNodesAndCredentials, cipher, logger) {
|
|
25
|
+
this.resolverRegistry = resolverRegistry;
|
|
26
|
+
this.resolverRepository = resolverRepository;
|
|
27
|
+
this.loadNodesAndCredentials = loadNodesAndCredentials;
|
|
28
|
+
this.cipher = cipher;
|
|
29
|
+
this.logger = logger;
|
|
30
|
+
}
|
|
31
|
+
async resolveIfNeeded(credentialsResolveMetadata, staticData, executionContext, workflowSettings) {
|
|
32
|
+
const resolverId = credentialsResolveMetadata.resolverId ?? workflowSettings?.credentialResolverId;
|
|
33
|
+
if (!credentialsResolveMetadata.isResolvable || !resolverId) {
|
|
34
|
+
return staticData;
|
|
35
|
+
}
|
|
36
|
+
const resolverEntity = await this.resolverRepository.findOneBy({
|
|
37
|
+
id: resolverId,
|
|
38
|
+
});
|
|
39
|
+
if (!resolverEntity) {
|
|
40
|
+
return this.handleMissingResolver(credentialsResolveMetadata, staticData, resolverId);
|
|
41
|
+
}
|
|
42
|
+
const resolver = this.resolverRegistry.getResolverByTypename(resolverEntity.type);
|
|
43
|
+
if (!resolver) {
|
|
44
|
+
return this.handleMissingResolver(credentialsResolveMetadata, staticData, resolverId);
|
|
45
|
+
}
|
|
46
|
+
const credentialContext = this.buildCredentialContext(executionContext);
|
|
47
|
+
if (!credentialContext) {
|
|
48
|
+
return this.handleMissingContext(credentialsResolveMetadata, staticData);
|
|
49
|
+
}
|
|
50
|
+
try {
|
|
51
|
+
const credentialType = this.loadNodesAndCredentials.getCredential(credentialsResolveMetadata.type);
|
|
52
|
+
const sharedFields = (0, shared_fields_1.extractSharedFields)(credentialType.type);
|
|
53
|
+
const decryptedConfig = this.cipher.decrypt(resolverEntity.config);
|
|
54
|
+
const resolverConfig = (0, n8n_workflow_1.jsonParse)(decryptedConfig);
|
|
55
|
+
const dynamicData = await resolver.getSecret(credentialsResolveMetadata.id, credentialContext, {
|
|
56
|
+
resolverId: resolverEntity.id,
|
|
57
|
+
resolverName: resolverEntity.type,
|
|
58
|
+
configuration: resolverConfig,
|
|
59
|
+
});
|
|
60
|
+
this.logger.debug('Successfully resolved dynamic credentials', {
|
|
61
|
+
credentialId: credentialsResolveMetadata.id,
|
|
62
|
+
resolverId,
|
|
63
|
+
resolverSource: credentialsResolveMetadata.resolverId ? 'credential' : 'workflow',
|
|
64
|
+
identity: credentialContext.identity,
|
|
65
|
+
});
|
|
66
|
+
for (const field of sharedFields) {
|
|
67
|
+
if (field in dynamicData) {
|
|
68
|
+
delete dynamicData[field];
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
return { ...staticData, ...dynamicData };
|
|
72
|
+
}
|
|
73
|
+
catch (error) {
|
|
74
|
+
return this.handleResolutionError(credentialsResolveMetadata, staticData, error, resolverId);
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
buildCredentialContext(executionContext) {
|
|
78
|
+
if (!executionContext?.credentials) {
|
|
79
|
+
return undefined;
|
|
80
|
+
}
|
|
81
|
+
try {
|
|
82
|
+
const decrypted = this.cipher.decrypt(executionContext.credentials);
|
|
83
|
+
return (0, n8n_workflow_1.toCredentialContext)(decrypted);
|
|
84
|
+
}
|
|
85
|
+
catch (error) {
|
|
86
|
+
this.logger.error('Failed to decrypt credential context from execution context', {
|
|
87
|
+
error: error instanceof Error ? error.message : String(error),
|
|
88
|
+
});
|
|
89
|
+
return undefined;
|
|
90
|
+
}
|
|
91
|
+
}
|
|
92
|
+
handleResolutionError(credentialsResolveMetadata, staticData, error, resolverId) {
|
|
93
|
+
const isDataNotFound = error instanceof decorators_1.CredentialResolverDataNotFoundError;
|
|
94
|
+
if (credentialsResolveMetadata.resolvableAllowFallback) {
|
|
95
|
+
this.logger.debug('Dynamic credential resolution failed, falling back to static', {
|
|
96
|
+
credentialId: credentialsResolveMetadata.id,
|
|
97
|
+
credentialName: credentialsResolveMetadata.name,
|
|
98
|
+
resolverId,
|
|
99
|
+
resolverSource: credentialsResolveMetadata.resolverId ? 'credential' : 'workflow',
|
|
100
|
+
error: error instanceof Error ? error.message : String(error),
|
|
101
|
+
isDataNotFound,
|
|
102
|
+
});
|
|
103
|
+
return staticData;
|
|
104
|
+
}
|
|
105
|
+
this.logger.debug('Dynamic credential resolution failed without fallback', {
|
|
106
|
+
credentialId: credentialsResolveMetadata.id,
|
|
107
|
+
credentialName: credentialsResolveMetadata.name,
|
|
108
|
+
resolverId,
|
|
109
|
+
resolverSource: credentialsResolveMetadata.resolverId ? 'credential' : 'workflow',
|
|
110
|
+
error,
|
|
111
|
+
});
|
|
112
|
+
throw new credential_resolution_error_1.CredentialResolutionError(`Failed to resolve dynamic credentials for "${credentialsResolveMetadata.name}"`, { cause: error });
|
|
113
|
+
}
|
|
114
|
+
handleMissingResolver(credentialsResolveMetadata, staticData, resolverId) {
|
|
115
|
+
if (credentialsResolveMetadata.resolvableAllowFallback) {
|
|
116
|
+
this.logger.debug('Resolver not found, falling back to static credentials', {
|
|
117
|
+
credentialId: credentialsResolveMetadata.id,
|
|
118
|
+
credentialName: credentialsResolveMetadata.name,
|
|
119
|
+
resolverId,
|
|
120
|
+
resolverSource: credentialsResolveMetadata.resolverId ? 'credential' : 'workflow',
|
|
121
|
+
});
|
|
122
|
+
return staticData;
|
|
123
|
+
}
|
|
124
|
+
throw new credential_resolution_error_1.CredentialResolutionError(`Resolver "${resolverId}" not found for credential "${credentialsResolveMetadata.name}"`);
|
|
125
|
+
}
|
|
126
|
+
handleMissingContext(credentialsResolveMetadata, staticData) {
|
|
127
|
+
if (credentialsResolveMetadata.resolvableAllowFallback) {
|
|
128
|
+
this.logger.debug('No execution context available, falling back to static credentials', {
|
|
129
|
+
credentialId: credentialsResolveMetadata.id,
|
|
130
|
+
credentialName: credentialsResolveMetadata.name,
|
|
131
|
+
});
|
|
132
|
+
return staticData;
|
|
133
|
+
}
|
|
134
|
+
throw new credential_resolution_error_1.CredentialResolutionError(`Cannot resolve dynamic credentials without execution context for "${credentialsResolveMetadata.name}"`);
|
|
135
|
+
}
|
|
136
|
+
};
|
|
137
|
+
exports.DynamicCredentialService = DynamicCredentialService;
|
|
138
|
+
exports.DynamicCredentialService = DynamicCredentialService = __decorate([
|
|
139
|
+
(0, di_1.Service)(),
|
|
140
|
+
__metadata("design:paramtypes", [credential_resolver_registry_service_1.DynamicCredentialResolverRegistry,
|
|
141
|
+
credential_resolver_repository_1.DynamicCredentialResolverRepository,
|
|
142
|
+
load_nodes_and_credentials_1.LoadNodesAndCredentials,
|
|
143
|
+
n8n_core_1.Cipher,
|
|
144
|
+
backend_common_1.Logger])
|
|
145
|
+
], DynamicCredentialService);
|
|
146
|
+
//# sourceMappingURL=dynamic-credential.service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"dynamic-credential.service.js","sourceRoot":"","sources":["../../../../src/modules/dynamic-credentials.ee/services/dynamic-credential.service.ts"],"names":[],"mappings":"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"}
|