passwordReset === null ) { $this->passwordReset = new PasswordReset( $this->getConfig(), AuthManager::singleton() ); } return $this->passwordReset; } public function doesWrites() { return true; } public function userCanExecute( User $user ) { return $this->getPasswordReset()->isAllowed( $user )->isGood(); } public function checkExecutePermissions( User $user ) { $status = Status::wrap( $this->getPasswordReset()->isAllowed( $user ) ); if ( !$status->isGood() ) { throw new ErrorPageError( 'internalerror', $status->getMessage() ); } parent::checkExecutePermissions( $user ); } protected function getFormFields() { $resetRoutes = $this->getConfig()->get( 'PasswordResetRoutes' ); $a = []; if ( isset( $resetRoutes['username'] ) && $resetRoutes['username'] ) { $a['Username'] = [ 'type' => 'text', 'label-message' => 'passwordreset-username', ]; if ( $this->getUser()->isLoggedIn() ) { $a['Username']['default'] = $this->getUser()->getName(); } } if ( isset( $resetRoutes['email'] ) && $resetRoutes['email'] ) { $a['Email'] = [ 'type' => 'email', 'label-message' => 'passwordreset-email', ]; } if ( $this->getUser()->isAllowed( 'passwordreset' ) ) { $a['Capture'] = [ 'type' => 'check', 'label-message' => 'passwordreset-capture', 'help-message' => 'passwordreset-capture-help', ]; } return $a; } protected function getDisplayFormat() { return 'ooui'; } public function alterForm( HTMLForm $form ) { $resetRoutes = $this->getConfig()->get( 'PasswordResetRoutes' ); $form->addHiddenFields( $this->getRequest()->getValues( 'returnto', 'returntoquery' ) ); $i = 0; if ( isset( $resetRoutes['username'] ) && $resetRoutes['username'] ) { $i++; } if ( isset( $resetRoutes['email'] ) && $resetRoutes['email'] ) { $i++; } $message = ( $i > 1 ) ? 'passwordreset-text-many' : 'passwordreset-text-one'; $form->setHeaderText( $this->msg( $message, $i )->parseAsBlock() ); $form->setSubmitTextMsg( 'mailmypassword' ); } /** * Process the form. At this point we know that the user passes all the criteria in * userCanExecute(), and if the data array contains 'Username', etc, then Username * resets are allowed. * @param array $data * @throws MWException * @throws ThrottledError|PermissionsError * @return Status */ public function onSubmit( array $data ) { if ( isset( $data['Capture'] ) && !$this->getUser()->isAllowed( 'passwordreset' ) ) { // The user knows they don't have the passwordreset permission, // but they tried to spoof the form. That's naughty throw new PermissionsError( 'passwordreset' ); } $username = isset( $data['Username'] ) ? $data['Username'] : null; $email = isset( $data['Email'] ) ? $data['Email'] : null; $capture = !empty( $data['Capture'] ); $this->method = $username ? 'username' : 'email'; $this->result = Status::wrap( $this->getPasswordReset()->execute( $this->getUser(), $username, $email, $capture ) ); if ( $capture && $this->result->isOK() ) { $this->passwords = $this->result->getValue(); } if ( $this->result->hasMessage( 'actionthrottledtext' ) ) { throw new ThrottledError; } return $this->result; } public function onSuccess() { if ( $this->getUser()->isAllowed( 'passwordreset' ) && $this->passwords ) { // @todo Logging if ( $this->result->isGood() ) { $this->getOutput()->addWikiMsg( 'passwordreset-emailsent-capture2', count( $this->passwords ) ); } else { $this->getOutput()->addWikiMsg( 'passwordreset-emailerror-capture2', $this->result->getMessage(), key( $this->passwords ), count( $this->passwords ) ); } $this->getOutput()->addHTML( Html::openElement( 'ul' ) ); foreach ( $this->passwords as $username => $pwd ) { $this->getOutput()->addHTML( Html::rawElement( 'li', [], htmlspecialchars( $username, ENT_QUOTES ) . $this->msg( 'colon-separator' )->text() . htmlspecialchars( $pwd, ENT_QUOTES ) ) ); } $this->getOutput()->addHTML( Html::closeElement( 'ul' ) ); } if ( $this->method === 'email' ) { $this->getOutput()->addWikiMsg( 'passwordreset-emailsentemail' ); } else { $this->getOutput()->addWikiMsg( 'passwordreset-emailsentusername' ); } $this->getOutput()->returnToMain(); } /** * Hide the password reset page if resets are disabled. * @return bool */ public function isListed() { if ( $this->getPasswordReset()->isAllowed( $this->getUser() )->isGood() ) { return parent::isListed(); } return false; } protected function getGroupName() { return 'users'; } }