3 * Implements Special:Protectedpages
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 protected pages
27 * @ingroup SpecialPage
29 class SpecialProtectedpages
extends SpecialPage
{
30 protected $IdLevel = 'level';
31 protected $IdType = 'type';
33 public function __construct() {
34 parent
::__construct( 'Protectedpages' );
37 public function execute( $par ) {
39 $this->outputHeader();
40 $this->getOutput()->addModuleStyles( 'mediawiki.special' );
42 $request = $this->getRequest();
43 $type = $request->getVal( $this->IdType
);
44 $level = $request->getVal( $this->IdLevel
);
45 $sizetype = $request->getVal( 'size-mode' );
46 $size = $request->getIntOrNull( 'size' );
47 $ns = $request->getIntOrNull( 'namespace' );
48 $indefOnly = $request->getBool( 'indefonly' ) ?
1 : 0;
49 $cascadeOnly = $request->getBool( 'cascadeonly' ) ?
1 : 0;
50 $noRedirect = $request->getBool( 'noredirect' ) ?
1 : 0;
52 $pager = new ProtectedPagesPager(
63 $this->getLinkRenderer()
66 $this->getOutput()->addHTML( $this->showOptions(
77 if ( $pager->getNumRows() ) {
78 $this->getOutput()->addParserOutputContent( $pager->getFullOutput() );
80 $this->getOutput()->addWikiMsg( 'protectedpagesempty' );
85 * @param int $namespace
86 * @param string $type Restriction type
87 * @param string $level Restriction level
88 * @param string $sizetype "min" or "max"
90 * @param bool $indefOnly Only indefinite protection
91 * @param bool $cascadeOnly Only cascading protection
92 * @param bool $noRedirect Don't show redirects
93 * @return string Input form
95 protected function showOptions( $namespace, $type = 'edit', $level, $sizetype,
96 $size, $indefOnly, $cascadeOnly, $noRedirect
100 'class' => 'HTMLSelectNamespace',
101 'name' => 'namespace',
103 'cssclass' => 'namespaceselector',
104 'selected' => $namespace,
106 'label' => $this->msg( 'namespace' )->text(),
108 'typemenu' => $this->getTypeMenu( $type ),
109 'levelmenu' => $this->getLevelMenu( $level ),
112 'label' => $this->msg( 'protectedpages-indef' )->text(),
113 'name' => 'indefonly',
115 'value' => $indefOnly
119 'label' => $this->msg( 'protectedpages-cascade' )->text(),
120 'name' => 'cascadeonly',
121 'id' => 'cascadeonly',
122 'value' => $cascadeOnly
126 'label' => $this->msg( 'protectedpages-noredirect' )->text(),
127 'name' => 'noredirect',
128 'id' => 'noredirect',
129 'value' => $noRedirect,
132 'class' => 'HTMLSizeFilterField',
136 $htmlForm = new HTMLForm( $formDescriptor, $this->getContext() );
139 ->setWrapperLegendMsg( 'protectedpages' )
140 ->setSubmitText( $this->msg( 'protectedpages-submit' )->text() );
142 return $htmlForm->prepareForm()->getHTML( false );
146 * Creates the input label of the restriction type
147 * @param string $pr_type Protection type
150 protected function getTypeMenu( $pr_type ) {
151 $m = []; // Temporary array
154 // First pass to load the log names
155 foreach ( Title
::getFilteredRestrictionTypes( true ) as $type ) {
156 // Messages: restriction-edit, restriction-move, restriction-create, restriction-upload
157 $text = $this->msg( "restriction-$type" )->text();
161 // Third pass generates sorted XHTML content
162 foreach ( $m as $text => $type ) {
163 $options[$text] = $type;
168 'options' => $options,
170 'label' => $this->msg( 'restriction-type' )->text(),
171 'name' => $this->IdType
,
172 'id' => $this->IdType
,
177 * Creates the input label of the restriction level
178 * @param string $pr_level Protection level
181 protected function getLevelMenu( $pr_level ) {
183 $m = [ $this->msg( 'restriction-level-all' )->text() => 0 ];
186 // First pass to load the log names
187 foreach ( $this->getConfig()->get( 'RestrictionLevels' ) as $type ) {
188 // Messages used can be 'restriction-level-sysop' and 'restriction-level-autoconfirmed'
189 if ( $type != '' && $type != '*' ) {
190 $text = $this->msg( "restriction-level-$type" )->text();
195 // Third pass generates sorted XHTML content
196 foreach ( $m as $text => $type ) {
197 $options[$text] = $type;
202 'options' => $options,
203 'value' => $pr_level,
204 'label' => $this->msg( 'restriction-level' )->text(),
205 'name' => $this->IdLevel
,
206 'id' => $this->IdLevel
210 protected function getGroupName() {
211 return 'maintenance';