n8n 0.167.0 → 0.168.2

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 (258) hide show
  1. package/dist/commands/execute.js +3 -0
  2. package/dist/commands/execute.js.map +1 -1
  3. package/dist/commands/executeBatch.d.ts +2 -0
  4. package/dist/commands/executeBatch.js +3 -0
  5. package/dist/commands/executeBatch.js.map +1 -1
  6. package/dist/commands/import/credentials.d.ts +10 -0
  7. package/dist/commands/import/credentials.js +87 -26
  8. package/dist/commands/import/credentials.js.map +1 -1
  9. package/dist/commands/import/workflow.d.ts +11 -1
  10. package/dist/commands/import/workflow.js +109 -48
  11. package/dist/commands/import/workflow.js.map +1 -1
  12. package/dist/commands/start.js +25 -0
  13. package/dist/commands/start.js.map +1 -1
  14. package/dist/commands/user-management/reset.d.ts +7 -0
  15. package/dist/commands/user-management/reset.js +66 -0
  16. package/dist/commands/user-management/reset.js.map +1 -0
  17. package/dist/commands/worker.js +4 -1
  18. package/dist/commands/worker.js.map +1 -1
  19. package/dist/config/index.d.ts +23 -0
  20. package/dist/config/index.js +92 -4
  21. package/dist/config/index.js.map +1 -1
  22. package/dist/src/ActiveWorkflowRunner.d.ts +2 -1
  23. package/dist/src/ActiveWorkflowRunner.js +44 -24
  24. package/dist/src/ActiveWorkflowRunner.js.map +1 -1
  25. package/dist/src/CredentialsHelper.d.ts +10 -2
  26. package/dist/src/CredentialsHelper.js +40 -11
  27. package/dist/src/CredentialsHelper.js.map +1 -1
  28. package/dist/src/Db.d.ts +4 -1
  29. package/dist/src/Db.js +90 -66
  30. package/dist/src/Db.js.map +1 -1
  31. package/dist/src/GenericHelpers.d.ts +6 -0
  32. package/dist/src/GenericHelpers.js +18 -1
  33. package/dist/src/GenericHelpers.js.map +1 -1
  34. package/dist/src/Interfaces.d.ts +74 -9
  35. package/dist/src/InternalHooks.d.ts +42 -6
  36. package/dist/src/InternalHooks.js +54 -13
  37. package/dist/src/InternalHooks.js.map +1 -1
  38. package/dist/src/ResponseHelper.js +5 -0
  39. package/dist/src/ResponseHelper.js.map +1 -1
  40. package/dist/src/Server.d.ts +2 -0
  41. package/dist/src/Server.js +584 -458
  42. package/dist/src/Server.js.map +1 -1
  43. package/dist/src/TagHelpers.d.ts +3 -3
  44. package/dist/src/TagHelpers.js +5 -24
  45. package/dist/src/TagHelpers.js.map +1 -1
  46. package/dist/src/UserManagement/Interfaces.d.ts +34 -0
  47. package/dist/src/UserManagement/Interfaces.js +3 -0
  48. package/dist/src/UserManagement/Interfaces.js.map +1 -0
  49. package/dist/src/UserManagement/UserManagementHelper.d.ts +17 -0
  50. package/dist/src/UserManagement/UserManagementHelper.js +158 -0
  51. package/dist/src/UserManagement/UserManagementHelper.js.map +1 -0
  52. package/dist/src/UserManagement/auth/jwt.d.ts +7 -0
  53. package/dist/src/UserManagement/auth/jwt.js +57 -0
  54. package/dist/src/UserManagement/auth/jwt.js.map +1 -0
  55. package/dist/src/UserManagement/email/Interfaces.d.ts +29 -0
  56. package/dist/src/UserManagement/email/Interfaces.js +3 -0
  57. package/dist/src/UserManagement/email/Interfaces.js.map +1 -0
  58. package/dist/src/UserManagement/email/NodeMailer.d.ts +7 -0
  59. package/dist/src/UserManagement/email/NodeMailer.js +67 -0
  60. package/dist/src/UserManagement/email/NodeMailer.js.map +1 -0
  61. package/dist/src/UserManagement/email/UserManagementMailer.d.ts +9 -0
  62. package/dist/src/UserManagement/email/UserManagementMailer.js +77 -0
  63. package/dist/src/UserManagement/email/UserManagementMailer.js.map +1 -0
  64. package/dist/src/UserManagement/email/index.d.ts +2 -0
  65. package/dist/src/UserManagement/email/index.js +7 -0
  66. package/dist/src/UserManagement/email/index.js.map +1 -0
  67. package/dist/src/UserManagement/email/templates/instanceSetup.html +5 -0
  68. package/dist/src/UserManagement/email/templates/invite.html +4 -0
  69. package/dist/src/UserManagement/email/templates/passwordReset.html +5 -0
  70. package/dist/src/UserManagement/index.d.ts +4 -0
  71. package/dist/src/UserManagement/index.js +6 -0
  72. package/dist/src/UserManagement/index.js.map +1 -0
  73. package/dist/src/UserManagement/routes/auth.d.ts +2 -0
  74. package/dist/src/UserManagement/routes/auth.js +74 -0
  75. package/dist/src/UserManagement/routes/auth.js.map +1 -0
  76. package/dist/src/UserManagement/routes/index.d.ts +2 -0
  77. package/dist/src/UserManagement/routes/index.js +100 -0
  78. package/dist/src/UserManagement/routes/index.js.map +1 -0
  79. package/dist/src/UserManagement/routes/me.d.ts +2 -0
  80. package/dist/src/UserManagement/routes/me.js +85 -0
  81. package/dist/src/UserManagement/routes/me.js.map +1 -0
  82. package/dist/src/UserManagement/routes/owner.d.ts +2 -0
  83. package/dist/src/UserManagement/routes/owner.js +68 -0
  84. package/dist/src/UserManagement/routes/owner.js.map +1 -0
  85. package/dist/src/UserManagement/routes/passwordReset.d.ts +2 -0
  86. package/dist/src/UserManagement/routes/passwordReset.js +129 -0
  87. package/dist/src/UserManagement/routes/passwordReset.js.map +1 -0
  88. package/dist/src/UserManagement/routes/users.d.ts +2 -0
  89. package/dist/src/UserManagement/routes/users.js +334 -0
  90. package/dist/src/UserManagement/routes/users.js.map +1 -0
  91. package/dist/src/WaitTracker.js +6 -0
  92. package/dist/src/WaitTracker.js.map +1 -1
  93. package/dist/src/WaitingWebhooks.js +9 -1
  94. package/dist/src/WaitingWebhooks.js.map +1 -1
  95. package/dist/src/WebhookHelpers.js +17 -1
  96. package/dist/src/WebhookHelpers.js.map +1 -1
  97. package/dist/src/WorkflowExecuteAdditionalData.d.ts +3 -3
  98. package/dist/src/WorkflowExecuteAdditionalData.js +41 -13
  99. package/dist/src/WorkflowExecuteAdditionalData.js.map +1 -1
  100. package/dist/src/WorkflowHelpers.d.ts +9 -10
  101. package/dist/src/WorkflowHelpers.js +48 -17
  102. package/dist/src/WorkflowHelpers.js.map +1 -1
  103. package/dist/src/WorkflowRunner.js +4 -2
  104. package/dist/src/WorkflowRunner.js.map +1 -1
  105. package/dist/src/WorkflowRunnerProcess.js +7 -4
  106. package/dist/src/WorkflowRunnerProcess.js.map +1 -1
  107. package/dist/src/api/credentials.api.d.ts +1 -0
  108. package/dist/src/api/credentials.api.js +222 -0
  109. package/dist/src/api/credentials.api.js.map +1 -0
  110. package/dist/src/constants.d.ts +5 -0
  111. package/dist/src/constants.js +9 -0
  112. package/dist/src/constants.js.map +1 -0
  113. package/dist/src/databases/entities/CredentialsEntity.d.ts +2 -0
  114. package/dist/src/databases/entities/CredentialsEntity.js +13 -2
  115. package/dist/src/databases/entities/CredentialsEntity.js.map +1 -1
  116. package/dist/src/databases/entities/Role.d.ts +16 -0
  117. package/dist/src/databases/entities/Role.js +87 -0
  118. package/dist/src/databases/entities/Role.js.map +1 -0
  119. package/dist/src/databases/entities/Settings.d.ts +6 -0
  120. package/dist/src/databases/entities/Settings.js +32 -0
  121. package/dist/src/databases/entities/Settings.js.map +1 -0
  122. package/dist/src/databases/entities/SharedCredentials.d.ts +13 -0
  123. package/dist/src/databases/entities/SharedCredentials.js +83 -0
  124. package/dist/src/databases/entities/SharedCredentials.js.map +1 -0
  125. package/dist/src/databases/entities/SharedWorkflow.d.ts +13 -0
  126. package/dist/src/databases/entities/SharedWorkflow.js +83 -0
  127. package/dist/src/databases/entities/SharedWorkflow.js.map +1 -0
  128. package/dist/src/databases/entities/TagEntity.js +6 -2
  129. package/dist/src/databases/entities/TagEntity.js.map +1 -1
  130. package/dist/src/databases/entities/User.d.ts +24 -0
  131. package/dist/src/databases/entities/User.js +145 -0
  132. package/dist/src/databases/entities/User.js.map +1 -0
  133. package/dist/src/databases/entities/WorkflowEntity.d.ts +2 -0
  134. package/dist/src/databases/entities/WorkflowEntity.js +8 -1
  135. package/dist/src/databases/entities/WorkflowEntity.js.map +1 -1
  136. package/dist/src/databases/entities/index.d.ts +10 -0
  137. package/dist/src/databases/entities/index.js +10 -0
  138. package/dist/src/databases/entities/index.js.map +1 -1
  139. package/dist/src/databases/mysqldb/migrations/1626183952959-AddWaitColumn.js +0 -1
  140. package/dist/src/databases/mysqldb/migrations/1626183952959-AddWaitColumn.js.map +1 -1
  141. package/dist/src/databases/mysqldb/migrations/1630451444017-UpdateWorkflowCredentials.js +0 -3
  142. package/dist/src/databases/mysqldb/migrations/1630451444017-UpdateWorkflowCredentials.js.map +1 -1
  143. package/dist/src/databases/mysqldb/migrations/1644424784709-AddExecutionEntityIndexes.js +21 -8
  144. package/dist/src/databases/mysqldb/migrations/1644424784709-AddExecutionEntityIndexes.js.map +1 -1
  145. package/dist/src/databases/mysqldb/migrations/1646992772331-CreateUserManagement.d.ts +6 -0
  146. package/dist/src/databases/mysqldb/migrations/1646992772331-CreateUserManagement.js +100 -0
  147. package/dist/src/databases/mysqldb/migrations/1646992772331-CreateUserManagement.js.map +1 -0
  148. package/dist/src/databases/mysqldb/migrations/index.js +2 -0
  149. package/dist/src/databases/mysqldb/migrations/index.js.map +1 -1
  150. package/dist/src/databases/postgresdb/migrations/1620824779533-UniqueWorkflowNames.d.ts +1 -1
  151. package/dist/src/databases/postgresdb/migrations/1620824779533-UniqueWorkflowNames.js +1 -1
  152. package/dist/src/databases/postgresdb/migrations/1620824779533-UniqueWorkflowNames.js.map +1 -1
  153. package/dist/src/databases/postgresdb/migrations/1626176912946-AddwaitTill.js +0 -1
  154. package/dist/src/databases/postgresdb/migrations/1626176912946-AddwaitTill.js.map +1 -1
  155. package/dist/src/databases/postgresdb/migrations/1630419189837-UpdateWorkflowCredentials.js +0 -3
  156. package/dist/src/databases/postgresdb/migrations/1630419189837-UpdateWorkflowCredentials.js.map +1 -1
  157. package/dist/src/databases/postgresdb/migrations/1644422880309-AddExecutionEntityIndexes.js +16 -17
  158. package/dist/src/databases/postgresdb/migrations/1644422880309-AddExecutionEntityIndexes.js.map +1 -1
  159. package/dist/src/databases/postgresdb/migrations/1646992772331-CreateUserManagement.d.ts +6 -0
  160. package/dist/src/databases/postgresdb/migrations/1646992772331-CreateUserManagement.js +106 -0
  161. package/dist/src/databases/postgresdb/migrations/1646992772331-CreateUserManagement.js.map +1 -0
  162. package/dist/src/databases/postgresdb/migrations/index.js +2 -0
  163. package/dist/src/databases/postgresdb/migrations/index.js.map +1 -1
  164. package/dist/src/databases/sqlite/migrations/1588102412422-InitialMigration.js +3 -0
  165. package/dist/src/databases/sqlite/migrations/1588102412422-InitialMigration.js.map +1 -1
  166. package/dist/src/databases/sqlite/migrations/1592445003908-WebhookModel.js +3 -0
  167. package/dist/src/databases/sqlite/migrations/1592445003908-WebhookModel.js.map +1 -1
  168. package/dist/src/databases/sqlite/migrations/1594825041918-CreateIndexStoppedAt.d.ts +1 -1
  169. package/dist/src/databases/sqlite/migrations/1594825041918-CreateIndexStoppedAt.js +3 -0
  170. package/dist/src/databases/sqlite/migrations/1594825041918-CreateIndexStoppedAt.js.map +1 -1
  171. package/dist/src/databases/sqlite/migrations/1607431743769-MakeStoppedAtNullable.d.ts +2 -1
  172. package/dist/src/databases/sqlite/migrations/1607431743769-MakeStoppedAtNullable.js +6 -0
  173. package/dist/src/databases/sqlite/migrations/1607431743769-MakeStoppedAtNullable.js.map +1 -1
  174. package/dist/src/databases/sqlite/migrations/1611071044839-AddWebhookId.d.ts +1 -1
  175. package/dist/src/databases/sqlite/migrations/1611071044839-AddWebhookId.js +3 -0
  176. package/dist/src/databases/sqlite/migrations/1611071044839-AddWebhookId.js.map +1 -1
  177. package/dist/src/databases/sqlite/migrations/1617213344594-CreateTagEntity.d.ts +1 -1
  178. package/dist/src/databases/sqlite/migrations/1617213344594-CreateTagEntity.js +3 -0
  179. package/dist/src/databases/sqlite/migrations/1617213344594-CreateTagEntity.js.map +1 -1
  180. package/dist/src/databases/sqlite/migrations/1620821879465-UniqueWorkflowNames.d.ts +1 -1
  181. package/dist/src/databases/sqlite/migrations/1620821879465-UniqueWorkflowNames.js +3 -0
  182. package/dist/src/databases/sqlite/migrations/1620821879465-UniqueWorkflowNames.js.map +1 -1
  183. package/dist/src/databases/sqlite/migrations/1621707690587-AddWaitColumn.js +3 -1
  184. package/dist/src/databases/sqlite/migrations/1621707690587-AddWaitColumn.js.map +1 -1
  185. package/dist/src/databases/sqlite/migrations/1630330987096-UpdateWorkflowCredentials.js +3 -3
  186. package/dist/src/databases/sqlite/migrations/1630330987096-UpdateWorkflowCredentials.js.map +1 -1
  187. package/dist/src/databases/sqlite/migrations/1644421939510-AddExecutionEntityIndexes.js +17 -13
  188. package/dist/src/databases/sqlite/migrations/1644421939510-AddExecutionEntityIndexes.js.map +1 -1
  189. package/dist/src/databases/sqlite/migrations/1646992772331-CreateUserManagement.d.ts +6 -0
  190. package/dist/src/databases/sqlite/migrations/1646992772331-CreateUserManagement.js +73 -0
  191. package/dist/src/databases/sqlite/migrations/1646992772331-CreateUserManagement.js.map +1 -0
  192. package/dist/src/databases/sqlite/migrations/index.d.ts +3 -2
  193. package/dist/src/databases/sqlite/migrations/index.js +4 -1
  194. package/dist/src/databases/sqlite/migrations/index.js.map +1 -1
  195. package/dist/src/databases/utils/customValidators.d.ts +1 -0
  196. package/dist/src/databases/utils/customValidators.js +22 -0
  197. package/dist/src/databases/utils/customValidators.js.map +1 -0
  198. package/dist/src/databases/utils/migrationHelpers.d.ts +3 -0
  199. package/dist/src/databases/utils/migrationHelpers.js +60 -0
  200. package/dist/src/databases/utils/migrationHelpers.js.map +1 -0
  201. package/dist/src/databases/utils/transformers.d.ts +9 -0
  202. package/dist/src/databases/utils/transformers.js +16 -0
  203. package/dist/src/databases/utils/transformers.js.map +1 -0
  204. package/dist/src/telemetry/index.d.ts +4 -1
  205. package/dist/src/telemetry/index.js +4 -2
  206. package/dist/src/telemetry/index.js.map +1 -1
  207. package/dist/test/{CredentialsHelper.test.d.ts → integration/auth.endpoints.test.d.ts} +0 -0
  208. package/dist/test/integration/auth.endpoints.test.js +99 -0
  209. package/dist/test/integration/auth.endpoints.test.js.map +1 -0
  210. package/dist/test/integration/auth.middleware.test.d.ts +1 -0
  211. package/dist/test/integration/auth.middleware.test.js +46 -0
  212. package/dist/test/integration/auth.middleware.test.js.map +1 -0
  213. package/dist/test/integration/credentials.api.test.d.ts +1 -0
  214. package/dist/test/integration/credentials.api.test.js +401 -0
  215. package/dist/test/integration/credentials.api.test.js.map +1 -0
  216. package/dist/test/integration/me.endpoints.test.d.ts +1 -0
  217. package/dist/test/integration/me.endpoints.test.js +383 -0
  218. package/dist/test/integration/me.endpoints.test.js.map +1 -0
  219. package/dist/test/integration/owner.endpoints.test.d.ts +1 -0
  220. package/dist/test/integration/owner.endpoints.test.js +125 -0
  221. package/dist/test/integration/owner.endpoints.test.js.map +1 -0
  222. package/dist/test/integration/passwordReset.endpoints.test.d.ts +1 -0
  223. package/dist/test/integration/passwordReset.endpoints.test.js +221 -0
  224. package/dist/test/integration/passwordReset.endpoints.test.js.map +1 -0
  225. package/dist/test/integration/shared/constants.d.ts +16 -0
  226. package/dist/test/integration/shared/constants.js +41 -0
  227. package/dist/test/integration/shared/constants.js.map +1 -0
  228. package/dist/test/integration/shared/random.d.ts +5 -0
  229. package/dist/test/integration/shared/random.js +34 -0
  230. package/dist/test/integration/shared/random.js.map +1 -0
  231. package/dist/test/integration/shared/testDb.d.ts +47 -0
  232. package/dist/test/integration/shared/testDb.js +280 -0
  233. package/dist/test/integration/shared/testDb.js.map +1 -0
  234. package/dist/test/integration/shared/utils.d.ts +20 -0
  235. package/dist/test/integration/shared/utils.js +132 -0
  236. package/dist/test/integration/shared/utils.js.map +1 -0
  237. package/dist/test/integration/users.endpoints.test.d.ts +1 -0
  238. package/dist/test/integration/users.endpoints.test.js +420 -0
  239. package/dist/test/integration/users.endpoints.test.js.map +1 -0
  240. package/dist/test/setup.d.ts +1 -0
  241. package/dist/test/setup.js +27 -0
  242. package/dist/test/setup.js.map +1 -0
  243. package/dist/test/teardown.d.ts +2 -0
  244. package/dist/test/teardown.js +33 -0
  245. package/dist/test/teardown.js.map +1 -0
  246. package/dist/test/unit/CredentialsHelper.test.d.ts +1 -0
  247. package/dist/test/{CredentialsHelper.test.js → unit/CredentialsHelper.test.js} +1 -1
  248. package/dist/test/unit/CredentialsHelper.test.js.map +1 -0
  249. package/dist/test/{Helpers.d.ts → unit/Helpers.d.ts} +0 -0
  250. package/dist/test/{Helpers.js → unit/Helpers.js} +0 -0
  251. package/dist/test/unit/Helpers.js.map +1 -0
  252. package/oclif.manifest.json +1 -1
  253. package/package.json +30 -29
  254. package/dist/src/PersonalizationSurvey.d.ts +0 -3
  255. package/dist/src/PersonalizationSurvey.js +0 -48
  256. package/dist/src/PersonalizationSurvey.js.map +0 -1
  257. package/dist/test/CredentialsHelper.test.js.map +0 -1
  258. package/dist/test/Helpers.js.map +0 -1
@@ -0,0 +1,85 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.meNamespace = void 0;
4
+ const bcryptjs_1 = require("bcryptjs");
5
+ const validator_1 = require("validator");
6
+ const n8n_workflow_1 = require("n8n-workflow");
7
+ const __1 = require("../..");
8
+ const jwt_1 = require("../auth/jwt");
9
+ const UserManagementHelper_1 = require("../UserManagementHelper");
10
+ const GenericHelpers_1 = require("../../GenericHelpers");
11
+ const User_1 = require("../../databases/entities/User");
12
+ function meNamespace() {
13
+ this.app.get(`/${this.restEndpoint}/me`, __1.ResponseHelper.send(async (req) => {
14
+ return UserManagementHelper_1.sanitizeUser(req.user);
15
+ }));
16
+ this.app.patch(`/${this.restEndpoint}/me`, __1.ResponseHelper.send(async (req, res) => {
17
+ if (!req.body.email) {
18
+ n8n_workflow_1.LoggerProxy.debug('Request to update user email failed because of missing email in payload', {
19
+ userId: req.user.id,
20
+ payload: req.body,
21
+ });
22
+ throw new __1.ResponseHelper.ResponseError('Email is mandatory', undefined, 400);
23
+ }
24
+ if (!validator_1.default.isEmail(req.body.email)) {
25
+ n8n_workflow_1.LoggerProxy.debug('Request to update user email failed because of invalid email in payload', {
26
+ userId: req.user.id,
27
+ invalidEmail: req.body.email,
28
+ });
29
+ throw new __1.ResponseHelper.ResponseError('Invalid email address', undefined, 400);
30
+ }
31
+ const newUser = new User_1.User();
32
+ Object.assign(newUser, req.user, req.body);
33
+ await GenericHelpers_1.validateEntity(newUser);
34
+ const user = await __1.Db.collections.User.save(newUser);
35
+ n8n_workflow_1.LoggerProxy.info('User updated successfully', { userId: user.id });
36
+ await jwt_1.issueCookie(res, user);
37
+ const updatedkeys = Object.keys(req.body);
38
+ void __1.InternalHooksManager.getInstance().onUserUpdate({
39
+ user_id: req.user.id,
40
+ fields_changed: updatedkeys,
41
+ });
42
+ return UserManagementHelper_1.sanitizeUser(user);
43
+ }));
44
+ this.app.patch(`/${this.restEndpoint}/me/password`, __1.ResponseHelper.send(async (req, res) => {
45
+ const { currentPassword, newPassword } = req.body;
46
+ if (typeof currentPassword !== 'string' || typeof newPassword !== 'string') {
47
+ throw new __1.ResponseHelper.ResponseError('Invalid payload.', undefined, 400);
48
+ }
49
+ if (!req.user.password) {
50
+ throw new __1.ResponseHelper.ResponseError('Requesting user not set up.');
51
+ }
52
+ const isCurrentPwCorrect = await bcryptjs_1.compare(currentPassword, req.user.password);
53
+ if (!isCurrentPwCorrect) {
54
+ throw new __1.ResponseHelper.ResponseError('Provided current password is incorrect.', undefined, 400);
55
+ }
56
+ const validPassword = UserManagementHelper_1.validatePassword(newPassword);
57
+ req.user.password = bcryptjs_1.hashSync(validPassword, bcryptjs_1.genSaltSync(10));
58
+ const user = await __1.Db.collections.User.save(req.user);
59
+ n8n_workflow_1.LoggerProxy.info('Password updated successfully', { userId: user.id });
60
+ await jwt_1.issueCookie(res, user);
61
+ void __1.InternalHooksManager.getInstance().onUserUpdate({
62
+ user_id: req.user.id,
63
+ fields_changed: ['password'],
64
+ });
65
+ return { success: true };
66
+ }));
67
+ this.app.post(`/${this.restEndpoint}/me/survey`, __1.ResponseHelper.send(async (req) => {
68
+ const { body: personalizationAnswers } = req;
69
+ if (!personalizationAnswers) {
70
+ n8n_workflow_1.LoggerProxy.debug('Request to store user personalization survey failed because of empty payload', {
71
+ userId: req.user.id,
72
+ });
73
+ throw new __1.ResponseHelper.ResponseError('Personalization answers are mandatory', undefined, 400);
74
+ }
75
+ await __1.Db.collections.User.save({
76
+ id: req.user.id,
77
+ personalizationAnswers,
78
+ });
79
+ n8n_workflow_1.LoggerProxy.info('User survey updated successfully', { userId: req.user.id });
80
+ void __1.InternalHooksManager.getInstance().onPersonalizationSurveySubmitted(req.user.id, personalizationAnswers);
81
+ return { success: true };
82
+ }));
83
+ }
84
+ exports.meNamespace = meNamespace;
85
+ //# sourceMappingURL=me.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"me.js","sourceRoot":"","sources":["../../../../src/UserManagement/routes/me.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ import { N8nApp } from '../Interfaces';
2
+ export declare function ownerNamespace(this: N8nApp): void;
@@ -0,0 +1,68 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.ownerNamespace = void 0;
4
+ const bcryptjs_1 = require("bcryptjs");
5
+ const validator_1 = require("validator");
6
+ const n8n_workflow_1 = require("n8n-workflow");
7
+ const __1 = require("../..");
8
+ const config = require("../../../config");
9
+ const GenericHelpers_1 = require("../../GenericHelpers");
10
+ const jwt_1 = require("../auth/jwt");
11
+ const UserManagementHelper_1 = require("../UserManagementHelper");
12
+ function ownerNamespace() {
13
+ this.app.post(`/${this.restEndpoint}/owner`, __1.ResponseHelper.send(async (req, res) => {
14
+ const { email, firstName, lastName, password } = req.body;
15
+ const { id: userId } = req.user;
16
+ if (config.get('userManagement.isInstanceOwnerSetUp')) {
17
+ n8n_workflow_1.LoggerProxy.debug('Request to claim instance ownership failed because instance owner already exists', {
18
+ userId,
19
+ });
20
+ throw new __1.ResponseHelper.ResponseError('Invalid request', undefined, 400);
21
+ }
22
+ if (!email || !validator_1.default.isEmail(email)) {
23
+ n8n_workflow_1.LoggerProxy.debug('Request to claim instance ownership failed because of invalid email', {
24
+ userId,
25
+ invalidEmail: email,
26
+ });
27
+ throw new __1.ResponseHelper.ResponseError('Invalid email address', undefined, 400);
28
+ }
29
+ const validPassword = UserManagementHelper_1.validatePassword(password);
30
+ if (!firstName || !lastName) {
31
+ n8n_workflow_1.LoggerProxy.debug('Request to claim instance ownership failed because of missing first name or last name in payload', { userId, payload: req.body });
32
+ throw new __1.ResponseHelper.ResponseError('First and last names are mandatory', undefined, 400);
33
+ }
34
+ let owner = await __1.Db.collections.User.findOne(userId, {
35
+ relations: ['globalRole'],
36
+ });
37
+ if (!owner || (owner.globalRole.scope === 'global' && owner.globalRole.name !== 'owner')) {
38
+ n8n_workflow_1.LoggerProxy.debug('Request to claim instance ownership failed because user shell does not exist or has wrong role!', {
39
+ userId,
40
+ });
41
+ throw new __1.ResponseHelper.ResponseError('Invalid request', undefined, 400);
42
+ }
43
+ owner = Object.assign(owner, {
44
+ email,
45
+ firstName,
46
+ lastName,
47
+ password: bcryptjs_1.hashSync(validPassword, bcryptjs_1.genSaltSync(10)),
48
+ });
49
+ await GenericHelpers_1.validateEntity(owner);
50
+ owner = await __1.Db.collections.User.save(owner);
51
+ n8n_workflow_1.LoggerProxy.info('Owner was set up successfully', { userId: req.user.id });
52
+ await __1.Db.collections.Settings.update({ key: 'userManagement.isInstanceOwnerSetUp' }, { value: JSON.stringify(true) });
53
+ config.set('userManagement.isInstanceOwnerSetUp', true);
54
+ n8n_workflow_1.LoggerProxy.debug('Setting isInstanceOwnerSetUp updated successfully', { userId: req.user.id });
55
+ await jwt_1.issueCookie(res, owner);
56
+ void __1.InternalHooksManager.getInstance().onInstanceOwnerSetup({
57
+ user_id: userId,
58
+ });
59
+ return UserManagementHelper_1.sanitizeUser(owner);
60
+ }));
61
+ this.app.post(`/${this.restEndpoint}/owner/skip-setup`, __1.ResponseHelper.send(async (_req, _res) => {
62
+ await __1.Db.collections.Settings.update({ key: 'userManagement.skipInstanceOwnerSetup' }, { value: JSON.stringify(true) });
63
+ config.set('userManagement.skipInstanceOwnerSetup', true);
64
+ return { success: true };
65
+ }));
66
+ }
67
+ exports.ownerNamespace = ownerNamespace;
68
+ //# sourceMappingURL=owner.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"owner.js","sourceRoot":"","sources":["../../../../src/UserManagement/routes/owner.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ import { N8nApp } from '../Interfaces';
2
+ export declare function passwordResetNamespace(this: N8nApp): void;
@@ -0,0 +1,129 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.passwordResetNamespace = void 0;
4
+ const uuid_1 = require("uuid");
5
+ const url_1 = require("url");
6
+ const bcryptjs_1 = require("bcryptjs");
7
+ const validator_1 = require("validator");
8
+ const typeorm_1 = require("typeorm");
9
+ const n8n_workflow_1 = require("n8n-workflow");
10
+ const __1 = require("../..");
11
+ const UserManagementHelper_1 = require("../UserManagementHelper");
12
+ const UserManagementMailer = require("../email");
13
+ const jwt_1 = require("../auth/jwt");
14
+ const config = require("../../../config");
15
+ function passwordResetNamespace() {
16
+ this.app.post(`/${this.restEndpoint}/forgot-password`, __1.ResponseHelper.send(async (req) => {
17
+ if (config.get('userManagement.emails.mode') === '') {
18
+ n8n_workflow_1.LoggerProxy.debug('Request to send password reset email failed because emailing was not set up');
19
+ throw new __1.ResponseHelper.ResponseError('Email sending must be set up in order to request a password reset email', undefined, 500);
20
+ }
21
+ const { email } = req.body;
22
+ if (!email) {
23
+ n8n_workflow_1.LoggerProxy.debug('Request to send password reset email failed because of missing email in payload', { payload: req.body });
24
+ throw new __1.ResponseHelper.ResponseError('Email is mandatory', undefined, 400);
25
+ }
26
+ if (!validator_1.default.isEmail(email)) {
27
+ n8n_workflow_1.LoggerProxy.debug('Request to send password reset email failed because of invalid email in payload', { invalidEmail: email });
28
+ throw new __1.ResponseHelper.ResponseError('Invalid email address', undefined, 400);
29
+ }
30
+ const user = await __1.Db.collections.User.findOne({ email, password: typeorm_1.Not(typeorm_1.IsNull()) });
31
+ if (!user || !user.password) {
32
+ n8n_workflow_1.LoggerProxy.debug('Request to send password reset email failed because no user was found for the provided email', { invalidEmail: email });
33
+ return;
34
+ }
35
+ user.resetPasswordToken = uuid_1.v4();
36
+ const { id, firstName, lastName, resetPasswordToken } = user;
37
+ const resetPasswordTokenExpiration = Math.floor(Date.now() / 1000) + 7200;
38
+ await __1.Db.collections.User.update(id, { resetPasswordToken, resetPasswordTokenExpiration });
39
+ const baseUrl = UserManagementHelper_1.getInstanceBaseUrl();
40
+ const url = new url_1.URL(`${baseUrl}/change-password`);
41
+ url.searchParams.append('userId', id);
42
+ url.searchParams.append('token', resetPasswordToken);
43
+ try {
44
+ const mailer = await UserManagementMailer.getInstance();
45
+ await mailer.passwordReset({
46
+ email,
47
+ firstName,
48
+ lastName,
49
+ passwordResetUrl: url.toString(),
50
+ domain: baseUrl,
51
+ });
52
+ }
53
+ catch (error) {
54
+ void __1.InternalHooksManager.getInstance().onEmailFailed({
55
+ user_id: user.id,
56
+ message_type: 'Reset password',
57
+ });
58
+ if (error instanceof Error) {
59
+ throw new __1.ResponseHelper.ResponseError(`Please contact your administrator: ${error.message}`, undefined, 500);
60
+ }
61
+ }
62
+ n8n_workflow_1.LoggerProxy.info('Sent password reset email successfully', { userId: user.id, email });
63
+ void __1.InternalHooksManager.getInstance().onUserTransactionalEmail({
64
+ user_id: id,
65
+ message_type: 'Reset password',
66
+ });
67
+ void __1.InternalHooksManager.getInstance().onUserPasswordResetRequestClick({
68
+ user_id: id,
69
+ });
70
+ }));
71
+ this.app.get(`/${this.restEndpoint}/resolve-password-token`, __1.ResponseHelper.send(async (req) => {
72
+ const { token: resetPasswordToken, userId: id } = req.query;
73
+ if (!resetPasswordToken || !id) {
74
+ n8n_workflow_1.LoggerProxy.debug('Request to resolve password token failed because of missing password reset token or user ID in query string', {
75
+ queryString: req.query,
76
+ });
77
+ throw new __1.ResponseHelper.ResponseError('', undefined, 400);
78
+ }
79
+ const currentTimestamp = Math.floor(Date.now() / 1000);
80
+ const user = await __1.Db.collections.User.findOne({
81
+ id,
82
+ resetPasswordToken,
83
+ resetPasswordTokenExpiration: typeorm_1.MoreThanOrEqual(currentTimestamp),
84
+ });
85
+ if (!user) {
86
+ n8n_workflow_1.LoggerProxy.debug('Request to resolve password token failed because no user was found for the provided user ID and reset password token', {
87
+ userId: id,
88
+ resetPasswordToken,
89
+ });
90
+ throw new __1.ResponseHelper.ResponseError('', undefined, 404);
91
+ }
92
+ n8n_workflow_1.LoggerProxy.info('Reset-password token resolved successfully', { userId: id });
93
+ void __1.InternalHooksManager.getInstance().onUserPasswordResetEmailClick({
94
+ user_id: id,
95
+ });
96
+ }));
97
+ this.app.post(`/${this.restEndpoint}/change-password`, __1.ResponseHelper.send(async (req, res) => {
98
+ const { token: resetPasswordToken, userId, password } = req.body;
99
+ if (!resetPasswordToken || !userId || !password) {
100
+ n8n_workflow_1.LoggerProxy.debug('Request to change password failed because of missing user ID or password or reset password token in payload', {
101
+ payload: req.body,
102
+ });
103
+ throw new __1.ResponseHelper.ResponseError('Missing user ID or password or reset password token', undefined, 400);
104
+ }
105
+ const validPassword = UserManagementHelper_1.validatePassword(password);
106
+ const currentTimestamp = Math.floor(Date.now() / 1000);
107
+ const user = await __1.Db.collections.User.findOne({
108
+ id: userId,
109
+ resetPasswordToken,
110
+ resetPasswordTokenExpiration: typeorm_1.MoreThanOrEqual(currentTimestamp),
111
+ });
112
+ if (!user) {
113
+ n8n_workflow_1.LoggerProxy.debug('Request to resolve password token failed because no user was found for the provided user ID and reset password token', {
114
+ userId,
115
+ resetPasswordToken,
116
+ });
117
+ throw new __1.ResponseHelper.ResponseError('', undefined, 404);
118
+ }
119
+ await __1.Db.collections.User.update(userId, {
120
+ password: bcryptjs_1.hashSync(validPassword, bcryptjs_1.genSaltSync(10)),
121
+ resetPasswordToken: null,
122
+ resetPasswordTokenExpiration: null,
123
+ });
124
+ n8n_workflow_1.LoggerProxy.info('User password updated successfully', { userId });
125
+ await jwt_1.issueCookie(res, user);
126
+ }));
127
+ }
128
+ exports.passwordResetNamespace = passwordResetNamespace;
129
+ //# sourceMappingURL=passwordReset.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"passwordReset.js","sourceRoot":"","sources":["../../../../src/UserManagement/routes/passwordReset.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ import { N8nApp } from '../Interfaces';
2
+ export declare function usersNamespace(this: N8nApp): void;