Skip to content

Commit

Permalink
fix: #8665, trim email before checking validity
Browse files Browse the repository at this point in the history
  • Loading branch information
barisusakli committed Sep 22, 2020
1 parent ccddbb1 commit ac43cd8
Show file tree
Hide file tree
Showing 2 changed files with 39 additions and 3 deletions.
21 changes: 18 additions & 3 deletions src/user/profile.js
Expand Up @@ -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;

Expand All @@ -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) {
Expand All @@ -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]]');
}
Expand Down
21 changes: 21 additions & 0 deletions test/user.js
Expand Up @@ -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%';
Expand Down

0 comments on commit ac43cd8

Please sign in to comment.