3 * Implements Special:AutoblockList
5 * This program is free software; you can redistribute it and/or modify
6 * it under the terms of the GNU General Public License as published by
7 * the Free Software Foundation; either version 2 of the License, or
8 * (at your option) any later version.
10 * This program is distributed in the hope that it will be useful,
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 * GNU General Public License for more details.
15 * You should have received a copy of the GNU General Public License along
16 * with this program; if not, write to the Free Software Foundation, Inc.,
17 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
18 * http://www.gnu.org/copyleft/gpl.html
21 * @ingroup SpecialPage
25 * A special page that lists autoblocks
28 * @ingroup SpecialPage
30 class SpecialAutoblockList
extends SpecialPage
{
32 function __construct() {
33 parent
::__construct( 'AutoblockList' );
37 * Main execution point
39 * @param string $par Title fragment
41 public function execute( $par ) {
43 $this->outputHeader();
44 $out = $this->getOutput();
45 $out->setPageTitle( $this->msg( 'autoblocklist' ) );
46 $this->addHelpLink( 'Autoblock' );
47 $out->addModuleStyles( [ 'mediawiki.special' ] );
49 # setup BlockListPager here to get the actual default Limit
50 $pager = $this->getBlockListPager();
52 # Just show the block list
55 'type' => 'limitselect',
56 'label-message' => 'table_pager_limit_label',
57 'options' => $pager->getLimitSelectList(),
59 'default' => $pager->getLimit(),
63 $context = new DerivativeContext( $this->getContext() );
64 $context->setTitle( $this->getPageTitle() ); // Remove subpage
65 $form = HTMLForm
::factory( 'ooui', $fields, $context );
66 $form->setMethod( 'get' )
67 ->setFormIdentifier( 'blocklist' )
68 ->setWrapperLegendMsg( 'autoblocklist-legend' )
69 ->setSubmitTextMsg( 'autoblocklist-submit' )
71 ->displayForm( false );
73 $this->showTotal( $pager );
74 $this->showList( $pager );
78 * Setup a new BlockListPager instance.
79 * @return BlockListPager
81 protected function getBlockListPager() {
83 'ipb_parent_block_id IS NOT NULL'
85 # Is the user allowed to see hidden blocks?
86 if ( !$this->getUser()->isAllowed( 'hideuser' ) ) {
87 $conds['ipb_deleted'] = 0;
90 return new BlockListPager( $this, $conds );
94 * Show total number of autoblocks on top of the table
96 * @param BlockListPager $pager The BlockListPager instance for this page
98 protected function showTotal( BlockListPager
$pager ) {
99 $out = $this->getOutput();
101 Html
::rawElement( 'div', [ 'style' => 'font-weight: bold;' ],
102 $this->msg( 'autoblocklist-total-autoblocks', $pager->getTotalAutoblocks() )->parse() )
108 * Show the list of blocked accounts matching the actual filter.
109 * @param BlockListPager $pager The BlockListPager instance for this page
111 protected function showList( BlockListPager
$pager ) {
112 $out = $this->getOutput();
114 # Check for other blocks, i.e. global/tor blocks
115 $otherAutoblockLink = [];
116 Hooks
::run( 'OtherAutoblockLogLink', [ &$otherAutoblockLink ] );
118 # Show additional header for the local block only when other blocks exists.
119 # Not necessary in a standard installation without such extensions enabled
120 if ( count( $otherAutoblockLink ) ) {
122 Html
::rawElement( 'h2', [], $this->msg( 'autoblocklist-localblocks',
123 $pager->getNumRows() )->parse() )
128 if ( $pager->getNumRows() ) {
129 $out->addParserOutputContent( $pager->getFullOutput() );
131 $out->addWikiMsg( 'autoblocklist-empty' );
134 if ( count( $otherAutoblockLink ) ) {
139 $this->msg( 'autoblocklist-otherblocks', count( $otherAutoblockLink ) )->parse()
143 foreach ( $otherAutoblockLink as $link ) {
144 $list .= Html
::rawElement( 'li', [], $link ) . "\n";
149 [ 'class' => 'mw-autoblocklist-otherblocks' ],
156 protected function getGroupName() {