3 * Implements Special:Confirmemail
5 * This program is free software; you can redistribute it and/or modify
6 * it under the terms of the GNU General Public License as published by
7 * the Free Software Foundation; either version 2 of the License, or
8 * (at your option) any later version.
10 * This program is distributed in the hope that it will be useful,
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 * GNU General Public License for more details.
15 * You should have received a copy of the GNU General Public License along
16 * with this program; if not, write to the Free Software Foundation, Inc.,
17 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
18 * http://www.gnu.org/copyleft/gpl.html
21 * @ingroup SpecialPage
25 * Special page allows users to request email confirmation message, and handles
26 * processing of the confirmation code when the link in the email is followed
28 * @ingroup SpecialPage
29 * @author Brion Vibber
30 * @author Rob Church <robchur@gmail.com>
32 class EmailConfirmation
extends UnlistedSpecialPage
{
33 public function __construct() {
34 parent
::__construct( 'Confirmemail', 'editmyprivateinfo' );
37 public function doesWrites() {
42 * Main execution point
44 * @param null|string $code Confirmation code passed to the page
45 * @throws PermissionsError
46 * @throws ReadOnlyError
47 * @throws UserNotLoggedIn
49 function execute( $code ) {
50 // Ignore things like master queries/connections on GET requests.
51 // It's very convenient to just allow formless link usage.
52 Profiler
::instance()->getTransactionProfiler()->resetExpectations();
56 $this->checkReadOnly();
57 $this->checkPermissions();
59 // This could also let someone check the current email address, so
60 // require both permissions.
61 if ( !$this->getUser()->isAllowed( 'viewmyprivateinfo' ) ) {
62 throw new PermissionsError( 'viewmyprivateinfo' );
65 if ( $code === null ||
$code === '' ) {
66 $this->requireLogin( 'confirmemail_needlogin' );
67 if ( Sanitizer
::validateEmail( $this->getUser()->getEmail() ) ) {
68 $this->showRequestForm();
70 $this->getOutput()->addWikiMsg( 'confirmemail_noemail' );
73 $this->attemptConfirm( $code );
78 * Show a nice form for the user to request a confirmation mail
80 function showRequestForm() {
81 $user = $this->getUser();
82 $out = $this->getOutput();
84 if ( !$user->isEmailConfirmed() ) {
86 if ( $user->isEmailConfirmationPending() ) {
91 'default' => "<div class=\"error mw-confirmemail-pending\">\n" .
92 $this->msg( 'confirmemail_pending' )->escaped() .
98 $out->addWikiMsg( 'confirmemail_text' );
99 $form = HTMLForm
::factory( 'ooui', $descriptor, $this->getContext() );
101 ->setMethod( 'post' )
102 ->setAction( $this->getPageTitle()->getLocalURL() )
103 ->setSubmitTextMsg( 'confirmemail_send' )
104 ->setSubmitCallback( [ $this, 'submitSend' ] );
106 $retval = $form->show();
108 if ( $retval === true ) {
109 // should never happen, but if so, don't let the user without any message
110 $out->addWikiMsg( 'confirmemail_sent' );
111 } elseif ( $retval instanceof Status
&& $retval->isGood() ) {
112 $out->addWikiText( $retval->getValue() );
115 // date and time are separate parameters to facilitate localisation.
116 // $time is kept for backward compat reasons.
117 // 'emailauthenticated' is also used in SpecialPreferences.php
118 $lang = $this->getLanguage();
119 $emailAuthenticated = $user->getEmailAuthenticationTimestamp();
120 $time = $lang->userTimeAndDate( $emailAuthenticated, $user );
121 $d = $lang->userDate( $emailAuthenticated, $user );
122 $t = $lang->userTime( $emailAuthenticated, $user );
123 $out->addWikiMsg( 'emailauthenticated', $time, $d, $t );
128 * Callback for HTMLForm send confirmation mail.
130 * @return Status Status object with the result
132 public function submitSend() {
133 $status = $this->getUser()->sendConfirmationMail();
134 if ( $status->isGood() ) {
135 return Status
::newGood( $this->msg( 'confirmemail_sent' )->text() );
137 return Status
::newFatal( new RawMessage(
138 $status->getWikiText( 'confirmemail_sendfailed' )
144 * Attempt to confirm the user's email address and show success or failure
145 * as needed; if successful, take the user to log in
147 * @param string $code Confirmation code
149 function attemptConfirm( $code ) {
150 $user = User
::newFromConfirmationCode( $code, User
::READ_LATEST
);
151 if ( !is_object( $user ) ) {
152 $this->getOutput()->addWikiMsg( 'confirmemail_invalid' );
157 $user->confirmEmail();
158 $user->saveSettings();
159 $message = $this->getUser()->isLoggedIn() ?
'confirmemail_loggedin' : 'confirmemail_success';
160 $this->getOutput()->addWikiMsg( $message );
162 if ( !$this->getUser()->isLoggedIn() ) {
163 $title = SpecialPage
::getTitleFor( 'Userlogin' );
164 $this->getOutput()->returnToMain( true, $title );