n8n 2.26.6 → 2.27.1

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 (660) 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/start.js +7 -3
  14. package/dist/commands/start.js.map +1 -1
  15. package/dist/commands/worker.js +6 -3
  16. package/dist/commands/worker.js.map +1 -1
  17. package/dist/concurrency/concurrency-queue.d.ts +1 -1
  18. package/dist/concurrency/concurrency-queue.js +2 -2
  19. package/dist/concurrency/concurrency-queue.js.map +1 -1
  20. package/dist/controllers/api-keys.controller.js +6 -2
  21. package/dist/controllers/api-keys.controller.js.map +1 -1
  22. package/dist/controllers/e2e.controller.js +1 -1
  23. package/dist/controllers/e2e.controller.js.map +1 -1
  24. package/dist/controllers/oauth/oauth2-credential.controller.js +7 -0
  25. package/dist/controllers/oauth/oauth2-credential.controller.js.map +1 -1
  26. package/dist/controllers/security-settings.controller.d.ts +3 -3
  27. package/dist/controllers/security-settings.controller.js +3 -8
  28. package/dist/controllers/security-settings.controller.js.map +1 -1
  29. package/dist/credentials-helper.js +3 -0
  30. package/dist/credentials-helper.js.map +1 -1
  31. package/dist/errors/http-error-serializers.js +2 -15
  32. package/dist/errors/http-error-serializers.js.map +1 -1
  33. package/dist/errors/response-errors/bad-request.error.d.ts +1 -1
  34. package/dist/errors/response-errors/bad-request.error.js +2 -2
  35. package/dist/errors/response-errors/bad-request.error.js.map +1 -1
  36. package/dist/errors/response-errors/unprocessable.error.d.ts +2 -1
  37. package/dist/errors/response-errors/unprocessable.error.js +2 -1
  38. package/dist/errors/response-errors/unprocessable.error.js.map +1 -1
  39. package/dist/events/event.service.d.ts +1 -1
  40. package/dist/events/event.service.js +2 -2
  41. package/dist/events/event.service.js.map +1 -1
  42. package/dist/events/maps/execution-data.event-map.d.ts +1 -0
  43. package/dist/events/maps/relay.event-map.d.ts +1 -0
  44. package/dist/events/relays/log-streaming.event-relay.js +2 -2
  45. package/dist/events/relays/log-streaming.event-relay.js.map +1 -1
  46. package/dist/events/relays/telemetry.event-relay.js +3 -2
  47. package/dist/events/relays/telemetry.event-relay.js.map +1 -1
  48. package/dist/executions/execution-data/db-store.d.ts +3 -1
  49. package/dist/executions/execution-data/db-store.js +14 -0
  50. package/dist/executions/execution-data/db-store.js.map +1 -1
  51. package/dist/executions/execution-data/fs-store.d.ts +1 -1
  52. package/dist/executions/execution-data/fs-store.js +3 -1
  53. package/dist/executions/execution-data/fs-store.js.map +1 -1
  54. package/dist/executions/execution-data/s3-store.ee.d.ts +15 -0
  55. package/dist/executions/execution-data/s3-store.ee.js +115 -0
  56. package/dist/executions/execution-data/s3-store.ee.js.map +1 -0
  57. package/dist/executions/execution-data/types.d.ts +1 -1
  58. package/dist/executions/execution-persistence.d.ts +16 -2
  59. package/dist/executions/execution-persistence.js +80 -22
  60. package/dist/executions/execution-persistence.js.map +1 -1
  61. package/dist/metrics/prometheus/active-workflow-metrics.service.d.ts +12 -0
  62. package/dist/metrics/prometheus/active-workflow-metrics.service.js +61 -0
  63. package/dist/metrics/prometheus/active-workflow-metrics.service.js.map +1 -0
  64. package/dist/metrics/prometheus/base.d.ts +5 -0
  65. package/dist/metrics/{types.js → prometheus/base.js} +1 -1
  66. package/dist/metrics/prometheus/base.js.map +1 -0
  67. package/dist/metrics/prometheus/cache-metrics.service.d.ts +11 -0
  68. package/dist/metrics/prometheus/cache-metrics.service.js +48 -0
  69. package/dist/metrics/prometheus/cache-metrics.service.js.map +1 -0
  70. package/dist/metrics/prometheus/constant.d.ts +2 -0
  71. package/dist/metrics/prometheus/constant.js +18 -0
  72. package/dist/metrics/prometheus/constant.js.map +1 -0
  73. package/dist/metrics/prometheus/default-metrics.service.d.ts +8 -0
  74. package/dist/metrics/prometheus/default-metrics.service.js +35 -0
  75. package/dist/metrics/prometheus/default-metrics.service.js.map +1 -0
  76. package/dist/metrics/prometheus/dns-cache-metrics.service.d.ts +12 -0
  77. package/dist/metrics/prometheus/dns-cache-metrics.service.js +58 -0
  78. package/dist/metrics/prometheus/dns-cache-metrics.service.js.map +1 -0
  79. package/dist/metrics/prometheus/event-bus-metrics.service.d.ts +15 -0
  80. package/dist/metrics/prometheus/event-bus-metrics.service.js +106 -0
  81. package/dist/metrics/prometheus/event-bus-metrics.service.js.map +1 -0
  82. package/dist/metrics/prometheus/execution-data-metrics.service.d.ts +12 -0
  83. package/dist/metrics/prometheus/execution-data-metrics.service.js +106 -0
  84. package/dist/metrics/prometheus/execution-data-metrics.service.js.map +1 -0
  85. package/dist/metrics/prometheus/index.d.ts +1 -0
  86. package/dist/metrics/prometheus/index.js +6 -0
  87. package/dist/metrics/prometheus/index.js.map +1 -0
  88. package/dist/metrics/prometheus/instance-role-metrics.service.d.ts +13 -0
  89. package/dist/metrics/prometheus/instance-role-metrics.service.js +61 -0
  90. package/dist/metrics/prometheus/instance-role-metrics.service.js.map +1 -0
  91. package/dist/metrics/prometheus/prometheus.service.d.ts +26 -0
  92. package/dist/metrics/prometheus/prometheus.service.js +105 -0
  93. package/dist/metrics/prometheus/prometheus.service.js.map +1 -0
  94. package/dist/metrics/prometheus/pss-metrics.service.d.ts +9 -0
  95. package/dist/metrics/prometheus/pss-metrics.service.js +59 -0
  96. package/dist/metrics/prometheus/pss-metrics.service.js.map +1 -0
  97. package/dist/metrics/prometheus/queue-metrics.service.d.ts +13 -0
  98. package/dist/metrics/prometheus/queue-metrics.service.js +71 -0
  99. package/dist/metrics/prometheus/queue-metrics.service.js.map +1 -0
  100. package/dist/metrics/prometheus/route-metrics.service.d.ts +11 -0
  101. package/dist/metrics/prometheus/route-metrics.service.js +69 -0
  102. package/dist/metrics/prometheus/route-metrics.service.js.map +1 -0
  103. package/dist/metrics/prometheus/ssrf-metrics.service.d.ts +11 -0
  104. package/dist/metrics/prometheus/ssrf-metrics.service.js +65 -0
  105. package/dist/metrics/prometheus/ssrf-metrics.service.js.map +1 -0
  106. package/dist/metrics/prometheus/token-exchange-metrics.service.d.ts +10 -0
  107. package/dist/metrics/prometheus/token-exchange-metrics.service.js +91 -0
  108. package/dist/metrics/prometheus/token-exchange-metrics.service.js.map +1 -0
  109. package/dist/metrics/prometheus/version-metrics.service.d.ts +8 -0
  110. package/dist/metrics/prometheus/version-metrics.service.js +46 -0
  111. package/dist/metrics/prometheus/version-metrics.service.js.map +1 -0
  112. package/dist/metrics/prometheus/workflow-execution-duration-metrics.service.d.ts +10 -0
  113. package/dist/metrics/prometheus/workflow-execution-duration-metrics.service.js +61 -0
  114. package/dist/metrics/prometheus/workflow-execution-duration-metrics.service.js.map +1 -0
  115. package/dist/metrics/prometheus/workflow-statistics-metrics.service.d.ts +17 -0
  116. package/dist/metrics/prometheus/workflow-statistics-metrics.service.js +130 -0
  117. package/dist/metrics/prometheus/workflow-statistics-metrics.service.js.map +1 -0
  118. package/dist/modules/agents/agent-knowledge.service.d.ts +3 -32
  119. package/dist/modules/agents/agent-knowledge.service.js +7 -248
  120. package/dist/modules/agents/agent-knowledge.service.js.map +1 -1
  121. package/dist/modules/agents/agent-runtime-reconstruction.service.d.ts +1 -6
  122. package/dist/modules/agents/agent-runtime-reconstruction.service.js +2 -28
  123. package/dist/modules/agents/agent-runtime-reconstruction.service.js.map +1 -1
  124. package/dist/modules/agents/agents-list.controller.d.ts +9 -0
  125. package/dist/modules/agents/agents-list.controller.js +39 -0
  126. package/dist/modules/agents/agents-list.controller.js.map +1 -0
  127. package/dist/modules/agents/agents.controller.d.ts +6 -6
  128. package/dist/modules/agents/agents.controller.js +12 -19
  129. package/dist/modules/agents/agents.controller.js.map +1 -1
  130. package/dist/modules/agents/agents.module.d.ts +3 -2
  131. package/dist/modules/agents/agents.module.js +4 -2
  132. package/dist/modules/agents/agents.module.js.map +1 -1
  133. package/dist/modules/agents/agents.service.d.ts +10 -2
  134. package/dist/modules/agents/agents.service.js +119 -82
  135. package/dist/modules/agents/agents.service.js.map +1 -1
  136. package/dist/modules/agents/entities/agent-chat-subscription.entity.d.ts +10 -0
  137. package/dist/modules/agents/entities/{agent-file.entity.js → agent-chat-subscription.entity.js} +34 -23
  138. package/dist/modules/agents/entities/agent-chat-subscription.entity.js.map +1 -0
  139. package/dist/modules/agents/execution-recorder.js +15 -2
  140. package/dist/modules/agents/execution-recorder.js.map +1 -1
  141. package/dist/modules/agents/integrations/agent-chat-subscription-state.adapter.d.ts +43 -0
  142. package/dist/modules/agents/integrations/agent-chat-subscription-state.adapter.js +139 -0
  143. package/dist/modules/agents/integrations/agent-chat-subscription-state.adapter.js.map +1 -0
  144. package/dist/modules/agents/integrations/agent-chat-subscription-state.service.d.ts +26 -0
  145. package/dist/modules/agents/integrations/agent-chat-subscription-state.service.js +88 -0
  146. package/dist/modules/agents/integrations/agent-chat-subscription-state.service.js.map +1 -0
  147. package/dist/modules/agents/integrations/chat-integration.service.d.ts +3 -1
  148. package/dist/modules/agents/integrations/chat-integration.service.js +47 -18
  149. package/dist/modules/agents/integrations/chat-integration.service.js.map +1 -1
  150. package/dist/modules/agents/integrations/component-mapper.js.map +1 -1
  151. package/dist/modules/agents/integrations/slack-app-setup.service.js +8 -8
  152. package/dist/modules/agents/integrations/slack-app-setup.service.js.map +1 -1
  153. package/dist/modules/agents/repositories/agent-chat-subscription.repository.d.ts +15 -0
  154. package/dist/modules/agents/repositories/agent-chat-subscription.repository.js +51 -0
  155. package/dist/modules/agents/repositories/agent-chat-subscription.repository.js.map +1 -0
  156. package/dist/modules/agents/repositories/agent.repository.d.ts +7 -0
  157. package/dist/modules/agents/repositories/agent.repository.js +28 -0
  158. package/dist/modules/agents/repositories/agent.repository.js.map +1 -1
  159. package/dist/modules/data-table/data-table.repository.js +1 -1
  160. package/dist/modules/data-table/data-table.repository.js.map +1 -1
  161. package/dist/modules/data-table/utils/sql-utils.js +16 -1
  162. package/dist/modules/data-table/utils/sql-utils.js.map +1 -1
  163. package/dist/modules/dynamic-credentials.ee/dynamic-credentials.module.js +15 -7
  164. package/dist/modules/dynamic-credentials.ee/dynamic-credentials.module.js.map +1 -1
  165. package/dist/modules/instance-ai/eval/execution.service.js +51 -32
  166. package/dist/modules/instance-ai/eval/execution.service.js.map +1 -1
  167. package/dist/modules/instance-ai/eval/mock-handler.js +77 -13
  168. package/dist/modules/instance-ai/eval/mock-handler.js.map +1 -1
  169. package/dist/modules/instance-ai/eval/mock-quirks.js +8 -1
  170. package/dist/modules/instance-ai/eval/mock-quirks.js.map +1 -1
  171. package/dist/modules/instance-ai/eval/workflow-analysis.js +2 -0
  172. package/dist/modules/instance-ai/eval/workflow-analysis.js.map +1 -1
  173. package/dist/modules/instance-ai/instance-ai.adapter.service.d.ts +5 -4
  174. package/dist/modules/instance-ai/instance-ai.adapter.service.js +7 -121
  175. package/dist/modules/instance-ai/instance-ai.adapter.service.js.map +1 -1
  176. package/dist/modules/instance-ai/instance-ai.controller.js +1 -1
  177. package/dist/modules/instance-ai/instance-ai.service.d.ts +5 -28
  178. package/dist/modules/instance-ai/instance-ai.service.js +58 -471
  179. package/dist/modules/instance-ai/instance-ai.service.js.map +1 -1
  180. package/dist/modules/instance-ai/output-redaction-config.d.ts +3 -0
  181. package/dist/modules/instance-ai/output-redaction-config.js +19 -0
  182. package/dist/modules/instance-ai/output-redaction-config.js.map +1 -0
  183. package/dist/modules/instance-ai/sandbox/index.d.ts +1 -0
  184. package/dist/modules/instance-ai/sandbox/index.js +6 -0
  185. package/dist/modules/instance-ai/sandbox/index.js.map +1 -0
  186. package/dist/modules/instance-ai/sandbox/instance-ai-sandbox.service.d.ts +77 -0
  187. package/dist/modules/instance-ai/sandbox/instance-ai-sandbox.service.js +297 -0
  188. package/dist/modules/instance-ai/sandbox/instance-ai-sandbox.service.js.map +1 -0
  189. package/dist/modules/instance-ai/suspended-run-restorer.service.d.ts +62 -0
  190. package/dist/modules/instance-ai/suspended-run-restorer.service.js +116 -0
  191. package/dist/modules/instance-ai/suspended-run-restorer.service.js.map +1 -0
  192. package/dist/modules/instance-ai/suspended-thread-persistence.service.d.ts +51 -0
  193. package/dist/modules/instance-ai/suspended-thread-persistence.service.js +106 -0
  194. package/dist/modules/instance-ai/suspended-thread-persistence.service.js.map +1 -0
  195. package/dist/modules/instance-ai/web-research/fetch-and-extract.d.ts +1 -1
  196. package/dist/modules/mcp/mcp-api-key.service.d.ts +3 -7
  197. package/dist/modules/mcp/mcp-api-key.service.js +1 -22
  198. package/dist/modules/mcp/mcp-api-key.service.js.map +1 -1
  199. package/dist/modules/mcp/mcp-protected-resource.d.ts +13 -0
  200. package/dist/modules/mcp/mcp-protected-resource.js +39 -0
  201. package/dist/modules/mcp/mcp-protected-resource.js.map +1 -0
  202. package/dist/modules/mcp/mcp-server-middleware.service.d.ts +5 -4
  203. package/dist/modules/mcp/mcp-server-middleware.service.js +9 -6
  204. package/dist/modules/mcp/mcp-server-middleware.service.js.map +1 -1
  205. package/dist/modules/mcp/mcp.config.d.ts +3 -0
  206. package/dist/modules/mcp/mcp.config.js +28 -0
  207. package/dist/modules/mcp/mcp.config.js.map +1 -0
  208. package/dist/modules/mcp/mcp.controller.js +4 -2
  209. package/dist/modules/mcp/mcp.controller.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.config.d.ts +7 -0
  349. package/dist/modules/oauth-server/oauth-server.config.js +49 -0
  350. package/dist/modules/oauth-server/oauth-server.config.js.map +1 -0
  351. package/dist/modules/oauth-server/oauth-server.module.d.ts +5 -0
  352. package/dist/modules/oauth-server/oauth-server.module.js +75 -0
  353. package/dist/modules/oauth-server/oauth-server.module.js.map +1 -0
  354. package/dist/modules/{mcp/mcp-oauth-service.d.ts → oauth-server/oauth-server.service.d.ts} +6 -6
  355. package/dist/modules/{mcp/mcp-oauth-service.js → oauth-server/oauth-server.service.js} +33 -30
  356. package/dist/modules/oauth-server/oauth-server.service.js.map +1 -0
  357. package/dist/modules/oauth-server/oauth-session.service.js.map +1 -0
  358. package/dist/modules/{mcp/mcp-oauth-token.service.d.ts → oauth-server/oauth-token.service.d.ts} +5 -8
  359. package/dist/modules/{mcp/mcp-oauth-token.service.js → oauth-server/oauth-token.service.js} +29 -30
  360. package/dist/modules/oauth-server/oauth-token.service.js.map +1 -0
  361. package/dist/modules/{mcp/mcp.oauth.controller.d.ts → oauth-server/oauth.controller.d.ts} +5 -3
  362. package/dist/modules/{mcp/mcp.oauth.controller.js → oauth-server/oauth.controller.js} +86 -72
  363. package/dist/modules/oauth-server/oauth.controller.js.map +1 -0
  364. package/dist/modules/oauth-server/oauth.errors.d.ts +13 -0
  365. package/dist/modules/oauth-server/oauth.errors.js +30 -0
  366. package/dist/modules/oauth-server/oauth.errors.js.map +1 -0
  367. package/dist/modules/{mcp/mcp-oauth.helpers.d.ts → oauth-server/oauth.helpers.d.ts} +1 -1
  368. package/dist/modules/{mcp/mcp-oauth.helpers.js → oauth-server/oauth.helpers.js} +4 -4
  369. package/dist/modules/oauth-server/oauth.helpers.js.map +1 -0
  370. package/dist/modules/oauth-server/protected-resource-resolvers/utils.d.ts +4 -0
  371. package/dist/modules/oauth-server/protected-resource-resolvers/utils.js +41 -0
  372. package/dist/modules/oauth-server/protected-resource-resolvers/utils.js.map +1 -0
  373. package/dist/modules/oauth-server/protected-resource-resolvers/workflow-mcp-test-trigger-resource.resolver.d.ts +28 -0
  374. package/dist/modules/oauth-server/protected-resource-resolvers/workflow-mcp-test-trigger-resource.resolver.js +78 -0
  375. package/dist/modules/oauth-server/protected-resource-resolvers/workflow-mcp-test-trigger-resource.resolver.js.map +1 -0
  376. package/dist/modules/oauth-server/protected-resource-resolvers/workflow-mcp-trigger-resource.resolver.d.ts +30 -0
  377. package/dist/modules/oauth-server/protected-resource-resolvers/workflow-mcp-trigger-resource.resolver.js +95 -0
  378. package/dist/modules/oauth-server/protected-resource-resolvers/workflow-mcp-trigger-resource.resolver.js.map +1 -0
  379. package/dist/modules/otel/execution-level-tracer.d.ts +5 -4
  380. package/dist/modules/otel/execution-level-tracer.js +8 -5
  381. package/dist/modules/otel/execution-level-tracer.js.map +1 -1
  382. package/dist/modules/otel/otel-lifecycle-handler.d.ts +8 -4
  383. package/dist/modules/otel/otel-lifecycle-handler.js +32 -15
  384. package/dist/modules/otel/otel-lifecycle-handler.js.map +1 -1
  385. package/dist/modules/otel/otel-settings.controller.d.ts +18 -0
  386. package/dist/modules/otel/otel-settings.controller.js +79 -0
  387. package/dist/modules/otel/otel-settings.controller.js.map +1 -0
  388. package/dist/modules/otel/otel-settings.service.d.ts +21 -0
  389. package/dist/modules/otel/otel-settings.service.js +89 -0
  390. package/dist/modules/otel/otel-settings.service.js.map +1 -0
  391. package/dist/modules/otel/otel.config.js +11 -10
  392. package/dist/modules/otel/otel.config.js.map +1 -1
  393. package/dist/modules/otel/otel.constants.d.ts +14 -0
  394. package/dist/modules/otel/otel.constants.js +15 -1
  395. package/dist/modules/otel/otel.constants.js.map +1 -1
  396. package/dist/modules/otel/otel.module.js +9 -17
  397. package/dist/modules/otel/otel.module.js.map +1 -1
  398. package/dist/modules/otel/otel.service.d.ts +15 -4
  399. package/dist/modules/otel/otel.service.js +73 -17
  400. package/dist/modules/otel/otel.service.js.map +1 -1
  401. package/dist/modules/provisioning.ee/role-mapping-rule.service.ee.d.ts +1 -0
  402. package/dist/modules/provisioning.ee/role-mapping-rule.service.ee.js +46 -19
  403. package/dist/modules/provisioning.ee/role-mapping-rule.service.ee.js.map +1 -1
  404. package/dist/modules/redaction/instance-redaction-enforcement.service.js +0 -6
  405. package/dist/modules/redaction/instance-redaction-enforcement.service.js.map +1 -1
  406. package/dist/modules/source-control.ee/source-control-git.service.ee.js +2 -5
  407. package/dist/modules/source-control.ee/source-control-git.service.ee.js.map +1 -1
  408. package/dist/modules/sso-saml/saml.service.ee.js +3 -2
  409. package/dist/modules/sso-saml/saml.service.ee.js.map +1 -1
  410. package/dist/modules/workflow-index/workflow-dependency-query.service.js +39 -20
  411. package/dist/modules/workflow-index/workflow-dependency-query.service.js.map +1 -1
  412. package/dist/oauth/oauth.service.d.ts +14 -0
  413. package/dist/oauth/oauth.service.js +220 -102
  414. package/dist/oauth/oauth.service.js.map +1 -1
  415. package/dist/oauth/types.d.ts +1 -0
  416. package/dist/oauth/types.js.map +1 -1
  417. package/dist/public-api/index.js +8 -8
  418. package/dist/public-api/index.js.map +1 -1
  419. package/dist/public-api/types.d.ts +1 -6
  420. package/dist/public-api/v1/handlers/credentials/credentials.service.js +7 -8
  421. package/dist/public-api/v1/handlers/credentials/credentials.service.js.map +1 -1
  422. package/dist/public-api/v1/handlers/executions/executions.handler.js +1 -1
  423. package/dist/public-api/v1/handlers/executions/executions.handler.js.map +1 -1
  424. package/dist/public-api/v1/handlers/n8n-packages/n8n-packages.handler.js +3 -3
  425. package/dist/public-api/v1/handlers/n8n-packages/n8n-packages.handler.js.map +1 -1
  426. package/dist/public-api/v1/openapi.yml +208 -51
  427. package/dist/push/abstract.push.d.ts +1 -2
  428. package/dist/push/abstract.push.js +1 -2
  429. package/dist/push/abstract.push.js.map +1 -1
  430. package/dist/push/index.d.ts +1 -2
  431. package/dist/push/index.js +3 -4
  432. package/dist/push/index.js.map +1 -1
  433. package/dist/scaling/constants.d.ts +2 -2
  434. package/dist/scaling/constants.js +1 -0
  435. package/dist/scaling/constants.js.map +1 -1
  436. package/dist/scaling/job-processor.d.ts +0 -1
  437. package/dist/scaling/job-processor.js +1 -23
  438. package/dist/scaling/job-processor.js.map +1 -1
  439. package/dist/scaling/multi-main-setup.ee.d.ts +1 -2
  440. package/dist/scaling/multi-main-setup.ee.js +1 -2
  441. package/dist/scaling/multi-main-setup.ee.js.map +1 -1
  442. package/dist/scaling/pubsub/pubsub.event-map.d.ts +7 -0
  443. package/dist/scaling/pubsub/pubsub.eventbus.d.ts +1 -1
  444. package/dist/scaling/pubsub/pubsub.eventbus.js +2 -2
  445. package/dist/scaling/pubsub/pubsub.eventbus.js.map +1 -1
  446. package/dist/scaling/pubsub/pubsub.types.d.ts +3 -1
  447. package/dist/scaling/worker-server.d.ts +1 -1
  448. package/dist/scaling/worker-server.js +5 -5
  449. package/dist/scaling/worker-server.js.map +1 -1
  450. package/dist/server.js +4 -3
  451. package/dist/server.js.map +1 -1
  452. package/dist/services/ai-workflow-builder.service.d.ts +2 -1
  453. package/dist/services/ai-workflow-builder.service.js +2 -1
  454. package/dist/services/ai-workflow-builder.service.js.map +1 -1
  455. package/dist/services/cache/cache.service.d.ts +1 -1
  456. package/dist/services/cache/cache.service.js +2 -2
  457. package/dist/services/cache/cache.service.js.map +1 -1
  458. package/dist/services/node-resource-explorer.service.d.ts +16 -0
  459. package/dist/services/node-resource-explorer.service.js +154 -0
  460. package/dist/services/node-resource-explorer.service.js.map +1 -0
  461. package/dist/services/oauth-token-verifier-proxy.service.d.ts +22 -0
  462. package/dist/services/oauth-token-verifier-proxy.service.js +36 -0
  463. package/dist/services/oauth-token-verifier-proxy.service.js.map +1 -0
  464. package/dist/services/protected-resource.registry.d.ts +31 -0
  465. package/dist/services/protected-resource.registry.js +115 -0
  466. package/dist/services/protected-resource.registry.js.map +1 -0
  467. package/dist/services/public-api-key.service.d.ts +8 -2
  468. package/dist/services/public-api-key.service.js +29 -6
  469. package/dist/services/public-api-key.service.js.map +1 -1
  470. package/dist/services/redis-client.service.d.ts +2 -2
  471. package/dist/services/redis-client.service.js +6 -4
  472. package/dist/services/redis-client.service.js.map +1 -1
  473. package/dist/services/tag.service.d.ts +10 -0
  474. package/dist/services/tag.service.js +84 -4
  475. package/dist/services/tag.service.js.map +1 -1
  476. package/dist/services/workflow-statistics.service.d.ts +1 -2
  477. package/dist/services/workflow-statistics.service.js +1 -2
  478. package/dist/services/workflow-statistics.service.js.map +1 -1
  479. package/dist/task-runners/sliding-window-signal.d.ts +1 -1
  480. package/dist/task-runners/task-runner-lifecycle-events.d.ts +1 -1
  481. package/dist/task-runners/task-runner-lifecycle-events.js +2 -2
  482. package/dist/task-runners/task-runner-lifecycle-events.js.map +1 -1
  483. package/dist/task-runners/task-runner-process-base.d.ts +1 -2
  484. package/dist/task-runners/task-runner-process-base.js +1 -2
  485. package/dist/task-runners/task-runner-process-base.js.map +1 -1
  486. package/dist/task-runners/task-runner-process-restart-loop-detector.d.ts +1 -1
  487. package/dist/task-runners/task-runner-process-restart-loop-detector.js +2 -2
  488. package/dist/task-runners/task-runner-process-restart-loop-detector.js.map +1 -1
  489. package/dist/user-management/email/templates/api-key-revoked.handlebars +196 -0
  490. package/dist/user-management/email/user-management-mailer.d.ts +6 -2
  491. package/dist/user-management/email/user-management-mailer.js +32 -0
  492. package/dist/user-management/email/user-management-mailer.js.map +1 -1
  493. package/dist/wait-tracker.d.ts +1 -1
  494. package/dist/wait-tracker.js +3 -3
  495. package/dist/wait-tracker.js.map +1 -1
  496. package/dist/webhooks/webhook-helpers.js +30 -1
  497. package/dist/webhooks/webhook-helpers.js.map +1 -1
  498. package/dist/webhooks/webhook-server.js +2 -2
  499. package/dist/webhooks/webhook-server.js.map +1 -1
  500. package/dist/webhooks/webhook.service.d.ts +4 -1
  501. package/dist/webhooks/webhook.service.js +19 -4
  502. package/dist/webhooks/webhook.service.js.map +1 -1
  503. package/dist/workflow-execute-additional-data.d.ts +1 -1
  504. package/dist/workflow-execute-additional-data.js +4 -1
  505. package/dist/workflow-execute-additional-data.js.map +1 -1
  506. package/dist/workflow-helpers.d.ts +1 -1
  507. package/dist/workflow-helpers.js +13 -3
  508. package/dist/workflow-helpers.js.map +1 -1
  509. package/dist/workflow-runner.js +0 -2
  510. package/dist/workflow-runner.js.map +1 -1
  511. package/dist/workflows/publication/publication-result.d.ts +17 -0
  512. package/dist/workflows/publication/publication-result.js +3 -0
  513. package/dist/workflows/publication/publication-result.js.map +1 -0
  514. package/dist/workflows/publication/publication-status-reporter.d.ts +19 -0
  515. package/dist/workflows/publication/publication-status-reporter.js +110 -0
  516. package/dist/workflows/publication/publication-status-reporter.js.map +1 -0
  517. package/dist/workflows/publication/trigger-diff.d.ts +6 -0
  518. package/dist/workflows/publication/trigger-diff.js +27 -0
  519. package/dist/workflows/publication/trigger-diff.js.map +1 -0
  520. package/dist/workflows/publication/workflow-publication-applier.d.ts +14 -0
  521. package/dist/workflows/publication/workflow-publication-applier.js +96 -0
  522. package/dist/workflows/publication/workflow-publication-applier.js.map +1 -0
  523. package/dist/workflows/{workflow-publication-outbox-consumer.d.ts → publication/workflow-publication-outbox-consumer.d.ts} +9 -13
  524. package/dist/workflows/{workflow-publication-outbox-consumer.js → publication/workflow-publication-outbox-consumer.js} +25 -93
  525. package/dist/workflows/publication/workflow-publication-outbox-consumer.js.map +1 -0
  526. package/dist/workflows/triggers/non-webhook-trigger-registrar.d.ts +39 -0
  527. package/dist/workflows/triggers/non-webhook-trigger-registrar.js +58 -0
  528. package/dist/workflows/triggers/non-webhook-trigger-registrar.js.map +1 -0
  529. package/dist/workflows/triggers/trigger-count.service.d.ts +5 -0
  530. package/dist/workflows/triggers/trigger-count.service.js +65 -0
  531. package/dist/workflows/triggers/trigger-count.service.js.map +1 -0
  532. package/dist/workflows/triggers/trigger-execution-context.factory.d.ts +33 -0
  533. package/dist/workflows/triggers/trigger-execution-context.factory.js +171 -0
  534. package/dist/workflows/triggers/trigger-execution-context.factory.js.map +1 -0
  535. package/dist/workflows/triggers/webhook-trigger-registrar.d.ts +29 -0
  536. package/dist/workflows/triggers/webhook-trigger-registrar.js +143 -0
  537. package/dist/workflows/triggers/webhook-trigger-registrar.js.map +1 -0
  538. package/dist/workflows/triggers/workflow-trigger-activator.d.ts +56 -0
  539. package/dist/workflows/triggers/workflow-trigger-activator.js +313 -0
  540. package/dist/workflows/triggers/workflow-trigger-activator.js.map +1 -0
  541. package/dist/workflows/workflow-validation.service.d.ts +3 -0
  542. package/dist/workflows/workflow-validation.service.js +63 -37
  543. package/dist/workflows/workflow-validation.service.js.map +1 -1
  544. package/dist/workflows/workflow.service.d.ts +5 -3
  545. package/dist/workflows/workflow.service.js +91 -28
  546. package/dist/workflows/workflow.service.js.map +1 -1
  547. package/dist/workflows/workflows.controller.d.ts +3 -3
  548. package/dist/workflows/workflows.controller.js +3 -3
  549. package/dist/workflows/workflows.controller.js.map +1 -1
  550. package/package.json +35 -34
  551. package/templates/oauth-callback.handlebars +3 -0
  552. package/templates/oauth-error-callback.handlebars +3 -0
  553. package/dist/metrics/prometheus-metrics.service.d.ts +0 -54
  554. package/dist/metrics/prometheus-metrics.service.js +0 -607
  555. package/dist/metrics/prometheus-metrics.service.js.map +0 -1
  556. package/dist/metrics/types.d.ts +0 -6
  557. package/dist/metrics/types.js.map +0 -1
  558. package/dist/modules/agents/agent-knowledge-command.service.d.ts +0 -40
  559. package/dist/modules/agents/agent-knowledge-command.service.js +0 -221
  560. package/dist/modules/agents/agent-knowledge-command.service.js.map +0 -1
  561. package/dist/modules/agents/entities/agent-file.entity.d.ts +0 -11
  562. package/dist/modules/agents/entities/agent-file.entity.js.map +0 -1
  563. package/dist/modules/agents/repositories/agent-file.repository.d.ts +0 -7
  564. package/dist/modules/agents/repositories/agent-file.repository.js +0 -35
  565. package/dist/modules/agents/repositories/agent-file.repository.js.map +0 -1
  566. package/dist/modules/agents/tools/knowledge/csv-helpers.d.ts +0 -73
  567. package/dist/modules/agents/tools/knowledge/csv-helpers.js +0 -341
  568. package/dist/modules/agents/tools/knowledge/csv-helpers.js.map +0 -1
  569. package/dist/modules/agents/tools/knowledge/csv.operation.d.ts +0 -61
  570. package/dist/modules/agents/tools/knowledge/csv.operation.js +0 -207
  571. package/dist/modules/agents/tools/knowledge/csv.operation.js.map +0 -1
  572. package/dist/modules/agents/tools/knowledge/file-references.d.ts +0 -16
  573. package/dist/modules/agents/tools/knowledge/file-references.js +0 -35
  574. package/dist/modules/agents/tools/knowledge/file-references.js.map +0 -1
  575. package/dist/modules/agents/tools/knowledge/read.operation.d.ts +0 -8
  576. package/dist/modules/agents/tools/knowledge/read.operation.js +0 -38
  577. package/dist/modules/agents/tools/knowledge/read.operation.js.map +0 -1
  578. package/dist/modules/agents/tools/knowledge/schemas.d.ts +0 -1505
  579. package/dist/modules/agents/tools/knowledge/schemas.js +0 -441
  580. package/dist/modules/agents/tools/knowledge/schemas.js.map +0 -1
  581. package/dist/modules/agents/tools/knowledge/search.operation.d.ts +0 -9
  582. package/dist/modules/agents/tools/knowledge/search.operation.js +0 -332
  583. package/dist/modules/agents/tools/knowledge/search.operation.js.map +0 -1
  584. package/dist/modules/agents/tools/knowledge/tool.d.ts +0 -8
  585. package/dist/modules/agents/tools/knowledge/tool.js +0 -121
  586. package/dist/modules/agents/tools/knowledge/tool.js.map +0 -1
  587. package/dist/modules/mcp/database/entities/oauth-access-token.entity.js.map +0 -1
  588. package/dist/modules/mcp/database/entities/oauth-authorization-code.entity.js.map +0 -1
  589. package/dist/modules/mcp/database/entities/oauth-client.entity.js.map +0 -1
  590. package/dist/modules/mcp/database/entities/oauth-refresh-token.entity.js.map +0 -1
  591. package/dist/modules/mcp/database/entities/oauth-user-consent.entity.js.map +0 -1
  592. package/dist/modules/mcp/database/repositories/oauth-access-token.repository.js.map +0 -1
  593. package/dist/modules/mcp/database/repositories/oauth-authorization-code.repository.js.map +0 -1
  594. package/dist/modules/mcp/database/repositories/oauth-client.repository.js.map +0 -1
  595. package/dist/modules/mcp/database/repositories/oauth-refresh-token.repository.js.map +0 -1
  596. package/dist/modules/mcp/database/repositories/oauth-user-consent.repository.js.map +0 -1
  597. package/dist/modules/mcp/dto/approve-consent-request.dto.js.map +0 -1
  598. package/dist/modules/mcp/mcp-oauth-authorization-code.service.js.map +0 -1
  599. package/dist/modules/mcp/mcp-oauth-consent.service.js.map +0 -1
  600. package/dist/modules/mcp/mcp-oauth-service.js.map +0 -1
  601. package/dist/modules/mcp/mcp-oauth-token.service.js.map +0 -1
  602. package/dist/modules/mcp/mcp-oauth.helpers.js.map +0 -1
  603. package/dist/modules/mcp/mcp.auth.consent.controller.js.map +0 -1
  604. package/dist/modules/mcp/mcp.oauth-clients.controller.js.map +0 -1
  605. package/dist/modules/mcp/mcp.oauth.controller.js.map +0 -1
  606. package/dist/modules/mcp/oauth-session.service.js.map +0 -1
  607. package/dist/modules/n8n-packages/entities/credential/credential-missing-mode-factory.d.ts +0 -7
  608. package/dist/modules/n8n-packages/entities/credential/credential-missing-mode-factory.js +0 -35
  609. package/dist/modules/n8n-packages/entities/credential/credential-missing-mode-factory.js.map +0 -1
  610. package/dist/modules/n8n-packages/entities/credential/credential-resolution-error.d.ts +0 -3
  611. package/dist/modules/n8n-packages/entities/credential/credential-resolution-error.js +0 -14
  612. package/dist/modules/n8n-packages/entities/credential/credential-resolution-error.js.map +0 -1
  613. package/dist/modules/n8n-packages/entities/workflow/workflow-conflict-policy-fail.handler.d.ts +0 -9
  614. package/dist/modules/n8n-packages/entities/workflow/workflow-conflict-policy-fail.handler.js +0 -41
  615. package/dist/modules/n8n-packages/entities/workflow/workflow-conflict-policy-fail.handler.js.map +0 -1
  616. package/dist/modules/n8n-packages/entities/workflow/workflow-conflict-policy-handler.d.ts +0 -10
  617. package/dist/modules/n8n-packages/entities/workflow/workflow-conflict-policy-handler.js +0 -20
  618. package/dist/modules/n8n-packages/entities/workflow/workflow-conflict-policy-handler.js.map +0 -1
  619. package/dist/modules/n8n-packages/entities/workflow/workflow-conflict-policy-new-version.handler.d.ts +0 -11
  620. package/dist/modules/n8n-packages/entities/workflow/workflow-conflict-policy-new-version.handler.js +0 -42
  621. package/dist/modules/n8n-packages/entities/workflow/workflow-conflict-policy-new-version.handler.js.map +0 -1
  622. package/dist/modules/n8n-packages/entities/workflow/workflow-conflict-policy-skip.handler.d.ts +0 -9
  623. package/dist/modules/n8n-packages/entities/workflow/workflow-conflict-policy-skip.handler.js +0 -33
  624. package/dist/modules/n8n-packages/entities/workflow/workflow-conflict-policy-skip.handler.js.map +0 -1
  625. package/dist/modules/n8n-packages/entities/workflow/workflow-conflict-policy.factory.d.ts +0 -10
  626. package/dist/modules/n8n-packages/entities/workflow/workflow-conflict-policy.factory.js +0 -37
  627. package/dist/modules/n8n-packages/entities/workflow/workflow-conflict-policy.factory.js.map +0 -1
  628. package/dist/modules/n8n-packages/entities/workflow/workflow-conflict-policy.types.d.ts +0 -20
  629. package/dist/modules/n8n-packages/entities/workflow/workflow-conflict-policy.types.js.map +0 -1
  630. package/dist/modules/redaction/redaction-enforcement.feature-flag.d.ts +0 -2
  631. package/dist/modules/redaction/redaction-enforcement.feature-flag.js +0 -9
  632. package/dist/modules/redaction/redaction-enforcement.feature-flag.js.map +0 -1
  633. package/dist/typed-emitter.d.ts +0 -14
  634. package/dist/typed-emitter.js +0 -29
  635. package/dist/typed-emitter.js.map +0 -1
  636. package/dist/workflows/workflow-publication-outbox-consumer.js.map +0 -1
  637. /package/dist/modules/{mcp → oauth-server}/database/entities/oauth-access-token.entity.d.ts +0 -0
  638. /package/dist/modules/{mcp → oauth-server}/database/entities/oauth-access-token.entity.js +0 -0
  639. /package/dist/modules/{mcp → oauth-server}/database/entities/oauth-authorization-code.entity.d.ts +0 -0
  640. /package/dist/modules/{mcp → oauth-server}/database/entities/oauth-authorization-code.entity.js +0 -0
  641. /package/dist/modules/{mcp → oauth-server}/database/entities/oauth-client.entity.d.ts +0 -0
  642. /package/dist/modules/{mcp → oauth-server}/database/entities/oauth-client.entity.js +0 -0
  643. /package/dist/modules/{mcp → oauth-server}/database/entities/oauth-refresh-token.entity.d.ts +0 -0
  644. /package/dist/modules/{mcp → oauth-server}/database/entities/oauth-refresh-token.entity.js +0 -0
  645. /package/dist/modules/{mcp → oauth-server}/database/entities/oauth-user-consent.entity.d.ts +0 -0
  646. /package/dist/modules/{mcp → oauth-server}/database/entities/oauth-user-consent.entity.js +0 -0
  647. /package/dist/modules/{mcp → oauth-server}/database/repositories/oauth-access-token.repository.d.ts +0 -0
  648. /package/dist/modules/{mcp → oauth-server}/database/repositories/oauth-access-token.repository.js +0 -0
  649. /package/dist/modules/{mcp → oauth-server}/database/repositories/oauth-authorization-code.repository.d.ts +0 -0
  650. /package/dist/modules/{mcp → oauth-server}/database/repositories/oauth-authorization-code.repository.js +0 -0
  651. /package/dist/modules/{mcp → oauth-server}/database/repositories/oauth-client.repository.d.ts +0 -0
  652. /package/dist/modules/{mcp → oauth-server}/database/repositories/oauth-client.repository.js +0 -0
  653. /package/dist/modules/{mcp → oauth-server}/database/repositories/oauth-refresh-token.repository.d.ts +0 -0
  654. /package/dist/modules/{mcp → oauth-server}/database/repositories/oauth-refresh-token.repository.js +0 -0
  655. /package/dist/modules/{mcp → oauth-server}/database/repositories/oauth-user-consent.repository.d.ts +0 -0
  656. /package/dist/modules/{mcp → oauth-server}/database/repositories/oauth-user-consent.repository.js +0 -0
  657. /package/dist/modules/{mcp → oauth-server}/dto/approve-consent-request.dto.d.ts +0 -0
  658. /package/dist/modules/{mcp → oauth-server}/dto/approve-consent-request.dto.js +0 -0
  659. /package/dist/modules/{mcp → oauth-server}/oauth-session.service.d.ts +0 -0
  660. /package/dist/modules/{mcp → oauth-server}/oauth-session.service.js +0 -0
@@ -0,0 +1,96 @@
1
+ "use strict";
2
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
3
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
4
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
5
+ else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
6
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
7
+ };
8
+ var __metadata = (this && this.__metadata) || function (k, v) {
9
+ if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
10
+ };
11
+ Object.defineProperty(exports, "__esModule", { value: true });
12
+ exports.WorkflowPublicationApplier = void 0;
13
+ const db_1 = require("@n8n/db");
14
+ const di_1 = require("@n8n/di");
15
+ const n8n_workflow_1 = require("n8n-workflow");
16
+ const trigger_diff_1 = require("../../workflows/publication/trigger-diff");
17
+ const workflow_trigger_activator_1 = require("../../workflows/triggers/workflow-trigger-activator");
18
+ let WorkflowPublicationApplier = class WorkflowPublicationApplier {
19
+ constructor(workflowRepository, workflowHistoryRepository, workflowPublishedVersionRepository, workflowTriggerActivator) {
20
+ this.workflowRepository = workflowRepository;
21
+ this.workflowHistoryRepository = workflowHistoryRepository;
22
+ this.workflowPublishedVersionRepository = workflowPublishedVersionRepository;
23
+ this.workflowTriggerActivator = workflowTriggerActivator;
24
+ }
25
+ async apply(record) {
26
+ const { workflow, oldVersion, newVersion } = await this.resolveVersions(record);
27
+ if (!workflow)
28
+ return { type: 'skipped', reason: 'workflow-not-found' };
29
+ if (workflow.activeVersionId === null) {
30
+ return { type: 'skipped', reason: 'workflow-inactive' };
31
+ }
32
+ if (!newVersion)
33
+ return { type: 'version-missing' };
34
+ const oldTriggerNodes = this.workflowTriggerActivator.getEnabledTriggerNodes(oldVersion);
35
+ const desiredTriggerNodes = this.workflowTriggerActivator.getEnabledTriggerNodes(newVersion);
36
+ const { toAdd, toRemove } = (0, trigger_diff_1.computeTriggerDiff)(oldTriggerNodes, desiredTriggerNodes);
37
+ this.workflowTriggerActivator
38
+ .getUnregisteredNonWebhookTriggerNodeIds(record.workflowId, desiredTriggerNodes)
39
+ .forEach((nodeId) => toAdd.add(nodeId));
40
+ if (toAdd.size === 0 && toRemove.size === 0) {
41
+ await this.advancePublishedVersion(record);
42
+ return { type: 'completed' };
43
+ }
44
+ if (toRemove.size > 0 && oldVersion) {
45
+ await this.workflowTriggerActivator.deactivate(workflow, oldVersion, toRemove);
46
+ }
47
+ await this.advancePublishedVersion(record);
48
+ try {
49
+ if (toAdd.size > 0) {
50
+ const outcome = await this.workflowTriggerActivator.activate(workflow, newVersion, toAdd);
51
+ return this.classifyActivationOutcome(outcome);
52
+ }
53
+ if (toRemove.size > 0) {
54
+ await this.workflowTriggerActivator.updateTriggerCount(workflow, newVersion);
55
+ }
56
+ }
57
+ catch (e) {
58
+ return { type: 'failed', error: (0, n8n_workflow_1.ensureError)(e) };
59
+ }
60
+ return { type: 'completed' };
61
+ }
62
+ classifyActivationOutcome(outcome) {
63
+ if (outcome.failures.length === 0)
64
+ return { type: 'completed' };
65
+ return {
66
+ type: 'partial',
67
+ activatedNodeIds: outcome.activated,
68
+ failures: outcome.failures,
69
+ };
70
+ }
71
+ async resolveVersions(record) {
72
+ const [workflow, currentlyPublishedVersion, newVersion] = await Promise.all([
73
+ this.workflowRepository.findOneBy({ id: record.workflowId }),
74
+ this.workflowPublishedVersionRepository.findOne({
75
+ where: { workflowId: record.workflowId },
76
+ relations: { publishedVersion: true },
77
+ loadEagerRelations: false,
78
+ }),
79
+ this.workflowHistoryRepository.findOneBy({ versionId: record.publishedVersionId }),
80
+ ]);
81
+ const oldVersion = currentlyPublishedVersion?.publishedVersion ?? null;
82
+ return { workflow, oldVersion, newVersion };
83
+ }
84
+ async advancePublishedVersion(record) {
85
+ await this.workflowPublishedVersionRepository.setPublishedVersion(record.workflowId, record.publishedVersionId);
86
+ }
87
+ };
88
+ exports.WorkflowPublicationApplier = WorkflowPublicationApplier;
89
+ exports.WorkflowPublicationApplier = WorkflowPublicationApplier = __decorate([
90
+ (0, di_1.Service)(),
91
+ __metadata("design:paramtypes", [db_1.WorkflowRepository,
92
+ db_1.WorkflowHistoryRepository,
93
+ db_1.WorkflowPublishedVersionRepository,
94
+ workflow_trigger_activator_1.WorkflowTriggerActivator])
95
+ ], WorkflowPublicationApplier);
96
+ //# sourceMappingURL=workflow-publication-applier.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"workflow-publication-applier.js","sourceRoot":"","sources":["../../../src/workflows/publication/workflow-publication-applier.ts"],"names":[],"mappings":"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"}
@@ -1,31 +1,27 @@
1
1
  import { Logger } from '@n8n/backend-common';
2
2
  import { WorkflowsConfig } from '@n8n/config';
3
- import { WorkflowPublicationOutbox, WorkflowPublicationOutboxRepository, WorkflowRepository } from '@n8n/db';
4
- import { ErrorReporter } from 'n8n-core';
5
- import { ActivationErrorsService } from '../activation-errors.service';
6
- import { ActiveWorkflowManager } from '../active-workflow-manager';
3
+ import { WorkflowPublicationOutbox, WorkflowPublicationOutboxRepository } from '@n8n/db';
4
+ import { ErrorReporter, InstanceSettings } from 'n8n-core';
5
+ import { PublicationStatusReporter } from '../../workflows/publication/publication-status-reporter';
6
+ import { WorkflowPublicationApplier } from '../../workflows/publication/workflow-publication-applier';
7
7
  export declare class WorkflowPublicationOutboxConsumer {
8
8
  private readonly logger;
9
9
  private readonly workflowsConfig;
10
10
  private readonly errorReporter;
11
11
  private readonly outboxRepository;
12
- private readonly workflowRepository;
13
- private readonly activeWorkflowManager;
14
- private readonly activationErrorsService;
12
+ private readonly applier;
13
+ private readonly reporter;
14
+ private readonly instanceSettings;
15
15
  private pollTimeout;
16
16
  private isPolling;
17
17
  private isShuttingDown;
18
- constructor(logger: Logger, workflowsConfig: WorkflowsConfig, errorReporter: ErrorReporter, outboxRepository: WorkflowPublicationOutboxRepository, workflowRepository: WorkflowRepository, activeWorkflowManager: ActiveWorkflowManager, activationErrorsService: ActivationErrorsService);
18
+ constructor(logger: Logger, workflowsConfig: WorkflowsConfig, errorReporter: ErrorReporter, outboxRepository: WorkflowPublicationOutboxRepository, applier: WorkflowPublicationApplier, reporter: PublicationStatusReporter, instanceSettings: InstanceSettings);
19
+ init(): void;
19
20
  startPolling(): void;
20
21
  stopPolling(): void;
21
22
  shutdown(): void;
22
23
  private schedulePollCycle;
23
24
  private pollCycle;
24
25
  private shouldKeepPolling;
25
- private tryProcessRecord;
26
26
  processRecord(record: WorkflowPublicationOutbox): Promise<void>;
27
- private tearDownOldTriggers;
28
- private registerNewTriggers;
29
- private advancePublishedVersion;
30
- private finalizePublication;
31
27
  }
@@ -17,21 +17,26 @@ const decorators_1 = require("@n8n/decorators");
17
17
  const di_1 = require("@n8n/di");
18
18
  const n8n_core_1 = require("n8n-core");
19
19
  const n8n_workflow_1 = require("n8n-workflow");
20
- const activation_errors_service_1 = require("../activation-errors.service");
21
- const active_workflow_manager_1 = require("../active-workflow-manager");
20
+ const publication_status_reporter_1 = require("../../workflows/publication/publication-status-reporter");
21
+ const workflow_publication_applier_1 = require("../../workflows/publication/workflow-publication-applier");
22
22
  let WorkflowPublicationOutboxConsumer = class WorkflowPublicationOutboxConsumer {
23
- constructor(logger, workflowsConfig, errorReporter, outboxRepository, workflowRepository, activeWorkflowManager, activationErrorsService) {
23
+ constructor(logger, workflowsConfig, errorReporter, outboxRepository, applier, reporter, instanceSettings) {
24
24
  this.logger = logger;
25
25
  this.workflowsConfig = workflowsConfig;
26
26
  this.errorReporter = errorReporter;
27
27
  this.outboxRepository = outboxRepository;
28
- this.workflowRepository = workflowRepository;
29
- this.activeWorkflowManager = activeWorkflowManager;
30
- this.activationErrorsService = activationErrorsService;
28
+ this.applier = applier;
29
+ this.reporter = reporter;
30
+ this.instanceSettings = instanceSettings;
31
31
  this.isPolling = false;
32
32
  this.isShuttingDown = false;
33
33
  this.logger = this.logger.scoped('workflow-publication');
34
34
  }
35
+ init() {
36
+ if (this.instanceSettings.isLeader) {
37
+ this.startPolling();
38
+ }
39
+ }
35
40
  startPolling() {
36
41
  if (!this.workflowsConfig.useWorkflowPublicationService || this.isShuttingDown)
37
42
  return;
@@ -74,7 +79,7 @@ let WorkflowPublicationOutboxConsumer = class WorkflowPublicationOutboxConsumer
74
79
  const record = await this.outboxRepository.claimNextPendingRecord();
75
80
  if (!record)
76
81
  break;
77
- await this.tryProcessRecord(record);
82
+ await this.processRecord(record);
78
83
  processed++;
79
84
  }
80
85
  if (processed > 0) {
@@ -84,98 +89,25 @@ let WorkflowPublicationOutboxConsumer = class WorkflowPublicationOutboxConsumer
84
89
  shouldKeepPolling() {
85
90
  return this.isPolling && !this.isShuttingDown;
86
91
  }
87
- async tryProcessRecord(record) {
88
- try {
89
- await this.processRecord(record);
90
- }
91
- catch (error) {
92
- this.errorReporter.error(error, { shouldBeLogged: true });
93
- try {
94
- await this.outboxRepository.markFailed(record.id, `Unexpected: ${(0, n8n_workflow_1.ensureError)(error).message}`);
95
- }
96
- catch (markError) {
97
- this.errorReporter.error(markError, { shouldBeLogged: true });
98
- }
99
- }
100
- }
101
92
  async processRecord(record) {
102
- const { workflowId, publishedVersionId } = record;
103
- const workflow = await this.workflowRepository.findById(workflowId);
104
- if (!workflow) {
105
- this.logger.warn('Workflow not found, marking outbox record as completed', {
106
- workflowId,
107
- outboxId: record.id,
108
- });
109
- await this.outboxRepository.markCompleted(record.id);
110
- return;
111
- }
112
- if (!workflow.active || workflow.activeVersionId === null) {
113
- this.logger.debug('Workflow is no longer active, marking outbox record as completed', {
114
- workflowId,
115
- outboxId: record.id,
116
- });
117
- await this.outboxRepository.markCompleted(record.id);
118
- return;
119
- }
120
- if (workflow.activeVersionId === publishedVersionId) {
121
- await this.advancePublishedVersion(record);
122
- await this.finalizePublication(record);
123
- return;
124
- }
125
- try {
126
- await this.tearDownOldTriggers(record);
127
- await this.advancePublishedVersion(record);
128
- await this.registerNewTriggers(record);
129
- }
130
- catch (error) {
131
- await this.outboxRepository.markFailed(record.id, (0, n8n_workflow_1.ensureError)(error).message);
132
- return;
133
- }
134
- await this.finalizePublication(record);
135
- this.logger.debug('Successfully processed outbox record', {
136
- workflowId,
137
- publishedVersionId,
138
- outboxId: record.id,
139
- });
140
- }
141
- async tearDownOldTriggers(record) {
93
+ let result;
142
94
  try {
143
- await this.activeWorkflowManager.clearWebhooks(record.workflowId);
95
+ result = await this.applier.apply(record);
144
96
  }
145
97
  catch (error) {
146
- this.errorReporter.error(error, {
147
- shouldBeLogged: true,
148
- tags: {
149
- workflowId: record.workflowId,
150
- outboxId: record.id,
151
- },
152
- });
98
+ const cause = (0, n8n_workflow_1.ensureError)(error);
99
+ result = {
100
+ type: 'failed',
101
+ error: new n8n_workflow_1.UnexpectedError(`Unexpected: ${cause.message}`, { cause }),
102
+ };
153
103
  }
154
- await this.activeWorkflowManager.removeActivationError(record.workflowId);
155
- await this.activeWorkflowManager.removeNonWebhookTriggers(record.workflowId);
156
- }
157
- async registerNewTriggers(record) {
158
104
  try {
159
- await this.activeWorkflowManager.add(record.workflowId, 'update', undefined, {
160
- shouldPublish: false,
161
- });
105
+ await this.reporter.report(record, result);
162
106
  }
163
- catch (error) {
164
- await this.workflowRepository.update(record.workflowId, {
165
- active: false,
166
- activeVersionId: null,
167
- });
168
- await this.activationErrorsService.register(record.workflowId, (0, n8n_workflow_1.ensureError)(error).message);
169
- throw error;
107
+ catch (reportError) {
108
+ this.errorReporter.error(reportError, { shouldBeLogged: true });
170
109
  }
171
110
  }
172
- async advancePublishedVersion(record) {
173
- await this.outboxRepository.manager.upsert(db_1.WorkflowPublishedVersion, { workflowId: record.workflowId, publishedVersionId: record.publishedVersionId }, ['workflowId']);
174
- }
175
- async finalizePublication(record) {
176
- await this.outboxRepository.markCompleted(record.id);
177
- await this.activationErrorsService.deregister(record.workflowId);
178
- }
179
111
  };
180
112
  exports.WorkflowPublicationOutboxConsumer = WorkflowPublicationOutboxConsumer;
181
113
  __decorate([
@@ -202,8 +134,8 @@ exports.WorkflowPublicationOutboxConsumer = WorkflowPublicationOutboxConsumer =
202
134
  config_1.WorkflowsConfig,
203
135
  n8n_core_1.ErrorReporter,
204
136
  db_1.WorkflowPublicationOutboxRepository,
205
- db_1.WorkflowRepository,
206
- active_workflow_manager_1.ActiveWorkflowManager,
207
- activation_errors_service_1.ActivationErrorsService])
137
+ workflow_publication_applier_1.WorkflowPublicationApplier,
138
+ publication_status_reporter_1.PublicationStatusReporter,
139
+ n8n_core_1.InstanceSettings])
208
140
  ], WorkflowPublicationOutboxConsumer);
209
141
  //# sourceMappingURL=workflow-publication-outbox-consumer.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"workflow-publication-outbox-consumer.js","sourceRoot":"","sources":["../../../src/workflows/publication/workflow-publication-outbox-consumer.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,39 @@
1
+ import { Logger } from '@n8n/backend-common';
2
+ import type { WorkflowEntity } from '@n8n/db';
3
+ import { ActiveWorkflowTriggers, type IGetExecutePollFunctions, type IGetExecuteTriggerFunctions } from 'n8n-core';
4
+ import type { INode, IWorkflowBase, IWorkflowExecuteAdditionalData, Workflow, WorkflowActivateMode, WorkflowExecuteMode, WorkflowId } from 'n8n-workflow';
5
+ import type { TriggerFailureHandler } from '../../workflows/triggers/trigger-execution-context.factory';
6
+ import { TriggerExecutionContextFactory } from '../../workflows/triggers/trigger-execution-context.factory';
7
+ export interface NonWebhookTriggerRegistrationContext {
8
+ activationMode: WorkflowActivateMode;
9
+ executionMode: WorkflowExecuteMode;
10
+ additionalData: IWorkflowExecuteAdditionalData;
11
+ resolveWorkflowData: () => Promise<IWorkflowBase>;
12
+ onTriggerFailure: TriggerFailureHandler;
13
+ }
14
+ export interface PreparedNonWebhookTriggerRegistration {
15
+ dbWorkflow: WorkflowEntity;
16
+ activationMode: WorkflowActivateMode;
17
+ executionMode: WorkflowExecuteMode;
18
+ additionalData: IWorkflowExecuteAdditionalData;
19
+ getTriggerFunctions: IGetExecuteTriggerFunctions;
20
+ getPollFunctions: IGetExecutePollFunctions;
21
+ }
22
+ export declare class NonWebhookTriggerRegistrar {
23
+ private readonly logger;
24
+ private readonly activeWorkflowTriggers;
25
+ private readonly triggerExecutionContextFactory;
26
+ constructor(logger: Logger, activeWorkflowTriggers: ActiveWorkflowTriggers, triggerExecutionContextFactory: TriggerExecutionContextFactory);
27
+ getTriggerNodeIds(workflow: Workflow): string[];
28
+ getRegisteredTriggerNodeIds(workflowId: WorkflowId): Set<string>;
29
+ createRegistrationContext(dbWorkflow: WorkflowEntity, { activationMode, executionMode, additionalData, resolveWorkflowData, onTriggerFailure, }: NonWebhookTriggerRegistrationContext): {
30
+ dbWorkflow: WorkflowEntity;
31
+ activationMode: WorkflowActivateMode;
32
+ executionMode: "error" | "trigger" | "webhook" | "agent" | "retry" | "manual" | "cli" | "integrated" | "internal" | "evaluation" | "chat";
33
+ additionalData: IWorkflowExecuteAdditionalData;
34
+ getTriggerFunctions: IGetExecuteTriggerFunctions;
35
+ getPollFunctions: IGetExecutePollFunctions;
36
+ };
37
+ register(workflow: Workflow, { dbWorkflow, activationMode, executionMode, additionalData, getTriggerFunctions, getPollFunctions, }: PreparedNonWebhookTriggerRegistration, nodeId: INode['id']): Promise<void>;
38
+ deregister(workflowId: WorkflowId, nodeId: INode['id']): Promise<void>;
39
+ }
@@ -0,0 +1,58 @@
1
+ "use strict";
2
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
3
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
4
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
5
+ else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
6
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
7
+ };
8
+ var __metadata = (this && this.__metadata) || function (k, v) {
9
+ if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
10
+ };
11
+ Object.defineProperty(exports, "__esModule", { value: true });
12
+ exports.NonWebhookTriggerRegistrar = void 0;
13
+ const backend_common_1 = require("@n8n/backend-common");
14
+ const di_1 = require("@n8n/di");
15
+ const n8n_core_1 = require("n8n-core");
16
+ const trigger_execution_context_factory_1 = require("../../workflows/triggers/trigger-execution-context.factory");
17
+ const workflow_formatter_1 = require("../../workflows/workflow.formatter");
18
+ let NonWebhookTriggerRegistrar = class NonWebhookTriggerRegistrar {
19
+ constructor(logger, activeWorkflowTriggers, triggerExecutionContextFactory) {
20
+ this.logger = logger;
21
+ this.activeWorkflowTriggers = activeWorkflowTriggers;
22
+ this.triggerExecutionContextFactory = triggerExecutionContextFactory;
23
+ this.logger = this.logger.scoped(['workflow-activation']);
24
+ }
25
+ getTriggerNodeIds(workflow) {
26
+ return [...workflow.getTriggerNodes(), ...workflow.getPollNodes()].map((node) => node.id);
27
+ }
28
+ getRegisteredTriggerNodeIds(workflowId) {
29
+ return this.activeWorkflowTriggers.getRegisteredTriggerNodeIds(workflowId);
30
+ }
31
+ createRegistrationContext(dbWorkflow, { activationMode, executionMode, additionalData, resolveWorkflowData, onTriggerFailure, }) {
32
+ const getTriggerFunctions = this.triggerExecutionContextFactory.getExecuteTriggerFunctions(dbWorkflow, additionalData, executionMode, activationMode, resolveWorkflowData, onTriggerFailure);
33
+ const getPollFunctions = this.triggerExecutionContextFactory.getExecutePollFunctions(dbWorkflow, additionalData, executionMode, activationMode, resolveWorkflowData);
34
+ return {
35
+ dbWorkflow,
36
+ activationMode,
37
+ executionMode,
38
+ additionalData,
39
+ getTriggerFunctions,
40
+ getPollFunctions,
41
+ };
42
+ }
43
+ async register(workflow, { dbWorkflow, activationMode, executionMode, additionalData, getTriggerFunctions, getPollFunctions, }, nodeId) {
44
+ await this.activeWorkflowTriggers.addTriggers(workflow.id, workflow, [nodeId], additionalData, executionMode, activationMode, getTriggerFunctions, getPollFunctions);
45
+ this.logger.debug(`Added non-webhook trigger "${nodeId}" for workflow ${(0, workflow_formatter_1.formatWorkflow)(dbWorkflow)}`);
46
+ }
47
+ async deregister(workflowId, nodeId) {
48
+ await this.activeWorkflowTriggers.removeTriggers(workflowId, new Set([nodeId]));
49
+ }
50
+ };
51
+ exports.NonWebhookTriggerRegistrar = NonWebhookTriggerRegistrar;
52
+ exports.NonWebhookTriggerRegistrar = NonWebhookTriggerRegistrar = __decorate([
53
+ (0, di_1.Service)(),
54
+ __metadata("design:paramtypes", [backend_common_1.Logger,
55
+ n8n_core_1.ActiveWorkflowTriggers,
56
+ trigger_execution_context_factory_1.TriggerExecutionContextFactory])
57
+ ], NonWebhookTriggerRegistrar);
58
+ //# sourceMappingURL=non-webhook-trigger-registrar.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"non-webhook-trigger-registrar.js","sourceRoot":"","sources":["../../../src/workflows/triggers/non-webhook-trigger-registrar.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,wDAA6C;AAE7C,gCAAkC;AAClC,uCAIkB;AAYlB,8GAAwG;AACxG,uEAAgE;AAuBzD,IAAM,0BAA0B,GAAhC,MAAM,0BAA0B;IACtC,YACkB,MAAc,EACd,sBAA8C,EAC9C,8BAA8D;QAF9D,WAAM,GAAN,MAAM,CAAQ;QACd,2BAAsB,GAAtB,sBAAsB,CAAwB;QAC9C,mCAA8B,GAA9B,8BAA8B,CAAgC;QAE/E,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,qBAAqB,CAAC,CAAC,CAAC;IAC3D,CAAC;IAKD,iBAAiB,CAAC,QAAkB;QACnC,OAAO,CAAC,GAAG,QAAQ,CAAC,eAAe,EAAE,EAAE,GAAG,QAAQ,CAAC,YAAY,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;IAC3F,CAAC;IAMD,2BAA2B,CAAC,UAAsB;QACjD,OAAO,IAAI,CAAC,sBAAsB,CAAC,2BAA2B,CAAC,UAAU,CAAC,CAAC;IAC5E,CAAC;IAKD,yBAAyB,CACxB,UAA0B,EAC1B,EACC,cAAc,EACd,aAAa,EACb,cAAc,EACd,mBAAmB,EACnB,gBAAgB,GACsB;QAEvC,MAAM,mBAAmB,GAAG,IAAI,CAAC,8BAA8B,CAAC,0BAA0B,CACzF,UAAU,EACV,cAAc,EACd,aAAa,EACb,cAAc,EACd,mBAAmB,EACnB,gBAAgB,CAChB,CAAC;QAEF,MAAM,gBAAgB,GAAG,IAAI,CAAC,8BAA8B,CAAC,uBAAuB,CACnF,UAAU,EACV,cAAc,EACd,aAAa,EACb,cAAc,EACd,mBAAmB,CACnB,CAAC;QAEF,OAAO;YACN,UAAU;YACV,cAAc;YACd,aAAa;YACb,cAAc;YACd,mBAAmB;YACnB,gBAAgB;SAChB,CAAC;IACH,CAAC;IAKD,KAAK,CAAC,QAAQ,CACb,QAAkB,EAClB,EACC,UAAU,EACV,cAAc,EACd,aAAa,EACb,cAAc,EACd,mBAAmB,EACnB,gBAAgB,GACuB,EACxC,MAAmB;QAEnB,MAAM,IAAI,CAAC,sBAAsB,CAAC,WAAW,CAC5C,QAAQ,CAAC,EAAE,EACX,QAAQ,EACR,CAAC,MAAM,CAAC,EACR,cAAc,EACd,aAAa,EACb,cAAc,EACd,mBAAmB,EACnB,gBAAgB,CAChB,CAAC;QAEF,IAAI,CAAC,MAAM,CAAC,KAAK,CAChB,8BAA8B,MAAM,kBAAkB,IAAA,mCAAc,EAAC,UAAU,CAAC,EAAE,CAClF,CAAC;IACH,CAAC;IAKD,KAAK,CAAC,UAAU,CAAC,UAAsB,EAAE,MAAmB;QAC3D,MAAM,IAAI,CAAC,sBAAsB,CAAC,cAAc,CAAC,UAAU,EAAE,IAAI,GAAG,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;IACjF,CAAC;CACD,CAAA;AArGY,gEAA0B;qCAA1B,0BAA0B;IADtC,IAAA,YAAO,GAAE;qCAGiB,uBAAM;QACU,iCAAsB;QACd,kEAA8B;GAJpE,0BAA0B,CAqGtC"}
@@ -0,0 +1,5 @@
1
+ import type { IWorkflowExecuteAdditionalData } from 'n8n-workflow';
2
+ import { Workflow } from 'n8n-workflow';
3
+ export declare class TriggerCountService {
4
+ count(workflow: Workflow, additionalData: IWorkflowExecuteAdditionalData): number;
5
+ }
@@ -0,0 +1,65 @@
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
+ Object.defineProperty(exports, "__esModule", { value: true });
42
+ exports.TriggerCountService = void 0;
43
+ const constants_1 = require("../../constants");
44
+ const di_1 = require("@n8n/di");
45
+ const WebhookHelpers = __importStar(require("../../webhooks/webhook-helpers"));
46
+ let TriggerCountService = class TriggerCountService {
47
+ count(workflow, additionalData) {
48
+ const triggerFilter = (nodeType) => !!nodeType.trigger &&
49
+ !nodeType.description.name.includes('manualTrigger') &&
50
+ !constants_1.TRIGGER_COUNT_EXCLUDED_NODES.some((x) => x.endsWith(nodeType.description.name));
51
+ const workflowWebhooks = WebhookHelpers.getWorkflowWebhooks(workflow, additionalData, undefined, true);
52
+ const uniqueWebhooks = workflowWebhooks.reduce((acc, webhook) => {
53
+ acc.add(webhook.node);
54
+ return acc;
55
+ }, new Set());
56
+ return (workflow.queryNodes(triggerFilter).length +
57
+ workflow.getPollNodes().length +
58
+ uniqueWebhooks.size);
59
+ }
60
+ };
61
+ exports.TriggerCountService = TriggerCountService;
62
+ exports.TriggerCountService = TriggerCountService = __decorate([
63
+ (0, di_1.Service)()
64
+ ], TriggerCountService);
65
+ //# sourceMappingURL=trigger-count.service.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"trigger-count.service.js","sourceRoot":"","sources":["../../../src/workflows/triggers/trigger-count.service.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,2CAA2D;AAC3D,gCAAkC;AAIlC,2EAA6D;AAGtD,IAAM,mBAAmB,GAAzB,MAAM,mBAAmB;IAI/B,KAAK,CAAC,QAAkB,EAAE,cAA8C;QACvE,MAAM,aAAa,GAAG,CAAC,QAAmB,EAAE,EAAE,CAC7C,CAAC,CAAC,QAAQ,CAAC,OAAO;YAClB,CAAC,QAAQ,CAAC,WAAW,CAAC,IAAI,CAAC,QAAQ,CAAC,eAAe,CAAC;YACpD,CAAC,wCAA4B,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC,QAAQ,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC,CAAC;QAGlF,MAAM,gBAAgB,GAAG,cAAc,CAAC,mBAAmB,CAC1D,QAAQ,EACR,cAAc,EACd,SAAS,EACT,IAAI,CACJ,CAAC;QAEF,MAAM,cAAc,GAAG,gBAAgB,CAAC,MAAM,CAAc,CAAC,GAAG,EAAE,OAAO,EAAE,EAAE;YAC5E,GAAG,CAAC,GAAG,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;YACtB,OAAO,GAAG,CAAC;QACZ,CAAC,EAAE,IAAI,GAAG,EAAE,CAAC,CAAC;QAEd,OAAO,CACN,QAAQ,CAAC,UAAU,CAAC,aAAa,CAAC,CAAC,MAAM;YACzC,QAAQ,CAAC,YAAY,EAAE,CAAC,MAAM;YAC9B,cAAc,CAAC,IAAI,CACnB,CAAC;IACH,CAAC;CACD,CAAA;AA7BY,kDAAmB;8BAAnB,mBAAmB;IAD/B,IAAA,YAAO,GAAE;GACG,mBAAmB,CA6B/B"}
@@ -0,0 +1,33 @@
1
+ import { Logger } from '@n8n/backend-common';
2
+ import { ErrorReporter, StorageConfig, type IGetExecutePollFunctions, type IGetExecuteTriggerFunctions } from 'n8n-core';
3
+ import { ActiveExecutions } from '../../active-executions';
4
+ import type { ExecutionError, INode, IWorkflowBase, IWorkflowExecuteAdditionalData, WorkflowActivateMode, WorkflowExecuteMode } from 'n8n-workflow';
5
+ import { EventService } from '../../events/event.service';
6
+ import { ExecutionService } from '../../executions/execution.service';
7
+ import { WorkflowExecutionService } from '../../workflows/workflow-execution.service';
8
+ import { WorkflowPublishedDataService } from '../../workflows/workflow-published-data.service';
9
+ import { WorkflowStaticDataService } from '../../workflows/workflow-static-data.service';
10
+ import type { IWorkflowDb } from '@n8n/db';
11
+ export type TriggerFailureHandler = (opts: {
12
+ error: Error;
13
+ node: INode;
14
+ workflowData: IWorkflowDb;
15
+ mode: WorkflowExecuteMode;
16
+ activation: WorkflowActivateMode;
17
+ }) => void;
18
+ export declare class TriggerExecutionContextFactory {
19
+ private logger;
20
+ private readonly errorReporter;
21
+ private readonly activeExecutions;
22
+ private readonly eventService;
23
+ private readonly executionService;
24
+ private readonly workflowStaticDataService;
25
+ private readonly workflowExecutionService;
26
+ private readonly storageConfig;
27
+ private readonly workflowPublishedDataService;
28
+ constructor(logger: Logger, errorReporter: ErrorReporter, activeExecutions: ActiveExecutions, eventService: EventService, executionService: ExecutionService, workflowStaticDataService: WorkflowStaticDataService, workflowExecutionService: WorkflowExecutionService, storageConfig: StorageConfig, workflowPublishedDataService: WorkflowPublishedDataService);
29
+ getExecuteTriggerFunctions(workflowData: IWorkflowDb, additionalData: IWorkflowExecuteAdditionalData, mode: WorkflowExecuteMode, activation: WorkflowActivateMode, resolveWorkflowData: () => Promise<IWorkflowBase>, onTriggerFailure: TriggerFailureHandler): IGetExecuteTriggerFunctions;
30
+ getExecutePollFunctions(workflowData: IWorkflowDb, additionalData: IWorkflowExecuteAdditionalData, mode: WorkflowExecuteMode, activation: WorkflowActivateMode, resolveWorkflowData: () => Promise<IWorkflowBase>): IGetExecutePollFunctions;
31
+ executeErrorWorkflow(error: ExecutionError, workflowData: IWorkflowBase, mode: WorkflowExecuteMode): void;
32
+ loadPublishedWorkflowData(initialWorkflowData: IWorkflowDb): Promise<IWorkflowBase>;
33
+ }