From 28c72a277e5a101555f9c669dab5ef50cd6fe94d Mon Sep 17 00:00:00 2001 From: Alexandre Emsenhuber Date: Sat, 11 Jul 2009 19:07:55 +0000 Subject: [PATCH] follow-up r53116: let's just delete the files since the feature was reverted in r41405 but these files were not deleted --- .../specials/SpecialListUserRestrictions.php | 162 --------------- includes/specials/SpecialRestrictUser.php | 190 ------------------ 2 files changed, 352 deletions(-) delete mode 100644 includes/specials/SpecialListUserRestrictions.php delete mode 100644 includes/specials/SpecialRestrictUser.php diff --git a/includes/specials/SpecialListUserRestrictions.php b/includes/specials/SpecialListUserRestrictions.php deleted file mode 100644 index e7fc8074ff..0000000000 --- a/includes/specials/SpecialListUserRestrictions.php +++ /dev/null @@ -1,162 +0,0 @@ -addWikiMsg( 'listuserrestrictions-intro' ); - $f = new SpecialListUserRestrictionsForm(); - $wgOut->addHTML( $f->getHTML() ); - - if( !mt_rand( 0, 10 ) ) - UserRestriction::purgeExpired(); - $pager = new UserRestrictionsPager( $f->getConds() ); - if( $pager->getNumRows() ) - $wgOut->addHTML( $pager->getNavigationBar() . - Xml::tags( 'ul', null, $pager->getBody() ) . - $pager->getNavigationBar() - ); - elseif( $f->getConds() ) - $wgOut->addWikiMsg( 'listuserrestrictions-notfound' ); - else - $wgOut->addWikiMsg( 'listuserrestrictions-empty' ); -} - -class SpecialListUserRestrictionsForm { - public function getHTML() { - global $wgRequest, $wgScript; - $action = htmlspecialchars( $wgScript ); - $s = ''; - $s .= Xml::fieldset( wfMsg( 'listuserrestrictions-legend' ) ); - $s .= "
"; - $s .= Xml::hidden( 'title', SpecialPage::getTitleFor('ListUserRestrictions')->getPrefixedDbKey() ); - $s .= Xml::label( wfMsgHtml( 'listuserrestrictions-type' ), 'type' ) . ' ' . - self::typeSelector( 'type', $wgRequest->getVal( 'type' ), 'type' ); - $s .= ' '; - $s .= Xml::inputLabel( wfMsgHtml( 'listuserrestrictions-user' ), 'user', 'user', - false, $wgRequest->getVal( 'user' ) ); - $s .= '

'; - $s .= Xml::label( wfMsgHtml( 'listuserrestrictions-namespace' ), 'namespace' ) . ' ' . - Xml::namespaceSelector( $wgRequest->getVal( 'namespace' ), '', 'namespace' ); - $s .= ' '; - $s .= Xml::inputLabel( wfMsgHtml( 'listuserrestrictions-page' ), 'page', 'page', - false, $wgRequest->getVal( 'page' ) ); - $s .= Xml::submitButton( wfMsg( 'listuserrestrictions-submit' ) ); - $s .= "

"; - return $s; - } - - public static function typeSelector( $name = 'type', $value = '', $id = false ) { - $s = new XmlSelect( $name, $id, $value ); - $s->addOption( wfMsg( 'userrestrictiontype-none' ), '' ); - $s->addOption( wfMsg( 'userrestrictiontype-page' ), UserRestriction::PAGE_RESTRICTION ); - $s->addOption( wfMsg( 'userrestrictiontype-namespace' ), UserRestriction::NAMESPACE_RESTRICTION ); - return $s->getHTML(); - } - - public function getConds() { - global $wgRequest; - $conds = array(); - - $type = $wgRequest->getVal( 'type' ); - if( in_array( $type, array( UserRestriction::PAGE_RESTRICTION, UserRestriction::NAMESPACE_RESTRICTION ) ) ) - $conds['ur_type'] = $type; - - $user = $wgRequest->getVal( 'user' ); - if( $user ) - $conds['ur_user_text'] = $user; - - $namespace = $wgRequest->getVal( 'namespace' ); - if( $namespace || $namespace === '0' ) - $conds['ur_namespace'] = $namespace; - - $page = $wgRequest->getVal( 'page' ); - $title = Title::newFromText( $page ); - if( $title ) { - $conds['ur_page_namespace'] = $title->getNamespace(); - $conds['ur_page_title'] = $title->getDBkey(); - } - - return $conds; - } -} - -class UserRestrictionsPager extends ReverseChronologicalPager { - public $mConds; - - public function __construct( $conds = array() ) { - $this->mConds = $conds; - parent::__construct(); - } - - public function getStartBody() { - # Copied from Special:Ipblocklist - wfProfileIn( __METHOD__ ); - # Do a link batch query - $this->mResult->seek( 0 ); - $lb = new LinkBatch; - - # Faster way - # Usernames and titles are in fact related by a simple substitution of space -> underscore - # The last few lines of Title::secureAndSplit() tell the story. - foreach( $this->mResult as $row ) { - $name = str_replace( ' ', '_', $row->ur_by_text ); - $lb->add( NS_USER, $name ); - $lb->add( NS_USER_TALK, $name ); - $name = str_replace( ' ', '_', $row->ur_user_text ); - $lb->add( NS_USER, $name ); - $lb->add( NS_USER_TALK, $name ); - if( $row->ur_type == UserRestriction::PAGE_RESTRICTION ) - $lb->add( $row->ur_page_namespace, $row->ur_page_title ); - } - $lb->execute(); - wfProfileOut( __METHOD__ ); - return ''; - } - - public function getQueryInfo() { - return array( - 'tables' => 'user_restrictions', - 'fields' => '*', - 'conds' => $this->mConds, - ); - } - - public function formatRow( $row ) { - return self::formatRestriction( UserRestriction::newFromRow( $row ) ); - } - - // Split off for use on Special:RestrictUser - public static function formatRestriction( $r ) { - global $wgUser, $wgLang; - $sk = $wgUser->getSkin(); - $timestamp = $wgLang->timeanddate( $r->getTimestamp(), true ); - $blockerlink = $sk->userLink( $r->getBlockerId(), $r->getBlockerText() ) . - $sk->userToolLinks( $r->getBlockerId(), $r->getBlockerText() ); - $subjlink = $sk->userLink( $r->getSubjectId(), $r->getSubjectText() ) . - $sk->userToolLinks( $r->getSubjectId(), $r->getSubjectText() ); - $expiry = is_numeric( $r->getExpiry() ) ? - wfMsg( 'listuserrestrictions-row-expiry', $wgLang->timeanddate( $r->getExpiry() ) ) : - wfMsg( 'ipbinfinite' ); - $msg = ''; - if( $r->isNamespace() ) { - $msg = wfMsgHtml( 'listuserrestrictions-row-ns', $subjlink, - $wgLang->getDisplayNsText( $r->getNamespace() ), $expiry ); - } - if( $r->isPage() ) { - $pagelink = $sk->link( $r->getPage() ); - $msg = wfMsgHtml( 'listuserrestrictions-row-page', $subjlink, - $pagelink, $expiry ); - } - $reason = $sk->commentBlock( $r->getReason() ); - $removelink = ''; - if( $wgUser->isAllowed( 'restrict' ) ) { - $removelink = '(' . $sk->link( SpecialPage::getTitleFor( 'RemoveRestrictions' ), - wfMsgHtml( 'listuserrestrictions-remove' ), array(), array( 'id' => $r->getId() ) ) . ')'; - } - return "
  • {$timestamp}, {$blockerlink} {$msg} {$reason} {$removelink}
  • \n"; - } - - public function getIndexField() { - return 'ur_timestamp'; - } -} diff --git a/includes/specials/SpecialRestrictUser.php b/includes/specials/SpecialRestrictUser.php deleted file mode 100644 index 8f6be0defb..0000000000 --- a/includes/specials/SpecialRestrictUser.php +++ /dev/null @@ -1,190 +0,0 @@ -getVal( 'user' ) ) { - $userOrig = $wgRequest->getVal( 'user' ); - } else { - $wgOut->addHTML( RestrictUserForm::selectUserForm() ); - return; - } - $isIP = User::isIP( $userOrig ); - $user = $isIP ? $userOrig : User::getCanonicalName( $userOrig ); - $uid = User::idFromName( $user ); - if( !$uid && !$isIP ) { - $err = '' . wfMsgHtml( 'restrictuser-notfound' ) . ''; - $wgOut->addHTML( RestrictUserForm::selectUserForm( $userOrig, $err ) ); - return; - } - $wgOut->addHTML( RestrictUserForm::selectUserForm( $user ) ); - - UserRestriction::purgeExpired(); - $old = UserRestriction::fetchForUser( $user, true ); - - RestrictUserForm::pageRestrictionForm( $uid, $user, $old ); - RestrictUserForm::namespaceRestrictionForm( $uid, $user, $old ); - - // Renew it after possible changes in previous two functions - $old = UserRestriction::fetchForUser( $user, true ); - if( $old ) { - $wgOut->addHTML( RestrictUserForm::existingRestrictions( $old ) ); - } -} - -class RestrictUserForm { - public static function selectUserForm( $val = null, $error = null ) { - global $wgScript; - $action = htmlspecialchars( $wgScript ); - $s = Xml::fieldset( wfMsg( 'restrictuser-userselect' ) ) . "
    "; - if( $error ) - $s .= '

    ' . $error . '

    '; - $s .= Xml::hidden( 'title', SpecialPage::getTitleFor( 'RestrictUser' )->getPrefixedDbKey() ); - $form = array( 'restrictuser-user' => Xml::input( 'user', false, $val ) ); - $s .= Xml::buildForm( $form, 'restrictuser-go' ); - $s .= "
    "; - return $s; - } - - public static function existingRestrictions( $restrictions ) { - //TODO: autoload? - require_once( dirname( __FILE__ ) . '/SpecialListUserRestrictions.php' ); - $s = Xml::fieldset( wfMsg( 'restrictuser-existing' ) ) . '"; - return $s; - } - - public static function pageRestrictionForm( $uid, $user, $oldRestrictions ) { - global $wgOut, $wgRequest, $wgUser; - $error = ''; - $success = false; - if( $wgRequest->wasPosted() && $wgRequest->getVal( 'type' ) == UserRestriction::PAGE_RESTRICTION && - $wgUser->matchEditToken( $wgRequest->getVal( 'edittoken' ) ) ) { - - $title = Title::newFromText( $wgRequest->getVal( 'page' ) ); - if( !$title ) { - $error = array( 'restrictuser-badtitle', $wgRequest->getVal( 'page' ) ); - } elseif( UserRestriction::convertExpiry( $wgRequest->getVal( 'expiry' ) ) === false ) { - $error = array( 'restrictuser-badexpiry', $wgRequest->getVal( 'expiry' ) ); - } else { - foreach( $oldRestrictions as $r ) { - if( $r->isPage() && $r->getPage()->equals( $title ) ) - $error = array( 'restrictuser-duptitle' ); - } - } - if( !$error ) { - self::doPageRestriction( $uid, $user ); - $success = array('restrictuser-success', $user); - } - } - $useRequestValues = $wgRequest->getVal( 'type' ) == UserRestriction::PAGE_RESTRICTION; - $wgOut->addHTML( Xml::fieldset( wfMsg( 'restrictuser-legend-page' ) ) ); - - self::printSuccessError( $success, $error ); - - $wgOut->addHTML( Xml::openElement( 'form', array( 'action' => SpecialPage::getTitleFor( 'RestrictUser' )->getLocalUrl(), - 'method' => 'post' ) ) ); - $wgOut->addHTML( Xml::hidden( 'type', UserRestriction::PAGE_RESTRICTION ) ); - $wgOut->addHTML( Xml::hidden( 'edittoken', $wgUser->editToken() ) ); - $wgOut->addHTML( Xml::hidden( 'user', $user ) ); - $form = array(); - $form['restrictuser-title'] = Xml::input( 'page', false, - $useRequestValues ? $wgRequest->getVal( 'page' ) : false ); - $form['restrictuser-expiry'] = Xml::input( 'expiry', false, - $useRequestValues ? $wgRequest->getVal( 'expiry' ) : false ); - $form['restrictuser-reason'] = Xml::input( 'reason', false, - $useRequestValues ? $wgRequest->getVal( 'reason' ) : false ); - $wgOut->addHTML( Xml::buildForm( $form, 'restrictuser-submit' ) ); - $wgOut->addHTML( "" ); - } - - public static function printSuccessError( $success, $error ) { - global $wgOut; - if ( $error ) - $wgOut->wrapWikiMsg( '$1', $error ); - if ( $success ) - $wgOut->wrapWikiMsg( '$1', $success ); - } - - public static function doPageRestriction( $uid, $user ) { - global $wgUser, $wgRequest; - $r = new UserRestriction(); - $r->setType( UserRestriction::PAGE_RESTRICTION ); - $r->setPage( Title::newFromText( $wgRequest->getVal( 'page' ) ) ); - $r->setSubjectId( $uid ); - $r->setSubjectText( $user ); - $r->setBlockerId( $wgUser->getId() ); - $r->setBlockerText( $wgUser->getName() ); - $r->setReason( $wgRequest->getVal( 'reason' ) ); - $r->setExpiry( UserRestriction::convertExpiry( $wgRequest->getVal( 'expiry' ) ) ); - $r->setTimestamp( wfTimestampNow( TS_MW ) ); - $r->commit(); - $logExpiry = $wgRequest->getVal( 'expiry' ) ? $wgRequest->getVal( 'expiry' ) : Block::infinity(); - $l = new LogPage( 'restrict' ); - $l->addEntry( 'restrict', Title::makeTitle( NS_USER, $user ), $r->getReason(), - array( $r->getType(), $r->getPage()->getFullText(), $logExpiry) ); - } - - public static function namespaceRestrictionForm( $uid, $user, $oldRestrictions ) { - global $wgOut, $wgRequest, $wgUser, $wgContLang; - $error = ''; - $success = false; - if( $wgRequest->wasPosted() && $wgRequest->getVal( 'type' ) == UserRestriction::NAMESPACE_RESTRICTION && - $wgUser->matchEditToken( $wgRequest->getVal( 'edittoken' ) ) ) { - $ns = $wgRequest->getVal( 'namespace' ); - if( $wgContLang->getNsText( $ns ) === false ) - $error = wfMsgExt( 'restrictuser-badnamespace', 'parseinline' ); - elseif( UserRestriction::convertExpiry( $wgRequest->getVal( 'expiry' ) ) === false ) - $error = wfMsgExt( 'restrictuser-badexpiry', 'parseinline', $wgRequest->getVal( 'expiry' ) ); - else - foreach( $oldRestrictions as $r ) - if( $r->isNamespace() && $r->getNamespace() == $ns ) - $error = wfMsgExt( 'restrictuser-dupnamespace', 'parse' ); - if( !$error ) { - self::doNamespaceRestriction( $uid, $user ); - $success = array('restrictuser-success', $user); - } - } - $useRequestValues = $wgRequest->getVal( 'type' ) == UserRestriction::NAMESPACE_RESTRICTION; - $wgOut->addHTML( Xml::fieldset( wfMsg( 'restrictuser-legend-namespace' ) ) ); - - self::printSuccessError( $success, $error ); - - $wgOut->addHTML( Xml::openElement( 'form', array( 'action' => SpecialPage::getTitleFor( 'RestrictUser' )->getLocalUrl(), - 'method' => 'post' ) ) ); - $wgOut->addHTML( Xml::hidden( 'type', UserRestriction::NAMESPACE_RESTRICTION ) ); - $wgOut->addHTML( Xml::hidden( 'edittoken', $wgUser->editToken() ) ); - $wgOut->addHTML( Xml::hidden( 'user', $user ) ); - $form = array(); - $form['restrictuser-namespace'] = Xml::namespaceSelector( $wgRequest->getVal( 'namespace' ) ); - $form['restrictuser-expiry'] = Xml::input( 'expiry', false, - $useRequestValues ? $wgRequest->getVal( 'expiry' ) : false ); - $form['restrictuser-reason'] = Xml::input( 'reason', false, - $useRequestValues ? $wgRequest->getVal( 'reason' ) : false ); - $wgOut->addHTML( Xml::buildForm( $form, 'restrictuser-submit' ) ); - $wgOut->addHTML( "" ); - } - - public static function doNamespaceRestriction( $uid, $user ) { - global $wgUser, $wgRequest; - $r = new UserRestriction(); - $r->setType( UserRestriction::NAMESPACE_RESTRICTION ); - $r->setNamespace( $wgRequest->getVal( 'namespace' ) ); - $r->setSubjectId( $uid ); - $r->setSubjectText( $user ); - $r->setBlockerId( $wgUser->getId() ); - $r->setBlockerText( $wgUser->getName() ); - $r->setReason( $wgRequest->getVal( 'reason' ) ); - $r->setExpiry( UserRestriction::convertExpiry( $wgRequest->getVal( 'expiry' ) ) ); - $r->setTimestamp( wfTimestampNow( TS_MW ) ); - $r->commit(); - $logExpiry = $wgRequest->getVal( 'expiry' ) ? $wgRequest->getVal( 'expiry' ) : Block::infinity(); - $l = new LogPage( 'restrict' ); - $l->addEntry( 'restrict', Title::makeTitle( NS_USER, $user ), $r->getReason(), - array( $r->getType(), $r->getNamespace(), $logExpiry ) ); - } -} -- 2.20.1