n8n 2.0.2 → 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.
Files changed (349) hide show
  1. package/dist/active-executions.js +7 -1
  2. package/dist/active-executions.js.map +1 -1
  3. package/dist/active-workflow-manager.d.ts +0 -1
  4. package/dist/active-workflow-manager.js +5 -8
  5. package/dist/active-workflow-manager.js.map +1 -1
  6. package/dist/auth/auth.service.js +1 -7
  7. package/dist/auth/auth.service.js.map +1 -1
  8. package/dist/build.tsbuildinfo +1 -1
  9. package/dist/commands/base-command.js +1 -2
  10. package/dist/commands/base-command.js.map +1 -1
  11. package/dist/commands/start.js +3 -0
  12. package/dist/commands/start.js.map +1 -1
  13. package/dist/commands/user-management/reset.js +1 -1
  14. package/dist/commands/user-management/reset.js.map +1 -1
  15. package/dist/commands/worker.js +3 -0
  16. package/dist/commands/worker.js.map +1 -1
  17. package/dist/concurrency/concurrency-control.service.js +2 -1
  18. package/dist/concurrency/concurrency-control.service.js.map +1 -1
  19. package/dist/config/schema.js.map +1 -1
  20. package/dist/config/types.d.ts +0 -1
  21. package/dist/controllers/ai.controller.d.ts +3 -0
  22. package/dist/controllers/ai.controller.js +2 -1
  23. package/dist/controllers/ai.controller.js.map +1 -1
  24. package/dist/controllers/api-keys.controller.js +5 -0
  25. package/dist/controllers/api-keys.controller.js.map +1 -1
  26. package/dist/controllers/e2e.controller.d.ts +1 -0
  27. package/dist/controllers/e2e.controller.js +10 -11
  28. package/dist/controllers/e2e.controller.js.map +1 -1
  29. package/dist/controllers/invitation.controller.d.ts +3 -1
  30. package/dist/controllers/invitation.controller.js +6 -7
  31. package/dist/controllers/invitation.controller.js.map +1 -1
  32. package/dist/controllers/oauth/oauth1-credential.controller.d.ts +6 -3
  33. package/dist/controllers/oauth/oauth1-credential.controller.js +39 -57
  34. package/dist/controllers/oauth/oauth1-credential.controller.js.map +1 -1
  35. package/dist/controllers/oauth/oauth2-credential.controller.d.ts +8 -5
  36. package/dist/controllers/oauth/oauth2-credential.controller.js +41 -179
  37. package/dist/controllers/oauth/oauth2-credential.controller.js.map +1 -1
  38. package/dist/controllers/owner.controller.d.ts +4 -10
  39. package/dist/controllers/owner.controller.js +6 -42
  40. package/dist/controllers/owner.controller.js.map +1 -1
  41. package/dist/controllers/project.controller.d.ts +4 -0
  42. package/dist/credentials/credential-resolution-provider.interface.d.ts +12 -0
  43. package/dist/credentials/credential-resolution-provider.interface.js +3 -0
  44. package/dist/credentials/credential-resolution-provider.interface.js.map +1 -0
  45. package/dist/credentials/credentials-finder.service.d.ts +4 -0
  46. package/dist/credentials/credentials-finder.service.js +3 -0
  47. package/dist/credentials/credentials-finder.service.js.map +1 -1
  48. package/dist/credentials/credentials.controller.d.ts +12 -4
  49. package/dist/credentials/credentials.controller.js +9 -6
  50. package/dist/credentials/credentials.controller.js.map +1 -1
  51. package/dist/credentials/credentials.service.d.ts +13 -0
  52. package/dist/credentials/credentials.service.ee.d.ts +9 -2
  53. package/dist/credentials/credentials.service.ee.js +4 -1
  54. package/dist/credentials/credentials.service.ee.js.map +1 -1
  55. package/dist/credentials/credentials.service.js +10 -6
  56. package/dist/credentials/credentials.service.js.map +1 -1
  57. package/dist/credentials/dynamic-credential-storage.interface.d.ts +11 -0
  58. package/dist/credentials/dynamic-credential-storage.interface.js +3 -0
  59. package/dist/credentials/dynamic-credential-storage.interface.js.map +1 -0
  60. package/dist/credentials/dynamic-credentials-proxy.d.ts +14 -0
  61. package/dist/credentials/dynamic-credentials-proxy.js +50 -0
  62. package/dist/credentials/dynamic-credentials-proxy.js.map +1 -0
  63. package/dist/credentials-helper.d.ts +5 -2
  64. package/dist/credentials-helper.js +25 -7
  65. package/dist/credentials-helper.js.map +1 -1
  66. package/dist/environments.ee/source-control/source-control-import.service.ee.js.map +1 -1
  67. package/dist/environments.ee/source-control/source-control-status.service.ee.d.ts +2 -2
  68. package/dist/environments.ee/source-control/source-control.controller.ee.d.ts +4 -4
  69. package/dist/environments.ee/source-control/source-control.service.ee.d.ts +2 -2
  70. package/dist/environments.ee/source-control/source-control.service.ee.js +67 -39
  71. package/dist/environments.ee/source-control/source-control.service.ee.js.map +1 -1
  72. package/dist/errors/single-webhook-trigger.error.d.ts +4 -0
  73. package/dist/errors/single-webhook-trigger.error.js +11 -0
  74. package/dist/errors/single-webhook-trigger.error.js.map +1 -0
  75. package/dist/eventbus/event-message-classes/index.d.ts +2 -2
  76. package/dist/eventbus/event-message-classes/index.js +1 -0
  77. package/dist/eventbus/event-message-classes/index.js.map +1 -1
  78. package/dist/events/maps/relay.event-map.d.ts +6 -1
  79. package/dist/events/relays/log-streaming.event-relay.d.ts +1 -0
  80. package/dist/events/relays/log-streaming.event-relay.js +12 -0
  81. package/dist/events/relays/log-streaming.event-relay.js.map +1 -1
  82. package/dist/events/relays/telemetry.event-relay.js +14 -3
  83. package/dist/events/relays/telemetry.event-relay.js.map +1 -1
  84. package/dist/execution-lifecycle/execution-lifecycle-hooks.d.ts +2 -2
  85. package/dist/execution-lifecycle/execution-lifecycle-hooks.js +15 -3
  86. package/dist/execution-lifecycle/execution-lifecycle-hooks.js.map +1 -1
  87. package/dist/license.d.ts +6 -0
  88. package/dist/license.js +27 -0
  89. package/dist/license.js.map +1 -1
  90. package/dist/load-nodes-and-credentials.d.ts +2 -0
  91. package/dist/load-nodes-and-credentials.js +97 -86
  92. package/dist/load-nodes-and-credentials.js.map +1 -1
  93. package/dist/modules/breaking-changes/rules/index.d.ts +1 -1
  94. package/dist/modules/breaking-changes/rules/v2/index.d.ts +2 -1
  95. package/dist/modules/breaking-changes/rules/v2/index.js +2 -0
  96. package/dist/modules/breaking-changes/rules/v2/index.js.map +1 -1
  97. package/dist/modules/breaking-changes/rules/v2/pyodide-removed.rule.js +2 -1
  98. package/dist/modules/breaking-changes/rules/v2/pyodide-removed.rule.js.map +1 -1
  99. package/dist/modules/breaking-changes/rules/v2/settings-file-permissions.rule.d.ts +3 -3
  100. package/dist/modules/breaking-changes/rules/v2/settings-file-permissions.rule.js +11 -4
  101. package/dist/modules/breaking-changes/rules/v2/settings-file-permissions.rule.js.map +1 -1
  102. package/dist/modules/breaking-changes/rules/v2/start-node-removed.rule.d.ts +11 -0
  103. package/dist/modules/breaking-changes/rules/v2/start-node-removed.rule.js +63 -0
  104. package/dist/modules/breaking-changes/rules/v2/start-node-removed.rule.js.map +1 -0
  105. package/dist/modules/breaking-changes/rules/v2/task-runner-docker-image.rule.d.ts +3 -0
  106. package/dist/modules/breaking-changes/rules/v2/task-runner-docker-image.rule.js +15 -2
  107. package/dist/modules/breaking-changes/rules/v2/task-runner-docker-image.rule.js.map +1 -1
  108. package/dist/modules/breaking-changes/rules/v2/task-runners.rule.d.ts +3 -2
  109. package/dist/modules/breaking-changes/rules/v2/task-runners.rule.js +11 -2
  110. package/dist/modules/breaking-changes/rules/v2/task-runners.rule.js.map +1 -1
  111. package/dist/modules/chat-hub/chat-hub-agent.entity.d.ts +4 -3
  112. package/dist/modules/chat-hub/chat-hub-agent.entity.js +4 -0
  113. package/dist/modules/chat-hub/chat-hub-agent.entity.js.map +1 -1
  114. package/dist/modules/chat-hub/chat-hub-agent.service.d.ts +5 -21
  115. package/dist/modules/chat-hub/chat-hub-agent.service.js +17 -11
  116. package/dist/modules/chat-hub/chat-hub-agent.service.js.map +1 -1
  117. package/dist/modules/chat-hub/chat-hub-credentials.service.js +4 -2
  118. package/dist/modules/chat-hub/chat-hub-credentials.service.js.map +1 -1
  119. package/dist/modules/chat-hub/chat-hub-message.entity.js +1 -1
  120. package/dist/modules/chat-hub/chat-hub-message.entity.js.map +1 -1
  121. package/dist/modules/chat-hub/chat-hub-session.entity.d.ts +2 -0
  122. package/dist/modules/chat-hub/chat-hub-session.entity.js +6 -1
  123. package/dist/modules/chat-hub/chat-hub-session.entity.js.map +1 -1
  124. package/dist/modules/chat-hub/chat-hub-workflow.service.d.ts +17 -4
  125. package/dist/modules/chat-hub/chat-hub-workflow.service.js +161 -31
  126. package/dist/modules/chat-hub/chat-hub-workflow.service.js.map +1 -1
  127. package/dist/modules/chat-hub/chat-hub.attachment.service.d.ts +2 -0
  128. package/dist/modules/chat-hub/chat-hub.attachment.service.js +12 -0
  129. package/dist/modules/chat-hub/chat-hub.attachment.service.js.map +1 -1
  130. package/dist/modules/chat-hub/chat-hub.constants.d.ts +7 -3
  131. package/dist/modules/chat-hub/chat-hub.constants.js +468 -10
  132. package/dist/modules/chat-hub/chat-hub.constants.js.map +1 -1
  133. package/dist/modules/chat-hub/chat-hub.controller.d.ts +3 -1
  134. package/dist/modules/chat-hub/chat-hub.controller.js +7 -14
  135. package/dist/modules/chat-hub/chat-hub.controller.js.map +1 -1
  136. package/dist/modules/chat-hub/chat-hub.models.service.d.ts +35 -0
  137. package/dist/modules/chat-hub/chat-hub.models.service.js +640 -0
  138. package/dist/modules/chat-hub/chat-hub.models.service.js.map +1 -0
  139. package/dist/modules/chat-hub/chat-hub.module.js +0 -8
  140. package/dist/modules/chat-hub/chat-hub.module.js.map +1 -1
  141. package/dist/modules/chat-hub/chat-hub.service.d.ts +13 -26
  142. package/dist/modules/chat-hub/chat-hub.service.js +162 -760
  143. package/dist/modules/chat-hub/chat-hub.service.js.map +1 -1
  144. package/dist/modules/chat-hub/chat-hub.types.d.ts +27 -6
  145. package/dist/modules/chat-hub/chat-hub.types.js +11 -3
  146. package/dist/modules/chat-hub/chat-hub.types.js.map +1 -1
  147. package/dist/modules/chat-hub/chat-session.repository.js +17 -2
  148. package/dist/modules/chat-hub/chat-session.repository.js.map +1 -1
  149. package/dist/modules/chat-hub/context-limits.js +62 -5
  150. package/dist/modules/chat-hub/context-limits.js.map +1 -1
  151. package/dist/modules/data-table/data-table-column.repository.d.ts +15 -0
  152. package/dist/modules/data-table/data-table-column.repository.js +33 -17
  153. package/dist/modules/data-table/data-table-column.repository.js.map +1 -1
  154. package/dist/modules/data-table/data-table-ddl.service.d.ts +1 -0
  155. package/dist/modules/data-table/data-table-ddl.service.js +5 -0
  156. package/dist/modules/data-table/data-table-ddl.service.js.map +1 -1
  157. package/dist/modules/data-table/data-table-rows.repository.js +1 -1
  158. package/dist/modules/data-table/data-table-rows.repository.js.map +1 -1
  159. package/dist/modules/data-table/data-table.controller.d.ts +16 -1
  160. package/dist/modules/data-table/data-table.controller.js +39 -35
  161. package/dist/modules/data-table/data-table.controller.js.map +1 -1
  162. package/dist/modules/data-table/data-table.repository.d.ts +4 -1
  163. package/dist/modules/data-table/data-table.repository.js +12 -2
  164. package/dist/modules/data-table/data-table.repository.js.map +1 -1
  165. package/dist/modules/data-table/data-table.service.d.ts +13 -1
  166. package/dist/modules/data-table/data-table.service.js +13 -1
  167. package/dist/modules/data-table/data-table.service.js.map +1 -1
  168. package/dist/modules/data-table/errors/data-table-column-not-found.error.d.ts +2 -2
  169. package/dist/modules/data-table/errors/data-table-column-not-found.error.js +3 -5
  170. package/dist/modules/data-table/errors/data-table-column-not-found.error.js.map +1 -1
  171. package/dist/modules/data-table/errors/data-table-not-found.error.d.ts +2 -2
  172. package/dist/modules/data-table/errors/data-table-not-found.error.js +3 -5
  173. package/dist/modules/data-table/errors/data-table-not-found.error.js.map +1 -1
  174. package/dist/modules/data-table/utils/sql-utils.d.ts +1 -0
  175. package/dist/modules/data-table/utils/sql-utils.js +10 -0
  176. package/dist/modules/data-table/utils/sql-utils.js.map +1 -1
  177. package/dist/modules/dynamic-credentials.ee/context-establishment-hooks/bearer-token-extractor.d.ts +9 -0
  178. package/dist/modules/dynamic-credentials.ee/context-establishment-hooks/bearer-token-extractor.js +42 -0
  179. package/dist/modules/dynamic-credentials.ee/context-establishment-hooks/bearer-token-extractor.js.map +1 -0
  180. package/dist/modules/dynamic-credentials.ee/context-establishment-hooks/http-header-extractor.d.ts +9 -0
  181. package/dist/modules/dynamic-credentials.ee/context-establishment-hooks/http-header-extractor.js +141 -0
  182. package/dist/modules/dynamic-credentials.ee/context-establishment-hooks/http-header-extractor.js.map +1 -0
  183. package/dist/modules/dynamic-credentials.ee/context-establishment-hooks/index.d.ts +2 -0
  184. package/dist/modules/dynamic-credentials.ee/context-establishment-hooks/index.js +5 -0
  185. package/dist/modules/dynamic-credentials.ee/context-establishment-hooks/index.js.map +1 -0
  186. package/dist/modules/dynamic-credentials.ee/credential-resolvers/identifiers/identifier-interface.d.ts +7 -0
  187. package/dist/modules/dynamic-credentials.ee/credential-resolvers/identifiers/identifier-interface.js +7 -0
  188. package/dist/modules/dynamic-credentials.ee/credential-resolvers/identifiers/identifier-interface.js.map +1 -0
  189. package/dist/modules/dynamic-credentials.ee/credential-resolvers/identifiers/oauth2-introspection-identifier.d.ts +78 -0
  190. package/dist/modules/dynamic-credentials.ee/credential-resolvers/identifiers/oauth2-introspection-identifier.js +223 -0
  191. package/dist/modules/dynamic-credentials.ee/credential-resolvers/identifiers/oauth2-introspection-identifier.js.map +1 -0
  192. package/dist/modules/dynamic-credentials.ee/credential-resolvers/identifiers/oauth2-userinfo-identifier.d.ts +37 -0
  193. package/dist/modules/dynamic-credentials.ee/credential-resolvers/identifiers/oauth2-userinfo-identifier.js +160 -0
  194. package/dist/modules/dynamic-credentials.ee/credential-resolvers/identifiers/oauth2-userinfo-identifier.js.map +1 -0
  195. package/dist/modules/dynamic-credentials.ee/credential-resolvers/identifiers/oauth2-utils.d.ts +13 -0
  196. package/dist/modules/dynamic-credentials.ee/credential-resolvers/identifiers/oauth2-utils.js +17 -0
  197. package/dist/modules/dynamic-credentials.ee/credential-resolvers/identifiers/oauth2-utils.js.map +1 -0
  198. package/dist/modules/dynamic-credentials.ee/credential-resolvers/index.d.ts +2 -0
  199. package/dist/modules/dynamic-credentials.ee/credential-resolvers/index.js +5 -0
  200. package/dist/modules/dynamic-credentials.ee/credential-resolvers/index.js.map +1 -0
  201. package/dist/modules/dynamic-credentials.ee/credential-resolvers/oauth-credential-resolver.d.ts +103 -0
  202. package/dist/modules/dynamic-credentials.ee/credential-resolvers/oauth-credential-resolver.js +174 -0
  203. package/dist/modules/dynamic-credentials.ee/credential-resolvers/oauth-credential-resolver.js.map +1 -0
  204. package/dist/modules/dynamic-credentials.ee/credential-resolvers/storage/dynamic-credential-entry-storage.d.ts +9 -0
  205. package/dist/modules/dynamic-credentials.ee/credential-resolvers/storage/dynamic-credential-entry-storage.js +56 -0
  206. package/dist/modules/dynamic-credentials.ee/credential-resolvers/storage/dynamic-credential-entry-storage.js.map +1 -0
  207. package/dist/modules/dynamic-credentials.ee/credential-resolvers/storage/storage-interface.d.ts +5 -0
  208. package/dist/modules/dynamic-credentials.ee/credential-resolvers/storage/storage-interface.js +3 -0
  209. package/dist/modules/dynamic-credentials.ee/credential-resolvers/storage/storage-interface.js.map +1 -0
  210. package/dist/modules/dynamic-credentials.ee/credential-resolvers/stub-credential-resolver.d.ts +28 -0
  211. package/dist/modules/dynamic-credentials.ee/credential-resolvers/stub-credential-resolver.js +86 -0
  212. package/dist/modules/dynamic-credentials.ee/credential-resolvers/stub-credential-resolver.js.map +1 -0
  213. package/dist/modules/dynamic-credentials.ee/credential-resolvers.controller.d.ts +16 -0
  214. package/dist/modules/dynamic-credentials.ee/credential-resolvers.controller.js +172 -0
  215. package/dist/modules/dynamic-credentials.ee/credential-resolvers.controller.js.map +1 -0
  216. package/dist/modules/dynamic-credentials.ee/database/entities/credential-resolver.d.ts +8 -0
  217. package/dist/modules/dynamic-credentials.ee/database/entities/credential-resolver.js +33 -0
  218. package/dist/modules/dynamic-credentials.ee/database/entities/credential-resolver.js.map +1 -0
  219. package/dist/modules/dynamic-credentials.ee/database/entities/dynamic-credential-entry.d.ts +11 -0
  220. package/dist/modules/dynamic-credentials.ee/database/entities/dynamic-credential-entry.js +60 -0
  221. package/dist/modules/dynamic-credentials.ee/database/entities/dynamic-credential-entry.js.map +1 -0
  222. package/dist/modules/dynamic-credentials.ee/database/repositories/credential-resolver.repository.d.ts +5 -0
  223. package/dist/modules/dynamic-credentials.ee/database/repositories/credential-resolver.repository.js +26 -0
  224. package/dist/modules/dynamic-credentials.ee/database/repositories/credential-resolver.repository.js.map +1 -0
  225. package/dist/modules/dynamic-credentials.ee/database/repositories/dynamic-credential-entry.repository.d.ts +5 -0
  226. package/dist/modules/dynamic-credentials.ee/database/repositories/dynamic-credential-entry.repository.js +26 -0
  227. package/dist/modules/dynamic-credentials.ee/database/repositories/dynamic-credential-entry.repository.js.map +1 -0
  228. package/dist/modules/dynamic-credentials.ee/dynamic-credentials.controller.d.ts +9 -0
  229. package/dist/modules/dynamic-credentials.ee/dynamic-credentials.controller.js +61 -0
  230. package/dist/modules/dynamic-credentials.ee/dynamic-credentials.controller.js.map +1 -0
  231. package/dist/modules/dynamic-credentials.ee/dynamic-credentials.module.d.ts +6 -0
  232. package/dist/modules/dynamic-credentials.ee/dynamic-credentials.module.js +91 -0
  233. package/dist/modules/dynamic-credentials.ee/dynamic-credentials.module.js.map +1 -0
  234. package/dist/modules/dynamic-credentials.ee/errors/credential-resolution.error.d.ts +6 -0
  235. package/dist/modules/dynamic-credentials.ee/errors/credential-resolution.error.js +12 -0
  236. package/dist/modules/dynamic-credentials.ee/errors/credential-resolution.error.js.map +1 -0
  237. package/dist/modules/dynamic-credentials.ee/errors/credential-resolver-not-found.error.d.ts +4 -0
  238. package/dist/modules/dynamic-credentials.ee/errors/credential-resolver-not-found.error.js +11 -0
  239. package/dist/modules/dynamic-credentials.ee/errors/credential-resolver-not-found.error.js.map +1 -0
  240. package/dist/modules/dynamic-credentials.ee/errors/credential-storage.error.d.ts +6 -0
  241. package/dist/modules/dynamic-credentials.ee/errors/credential-storage.error.js +12 -0
  242. package/dist/modules/dynamic-credentials.ee/errors/credential-storage.error.js.map +1 -0
  243. package/dist/modules/dynamic-credentials.ee/services/credential-resolver-registry.service.d.ts +11 -0
  244. package/dist/modules/dynamic-credentials.ee/services/credential-resolver-registry.service.js +64 -0
  245. package/dist/modules/dynamic-credentials.ee/services/credential-resolver-registry.service.js.map +1 -0
  246. package/dist/modules/dynamic-credentials.ee/services/credential-resolver-workflow.service.d.ts +22 -0
  247. package/dist/modules/dynamic-credentials.ee/services/credential-resolver-workflow.service.js +150 -0
  248. package/dist/modules/dynamic-credentials.ee/services/credential-resolver-workflow.service.js.map +1 -0
  249. package/dist/modules/dynamic-credentials.ee/services/credential-resolver.service.d.ts +33 -0
  250. package/dist/modules/dynamic-credentials.ee/services/credential-resolver.service.js +118 -0
  251. package/dist/modules/dynamic-credentials.ee/services/credential-resolver.service.js.map +1 -0
  252. package/dist/modules/dynamic-credentials.ee/services/dynamic-credential-storage.service.d.ts +18 -0
  253. package/dist/modules/dynamic-credentials.ee/services/dynamic-credential-storage.service.js +94 -0
  254. package/dist/modules/dynamic-credentials.ee/services/dynamic-credential-storage.service.js.map +1 -0
  255. package/dist/modules/dynamic-credentials.ee/services/dynamic-credential.service.d.ts +20 -0
  256. package/dist/modules/dynamic-credentials.ee/services/dynamic-credential.service.js +146 -0
  257. package/dist/modules/dynamic-credentials.ee/services/dynamic-credential.service.js.map +1 -0
  258. package/dist/modules/dynamic-credentials.ee/services/index.d.ts +5 -0
  259. package/dist/modules/dynamic-credentials.ee/services/index.js +22 -0
  260. package/dist/modules/dynamic-credentials.ee/services/index.js.map +1 -0
  261. package/dist/modules/dynamic-credentials.ee/services/shared-fields.d.ts +2 -0
  262. package/dist/modules/dynamic-credentials.ee/services/shared-fields.js +13 -0
  263. package/dist/modules/dynamic-credentials.ee/services/shared-fields.js.map +1 -0
  264. package/dist/modules/dynamic-credentials.ee/workflow-status.controller.d.ts +8 -0
  265. package/dist/modules/dynamic-credentials.ee/workflow-status.controller.js +62 -0
  266. package/dist/modules/dynamic-credentials.ee/workflow-status.controller.js.map +1 -0
  267. package/dist/modules/external-secrets.ee/external-secrets-manager.ee.js +40 -24
  268. package/dist/modules/external-secrets.ee/external-secrets-manager.ee.js.map +1 -1
  269. package/dist/modules/insights/database/repositories/insights-by-period.repository.d.ts +2 -2
  270. package/dist/modules/insights/insights-collection.service.d.ts +2 -0
  271. package/dist/modules/insights/insights-collection.service.js +30 -6
  272. package/dist/modules/insights/insights-collection.service.js.map +1 -1
  273. package/dist/modules/insights/insights.service.d.ts +1 -1
  274. package/dist/modules/workflow-index/workflow-index.service.js +17 -10
  275. package/dist/modules/workflow-index/workflow-index.service.js.map +1 -1
  276. package/dist/oauth/oauth.service.d.ts +52 -0
  277. package/dist/oauth/oauth.service.js +416 -0
  278. package/dist/oauth/oauth.service.js.map +1 -0
  279. package/dist/oauth/types.d.ts +28 -0
  280. package/dist/oauth/types.js +16 -0
  281. package/dist/oauth/types.js.map +1 -0
  282. package/dist/public-api/v1/handlers/credentials/credentials.service.js +6 -8
  283. package/dist/public-api/v1/handlers/credentials/credentials.service.js.map +1 -1
  284. package/dist/public-api/v1/handlers/workflows/workflows.handler.js +2 -1
  285. package/dist/public-api/v1/handlers/workflows/workflows.handler.js.map +1 -1
  286. package/dist/public-api/v1/openapi.yml +4 -0
  287. package/dist/requests.d.ts +1 -0
  288. package/dist/scaling/job-processor.js +8 -2
  289. package/dist/scaling/job-processor.js.map +1 -1
  290. package/dist/scaling/worker-status.service.ee.js +20 -2
  291. package/dist/scaling/worker-status.service.ee.js.map +1 -1
  292. package/dist/server.js +5 -3
  293. package/dist/server.js.map +1 -1
  294. package/dist/services/ai-workflow-builder.service.d.ts +1 -0
  295. package/dist/services/ai-workflow-builder.service.js +5 -3
  296. package/dist/services/ai-workflow-builder.service.js.map +1 -1
  297. package/dist/services/ai.service.js +3 -0
  298. package/dist/services/ai.service.js.map +1 -1
  299. package/dist/services/cache/cache.service.d.ts +1 -0
  300. package/dist/services/cache/cache.service.js +4 -0
  301. package/dist/services/cache/cache.service.js.map +1 -1
  302. package/dist/services/frontend.service.d.ts +6 -4
  303. package/dist/services/frontend.service.js +14 -9
  304. package/dist/services/frontend.service.js.map +1 -1
  305. package/dist/services/ownership.service.d.ts +13 -3
  306. package/dist/services/ownership.service.js +59 -4
  307. package/dist/services/ownership.service.js.map +1 -1
  308. package/dist/services/project.service.ee.js +1 -1
  309. package/dist/services/project.service.ee.js.map +1 -1
  310. package/dist/services/public-api-key.service.d.ts +1 -0
  311. package/dist/services/public-api-key.service.js +8 -0
  312. package/dist/services/public-api-key.service.js.map +1 -1
  313. package/dist/services/user.service.d.ts +4 -3
  314. package/dist/services/user.service.js +50 -4
  315. package/dist/services/user.service.js.map +1 -1
  316. package/dist/telemetry/index.js +1 -0
  317. package/dist/telemetry/index.js.map +1 -1
  318. package/dist/webhooks/test-webhook-registrations.service.d.ts +5 -3
  319. package/dist/webhooks/test-webhook-registrations.service.js +25 -6
  320. package/dist/webhooks/test-webhook-registrations.service.js.map +1 -1
  321. package/dist/webhooks/test-webhooks.d.ts +1 -0
  322. package/dist/webhooks/test-webhooks.js +17 -10
  323. package/dist/webhooks/test-webhooks.js.map +1 -1
  324. package/dist/webhooks/waiting-forms.js +2 -0
  325. package/dist/webhooks/waiting-forms.js.map +1 -1
  326. package/dist/webhooks/webhook-helpers.js +12 -3
  327. package/dist/webhooks/webhook-helpers.js.map +1 -1
  328. package/dist/workflow-execute-additional-data.d.ts +2 -1
  329. package/dist/workflow-execute-additional-data.js +5 -3
  330. package/dist/workflow-execute-additional-data.js.map +1 -1
  331. package/dist/workflow-runner.js +1 -0
  332. package/dist/workflow-runner.js.map +1 -1
  333. package/dist/workflows/workflow-execution.service.js +3 -0
  334. package/dist/workflows/workflow-execution.service.js.map +1 -1
  335. package/dist/workflows/workflow-history/workflow-history.service.d.ts +1 -1
  336. package/dist/workflows/workflow-history/workflow-history.service.js +2 -1
  337. package/dist/workflows/workflow-history/workflow-history.service.js.map +1 -1
  338. package/dist/workflows/workflow.request.d.ts +2 -0
  339. package/dist/workflows/workflow.service.d.ts +2 -0
  340. package/dist/workflows/workflow.service.js +4 -2
  341. package/dist/workflows/workflow.service.js.map +1 -1
  342. package/dist/workflows/workflows.controller.js +13 -11
  343. package/dist/workflows/workflows.controller.js.map +1 -1
  344. package/package.json +18 -18
  345. package/templates/form-trigger-completion.handlebars +1 -4
  346. package/templates/form-trigger.handlebars +1 -2
  347. package/dist/controllers/oauth/abstract-oauth.controller.d.ts +0 -47
  348. package/dist/controllers/oauth/abstract-oauth.controller.js +0 -185
  349. package/dist/controllers/oauth/abstract-oauth.controller.js.map +0 -1
@@ -0,0 +1,11 @@
1
+ import { CredentialsEntity, WithTimestamps } from '@n8n/db';
2
+ import { DynamicCredentialResolver } from './credential-resolver';
3
+ export declare class DynamicCredentialEntry extends WithTimestamps {
4
+ constructor();
5
+ credentialId: string;
6
+ subjectId: string;
7
+ resolverId: string;
8
+ data: string;
9
+ credential: CredentialsEntity;
10
+ resolver: DynamicCredentialResolver;
11
+ }
@@ -0,0 +1,60 @@
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.DynamicCredentialEntry = void 0;
13
+ const db_1 = require("@n8n/db");
14
+ const typeorm_1 = require("@n8n/typeorm");
15
+ const credential_resolver_1 = require("./credential-resolver");
16
+ let DynamicCredentialEntry = class DynamicCredentialEntry extends db_1.WithTimestamps {
17
+ constructor() {
18
+ super();
19
+ }
20
+ };
21
+ exports.DynamicCredentialEntry = DynamicCredentialEntry;
22
+ __decorate([
23
+ (0, typeorm_1.PrimaryColumn)({
24
+ name: 'credential_id',
25
+ }),
26
+ __metadata("design:type", String)
27
+ ], DynamicCredentialEntry.prototype, "credentialId", void 0);
28
+ __decorate([
29
+ (0, typeorm_1.PrimaryColumn)({
30
+ name: 'subject_id',
31
+ }),
32
+ __metadata("design:type", String)
33
+ ], DynamicCredentialEntry.prototype, "subjectId", void 0);
34
+ __decorate([
35
+ (0, typeorm_1.PrimaryColumn)({
36
+ name: 'resolver_id',
37
+ }),
38
+ __metadata("design:type", String)
39
+ ], DynamicCredentialEntry.prototype, "resolverId", void 0);
40
+ __decorate([
41
+ (0, typeorm_1.Column)('text'),
42
+ __metadata("design:type", String)
43
+ ], DynamicCredentialEntry.prototype, "data", void 0);
44
+ __decorate([
45
+ (0, typeorm_1.ManyToOne)(() => db_1.CredentialsEntity, { onDelete: 'CASCADE' }),
46
+ (0, typeorm_1.JoinColumn)({ name: 'credential_id' }),
47
+ __metadata("design:type", db_1.CredentialsEntity)
48
+ ], DynamicCredentialEntry.prototype, "credential", void 0);
49
+ __decorate([
50
+ (0, typeorm_1.ManyToOne)(() => credential_resolver_1.DynamicCredentialResolver, { onDelete: 'CASCADE' }),
51
+ (0, typeorm_1.JoinColumn)({ name: 'resolver_id' }),
52
+ __metadata("design:type", credential_resolver_1.DynamicCredentialResolver)
53
+ ], DynamicCredentialEntry.prototype, "resolver", void 0);
54
+ exports.DynamicCredentialEntry = DynamicCredentialEntry = __decorate([
55
+ (0, typeorm_1.Entity)({
56
+ name: 'dynamic_credential_entry',
57
+ }),
58
+ __metadata("design:paramtypes", [])
59
+ ], DynamicCredentialEntry);
60
+ //# sourceMappingURL=dynamic-credential-entry.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"dynamic-credential-entry.js","sourceRoot":"","sources":["../../../../../src/modules/dynamic-credentials.ee/database/entities/dynamic-credential-entry.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,gCAA4D;AAC5D,0CAAoF;AAEpF,+DAAkE;AAK3D,IAAM,sBAAsB,GAA5B,MAAM,sBAAuB,SAAQ,mBAAc;IACzD;QACC,KAAK,EAAE,CAAC;IACT,CAAC;CA2BD,CAAA;AA9BY,wDAAsB;AAQlC;IAHC,IAAA,uBAAa,EAAC;QACd,IAAI,EAAE,eAAe;KACrB,CAAC;;4DACmB;AAKrB;IAHC,IAAA,uBAAa,EAAC;QACd,IAAI,EAAE,YAAY;KAClB,CAAC;;yDACgB;AAKlB;IAHC,IAAA,uBAAa,EAAC;QACd,IAAI,EAAE,aAAa;KACnB,CAAC;;0DACiB;AAGnB;IADC,IAAA,gBAAM,EAAC,MAAM,CAAC;;oDACF;AAIb;IAFC,IAAA,mBAAS,EAAC,GAAG,EAAE,CAAC,sBAAiB,EAAE,EAAE,QAAQ,EAAE,SAAS,EAAE,CAAC;IAC3D,IAAA,oBAAU,EAAC,EAAE,IAAI,EAAE,eAAe,EAAE,CAAC;8BAC1B,sBAAiB;0DAAC;AAI9B;IAFC,IAAA,mBAAS,EAAC,GAAG,EAAE,CAAC,+CAAyB,EAAE,EAAE,QAAQ,EAAE,SAAS,EAAE,CAAC;IACnE,IAAA,oBAAU,EAAC,EAAE,IAAI,EAAE,aAAa,EAAE,CAAC;8BAC1B,+CAAyB;wDAAC;iCA7BxB,sBAAsB;IAHlC,IAAA,gBAAM,EAAC;QACP,IAAI,EAAE,0BAA0B;KAChC,CAAC;;GACW,sBAAsB,CA8BlC"}
@@ -0,0 +1,5 @@
1
+ import { DataSource, Repository } from '@n8n/typeorm';
2
+ import { DynamicCredentialResolver } from '../entities/credential-resolver';
3
+ export declare class DynamicCredentialResolverRepository extends Repository<DynamicCredentialResolver> {
4
+ constructor(dataSource: DataSource);
5
+ }
@@ -0,0 +1,26 @@
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.DynamicCredentialResolverRepository = void 0;
13
+ const di_1 = require("@n8n/di");
14
+ const typeorm_1 = require("@n8n/typeorm");
15
+ const credential_resolver_1 = require("../entities/credential-resolver");
16
+ let DynamicCredentialResolverRepository = class DynamicCredentialResolverRepository extends typeorm_1.Repository {
17
+ constructor(dataSource) {
18
+ super(credential_resolver_1.DynamicCredentialResolver, dataSource.manager);
19
+ }
20
+ };
21
+ exports.DynamicCredentialResolverRepository = DynamicCredentialResolverRepository;
22
+ exports.DynamicCredentialResolverRepository = DynamicCredentialResolverRepository = __decorate([
23
+ (0, di_1.Service)(),
24
+ __metadata("design:paramtypes", [typeorm_1.DataSource])
25
+ ], DynamicCredentialResolverRepository);
26
+ //# sourceMappingURL=credential-resolver.repository.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"credential-resolver.repository.js","sourceRoot":"","sources":["../../../../../src/modules/dynamic-credentials.ee/database/repositories/credential-resolver.repository.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,gCAAkC;AAClC,0CAAsD;AAEtD,yEAA4E;AAGrE,IAAM,mCAAmC,GAAzC,MAAM,mCAAoC,SAAQ,oBAAqC;IAC7F,YAAY,UAAsB;QACjC,KAAK,CAAC,+CAAyB,EAAE,UAAU,CAAC,OAAO,CAAC,CAAC;IACtD,CAAC;CACD,CAAA;AAJY,kFAAmC;8CAAnC,mCAAmC;IAD/C,IAAA,YAAO,GAAE;qCAEe,oBAAU;GADtB,mCAAmC,CAI/C"}
@@ -0,0 +1,5 @@
1
+ import { DataSource, Repository } from '@n8n/typeorm';
2
+ import { DynamicCredentialEntry } from '../entities/dynamic-credential-entry';
3
+ export declare class DynamicCredentialEntryRepository extends Repository<DynamicCredentialEntry> {
4
+ constructor(dataSource: DataSource);
5
+ }
@@ -0,0 +1,26 @@
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.DynamicCredentialEntryRepository = void 0;
13
+ const di_1 = require("@n8n/di");
14
+ const typeorm_1 = require("@n8n/typeorm");
15
+ const dynamic_credential_entry_1 = require("../entities/dynamic-credential-entry");
16
+ let DynamicCredentialEntryRepository = class DynamicCredentialEntryRepository extends typeorm_1.Repository {
17
+ constructor(dataSource) {
18
+ super(dynamic_credential_entry_1.DynamicCredentialEntry, dataSource.manager);
19
+ }
20
+ };
21
+ exports.DynamicCredentialEntryRepository = DynamicCredentialEntryRepository;
22
+ exports.DynamicCredentialEntryRepository = DynamicCredentialEntryRepository = __decorate([
23
+ (0, di_1.Service)(),
24
+ __metadata("design:paramtypes", [typeorm_1.DataSource])
25
+ ], DynamicCredentialEntryRepository);
26
+ //# sourceMappingURL=dynamic-credential-entry.repository.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"dynamic-credential-entry.repository.js","sourceRoot":"","sources":["../../../../../src/modules/dynamic-credentials.ee/database/repositories/dynamic-credential-entry.repository.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,gCAAkC;AAClC,0CAAsD;AAEtD,mFAA8E;AAGvE,IAAM,gCAAgC,GAAtC,MAAM,gCAAiC,SAAQ,oBAAkC;IACvF,YAAY,UAAsB;QACjC,KAAK,CAAC,iDAAsB,EAAE,UAAU,CAAC,OAAO,CAAC,CAAC;IACnD,CAAC;CACD,CAAA;AAJY,4EAAgC;2CAAhC,gCAAgC;IAD5C,IAAA,YAAO,GAAE;qCAEe,oBAAU;GADtB,gCAAgC,CAI5C"}
@@ -0,0 +1,9 @@
1
+ import { Request, Response } from 'express';
2
+ import { EnterpriseCredentialsService } from '../../credentials/credentials.service.ee';
3
+ import { OauthService } from '../../oauth/oauth.service';
4
+ export declare class DynamicCredentialsController {
5
+ private readonly enterpriseCredentialsService;
6
+ private readonly oauthService;
7
+ constructor(enterpriseCredentialsService: EnterpriseCredentialsService, oauthService: OauthService);
8
+ authorizeCredential(req: Request, _res: Response): Promise<string>;
9
+ }
@@ -0,0 +1,61 @@
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.DynamicCredentialsController = void 0;
13
+ const decorators_1 = require("@n8n/decorators");
14
+ const credentials_service_ee_1 = require("../../credentials/credentials.service.ee");
15
+ const not_found_error_1 = require("../../errors/response-errors/not-found.error");
16
+ const bad_request_error_1 = require("../../errors/response-errors/bad-request.error");
17
+ const oauth_service_1 = require("../../oauth/oauth.service");
18
+ let DynamicCredentialsController = class DynamicCredentialsController {
19
+ constructor(enterpriseCredentialsService, oauthService) {
20
+ this.enterpriseCredentialsService = enterpriseCredentialsService;
21
+ this.oauthService = oauthService;
22
+ }
23
+ async authorizeCredential(req, _res) {
24
+ const credential = await this.enterpriseCredentialsService.getOne(req.params.id);
25
+ if (!credential) {
26
+ throw new not_found_error_1.NotFoundError('Credential not found');
27
+ }
28
+ if (!credential.type.includes('OAuth2') && !credential.type.includes('OAuth1')) {
29
+ throw new bad_request_error_1.BadRequestError('Credential type not supported');
30
+ }
31
+ const callerData = [
32
+ credential,
33
+ {
34
+ cid: credential.id,
35
+ origin: 'dynamic-credential',
36
+ authorizationHeader: req.headers.authorization ?? '',
37
+ credentialResolverId: req.query.resolverId,
38
+ },
39
+ ];
40
+ if (credential.type.includes('OAuth2')) {
41
+ return await this.oauthService.generateAOauth2AuthUri(...callerData);
42
+ }
43
+ if (credential.type.includes('OAuth1')) {
44
+ return await this.oauthService.generateAOauth1AuthUri(...callerData);
45
+ }
46
+ throw new bad_request_error_1.BadRequestError('Credential type not supported');
47
+ }
48
+ };
49
+ exports.DynamicCredentialsController = DynamicCredentialsController;
50
+ __decorate([
51
+ (0, decorators_1.Post)('/:id/authorize', { skipAuth: true }),
52
+ __metadata("design:type", Function),
53
+ __metadata("design:paramtypes", [Object, Object]),
54
+ __metadata("design:returntype", Promise)
55
+ ], DynamicCredentialsController.prototype, "authorizeCredential", null);
56
+ exports.DynamicCredentialsController = DynamicCredentialsController = __decorate([
57
+ (0, decorators_1.RestController)('/credentials'),
58
+ __metadata("design:paramtypes", [credentials_service_ee_1.EnterpriseCredentialsService,
59
+ oauth_service_1.OauthService])
60
+ ], DynamicCredentialsController);
61
+ //# sourceMappingURL=dynamic-credentials.controller.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"dynamic-credentials.controller.js","sourceRoot":"","sources":["../../../src/modules/dynamic-credentials.ee/dynamic-credentials.controller.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,gDAAuD;AAGvD,iFAAoF;AACpF,8EAAyE;AACzE,kFAA6E;AAC7E,yDAA0E;AAInE,IAAM,4BAA4B,GAAlC,MAAM,4BAA4B;IACxC,YACkB,4BAA0D,EAC1D,YAA0B;QAD1B,iCAA4B,GAA5B,4BAA4B,CAA8B;QAC1D,iBAAY,GAAZ,YAAY,CAAc;IACzC,CAAC;IAGE,AAAN,KAAK,CAAC,mBAAmB,CAAC,GAAY,EAAE,IAAc;QACrD,MAAM,UAAU,GAAG,MAAM,IAAI,CAAC,4BAA4B,CAAC,MAAM,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC;QAEjF,IAAI,CAAC,UAAU,EAAE,CAAC;YACjB,MAAM,IAAI,+BAAa,CAAC,sBAAsB,CAAC,CAAC;QACjD,CAAC;QAED,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,EAAE,CAAC;YAChF,MAAM,IAAI,mCAAe,CAAC,+BAA+B,CAAC,CAAC;QAC5D,CAAC;QAED,MAAM,UAAU,GAA6C;YAC5D,UAAU;YACV;gBACC,GAAG,EAAE,UAAU,CAAC,EAAE;gBAClB,MAAM,EAAE,oBAAoB;gBAC5B,mBAAmB,EAAE,GAAG,CAAC,OAAO,CAAC,aAAa,IAAI,EAAE;gBACpD,oBAAoB,EAAE,GAAG,CAAC,KAAK,CAAC,UAAU;aAC1C;SACD,CAAC;QAEF,IAAI,UAAU,CAAC,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,EAAE,CAAC;YACxC,OAAO,MAAM,IAAI,CAAC,YAAY,CAAC,sBAAsB,CAAC,GAAG,UAAU,CAAC,CAAC;QACtE,CAAC;QAED,IAAI,UAAU,CAAC,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,EAAE,CAAC;YACxC,OAAO,MAAM,IAAI,CAAC,YAAY,CAAC,sBAAsB,CAAC,GAAG,UAAU,CAAC,CAAC;QACtE,CAAC;QAED,MAAM,IAAI,mCAAe,CAAC,+BAA+B,CAAC,CAAC;IAC5D,CAAC;CACD,CAAA;AAtCY,oEAA4B;AAOlC;IADL,IAAA,iBAAI,EAAC,gBAAgB,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;;;;uEA+B1C;uCArCW,4BAA4B;IADxC,IAAA,2BAAc,EAAC,cAAc,CAAC;qCAGkB,qDAA4B;QAC5C,4BAAY;GAHhC,4BAA4B,CAsCxC"}
@@ -0,0 +1,6 @@
1
+ import type { ModuleInterface } from '@n8n/decorators';
2
+ export declare class DynamicCredentialsModule implements ModuleInterface {
3
+ init(): Promise<void>;
4
+ entities(): Promise<(typeof import("./database/entities/credential-resolver").DynamicCredentialResolver | typeof import("./database/entities/dynamic-credential-entry").DynamicCredentialEntry)[]>;
5
+ shutdown(): Promise<void>;
6
+ }
@@ -0,0 +1,91 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
19
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
20
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
21
+ 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;
22
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
23
+ };
24
+ var __importStar = (this && this.__importStar) || (function () {
25
+ var ownKeys = function(o) {
26
+ ownKeys = Object.getOwnPropertyNames || function (o) {
27
+ var ar = [];
28
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
29
+ return ar;
30
+ };
31
+ return ownKeys(o);
32
+ };
33
+ return function (mod) {
34
+ if (mod && mod.__esModule) return mod;
35
+ var result = {};
36
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
37
+ __setModuleDefault(result, mod);
38
+ return result;
39
+ };
40
+ })();
41
+ var __metadata = (this && this.__metadata) || function (k, v) {
42
+ if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
43
+ };
44
+ Object.defineProperty(exports, "__esModule", { value: true });
45
+ exports.DynamicCredentialsModule = void 0;
46
+ const constants_1 = require("@n8n/constants");
47
+ const decorators_1 = require("@n8n/decorators");
48
+ const di_1 = require("@n8n/di");
49
+ function isFeatureFlagEnabled() {
50
+ return process.env.N8N_ENV_FEAT_DYNAMIC_CREDENTIALS === 'true';
51
+ }
52
+ let DynamicCredentialsModule = class DynamicCredentialsModule {
53
+ async init() {
54
+ if (!isFeatureFlagEnabled()) {
55
+ return;
56
+ }
57
+ await Promise.resolve().then(() => __importStar(require('./dynamic-credentials.controller')));
58
+ await Promise.resolve().then(() => __importStar(require('./credential-resolvers.controller')));
59
+ await Promise.resolve().then(() => __importStar(require('./context-establishment-hooks')));
60
+ await Promise.resolve().then(() => __importStar(require('./credential-resolvers')));
61
+ const { DynamicCredentialResolverRegistry, DynamicCredentialStorageService, DynamicCredentialService, } = await Promise.resolve().then(() => __importStar(require('./services')));
62
+ await Promise.resolve().then(() => __importStar(require('./workflow-status.controller')));
63
+ await di_1.Container.get(DynamicCredentialResolverRegistry).init();
64
+ const { DynamicCredentialsProxy } = await Promise.resolve().then(() => __importStar(require('../../credentials/dynamic-credentials-proxy')));
65
+ const credentialsProxy = di_1.Container.get(DynamicCredentialsProxy);
66
+ const dynamicCredentialService = di_1.Container.get(DynamicCredentialService);
67
+ const dynamicCredentialStorageService = di_1.Container.get(DynamicCredentialStorageService);
68
+ credentialsProxy.setResolverProvider(dynamicCredentialService);
69
+ credentialsProxy.setStorageProvider(dynamicCredentialStorageService);
70
+ }
71
+ async entities() {
72
+ if (!isFeatureFlagEnabled()) {
73
+ return [];
74
+ }
75
+ const { DynamicCredentialResolver } = await Promise.resolve().then(() => __importStar(require('./database/entities/credential-resolver')));
76
+ const { DynamicCredentialEntry } = await Promise.resolve().then(() => __importStar(require('./database/entities/dynamic-credential-entry')));
77
+ return [DynamicCredentialResolver, DynamicCredentialEntry];
78
+ }
79
+ async shutdown() { }
80
+ };
81
+ exports.DynamicCredentialsModule = DynamicCredentialsModule;
82
+ __decorate([
83
+ (0, decorators_1.OnShutdown)(),
84
+ __metadata("design:type", Function),
85
+ __metadata("design:paramtypes", []),
86
+ __metadata("design:returntype", Promise)
87
+ ], DynamicCredentialsModule.prototype, "shutdown", null);
88
+ exports.DynamicCredentialsModule = DynamicCredentialsModule = __decorate([
89
+ (0, decorators_1.BackendModule)({ name: 'dynamic-credentials', licenseFlag: constants_1.LICENSE_FEATURES.DYNAMIC_CREDENTIALS })
90
+ ], DynamicCredentialsModule);
91
+ //# sourceMappingURL=dynamic-credentials.module.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"dynamic-credentials.module.js","sourceRoot":"","sources":["../../../src/modules/dynamic-credentials.ee/dynamic-credentials.module.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,8CAAkD;AAElD,gDAA4D;AAC5D,gCAAoC;AAEpC,SAAS,oBAAoB;IAC5B,OAAO,OAAO,CAAC,GAAG,CAAC,gCAAgC,KAAK,MAAM,CAAC;AAChE,CAAC;AAGM,IAAM,wBAAwB,GAA9B,MAAM,wBAAwB;IACpC,KAAK,CAAC,IAAI;QACT,IAAI,CAAC,oBAAoB,EAAE,EAAE,CAAC;YAC7B,OAAO;QACR,CAAC;QACD,wDAAa,kCAAkC,GAAC,CAAC;QACjD,wDAAa,mCAAmC,GAAC,CAAC;QAClD,wDAAa,+BAA+B,GAAC,CAAC;QAC9C,wDAAa,wBAAwB,GAAC,CAAC;QACvC,MAAM,EACL,iCAAiC,EACjC,+BAA+B,EAC/B,wBAAwB,GACxB,GAAG,wDAAa,YAAY,GAAC,CAAC;QAC/B,wDAAa,8BAA8B,GAAC,CAAC;QAE7C,MAAM,cAAS,CAAC,GAAG,CAAC,iCAAiC,CAAC,CAAC,IAAI,EAAE,CAAC;QAG9D,MAAM,EAAE,uBAAuB,EAAE,GAAG,wDAAa,6CAA6C,GAAC,CAAC;QAChG,MAAM,gBAAgB,GAAG,cAAS,CAAC,GAAG,CAAC,uBAAuB,CAAC,CAAC;QAChE,MAAM,wBAAwB,GAAG,cAAS,CAAC,GAAG,CAAC,wBAAwB,CAAC,CAAC;QACzE,MAAM,+BAA+B,GAAG,cAAS,CAAC,GAAG,CAAC,+BAA+B,CAAC,CAAC;QACvF,gBAAgB,CAAC,mBAAmB,CAAC,wBAAwB,CAAC,CAAC;QAC/D,gBAAgB,CAAC,kBAAkB,CAAC,+BAA+B,CAAC,CAAC;IACtE,CAAC;IAED,KAAK,CAAC,QAAQ;QACb,IAAI,CAAC,oBAAoB,EAAE,EAAE,CAAC;YAC7B,OAAO,EAAE,CAAC;QACX,CAAC;QACD,MAAM,EAAE,yBAAyB,EAAE,GAAG,wDAAa,yCAAyC,GAAC,CAAC;QAC9F,MAAM,EAAE,sBAAsB,EAAE,GAAG,wDAAa,8CAA8C,GAAC,CAAC;QAEhG,OAAO,CAAC,yBAAyB,EAAE,sBAAsB,CAAC,CAAC;IAC5D,CAAC;IAGK,AAAN,KAAK,CAAC,QAAQ,KAAI,CAAC;CACnB,CAAA;AAvCY,4DAAwB;AAsC9B;IADL,IAAA,uBAAU,GAAE;;;;wDACM;mCAtCP,wBAAwB;IADpC,IAAA,0BAAa,EAAC,EAAE,IAAI,EAAE,qBAAqB,EAAE,WAAW,EAAE,4BAAgB,CAAC,mBAAmB,EAAE,CAAC;GACrF,wBAAwB,CAuCpC"}
@@ -0,0 +1,6 @@
1
+ import { OperationalError } from 'n8n-workflow';
2
+ export declare class CredentialResolutionError extends OperationalError {
3
+ constructor(message: string, options?: {
4
+ cause?: unknown;
5
+ });
6
+ }
@@ -0,0 +1,12 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.CredentialResolutionError = void 0;
4
+ const n8n_workflow_1 = require("n8n-workflow");
5
+ class CredentialResolutionError extends n8n_workflow_1.OperationalError {
6
+ constructor(message, options) {
7
+ super(message, options);
8
+ this.name = 'CredentialResolutionError';
9
+ }
10
+ }
11
+ exports.CredentialResolutionError = CredentialResolutionError;
12
+ //# sourceMappingURL=credential-resolution.error.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"credential-resolution.error.js","sourceRoot":"","sources":["../../../../src/modules/dynamic-credentials.ee/errors/credential-resolution.error.ts"],"names":[],"mappings":";;;AAAA,+CAAgD;AAEhD,MAAa,yBAA0B,SAAQ,+BAAgB;IAC9D,YAAY,OAAe,EAAE,OAA6B;QACzD,KAAK,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC;QACxB,IAAI,CAAC,IAAI,GAAG,2BAA2B,CAAC;IACzC,CAAC;CACD;AALD,8DAKC"}
@@ -0,0 +1,4 @@
1
+ import { UserError } from 'n8n-workflow';
2
+ export declare class DynamicCredentialResolverNotFoundError extends UserError {
3
+ constructor(resolverId: string);
4
+ }
@@ -0,0 +1,11 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.DynamicCredentialResolverNotFoundError = void 0;
4
+ const n8n_workflow_1 = require("n8n-workflow");
5
+ class DynamicCredentialResolverNotFoundError extends n8n_workflow_1.UserError {
6
+ constructor(resolverId) {
7
+ super(`Credential resolver with ID "${resolverId}" does not exist.`);
8
+ }
9
+ }
10
+ exports.DynamicCredentialResolverNotFoundError = DynamicCredentialResolverNotFoundError;
11
+ //# sourceMappingURL=credential-resolver-not-found.error.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"credential-resolver-not-found.error.js","sourceRoot":"","sources":["../../../../src/modules/dynamic-credentials.ee/errors/credential-resolver-not-found.error.ts"],"names":[],"mappings":";;;AAAA,+CAAyC;AAEzC,MAAa,sCAAuC,SAAQ,wBAAS;IACpE,YAAY,UAAkB;QAC7B,KAAK,CAAC,gCAAgC,UAAU,mBAAmB,CAAC,CAAC;IACtE,CAAC;CACD;AAJD,wFAIC"}
@@ -0,0 +1,6 @@
1
+ import { UserError } from 'n8n-workflow';
2
+ export declare class CredentialStorageError extends UserError {
3
+ constructor(message: string, options?: {
4
+ cause?: unknown;
5
+ });
6
+ }
@@ -0,0 +1,12 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.CredentialStorageError = void 0;
4
+ const n8n_workflow_1 = require("n8n-workflow");
5
+ class CredentialStorageError extends n8n_workflow_1.UserError {
6
+ constructor(message, options) {
7
+ super(message, options);
8
+ this.name = 'CredentialStorageError';
9
+ }
10
+ }
11
+ exports.CredentialStorageError = CredentialStorageError;
12
+ //# sourceMappingURL=credential-storage.error.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"credential-storage.error.js","sourceRoot":"","sources":["../../../../src/modules/dynamic-credentials.ee/errors/credential-storage.error.ts"],"names":[],"mappings":";;;AAAA,+CAAyC;AAEzC,MAAa,sBAAuB,SAAQ,wBAAS;IACpD,YAAY,OAAe,EAAE,OAA6B;QACzD,KAAK,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC;QACxB,IAAI,CAAC,IAAI,GAAG,wBAAwB,CAAC;IACtC,CAAC;CACD;AALD,wDAKC"}
@@ -0,0 +1,11 @@
1
+ import { Logger } from '@n8n/backend-common';
2
+ import { CredentialResolverEntryMetadata, ICredentialResolver } from '@n8n/decorators';
3
+ export declare class DynamicCredentialResolverRegistry {
4
+ private readonly credentialResolverEntryMetadata;
5
+ private readonly logger;
6
+ private resolverMap;
7
+ constructor(credentialResolverEntryMetadata: CredentialResolverEntryMetadata, logger: Logger);
8
+ init(): Promise<void>;
9
+ getResolverByTypename(name: string): ICredentialResolver | undefined;
10
+ getAllResolvers(): ICredentialResolver[];
11
+ }
@@ -0,0 +1,64 @@
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.DynamicCredentialResolverRegistry = void 0;
13
+ const backend_common_1 = require("@n8n/backend-common");
14
+ const decorators_1 = require("@n8n/decorators");
15
+ const di_1 = require("@n8n/di");
16
+ let DynamicCredentialResolverRegistry = class DynamicCredentialResolverRegistry {
17
+ constructor(credentialResolverEntryMetadata, logger) {
18
+ this.credentialResolverEntryMetadata = credentialResolverEntryMetadata;
19
+ this.logger = logger;
20
+ this.resolverMap = new Map();
21
+ }
22
+ async init() {
23
+ this.resolverMap.clear();
24
+ const resolverClasses = this.credentialResolverEntryMetadata.getClasses();
25
+ this.logger.debug(`Registering ${resolverClasses.length} credential resolvers.`);
26
+ for (const ResolverClass of resolverClasses) {
27
+ let resolver;
28
+ try {
29
+ resolver = di_1.Container.get(ResolverClass);
30
+ }
31
+ catch (error) {
32
+ this.logger.error(`Failed to instantiate credential resolver class "${ResolverClass.name}": ${error.message}`, { error });
33
+ continue;
34
+ }
35
+ if (this.resolverMap.has(resolver.metadata.name)) {
36
+ this.logger.warn(`Credential resolver with name "${resolver.metadata.name}" is already registered. Conflicting classes are "${this.resolverMap.get(resolver.metadata.name)?.constructor.name}" and "${ResolverClass.name}". Skipping the latter.`);
37
+ continue;
38
+ }
39
+ if (resolver.init) {
40
+ try {
41
+ await resolver.init();
42
+ }
43
+ catch (error) {
44
+ this.logger.error(`Failed to initialize credential resolver "${resolver.metadata.name}": ${error.message}`, { error });
45
+ continue;
46
+ }
47
+ }
48
+ this.resolverMap.set(resolver.metadata.name, resolver);
49
+ }
50
+ }
51
+ getResolverByTypename(name) {
52
+ return this.resolverMap.get(name);
53
+ }
54
+ getAllResolvers() {
55
+ return Array.from(this.resolverMap.values());
56
+ }
57
+ };
58
+ exports.DynamicCredentialResolverRegistry = DynamicCredentialResolverRegistry;
59
+ exports.DynamicCredentialResolverRegistry = DynamicCredentialResolverRegistry = __decorate([
60
+ (0, di_1.Service)(),
61
+ __metadata("design:paramtypes", [decorators_1.CredentialResolverEntryMetadata,
62
+ backend_common_1.Logger])
63
+ ], DynamicCredentialResolverRegistry);
64
+ //# sourceMappingURL=credential-resolver-registry.service.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"credential-resolver-registry.service.js","sourceRoot":"","sources":["../../../../src/modules/dynamic-credentials.ee/services/credential-resolver-registry.service.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,wDAA6C;AAC7C,gDAAuF;AACvF,gCAA6C;AAOtC,IAAM,iCAAiC,GAAvC,MAAM,iCAAiC;IAI7C,YACkB,+BAAgE,EAChE,MAAc;QADd,oCAA+B,GAA/B,+BAA+B,CAAiC;QAChE,WAAM,GAAN,MAAM,CAAQ;QAJxB,gBAAW,GAAqC,IAAI,GAAG,EAAE,CAAC;IAK/D,CAAC;IAOJ,KAAK,CAAC,IAAI;QACT,IAAI,CAAC,WAAW,CAAC,KAAK,EAAE,CAAC;QAEzB,MAAM,eAAe,GAAG,IAAI,CAAC,+BAA+B,CAAC,UAAU,EAAE,CAAC;QAC1E,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,eAAe,eAAe,CAAC,MAAM,wBAAwB,CAAC,CAAC;QAEjF,KAAK,MAAM,aAAa,IAAI,eAAe,EAAE,CAAC;YAC7C,IAAI,QAA6B,CAAC;YAClC,IAAI,CAAC;gBACJ,QAAQ,GAAG,cAAS,CAAC,GAAG,CAAC,aAAa,CAAC,CAAC;YACzC,CAAC;YAAC,OAAO,KAAK,EAAE,CAAC;gBAChB,IAAI,CAAC,MAAM,CAAC,KAAK,CAChB,oDAAoD,aAAa,CAAC,IAAI,MAAO,KAAe,CAAC,OAAO,EAAE,EACtG,EAAE,KAAK,EAAE,CACT,CAAC;gBACF,SAAS;YACV,CAAC;YAED,IAAI,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC;gBAClD,IAAI,CAAC,MAAM,CAAC,IAAI,CACf,kCAAkC,QAAQ,CAAC,QAAQ,CAAC,IAAI,qDAAqD,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE,WAAW,CAAC,IAAI,UAAU,aAAa,CAAC,IAAI,yBAAyB,CAChO,CAAC;gBACF,SAAS;YACV,CAAC;YAED,IAAI,QAAQ,CAAC,IAAI,EAAE,CAAC;gBACnB,IAAI,CAAC;oBACJ,MAAM,QAAQ,CAAC,IAAI,EAAE,CAAC;gBACvB,CAAC;gBAAC,OAAO,KAAK,EAAE,CAAC;oBAChB,IAAI,CAAC,MAAM,CAAC,KAAK,CAChB,6CAA6C,QAAQ,CAAC,QAAQ,CAAC,IAAI,MAAO,KAAe,CAAC,OAAO,EAAE,EACnG,EAAE,KAAK,EAAE,CACT,CAAC;oBACF,SAAS;gBACV,CAAC;YACF,CAAC;YACD,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,EAAE,QAAQ,CAAC,CAAC;QACxD,CAAC;IACF,CAAC;IAMD,qBAAqB,CAAC,IAAY;QACjC,OAAO,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;IACnC,CAAC;IAKD,eAAe;QACd,OAAO,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,MAAM,EAAE,CAAC,CAAC;IAC9C,CAAC;CACD,CAAA;AApEY,8EAAiC;4CAAjC,iCAAiC;IAD7C,IAAA,YAAO,GAAE;qCAM0C,4CAA+B;QACxD,uBAAM;GANpB,iCAAiC,CAoE7C"}
@@ -0,0 +1,22 @@
1
+ import { CredentialsRepository, WorkflowRepository } from '@n8n/db';
2
+ import { DynamicCredentialResolverRegistry } from './credential-resolver-registry.service';
3
+ import { DynamicCredentialResolverRepository } from '../database/repositories/credential-resolver.repository';
4
+ import { Cipher } from 'n8n-core';
5
+ type CredentialStatus = {
6
+ credentialId: string;
7
+ resolverId: string;
8
+ credentialType: string;
9
+ status: 'missing' | 'configured';
10
+ };
11
+ export declare class CredentialResolverWorkflowService {
12
+ private readonly workflowRepository;
13
+ private readonly credentialRepository;
14
+ private readonly resolverRegistry;
15
+ private readonly resolverRepository;
16
+ private readonly cipher;
17
+ constructor(workflowRepository: WorkflowRepository, credentialRepository: CredentialsRepository, resolverRegistry: DynamicCredentialResolverRegistry, resolverRepository: DynamicCredentialResolverRepository, cipher: Cipher);
18
+ private getResolver;
19
+ getWorkflowStatus(workflowId: string, identityToken: string): Promise<CredentialStatus[]>;
20
+ private checkCredentialStatus;
21
+ }
22
+ export {};