Regenerate Email Verification Token on Email Request (#4439)

* regenerate email verification token & expiration in /verificationEmailRequest

* Remove password field when saving on postgres
This commit is contained in:
Benjamin Wilson Friedman
2018-02-01 15:35:08 -08:00
committed by Florent Vilmart
parent f2e21b0538
commit db8594dd33
3 changed files with 48 additions and 11 deletions

View File

@@ -487,6 +487,7 @@ describe("Email Verification Token Expiration: ", () => {
var user = new Parse.User();
var sendEmailOptions;
var sendVerificationEmailCallCount = 0;
let userBeforeRequest;
var emailAdapter = {
sendVerificationEmail: options => {
sendEmailOptions = options;
@@ -509,6 +510,15 @@ describe("Email Verification Token Expiration: ", () => {
return user.signUp();
})
.then(() => {
const config = Config.get('test');
return config.database.find('_User', {username: 'resends_verification_token'}).then((results) => {
return results[0];
});
})
.then((newUser) => {
// store this user before we make our email request
userBeforeRequest = newUser;
expect(sendVerificationEmailCallCount).toBe(1);
return requestp.post({
@@ -523,14 +533,26 @@ describe("Email Verification Token Expiration: ", () => {
json: true,
resolveWithFullResponse: true,
simple: false // this promise is only rejected if the call itself failed
});
})
.then((response) => {
expect(response.statusCode).toBe(200);
expect(sendVerificationEmailCallCount).toBe(2);
expect(sendEmailOptions).toBeDefined();
done();
// query for this user again
const config = Config.get('test');
return config.database.find('_User', {username: 'resends_verification_token'}).then((results) => {
return results[0];
});
})
.then((userAfterRequest) => {
// verify that our token & expiration has been changed for this new request
expect(typeof userAfterRequest).toBe('object');
expect(userBeforeRequest._email_verify_token).not.toEqual(userAfterRequest._email_verify_token);
expect(userBeforeRequest._email_verify_token_expires_at).not.toEqual(userAfterRequest.__email_verify_token_expires_at);
done();
})
.catch(error => {
jfail(error);
done();

View File

@@ -135,13 +135,23 @@ export class UserController extends AdaptableController {
});
}
/**
* Regenerates the given user's email verification token
*
* @param user
* @returns {*}
*/
regenerateEmailVerifyToken(user) {
this.setEmailVerifyToken(user);
return this.config.database.update('_User', { username: user.username }, user);
}
resendVerificationEmail(username) {
return this.getUserIfNeeded({username: username}).then((aUser) => {
if (!aUser || aUser.emailVerified) {
throw undefined;
}
this.setEmailVerifyToken(aUser);
return this.config.database.update('_User', {username}, aUser).then(() => {
return this.regenerateEmailVerifyToken(aUser).then(() => {
this.sendVerificationEmail(aUser);
});
});

View File

@@ -269,14 +269,19 @@ export class UsersRouter extends ClassesRouter {
}
const user = results[0];
// remove password field, messes with saving on postgres
delete user.password;
if (user.emailVerified) {
throw new Parse.Error(Parse.Error.OTHER_CAUSE, `Email ${email} is already verified.`);
}
const userController = req.config.userController;
return userController.regenerateEmailVerifyToken(user).then(() => {
userController.sendVerificationEmail(user);
return { response: {} };
});
});
}