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,71 @@
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
+ var __importDefault = (this && this.__importDefault) || function (mod) {
12
+ return (mod && mod.__esModule) ? mod : { "default": mod };
13
+ };
14
+ Object.defineProperty(exports, "__esModule", { value: true });
15
+ exports.PrometheusQueueMetricsService = void 0;
16
+ const config_1 = require("@n8n/config");
17
+ const di_1 = require("@n8n/di");
18
+ const n8n_core_1 = require("n8n-core");
19
+ const prom_client_1 = __importDefault(require("prom-client"));
20
+ const event_service_1 = require("../../events/event.service");
21
+ let PrometheusQueueMetricsService = class PrometheusQueueMetricsService {
22
+ constructor(config, executionsConfig, instanceSettings, eventService) {
23
+ this.config = config;
24
+ this.executionsConfig = executionsConfig;
25
+ this.instanceSettings = instanceSettings;
26
+ this.eventService = eventService;
27
+ }
28
+ get enabled() {
29
+ return (this.config.includeQueueMetrics &&
30
+ this.executionsConfig.mode === 'queue' &&
31
+ this.instanceSettings.instanceType === 'main');
32
+ }
33
+ init() {
34
+ const prefix = this.config.prefix;
35
+ const waitingGauge = new prom_client_1.default.Gauge({
36
+ name: `${prefix}scaling_mode_queue_jobs_waiting`,
37
+ help: 'Current number of enqueued jobs waiting for pickup in scaling mode.',
38
+ });
39
+ waitingGauge.set(0);
40
+ const activeGauge = new prom_client_1.default.Gauge({
41
+ name: `${prefix}scaling_mode_queue_jobs_active`,
42
+ help: 'Current number of jobs being processed across all workers in scaling mode.',
43
+ });
44
+ activeGauge.set(0);
45
+ const completedCounter = new prom_client_1.default.Counter({
46
+ name: `${prefix}scaling_mode_queue_jobs_completed`,
47
+ help: 'Total number of jobs completed across all workers in scaling mode since instance start.',
48
+ });
49
+ completedCounter.inc(0);
50
+ const failedCounter = new prom_client_1.default.Counter({
51
+ name: `${prefix}scaling_mode_queue_jobs_failed`,
52
+ help: 'Total number of jobs failed across all workers in scaling mode since instance start.',
53
+ });
54
+ failedCounter.inc(0);
55
+ this.eventService.on('job-counts-updated', (jobCounts) => {
56
+ waitingGauge.set(jobCounts.waiting);
57
+ activeGauge.set(jobCounts.active);
58
+ completedCounter.inc(jobCounts.completed);
59
+ failedCounter.inc(jobCounts.failed);
60
+ });
61
+ }
62
+ };
63
+ exports.PrometheusQueueMetricsService = PrometheusQueueMetricsService;
64
+ exports.PrometheusQueueMetricsService = PrometheusQueueMetricsService = __decorate([
65
+ (0, di_1.Service)(),
66
+ __metadata("design:paramtypes", [config_1.PrometheusMetricsConfig,
67
+ config_1.ExecutionsConfig,
68
+ n8n_core_1.InstanceSettings,
69
+ event_service_1.EventService])
70
+ ], PrometheusQueueMetricsService);
71
+ //# sourceMappingURL=queue-metrics.service.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"queue-metrics.service.js","sourceRoot":"","sources":["../../../src/metrics/prometheus/queue-metrics.service.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AAAA,wCAAwE;AACxE,gCAAkC;AAClC,uCAA4C;AAC5C,8DAAqC;AAErC,0DAAsD;AAS/C,IAAM,6BAA6B,GAAnC,MAAM,6BAA6B;IACzC,YACkB,MAA+B,EAC/B,gBAAkC,EAClC,gBAAkC,EAClC,YAA0B;QAH1B,WAAM,GAAN,MAAM,CAAyB;QAC/B,qBAAgB,GAAhB,gBAAgB,CAAkB;QAClC,qBAAgB,GAAhB,gBAAgB,CAAkB;QAClC,iBAAY,GAAZ,YAAY,CAAc;IACzC,CAAC;IAEJ,IAAI,OAAO;QACV,OAAO,CACN,IAAI,CAAC,MAAM,CAAC,mBAAmB;YAC/B,IAAI,CAAC,gBAAgB,CAAC,IAAI,KAAK,OAAO;YACtC,IAAI,CAAC,gBAAgB,CAAC,YAAY,KAAK,MAAM,CAC7C,CAAC;IACH,CAAC;IAED,IAAI;QACH,MAAM,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC;QAClC,MAAM,YAAY,GAAG,IAAI,qBAAU,CAAC,KAAK,CAAC;YACzC,IAAI,EAAE,GAAG,MAAM,iCAAiC;YAChD,IAAI,EAAE,qEAAqE;SAC3E,CAAC,CAAC;QACH,YAAY,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;QAEpB,MAAM,WAAW,GAAG,IAAI,qBAAU,CAAC,KAAK,CAAC;YACxC,IAAI,EAAE,GAAG,MAAM,gCAAgC;YAC/C,IAAI,EAAE,4EAA4E;SAClF,CAAC,CAAC;QACH,WAAW,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;QAEnB,MAAM,gBAAgB,GAAG,IAAI,qBAAU,CAAC,OAAO,CAAC;YAC/C,IAAI,EAAE,GAAG,MAAM,mCAAmC;YAClD,IAAI,EAAE,yFAAyF;SAC/F,CAAC,CAAC;QACH,gBAAgB,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;QAExB,MAAM,aAAa,GAAG,IAAI,qBAAU,CAAC,OAAO,CAAC;YAC5C,IAAI,EAAE,GAAG,MAAM,gCAAgC;YAC/C,IAAI,EAAE,sFAAsF;SAC5F,CAAC,CAAC;QACH,aAAa,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;QAErB,IAAI,CAAC,YAAY,CAAC,EAAE,CAAC,oBAAoB,EAAE,CAAC,SAAS,EAAE,EAAE;YACxD,YAAY,CAAC,GAAG,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC;YACpC,WAAW,CAAC,GAAG,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC;YAClC,gBAAgB,CAAC,GAAG,CAAC,SAAS,CAAC,SAAS,CAAC,CAAC;YAC1C,aAAa,CAAC,GAAG,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC;QACrC,CAAC,CAAC,CAAC;IACJ,CAAC;CACD,CAAA;AAjDY,sEAA6B;wCAA7B,6BAA6B;IADzC,IAAA,YAAO,GAAE;qCAGiB,gCAAuB;QACb,yBAAgB;QAChB,2BAAgB;QACpB,4BAAY;GALhC,6BAA6B,CAiDzC"}
@@ -0,0 +1,11 @@
1
+ import { EndpointsConfig, PrometheusMetricsConfig } from '@n8n/config';
2
+ import type express from 'express';
3
+ import type { PrometheusMetricsCollector } from './base';
4
+ export declare class PrometheusRouteMetricsService implements PrometheusMetricsCollector {
5
+ private readonly config;
6
+ private readonly endpointsConfig;
7
+ constructor(config: PrometheusMetricsConfig, endpointsConfig: EndpointsConfig);
8
+ get enabled(): boolean;
9
+ init(app?: express.Application): void;
10
+ private registerMiddleware;
11
+ }
@@ -0,0 +1,69 @@
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
+ var __importDefault = (this && this.__importDefault) || function (mod) {
12
+ return (mod && mod.__esModule) ? mod : { "default": mod };
13
+ };
14
+ Object.defineProperty(exports, "__esModule", { value: true });
15
+ exports.PrometheusRouteMetricsService = void 0;
16
+ const config_1 = require("@n8n/config");
17
+ const di_1 = require("@n8n/di");
18
+ const express_prom_bundle_1 = __importDefault(require("express-prom-bundle"));
19
+ const luxon_1 = require("luxon");
20
+ const n8n_workflow_1 = require("n8n-workflow");
21
+ const prom_client_1 = __importDefault(require("prom-client"));
22
+ let PrometheusRouteMetricsService = class PrometheusRouteMetricsService {
23
+ constructor(config, endpointsConfig) {
24
+ this.config = config;
25
+ this.endpointsConfig = endpointsConfig;
26
+ }
27
+ get enabled() {
28
+ return this.config.includeApiEndpoints;
29
+ }
30
+ init(app) {
31
+ (0, n8n_workflow_1.assert)(app, "PrometheusRouteMetricsService is initialized through the app middleware. 'app' must be defined.");
32
+ const gauge = new prom_client_1.default.Gauge({
33
+ name: `${this.config.prefix}last_activity`,
34
+ help: 'last instance activity (backend request) in Unix time (seconds).',
35
+ });
36
+ gauge.set(luxon_1.DateTime.now().toUnixInteger());
37
+ this.registerMiddleware(app, gauge);
38
+ }
39
+ registerMiddleware(app, gauge) {
40
+ const metricsMiddleware = (0, express_prom_bundle_1.default)({
41
+ autoregister: false,
42
+ includeUp: false,
43
+ includePath: this.config.includeApiPathLabel,
44
+ includeMethod: this.config.includeApiMethodLabel,
45
+ includeStatusCode: this.config.includeApiStatusCodeLabel,
46
+ httpDurationMetricName: `${this.config.prefix}http_request_duration_seconds`,
47
+ });
48
+ app.use([
49
+ '/api/',
50
+ `/${this.endpointsConfig.rest}/`,
51
+ `/${this.endpointsConfig.webhook}/`,
52
+ `/${this.endpointsConfig.webhookWaiting}/`,
53
+ `/${this.endpointsConfig.webhookTest}/`,
54
+ `/${this.endpointsConfig.form}/`,
55
+ `/${this.endpointsConfig.formWaiting}/`,
56
+ `/${this.endpointsConfig.formTest}/`,
57
+ ], async (req, res, next) => {
58
+ gauge.set(luxon_1.DateTime.now().toUnixInteger());
59
+ await metricsMiddleware(req, res, next);
60
+ });
61
+ }
62
+ };
63
+ exports.PrometheusRouteMetricsService = PrometheusRouteMetricsService;
64
+ exports.PrometheusRouteMetricsService = PrometheusRouteMetricsService = __decorate([
65
+ (0, di_1.Service)(),
66
+ __metadata("design:paramtypes", [config_1.PrometheusMetricsConfig,
67
+ config_1.EndpointsConfig])
68
+ ], PrometheusRouteMetricsService);
69
+ //# sourceMappingURL=route-metrics.service.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"route-metrics.service.js","sourceRoot":"","sources":["../../../src/metrics/prometheus/route-metrics.service.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AAAA,wCAAuE;AACvE,gCAAkC;AAElC,8EAA6C;AAC7C,iCAAiC;AACjC,+CAAsC;AACtC,8DAAgD;AASzC,IAAM,6BAA6B,GAAnC,MAAM,6BAA6B;IACzC,YACkB,MAA+B,EAC/B,eAAgC;QADhC,WAAM,GAAN,MAAM,CAAyB;QAC/B,oBAAe,GAAf,eAAe,CAAiB;IAC/C,CAAC;IAEJ,IAAI,OAAO;QACV,OAAO,IAAI,CAAC,MAAM,CAAC,mBAAmB,CAAC;IACxC,CAAC;IAED,IAAI,CAAC,GAAyB;QAC7B,IAAA,qBAAM,EACL,GAAG,EACH,iGAAiG,CACjG,CAAC;QAEF,MAAM,KAAK,GAAG,IAAI,qBAAU,CAAC,KAAK,CAAC;YAClC,IAAI,EAAE,GAAG,IAAI,CAAC,MAAM,CAAC,MAAM,eAAe;YAC1C,IAAI,EAAE,kEAAkE;SACxE,CAAC,CAAC;QAEH,KAAK,CAAC,GAAG,CAAC,gBAAQ,CAAC,GAAG,EAAE,CAAC,aAAa,EAAE,CAAC,CAAC;QAC1C,IAAI,CAAC,kBAAkB,CAAC,GAAG,EAAE,KAAK,CAAC,CAAC;IACrC,CAAC;IAEO,kBAAkB,CAAC,GAAwB,EAAE,KAAY;QAChE,MAAM,iBAAiB,GAAG,IAAA,6BAAU,EAAC;YACpC,YAAY,EAAE,KAAK;YACnB,SAAS,EAAE,KAAK;YAChB,WAAW,EAAE,IAAI,CAAC,MAAM,CAAC,mBAAmB;YAC5C,aAAa,EAAE,IAAI,CAAC,MAAM,CAAC,qBAAqB;YAChD,iBAAiB,EAAE,IAAI,CAAC,MAAM,CAAC,yBAAyB;YACxD,sBAAsB,EAAE,GAAG,IAAI,CAAC,MAAM,CAAC,MAAM,+BAA+B;SAC5E,CAAC,CAAC;QAEH,GAAG,CAAC,GAAG,CACN;YACC,OAAO;YACP,IAAI,IAAI,CAAC,eAAe,CAAC,IAAI,GAAG;YAChC,IAAI,IAAI,CAAC,eAAe,CAAC,OAAO,GAAG;YACnC,IAAI,IAAI,CAAC,eAAe,CAAC,cAAc,GAAG;YAC1C,IAAI,IAAI,CAAC,eAAe,CAAC,WAAW,GAAG;YACvC,IAAI,IAAI,CAAC,eAAe,CAAC,IAAI,GAAG;YAChC,IAAI,IAAI,CAAC,eAAe,CAAC,WAAW,GAAG;YACvC,IAAI,IAAI,CAAC,eAAe,CAAC,QAAQ,GAAG;SACpC,EACD,KAAK,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,EAAE,EAAE;YACxB,KAAK,CAAC,GAAG,CAAC,gBAAQ,CAAC,GAAG,EAAE,CAAC,aAAa,EAAE,CAAC,CAAC;YAC1C,MAAM,iBAAiB,CAAC,GAAG,EAAE,GAAG,EAAE,IAAI,CAAC,CAAC;QACzC,CAAC,CACD,CAAC;IACH,CAAC;CACD,CAAA;AApDY,sEAA6B;wCAA7B,6BAA6B;IADzC,IAAA,YAAO,GAAE;qCAGiB,gCAAuB;QACd,wBAAe;GAHtC,6BAA6B,CAoDzC"}
@@ -0,0 +1,11 @@
1
+ import { PrometheusMetricsConfig, SsrfProtectionConfig } from '@n8n/config';
2
+ import type { PrometheusMetricsCollector } from './base';
3
+ import { SsrfProtectionService } from '@n8n/backend-network';
4
+ export declare class PrometheusSsrfMetricsService implements PrometheusMetricsCollector {
5
+ private readonly ssrfProtectionService;
6
+ private readonly config;
7
+ private readonly ssrfConfig;
8
+ constructor(ssrfProtectionService: SsrfProtectionService, config: PrometheusMetricsConfig, ssrfConfig: SsrfProtectionConfig);
9
+ get enabled(): boolean;
10
+ init(): void;
11
+ }
@@ -0,0 +1,65 @@
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
+ var __importDefault = (this && this.__importDefault) || function (mod) {
12
+ return (mod && mod.__esModule) ? mod : { "default": mod };
13
+ };
14
+ Object.defineProperty(exports, "__esModule", { value: true });
15
+ exports.PrometheusSsrfMetricsService = void 0;
16
+ const config_1 = require("@n8n/config");
17
+ const di_1 = require("@n8n/di");
18
+ const prom_client_1 = __importDefault(require("prom-client"));
19
+ const constant_1 = require("./constant");
20
+ const backend_network_1 = require("@n8n/backend-network");
21
+ let PrometheusSsrfMetricsService = class PrometheusSsrfMetricsService {
22
+ constructor(ssrfProtectionService, config, ssrfConfig) {
23
+ this.ssrfProtectionService = ssrfProtectionService;
24
+ this.config = config;
25
+ this.ssrfConfig = ssrfConfig;
26
+ }
27
+ get enabled() {
28
+ return this.config.includeSsrfMetrics && this.ssrfConfig.enabled;
29
+ }
30
+ init() {
31
+ const checksCounter = new prom_client_1.default.Counter({
32
+ name: `${this.config.prefix}ssrf_checks_total`,
33
+ help: 'Total number of SSRF checks by result and phase.',
34
+ labelNames: ['result', 'phase'],
35
+ });
36
+ const blockedCounter = new prom_client_1.default.Counter({
37
+ name: `${this.config.prefix}ssrf_blocked_checks_total`,
38
+ help: 'Total number of blocked SSRF checks by phase and reason.',
39
+ labelNames: ['phase', 'reason'],
40
+ });
41
+ const durationHistogram = new prom_client_1.default.Histogram({
42
+ name: `${this.config.prefix}ssrf_check_duration_seconds`,
43
+ help: 'Duration of SSRF checks in seconds.',
44
+ labelNames: ['result', 'phase'],
45
+ buckets: constant_1.DURATION_BUCKETS_SECONDS,
46
+ });
47
+ this.ssrfProtectionService.events.on('ssrf.blocked', ({ phase, reason, durationMs }) => {
48
+ checksCounter.inc({ result: 'blocked', phase });
49
+ blockedCounter.inc({ phase, reason });
50
+ durationHistogram.observe({ result: 'blocked', phase }, durationMs / 1000);
51
+ });
52
+ this.ssrfProtectionService.events.on('ssrf.allowed', ({ phase, durationMs }) => {
53
+ checksCounter.inc({ result: 'allowed', phase });
54
+ durationHistogram.observe({ result: 'allowed', phase }, durationMs / 1000);
55
+ });
56
+ }
57
+ };
58
+ exports.PrometheusSsrfMetricsService = PrometheusSsrfMetricsService;
59
+ exports.PrometheusSsrfMetricsService = PrometheusSsrfMetricsService = __decorate([
60
+ (0, di_1.Service)(),
61
+ __metadata("design:paramtypes", [backend_network_1.SsrfProtectionService,
62
+ config_1.PrometheusMetricsConfig,
63
+ config_1.SsrfProtectionConfig])
64
+ ], PrometheusSsrfMetricsService);
65
+ //# sourceMappingURL=ssrf-metrics.service.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ssrf-metrics.service.js","sourceRoot":"","sources":["../../../src/metrics/prometheus/ssrf-metrics.service.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AAAA,wCAA4E;AAC5E,gCAAkC;AAClC,8DAAqC;AAGrC,yCAAsD;AACtD,0DAA6D;AAUtD,IAAM,4BAA4B,GAAlC,MAAM,4BAA4B;IACxC,YACkB,qBAA4C,EAC5C,MAA+B,EAC/B,UAAgC;QAFhC,0BAAqB,GAArB,qBAAqB,CAAuB;QAC5C,WAAM,GAAN,MAAM,CAAyB;QAC/B,eAAU,GAAV,UAAU,CAAsB;IAC/C,CAAC;IAEJ,IAAI,OAAO;QACV,OAAO,IAAI,CAAC,MAAM,CAAC,kBAAkB,IAAI,IAAI,CAAC,UAAU,CAAC,OAAO,CAAC;IAClE,CAAC;IAED,IAAI;QACH,MAAM,aAAa,GAAG,IAAI,qBAAU,CAAC,OAAO,CAAC;YAC5C,IAAI,EAAE,GAAG,IAAI,CAAC,MAAM,CAAC,MAAM,mBAAmB;YAC9C,IAAI,EAAE,kDAAkD;YACxD,UAAU,EAAE,CAAC,QAAQ,EAAE,OAAO,CAAC;SAC/B,CAAC,CAAC;QAEH,MAAM,cAAc,GAAG,IAAI,qBAAU,CAAC,OAAO,CAAC;YAC7C,IAAI,EAAE,GAAG,IAAI,CAAC,MAAM,CAAC,MAAM,2BAA2B;YACtD,IAAI,EAAE,0DAA0D;YAChE,UAAU,EAAE,CAAC,OAAO,EAAE,QAAQ,CAAC;SAC/B,CAAC,CAAC;QAEH,MAAM,iBAAiB,GAAG,IAAI,qBAAU,CAAC,SAAS,CAAC;YAClD,IAAI,EAAE,GAAG,IAAI,CAAC,MAAM,CAAC,MAAM,6BAA6B;YACxD,IAAI,EAAE,qCAAqC;YAC3C,UAAU,EAAE,CAAC,QAAQ,EAAE,OAAO,CAAC;YAC/B,OAAO,EAAE,mCAAwB;SACjC,CAAC,CAAC;QAEH,IAAI,CAAC,qBAAqB,CAAC,MAAM,CAAC,EAAE,CAAC,cAAc,EAAE,CAAC,EAAE,KAAK,EAAE,MAAM,EAAE,UAAU,EAAE,EAAE,EAAE;YACtF,aAAa,CAAC,GAAG,CAAC,EAAE,MAAM,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC,CAAC;YAChD,cAAc,CAAC,GAAG,CAAC,EAAE,KAAK,EAAE,MAAM,EAAE,CAAC,CAAC;YACtC,iBAAiB,CAAC,OAAO,CAAC,EAAE,MAAM,EAAE,SAAS,EAAE,KAAK,EAAE,EAAE,UAAU,GAAG,IAAI,CAAC,CAAC;QAC5E,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,qBAAqB,CAAC,MAAM,CAAC,EAAE,CAAC,cAAc,EAAE,CAAC,EAAE,KAAK,EAAE,UAAU,EAAE,EAAE,EAAE;YAC9E,aAAa,CAAC,GAAG,CAAC,EAAE,MAAM,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC,CAAC;YAChD,iBAAiB,CAAC,OAAO,CAAC,EAAE,MAAM,EAAE,SAAS,EAAE,KAAK,EAAE,EAAE,UAAU,GAAG,IAAI,CAAC,CAAC;QAC5E,CAAC,CAAC,CAAC;IACJ,CAAC;CACD,CAAA;AA1CY,oEAA4B;uCAA5B,4BAA4B;IADxC,IAAA,YAAO,GAAE;qCAGgC,uCAAqB;QACpC,gCAAuB;QACnB,6BAAoB;GAJtC,4BAA4B,CA0CxC"}
@@ -0,0 +1,10 @@
1
+ import { PrometheusMetricsConfig } from '@n8n/config';
2
+ import { EventService } from '../../events/event.service';
3
+ import type { PrometheusMetricsCollector } from './base';
4
+ export declare class PrometheusTokenExchangeMetricsService implements PrometheusMetricsCollector {
5
+ private readonly config;
6
+ private readonly eventService;
7
+ constructor(config: PrometheusMetricsConfig, eventService: EventService);
8
+ get enabled(): boolean;
9
+ init(): void;
10
+ }
@@ -0,0 +1,91 @@
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
+ var __importDefault = (this && this.__importDefault) || function (mod) {
12
+ return (mod && mod.__esModule) ? mod : { "default": mod };
13
+ };
14
+ Object.defineProperty(exports, "__esModule", { value: true });
15
+ exports.PrometheusTokenExchangeMetricsService = void 0;
16
+ const config_1 = require("@n8n/config");
17
+ const di_1 = require("@n8n/di");
18
+ const prom_client_1 = __importDefault(require("prom-client"));
19
+ const event_service_1 = require("../../events/event.service");
20
+ let PrometheusTokenExchangeMetricsService = class PrometheusTokenExchangeMetricsService {
21
+ constructor(config, eventService) {
22
+ this.config = config;
23
+ this.eventService = eventService;
24
+ }
25
+ get enabled() {
26
+ return true;
27
+ }
28
+ init() {
29
+ const tokenExchangeRequestsTotal = new prom_client_1.default.Counter({
30
+ name: `${this.config.prefix}token_exchange_requests_total`,
31
+ help: 'Total number of token exchange requests.',
32
+ labelNames: ['result'],
33
+ });
34
+ tokenExchangeRequestsTotal.inc({ result: 'success' }, 0);
35
+ tokenExchangeRequestsTotal.inc({ result: 'failure' }, 0);
36
+ const tokenExchangeFailuresTotal = new prom_client_1.default.Counter({
37
+ name: `${this.config.prefix}token_exchange_failures_total`,
38
+ help: 'Total number of token exchange failures broken down by reason.',
39
+ labelNames: ['reason'],
40
+ });
41
+ const embedLoginRequestsTotal = new prom_client_1.default.Counter({
42
+ name: `${this.config.prefix}embed_login_requests_total`,
43
+ help: 'Total number of embed login requests.',
44
+ labelNames: ['result'],
45
+ });
46
+ embedLoginRequestsTotal.inc({ result: 'success' }, 0);
47
+ embedLoginRequestsTotal.inc({ result: 'failure' }, 0);
48
+ const embedLoginFailuresTotal = new prom_client_1.default.Counter({
49
+ name: `${this.config.prefix}embed_login_failures_total`,
50
+ help: 'Total number of embed login failures broken down by reason.',
51
+ labelNames: ['reason'],
52
+ });
53
+ const tokenExchangeJitProvisioningTotal = new prom_client_1.default.Counter({
54
+ name: `${this.config.prefix}token_exchange_jit_provisioning_total`,
55
+ help: 'Total number of users JIT-provisioned via token exchange.',
56
+ });
57
+ tokenExchangeJitProvisioningTotal.inc(0);
58
+ const tokenExchangeIdentityLinkedTotal = new prom_client_1.default.Counter({
59
+ name: `${this.config.prefix}token_exchange_identity_linked_total`,
60
+ help: 'Total number of external identities linked to existing users via token exchange.',
61
+ });
62
+ tokenExchangeIdentityLinkedTotal.inc(0);
63
+ this.eventService.on('token-exchange-succeeded', () => {
64
+ tokenExchangeRequestsTotal.inc({ result: 'success' }, 1);
65
+ });
66
+ this.eventService.on('token-exchange-failed', ({ failureReason }) => {
67
+ tokenExchangeRequestsTotal.inc({ result: 'failure' }, 1);
68
+ tokenExchangeFailuresTotal.inc({ reason: failureReason }, 1);
69
+ });
70
+ this.eventService.on('embed-login', () => {
71
+ embedLoginRequestsTotal.inc({ result: 'success' }, 1);
72
+ });
73
+ this.eventService.on('embed-login-failed', ({ failureReason }) => {
74
+ embedLoginRequestsTotal.inc({ result: 'failure' }, 1);
75
+ embedLoginFailuresTotal.inc({ reason: failureReason }, 1);
76
+ });
77
+ this.eventService.on('token-exchange-user-provisioned', () => {
78
+ tokenExchangeJitProvisioningTotal.inc(1);
79
+ });
80
+ this.eventService.on('token-exchange-identity-linked', () => {
81
+ tokenExchangeIdentityLinkedTotal.inc(1);
82
+ });
83
+ }
84
+ };
85
+ exports.PrometheusTokenExchangeMetricsService = PrometheusTokenExchangeMetricsService;
86
+ exports.PrometheusTokenExchangeMetricsService = PrometheusTokenExchangeMetricsService = __decorate([
87
+ (0, di_1.Service)(),
88
+ __metadata("design:paramtypes", [config_1.PrometheusMetricsConfig,
89
+ event_service_1.EventService])
90
+ ], PrometheusTokenExchangeMetricsService);
91
+ //# sourceMappingURL=token-exchange-metrics.service.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"token-exchange-metrics.service.js","sourceRoot":"","sources":["../../../src/metrics/prometheus/token-exchange-metrics.service.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AAAA,wCAAsD;AACtD,gCAAkC;AAClC,8DAAqC;AAErC,0DAAsD;AAgB/C,IAAM,qCAAqC,GAA3C,MAAM,qCAAqC;IACjD,YACkB,MAA+B,EAC/B,YAA0B;QAD1B,WAAM,GAAN,MAAM,CAAyB;QAC/B,iBAAY,GAAZ,YAAY,CAAc;IACzC,CAAC;IAEJ,IAAI,OAAO;QACV,OAAO,IAAI,CAAC;IACb,CAAC;IAED,IAAI;QACH,MAAM,0BAA0B,GAAG,IAAI,qBAAU,CAAC,OAAO,CAAC;YACzD,IAAI,EAAE,GAAG,IAAI,CAAC,MAAM,CAAC,MAAM,+BAA+B;YAC1D,IAAI,EAAE,0CAA0C;YAChD,UAAU,EAAE,CAAC,QAAQ,CAAC;SACtB,CAAC,CAAC;QACH,0BAA0B,CAAC,GAAG,CAAC,EAAE,MAAM,EAAE,SAAS,EAAE,EAAE,CAAC,CAAC,CAAC;QACzD,0BAA0B,CAAC,GAAG,CAAC,EAAE,MAAM,EAAE,SAAS,EAAE,EAAE,CAAC,CAAC,CAAC;QAEzD,MAAM,0BAA0B,GAAG,IAAI,qBAAU,CAAC,OAAO,CAAC;YACzD,IAAI,EAAE,GAAG,IAAI,CAAC,MAAM,CAAC,MAAM,+BAA+B;YAC1D,IAAI,EAAE,gEAAgE;YACtE,UAAU,EAAE,CAAC,QAAQ,CAAC;SACtB,CAAC,CAAC;QAEH,MAAM,uBAAuB,GAAG,IAAI,qBAAU,CAAC,OAAO,CAAC;YACtD,IAAI,EAAE,GAAG,IAAI,CAAC,MAAM,CAAC,MAAM,4BAA4B;YACvD,IAAI,EAAE,uCAAuC;YAC7C,UAAU,EAAE,CAAC,QAAQ,CAAC;SACtB,CAAC,CAAC;QACH,uBAAuB,CAAC,GAAG,CAAC,EAAE,MAAM,EAAE,SAAS,EAAE,EAAE,CAAC,CAAC,CAAC;QACtD,uBAAuB,CAAC,GAAG,CAAC,EAAE,MAAM,EAAE,SAAS,EAAE,EAAE,CAAC,CAAC,CAAC;QAEtD,MAAM,uBAAuB,GAAG,IAAI,qBAAU,CAAC,OAAO,CAAC;YACtD,IAAI,EAAE,GAAG,IAAI,CAAC,MAAM,CAAC,MAAM,4BAA4B;YACvD,IAAI,EAAE,6DAA6D;YACnE,UAAU,EAAE,CAAC,QAAQ,CAAC;SACtB,CAAC,CAAC;QAEH,MAAM,iCAAiC,GAAG,IAAI,qBAAU,CAAC,OAAO,CAAC;YAChE,IAAI,EAAE,GAAG,IAAI,CAAC,MAAM,CAAC,MAAM,uCAAuC;YAClE,IAAI,EAAE,2DAA2D;SACjE,CAAC,CAAC;QACH,iCAAiC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;QAEzC,MAAM,gCAAgC,GAAG,IAAI,qBAAU,CAAC,OAAO,CAAC;YAC/D,IAAI,EAAE,GAAG,IAAI,CAAC,MAAM,CAAC,MAAM,sCAAsC;YACjE,IAAI,EAAE,kFAAkF;SACxF,CAAC,CAAC;QACH,gCAAgC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;QAExC,IAAI,CAAC,YAAY,CAAC,EAAE,CAAC,0BAA0B,EAAE,GAAG,EAAE;YACrD,0BAA0B,CAAC,GAAG,CAAC,EAAE,MAAM,EAAE,SAAS,EAAE,EAAE,CAAC,CAAC,CAAC;QAC1D,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,YAAY,CAAC,EAAE,CAAC,uBAAuB,EAAE,CAAC,EAAE,aAAa,EAAE,EAAE,EAAE;YACnE,0BAA0B,CAAC,GAAG,CAAC,EAAE,MAAM,EAAE,SAAS,EAAE,EAAE,CAAC,CAAC,CAAC;YACzD,0BAA0B,CAAC,GAAG,CAAC,EAAE,MAAM,EAAE,aAAa,EAAE,EAAE,CAAC,CAAC,CAAC;QAC9D,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,YAAY,CAAC,EAAE,CAAC,aAAa,EAAE,GAAG,EAAE;YACxC,uBAAuB,CAAC,GAAG,CAAC,EAAE,MAAM,EAAE,SAAS,EAAE,EAAE,CAAC,CAAC,CAAC;QACvD,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,YAAY,CAAC,EAAE,CAAC,oBAAoB,EAAE,CAAC,EAAE,aAAa,EAAE,EAAE,EAAE;YAChE,uBAAuB,CAAC,GAAG,CAAC,EAAE,MAAM,EAAE,SAAS,EAAE,EAAE,CAAC,CAAC,CAAC;YACtD,uBAAuB,CAAC,GAAG,CAAC,EAAE,MAAM,EAAE,aAAa,EAAE,EAAE,CAAC,CAAC,CAAC;QAC3D,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,YAAY,CAAC,EAAE,CAAC,iCAAiC,EAAE,GAAG,EAAE;YAC5D,iCAAiC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;QAC1C,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,YAAY,CAAC,EAAE,CAAC,gCAAgC,EAAE,GAAG,EAAE;YAC3D,gCAAgC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;QACzC,CAAC,CAAC,CAAC;IACJ,CAAC;CACD,CAAA;AA7EY,sFAAqC;gDAArC,qCAAqC;IADjD,IAAA,YAAO,GAAE;qCAGiB,gCAAuB;QACjB,4BAAY;GAHhC,qCAAqC,CA6EjD"}
@@ -0,0 +1,8 @@
1
+ import { PrometheusMetricsConfig } from '@n8n/config';
2
+ import type { PrometheusMetricsCollector } from './base';
3
+ export declare class PrometheusVersionMetricsService implements PrometheusMetricsCollector {
4
+ private readonly config;
5
+ constructor(config: PrometheusMetricsConfig);
6
+ get enabled(): boolean;
7
+ init(): void;
8
+ }
@@ -0,0 +1,46 @@
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
+ var __importDefault = (this && this.__importDefault) || function (mod) {
12
+ return (mod && mod.__esModule) ? mod : { "default": mod };
13
+ };
14
+ Object.defineProperty(exports, "__esModule", { value: true });
15
+ exports.PrometheusVersionMetricsService = void 0;
16
+ const config_1 = require("@n8n/config");
17
+ const di_1 = require("@n8n/di");
18
+ const prom_client_1 = __importDefault(require("prom-client"));
19
+ const parse_1 = __importDefault(require("semver/functions/parse"));
20
+ const constants_1 = require("../../constants");
21
+ let PrometheusVersionMetricsService = class PrometheusVersionMetricsService {
22
+ constructor(config) {
23
+ this.config = config;
24
+ }
25
+ get enabled() {
26
+ return true;
27
+ }
28
+ init() {
29
+ const n8nVersion = (0, parse_1.default)(constants_1.N8N_VERSION ?? '0.0.0');
30
+ if (n8nVersion) {
31
+ const versionGauge = new prom_client_1.default.Gauge({
32
+ name: `${this.config.prefix}version_info`,
33
+ help: 'n8n version info.',
34
+ labelNames: ['version', 'major', 'minor', 'patch'],
35
+ });
36
+ const { version, major, minor, patch } = n8nVersion;
37
+ versionGauge.set({ version: 'v' + version, major, minor, patch }, 1);
38
+ }
39
+ }
40
+ };
41
+ exports.PrometheusVersionMetricsService = PrometheusVersionMetricsService;
42
+ exports.PrometheusVersionMetricsService = PrometheusVersionMetricsService = __decorate([
43
+ (0, di_1.Service)(),
44
+ __metadata("design:paramtypes", [config_1.PrometheusMetricsConfig])
45
+ ], PrometheusVersionMetricsService);
46
+ //# sourceMappingURL=version-metrics.service.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"version-metrics.service.js","sourceRoot":"","sources":["../../../src/metrics/prometheus/version-metrics.service.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AAAA,wCAAsD;AACtD,gCAAkC;AAClC,8DAAqC;AACrC,mEAAiD;AAEjD,2CAA0C;AAMnC,IAAM,+BAA+B,GAArC,MAAM,+BAA+B;IAC3C,YAA6B,MAA+B;QAA/B,WAAM,GAAN,MAAM,CAAyB;IAAG,CAAC;IAEhE,IAAI,OAAO;QACV,OAAO,IAAI,CAAC;IACb,CAAC;IAED,IAAI;QACH,MAAM,UAAU,GAAG,IAAA,eAAW,EAAC,uBAAW,IAAI,OAAO,CAAC,CAAC;QAEvD,IAAI,UAAU,EAAE,CAAC;YAChB,MAAM,YAAY,GAAG,IAAI,qBAAU,CAAC,KAAK,CAAC;gBACzC,IAAI,EAAE,GAAG,IAAI,CAAC,MAAM,CAAC,MAAM,cAAc;gBACzC,IAAI,EAAE,mBAAmB;gBACzB,UAAU,EAAE,CAAC,SAAS,EAAE,OAAO,EAAE,OAAO,EAAE,OAAO,CAAC;aAClD,CAAC,CAAC;YAEH,MAAM,EAAE,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,GAAG,UAAU,CAAC;YACpD,YAAY,CAAC,GAAG,CAAC,EAAE,OAAO,EAAE,GAAG,GAAG,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,EAAE,CAAC,CAAC,CAAC;QACtE,CAAC;IACF,CAAC;CACD,CAAA;AArBY,0EAA+B;0CAA/B,+BAA+B;IAD3C,IAAA,YAAO,GAAE;qCAE4B,gCAAuB;GADhD,+BAA+B,CAqB3C"}
@@ -0,0 +1,10 @@
1
+ import { PrometheusMetricsConfig } from '@n8n/config';
2
+ import { EventService } from '../../events/event.service';
3
+ import type { PrometheusMetricsCollector } from './base';
4
+ export declare class PrometheusWorkflowExecutionDurationMetricsService implements PrometheusMetricsCollector {
5
+ private readonly config;
6
+ private readonly eventService;
7
+ constructor(config: PrometheusMetricsConfig, eventService: EventService);
8
+ get enabled(): boolean;
9
+ init(): void;
10
+ }
@@ -0,0 +1,61 @@
1
+ "use strict";
2
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
3
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
4
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
5
+ else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
6
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
7
+ };
8
+ var __metadata = (this && this.__metadata) || function (k, v) {
9
+ if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
10
+ };
11
+ var __importDefault = (this && this.__importDefault) || function (mod) {
12
+ return (mod && mod.__esModule) ? mod : { "default": mod };
13
+ };
14
+ Object.defineProperty(exports, "__esModule", { value: true });
15
+ exports.PrometheusWorkflowExecutionDurationMetricsService = void 0;
16
+ const config_1 = require("@n8n/config");
17
+ const di_1 = require("@n8n/di");
18
+ const prom_client_1 = __importDefault(require("prom-client"));
19
+ const event_service_1 = require("../../events/event.service");
20
+ const constant_1 = require("./constant");
21
+ let PrometheusWorkflowExecutionDurationMetricsService = class PrometheusWorkflowExecutionDurationMetricsService {
22
+ constructor(config, eventService) {
23
+ this.config = config;
24
+ this.eventService = eventService;
25
+ }
26
+ get enabled() {
27
+ return this.config.includeWorkflowExecutionDuration;
28
+ }
29
+ init() {
30
+ const labelNames = ['status', 'mode'];
31
+ if (this.config.includeWorkflowIdLabel) {
32
+ labelNames.push('workflow_id');
33
+ }
34
+ const durationHistogram = new prom_client_1.default.Histogram({
35
+ name: `${this.config.prefix}workflow_execution_duration_seconds`,
36
+ help: 'Workflow execution duration in seconds.',
37
+ labelNames,
38
+ buckets: constant_1.DURATION_BUCKETS_SECONDS,
39
+ });
40
+ this.eventService.on('workflow-post-execute', ({ runData, workflow }) => {
41
+ if (runData?.stoppedAt) {
42
+ const durationSeconds = (runData.stoppedAt.getTime() - runData.startedAt.getTime()) / 1000;
43
+ const labels = {
44
+ status: runData.status === 'success' ? 'success' : 'failed',
45
+ mode: runData.mode,
46
+ };
47
+ if (this.config.includeWorkflowIdLabel) {
48
+ labels.workflow_id = String(workflow.id ?? 'unknown');
49
+ }
50
+ durationHistogram.observe(labels, durationSeconds);
51
+ }
52
+ });
53
+ }
54
+ };
55
+ exports.PrometheusWorkflowExecutionDurationMetricsService = PrometheusWorkflowExecutionDurationMetricsService;
56
+ exports.PrometheusWorkflowExecutionDurationMetricsService = PrometheusWorkflowExecutionDurationMetricsService = __decorate([
57
+ (0, di_1.Service)(),
58
+ __metadata("design:paramtypes", [config_1.PrometheusMetricsConfig,
59
+ event_service_1.EventService])
60
+ ], PrometheusWorkflowExecutionDurationMetricsService);
61
+ //# sourceMappingURL=workflow-execution-duration-metrics.service.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"workflow-execution-duration-metrics.service.js","sourceRoot":"","sources":["../../../src/metrics/prometheus/workflow-execution-duration-metrics.service.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AAAA,wCAAsD;AACtD,gCAAkC;AAClC,8DAAqC;AAErC,0DAAsD;AAGtD,yCAAsD;AAQ/C,IAAM,iDAAiD,GAAvD,MAAM,iDAAiD;IAG7D,YACkB,MAA+B,EAC/B,YAA0B;QAD1B,WAAM,GAAN,MAAM,CAAyB;QAC/B,iBAAY,GAAZ,YAAY,CAAc;IACzC,CAAC;IAEJ,IAAI,OAAO;QACV,OAAO,IAAI,CAAC,MAAM,CAAC,gCAAgC,CAAC;IACrD,CAAC;IAED,IAAI;QACH,MAAM,UAAU,GAAG,CAAC,QAAQ,EAAE,MAAM,CAAC,CAAC;QACtC,IAAI,IAAI,CAAC,MAAM,CAAC,sBAAsB,EAAE,CAAC;YACxC,UAAU,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;QAChC,CAAC;QAED,MAAM,iBAAiB,GAAG,IAAI,qBAAU,CAAC,SAAS,CAAC;YAClD,IAAI,EAAE,GAAG,IAAI,CAAC,MAAM,CAAC,MAAM,qCAAqC;YAChE,IAAI,EAAE,yCAAyC;YAC/C,UAAU;YACV,OAAO,EAAE,mCAAwB;SACjC,CAAC,CAAC;QAEH,IAAI,CAAC,YAAY,CAAC,EAAE,CAAC,uBAAuB,EAAE,CAAC,EAAE,OAAO,EAAE,QAAQ,EAAE,EAAE,EAAE;YACvE,IAAI,OAAO,EAAE,SAAS,EAAE,CAAC;gBACxB,MAAM,eAAe,GAAG,CAAC,OAAO,CAAC,SAAS,CAAC,OAAO,EAAE,GAAG,OAAO,CAAC,SAAS,CAAC,OAAO,EAAE,CAAC,GAAG,IAAI,CAAC;gBAC3F,MAAM,MAAM,GAA2B;oBACtC,MAAM,EAAE,OAAO,CAAC,MAAM,KAAK,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,QAAQ;oBAC3D,IAAI,EAAE,OAAO,CAAC,IAAI;iBAClB,CAAC;gBAEF,IAAI,IAAI,CAAC,MAAM,CAAC,sBAAsB,EAAE,CAAC;oBACxC,MAAM,CAAC,WAAW,GAAG,MAAM,CAAC,QAAQ,CAAC,EAAE,IAAI,SAAS,CAAC,CAAC;gBACvD,CAAC;gBAED,iBAAiB,CAAC,OAAO,CAAC,MAAM,EAAE,eAAe,CAAC,CAAC;YACpD,CAAC;QACF,CAAC,CAAC,CAAC;IACJ,CAAC;CACD,CAAA;AAzCY,8GAAiD;4DAAjD,iDAAiD;IAD7D,IAAA,YAAO,GAAE;qCAKiB,gCAAuB;QACjB,4BAAY;GALhC,iDAAiD,CAyC7D"}
@@ -0,0 +1,17 @@
1
+ import { PrometheusMetricsConfig } from '@n8n/config';
2
+ import { LicenseMetricsRepository } from '@n8n/db';
3
+ import { CacheService } from '../../services/cache/cache.service';
4
+ import type { PrometheusMetricsCollector } from './base';
5
+ export declare class PrometheusWorkflowStatisticsMetricsService implements PrometheusMetricsCollector {
6
+ private readonly config;
7
+ private readonly cacheService;
8
+ private readonly licenseMetricsRepository;
9
+ private workflowStatisticsCache;
10
+ private inFlightRequest;
11
+ constructor(config: PrometheusMetricsConfig, cacheService: CacheService, licenseMetricsRepository: LicenseMetricsRepository);
12
+ get enabled(): boolean;
13
+ init(): void;
14
+ private createWorkflowStatisticsGauge;
15
+ private getWorkflowStatistics;
16
+ private fetchAndCacheMetrics;
17
+ }