n8n 2.26.4 → 2.27.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 (657) hide show
  1. package/dist/active-workflow-manager.d.ts +9 -17
  2. package/dist/active-workflow-manager.js +48 -159
  3. package/dist/active-workflow-manager.js.map +1 -1
  4. package/dist/binary-data/database.manager.js +2 -1
  5. package/dist/binary-data/database.manager.js.map +1 -1
  6. package/dist/build.tsbuildinfo +1 -1
  7. package/dist/commands/audit.d.ts +1 -0
  8. package/dist/commands/audit.js +9 -0
  9. package/dist/commands/audit.js.map +1 -1
  10. package/dist/commands/base-command.d.ts +1 -0
  11. package/dist/commands/base-command.js +31 -10
  12. package/dist/commands/base-command.js.map +1 -1
  13. package/dist/commands/export/workflow.js +9 -0
  14. package/dist/commands/export/workflow.js.map +1 -1
  15. package/dist/commands/import/workflow.js +6 -0
  16. package/dist/commands/import/workflow.js.map +1 -1
  17. package/dist/commands/start.js +7 -3
  18. package/dist/commands/start.js.map +1 -1
  19. package/dist/commands/worker.js +6 -3
  20. package/dist/commands/worker.js.map +1 -1
  21. package/dist/concurrency/concurrency-queue.d.ts +1 -1
  22. package/dist/concurrency/concurrency-queue.js +2 -2
  23. package/dist/concurrency/concurrency-queue.js.map +1 -1
  24. package/dist/controllers/api-keys.controller.js +6 -2
  25. package/dist/controllers/api-keys.controller.js.map +1 -1
  26. package/dist/controllers/e2e.controller.js +1 -1
  27. package/dist/controllers/e2e.controller.js.map +1 -1
  28. package/dist/controllers/oauth/oauth2-credential.controller.js +7 -0
  29. package/dist/controllers/oauth/oauth2-credential.controller.js.map +1 -1
  30. package/dist/controllers/security-settings.controller.d.ts +3 -3
  31. package/dist/controllers/security-settings.controller.js +3 -8
  32. package/dist/controllers/security-settings.controller.js.map +1 -1
  33. package/dist/credentials-helper.js +3 -0
  34. package/dist/credentials-helper.js.map +1 -1
  35. package/dist/errors/http-error-serializers.js +2 -15
  36. package/dist/errors/http-error-serializers.js.map +1 -1
  37. package/dist/errors/response-errors/bad-request.error.d.ts +1 -1
  38. package/dist/errors/response-errors/bad-request.error.js +2 -2
  39. package/dist/errors/response-errors/bad-request.error.js.map +1 -1
  40. package/dist/errors/response-errors/unprocessable.error.d.ts +2 -1
  41. package/dist/errors/response-errors/unprocessable.error.js +2 -1
  42. package/dist/errors/response-errors/unprocessable.error.js.map +1 -1
  43. package/dist/events/event.service.d.ts +1 -1
  44. package/dist/events/event.service.js +2 -2
  45. package/dist/events/event.service.js.map +1 -1
  46. package/dist/events/maps/execution-data.event-map.d.ts +1 -0
  47. package/dist/events/maps/relay.event-map.d.ts +13 -0
  48. package/dist/events/relays/log-streaming.event-relay.js +2 -2
  49. package/dist/events/relays/log-streaming.event-relay.js.map +1 -1
  50. package/dist/events/relays/telemetry.event-relay.d.ts +2 -0
  51. package/dist/events/relays/telemetry.event-relay.js +21 -2
  52. package/dist/events/relays/telemetry.event-relay.js.map +1 -1
  53. package/dist/executions/execution-data/db-store.d.ts +3 -1
  54. package/dist/executions/execution-data/db-store.js +14 -0
  55. package/dist/executions/execution-data/db-store.js.map +1 -1
  56. package/dist/executions/execution-data/fs-store.d.ts +1 -1
  57. package/dist/executions/execution-data/fs-store.js +3 -1
  58. package/dist/executions/execution-data/fs-store.js.map +1 -1
  59. package/dist/executions/execution-data/s3-store.ee.d.ts +15 -0
  60. package/dist/executions/execution-data/s3-store.ee.js +115 -0
  61. package/dist/executions/execution-data/s3-store.ee.js.map +1 -0
  62. package/dist/executions/execution-data/types.d.ts +1 -1
  63. package/dist/executions/execution-persistence.d.ts +16 -2
  64. package/dist/executions/execution-persistence.js +80 -22
  65. package/dist/executions/execution-persistence.js.map +1 -1
  66. package/dist/metrics/prometheus/active-workflow-metrics.service.d.ts +12 -0
  67. package/dist/metrics/prometheus/active-workflow-metrics.service.js +61 -0
  68. package/dist/metrics/prometheus/active-workflow-metrics.service.js.map +1 -0
  69. package/dist/metrics/prometheus/base.d.ts +5 -0
  70. package/dist/metrics/{types.js → prometheus/base.js} +1 -1
  71. package/dist/metrics/prometheus/base.js.map +1 -0
  72. package/dist/metrics/prometheus/cache-metrics.service.d.ts +11 -0
  73. package/dist/metrics/prometheus/cache-metrics.service.js +48 -0
  74. package/dist/metrics/prometheus/cache-metrics.service.js.map +1 -0
  75. package/dist/metrics/prometheus/constant.d.ts +2 -0
  76. package/dist/metrics/prometheus/constant.js +18 -0
  77. package/dist/metrics/prometheus/constant.js.map +1 -0
  78. package/dist/metrics/prometheus/default-metrics.service.d.ts +8 -0
  79. package/dist/metrics/prometheus/default-metrics.service.js +35 -0
  80. package/dist/metrics/prometheus/default-metrics.service.js.map +1 -0
  81. package/dist/metrics/prometheus/dns-cache-metrics.service.d.ts +12 -0
  82. package/dist/metrics/prometheus/dns-cache-metrics.service.js +58 -0
  83. package/dist/metrics/prometheus/dns-cache-metrics.service.js.map +1 -0
  84. package/dist/metrics/prometheus/event-bus-metrics.service.d.ts +15 -0
  85. package/dist/metrics/prometheus/event-bus-metrics.service.js +106 -0
  86. package/dist/metrics/prometheus/event-bus-metrics.service.js.map +1 -0
  87. package/dist/metrics/prometheus/execution-data-metrics.service.d.ts +12 -0
  88. package/dist/metrics/prometheus/execution-data-metrics.service.js +106 -0
  89. package/dist/metrics/prometheus/execution-data-metrics.service.js.map +1 -0
  90. package/dist/metrics/prometheus/index.d.ts +1 -0
  91. package/dist/metrics/prometheus/index.js +6 -0
  92. package/dist/metrics/prometheus/index.js.map +1 -0
  93. package/dist/metrics/prometheus/instance-role-metrics.service.d.ts +13 -0
  94. package/dist/metrics/prometheus/instance-role-metrics.service.js +61 -0
  95. package/dist/metrics/prometheus/instance-role-metrics.service.js.map +1 -0
  96. package/dist/metrics/prometheus/prometheus.service.d.ts +26 -0
  97. package/dist/metrics/prometheus/prometheus.service.js +105 -0
  98. package/dist/metrics/prometheus/prometheus.service.js.map +1 -0
  99. package/dist/metrics/prometheus/pss-metrics.service.d.ts +9 -0
  100. package/dist/metrics/prometheus/pss-metrics.service.js +59 -0
  101. package/dist/metrics/prometheus/pss-metrics.service.js.map +1 -0
  102. package/dist/metrics/prometheus/queue-metrics.service.d.ts +13 -0
  103. package/dist/metrics/prometheus/queue-metrics.service.js +71 -0
  104. package/dist/metrics/prometheus/queue-metrics.service.js.map +1 -0
  105. package/dist/metrics/prometheus/route-metrics.service.d.ts +11 -0
  106. package/dist/metrics/prometheus/route-metrics.service.js +69 -0
  107. package/dist/metrics/prometheus/route-metrics.service.js.map +1 -0
  108. package/dist/metrics/prometheus/ssrf-metrics.service.d.ts +11 -0
  109. package/dist/metrics/prometheus/ssrf-metrics.service.js +65 -0
  110. package/dist/metrics/prometheus/ssrf-metrics.service.js.map +1 -0
  111. package/dist/metrics/prometheus/token-exchange-metrics.service.d.ts +10 -0
  112. package/dist/metrics/prometheus/token-exchange-metrics.service.js +91 -0
  113. package/dist/metrics/prometheus/token-exchange-metrics.service.js.map +1 -0
  114. package/dist/metrics/prometheus/version-metrics.service.d.ts +8 -0
  115. package/dist/metrics/prometheus/version-metrics.service.js +46 -0
  116. package/dist/metrics/prometheus/version-metrics.service.js.map +1 -0
  117. package/dist/metrics/prometheus/workflow-execution-duration-metrics.service.d.ts +10 -0
  118. package/dist/metrics/prometheus/workflow-execution-duration-metrics.service.js +61 -0
  119. package/dist/metrics/prometheus/workflow-execution-duration-metrics.service.js.map +1 -0
  120. package/dist/metrics/prometheus/workflow-statistics-metrics.service.d.ts +17 -0
  121. package/dist/metrics/prometheus/workflow-statistics-metrics.service.js +130 -0
  122. package/dist/metrics/prometheus/workflow-statistics-metrics.service.js.map +1 -0
  123. package/dist/modules/agents/agent-knowledge.service.d.ts +3 -32
  124. package/dist/modules/agents/agent-knowledge.service.js +7 -248
  125. package/dist/modules/agents/agent-knowledge.service.js.map +1 -1
  126. package/dist/modules/agents/agent-runtime-reconstruction.service.d.ts +1 -6
  127. package/dist/modules/agents/agent-runtime-reconstruction.service.js +2 -28
  128. package/dist/modules/agents/agent-runtime-reconstruction.service.js.map +1 -1
  129. package/dist/modules/agents/agents-list.controller.d.ts +9 -0
  130. package/dist/modules/agents/agents-list.controller.js +39 -0
  131. package/dist/modules/agents/agents-list.controller.js.map +1 -0
  132. package/dist/modules/agents/agents.controller.d.ts +6 -6
  133. package/dist/modules/agents/agents.controller.js +12 -19
  134. package/dist/modules/agents/agents.controller.js.map +1 -1
  135. package/dist/modules/agents/agents.module.d.ts +3 -2
  136. package/dist/modules/agents/agents.module.js +4 -2
  137. package/dist/modules/agents/agents.module.js.map +1 -1
  138. package/dist/modules/agents/agents.service.d.ts +10 -2
  139. package/dist/modules/agents/agents.service.js +119 -82
  140. package/dist/modules/agents/agents.service.js.map +1 -1
  141. package/dist/modules/agents/entities/agent-chat-subscription.entity.d.ts +10 -0
  142. package/dist/modules/agents/entities/{agent-file.entity.js → agent-chat-subscription.entity.js} +34 -23
  143. package/dist/modules/agents/entities/agent-chat-subscription.entity.js.map +1 -0
  144. package/dist/modules/agents/execution-recorder.js +15 -2
  145. package/dist/modules/agents/execution-recorder.js.map +1 -1
  146. package/dist/modules/agents/integrations/agent-chat-subscription-state.adapter.d.ts +43 -0
  147. package/dist/modules/agents/integrations/agent-chat-subscription-state.adapter.js +139 -0
  148. package/dist/modules/agents/integrations/agent-chat-subscription-state.adapter.js.map +1 -0
  149. package/dist/modules/agents/integrations/agent-chat-subscription-state.service.d.ts +26 -0
  150. package/dist/modules/agents/integrations/agent-chat-subscription-state.service.js +88 -0
  151. package/dist/modules/agents/integrations/agent-chat-subscription-state.service.js.map +1 -0
  152. package/dist/modules/agents/integrations/chat-integration.service.d.ts +3 -1
  153. package/dist/modules/agents/integrations/chat-integration.service.js +47 -18
  154. package/dist/modules/agents/integrations/chat-integration.service.js.map +1 -1
  155. package/dist/modules/agents/integrations/component-mapper.js.map +1 -1
  156. package/dist/modules/agents/integrations/slack-app-setup.service.js +8 -8
  157. package/dist/modules/agents/integrations/slack-app-setup.service.js.map +1 -1
  158. package/dist/modules/agents/repositories/agent-chat-subscription.repository.d.ts +15 -0
  159. package/dist/modules/agents/repositories/agent-chat-subscription.repository.js +51 -0
  160. package/dist/modules/agents/repositories/agent-chat-subscription.repository.js.map +1 -0
  161. package/dist/modules/agents/repositories/agent.repository.d.ts +7 -0
  162. package/dist/modules/agents/repositories/agent.repository.js +28 -0
  163. package/dist/modules/agents/repositories/agent.repository.js.map +1 -1
  164. package/dist/modules/data-table/data-table.repository.js +1 -1
  165. package/dist/modules/data-table/data-table.repository.js.map +1 -1
  166. package/dist/modules/data-table/utils/sql-utils.js +16 -1
  167. package/dist/modules/data-table/utils/sql-utils.js.map +1 -1
  168. package/dist/modules/dynamic-credentials.ee/dynamic-credentials.module.js +15 -7
  169. package/dist/modules/dynamic-credentials.ee/dynamic-credentials.module.js.map +1 -1
  170. package/dist/modules/instance-ai/eval/execution.service.js +51 -32
  171. package/dist/modules/instance-ai/eval/execution.service.js.map +1 -1
  172. package/dist/modules/instance-ai/eval/mock-handler.js +77 -13
  173. package/dist/modules/instance-ai/eval/mock-handler.js.map +1 -1
  174. package/dist/modules/instance-ai/eval/mock-quirks.js +8 -1
  175. package/dist/modules/instance-ai/eval/mock-quirks.js.map +1 -1
  176. package/dist/modules/instance-ai/eval/workflow-analysis.js +2 -0
  177. package/dist/modules/instance-ai/eval/workflow-analysis.js.map +1 -1
  178. package/dist/modules/instance-ai/instance-ai.adapter.service.d.ts +5 -4
  179. package/dist/modules/instance-ai/instance-ai.adapter.service.js +7 -121
  180. package/dist/modules/instance-ai/instance-ai.adapter.service.js.map +1 -1
  181. package/dist/modules/instance-ai/instance-ai.controller.js +1 -1
  182. package/dist/modules/instance-ai/instance-ai.service.d.ts +5 -28
  183. package/dist/modules/instance-ai/instance-ai.service.js +58 -471
  184. package/dist/modules/instance-ai/instance-ai.service.js.map +1 -1
  185. package/dist/modules/instance-ai/output-redaction-config.d.ts +3 -0
  186. package/dist/modules/instance-ai/output-redaction-config.js +19 -0
  187. package/dist/modules/instance-ai/output-redaction-config.js.map +1 -0
  188. package/dist/modules/instance-ai/sandbox/index.d.ts +1 -0
  189. package/dist/modules/instance-ai/sandbox/index.js +6 -0
  190. package/dist/modules/instance-ai/sandbox/index.js.map +1 -0
  191. package/dist/modules/instance-ai/sandbox/instance-ai-sandbox.service.d.ts +77 -0
  192. package/dist/modules/instance-ai/sandbox/instance-ai-sandbox.service.js +297 -0
  193. package/dist/modules/instance-ai/sandbox/instance-ai-sandbox.service.js.map +1 -0
  194. package/dist/modules/instance-ai/suspended-run-restorer.service.d.ts +62 -0
  195. package/dist/modules/instance-ai/suspended-run-restorer.service.js +116 -0
  196. package/dist/modules/instance-ai/suspended-run-restorer.service.js.map +1 -0
  197. package/dist/modules/instance-ai/suspended-thread-persistence.service.d.ts +51 -0
  198. package/dist/modules/instance-ai/suspended-thread-persistence.service.js +106 -0
  199. package/dist/modules/instance-ai/suspended-thread-persistence.service.js.map +1 -0
  200. package/dist/modules/instance-ai/web-research/fetch-and-extract.d.ts +1 -1
  201. package/dist/modules/mcp/mcp-api-key.service.d.ts +3 -7
  202. package/dist/modules/mcp/mcp-api-key.service.js +1 -22
  203. package/dist/modules/mcp/mcp-api-key.service.js.map +1 -1
  204. package/dist/modules/mcp/mcp-protected-resource.d.ts +13 -0
  205. package/dist/modules/mcp/mcp-protected-resource.js +39 -0
  206. package/dist/modules/mcp/mcp-protected-resource.js.map +1 -0
  207. package/dist/modules/mcp/mcp-server-middleware.service.d.ts +5 -4
  208. package/dist/modules/mcp/mcp-server-middleware.service.js +9 -6
  209. package/dist/modules/mcp/mcp-server-middleware.service.js.map +1 -1
  210. package/dist/modules/mcp/mcp.errors.d.ts +0 -13
  211. package/dist/modules/mcp/mcp.errors.js +1 -27
  212. package/dist/modules/mcp/mcp.errors.js.map +1 -1
  213. package/dist/modules/mcp/mcp.module.d.ts +0 -1
  214. package/dist/modules/mcp/mcp.module.js +3 -11
  215. package/dist/modules/mcp/mcp.module.js.map +1 -1
  216. package/dist/modules/mcp/mcp.service.d.ts +5 -1
  217. package/dist/modules/mcp/mcp.service.js +16 -2
  218. package/dist/modules/mcp/mcp.service.js.map +1 -1
  219. package/dist/modules/mcp/mcp.types.d.ts +6 -14
  220. package/dist/modules/mcp/mcp.types.js.map +1 -1
  221. package/dist/modules/mcp/tools/get-workflow-details.tool.js +1 -1
  222. package/dist/modules/mcp/tools/get-workflow-details.tool.js.map +1 -1
  223. package/dist/modules/mcp/tools/list-tags.tool.d.ts +26 -0
  224. package/dist/modules/mcp/tools/list-tags.tool.js +91 -0
  225. package/dist/modules/mcp/tools/list-tags.tool.js.map +1 -0
  226. package/dist/modules/mcp/tools/schemas.d.ts +7 -0
  227. package/dist/modules/mcp/tools/schemas.js +3 -1
  228. package/dist/modules/mcp/tools/schemas.js.map +1 -1
  229. package/dist/modules/mcp/tools/search-workflows.tool.d.ts +2 -1
  230. package/dist/modules/mcp/tools/search-workflows.tool.js +14 -4
  231. package/dist/modules/mcp/tools/search-workflows.tool.js.map +1 -1
  232. package/dist/modules/mcp/tools/workflow-builder/constants.d.ts +1 -1
  233. package/dist/modules/mcp/tools/workflow-builder/constants.js +2 -1
  234. package/dist/modules/mcp/tools/workflow-builder/constants.js.map +1 -1
  235. package/dist/modules/mcp/tools/workflow-builder/create-workflow-from-code.tool.js +24 -6
  236. package/dist/modules/mcp/tools/workflow-builder/create-workflow-from-code.tool.js.map +1 -1
  237. package/dist/modules/mcp/tools/workflow-builder/explore-node-resources.tool.d.ts +18 -0
  238. package/dist/modules/mcp/tools/workflow-builder/explore-node-resources.tool.js +119 -0
  239. package/dist/modules/mcp/tools/workflow-builder/explore-node-resources.tool.js.map +1 -0
  240. package/dist/modules/mcp/tools/workflow-builder/get-workflow-node-types.tool.d.ts +2 -2
  241. package/dist/modules/mcp/tools/workflow-builder/get-workflow-node-types.tool.js +4 -4
  242. package/dist/modules/mcp/tools/workflow-builder/get-workflow-node-types.tool.js.map +1 -1
  243. package/dist/modules/mcp/tools/workflow-builder/mcp-instructions.js +8 -6
  244. package/dist/modules/mcp/tools/workflow-builder/mcp-instructions.js.map +1 -1
  245. package/dist/modules/mcp/tools/workflow-builder/search-workflow-nodes.tool.js +1 -1
  246. package/dist/modules/mcp/tools/workflow-builder/search-workflow-nodes.tool.js.map +1 -1
  247. package/dist/modules/mcp/tools/workflow-builder/update-workflow.tool.d.ts +4 -294
  248. package/dist/modules/mcp/tools/workflow-builder/update-workflow.tool.js +137 -16
  249. package/dist/modules/mcp/tools/workflow-builder/update-workflow.tool.js.map +1 -1
  250. package/dist/modules/mcp/tools/workflow-builder/workflow-operations.d.ts +23 -1
  251. package/dist/modules/mcp/tools/workflow-builder/workflow-operations.js +54 -2
  252. package/dist/modules/mcp/tools/workflow-builder/workflow-operations.js.map +1 -1
  253. package/dist/modules/mcp/tools/workflow-validation.utils.d.ts +1 -0
  254. package/dist/modules/mcp/tools/workflow-validation.utils.js +1 -0
  255. package/dist/modules/mcp/tools/workflow-validation.utils.js.map +1 -1
  256. package/dist/modules/mcp-registry/node-description-transform.js +6 -0
  257. package/dist/modules/mcp-registry/node-description-transform.js.map +1 -1
  258. package/dist/modules/n8n-packages/engine/import-blocked.error.d.ts +4 -0
  259. package/dist/modules/n8n-packages/engine/import-blocked.error.js +14 -0
  260. package/dist/modules/n8n-packages/engine/import-blocked.error.js.map +1 -0
  261. package/dist/modules/n8n-packages/engine/import-pipeline.d.ts +9 -7
  262. package/dist/modules/n8n-packages/engine/import-pipeline.js +57 -113
  263. package/dist/modules/n8n-packages/engine/import-pipeline.js.map +1 -1
  264. package/dist/modules/n8n-packages/engine/n8n-package-parser.d.ts +11 -0
  265. package/dist/modules/n8n-packages/engine/n8n-package-parser.js +114 -0
  266. package/dist/modules/n8n-packages/engine/n8n-package-parser.js.map +1 -0
  267. package/dist/modules/n8n-packages/entities/credential/credential-importer.d.ts +4 -5
  268. package/dist/modules/n8n-packages/entities/credential/credential-importer.js +9 -12
  269. package/dist/modules/n8n-packages/entities/credential/credential-importer.js.map +1 -1
  270. package/dist/modules/n8n-packages/entities/credential/credential-matcher.d.ts +1 -0
  271. package/dist/modules/n8n-packages/entities/credential/credential-matcher.js +27 -2
  272. package/dist/modules/n8n-packages/entities/credential/credential-matcher.js.map +1 -1
  273. package/dist/modules/n8n-packages/entities/credential/credential-missing-mode.d.ts +3 -7
  274. package/dist/modules/n8n-packages/entities/credential/credential-missing-mode.js +6 -13
  275. package/dist/modules/n8n-packages/entities/credential/credential-missing-mode.js.map +1 -1
  276. package/dist/modules/n8n-packages/entities/credential/credential.types.d.ts +3 -10
  277. package/dist/modules/n8n-packages/entities/credential/credential.types.js +0 -4
  278. package/dist/modules/n8n-packages/entities/credential/credential.types.js.map +1 -1
  279. package/dist/modules/n8n-packages/entities/credential/id-based-credential-matcher.js +11 -6
  280. package/dist/modules/n8n-packages/entities/credential/id-based-credential-matcher.js.map +1 -1
  281. package/dist/modules/n8n-packages/entities/workflow/workflow-conflict-policy.d.ts +4 -0
  282. package/dist/modules/n8n-packages/entities/workflow/workflow-conflict-policy.js +12 -0
  283. package/dist/modules/n8n-packages/entities/workflow/workflow-conflict-policy.js.map +1 -0
  284. package/dist/modules/n8n-packages/entities/workflow/workflow-id-policy.d.ts +2 -0
  285. package/dist/modules/n8n-packages/entities/workflow/workflow-id-policy.js +12 -0
  286. package/dist/modules/n8n-packages/entities/workflow/workflow-id-policy.js.map +1 -0
  287. package/dist/modules/n8n-packages/entities/workflow/workflow-import-match.service.d.ts +15 -2
  288. package/dist/modules/n8n-packages/entities/workflow/workflow-import-match.service.js +18 -2
  289. package/dist/modules/n8n-packages/entities/workflow/workflow-import-match.service.js.map +1 -1
  290. package/dist/modules/n8n-packages/entities/workflow/workflow-import.types.d.ts +47 -0
  291. package/dist/modules/n8n-packages/entities/workflow/{workflow-conflict-policy.types.js → workflow-import.types.js} +1 -1
  292. package/dist/modules/n8n-packages/entities/workflow/workflow-import.types.js.map +1 -0
  293. package/dist/modules/n8n-packages/entities/workflow/workflow-importer.d.ts +14 -6
  294. package/dist/modules/n8n-packages/entities/workflow/workflow-importer.js +136 -19
  295. package/dist/modules/n8n-packages/entities/workflow/workflow-importer.js.map +1 -1
  296. package/dist/modules/n8n-packages/entities/workflow/workflow-publisher.d.ts +16 -0
  297. package/dist/modules/n8n-packages/entities/workflow/workflow-publisher.js +87 -0
  298. package/dist/modules/n8n-packages/entities/workflow/workflow-publisher.js.map +1 -0
  299. package/dist/modules/n8n-packages/entities/workflow/workflow-publishing-policy.d.ts +2 -0
  300. package/dist/modules/n8n-packages/entities/workflow/workflow-publishing-policy.js +28 -0
  301. package/dist/modules/n8n-packages/entities/workflow/workflow-publishing-policy.js.map +1 -0
  302. package/dist/modules/n8n-packages/entities/workflow/workflow-publishing-policy.types.d.ts +14 -0
  303. package/dist/modules/n8n-packages/entities/workflow/workflow-publishing-policy.types.js +10 -0
  304. package/dist/modules/n8n-packages/entities/workflow/workflow-publishing-policy.types.js.map +1 -0
  305. package/dist/modules/n8n-packages/entities/workflow/workflow.serializer.js +1 -1
  306. package/dist/modules/n8n-packages/entities/workflow/workflow.serializer.js.map +1 -1
  307. package/dist/modules/n8n-packages/io/tar/tar-package-reader.d.ts +10 -3
  308. package/dist/modules/n8n-packages/io/tar/tar-package-reader.js +103 -20
  309. package/dist/modules/n8n-packages/io/tar/tar-package-reader.js.map +1 -1
  310. package/dist/modules/n8n-packages/n8n-packages.config.d.ts +6 -0
  311. package/dist/modules/n8n-packages/n8n-packages.config.js +43 -0
  312. package/dist/modules/n8n-packages/n8n-packages.config.js.map +1 -0
  313. package/dist/modules/n8n-packages/n8n-packages.controller.js +0 -1
  314. package/dist/modules/n8n-packages/n8n-packages.controller.js.map +1 -1
  315. package/dist/modules/n8n-packages/n8n-packages.module.js +0 -2
  316. package/dist/modules/n8n-packages/n8n-packages.module.js.map +1 -1
  317. package/dist/modules/n8n-packages/n8n-packages.types.d.ts +41 -7
  318. package/dist/modules/n8n-packages/n8n-packages.types.js +7 -1
  319. package/dist/modules/n8n-packages/n8n-packages.types.js.map +1 -1
  320. package/dist/modules/n8n-packages/spec/serialized/workflow.schema.d.ts +3 -3
  321. package/dist/modules/n8n-packages/spec/serialized/workflow.schema.js +1 -1
  322. package/dist/modules/n8n-packages/spec/serialized/workflow.schema.js.map +1 -1
  323. package/dist/modules/n8n-packages/utils/import-package-upload.js +2 -2
  324. package/dist/modules/n8n-packages/utils/import-package-upload.js.map +1 -1
  325. package/dist/modules/oauth-server/database/entities/oauth-access-token.entity.js.map +1 -0
  326. package/dist/modules/oauth-server/database/entities/oauth-authorization-code.entity.js.map +1 -0
  327. package/dist/modules/oauth-server/database/entities/oauth-client.entity.js.map +1 -0
  328. package/dist/modules/oauth-server/database/entities/oauth-refresh-token.entity.js.map +1 -0
  329. package/dist/modules/oauth-server/database/entities/oauth-user-consent.entity.js.map +1 -0
  330. package/dist/modules/oauth-server/database/repositories/oauth-access-token.repository.js.map +1 -0
  331. package/dist/modules/oauth-server/database/repositories/oauth-authorization-code.repository.js.map +1 -0
  332. package/dist/modules/oauth-server/database/repositories/oauth-client.repository.js.map +1 -0
  333. package/dist/modules/oauth-server/database/repositories/oauth-refresh-token.repository.js.map +1 -0
  334. package/dist/modules/oauth-server/database/repositories/oauth-user-consent.repository.js.map +1 -0
  335. package/dist/modules/oauth-server/dto/approve-consent-request.dto.js.map +1 -0
  336. package/dist/modules/{mcp/mcp-oauth-authorization-code.service.d.ts → oauth-server/oauth-authorization-code.service.d.ts} +1 -1
  337. package/dist/modules/{mcp/mcp-oauth-authorization-code.service.js → oauth-server/oauth-authorization-code.service.js} +12 -12
  338. package/dist/modules/oauth-server/oauth-authorization-code.service.js.map +1 -0
  339. package/dist/modules/{mcp/mcp.oauth-clients.controller.d.ts → oauth-server/oauth-clients.controller.d.ts} +4 -4
  340. package/dist/modules/{mcp/mcp.oauth-clients.controller.js → oauth-server/oauth-clients.controller.js} +16 -16
  341. package/dist/modules/oauth-server/oauth-clients.controller.js.map +1 -0
  342. package/dist/modules/{mcp/mcp.auth.consent.controller.d.ts → oauth-server/oauth-consent.controller.d.ts} +3 -3
  343. package/dist/modules/{mcp/mcp.auth.consent.controller.js → oauth-server/oauth-consent.controller.js} +16 -10
  344. package/dist/modules/oauth-server/oauth-consent.controller.js.map +1 -0
  345. package/dist/modules/{mcp/mcp-oauth-consent.service.d.ts → oauth-server/oauth-consent.service.d.ts} +16 -7
  346. package/dist/modules/{mcp/mcp-oauth-consent.service.js → oauth-server/oauth-consent.service.js} +28 -12
  347. package/dist/modules/oauth-server/oauth-consent.service.js.map +1 -0
  348. package/dist/modules/oauth-server/oauth-server.module.d.ts +5 -0
  349. package/dist/modules/oauth-server/oauth-server.module.js +75 -0
  350. package/dist/modules/oauth-server/oauth-server.module.js.map +1 -0
  351. package/dist/modules/{mcp/mcp-oauth-service.d.ts → oauth-server/oauth-server.service.d.ts} +6 -6
  352. package/dist/modules/{mcp/mcp-oauth-service.js → oauth-server/oauth-server.service.js} +33 -30
  353. package/dist/modules/oauth-server/oauth-server.service.js.map +1 -0
  354. package/dist/modules/oauth-server/oauth-session.service.js.map +1 -0
  355. package/dist/modules/{mcp/mcp-oauth-token.service.d.ts → oauth-server/oauth-token.service.d.ts} +5 -8
  356. package/dist/modules/{mcp/mcp-oauth-token.service.js → oauth-server/oauth-token.service.js} +29 -30
  357. package/dist/modules/oauth-server/oauth-token.service.js.map +1 -0
  358. package/dist/modules/{mcp/mcp.oauth.controller.d.ts → oauth-server/oauth.controller.d.ts} +5 -3
  359. package/dist/modules/{mcp/mcp.oauth.controller.js → oauth-server/oauth.controller.js} +79 -68
  360. package/dist/modules/oauth-server/oauth.controller.js.map +1 -0
  361. package/dist/modules/oauth-server/oauth.errors.d.ts +13 -0
  362. package/dist/modules/oauth-server/oauth.errors.js +30 -0
  363. package/dist/modules/oauth-server/oauth.errors.js.map +1 -0
  364. package/dist/modules/{mcp/mcp-oauth.helpers.d.ts → oauth-server/oauth.helpers.d.ts} +1 -1
  365. package/dist/modules/{mcp/mcp-oauth.helpers.js → oauth-server/oauth.helpers.js} +4 -4
  366. package/dist/modules/oauth-server/oauth.helpers.js.map +1 -0
  367. package/dist/modules/oauth-server/protected-resource-resolvers/utils.d.ts +4 -0
  368. package/dist/modules/oauth-server/protected-resource-resolvers/utils.js +41 -0
  369. package/dist/modules/oauth-server/protected-resource-resolvers/utils.js.map +1 -0
  370. package/dist/modules/oauth-server/protected-resource-resolvers/workflow-mcp-test-trigger-resource.resolver.d.ts +28 -0
  371. package/dist/modules/oauth-server/protected-resource-resolvers/workflow-mcp-test-trigger-resource.resolver.js +78 -0
  372. package/dist/modules/oauth-server/protected-resource-resolvers/workflow-mcp-test-trigger-resource.resolver.js.map +1 -0
  373. package/dist/modules/oauth-server/protected-resource-resolvers/workflow-mcp-trigger-resource.resolver.d.ts +30 -0
  374. package/dist/modules/oauth-server/protected-resource-resolvers/workflow-mcp-trigger-resource.resolver.js +95 -0
  375. package/dist/modules/oauth-server/protected-resource-resolvers/workflow-mcp-trigger-resource.resolver.js.map +1 -0
  376. package/dist/modules/otel/execution-level-tracer.d.ts +5 -4
  377. package/dist/modules/otel/execution-level-tracer.js +8 -5
  378. package/dist/modules/otel/execution-level-tracer.js.map +1 -1
  379. package/dist/modules/otel/otel-lifecycle-handler.d.ts +8 -4
  380. package/dist/modules/otel/otel-lifecycle-handler.js +32 -15
  381. package/dist/modules/otel/otel-lifecycle-handler.js.map +1 -1
  382. package/dist/modules/otel/otel-settings.controller.d.ts +18 -0
  383. package/dist/modules/otel/otel-settings.controller.js +79 -0
  384. package/dist/modules/otel/otel-settings.controller.js.map +1 -0
  385. package/dist/modules/otel/otel-settings.service.d.ts +21 -0
  386. package/dist/modules/otel/otel-settings.service.js +89 -0
  387. package/dist/modules/otel/otel-settings.service.js.map +1 -0
  388. package/dist/modules/otel/otel.config.js +11 -10
  389. package/dist/modules/otel/otel.config.js.map +1 -1
  390. package/dist/modules/otel/otel.constants.d.ts +14 -0
  391. package/dist/modules/otel/otel.constants.js +15 -1
  392. package/dist/modules/otel/otel.constants.js.map +1 -1
  393. package/dist/modules/otel/otel.module.js +9 -17
  394. package/dist/modules/otel/otel.module.js.map +1 -1
  395. package/dist/modules/otel/otel.service.d.ts +15 -4
  396. package/dist/modules/otel/otel.service.js +73 -17
  397. package/dist/modules/otel/otel.service.js.map +1 -1
  398. package/dist/modules/provisioning.ee/role-mapping-rule.service.ee.d.ts +1 -0
  399. package/dist/modules/provisioning.ee/role-mapping-rule.service.ee.js +46 -19
  400. package/dist/modules/provisioning.ee/role-mapping-rule.service.ee.js.map +1 -1
  401. package/dist/modules/redaction/instance-redaction-enforcement.service.js +0 -6
  402. package/dist/modules/redaction/instance-redaction-enforcement.service.js.map +1 -1
  403. package/dist/modules/source-control.ee/source-control-git.service.ee.js +2 -5
  404. package/dist/modules/source-control.ee/source-control-git.service.ee.js.map +1 -1
  405. package/dist/modules/sso-saml/saml.service.ee.js +3 -2
  406. package/dist/modules/sso-saml/saml.service.ee.js.map +1 -1
  407. package/dist/modules/workflow-index/workflow-dependency-query.service.js +39 -20
  408. package/dist/modules/workflow-index/workflow-dependency-query.service.js.map +1 -1
  409. package/dist/oauth/oauth.service.d.ts +14 -0
  410. package/dist/oauth/oauth.service.js +220 -102
  411. package/dist/oauth/oauth.service.js.map +1 -1
  412. package/dist/oauth/types.d.ts +1 -0
  413. package/dist/oauth/types.js.map +1 -1
  414. package/dist/public-api/index.js +8 -8
  415. package/dist/public-api/index.js.map +1 -1
  416. package/dist/public-api/types.d.ts +1 -6
  417. package/dist/public-api/v1/handlers/credentials/credentials.service.js +7 -8
  418. package/dist/public-api/v1/handlers/credentials/credentials.service.js.map +1 -1
  419. package/dist/public-api/v1/handlers/executions/executions.handler.js +1 -1
  420. package/dist/public-api/v1/handlers/executions/executions.handler.js.map +1 -1
  421. package/dist/public-api/v1/handlers/n8n-packages/n8n-packages.handler.js +3 -3
  422. package/dist/public-api/v1/handlers/n8n-packages/n8n-packages.handler.js.map +1 -1
  423. package/dist/public-api/v1/openapi.yml +208 -51
  424. package/dist/push/abstract.push.d.ts +1 -2
  425. package/dist/push/abstract.push.js +1 -2
  426. package/dist/push/abstract.push.js.map +1 -1
  427. package/dist/push/index.d.ts +1 -2
  428. package/dist/push/index.js +3 -4
  429. package/dist/push/index.js.map +1 -1
  430. package/dist/scaling/constants.d.ts +2 -2
  431. package/dist/scaling/constants.js +1 -0
  432. package/dist/scaling/constants.js.map +1 -1
  433. package/dist/scaling/job-processor.d.ts +0 -1
  434. package/dist/scaling/job-processor.js +1 -23
  435. package/dist/scaling/job-processor.js.map +1 -1
  436. package/dist/scaling/multi-main-setup.ee.d.ts +1 -2
  437. package/dist/scaling/multi-main-setup.ee.js +1 -2
  438. package/dist/scaling/multi-main-setup.ee.js.map +1 -1
  439. package/dist/scaling/pubsub/pubsub.event-map.d.ts +7 -0
  440. package/dist/scaling/pubsub/pubsub.eventbus.d.ts +1 -1
  441. package/dist/scaling/pubsub/pubsub.eventbus.js +2 -2
  442. package/dist/scaling/pubsub/pubsub.eventbus.js.map +1 -1
  443. package/dist/scaling/pubsub/pubsub.types.d.ts +3 -1
  444. package/dist/scaling/worker-server.d.ts +1 -1
  445. package/dist/scaling/worker-server.js +5 -5
  446. package/dist/scaling/worker-server.js.map +1 -1
  447. package/dist/server.js +4 -3
  448. package/dist/server.js.map +1 -1
  449. package/dist/services/ai-workflow-builder.service.d.ts +2 -1
  450. package/dist/services/ai-workflow-builder.service.js +2 -1
  451. package/dist/services/ai-workflow-builder.service.js.map +1 -1
  452. package/dist/services/cache/cache.service.d.ts +1 -1
  453. package/dist/services/cache/cache.service.js +2 -2
  454. package/dist/services/cache/cache.service.js.map +1 -1
  455. package/dist/services/node-resource-explorer.service.d.ts +16 -0
  456. package/dist/services/node-resource-explorer.service.js +154 -0
  457. package/dist/services/node-resource-explorer.service.js.map +1 -0
  458. package/dist/services/oauth-token-verifier-proxy.service.d.ts +22 -0
  459. package/dist/services/oauth-token-verifier-proxy.service.js +36 -0
  460. package/dist/services/oauth-token-verifier-proxy.service.js.map +1 -0
  461. package/dist/services/protected-resource.registry.d.ts +31 -0
  462. package/dist/services/protected-resource.registry.js +115 -0
  463. package/dist/services/protected-resource.registry.js.map +1 -0
  464. package/dist/services/public-api-key.service.d.ts +8 -2
  465. package/dist/services/public-api-key.service.js +29 -6
  466. package/dist/services/public-api-key.service.js.map +1 -1
  467. package/dist/services/redis-client.service.d.ts +2 -2
  468. package/dist/services/redis-client.service.js +6 -4
  469. package/dist/services/redis-client.service.js.map +1 -1
  470. package/dist/services/tag.service.d.ts +10 -0
  471. package/dist/services/tag.service.js +84 -4
  472. package/dist/services/tag.service.js.map +1 -1
  473. package/dist/services/workflow-statistics.service.d.ts +1 -2
  474. package/dist/services/workflow-statistics.service.js +1 -2
  475. package/dist/services/workflow-statistics.service.js.map +1 -1
  476. package/dist/task-runners/sliding-window-signal.d.ts +1 -1
  477. package/dist/task-runners/task-runner-lifecycle-events.d.ts +1 -1
  478. package/dist/task-runners/task-runner-lifecycle-events.js +2 -2
  479. package/dist/task-runners/task-runner-lifecycle-events.js.map +1 -1
  480. package/dist/task-runners/task-runner-process-base.d.ts +1 -2
  481. package/dist/task-runners/task-runner-process-base.js +1 -2
  482. package/dist/task-runners/task-runner-process-base.js.map +1 -1
  483. package/dist/task-runners/task-runner-process-restart-loop-detector.d.ts +1 -1
  484. package/dist/task-runners/task-runner-process-restart-loop-detector.js +2 -2
  485. package/dist/task-runners/task-runner-process-restart-loop-detector.js.map +1 -1
  486. package/dist/user-management/email/templates/api-key-revoked.handlebars +196 -0
  487. package/dist/user-management/email/user-management-mailer.d.ts +6 -2
  488. package/dist/user-management/email/user-management-mailer.js +32 -0
  489. package/dist/user-management/email/user-management-mailer.js.map +1 -1
  490. package/dist/wait-tracker.d.ts +1 -1
  491. package/dist/wait-tracker.js +3 -3
  492. package/dist/wait-tracker.js.map +1 -1
  493. package/dist/webhooks/webhook-helpers.js +30 -1
  494. package/dist/webhooks/webhook-helpers.js.map +1 -1
  495. package/dist/webhooks/webhook-server.js +2 -2
  496. package/dist/webhooks/webhook-server.js.map +1 -1
  497. package/dist/webhooks/webhook.service.d.ts +4 -1
  498. package/dist/webhooks/webhook.service.js +19 -4
  499. package/dist/webhooks/webhook.service.js.map +1 -1
  500. package/dist/workflow-execute-additional-data.d.ts +1 -1
  501. package/dist/workflow-execute-additional-data.js +4 -1
  502. package/dist/workflow-execute-additional-data.js.map +1 -1
  503. package/dist/workflow-helpers.d.ts +1 -1
  504. package/dist/workflow-helpers.js +13 -3
  505. package/dist/workflow-helpers.js.map +1 -1
  506. package/dist/workflow-runner.js +0 -2
  507. package/dist/workflow-runner.js.map +1 -1
  508. package/dist/workflows/publication/publication-result.d.ts +17 -0
  509. package/dist/workflows/publication/publication-result.js +3 -0
  510. package/dist/workflows/publication/publication-result.js.map +1 -0
  511. package/dist/workflows/publication/publication-status-reporter.d.ts +19 -0
  512. package/dist/workflows/publication/publication-status-reporter.js +110 -0
  513. package/dist/workflows/publication/publication-status-reporter.js.map +1 -0
  514. package/dist/workflows/publication/trigger-diff.d.ts +6 -0
  515. package/dist/workflows/publication/trigger-diff.js +27 -0
  516. package/dist/workflows/publication/trigger-diff.js.map +1 -0
  517. package/dist/workflows/publication/workflow-publication-applier.d.ts +14 -0
  518. package/dist/workflows/publication/workflow-publication-applier.js +96 -0
  519. package/dist/workflows/publication/workflow-publication-applier.js.map +1 -0
  520. package/dist/workflows/{workflow-publication-outbox-consumer.d.ts → publication/workflow-publication-outbox-consumer.d.ts} +9 -13
  521. package/dist/workflows/{workflow-publication-outbox-consumer.js → publication/workflow-publication-outbox-consumer.js} +25 -93
  522. package/dist/workflows/publication/workflow-publication-outbox-consumer.js.map +1 -0
  523. package/dist/workflows/triggers/non-webhook-trigger-registrar.d.ts +39 -0
  524. package/dist/workflows/triggers/non-webhook-trigger-registrar.js +58 -0
  525. package/dist/workflows/triggers/non-webhook-trigger-registrar.js.map +1 -0
  526. package/dist/workflows/triggers/trigger-count.service.d.ts +5 -0
  527. package/dist/workflows/triggers/trigger-count.service.js +65 -0
  528. package/dist/workflows/triggers/trigger-count.service.js.map +1 -0
  529. package/dist/workflows/triggers/trigger-execution-context.factory.d.ts +33 -0
  530. package/dist/workflows/triggers/trigger-execution-context.factory.js +171 -0
  531. package/dist/workflows/triggers/trigger-execution-context.factory.js.map +1 -0
  532. package/dist/workflows/triggers/webhook-trigger-registrar.d.ts +29 -0
  533. package/dist/workflows/triggers/webhook-trigger-registrar.js +143 -0
  534. package/dist/workflows/triggers/webhook-trigger-registrar.js.map +1 -0
  535. package/dist/workflows/triggers/workflow-trigger-activator.d.ts +56 -0
  536. package/dist/workflows/triggers/workflow-trigger-activator.js +313 -0
  537. package/dist/workflows/triggers/workflow-trigger-activator.js.map +1 -0
  538. package/dist/workflows/workflow-validation.service.d.ts +3 -0
  539. package/dist/workflows/workflow-validation.service.js +63 -37
  540. package/dist/workflows/workflow-validation.service.js.map +1 -1
  541. package/dist/workflows/workflow.service.d.ts +5 -3
  542. package/dist/workflows/workflow.service.js +91 -28
  543. package/dist/workflows/workflow.service.js.map +1 -1
  544. package/dist/workflows/workflows.controller.d.ts +3 -3
  545. package/dist/workflows/workflows.controller.js +3 -3
  546. package/dist/workflows/workflows.controller.js.map +1 -1
  547. package/package.json +34 -33
  548. package/templates/oauth-callback.handlebars +3 -0
  549. package/templates/oauth-error-callback.handlebars +3 -0
  550. package/dist/metrics/prometheus-metrics.service.d.ts +0 -54
  551. package/dist/metrics/prometheus-metrics.service.js +0 -607
  552. package/dist/metrics/prometheus-metrics.service.js.map +0 -1
  553. package/dist/metrics/types.d.ts +0 -6
  554. package/dist/metrics/types.js.map +0 -1
  555. package/dist/modules/agents/agent-knowledge-command.service.d.ts +0 -40
  556. package/dist/modules/agents/agent-knowledge-command.service.js +0 -221
  557. package/dist/modules/agents/agent-knowledge-command.service.js.map +0 -1
  558. package/dist/modules/agents/entities/agent-file.entity.d.ts +0 -11
  559. package/dist/modules/agents/entities/agent-file.entity.js.map +0 -1
  560. package/dist/modules/agents/repositories/agent-file.repository.d.ts +0 -7
  561. package/dist/modules/agents/repositories/agent-file.repository.js +0 -35
  562. package/dist/modules/agents/repositories/agent-file.repository.js.map +0 -1
  563. package/dist/modules/agents/tools/knowledge/csv-helpers.d.ts +0 -73
  564. package/dist/modules/agents/tools/knowledge/csv-helpers.js +0 -341
  565. package/dist/modules/agents/tools/knowledge/csv-helpers.js.map +0 -1
  566. package/dist/modules/agents/tools/knowledge/csv.operation.d.ts +0 -61
  567. package/dist/modules/agents/tools/knowledge/csv.operation.js +0 -207
  568. package/dist/modules/agents/tools/knowledge/csv.operation.js.map +0 -1
  569. package/dist/modules/agents/tools/knowledge/file-references.d.ts +0 -16
  570. package/dist/modules/agents/tools/knowledge/file-references.js +0 -35
  571. package/dist/modules/agents/tools/knowledge/file-references.js.map +0 -1
  572. package/dist/modules/agents/tools/knowledge/read.operation.d.ts +0 -8
  573. package/dist/modules/agents/tools/knowledge/read.operation.js +0 -38
  574. package/dist/modules/agents/tools/knowledge/read.operation.js.map +0 -1
  575. package/dist/modules/agents/tools/knowledge/schemas.d.ts +0 -1505
  576. package/dist/modules/agents/tools/knowledge/schemas.js +0 -441
  577. package/dist/modules/agents/tools/knowledge/schemas.js.map +0 -1
  578. package/dist/modules/agents/tools/knowledge/search.operation.d.ts +0 -9
  579. package/dist/modules/agents/tools/knowledge/search.operation.js +0 -332
  580. package/dist/modules/agents/tools/knowledge/search.operation.js.map +0 -1
  581. package/dist/modules/agents/tools/knowledge/tool.d.ts +0 -8
  582. package/dist/modules/agents/tools/knowledge/tool.js +0 -121
  583. package/dist/modules/agents/tools/knowledge/tool.js.map +0 -1
  584. package/dist/modules/mcp/database/entities/oauth-access-token.entity.js.map +0 -1
  585. package/dist/modules/mcp/database/entities/oauth-authorization-code.entity.js.map +0 -1
  586. package/dist/modules/mcp/database/entities/oauth-client.entity.js.map +0 -1
  587. package/dist/modules/mcp/database/entities/oauth-refresh-token.entity.js.map +0 -1
  588. package/dist/modules/mcp/database/entities/oauth-user-consent.entity.js.map +0 -1
  589. package/dist/modules/mcp/database/repositories/oauth-access-token.repository.js.map +0 -1
  590. package/dist/modules/mcp/database/repositories/oauth-authorization-code.repository.js.map +0 -1
  591. package/dist/modules/mcp/database/repositories/oauth-client.repository.js.map +0 -1
  592. package/dist/modules/mcp/database/repositories/oauth-refresh-token.repository.js.map +0 -1
  593. package/dist/modules/mcp/database/repositories/oauth-user-consent.repository.js.map +0 -1
  594. package/dist/modules/mcp/dto/approve-consent-request.dto.js.map +0 -1
  595. package/dist/modules/mcp/mcp-oauth-authorization-code.service.js.map +0 -1
  596. package/dist/modules/mcp/mcp-oauth-consent.service.js.map +0 -1
  597. package/dist/modules/mcp/mcp-oauth-service.js.map +0 -1
  598. package/dist/modules/mcp/mcp-oauth-token.service.js.map +0 -1
  599. package/dist/modules/mcp/mcp-oauth.helpers.js.map +0 -1
  600. package/dist/modules/mcp/mcp.auth.consent.controller.js.map +0 -1
  601. package/dist/modules/mcp/mcp.oauth-clients.controller.js.map +0 -1
  602. package/dist/modules/mcp/mcp.oauth.controller.js.map +0 -1
  603. package/dist/modules/mcp/oauth-session.service.js.map +0 -1
  604. package/dist/modules/n8n-packages/entities/credential/credential-missing-mode-factory.d.ts +0 -7
  605. package/dist/modules/n8n-packages/entities/credential/credential-missing-mode-factory.js +0 -35
  606. package/dist/modules/n8n-packages/entities/credential/credential-missing-mode-factory.js.map +0 -1
  607. package/dist/modules/n8n-packages/entities/credential/credential-resolution-error.d.ts +0 -3
  608. package/dist/modules/n8n-packages/entities/credential/credential-resolution-error.js +0 -14
  609. package/dist/modules/n8n-packages/entities/credential/credential-resolution-error.js.map +0 -1
  610. package/dist/modules/n8n-packages/entities/workflow/workflow-conflict-policy-fail.handler.d.ts +0 -9
  611. package/dist/modules/n8n-packages/entities/workflow/workflow-conflict-policy-fail.handler.js +0 -41
  612. package/dist/modules/n8n-packages/entities/workflow/workflow-conflict-policy-fail.handler.js.map +0 -1
  613. package/dist/modules/n8n-packages/entities/workflow/workflow-conflict-policy-handler.d.ts +0 -10
  614. package/dist/modules/n8n-packages/entities/workflow/workflow-conflict-policy-handler.js +0 -20
  615. package/dist/modules/n8n-packages/entities/workflow/workflow-conflict-policy-handler.js.map +0 -1
  616. package/dist/modules/n8n-packages/entities/workflow/workflow-conflict-policy-new-version.handler.d.ts +0 -11
  617. package/dist/modules/n8n-packages/entities/workflow/workflow-conflict-policy-new-version.handler.js +0 -42
  618. package/dist/modules/n8n-packages/entities/workflow/workflow-conflict-policy-new-version.handler.js.map +0 -1
  619. package/dist/modules/n8n-packages/entities/workflow/workflow-conflict-policy-skip.handler.d.ts +0 -9
  620. package/dist/modules/n8n-packages/entities/workflow/workflow-conflict-policy-skip.handler.js +0 -33
  621. package/dist/modules/n8n-packages/entities/workflow/workflow-conflict-policy-skip.handler.js.map +0 -1
  622. package/dist/modules/n8n-packages/entities/workflow/workflow-conflict-policy.factory.d.ts +0 -10
  623. package/dist/modules/n8n-packages/entities/workflow/workflow-conflict-policy.factory.js +0 -37
  624. package/dist/modules/n8n-packages/entities/workflow/workflow-conflict-policy.factory.js.map +0 -1
  625. package/dist/modules/n8n-packages/entities/workflow/workflow-conflict-policy.types.d.ts +0 -20
  626. package/dist/modules/n8n-packages/entities/workflow/workflow-conflict-policy.types.js.map +0 -1
  627. package/dist/modules/redaction/redaction-enforcement.feature-flag.d.ts +0 -2
  628. package/dist/modules/redaction/redaction-enforcement.feature-flag.js +0 -9
  629. package/dist/modules/redaction/redaction-enforcement.feature-flag.js.map +0 -1
  630. package/dist/typed-emitter.d.ts +0 -14
  631. package/dist/typed-emitter.js +0 -29
  632. package/dist/typed-emitter.js.map +0 -1
  633. package/dist/workflows/workflow-publication-outbox-consumer.js.map +0 -1
  634. /package/dist/modules/{mcp → oauth-server}/database/entities/oauth-access-token.entity.d.ts +0 -0
  635. /package/dist/modules/{mcp → oauth-server}/database/entities/oauth-access-token.entity.js +0 -0
  636. /package/dist/modules/{mcp → oauth-server}/database/entities/oauth-authorization-code.entity.d.ts +0 -0
  637. /package/dist/modules/{mcp → oauth-server}/database/entities/oauth-authorization-code.entity.js +0 -0
  638. /package/dist/modules/{mcp → oauth-server}/database/entities/oauth-client.entity.d.ts +0 -0
  639. /package/dist/modules/{mcp → oauth-server}/database/entities/oauth-client.entity.js +0 -0
  640. /package/dist/modules/{mcp → oauth-server}/database/entities/oauth-refresh-token.entity.d.ts +0 -0
  641. /package/dist/modules/{mcp → oauth-server}/database/entities/oauth-refresh-token.entity.js +0 -0
  642. /package/dist/modules/{mcp → oauth-server}/database/entities/oauth-user-consent.entity.d.ts +0 -0
  643. /package/dist/modules/{mcp → oauth-server}/database/entities/oauth-user-consent.entity.js +0 -0
  644. /package/dist/modules/{mcp → oauth-server}/database/repositories/oauth-access-token.repository.d.ts +0 -0
  645. /package/dist/modules/{mcp → oauth-server}/database/repositories/oauth-access-token.repository.js +0 -0
  646. /package/dist/modules/{mcp → oauth-server}/database/repositories/oauth-authorization-code.repository.d.ts +0 -0
  647. /package/dist/modules/{mcp → oauth-server}/database/repositories/oauth-authorization-code.repository.js +0 -0
  648. /package/dist/modules/{mcp → oauth-server}/database/repositories/oauth-client.repository.d.ts +0 -0
  649. /package/dist/modules/{mcp → oauth-server}/database/repositories/oauth-client.repository.js +0 -0
  650. /package/dist/modules/{mcp → oauth-server}/database/repositories/oauth-refresh-token.repository.d.ts +0 -0
  651. /package/dist/modules/{mcp → oauth-server}/database/repositories/oauth-refresh-token.repository.js +0 -0
  652. /package/dist/modules/{mcp → oauth-server}/database/repositories/oauth-user-consent.repository.d.ts +0 -0
  653. /package/dist/modules/{mcp → oauth-server}/database/repositories/oauth-user-consent.repository.js +0 -0
  654. /package/dist/modules/{mcp → oauth-server}/dto/approve-consent-request.dto.d.ts +0 -0
  655. /package/dist/modules/{mcp → oauth-server}/dto/approve-consent-request.dto.js +0 -0
  656. /package/dist/modules/{mcp → oauth-server}/oauth-session.service.d.ts +0 -0
  657. /package/dist/modules/{mcp → oauth-server}/oauth-session.service.js +0 -0
@@ -0,0 +1,11 @@
1
+ import type { PreparedWorkflow } from '../entities/workflow/workflow-import.types';
2
+ import { WorkflowSerializer } from '../entities/workflow/workflow.serializer';
3
+ import type { PackageReader } from '../io/package-reader';
4
+ import type { PackageManifest } from '../spec/manifest.schema';
5
+ export declare class N8nPackageParser {
6
+ private readonly workflowSerializer;
7
+ constructor(workflowSerializer: WorkflowSerializer);
8
+ getManifest(reader: PackageReader): Promise<PackageManifest>;
9
+ getWorkflows(reader: PackageReader): Promise<PreparedWorkflow[]>;
10
+ private readWorkflow;
11
+ }
@@ -0,0 +1,114 @@
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.N8nPackageParser = void 0;
46
+ const db_1 = require("@n8n/db");
47
+ const di_1 = require("@n8n/di");
48
+ const n8n_workflow_1 = require("n8n-workflow");
49
+ const zod_1 = require("zod");
50
+ const bad_request_error_1 = require("../../../errors/response-errors/bad-request.error");
51
+ const WorkflowHelpers = __importStar(require("../../../workflow-helpers"));
52
+ const workflow_serializer_1 = require("../entities/workflow/workflow.serializer");
53
+ const manifest_schema_1 = require("../spec/manifest.schema");
54
+ let N8nPackageParser = class N8nPackageParser {
55
+ constructor(workflowSerializer) {
56
+ this.workflowSerializer = workflowSerializer;
57
+ }
58
+ async getManifest(reader) {
59
+ try {
60
+ return manifest_schema_1.packageManifestSchema.parse(await reader.readManifest());
61
+ }
62
+ catch (error) {
63
+ if (error instanceof bad_request_error_1.BadRequestError)
64
+ throw error;
65
+ if (error instanceof zod_1.ZodError)
66
+ throw new bad_request_error_1.BadRequestError('Package manifest failed validation');
67
+ throw new bad_request_error_1.BadRequestError('Failed to read package manifest');
68
+ }
69
+ }
70
+ async getWorkflows(reader) {
71
+ const manifest = await this.getManifest(reader);
72
+ const workflows = [];
73
+ for (const entry of manifest.workflows ?? []) {
74
+ workflows.push(await this.readWorkflow(reader, entry));
75
+ }
76
+ return workflows;
77
+ }
78
+ async readWorkflow(reader, entry) {
79
+ const path = `${entry.target}/workflow.json`;
80
+ let content;
81
+ try {
82
+ content = await reader.readFile(path);
83
+ }
84
+ catch (cause) {
85
+ throw new n8n_workflow_1.UserError(`Package manifest references a missing workflow file at ${path}.`, {
86
+ cause,
87
+ });
88
+ }
89
+ const wire = (0, n8n_workflow_1.jsonParse)(content.toString('utf-8'), {
90
+ errorMessage: `Package workflow file at ${path} is not valid JSON.`,
91
+ });
92
+ let entity;
93
+ try {
94
+ const partial = this.workflowSerializer.deserialize(wire);
95
+ entity = Object.assign(new db_1.WorkflowEntity(), partial);
96
+ }
97
+ catch (cause) {
98
+ if (cause instanceof zod_1.ZodError) {
99
+ throw new n8n_workflow_1.UserError(`Package workflow file at ${path} failed schema validation.`, {
100
+ cause,
101
+ });
102
+ }
103
+ throw cause;
104
+ }
105
+ WorkflowHelpers.validateWorkflowStructure(entity);
106
+ return { entity, sourceWorkflowId: entry.id, sourcePublished: wire.isPublished };
107
+ }
108
+ };
109
+ exports.N8nPackageParser = N8nPackageParser;
110
+ exports.N8nPackageParser = N8nPackageParser = __decorate([
111
+ (0, di_1.Service)(),
112
+ __metadata("design:paramtypes", [workflow_serializer_1.WorkflowSerializer])
113
+ ], N8nPackageParser);
114
+ //# sourceMappingURL=n8n-package-parser.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"n8n-package-parser.js","sourceRoot":"","sources":["../../../../src/modules/n8n-packages/engine/n8n-package-parser.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,gCAAyC;AACzC,gCAAkC;AAClC,+CAAoD;AACpD,6BAA+B;AAE/B,kFAA6E;AAC7E,oEAAsD;AAGtD,kFAA8E;AAG9E,6DAAgE;AAUzD,IAAM,gBAAgB,GAAtB,MAAM,gBAAgB;IAC5B,YAA6B,kBAAsC;QAAtC,uBAAkB,GAAlB,kBAAkB,CAAoB;IAAG,CAAC;IAEvE,KAAK,CAAC,WAAW,CAAC,MAAqB;QACtC,IAAI,CAAC;YACJ,OAAO,uCAAqB,CAAC,KAAK,CAAC,MAAM,MAAM,CAAC,YAAY,EAAE,CAAC,CAAC;QACjE,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YAChB,IAAI,KAAK,YAAY,mCAAe;gBAAE,MAAM,KAAK,CAAC;YAClD,IAAI,KAAK,YAAY,cAAQ;gBAC5B,MAAM,IAAI,mCAAe,CAAC,oCAAoC,CAAC,CAAC;YACjE,MAAM,IAAI,mCAAe,CAAC,iCAAiC,CAAC,CAAC;QAC9D,CAAC;IACF,CAAC;IAED,KAAK,CAAC,YAAY,CAAC,MAAqB;QACvC,MAAM,QAAQ,GAAG,MAAM,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC;QAEhD,MAAM,SAAS,GAAuB,EAAE,CAAC;QACzC,KAAK,MAAM,KAAK,IAAI,QAAQ,CAAC,SAAS,IAAI,EAAE,EAAE,CAAC;YAC9C,SAAS,CAAC,IAAI,CAAC,MAAM,IAAI,CAAC,YAAY,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC,CAAC;QACxD,CAAC;QACD,OAAO,SAAS,CAAC;IAClB,CAAC;IAEO,KAAK,CAAC,YAAY,CACzB,MAAqB,EACrB,KAAoB;QAEpB,MAAM,IAAI,GAAG,GAAG,KAAK,CAAC,MAAM,gBAAgB,CAAC;QAE7C,IAAI,OAAe,CAAC;QACpB,IAAI,CAAC;YACJ,OAAO,GAAG,MAAM,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;QACvC,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YAChB,MAAM,IAAI,wBAAS,CAAC,0DAA0D,IAAI,GAAG,EAAE;gBACtF,KAAK;aACL,CAAC,CAAC;QACJ,CAAC;QAED,MAAM,IAAI,GAAG,IAAA,wBAAS,EAAqB,OAAO,CAAC,QAAQ,CAAC,OAAO,CAAC,EAAE;YACrE,YAAY,EAAE,4BAA4B,IAAI,qBAAqB;SACnE,CAAC,CAAC;QAEH,IAAI,MAAsB,CAAC;QAC3B,IAAI,CAAC;YACJ,MAAM,OAAO,GAAG,IAAI,CAAC,kBAAkB,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;YAC1D,MAAM,GAAG,MAAM,CAAC,MAAM,CAAC,IAAI,mBAAc,EAAE,EAAE,OAAO,CAAC,CAAC;QACvD,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YAChB,IAAI,KAAK,YAAY,cAAQ,EAAE,CAAC;gBAC/B,MAAM,IAAI,wBAAS,CAAC,4BAA4B,IAAI,4BAA4B,EAAE;oBACjF,KAAK;iBACL,CAAC,CAAC;YACJ,CAAC;YACD,MAAM,KAAK,CAAC;QACb,CAAC;QAED,eAAe,CAAC,yBAAyB,CAAC,MAAM,CAAC,CAAC;QAElD,OAAO,EAAE,MAAM,EAAE,gBAAgB,EAAE,KAAK,CAAC,EAAE,EAAE,eAAe,EAAE,IAAI,CAAC,WAAW,EAAE,CAAC;IAClF,CAAC;CACD,CAAA;AA5DY,4CAAgB;2BAAhB,gBAAgB;IAD5B,IAAA,YAAO,GAAE;qCAEwC,wCAAkB;GADvD,gBAAgB,CA4D5B"}
@@ -1,9 +1,8 @@
1
1
  import { CredentialMatcherFactory } from './credential-matcher-factory';
2
- import { CredentialMissingModeFactory } from './credential-missing-mode-factory';
3
- import type { CredentialBindingRequest, CredentialResolution } from './credential.types';
2
+ import type { CredentialBindingRequest, CredentialResolution, CredentialResolutionFailure } from './credential.types';
4
3
  export declare class CredentialImporter {
5
4
  private readonly credentialMatcherFactory;
6
- private readonly credentialMissingModeFactory;
7
- constructor(credentialMatcherFactory: CredentialMatcherFactory, credentialMissingModeFactory: CredentialMissingModeFactory);
8
- resolveForImport(request: CredentialBindingRequest): Promise<CredentialResolution>;
5
+ constructor(credentialMatcherFactory: CredentialMatcherFactory);
6
+ plan(request: CredentialBindingRequest): Promise<CredentialResolution>;
7
+ blockingFailures(resolution: CredentialResolution, request: CredentialBindingRequest): CredentialResolutionFailure[];
9
8
  }
@@ -12,30 +12,27 @@ Object.defineProperty(exports, "__esModule", { value: true });
12
12
  exports.CredentialImporter = void 0;
13
13
  const di_1 = require("@n8n/di");
14
14
  const credential_matcher_factory_1 = require("./credential-matcher-factory");
15
- const credential_missing_mode_factory_1 = require("./credential-missing-mode-factory");
15
+ const credential_missing_mode_1 = require("./credential-missing-mode");
16
16
  let CredentialImporter = class CredentialImporter {
17
- constructor(credentialMatcherFactory, credentialMissingModeFactory) {
17
+ constructor(credentialMatcherFactory) {
18
18
  this.credentialMatcherFactory = credentialMatcherFactory;
19
- this.credentialMissingModeFactory = credentialMissingModeFactory;
20
19
  }
21
- async resolveForImport(request) {
22
- const matched = await this.credentialMatcherFactory
20
+ async plan(request) {
21
+ return await this.credentialMatcherFactory
23
22
  .getMatcher(request.matchingMode)
24
23
  .match(request.requirements, {
25
24
  targetProject: request.targetProject,
26
25
  user: request.user,
26
+ credentialBindings: request.credentialBindings,
27
27
  });
28
- return await this.credentialMissingModeFactory.getHandler(request.missingMode).handle(matched, {
29
- requirements: request.requirements,
30
- targetProject: request.targetProject,
31
- user: request.user,
32
- });
28
+ }
29
+ blockingFailures(resolution, request) {
30
+ return (0, credential_missing_mode_1.credentialBlockingFailures)(request.missingMode, resolution);
33
31
  }
34
32
  };
35
33
  exports.CredentialImporter = CredentialImporter;
36
34
  exports.CredentialImporter = CredentialImporter = __decorate([
37
35
  (0, di_1.Service)(),
38
- __metadata("design:paramtypes", [credential_matcher_factory_1.CredentialMatcherFactory,
39
- credential_missing_mode_factory_1.CredentialMissingModeFactory])
36
+ __metadata("design:paramtypes", [credential_matcher_factory_1.CredentialMatcherFactory])
40
37
  ], CredentialImporter);
41
38
  //# sourceMappingURL=credential-importer.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"credential-importer.js","sourceRoot":"","sources":["../../../../../src/modules/n8n-packages/entities/credential/credential-importer.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,gCAAkC;AAElC,6EAAwE;AACxE,uFAAiF;AAI1E,IAAM,kBAAkB,GAAxB,MAAM,kBAAkB;IAC9B,YACkB,wBAAkD,EAClD,4BAA0D;QAD1D,6BAAwB,GAAxB,wBAAwB,CAA0B;QAClD,iCAA4B,GAA5B,4BAA4B,CAA8B;IACzE,CAAC;IAEJ,KAAK,CAAC,gBAAgB,CAAC,OAAiC;QACvD,MAAM,OAAO,GAAG,MAAM,IAAI,CAAC,wBAAwB;aACjD,UAAU,CAAC,OAAO,CAAC,YAAY,CAAC;aAChC,KAAK,CAAC,OAAO,CAAC,YAAY,EAAE;YAC5B,aAAa,EAAE,OAAO,CAAC,aAAa;YACpC,IAAI,EAAE,OAAO,CAAC,IAAI;SAClB,CAAC,CAAC;QAEJ,OAAO,MAAM,IAAI,CAAC,4BAA4B,CAAC,UAAU,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC,MAAM,CAAC,OAAO,EAAE;YAC9F,YAAY,EAAE,OAAO,CAAC,YAAY;YAClC,aAAa,EAAE,OAAO,CAAC,aAAa;YACpC,IAAI,EAAE,OAAO,CAAC,IAAI;SAClB,CAAC,CAAC;IACJ,CAAC;CACD,CAAA;AApBY,gDAAkB;6BAAlB,kBAAkB;IAD9B,IAAA,YAAO,GAAE;qCAGmC,qDAAwB;QACpB,8DAA4B;GAHhE,kBAAkB,CAoB9B"}
1
+ {"version":3,"file":"credential-importer.js","sourceRoot":"","sources":["../../../../../src/modules/n8n-packages/entities/credential/credential-importer.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,gCAAkC;AAElC,6EAAwE;AACxE,uEAAuE;AAQhE,IAAM,kBAAkB,GAAxB,MAAM,kBAAkB;IAC9B,YAA6B,wBAAkD;QAAlD,6BAAwB,GAAxB,wBAAwB,CAA0B;IAAG,CAAC;IAOnF,KAAK,CAAC,IAAI,CAAC,OAAiC;QAC3C,OAAO,MAAM,IAAI,CAAC,wBAAwB;aACxC,UAAU,CAAC,OAAO,CAAC,YAAY,CAAC;aAChC,KAAK,CAAC,OAAO,CAAC,YAAY,EAAE;YAC5B,aAAa,EAAE,OAAO,CAAC,aAAa;YACpC,IAAI,EAAE,OAAO,CAAC,IAAI;YAClB,kBAAkB,EAAE,OAAO,CAAC,kBAAkB;SAC9C,CAAC,CAAC;IACL,CAAC;IAOD,gBAAgB,CACf,UAAgC,EAChC,OAAiC;QAEjC,OAAO,IAAA,oDAA0B,EAAC,OAAO,CAAC,WAAW,EAAE,UAAU,CAAC,CAAC;IACpE,CAAC;CACD,CAAA;AA7BY,gDAAkB;6BAAlB,kBAAkB;IAD9B,IAAA,YAAO,GAAE;qCAE8C,qDAAwB;GADnE,kBAAkB,CA6B9B"}
@@ -7,6 +7,7 @@ import type { PackageCredentialRequirement } from '../../spec/requirements.schem
7
7
  export interface CredentialMatcherContext {
8
8
  targetProject: Project;
9
9
  user: User;
10
+ credentialBindings?: ImportBindingMap;
10
11
  }
11
12
  export declare abstract class CredentialMatcher {
12
13
  protected readonly credentialsFinderService: CredentialsFinderService;
@@ -9,12 +9,16 @@ class CredentialMatcher {
9
9
  this.credentialTypes = credentialTypes;
10
10
  }
11
11
  async match(requirements, context) {
12
+ const orphanFailures = orphanBindingFailures(context.credentialBindings, requirements);
12
13
  const { known, unknownTypeFailures } = partitionByKnownType(requirements, this.credentialTypes);
13
14
  const successes = await this.resolve(known, context);
14
15
  const notFoundFailures = known
15
16
  .filter((reference) => !successes.has(reference.id))
16
- .map((reference) => (0, credential_types_1.createFailure)(reference, 'not_found'));
17
- return { successes, failures: [...unknownTypeFailures, ...notFoundFailures] };
17
+ .map((reference) => createNotFoundFailure(reference, context.credentialBindings?.get(reference.id)));
18
+ return {
19
+ successes,
20
+ failures: [...orphanFailures, ...unknownTypeFailures, ...notFoundFailures],
21
+ };
18
22
  }
19
23
  }
20
24
  exports.CredentialMatcher = CredentialMatcher;
@@ -31,4 +35,25 @@ function partitionByKnownType(requirements, credentialTypes) {
31
35
  }
32
36
  return { known, unknownTypeFailures };
33
37
  }
38
+ function createNotFoundFailure(reference, requestedTargetId) {
39
+ const failure = (0, credential_types_1.createFailure)(reference, 'not_found');
40
+ return requestedTargetId === undefined ? failure : { ...failure, targetId: requestedTargetId };
41
+ }
42
+ function orphanBindingFailures(bindings, requirements) {
43
+ if (!bindings || bindings.size === 0)
44
+ return [];
45
+ const requirementIds = new Set((requirements ?? []).map((requirement) => requirement.id));
46
+ const failures = [];
47
+ for (const [sourceId, targetId] of bindings) {
48
+ if (!requirementIds.has(sourceId)) {
49
+ failures.push({
50
+ kind: 'source_not_found',
51
+ sourceId,
52
+ targetId,
53
+ usedByWorkflows: [],
54
+ });
55
+ }
56
+ }
57
+ return failures;
58
+ }
34
59
  //# sourceMappingURL=credential-matcher.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"credential-matcher.js","sourceRoot":"","sources":["../../../../../src/modules/n8n-packages/entities/credential/credential-matcher.ts"],"names":[],"mappings":";;;AAKA,yDAI4B;AAS5B,MAAsB,iBAAiB;IACtC,YACoB,wBAAkD,EAClD,2BAAwD,EACxD,eAAgC;QAFhC,6BAAwB,GAAxB,wBAAwB,CAA0B;QAClD,gCAA2B,GAA3B,2BAA2B,CAA6B;QACxD,oBAAe,GAAf,eAAe,CAAiB;IACjD,CAAC;IAEJ,KAAK,CAAC,KAAK,CACV,YAAwD,EACxD,OAAiC;QAEjC,MAAM,EAAE,KAAK,EAAE,mBAAmB,EAAE,GAAG,oBAAoB,CAAC,YAAY,EAAE,IAAI,CAAC,eAAe,CAAC,CAAC;QAEhG,MAAM,SAAS,GAAG,MAAM,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,OAAO,CAAC,CAAC;QAErD,MAAM,gBAAgB,GAAG,KAAK;aAC5B,MAAM,CAAC,CAAC,SAAS,EAAE,EAAE,CAAC,CAAC,SAAS,CAAC,GAAG,CAAC,SAAS,CAAC,EAAE,CAAC,CAAC;aACnD,GAAG,CAAC,CAAC,SAAS,EAAE,EAAE,CAAC,IAAA,gCAAa,EAAC,SAAS,EAAE,WAAW,CAAC,CAAC,CAAC;QAE5D,OAAO,EAAE,SAAS,EAAE,QAAQ,EAAE,CAAC,GAAG,mBAAmB,EAAE,GAAG,gBAAgB,CAAC,EAAE,CAAC;IAC/E,CAAC;CAMD;AA1BD,8CA0BC;AAED,SAAS,oBAAoB,CAC5B,YAAwD,EACxD,eAAgC;IAKhC,MAAM,KAAK,GAAmC,EAAE,CAAC;IACjD,MAAM,mBAAmB,GAAkC,EAAE,CAAC;IAE9D,KAAK,MAAM,SAAS,IAAI,YAAY,IAAI,EAAE,EAAE,CAAC;QAC5C,IAAI,eAAe,CAAC,UAAU,CAAC,SAAS,CAAC,IAAI,CAAC,EAAE,CAAC;YAChD,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QACvB,CAAC;aAAM,CAAC;YACP,mBAAmB,CAAC,IAAI,CAAC,IAAA,gCAAa,EAAC,SAAS,EAAE,cAAc,CAAC,CAAC,CAAC;QACpE,CAAC;IACF,CAAC;IAED,OAAO,EAAE,KAAK,EAAE,mBAAmB,EAAE,CAAC;AACvC,CAAC"}
1
+ {"version":3,"file":"credential-matcher.js","sourceRoot":"","sources":["../../../../../src/modules/n8n-packages/entities/credential/credential-matcher.ts"],"names":[],"mappings":";;;AAKA,yDAI4B;AAU5B,MAAsB,iBAAiB;IACtC,YACoB,wBAAkD,EAClD,2BAAwD,EACxD,eAAgC;QAFhC,6BAAwB,GAAxB,wBAAwB,CAA0B;QAClD,gCAA2B,GAA3B,2BAA2B,CAA6B;QACxD,oBAAe,GAAf,eAAe,CAAiB;IACjD,CAAC;IAEJ,KAAK,CAAC,KAAK,CACV,YAAwD,EACxD,OAAiC;QAEjC,MAAM,cAAc,GAAG,qBAAqB,CAAC,OAAO,CAAC,kBAAkB,EAAE,YAAY,CAAC,CAAC;QACvF,MAAM,EAAE,KAAK,EAAE,mBAAmB,EAAE,GAAG,oBAAoB,CAAC,YAAY,EAAE,IAAI,CAAC,eAAe,CAAC,CAAC;QAEhG,MAAM,SAAS,GAAG,MAAM,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,OAAO,CAAC,CAAC;QAErD,MAAM,gBAAgB,GAAG,KAAK;aAC5B,MAAM,CAAC,CAAC,SAAS,EAAE,EAAE,CAAC,CAAC,SAAS,CAAC,GAAG,CAAC,SAAS,CAAC,EAAE,CAAC,CAAC;aACnD,GAAG,CAAC,CAAC,SAAS,EAAE,EAAE,CAClB,qBAAqB,CAAC,SAAS,EAAE,OAAO,CAAC,kBAAkB,EAAE,GAAG,CAAC,SAAS,CAAC,EAAE,CAAC,CAAC,CAC/E,CAAC;QAEH,OAAO;YACN,SAAS;YACT,QAAQ,EAAE,CAAC,GAAG,cAAc,EAAE,GAAG,mBAAmB,EAAE,GAAG,gBAAgB,CAAC;SAC1E,CAAC;IACH,CAAC;CAMD;AAhCD,8CAgCC;AAED,SAAS,oBAAoB,CAC5B,YAAwD,EACxD,eAAgC;IAKhC,MAAM,KAAK,GAAmC,EAAE,CAAC;IACjD,MAAM,mBAAmB,GAAkC,EAAE,CAAC;IAE9D,KAAK,MAAM,SAAS,IAAI,YAAY,IAAI,EAAE,EAAE,CAAC;QAC5C,IAAI,eAAe,CAAC,UAAU,CAAC,SAAS,CAAC,IAAI,CAAC,EAAE,CAAC;YAChD,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QACvB,CAAC;aAAM,CAAC;YACP,mBAAmB,CAAC,IAAI,CAAC,IAAA,gCAAa,EAAC,SAAS,EAAE,cAAc,CAAC,CAAC,CAAC;QACpE,CAAC;IACF,CAAC;IAED,OAAO,EAAE,KAAK,EAAE,mBAAmB,EAAE,CAAC;AACvC,CAAC;AAMD,SAAS,qBAAqB,CAC7B,SAAuC,EACvC,iBAAqC;IAErC,MAAM,OAAO,GAAG,IAAA,gCAAa,EAAC,SAAS,EAAE,WAAW,CAAC,CAAC;IACtD,OAAO,iBAAiB,KAAK,SAAS,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,GAAG,OAAO,EAAE,QAAQ,EAAE,iBAAiB,EAAE,CAAC;AAChG,CAAC;AAOD,SAAS,qBAAqB,CAC7B,QAAsC,EACtC,YAAwD;IAExD,IAAI,CAAC,QAAQ,IAAI,QAAQ,CAAC,IAAI,KAAK,CAAC;QAAE,OAAO,EAAE,CAAC;IAEhD,MAAM,cAAc,GAAG,IAAI,GAAG,CAAC,CAAC,YAAY,IAAI,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,WAAW,EAAE,EAAE,CAAC,WAAW,CAAC,EAAE,CAAC,CAAC,CAAC;IAC1F,MAAM,QAAQ,GAAkC,EAAE,CAAC;IAEnD,KAAK,MAAM,CAAC,QAAQ,EAAE,QAAQ,CAAC,IAAI,QAAQ,EAAE,CAAC;QAC7C,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,QAAQ,CAAC,EAAE,CAAC;YACnC,QAAQ,CAAC,IAAI,CAAC;gBACb,IAAI,EAAE,kBAAkB;gBACxB,QAAQ;gBACR,QAAQ;gBACR,eAAe,EAAE,EAAE;aACnB,CAAC,CAAC;QACJ,CAAC;IACF,CAAC;IAED,OAAO,QAAQ,CAAC;AACjB,CAAC"}
@@ -1,7 +1,3 @@
1
- import type { CredentialMissingModeContext, CredentialResolution } from './credential.types';
2
- export declare abstract class CredentialMissingModeHandler {
3
- abstract handle(result: CredentialResolution, context: CredentialMissingModeContext): Promise<CredentialResolution>;
4
- }
5
- export declare class MustPreexistCredentialMissingModeHandler extends CredentialMissingModeHandler {
6
- handle(result: CredentialResolution): Promise<CredentialResolution>;
7
- }
1
+ import type { CredentialResolution, CredentialResolutionFailure } from './credential.types';
2
+ import type { CredentialMissingMode } from '../../n8n-packages.types';
3
+ export declare function credentialBlockingFailures(mode: CredentialMissingMode, resolution: CredentialResolution): CredentialResolutionFailure[];
@@ -1,17 +1,10 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.MustPreexistCredentialMissingModeHandler = exports.CredentialMissingModeHandler = void 0;
4
- const credential_resolution_error_1 = require("./credential-resolution-error");
5
- class CredentialMissingModeHandler {
3
+ exports.credentialBlockingFailures = credentialBlockingFailures;
4
+ const BLOCKING_FAILURES = {
5
+ 'must-preexist': (resolution) => resolution.failures,
6
+ };
7
+ function credentialBlockingFailures(mode, resolution) {
8
+ return BLOCKING_FAILURES[mode](resolution);
6
9
  }
7
- exports.CredentialMissingModeHandler = CredentialMissingModeHandler;
8
- class MustPreexistCredentialMissingModeHandler extends CredentialMissingModeHandler {
9
- async handle(result) {
10
- if (result.failures.length === 0) {
11
- return result;
12
- }
13
- throw (0, credential_resolution_error_1.toCredentialResolutionFailedError)(result.failures);
14
- }
15
- }
16
- exports.MustPreexistCredentialMissingModeHandler = MustPreexistCredentialMissingModeHandler;
17
10
  //# sourceMappingURL=credential-missing-mode.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"credential-missing-mode.js","sourceRoot":"","sources":["../../../../../src/modules/n8n-packages/entities/credential/credential-missing-mode.ts"],"names":[],"mappings":";;;AAAA,+EAAkF;AAGlF,MAAsB,4BAA4B;CAKjD;AALD,oEAKC;AAED,MAAa,wCAAyC,SAAQ,4BAA4B;IAEzF,KAAK,CAAC,MAAM,CAAC,MAA4B;QACxC,IAAI,MAAM,CAAC,QAAQ,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YAClC,OAAO,MAAM,CAAC;QACf,CAAC;QAED,MAAM,IAAA,+DAAiC,EAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;IAC1D,CAAC;CACD;AATD,4FASC"}
1
+ {"version":3,"file":"credential-missing-mode.js","sourceRoot":"","sources":["../../../../../src/modules/n8n-packages/entities/credential/credential-missing-mode.ts"],"names":[],"mappings":";;AAgBA,gEAKC;AAbD,MAAM,iBAAiB,GAGnB;IACH,eAAe,EAAE,CAAC,UAAU,EAAE,EAAE,CAAC,UAAU,CAAC,QAAQ;CACpD,CAAC;AAGF,SAAgB,0BAA0B,CACzC,IAA2B,EAC3B,UAAgC;IAEhC,OAAO,iBAAiB,CAAC,IAAI,CAAC,CAAC,UAAU,CAAC,CAAC;AAC5C,CAAC"}
@@ -7,10 +7,11 @@ export interface WorkflowCredentialRequirement {
7
7
  credentialName: string;
8
8
  credentialType: string;
9
9
  }
10
- export type CredentialResolutionFailureKind = 'not_found' | 'unknown_type';
10
+ export type CredentialResolutionFailureKind = 'not_found' | 'unknown_type' | 'source_not_found';
11
11
  export type CredentialResolutionFailure = {
12
12
  kind: CredentialResolutionFailureKind;
13
13
  sourceId: string;
14
+ targetId?: string;
14
15
  usedByWorkflows: string[];
15
16
  };
16
17
  export interface CredentialResolution {
@@ -21,16 +22,8 @@ export interface CredentialBindingRequest {
21
22
  requirements: PackageCredentialRequirement[] | undefined;
22
23
  matchingMode: CredentialMatchingMode;
23
24
  missingMode: CredentialMissingMode;
24
- targetProject: Project;
25
- user: User;
26
- }
27
- export interface CredentialMissingModeContext {
28
- requirements: PackageCredentialRequirement[] | undefined;
25
+ credentialBindings?: ImportBindingMap;
29
26
  targetProject: Project;
30
27
  user: User;
31
28
  }
32
29
  export declare function createFailure(reference: PackageCredentialRequirement, kind: CredentialResolutionFailureKind): CredentialResolutionFailure;
33
- export declare function resolvedBindingsToSummaries(successes: ImportBindingMap): Array<{
34
- sourceId: string;
35
- targetId: string;
36
- }>;
@@ -1,7 +1,6 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.createFailure = createFailure;
4
- exports.resolvedBindingsToSummaries = resolvedBindingsToSummaries;
5
4
  function createFailure(reference, kind) {
6
5
  return {
7
6
  kind,
@@ -9,7 +8,4 @@ function createFailure(reference, kind) {
9
8
  usedByWorkflows: [...reference.usedByWorkflows].sort(),
10
9
  };
11
10
  }
12
- function resolvedBindingsToSummaries(successes) {
13
- return [...successes].map(([sourceId, targetId]) => ({ sourceId, targetId }));
14
- }
15
11
  //# sourceMappingURL=credential.types.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"credential.types.js","sourceRoot":"","sources":["../../../../../src/modules/n8n-packages/entities/credential/credential.types.ts"],"names":[],"mappings":";;AA+CA,sCASC;AAGD,kEAIC;AAhBD,SAAgB,aAAa,CAC5B,SAAuC,EACvC,IAAqC;IAErC,OAAO;QACN,IAAI;QACJ,QAAQ,EAAE,SAAS,CAAC,EAAE;QACtB,eAAe,EAAE,CAAC,GAAG,SAAS,CAAC,eAAe,CAAC,CAAC,IAAI,EAAE;KACtD,CAAC;AACH,CAAC;AAGD,SAAgB,2BAA2B,CAC1C,SAA2B;IAE3B,OAAO,CAAC,GAAG,SAAS,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,QAAQ,EAAE,QAAQ,CAAC,EAAE,EAAE,CAAC,CAAC,EAAE,QAAQ,EAAE,QAAQ,EAAE,CAAC,CAAC,CAAC;AAC/E,CAAC"}
1
+ {"version":3,"file":"credential.types.js","sourceRoot":"","sources":["../../../../../src/modules/n8n-packages/entities/credential/credential.types.ts"],"names":[],"mappings":";;AAuCA,sCASC;AATD,SAAgB,aAAa,CAC5B,SAAuC,EACvC,IAAqC;IAErC,OAAO;QACN,IAAI;QACJ,QAAQ,EAAE,SAAS,CAAC,EAAE;QACtB,eAAe,EAAE,CAAC,GAAG,SAAS,CAAC,eAAe,CAAC,CAAC,IAAI,EAAE;KACtD,CAAC;AACH,CAAC"}
@@ -22,13 +22,18 @@ let IdBasedCredentialMatcher = class IdBasedCredentialMatcher extends credential
22
22
  this.credentialsService = credentialsService;
23
23
  }
24
24
  async resolve(known, context) {
25
- const resolvableIds = await this.findResolvableCredentialIds(known.map((reference) => reference.id), context.targetProject, context.user);
26
- return new Map(known
27
- .filter((reference) => resolvableIds.has(reference.id))
28
- .map((reference) => [reference.id, reference.id]));
25
+ const bindings = context.credentialBindings;
26
+ const targetIds = known.map((reference) => bindings?.get(reference.id) ?? reference.id);
27
+ const resolvableIds = await this.findResolvableCredentialIds(targetIds, context.targetProject, context.user);
28
+ return new Map(known.flatMap((reference) => {
29
+ const targetId = bindings?.get(reference.id) ?? reference.id;
30
+ if (!resolvableIds.has(targetId))
31
+ return [];
32
+ return [[reference.id, targetId]];
33
+ }));
29
34
  }
30
- async findResolvableCredentialIds(sourceIds, targetProject, user) {
31
- const uniqueIds = new Set(sourceIds);
35
+ async findResolvableCredentialIds(candidateIds, targetProject, user) {
36
+ const uniqueIds = new Set(candidateIds);
32
37
  if (uniqueIds.size === 0) {
33
38
  return new Set();
34
39
  }
@@ -1 +1 @@
1
- {"version":3,"file":"id-based-credential-matcher.js","sourceRoot":"","sources":["../../../../../src/modules/n8n-packages/entities/credential/id-based-credential-matcher.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,gCAAsD;AAEtD,gCAAkC;AAElC,yDAAqD;AACrD,yFAAoF;AACpF,2EAAuE;AAEvE,6DAAwF;AAKjF,IAAM,wBAAwB,GAA9B,MAAM,wBAAyB,SAAQ,sCAAiB;IAC9D,YACC,wBAAkD,EAClD,2BAAwD,EACxD,eAAgC,EACf,kBAAsC;QAEvD,KAAK,CAAC,wBAAwB,EAAE,2BAA2B,EAAE,eAAe,CAAC,CAAC;QAF7D,uBAAkB,GAAlB,kBAAkB,CAAoB;IAGxD,CAAC;IAES,KAAK,CAAC,OAAO,CACtB,KAAqC,EACrC,OAAiC;QAEjC,MAAM,aAAa,GAAG,MAAM,IAAI,CAAC,2BAA2B,CAC3D,KAAK,CAAC,GAAG,CAAC,CAAC,SAAS,EAAE,EAAE,CAAC,SAAS,CAAC,EAAE,CAAC,EACtC,OAAO,CAAC,aAAa,EACrB,OAAO,CAAC,IAAI,CACZ,CAAC;QAEF,OAAO,IAAI,GAAG,CACb,KAAK;aACH,MAAM,CAAC,CAAC,SAAS,EAAE,EAAE,CAAC,aAAa,CAAC,GAAG,CAAC,SAAS,CAAC,EAAE,CAAC,CAAC;aAEtD,GAAG,CAAC,CAAC,SAAS,EAAE,EAAE,CAAC,CAAC,SAAS,CAAC,EAAE,EAAE,SAAS,CAAC,EAAE,CAAC,CAAC,CAClD,CAAC;IACH,CAAC;IAEO,KAAK,CAAC,2BAA2B,CACxC,SAAmB,EACnB,aAAsB,EACtB,IAAU;QAEV,MAAM,SAAS,GAAG,IAAI,GAAG,CAAC,SAAS,CAAC,CAAC;QACrC,IAAI,SAAS,CAAC,IAAI,KAAK,CAAC,EAAE,CAAC;YAC1B,OAAO,IAAI,GAAG,EAAE,CAAC;QAClB,CAAC;QAED,MAAM,iBAAiB,GAAG,MAAM,IAAI,CAAC,kBAAkB,CAAC,oCAAoC,CAC3F,IAAI,EACJ,EAAE,SAAS,EAAE,aAAa,CAAC,EAAE,EAAE,CAC/B,CAAC;QAEF,OAAO,IAAI,GAAG,CACb,iBAAiB,CAAC,GAAG,CAAC,CAAC,UAAU,EAAE,EAAE,CAAC,UAAU,CAAC,EAAE,CAAC,CAAC,MAAM,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,SAAS,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,CACtF,CAAC;IACH,CAAC;CACD,CAAA;AA/CY,4DAAwB;mCAAxB,wBAAwB;IADpC,IAAA,YAAO,GAAE;qCAGkB,qDAAwB;QACrB,gCAA2B;QACvC,kCAAe;QACK,wCAAkB;GAL5C,wBAAwB,CA+CpC"}
1
+ {"version":3,"file":"id-based-credential-matcher.js","sourceRoot":"","sources":["../../../../../src/modules/n8n-packages/entities/credential/id-based-credential-matcher.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,gCAAsD;AAEtD,gCAAkC;AAElC,yDAAqD;AACrD,yFAAoF;AACpF,2EAAuE;AAEvE,6DAAwF;AAKjF,IAAM,wBAAwB,GAA9B,MAAM,wBAAyB,SAAQ,sCAAiB;IAC9D,YACC,wBAAkD,EAClD,2BAAwD,EACxD,eAAgC,EACf,kBAAsC;QAEvD,KAAK,CAAC,wBAAwB,EAAE,2BAA2B,EAAE,eAAe,CAAC,CAAC;QAF7D,uBAAkB,GAAlB,kBAAkB,CAAoB;IAGxD,CAAC;IAES,KAAK,CAAC,OAAO,CACtB,KAAqC,EACrC,OAAiC;QAEjC,MAAM,QAAQ,GAAG,OAAO,CAAC,kBAAkB,CAAC;QAC5C,MAAM,SAAS,GAAG,KAAK,CAAC,GAAG,CAAC,CAAC,SAAS,EAAE,EAAE,CAAC,QAAQ,EAAE,GAAG,CAAC,SAAS,CAAC,EAAE,CAAC,IAAI,SAAS,CAAC,EAAE,CAAC,CAAC;QACxF,MAAM,aAAa,GAAG,MAAM,IAAI,CAAC,2BAA2B,CAC3D,SAAS,EACT,OAAO,CAAC,aAAa,EACrB,OAAO,CAAC,IAAI,CACZ,CAAC;QAEF,OAAO,IAAI,GAAG,CACb,KAAK,CAAC,OAAO,CAAC,CAAC,SAAS,EAAE,EAAE;YAC3B,MAAM,QAAQ,GAAG,QAAQ,EAAE,GAAG,CAAC,SAAS,CAAC,EAAE,CAAC,IAAI,SAAS,CAAC,EAAE,CAAC;YAC7D,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,QAAQ,CAAC;gBAAE,OAAO,EAAE,CAAC;YAC5C,OAAO,CAAC,CAAC,SAAS,CAAC,EAAE,EAAE,QAAQ,CAAU,CAAC,CAAC;QAC5C,CAAC,CAAC,CACF,CAAC;IACH,CAAC;IAEO,KAAK,CAAC,2BAA2B,CACxC,YAAsB,EACtB,aAAsB,EACtB,IAAU;QAEV,MAAM,SAAS,GAAG,IAAI,GAAG,CAAC,YAAY,CAAC,CAAC;QACxC,IAAI,SAAS,CAAC,IAAI,KAAK,CAAC,EAAE,CAAC;YAC1B,OAAO,IAAI,GAAG,EAAE,CAAC;QAClB,CAAC;QAED,MAAM,iBAAiB,GAAG,MAAM,IAAI,CAAC,kBAAkB,CAAC,oCAAoC,CAC3F,IAAI,EACJ,EAAE,SAAS,EAAE,aAAa,CAAC,EAAE,EAAE,CAC/B,CAAC;QAEF,OAAO,IAAI,GAAG,CACb,iBAAiB,CAAC,GAAG,CAAC,CAAC,UAAU,EAAE,EAAE,CAAC,UAAU,CAAC,EAAE,CAAC,CAAC,MAAM,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,SAAS,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,CACtF,CAAC;IACH,CAAC;CACD,CAAA;AAlDY,4DAAwB;mCAAxB,wBAAwB;IADpC,IAAA,YAAO,GAAE;qCAGkB,qDAAwB;QACrB,gCAA2B;QACvC,kCAAe;QACK,wCAAkB;GAL5C,wBAAwB,CAkDpC"}
@@ -0,0 +1,4 @@
1
+ import type { WorkflowEntity } from '@n8n/db';
2
+ import type { WorkflowDecision } from './workflow-import.types';
3
+ import type { WorkflowConflictPolicy } from '../../n8n-packages.types';
4
+ export declare function decideWorkflowConflictAction(policy: WorkflowConflictPolicy, existing: WorkflowEntity | null): WorkflowDecision;
@@ -0,0 +1,12 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.decideWorkflowConflictAction = decideWorkflowConflictAction;
4
+ const WORKFLOW_CONFLICT_POLICIES = {
5
+ 'new-version': (existing) => ({ action: existing ? 'update' : 'create', blocked: false }),
6
+ fail: (existing) => ({ action: 'create', blocked: existing !== null }),
7
+ skip: (existing) => ({ action: existing ? 'skip' : 'create', blocked: false }),
8
+ };
9
+ function decideWorkflowConflictAction(policy, existing) {
10
+ return WORKFLOW_CONFLICT_POLICIES[policy](existing);
11
+ }
12
+ //# sourceMappingURL=workflow-conflict-policy.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"workflow-conflict-policy.js","sourceRoot":"","sources":["../../../../../src/modules/n8n-packages/entities/workflow/workflow-conflict-policy.ts"],"names":[],"mappings":";;AAqBA,oEAKC;AAfD,MAAM,0BAA0B,GAG5B;IACH,aAAa,EAAE,CAAC,QAAQ,EAAE,EAAE,CAAC,CAAC,EAAE,MAAM,EAAE,QAAQ,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,QAAQ,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC;IACzF,IAAI,EAAE,CAAC,QAAQ,EAAE,EAAE,CAAC,CAAC,EAAE,MAAM,EAAE,QAAQ,EAAE,OAAO,EAAE,QAAQ,KAAK,IAAI,EAAE,CAAC;IACtE,IAAI,EAAE,CAAC,QAAQ,EAAE,EAAE,CAAC,CAAC,EAAE,MAAM,EAAE,QAAQ,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,QAAQ,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC;CAC9E,CAAC;AAGF,SAAgB,4BAA4B,CAC3C,MAA8B,EAC9B,QAA+B;IAE/B,OAAO,0BAA0B,CAAC,MAAM,CAAC,CAAC,QAAQ,CAAC,CAAC;AACrD,CAAC"}
@@ -0,0 +1,2 @@
1
+ import type { WorkflowIdPolicy } from '../../n8n-packages.types';
2
+ export declare function decideWorkflowId(policy: WorkflowIdPolicy, sourceWorkflowId: string): string;
@@ -0,0 +1,12 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.decideWorkflowId = decideWorkflowId;
4
+ const db_1 = require("@n8n/db");
5
+ const WORKFLOW_ID_POLICIES = {
6
+ new: () => (0, db_1.generateNanoId)(),
7
+ source: (sourceWorkflowId) => sourceWorkflowId,
8
+ };
9
+ function decideWorkflowId(policy, sourceWorkflowId) {
10
+ return WORKFLOW_ID_POLICIES[policy](sourceWorkflowId);
11
+ }
12
+ //# sourceMappingURL=workflow-id-policy.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"workflow-id-policy.js","sourceRoot":"","sources":["../../../../../src/modules/n8n-packages/entities/workflow/workflow-id-policy.ts"],"names":[],"mappings":";;AAcA,4CAEC;AAhBD,gCAAyC;AASzC,MAAM,oBAAoB,GAAmE;IAC5F,GAAG,EAAE,GAAG,EAAE,CAAC,IAAA,mBAAc,GAAE;IAC3B,MAAM,EAAE,CAAC,gBAAgB,EAAE,EAAE,CAAC,gBAAgB;CAC9C,CAAC;AAEF,SAAgB,gBAAgB,CAAC,MAAwB,EAAE,gBAAwB;IAClF,OAAO,oBAAoB,CAAC,MAAM,CAAC,CAAC,gBAAgB,CAAC,CAAC;AACvD,CAAC"}
@@ -1,7 +1,20 @@
1
- import { type WorkflowEntity } from '@n8n/db';
1
+ import { WorkflowRepository, type WorkflowEntity } from '@n8n/db';
2
2
  import { WorkflowFinderService } from '../../../../workflows/workflow-finder.service';
3
+ export interface WorkflowIdConflict {
4
+ sourceWorkflowId: string;
5
+ existingWorkflowId: string;
6
+ existingProjectId: string | null;
7
+ isArchived: boolean;
8
+ name: string;
9
+ }
3
10
  export declare class WorkflowImportMatchService {
4
11
  private readonly workflowFinderService;
5
- constructor(workflowFinderService: WorkflowFinderService);
12
+ private readonly workflowRepository;
13
+ constructor(workflowFinderService: WorkflowFinderService, workflowRepository: WorkflowRepository);
14
+ findOwningProjectsByWorkflowId(workflowIds: string[]): Promise<Map<string, {
15
+ projectId: string | null;
16
+ name: string;
17
+ isArchived: boolean;
18
+ }>>;
6
19
  findBySourceWorkflowIds(projectId: string, sourceWorkflowIds: string[]): Promise<Map<string, WorkflowEntity>>;
7
20
  }
@@ -10,12 +10,27 @@ var __metadata = (this && this.__metadata) || function (k, v) {
10
10
  };
11
11
  Object.defineProperty(exports, "__esModule", { value: true });
12
12
  exports.WorkflowImportMatchService = void 0;
13
+ const db_1 = require("@n8n/db");
13
14
  const di_1 = require("@n8n/di");
14
15
  const n8n_workflow_1 = require("n8n-workflow");
15
16
  const workflow_finder_service_1 = require("../../../../workflows/workflow-finder.service");
16
17
  let WorkflowImportMatchService = class WorkflowImportMatchService {
17
- constructor(workflowFinderService) {
18
+ constructor(workflowFinderService, workflowRepository) {
18
19
  this.workflowFinderService = workflowFinderService;
20
+ this.workflowRepository = workflowRepository;
21
+ }
22
+ async findOwningProjectsByWorkflowId(workflowIds) {
23
+ if (workflowIds.length === 0)
24
+ return new Map();
25
+ const workflows = await this.workflowRepository.findPreExistingWorkflows(workflowIds);
26
+ return new Map(workflows.map((workflow) => [
27
+ workflow.id,
28
+ {
29
+ projectId: workflow.shared?.[0]?.projectId ?? null,
30
+ name: workflow.name,
31
+ isArchived: workflow.isArchived,
32
+ },
33
+ ]));
19
34
  }
20
35
  async findBySourceWorkflowIds(projectId, sourceWorkflowIds) {
21
36
  if (sourceWorkflowIds.length === 0)
@@ -49,6 +64,7 @@ let WorkflowImportMatchService = class WorkflowImportMatchService {
49
64
  exports.WorkflowImportMatchService = WorkflowImportMatchService;
50
65
  exports.WorkflowImportMatchService = WorkflowImportMatchService = __decorate([
51
66
  (0, di_1.Service)(),
52
- __metadata("design:paramtypes", [workflow_finder_service_1.WorkflowFinderService])
67
+ __metadata("design:paramtypes", [workflow_finder_service_1.WorkflowFinderService,
68
+ db_1.WorkflowRepository])
53
69
  ], WorkflowImportMatchService);
54
70
  //# sourceMappingURL=workflow-import-match.service.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"workflow-import-match.service.js","sourceRoot":"","sources":["../../../../../src/modules/n8n-packages/entities/workflow/workflow-import-match.service.ts"],"names":[],"mappings":";;;;;;;;;;;;AACA,gCAAkC;AAClC,+CAA+C;AAE/C,iFAA4E;AAGrE,IAAM,0BAA0B,GAAhC,MAAM,0BAA0B;IACtC,YAA6B,qBAA4C;QAA5C,0BAAqB,GAArB,qBAAqB,CAAuB;IAAG,CAAC;IAE7E,KAAK,CAAC,uBAAuB,CAC5B,SAAiB,EACjB,iBAA2B;QAE3B,IAAI,iBAAiB,CAAC,MAAM,KAAK,CAAC;YAAE,OAAO,IAAI,GAAG,EAAE,CAAC;QAErD,MAAM,kBAAkB,GAAG,IAAI,GAAG,CAAC,iBAAiB,CAAC,CAAC;QACtD,MAAM,aAAa,GAAG,EAAE,oBAAoB,EAAE,IAAI,EAAE,mBAAmB,EAAE,IAAI,EAAW,CAAC;QACzF,MAAM,uBAAuB,GAAG,IAAI,GAAG,EAA0B,CAAC;QAElE,MAAM,SAAS,GAAG,MAAM,IAAI,CAAC,qBAAqB,CAAC,qCAAqC,CACvF,SAAS,EACT,iBAAiB,EACjB,aAAa,CACb,CAAC;QAEF,KAAK,MAAM,QAAQ,IAAI,SAAS,EAAE,CAAC;YAClC,IAAI,CAAC,QAAQ,CAAC,gBAAgB;gBAAE,SAAS;YAEzC,MAAM,GAAG,GAAG,QAAQ,CAAC,gBAAgB,CAAC;YACtC,IAAI,CAAC,kBAAkB,CAAC,GAAG,CAAC,GAAG,CAAC;gBAAE,SAAS;YAE3C,IAAI,uBAAuB,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE,CAAC;gBACtC,MAAM,IAAI,8BAAe,CACxB,0EAA0E,EAC1E,EAAE,KAAK,EAAE,EAAE,SAAS,EAAE,gBAAgB,EAAE,GAAG,EAAE,EAAE,CAC/C,CAAC;YACH,CAAC;YAED,uBAAuB,CAAC,GAAG,CAAC,GAAG,EAAE,QAAQ,CAAC,CAAC;QAC5C,CAAC;QAED,KAAK,MAAM,QAAQ,IAAI,SAAS,EAAE,CAAC;YAClC,IAAI,QAAQ,CAAC,gBAAgB,KAAK,IAAI;gBAAE,SAAS;YAEjD,MAAM,GAAG,GAAG,QAAQ,CAAC,EAAE,CAAC;YACxB,IAAI,CAAC,kBAAkB,CAAC,GAAG,CAAC,GAAG,CAAC,IAAI,uBAAuB,CAAC,GAAG,CAAC,GAAG,CAAC;gBAAE,SAAS;YAE/E,uBAAuB,CAAC,GAAG,CAAC,GAAG,EAAE,QAAQ,CAAC,CAAC;QAC5C,CAAC;QAED,OAAO,uBAAuB,CAAC;IAChC,CAAC;CACD,CAAA;AA9CY,gEAA0B;qCAA1B,0BAA0B;IADtC,IAAA,YAAO,GAAE;qCAE2C,+CAAqB;GAD7D,0BAA0B,CA8CtC"}
1
+ {"version":3,"file":"workflow-import-match.service.js","sourceRoot":"","sources":["../../../../../src/modules/n8n-packages/entities/workflow/workflow-import-match.service.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,gCAAkE;AAClE,gCAAkC;AAClC,+CAA+C;AAE/C,iFAA4E;AAYrE,IAAM,0BAA0B,GAAhC,MAAM,0BAA0B;IACtC,YACkB,qBAA4C,EAC5C,kBAAsC;QADtC,0BAAqB,GAArB,qBAAqB,CAAuB;QAC5C,uBAAkB,GAAlB,kBAAkB,CAAoB;IACrD,CAAC;IAEJ,KAAK,CAAC,8BAA8B,CACnC,WAAqB;QAErB,IAAI,WAAW,CAAC,MAAM,KAAK,CAAC;YAAE,OAAO,IAAI,GAAG,EAAE,CAAC;QAE/C,MAAM,SAAS,GAAG,MAAM,IAAI,CAAC,kBAAkB,CAAC,wBAAwB,CAAC,WAAW,CAAC,CAAC;QAEtF,OAAO,IAAI,GAAG,CACb,SAAS,CAAC,GAAG,CAAC,CAAC,QAAQ,EAAE,EAAE,CAAC;YAC3B,QAAQ,CAAC,EAAE;YACX;gBACC,SAAS,EAAE,QAAQ,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC,EAAE,SAAS,IAAI,IAAI;gBAClD,IAAI,EAAE,QAAQ,CAAC,IAAI;gBACnB,UAAU,EAAE,QAAQ,CAAC,UAAU;aAC/B;SACD,CAAC,CACF,CAAC;IACH,CAAC;IAED,KAAK,CAAC,uBAAuB,CAC5B,SAAiB,EACjB,iBAA2B;QAE3B,IAAI,iBAAiB,CAAC,MAAM,KAAK,CAAC;YAAE,OAAO,IAAI,GAAG,EAAE,CAAC;QAErD,MAAM,kBAAkB,GAAG,IAAI,GAAG,CAAC,iBAAiB,CAAC,CAAC;QACtD,MAAM,aAAa,GAAG,EAAE,oBAAoB,EAAE,IAAI,EAAE,mBAAmB,EAAE,IAAI,EAAW,CAAC;QACzF,MAAM,uBAAuB,GAAG,IAAI,GAAG,EAA0B,CAAC;QAElE,MAAM,SAAS,GAAG,MAAM,IAAI,CAAC,qBAAqB,CAAC,qCAAqC,CACvF,SAAS,EACT,iBAAiB,EACjB,aAAa,CACb,CAAC;QAEF,KAAK,MAAM,QAAQ,IAAI,SAAS,EAAE,CAAC;YAClC,IAAI,CAAC,QAAQ,CAAC,gBAAgB;gBAAE,SAAS;YAEzC,MAAM,GAAG,GAAG,QAAQ,CAAC,gBAAgB,CAAC;YACtC,IAAI,CAAC,kBAAkB,CAAC,GAAG,CAAC,GAAG,CAAC;gBAAE,SAAS;YAE3C,IAAI,uBAAuB,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE,CAAC;gBACtC,MAAM,IAAI,8BAAe,CACxB,0EAA0E,EAC1E,EAAE,KAAK,EAAE,EAAE,SAAS,EAAE,gBAAgB,EAAE,GAAG,EAAE,EAAE,CAC/C,CAAC;YACH,CAAC;YAED,uBAAuB,CAAC,GAAG,CAAC,GAAG,EAAE,QAAQ,CAAC,CAAC;QAC5C,CAAC;QAED,KAAK,MAAM,QAAQ,IAAI,SAAS,EAAE,CAAC;YAClC,IAAI,QAAQ,CAAC,gBAAgB,KAAK,IAAI;gBAAE,SAAS;YAEjD,MAAM,GAAG,GAAG,QAAQ,CAAC,EAAE,CAAC;YACxB,IAAI,CAAC,kBAAkB,CAAC,GAAG,CAAC,GAAG,CAAC,IAAI,uBAAuB,CAAC,GAAG,CAAC,GAAG,CAAC;gBAAE,SAAS;YAE/E,uBAAuB,CAAC,GAAG,CAAC,GAAG,EAAE,QAAQ,CAAC,CAAC;QAC5C,CAAC;QAED,OAAO,uBAAuB,CAAC;IAChC,CAAC;CACD,CAAA;AApEY,gEAA0B;qCAA1B,0BAA0B;IADtC,IAAA,YAAO,GAAE;qCAGgC,+CAAqB;QACxB,uBAAkB;GAH5C,0BAA0B,CAoEtC"}
@@ -0,0 +1,47 @@
1
+ import type { User, WorkflowEntity } from '@n8n/db';
2
+ import type { WorkflowIdConflict } from './workflow-import-match.service';
3
+ import type { WorkflowPublishingPolicy } from './workflow-publishing-policy.types';
4
+ export interface WorkflowImportContext {
5
+ user: User;
6
+ projectId: string;
7
+ folderId: string | null;
8
+ publishingPolicy: WorkflowPublishingPolicy;
9
+ }
10
+ export interface PreparedWorkflow {
11
+ entity: WorkflowEntity;
12
+ sourceWorkflowId: string;
13
+ sourcePublished: boolean;
14
+ }
15
+ export type WorkflowPlannedAction = 'create' | 'update' | 'skip';
16
+ export interface WorkflowDecision {
17
+ action: WorkflowPlannedAction;
18
+ blocked: boolean;
19
+ }
20
+ export type WorkflowPlanItem = ({
21
+ action: 'create';
22
+ decidedId: string;
23
+ } & PreparedWorkflow) | ({
24
+ action: 'update';
25
+ existing: WorkflowEntity;
26
+ } & PreparedWorkflow) | ({
27
+ action: 'skip';
28
+ existing: WorkflowEntity;
29
+ } & PreparedWorkflow);
30
+ export type PersistedWorkflowPlanItem = Extract<WorkflowPlanItem, {
31
+ action: 'create' | 'update';
32
+ }>;
33
+ export interface WorkflowConflict {
34
+ sourceWorkflowId: string;
35
+ existingWorkflowId: string;
36
+ name: string;
37
+ }
38
+ export interface WorkflowImportPlan {
39
+ items: WorkflowPlanItem[];
40
+ conflicts: WorkflowConflict[];
41
+ idConflicts: WorkflowIdConflict[];
42
+ }
43
+ export interface WorkflowImportOutcome {
44
+ status: 'created' | 'updated' | 'skipped';
45
+ workflow: WorkflowEntity;
46
+ sourceWorkflowId: string;
47
+ }
@@ -1,3 +1,3 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- //# sourceMappingURL=workflow-conflict-policy.types.js.map
3
+ //# sourceMappingURL=workflow-import.types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"workflow-import.types.js","sourceRoot":"","sources":["../../../../../src/modules/n8n-packages/entities/workflow/workflow-import.types.ts"],"names":[],"mappings":""}
@@ -1,14 +1,22 @@
1
- import type { PackageImportBindings, WorkflowConflictPolicy } from '../../n8n-packages.types';
1
+ import { WorkflowCreationService } from '../../../../workflows/workflow-creation.service';
2
+ import { WorkflowService } from '../../../../workflows/workflow.service';
2
3
  import { WorkflowImportMatchService } from './workflow-import-match.service';
3
- import { WorkflowConflictPolicyFactory } from './workflow-conflict-policy.factory';
4
- import type { PreparedWorkflow, WorkflowImportOutcome, WorkflowMatchContext } from './workflow-conflict-policy.types';
4
+ import type { PreparedWorkflow, WorkflowImportContext, WorkflowImportOutcome, WorkflowImportPlan } from './workflow-import.types';
5
+ import { WorkflowPublisher } from './workflow-publisher';
6
+ import type { ImportWorkflowProperties, PackageImportBindings } from '../../n8n-packages.types';
5
7
  export interface WorkflowImportResult {
6
8
  outcomes: WorkflowImportOutcome[];
7
9
  bindings: PackageImportBindings;
8
10
  }
9
11
  export declare class WorkflowImporter {
10
- private readonly workflowConflictPolicyFactory;
11
12
  private readonly workflowImportMatchService;
12
- constructor(workflowConflictPolicyFactory: WorkflowConflictPolicyFactory, workflowImportMatchService: WorkflowImportMatchService);
13
- importWorkflows(prepared: PreparedWorkflow[], policy: WorkflowConflictPolicy, context: WorkflowMatchContext, bindings: PackageImportBindings): Promise<WorkflowImportResult>;
13
+ private readonly workflowCreationService;
14
+ private readonly workflowService;
15
+ private readonly workflowPublisher;
16
+ constructor(workflowImportMatchService: WorkflowImportMatchService, workflowCreationService: WorkflowCreationService, workflowService: WorkflowService, workflowPublisher: WorkflowPublisher);
17
+ plan(context: WorkflowImportContext, prepared: PreparedWorkflow[], options: ImportWorkflowProperties): Promise<WorkflowImportPlan>;
18
+ private collectIdConflicts;
19
+ apply(plan: WorkflowImportPlan, context: WorkflowImportContext, bindings: PackageImportBindings): Promise<WorkflowImportResult>;
20
+ private applyItem;
21
+ private persistWorkflow;
14
22
  }