X-Git-Url: https://scripts.mit.edu/gitweb/autoinstallsdev/mediawiki.git/blobdiff_plain/19e297c21b10b1b8a3acad5e73fc71dcb35db44a..6932310fd58ebef145fa01eb76edf7150284d8ea:/includes/specials/SpecialPreferences.php diff --git a/includes/specials/SpecialPreferences.php b/includes/specials/SpecialPreferences.php index e63aeee6..ba5a57ea 100644 --- a/includes/specials/SpecialPreferences.php +++ b/includes/specials/SpecialPreferences.php @@ -31,72 +31,140 @@ class SpecialPreferences extends SpecialPage { parent::__construct( 'Preferences' ); } - function execute( $par ) { - global $wgOut, $wgUser, $wgRequest; + public function doesWrites() { + return true; + } + public function execute( $par ) { $this->setHeaders(); $this->outputHeader(); - $wgOut->disallowUserJs(); # Prevent hijacked user scripts from sniffing passwords etc. + $out = $this->getOutput(); + $out->disallowUserJs(); # Prevent hijacked user scripts from sniffing passwords etc. - if ( $wgUser->isAnon() ) { - $wgOut->showErrorPage( 'prefsnologin', 'prefsnologintext', array( $this->getTitle()->getPrefixedDBkey() ) ); - return; - } - if ( wfReadOnly() ) { - $wgOut->readOnlyPage(); - return; - } + $this->requireLogin( 'prefsnologintext2' ); + $this->checkReadOnly(); if ( $par == 'reset' ) { $this->showResetForm(); + return; } - $wgOut->addModules( 'mediawiki.legacy.prefs' ); - $wgOut->addModules( 'mediawiki.special.preferences' ); - - if ( $wgRequest->getCheck( 'success' ) ) { - $wgOut->wrapWikiMsg( - "
\n$1\n
", - 'savedprefs' + $out->addModules( 'mediawiki.special.preferences' ); + $out->addModuleStyles( 'mediawiki.special.preferences.styles' ); + + $session = $this->getRequest()->getSession(); + if ( $session->get( 'specialPreferencesSaveSuccess' ) ) { + // Remove session data for the success message + $session->remove( 'specialPreferencesSaveSuccess' ); + $out->addModuleStyles( 'mediawiki.notification.convertmessagebox.styles' ); + + $out->addHTML( + Html::rawElement( + 'div', + [ + 'class' => 'mw-preferences-messagebox mw-notify-success successbox', + 'id' => 'mw-preferences-success', + 'data-mw-autohide' => 'false', + ], + Html::element( 'p', [], $this->msg( 'savedprefs' )->text() ) + ) ); } - - if ( $wgRequest->getCheck( 'eauth' ) ) { - $wgOut->wrapWikiMsg( "
\n$1\n
", - 'eauthentsent', $wgUser->getName() ); + + $this->addHelpLink( 'Help:Preferences' ); + + // Load the user from the master to reduce CAS errors on double post (T95839) + if ( $this->getRequest()->wasPosted() ) { + $user = $this->getUser()->getInstanceForUpdate() ?: $this->getUser(); + } else { + $user = $this->getUser(); } - $htmlForm = Preferences::getFormObject( $wgUser ); - $htmlForm->setSubmitCallback( array( 'Preferences', 'tryUISubmit' ) ); + $htmlForm = $this->getFormObject( $user, $this->getContext() ); + $htmlForm->setSubmitCallback( [ 'Preferences', 'tryUISubmit' ] ); + $sectionTitles = $htmlForm->getPreferenceSections(); + + $prefTabs = ''; + foreach ( $sectionTitles as $key ) { + $prefTabs .= Html::rawElement( 'li', + [ + 'role' => 'presentation', + 'class' => ( $key === 'personal' ) ? 'selected' : null + ], + Html::rawElement( 'a', + [ + 'id' => 'preftab-' . $key, + 'role' => 'tab', + 'href' => '#mw-prefsection-' . $key, + 'aria-controls' => 'mw-prefsection-' . $key, + 'aria-selected' => ( $key === 'personal' ) ? 'true' : 'false', + 'tabIndex' => ( $key === 'personal' ) ? 0 : -1, + ], + $htmlForm->getLegend( $key ) + ) + ); + } + $out->addHTML( + Html::rawElement( 'ul', + [ + 'id' => 'preftoc', + 'role' => 'tablist' + ], + $prefTabs ) + ); $htmlForm->show(); } - function showResetForm() { - global $wgOut; + /** + * Get the preferences form to use. + * @param User $user The user. + * @param IContextSource $context The context. + * @return PreferencesForm|HtmlForm + */ + protected function getFormObject( $user, IContextSource $context ) { + return Preferences::getFormObject( $user, $context ); + } + + private function showResetForm() { + if ( !$this->getUser()->isAllowed( 'editmyoptions' ) ) { + throw new PermissionsError( 'editmyoptions' ); + } - $wgOut->addWikiMsg( 'prefs-reset-intro' ); + $this->getOutput()->addWikiMsg( 'prefs-reset-intro' ); - $htmlForm = new HTMLForm( array(), 'prefs-restore' ); + $context = new DerivativeContext( $this->getContext() ); + $context->setTitle( $this->getPageTitle( 'reset' ) ); // Reset subpage + $htmlForm = new HTMLForm( [], $context, 'prefs-restore' ); - $htmlForm->setSubmitText( wfMsg( 'restoreprefs' ) ); - $htmlForm->setTitle( $this->getTitle( 'reset' ) ); - $htmlForm->setSubmitCallback( array( __CLASS__, 'submitReset' ) ); + $htmlForm->setSubmitTextMsg( 'restoreprefs' ); + $htmlForm->setSubmitDestructive(); + $htmlForm->setSubmitCallback( [ $this, 'submitReset' ] ); $htmlForm->suppressReset(); $htmlForm->show(); } - static function submitReset( $formData ) { - global $wgUser, $wgOut; - $wgUser->resetOptions(); - $wgUser->saveSettings(); + public function submitReset( $formData ) { + if ( !$this->getUser()->isAllowed( 'editmyoptions' ) ) { + throw new PermissionsError( 'editmyoptions' ); + } + + $user = $this->getUser()->getInstanceForUpdate(); + $user->resetOptions( 'all', $this->getContext() ); + $user->saveSettings(); - $url = SpecialPage::getTitleFor( 'Preferences' )->getFullURL( 'success' ); + // Set session data for the success message + $this->getRequest()->getSession()->set( 'specialPreferencesSaveSuccess', 1 ); - $wgOut->redirect( $url ); + $url = $this->getPageTitle()->getFullUrlForRedirect(); + $this->getOutput()->redirect( $url ); return true; } + + protected function getGroupName() { + return 'users'; + } }