mediawiki-extensions-AbuseF.../includes/special/SpecialAbuseFilter.php

151 lines
3.7 KiB
PHP
Raw Normal View History

2008-06-27 06:18:51 +00:00
<?php
class SpecialAbuseFilter extends SpecialPage {
/**
* @var int|string|null The current filter
*/
public $mFilter;
/**
* @var string|null The history ID of the current version
*/
public $mHistoryID;
public function __construct() {
2008-06-27 06:18:51 +00:00
parent::__construct( 'AbuseFilter', 'abusefilter-view' );
}
/**
* @return bool
*/
public function doesWrites() {
return true;
}
/**
* @param string|null $subpage
*/
public function execute( $subpage ) {
$out = $this->getOutput();
$request = $this->getRequest();
$out->addModuleStyles( 'ext.abuseFilter' );
$view = 'AbuseFilterViewList';
2008-06-27 06:18:51 +00:00
$this->setHeaders();
$this->loadParameters( $subpage );
$out->setPageTitle( $this->msg( 'abusefilter-management' ) );
$this->checkPermissions();
if ( $request->getVal( 'result' ) === 'success' ) {
$out->setSubtitle( $this->msg( 'abusefilter-edit-done-subtitle' ) );
$changedFilter = intval( $request->getVal( 'changedfilter' ) );
$changeId = intval( $request->getVal( 'changeid' ) );
$out->wrapWikiMsg( '<p class="success">$1</p>',
[
'abusefilter-edit-done',
$changedFilter,
$changeId,
$this->getLanguage()->formatNum( $changedFilter )
]
);
}
$this->mHistoryID = null;
$pageType = 'home';
$params = explode( '/', $subpage );
// Filter by removing blanks.
foreach ( $params as $index => $param ) {
if ( $param === '' ) {
unset( $params[$index] );
}
}
$params = array_values( $params );
if ( $subpage === 'tools' ) {
$view = 'AbuseFilterViewTools';
$pageType = 'tools';
$out->addHelpLink( 'Extension:AbuseFilter/Rules format' );
}
if ( count( $params ) === 2 && $params[0] === 'revert' && is_numeric( $params[1] ) ) {
$this->mFilter = $params[1];
$view = 'AbuseFilterViewRevert';
$pageType = 'revert';
}
if ( count( $params ) && $params[0] === 'test' ) {
$view = 'AbuseFilterViewTestBatch';
$pageType = 'test';
$out->addHelpLink( 'Extension:AbuseFilter/Rules format' );
}
if ( count( $params ) && $params[0] === 'examine' ) {
$view = 'AbuseFilterViewExamine';
$pageType = 'examine';
$out->addHelpLink( 'Extension:AbuseFilter/Rules format' );
}
if ( !empty( $params[0] ) && ( $params[0] === 'history' || $params[0] === 'log' ) ) {
$pageType = '';
if ( count( $params ) === 1 ) {
$view = 'AbuseFilterViewHistory';
$pageType = 'recentchanges';
} elseif ( count( $params ) === 2 ) {
// Second param is a filter ID
$view = 'AbuseFilterViewHistory';
$pageType = 'recentchanges';
$this->mFilter = $params[1];
} elseif ( count( $params ) === 4 && $params[2] === 'item' ) {
$this->mFilter = $params[1];
$this->mHistoryID = $params[3];
$view = 'AbuseFilterViewEdit';
} elseif ( count( $params ) === 5 && $params[2] === 'diff' ) {
// Special:AbuseFilter/history/<filter>/diff/<oldid>/<newid>
$view = 'AbuseFilterViewDiff';
}
2008-06-27 06:18:51 +00:00
}
if ( is_numeric( $subpage ) || $subpage === 'new' ) {
$this->mFilter = $subpage;
$view = 'AbuseFilterViewEdit';
2009-03-17 14:09:17 +00:00
$pageType = 'edit';
}
if ( $subpage === 'import' ) {
$view = 'AbuseFilterViewImport';
$pageType = 'import';
}
// Links at the top
AbuseFilter::addNavigationLinks(
$this->getContext(), $pageType, $this->getLinkRenderer() );
2008-06-27 09:26:54 +00:00
/** @var AbuseFilterView $v */
$v = new $view( $this, $params );
$v->show();
}
/**
* @param string|null $subpage
*/
public function loadParameters( $subpage ) {
2008-06-27 06:18:51 +00:00
$filter = $subpage;
if ( !is_numeric( $filter ) && $filter !== 'new' ) {
$filter = $this->getRequest()->getIntOrNull( 'wpFilter' );
2008-06-27 06:18:51 +00:00
}
$this->mFilter = $filter;
}
/**
* @return string
*/
protected function getGroupName() {
return 'wiki';
}
}