1
0
Fork 0
mirror of https://we.phorge.it/source/phorge.git synced 2025-01-03 11:21:01 +01:00

Require CSRF submission to verify email addresses

Summary: If an attacker somehow intercepts a verification URL for an email address, they can hypothetically CSRF the account owner into verifying it. What you'd do before (how do you get the link?) and after (why do you care that you tricked them into verifying) performing this attack is unclear, but in theory we should require a CSRF submission here; add one.

Test Plan: {F118691}

Reviewers: btrahan

Reviewed By: btrahan

CC: aran

Differential Revision: https://secure.phabricator.com/D8351
This commit is contained in:
epriestley 2014-02-26 11:17:46 -08:00
parent 424ba2e588
commit bcf255e9c9

View file

@ -36,6 +36,8 @@ final class PhabricatorEmailVerificationController
$user->getPHID(), $user->getPHID(),
$this->code); $this->code);
$submit = null;
if (!$email) { if (!$email) {
$title = pht('Unable to Verify Email'); $title = pht('Unable to Verify Email');
$content = pht( $content = pht(
@ -49,38 +51,46 @@ final class PhabricatorEmailVerificationController
$content = pht( $content = pht(
'This email address has already been verified.'); 'This email address has already been verified.');
$continue = pht('Continue to Phabricator'); $continue = pht('Continue to Phabricator');
} else { } else if ($request->isFormPost()) {
$guard = AphrontWriteGuard::beginScopedUnguardedWrites(); $email->openTransaction();
$email->openTransaction();
$email->setIsVerified(1); $email->setIsVerified(1);
$email->save(); $email->save();
// If the user just verified their primary email address, mark their // If the user just verified their primary email address, mark their
// account as email verified. // account as email verified.
$user_primary = $user->loadPrimaryEmail(); $user_primary = $user->loadPrimaryEmail();
if ($user_primary->getID() == $email->getID()) { if ($user_primary->getID() == $email->getID()) {
$user->setIsEmailVerified(1); $user->setIsEmailVerified(1);
$user->save(); $user->save();
} }
$email->saveTransaction(); $email->saveTransaction();
unset($guard);
$title = pht('Address Verified'); $title = pht('Address Verified');
$content = pht( $content = pht(
'The email address %s is now verified.', 'The email address %s is now verified.',
phutil_tag('strong', array(), $email->getAddress())); phutil_tag('strong', array(), $email->getAddress()));
$continue = pht('Continue to Phabricator'); $continue = pht('Continue to Phabricator');
} else {
$title = pht('Verify Email Address');
$content = pht(
'Verify this email address (%s) and attach it to your account?',
phutil_tag('strong', array(), $email->getAddress()));
$continue = pht('Cancel');
$submit = pht('Verify %s', $email->getAddress());
} }
$dialog = id(new AphrontDialogView()) $dialog = id(new AphrontDialogView())
->setUser($user) ->setUser($user)
->setTitle($title) ->setTitle($title)
->setMethod('GET')
->addCancelButton('/', $continue) ->addCancelButton('/', $continue)
->appendChild($content); ->appendChild($content);
if ($submit) {
$dialog->addSubmitButton($submit);
}
$crumbs = $this->buildApplicationCrumbs(); $crumbs = $this->buildApplicationCrumbs();
$crumbs->addTextCrumb(pht('Verify Email')); $crumbs->addTextCrumb(pht('Verify Email'));