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.
- package/dist/commands/execute.js +3 -0
- package/dist/commands/execute.js.map +1 -1
- package/dist/commands/executeBatch.d.ts +2 -0
- package/dist/commands/executeBatch.js +3 -0
- package/dist/commands/executeBatch.js.map +1 -1
- package/dist/commands/import/credentials.d.ts +10 -0
- package/dist/commands/import/credentials.js +87 -26
- package/dist/commands/import/credentials.js.map +1 -1
- package/dist/commands/import/workflow.d.ts +11 -1
- package/dist/commands/import/workflow.js +109 -48
- package/dist/commands/import/workflow.js.map +1 -1
- package/dist/commands/start.js +25 -0
- package/dist/commands/start.js.map +1 -1
- package/dist/commands/user-management/reset.d.ts +7 -0
- package/dist/commands/user-management/reset.js +66 -0
- package/dist/commands/user-management/reset.js.map +1 -0
- package/dist/commands/worker.js +4 -1
- package/dist/commands/worker.js.map +1 -1
- package/dist/config/index.d.ts +23 -0
- package/dist/config/index.js +92 -4
- package/dist/config/index.js.map +1 -1
- package/dist/src/ActiveWorkflowRunner.d.ts +2 -1
- package/dist/src/ActiveWorkflowRunner.js +44 -24
- package/dist/src/ActiveWorkflowRunner.js.map +1 -1
- package/dist/src/CredentialsHelper.d.ts +10 -2
- package/dist/src/CredentialsHelper.js +40 -11
- package/dist/src/CredentialsHelper.js.map +1 -1
- package/dist/src/Db.d.ts +4 -1
- package/dist/src/Db.js +90 -66
- package/dist/src/Db.js.map +1 -1
- package/dist/src/GenericHelpers.d.ts +6 -0
- package/dist/src/GenericHelpers.js +18 -1
- package/dist/src/GenericHelpers.js.map +1 -1
- package/dist/src/Interfaces.d.ts +74 -9
- package/dist/src/InternalHooks.d.ts +42 -6
- package/dist/src/InternalHooks.js +54 -13
- package/dist/src/InternalHooks.js.map +1 -1
- package/dist/src/ResponseHelper.js +5 -0
- package/dist/src/ResponseHelper.js.map +1 -1
- package/dist/src/Server.d.ts +2 -0
- package/dist/src/Server.js +584 -458
- package/dist/src/Server.js.map +1 -1
- package/dist/src/TagHelpers.d.ts +3 -3
- package/dist/src/TagHelpers.js +5 -24
- package/dist/src/TagHelpers.js.map +1 -1
- package/dist/src/UserManagement/Interfaces.d.ts +34 -0
- package/dist/src/UserManagement/Interfaces.js +3 -0
- package/dist/src/UserManagement/Interfaces.js.map +1 -0
- package/dist/src/UserManagement/UserManagementHelper.d.ts +17 -0
- package/dist/src/UserManagement/UserManagementHelper.js +158 -0
- package/dist/src/UserManagement/UserManagementHelper.js.map +1 -0
- package/dist/src/UserManagement/auth/jwt.d.ts +7 -0
- package/dist/src/UserManagement/auth/jwt.js +57 -0
- package/dist/src/UserManagement/auth/jwt.js.map +1 -0
- package/dist/src/UserManagement/email/Interfaces.d.ts +29 -0
- package/dist/src/UserManagement/email/Interfaces.js +3 -0
- package/dist/src/UserManagement/email/Interfaces.js.map +1 -0
- package/dist/src/UserManagement/email/NodeMailer.d.ts +7 -0
- package/dist/src/UserManagement/email/NodeMailer.js +67 -0
- package/dist/src/UserManagement/email/NodeMailer.js.map +1 -0
- package/dist/src/UserManagement/email/UserManagementMailer.d.ts +9 -0
- package/dist/src/UserManagement/email/UserManagementMailer.js +77 -0
- package/dist/src/UserManagement/email/UserManagementMailer.js.map +1 -0
- package/dist/src/UserManagement/email/index.d.ts +2 -0
- package/dist/src/UserManagement/email/index.js +7 -0
- package/dist/src/UserManagement/email/index.js.map +1 -0
- package/dist/src/UserManagement/email/templates/instanceSetup.html +5 -0
- package/dist/src/UserManagement/email/templates/invite.html +4 -0
- package/dist/src/UserManagement/email/templates/passwordReset.html +5 -0
- package/dist/src/UserManagement/index.d.ts +4 -0
- package/dist/src/UserManagement/index.js +6 -0
- package/dist/src/UserManagement/index.js.map +1 -0
- package/dist/src/UserManagement/routes/auth.d.ts +2 -0
- package/dist/src/UserManagement/routes/auth.js +74 -0
- package/dist/src/UserManagement/routes/auth.js.map +1 -0
- package/dist/src/UserManagement/routes/index.d.ts +2 -0
- package/dist/src/UserManagement/routes/index.js +100 -0
- package/dist/src/UserManagement/routes/index.js.map +1 -0
- package/dist/src/UserManagement/routes/me.d.ts +2 -0
- package/dist/src/UserManagement/routes/me.js +85 -0
- package/dist/src/UserManagement/routes/me.js.map +1 -0
- package/dist/src/UserManagement/routes/owner.d.ts +2 -0
- package/dist/src/UserManagement/routes/owner.js +68 -0
- package/dist/src/UserManagement/routes/owner.js.map +1 -0
- package/dist/src/UserManagement/routes/passwordReset.d.ts +2 -0
- package/dist/src/UserManagement/routes/passwordReset.js +129 -0
- package/dist/src/UserManagement/routes/passwordReset.js.map +1 -0
- package/dist/src/UserManagement/routes/users.d.ts +2 -0
- package/dist/src/UserManagement/routes/users.js +334 -0
- package/dist/src/UserManagement/routes/users.js.map +1 -0
- package/dist/src/WaitTracker.js +6 -0
- package/dist/src/WaitTracker.js.map +1 -1
- package/dist/src/WaitingWebhooks.js +9 -1
- package/dist/src/WaitingWebhooks.js.map +1 -1
- package/dist/src/WebhookHelpers.js +17 -1
- package/dist/src/WebhookHelpers.js.map +1 -1
- package/dist/src/WorkflowExecuteAdditionalData.d.ts +3 -3
- package/dist/src/WorkflowExecuteAdditionalData.js +41 -13
- package/dist/src/WorkflowExecuteAdditionalData.js.map +1 -1
- package/dist/src/WorkflowHelpers.d.ts +9 -10
- package/dist/src/WorkflowHelpers.js +48 -17
- package/dist/src/WorkflowHelpers.js.map +1 -1
- package/dist/src/WorkflowRunner.js +4 -2
- package/dist/src/WorkflowRunner.js.map +1 -1
- package/dist/src/WorkflowRunnerProcess.js +7 -4
- package/dist/src/WorkflowRunnerProcess.js.map +1 -1
- package/dist/src/api/credentials.api.d.ts +1 -0
- package/dist/src/api/credentials.api.js +222 -0
- package/dist/src/api/credentials.api.js.map +1 -0
- package/dist/src/constants.d.ts +5 -0
- package/dist/src/constants.js +9 -0
- package/dist/src/constants.js.map +1 -0
- package/dist/src/databases/entities/CredentialsEntity.d.ts +2 -0
- package/dist/src/databases/entities/CredentialsEntity.js +13 -2
- package/dist/src/databases/entities/CredentialsEntity.js.map +1 -1
- package/dist/src/databases/entities/Role.d.ts +16 -0
- package/dist/src/databases/entities/Role.js +87 -0
- package/dist/src/databases/entities/Role.js.map +1 -0
- package/dist/src/databases/entities/Settings.d.ts +6 -0
- package/dist/src/databases/entities/Settings.js +32 -0
- package/dist/src/databases/entities/Settings.js.map +1 -0
- package/dist/src/databases/entities/SharedCredentials.d.ts +13 -0
- package/dist/src/databases/entities/SharedCredentials.js +83 -0
- package/dist/src/databases/entities/SharedCredentials.js.map +1 -0
- package/dist/src/databases/entities/SharedWorkflow.d.ts +13 -0
- package/dist/src/databases/entities/SharedWorkflow.js +83 -0
- package/dist/src/databases/entities/SharedWorkflow.js.map +1 -0
- package/dist/src/databases/entities/TagEntity.js +6 -2
- package/dist/src/databases/entities/TagEntity.js.map +1 -1
- package/dist/src/databases/entities/User.d.ts +24 -0
- package/dist/src/databases/entities/User.js +145 -0
- package/dist/src/databases/entities/User.js.map +1 -0
- package/dist/src/databases/entities/WorkflowEntity.d.ts +2 -0
- package/dist/src/databases/entities/WorkflowEntity.js +8 -1
- package/dist/src/databases/entities/WorkflowEntity.js.map +1 -1
- package/dist/src/databases/entities/index.d.ts +10 -0
- package/dist/src/databases/entities/index.js +10 -0
- package/dist/src/databases/entities/index.js.map +1 -1
- package/dist/src/databases/mysqldb/migrations/1626183952959-AddWaitColumn.js +0 -1
- package/dist/src/databases/mysqldb/migrations/1626183952959-AddWaitColumn.js.map +1 -1
- package/dist/src/databases/mysqldb/migrations/1630451444017-UpdateWorkflowCredentials.js +0 -3
- package/dist/src/databases/mysqldb/migrations/1630451444017-UpdateWorkflowCredentials.js.map +1 -1
- package/dist/src/databases/mysqldb/migrations/1644424784709-AddExecutionEntityIndexes.js +21 -8
- package/dist/src/databases/mysqldb/migrations/1644424784709-AddExecutionEntityIndexes.js.map +1 -1
- package/dist/src/databases/mysqldb/migrations/1646992772331-CreateUserManagement.d.ts +6 -0
- package/dist/src/databases/mysqldb/migrations/1646992772331-CreateUserManagement.js +100 -0
- package/dist/src/databases/mysqldb/migrations/1646992772331-CreateUserManagement.js.map +1 -0
- package/dist/src/databases/mysqldb/migrations/index.js +2 -0
- package/dist/src/databases/mysqldb/migrations/index.js.map +1 -1
- package/dist/src/databases/postgresdb/migrations/1620824779533-UniqueWorkflowNames.d.ts +1 -1
- package/dist/src/databases/postgresdb/migrations/1620824779533-UniqueWorkflowNames.js +1 -1
- package/dist/src/databases/postgresdb/migrations/1620824779533-UniqueWorkflowNames.js.map +1 -1
- package/dist/src/databases/postgresdb/migrations/1626176912946-AddwaitTill.js +0 -1
- package/dist/src/databases/postgresdb/migrations/1626176912946-AddwaitTill.js.map +1 -1
- package/dist/src/databases/postgresdb/migrations/1630419189837-UpdateWorkflowCredentials.js +0 -3
- package/dist/src/databases/postgresdb/migrations/1630419189837-UpdateWorkflowCredentials.js.map +1 -1
- package/dist/src/databases/postgresdb/migrations/1644422880309-AddExecutionEntityIndexes.js +16 -17
- package/dist/src/databases/postgresdb/migrations/1644422880309-AddExecutionEntityIndexes.js.map +1 -1
- package/dist/src/databases/postgresdb/migrations/1646992772331-CreateUserManagement.d.ts +6 -0
- package/dist/src/databases/postgresdb/migrations/1646992772331-CreateUserManagement.js +106 -0
- package/dist/src/databases/postgresdb/migrations/1646992772331-CreateUserManagement.js.map +1 -0
- package/dist/src/databases/postgresdb/migrations/index.js +2 -0
- package/dist/src/databases/postgresdb/migrations/index.js.map +1 -1
- package/dist/src/databases/sqlite/migrations/1588102412422-InitialMigration.js +3 -0
- package/dist/src/databases/sqlite/migrations/1588102412422-InitialMigration.js.map +1 -1
- package/dist/src/databases/sqlite/migrations/1592445003908-WebhookModel.js +3 -0
- package/dist/src/databases/sqlite/migrations/1592445003908-WebhookModel.js.map +1 -1
- package/dist/src/databases/sqlite/migrations/1594825041918-CreateIndexStoppedAt.d.ts +1 -1
- package/dist/src/databases/sqlite/migrations/1594825041918-CreateIndexStoppedAt.js +3 -0
- package/dist/src/databases/sqlite/migrations/1594825041918-CreateIndexStoppedAt.js.map +1 -1
- package/dist/src/databases/sqlite/migrations/1607431743769-MakeStoppedAtNullable.d.ts +2 -1
- package/dist/src/databases/sqlite/migrations/1607431743769-MakeStoppedAtNullable.js +6 -0
- package/dist/src/databases/sqlite/migrations/1607431743769-MakeStoppedAtNullable.js.map +1 -1
- package/dist/src/databases/sqlite/migrations/1611071044839-AddWebhookId.d.ts +1 -1
- package/dist/src/databases/sqlite/migrations/1611071044839-AddWebhookId.js +3 -0
- package/dist/src/databases/sqlite/migrations/1611071044839-AddWebhookId.js.map +1 -1
- package/dist/src/databases/sqlite/migrations/1617213344594-CreateTagEntity.d.ts +1 -1
- package/dist/src/databases/sqlite/migrations/1617213344594-CreateTagEntity.js +3 -0
- package/dist/src/databases/sqlite/migrations/1617213344594-CreateTagEntity.js.map +1 -1
- package/dist/src/databases/sqlite/migrations/1620821879465-UniqueWorkflowNames.d.ts +1 -1
- package/dist/src/databases/sqlite/migrations/1620821879465-UniqueWorkflowNames.js +3 -0
- package/dist/src/databases/sqlite/migrations/1620821879465-UniqueWorkflowNames.js.map +1 -1
- package/dist/src/databases/sqlite/migrations/1621707690587-AddWaitColumn.js +3 -1
- package/dist/src/databases/sqlite/migrations/1621707690587-AddWaitColumn.js.map +1 -1
- package/dist/src/databases/sqlite/migrations/1630330987096-UpdateWorkflowCredentials.js +3 -3
- package/dist/src/databases/sqlite/migrations/1630330987096-UpdateWorkflowCredentials.js.map +1 -1
- package/dist/src/databases/sqlite/migrations/1644421939510-AddExecutionEntityIndexes.js +17 -13
- package/dist/src/databases/sqlite/migrations/1644421939510-AddExecutionEntityIndexes.js.map +1 -1
- package/dist/src/databases/sqlite/migrations/1646992772331-CreateUserManagement.d.ts +6 -0
- package/dist/src/databases/sqlite/migrations/1646992772331-CreateUserManagement.js +73 -0
- package/dist/src/databases/sqlite/migrations/1646992772331-CreateUserManagement.js.map +1 -0
- package/dist/src/databases/sqlite/migrations/index.d.ts +3 -2
- package/dist/src/databases/sqlite/migrations/index.js +4 -1
- package/dist/src/databases/sqlite/migrations/index.js.map +1 -1
- package/dist/src/databases/utils/customValidators.d.ts +1 -0
- package/dist/src/databases/utils/customValidators.js +22 -0
- package/dist/src/databases/utils/customValidators.js.map +1 -0
- package/dist/src/databases/utils/migrationHelpers.d.ts +3 -0
- package/dist/src/databases/utils/migrationHelpers.js +60 -0
- package/dist/src/databases/utils/migrationHelpers.js.map +1 -0
- package/dist/src/databases/utils/transformers.d.ts +9 -0
- package/dist/src/databases/utils/transformers.js +16 -0
- package/dist/src/databases/utils/transformers.js.map +1 -0
- package/dist/src/telemetry/index.d.ts +4 -1
- package/dist/src/telemetry/index.js +4 -2
- package/dist/src/telemetry/index.js.map +1 -1
- package/dist/test/{CredentialsHelper.test.d.ts → integration/auth.endpoints.test.d.ts} +0 -0
- package/dist/test/integration/auth.endpoints.test.js +99 -0
- package/dist/test/integration/auth.endpoints.test.js.map +1 -0
- package/dist/test/integration/auth.middleware.test.d.ts +1 -0
- package/dist/test/integration/auth.middleware.test.js +46 -0
- package/dist/test/integration/auth.middleware.test.js.map +1 -0
- package/dist/test/integration/credentials.api.test.d.ts +1 -0
- package/dist/test/integration/credentials.api.test.js +401 -0
- package/dist/test/integration/credentials.api.test.js.map +1 -0
- package/dist/test/integration/me.endpoints.test.d.ts +1 -0
- package/dist/test/integration/me.endpoints.test.js +383 -0
- package/dist/test/integration/me.endpoints.test.js.map +1 -0
- package/dist/test/integration/owner.endpoints.test.d.ts +1 -0
- package/dist/test/integration/owner.endpoints.test.js +125 -0
- package/dist/test/integration/owner.endpoints.test.js.map +1 -0
- package/dist/test/integration/passwordReset.endpoints.test.d.ts +1 -0
- package/dist/test/integration/passwordReset.endpoints.test.js +221 -0
- package/dist/test/integration/passwordReset.endpoints.test.js.map +1 -0
- package/dist/test/integration/shared/constants.d.ts +16 -0
- package/dist/test/integration/shared/constants.js +41 -0
- package/dist/test/integration/shared/constants.js.map +1 -0
- package/dist/test/integration/shared/random.d.ts +5 -0
- package/dist/test/integration/shared/random.js +34 -0
- package/dist/test/integration/shared/random.js.map +1 -0
- package/dist/test/integration/shared/testDb.d.ts +47 -0
- package/dist/test/integration/shared/testDb.js +280 -0
- package/dist/test/integration/shared/testDb.js.map +1 -0
- package/dist/test/integration/shared/utils.d.ts +20 -0
- package/dist/test/integration/shared/utils.js +132 -0
- package/dist/test/integration/shared/utils.js.map +1 -0
- package/dist/test/integration/users.endpoints.test.d.ts +1 -0
- package/dist/test/integration/users.endpoints.test.js +420 -0
- package/dist/test/integration/users.endpoints.test.js.map +1 -0
- package/dist/test/setup.d.ts +1 -0
- package/dist/test/setup.js +27 -0
- package/dist/test/setup.js.map +1 -0
- package/dist/test/teardown.d.ts +2 -0
- package/dist/test/teardown.js +33 -0
- package/dist/test/teardown.js.map +1 -0
- package/dist/test/unit/CredentialsHelper.test.d.ts +1 -0
- package/dist/test/{CredentialsHelper.test.js → unit/CredentialsHelper.test.js} +1 -1
- package/dist/test/unit/CredentialsHelper.test.js.map +1 -0
- package/dist/test/{Helpers.d.ts → unit/Helpers.d.ts} +0 -0
- package/dist/test/{Helpers.js → unit/Helpers.js} +0 -0
- package/dist/test/unit/Helpers.js.map +1 -0
- package/oclif.manifest.json +1 -1
- package/package.json +30 -29
- package/dist/src/PersonalizationSurvey.d.ts +0 -3
- package/dist/src/PersonalizationSurvey.js +0 -48
- package/dist/src/PersonalizationSurvey.js.map +0 -1
- package/dist/test/CredentialsHelper.test.js.map +0 -1
- 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,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,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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"}
|