From 63601400e476c6cf43d985f3e7b9864681695ed4 Mon Sep 17 00:00:00 2001 From: Pierre Schmitz Date: Fri, 18 Jan 2013 16:46:04 +0100 Subject: Update to MediaWiki 1.20.2 this update includes: * adjusted Arch Linux skin * updated FluxBBAuthPlugin * patch for https://bugzilla.wikimedia.org/show_bug.cgi?id=44024 --- extensions/Nuke/Nuke_body.php | 114 ++++++++++++++++++++++++------------------ 1 file changed, 66 insertions(+), 48 deletions(-) (limited to 'extensions/Nuke/Nuke_body.php') diff --git a/extensions/Nuke/Nuke_body.php b/extensions/Nuke/Nuke_body.php index fbe4f56e..b8cea2f4 100644 --- a/extensions/Nuke/Nuke_body.php +++ b/extensions/Nuke/Nuke_body.php @@ -17,7 +17,11 @@ class SpecialNuke extends SpecialPage { $block = $this->getUser()->getBlock(); throw new UserBlockedError( $block ); } - $this->checkReadOnly(); + + if ( method_exists( $this, 'checkReadOnly' ) ) { + // checkReadOnly was introduced only in 1.19 + $this->checkReadOnly(); + } $req = $this->getRequest(); @@ -29,31 +33,35 @@ class SpecialNuke extends SpecialPage { if ( $user ) $target = $user->getName(); } - $reason = $req->getText( 'wpReason', - $target === '' ? - wfMsgForContent( 'nuke-multiplepeople' ) : - wfMsgForContent( 'nuke-defaultreason', "[[Special:Contributions/$target|$target]]" ) - ); + $msg = $target === '' ? + $this->msg( 'nuke-multiplepeople' )->inContentLanguage()->text() : + $this->msg( 'nuke-defaultreason', "[[Special:Contributions/$target|$target]]" )-> + inContentLanguage()->text(); + $reason = $req->getText( 'wpReason', $msg ); - if( $req->wasPosted() + $limit = $req->getInt( 'limit', 500 ); + $namespace = $req->getVal( 'namespace' ); + $namespace = ctype_digit( $namespace ) ? (int)$namespace : null; + + if ( $req->wasPosted() && $this->getUser()->matchEditToken( $req->getVal( 'wpEditToken' ) ) ) { if ( $req->getVal( 'action' ) == 'delete' ) { $pages = $req->getArray( 'pages' ); - if( $pages ) { + if ( $pages ) { $this->doDelete( $pages, $reason ); return; } } elseif ( $req->getVal( 'action' ) == 'submit' ) { - $this->listForm( $target, $reason, $req->getInt( 'limit', 500 ) ); + $this->listForm( $target, $reason, $limit, $namespace ); } else { $this->promptForm(); } } elseif ( $target === '' ) { $this->promptForm(); } else { - $this->listForm( $target, $reason, $req->getInt( 'limit', 500 ) ); + $this->listForm( $target, $reason, $limit, $namespace ); } } @@ -76,19 +84,22 @@ class SpecialNuke extends SpecialPage { ) ) . '' - . '' + . '' . '' . '' - . '' + . '' . '' + . '' + . '' + . '' . '' - . '' + . '' . '' . '' . '' - . '' - .'
' . Xml::label( wfMsg( 'nuke-userorip' ), 'nuke-target' ) . '' . Xml::label( $this->msg( 'nuke-userorip' )->text(), 'nuke-target' ) . '' . Xml::input( 'target', 40, $userName, array( 'id' => 'nuke-target' ) ) . '
' . Xml::label( wfMsg( 'nuke-pattern' ), 'nuke-pattern' ) . '' . Xml::label( $this->msg( 'nuke-pattern' )->text(), 'nuke-pattern' ) . '' . Xml::input( 'pattern', 40, '', array( 'id' => 'nuke-pattern' ) ) . '
' . Xml::label( $this->msg( 'nuke-namespace' )->text(), 'nuke-namespace' ) . '' . Html::namespaceSelector( array( 'all' => 'all' ), array( 'name' => 'namespace' ) ) . '
' . Xml::label( wfMsg( 'nuke-maxpages' ), 'nuke-limit' ) . '' . Xml::label( $this->msg( 'nuke-maxpages' )->text(), 'nuke-limit' ) . '' . Xml::input( 'limit', 7, '500', array( 'id' => 'nuke-limit' ) ) . '
' . Xml::submitButton( wfMsg( 'nuke-submit-user' ) ) . '
' - . Html::hidden( 'wpEditToken', $this->getUser()->editToken() ) + . '' . Xml::submitButton( $this->msg( 'nuke-submit-user' )->text() ) . '' + . '' + . Html::hidden( 'wpEditToken', $this->getUser()->getEditToken() ) . Xml::closeElement( 'form' ) ); } @@ -99,13 +110,14 @@ class SpecialNuke extends SpecialPage { * @param string $username * @param string $reason * @param integer $limit + * @param integer|null $namespace */ - protected function listForm( $username, $reason, $limit ) { + protected function listForm( $username, $reason, $limit, $namespace = null ) { $out = $this->getOutput(); - $pages = $this->getNewPages( $username, $limit ); + $pages = $this->getNewPages( $username, $limit, $namespace ); - if( count( $pages ) == 0 ) { + if ( count( $pages ) == 0 ) { if ( $username === '' ) { $out->addWikiMsg( 'nuke-nopages-global' ); } else { @@ -130,13 +142,13 @@ class SpecialNuke extends SpecialPage { Xml::openElement( 'form', array( 'action' => $nuke->getLocalURL( 'action=delete' ), 'method' => 'post', - 'name' => 'nukelist') + 'name' => 'nukelist' ) ) . - Html::hidden( 'wpEditToken', $this->getUser()->editToken() ) . + Html::hidden( 'wpEditToken', $this->getUser()->getEditToken() ) . Xml::tags( 'p', null, Xml::inputLabel( - wfMsg( 'deletecomment' ), 'wpReason', 'wpReason', 70, $reason + $this->msg( 'deletecomment' )->text(), 'wpReason', 'wpReason', 70, $reason ) ) ); @@ -144,24 +156,27 @@ class SpecialNuke extends SpecialPage { // Select: All, None $links = array(); $links[] = '' . - wfMsg( 'powersearch-toggleall' ) . ''; + $this->msg( 'powersearch-toggleall' )->text() . ''; $links[] = '' . - wfMsg( 'powersearch-togglenone' ) . ''; + $this->msg( 'powersearch-togglenone' )->text() . ''; $out->addHTML( Xml::tags( 'p', null, - wfMsg( 'nuke-select', $this->getLanguage()->commaList( $links ) ) + $this->msg( 'nuke-select', $this->getLanguage()->commaList( $links ) )->text() ) ); // Delete button $out->addHTML( - Xml::submitButton( wfMsg( 'nuke-submit-delete' ) ) + Xml::submitButton( $this->msg( 'nuke-submit-delete' )->text() ) ); $out->addHTML( '\n" . - Xml::submitButton( wfMsg( 'nuke-submit-delete' ) ) . + Xml::submitButton( wfMessage( 'nuke-submit-delete' )->text() ) . '' ); } @@ -202,10 +216,11 @@ class SpecialNuke extends SpecialPage { * * @param string $username * @param integer $limit + * @param integer|null $namespace * * @return array */ - protected function getNewPages( $username, $limit ) { + protected function getNewPages( $username, $limit, $namespace = null ) { $dbr = wfGetDB( DB_SLAVE ); $what = array( @@ -222,6 +237,10 @@ class SpecialNuke extends SpecialPage { $where['rc_user_text'] = $username; } + if ( $namespace !== null ) { + $where['rc_namespace'] = $namespace; + } + $pattern = $this->getRequest()->getText( 'pattern' ); if ( !is_null( $pattern ) && trim( $pattern ) !== '' ) { $where[] = 'rc_title LIKE ' . $dbr->addQuotes( $pattern ); @@ -256,17 +275,18 @@ class SpecialNuke extends SpecialPage { * * @param array $pages The pages to delete * @param string $reason + * @throws PermissionsError */ protected function doDelete( array $pages, $reason ) { $res = array(); - foreach( $pages as $page ) { + foreach ( $pages as $page ) { $title = Title::newFromURL( $page ); $file = $title->getNamespace() == NS_FILE ? wfLocalFile( $title ) : false; - $permission_errors = $title->getUserPermissionsErrors( 'delete', $this->getUser()); + $permission_errors = $title->getUserPermissionsErrors( 'delete', $this->getUser() ); - if ( count( $permission_errors )) { + if ( $permission_errors !== array() ) { throw new PermissionsError( 'delete', $permission_errors ); } @@ -279,15 +299,13 @@ class SpecialNuke extends SpecialPage { } if ( $ok ) { - $res[] = wfMsgExt( 'nuke-deleted', array( 'parseinline' ), $title->getPrefixedText() ); + $res[] = wfMessage( 'nuke-deleted', $title->getPrefixedText() )->parse(); } else { - $res[] = wfMsgExt( 'nuke-not-deleted', array( 'parseinline' ), $title->getPrefixedText() ); + $res[] = wfMessage( 'nuke-not-deleted', $title->getPrefixedText() )->parse(); } } $this->getOutput()->addHTML( "\n" ); - $this->getOutput()->addWikiMsg( 'nuke-delete-more' ); } - } -- cgit v1.2.3-54-g00ecf