diff --git a/src/user/profile.js b/src/user/profile.js index c7c4af7bbd..d775824d06 100644 --- a/src/user/profile.js +++ b/src/user/profile.js @@ -21,7 +21,11 @@ module.exports = function (User) { } const updateUid = data.uid; - const result = await plugins.fireHook('filter:user.updateProfile', { uid: uid, data: data, fields: fields }); + const result = await plugins.fireHook('filter:user.updateProfile', { + uid: uid, + data: data, + fields: fields, + }); fields = result.fields; data = result.data; @@ -46,8 +50,18 @@ module.exports = function (User) { await User.setUserField(updateUid, field, data[field]); }); - plugins.fireHook('action:user.updateProfile', { uid: uid, data: data, fields: fields, oldData: oldData }); - return await User.getUserFields(updateUid, ['email', 'username', 'userslug', 'picture', 'icon:text', 'icon:bgColor']); + + plugins.fireHook('action:user.updateProfile', { + uid: uid, + data: data, + fields: fields, + oldData: oldData, + }); + + return await User.getUserFields(updateUid, [ + 'email', 'username', 'userslug', + 'picture', 'icon:text', 'icon:bgColor', + ]); }; async function validateData(callerUid, data) { @@ -67,6 +81,7 @@ module.exports = function (User) { return; } + data.email = data.email.trim(); if (!utils.isEmailValid(data.email)) { throw new Error('[[error:invalid-email]]'); } diff --git a/test/user.js b/test/user.js index 306244f0d5..863619ff65 100644 --- a/test/user.js +++ b/test/user.js @@ -942,6 +942,27 @@ describe('User', function () { }); }); + it('should error if email is identical', async function () { + await User.create({ + username: 'trimtest1', + email: 'trim1@trim.com', + }); + const uid2 = await User.create({ + username: 'trimtest2', + email: 'trim2@trim.com', + }); + let err; + try { + await socketUser.changeUsernameEmail({ uid: uid2 }, { + uid: uid2, + email: ' trim1@trim.com', + }); + } catch (_err) { + err = _err; + } + assert.strictEqual(err.message, '[[error:email-taken]]'); + }); + it('should update cover image', function (done) { var imageData = ''; var position = '50.0301% 19.2464%';