Port Special:Lockdb and Special:Unlockdb to HTMLForm using FormSpecialPage
authorAlexandre Emsenhuber <ialex@users.mediawiki.org>
Tue, 25 Oct 2011 18:20:44 +0000 (18:20 +0000)
committerAlexandre Emsenhuber <ialex@users.mediawiki.org>
Tue, 25 Oct 2011 18:20:44 +0000 (18:20 +0000)
includes/specials/SpecialLockdb.php
includes/specials/SpecialUnlockdb.php

index 85421c3..9dec018 100644 (file)
  *
  * @ingroup SpecialPage
  */
-class SpecialLockdb extends SpecialPage {
+class SpecialLockdb extends FormSpecialPage {
        var $reason = '';
 
        public function __construct() {
                parent::__construct( 'Lockdb', 'siteadmin' );
        }
 
-       public function execute( $par ) {
-               $this->setHeaders();
-
-               # Permission check
-               if( !$this->userCanExecute( $this->getUser() ) ) {
-                       $this->displayRestrictionError();
-                       return;
-               }
+       public function requiresWrite() {
+               return false;
+       }
 
-               $this->outputHeader();
+       public function userCanExecute( User $user ) {
+               parent::userCanExecute( $user );
 
                # If the lock file isn't writable, we can do sweet bugger all
                global $wgReadOnlyFile;
-               if( !is_writable( dirname( $wgReadOnlyFile ) ) ) {
-                       $this->getOutput()->addWikiMsg( 'lockfilenotwritable' );
-                       return;
-               }
-
-               $request = $this->getRequest();
-               $action = $request->getVal( 'action' );
-               $this->reason = $request->getVal( 'wpLockReason', '' );
-
-               if ( $action == 'success' ) {
-                       $this->showSuccess();
-               } elseif ( $action == 'submit' && $request->wasPosted() &&
-                       $this->getUser()->matchEditToken( $request->getVal( 'wpEditToken' ) ) ) {
-                       $this->doSubmit();
-               } else {
-                       $this->showForm();
+               if ( !is_writable( dirname( $wgReadOnlyFile ) ) ) {
+                       throw new ErrorPageError( 'lockdb', 'lockfilenotwritable' );
                }
        }
 
-       private function showForm( $err = '' ) {
-               $out = $this->getOutput();
-               $out->addWikiMsg( 'lockdbtext' );
-
-               if ( $err != '' ) {
-                       $out->setSubtitle( wfMsg( 'formerror' ) );
-                       $out->addHTML( '<p class="error">' . htmlspecialchars( $err ) . "</p>\n" );
-               }
-
-               $out->addHTML(
-                       Html::openElement( 'form', array( 'id' => 'lockdb', 'method' => 'POST',
-                               'action' => $this->getTitle()->getLocalURL( 'action=submit' ) ) ). "\n" .
-                       wfMsgHtml( 'enterlockreason' ) . ":\n" .
-                       Html::textarea( 'wpLockReason', $this->reason, array( 'rows' => 4 ) ). "
-<table>
-       <tr>
-               " . Html::openElement( 'td', array( 'style' => 'text-align:right' ) ) . "
-                       " . Html::input( 'wpLockConfirm', null, 'checkbox', array( 'id' => 'mw-input-wplockconfirm' ) ) . "
-               </td>
-               " . Html::openElement( 'td', array( 'style' => 'text-align:left' ) ) .
-                       Html::openElement( 'label', array( 'for' => 'mw-input-wplockconfirm' ) ) .
-                       wfMsgHtml( 'lockconfirm' ) . "</label>
-               </td>
-       </tr>
-       <tr>
-               <td>&#160;</td>
-               " . Html::openElement( 'td', array( 'style' => 'text-align:left' ) ) . "
-                       " . Html::input( 'wpLock', wfMsg( 'lockbtn' ), 'submit' ) . "
-               </td>
-       </tr>
-</table>\n" .
-                       Html::hidden( 'wpEditToken', $this->getUser()->editToken() ) . "\n" .
-                       Html::closeElement( 'form' )
+       protected function getFormFields() {
+               return array(
+                       'Reason' => array(
+                               'type' => 'textarea',
+                               'rows' => 4,
+                               'vertical-label' => true,
+                               'label-message' => 'enterlockreason',
+                       ),
+                       'Confirm' => array(
+                               'type' => 'toggle',
+                               'label-message' => 'lockconfirm',
+                       ),
                );
+       }
 
+       protected function alterForm( HTMLForm $form ) {
+               $form->setWrapperLegend( false );
+               $form->setHeaderText( $this->msg( 'lockdbtext' )->parseAsBlock() );
+               $form->setSubmitTextMsg( 'lockbtn' );
        }
 
-       private function doSubmit() {
+       public function onSubmit( array $data ) {
                global $wgContLang, $wgReadOnlyFile;
 
-               if ( !$this->getRequest()->getCheck( 'wpLockConfirm' ) ) {
-                       $this->showForm( wfMsg( 'locknoconfirm' ) );
-                       return;
+               if ( !$data['Confirm'] ) {
+                       return Status::newFatal( 'locknoconfirm' );
                }
 
                wfSuppressWarnings();
@@ -118,10 +83,9 @@ class SpecialLockdb extends SpecialPage {
                        # This used to show a file not found error, but the likeliest reason for fopen()
                        # to fail at this point is insufficient permission to write to the file...good old
                        # is_writable() is plain wrong in some cases, it seems...
-                       $this->getOutput()->addWikiMsg( 'lockfilenotwritable' );
-                       return;
+                       return Status::newFatal( 'lockfilenotwritable' );
                }
-               fwrite( $fp, $this->reason );
+               fwrite( $fp, $data['Reason'] );
                $timestamp = wfTimestampNow();
                fwrite( $fp, "\n<p>" . wfMsgExt(
                        'lockedbyandtime',
@@ -132,12 +96,11 @@ class SpecialLockdb extends SpecialPage {
                ) . "</p>\n" );
                fclose( $fp );
 
-               $this->getOutput()->redirect( $this->getTitle()->getFullURL( 'action=success' ) );
+               return Status::newGood();
        }
 
-       private function showSuccess() {
+       public function onSuccess() {
                $out = $this->getOutput();
-               $out->setPagetitle( wfMsg( 'lockdb' ) );
                $out->setSubtitle( wfMsg( 'lockdbsuccesssub' ) );
                $out->addWikiMsg( 'lockdbsuccesstext' );
        }
index 0443864..115e617 100644 (file)
  *
  * @ingroup SpecialPage
  */
-class SpecialUnlockdb extends SpecialPage {
+class SpecialUnlockdb extends FormSpecialPage {
 
        public function __construct() {
                parent::__construct( 'Unlockdb', 'siteadmin' );
        }
 
-       public function execute( $par ) {
-               $this->setHeaders();
-
-               # Permission check
-               if( !$this->userCanExecute( $this->getUser() ) ) {
-                       $this->displayRestrictionError();
-                       return;
-               }
-
-               $this->outputHeader();
-
-               $request = $this->getRequest();
-               $action = $request->getVal( 'action' );
-
-               if ( $action == 'success' ) {
-                       $this->showSuccess();
-               } elseif ( $action == 'submit' && $request->wasPosted() &&
-                       $this->getUser()->matchEditToken( $request->getVal( 'wpEditToken' ) ) ) {
-                       $this->doSubmit();
-               } else {
-                       $this->showForm();
-               }
+       public function requiresWrite() {
+               return false;
        }
 
-       private function showForm( $err = '' ) {
-               global $wgReadOnlyFile;
-
-               $out = $this->getOutput();
-
-               if( !file_exists( $wgReadOnlyFile ) ) {
-                       $out->addWikiMsg( 'databasenotlocked' );
-                       return;
-               }
-
-               $out->addWikiMsg( 'unlockdbtext' );
+       public function userCanExecute( User $user ) {
+               parent::userCanExecute( $user );
 
-               if ( $err != '' ) {
-                       $out->setSubtitle( wfMsg( 'formerror' ) );
-                       $out->addHTML( '<p class="error">' . htmlspecialchars( $err ) . "</p>\n" );
+               # If the lock file isn't writable, we can do sweet bugger all
+               global $wgReadOnlyFile;
+               if ( !file_exists( $wgReadOnlyFile ) ) {
+                       throw new ErrorPageError( 'lockdb', 'databasenotlocked' );
                }
+       }
 
-               $out->addHTML(
-                       Html::openElement( 'form', array( 'id' => 'unlockdb', 'method' => 'POST',
-                               'action' => $this->getTitle()->getLocalURL( 'action=submit' ) ) ) . "
-<table>
-       <tr>
-               " . Html::openElement( 'td', array( 'style' => 'text-align:right' ) ) . "
-                       " . Html::input( 'wpLockConfirm', null, 'checkbox',  array( 'id' => 'mw-input-wpunlockconfirm' )  ) . "
-               </td>
-               " . Html::openElement( 'td', array( 'style' => 'text-align:left' ) ) .
-                       Html::openElement( 'label', array( 'for' => 'mw-input-wpunlockconfirm' ) ) .
-                       wfMsgHtml( 'unlockconfirm' ) . "</label>
-               </td>
-       </tr>
-       <tr>
-               <td>&#160;</td>
-               " . Html::openElement( 'td', array( 'style' => 'text-align:left' ) ) . "
-                       " . Html::input( 'wpLock', wfMsg( 'unlockbtn' ), 'submit' ) . "
-               </td>
-       </tr>
-</table>\n" .
-                       Html::hidden( 'wpEditToken', $this->getUser()->editToken() ) . "\n" .
-                       Html::closeElement( 'form' )
+       protected function getFormFields() {
+               return array(
+                       'Confirm' => array(
+                               'type' => 'toggle',
+                               'label-message' => 'unlockconfirm',
+                       ),
                );
+       }
 
+       protected function alterForm( HTMLForm $form ) {
+               $form->setWrapperLegend( false );
+               $form->setHeaderText( $this->msg( 'unlockdbtext' )->parseAsBlock() );
+               $form->setSubmitTextMsg( 'unlockbtn' );
        }
 
-       private function doSubmit() {
+       public function onSubmit( array $data ) {
                global $wgReadOnlyFile;
 
-               if ( !$this->getRequest()->getCheck( 'wpLockConfirm' ) ) {
-                       $this->showForm( wfMsg( 'locknoconfirm' ) );
-                       return;
+               if ( !$data['Confirm'] ) {
+                       return Status::newFatal( 'locknoconfirm' );
                }
 
                wfSuppressWarnings();
@@ -112,13 +73,13 @@ class SpecialUnlockdb extends SpecialPage {
                wfRestoreWarnings();
 
                if ( $res ) {
-                       $this->getOutput()->redirect( $this->getTitle()->getFullURL( 'action=success' ) );
+                       return Status::newGood();
                } else {
-                       $this->getOutput()->addWikiMsg( 'filedeleteerror', $wgReadOnlyFile );
+                       return Status::newFatal( 'filedeleteerror', $wgReadOnlyFile );
                }
        }
 
-       private function showSuccess() {
+       public function onSuccess() {
                $out = $this->getOutput();
                $out->setSubtitle( wfMsg( 'unlockdbsuccesssub' ) );
                $out->addWikiMsg( 'unlockdbsuccesstext' );