refactor: Improve warnings and error messages to users about sharing (#4687) (no-changelog)

* refactor: Improve warnings and error messages to users about sharing
This commit is contained in:
Omar Ajoue 2022-11-22 13:05:51 +01:00 committed by GitHub
parent 91408dccf5
commit ad6c6f60a1
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
7 changed files with 33 additions and 24 deletions

View file

@ -77,22 +77,25 @@ export function authenticationMethods(this: N8nApp): void {
} }
if (config.get('userManagement.isInstanceOwnerSetUp')) { if (config.get('userManagement.isInstanceOwnerSetUp')) {
const error = new Error('Not logged in'); throw new ResponseHelper.ResponseError('Not logged in', undefined, 401);
// @ts-ignore
error.httpStatusCode = 401;
throw error;
} }
try { try {
user = await Db.collections.User.findOneOrFail({ relations: ['globalRole'] }); user = await Db.collections.User.findOneOrFail({ relations: ['globalRole'] });
} catch (error) { } catch (error) {
throw new Error( throw new ResponseHelper.ResponseError(
'No users found in database - did you wipe the users table? Create at least one user.', 'No users found in database - did you wipe the users table? Create at least one user.',
undefined,
500,
); );
} }
if (user.email || user.password) { if (user.email || user.password) {
throw new Error('Invalid database state - user has password set.'); throw new ResponseHelper.ResponseError(
'Invalid database state - user has password set.',
undefined,
500,
);
} }
await issueCookie(res, user); await issueCookie(res, user);

View file

@ -64,7 +64,7 @@ EECredentialsController.get(
if (!credential) { if (!credential) {
throw new ResponseHelper.ResponseError( throw new ResponseHelper.ResponseError(
`Credential with ID "${credentialId}" could not be found.`, 'Could not load the credential. If you think this is an error, ask the owner to share it with you again',
undefined, undefined,
404, 404,
); );

View file

@ -160,7 +160,7 @@ credentialsController.patch(
userId: req.user.id, userId: req.user.id,
}); });
throw new ResponseHelper.ResponseError( throw new ResponseHelper.ResponseError(
`Credential with ID "${credentialId}" could not be found to be updated.`, 'Credential to be updated not found. You can only update credentials owned by you',
undefined, undefined,
404, 404,
); );
@ -218,7 +218,7 @@ credentialsController.delete(
userId: req.user.id, userId: req.user.id,
}); });
throw new ResponseHelper.ResponseError( throw new ResponseHelper.ResponseError(
`Credential with ID "${credentialId}" could not be found to be deleted.`, 'Credential to be deleted not found. You can only removed credentials owned by you',
undefined, undefined,
404, 404,
); );

View file

@ -87,7 +87,7 @@ EEWorkflowController.get(
if (!workflow) { if (!workflow) {
throw new ResponseHelper.ResponseError( throw new ResponseHelper.ResponseError(
`Workflow with ID "${workflowId}" could not be found.`, `Workflow with ID "${workflowId}" does not exist`,
undefined, undefined,
404, 404,
); );
@ -96,7 +96,11 @@ EEWorkflowController.get(
const userSharing = workflow.shared?.find((shared) => shared.user.id === req.user.id); const userSharing = workflow.shared?.find((shared) => shared.user.id === req.user.id);
if (!userSharing && req.user.globalRole.name !== 'owner') { if (!userSharing && req.user.globalRole.name !== 'owner') {
throw new ResponseHelper.ResponseError(`Forbidden.`, undefined, 403); throw new ResponseHelper.ResponseError(
'It looks like you cannot access this workflow. Ask the owner to share it with you.',
undefined,
403,
);
} }
return EEWorkflows.addCredentialsToWorkflow( return EEWorkflows.addCredentialsToWorkflow(
@ -140,7 +144,7 @@ EEWorkflowController.post(
EEWorkflows.validateCredentialPermissionsToUser(newWorkflow, allCredentials); EEWorkflows.validateCredentialPermissionsToUser(newWorkflow, allCredentials);
} catch (error) { } catch (error) {
throw new ResponseHelper.ResponseError( throw new ResponseHelper.ResponseError(
'The workflow contains credentials that you do not have access to', 'The workflow you are trying to save contains credentials that are not shared with you',
undefined, undefined,
400, 400,
); );
@ -169,7 +173,9 @@ EEWorkflowController.post(
if (!savedWorkflow) { if (!savedWorkflow) {
LoggerProxy.error('Failed to create workflow', { userId: req.user.id }); LoggerProxy.error('Failed to create workflow', { userId: req.user.id });
throw new ResponseHelper.ResponseError('Failed to save workflow'); throw new ResponseHelper.ResponseError(
'An error occurred while saving your workflow. Please try again.',
);
} }
if (tagIds && !config.getEnv('workflowTagsDisabled') && savedWorkflow.tags) { if (tagIds && !config.getEnv('workflowTagsDisabled') && savedWorkflow.tags) {

View file

@ -223,7 +223,7 @@ workflowsController.get(
userId: req.user.id, userId: req.user.id,
}); });
throw new ResponseHelper.ResponseError( throw new ResponseHelper.ResponseError(
`Workflow with ID "${workflowId}" could not be found.`, 'Could not load the workflow - you can only access workflows owned by you',
undefined, undefined,
404, 404,
); );
@ -298,7 +298,7 @@ workflowsController.delete(
userId: req.user.id, userId: req.user.id,
}); });
throw new ResponseHelper.ResponseError( throw new ResponseHelper.ResponseError(
`Workflow with ID "${workflowId}" could not be found to be deleted.`, 'Could not delete the workflow - you can only remove workflows owned by you',
undefined, undefined,
400, 400,
); );

View file

@ -197,7 +197,7 @@ export class WorkflowsService {
userId: user.id, userId: user.id,
}); });
throw new ResponseHelper.ResponseError( throw new ResponseHelper.ResponseError(
`Workflow with ID "${workflowId}" could not be found to be updated.`, 'You do not have permission to update this workflow. Ask the owner to share it with you.',
undefined, undefined,
404, 404,
); );
@ -205,7 +205,7 @@ export class WorkflowsService {
if (!forceSave && workflow.hash !== '' && workflow.hash !== shared.workflow.hash) { if (!forceSave && workflow.hash !== '' && workflow.hash !== shared.workflow.hash) {
throw new ResponseHelper.ResponseError( throw new ResponseHelper.ResponseError(
`Workflow ID ${workflowId} cannot be saved because it was changed by another user.`, 'We are sorry, but the workflow has been changed in the meantime. Please reload the workflow and try again.',
undefined, undefined,
400, 400,
); );

View file

@ -471,7 +471,7 @@ describe('POST /workflows', () => {
expect(response.statusCode).toBe(400); expect(response.statusCode).toBe(400);
expect(response.body.message).toBe( expect(response.body.message).toBe(
'The workflow contains credentials that you do not have access to', 'The workflow you are trying to save contains credentials that are not shared with you',
); );
}); });
@ -760,7 +760,7 @@ describe('PATCH /workflows/:id - validate interim updates', () => {
expect(updateAttemptResponse.status).toBe(400); expect(updateAttemptResponse.status).toBe(400);
expect(updateAttemptResponse.body.message).toContain( expect(updateAttemptResponse.body.message).toContain(
'cannot be saved because it was changed by another user', 'the workflow has been changed in the meantime',
); );
}); });
@ -802,7 +802,7 @@ describe('PATCH /workflows/:id - validate interim updates', () => {
expect(updateAttemptResponse.status).toBe(400); expect(updateAttemptResponse.status).toBe(400);
expect(updateAttemptResponse.body.message).toContain( expect(updateAttemptResponse.body.message).toContain(
'cannot be saved because it was changed by another user', 'the workflow has been changed in the meantime',
); );
}); });
@ -832,7 +832,7 @@ describe('PATCH /workflows/:id - validate interim updates', () => {
expect(activationAttemptResponse.status).toBe(400); expect(activationAttemptResponse.status).toBe(400);
expect(activationAttemptResponse.body.message).toContain( expect(activationAttemptResponse.body.message).toContain(
'cannot be saved because it was changed by another user', 'the workflow has been changed in the meantime',
); );
}); });
@ -871,7 +871,7 @@ describe('PATCH /workflows/:id - validate interim updates', () => {
expect(updateAttemptResponse.status).toBe(400); expect(updateAttemptResponse.status).toBe(400);
expect(updateAttemptResponse.body.message).toContain( expect(updateAttemptResponse.body.message).toContain(
'cannot be saved because it was changed by another user', 'the workflow has been changed in the meantime',
); );
}); });
@ -906,7 +906,7 @@ describe('PATCH /workflows/:id - validate interim updates', () => {
expect(updateAttemptResponse.status).toBe(400); expect(updateAttemptResponse.status).toBe(400);
expect(updateAttemptResponse.body.message).toContain( expect(updateAttemptResponse.body.message).toContain(
'cannot be saved because it was changed by another user', 'the workflow has been changed in the meantime',
); );
}); });
@ -941,7 +941,7 @@ describe('PATCH /workflows/:id - validate interim updates', () => {
expect(updateAttemptResponse.status).toBe(400); expect(updateAttemptResponse.status).toBe(400);
expect(updateAttemptResponse.body.message).toContain( expect(updateAttemptResponse.body.message).toContain(
'cannot be saved because it was changed by another user', 'the workflow has been changed in the meantime',
); );
}); });
}); });