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
99 'namespace' => $this->getNamespaceMenu( $namespace ),
100 'typemenu' => $this->getTypeMenu( $type ),
101 'levelmenu' => $this->getLevelMenu( $level ),
103 'expirycheck' => $this->getExpiryCheck( $indefOnly ),
104 'cascadecheck' => $this->getCascadeCheck( $cascadeOnly ),
105 'redirectcheck' => $this->getRedirectCheck( $noRedirect ),
107 'sizelimit' => $this->getSizeLimit( $sizetype, $size ),
109 $htmlForm = new HTMLForm( $formDescriptor, $this->getContext() );
112 ->setWrapperLegendMsg( 'protectedpages' )
113 ->setSubmitText( $this->msg( 'protectedpages-submit' )->text() );
115 return $htmlForm->prepareForm()->getHTML( false );
119 * Prepare the namespace filter drop-down; standard namespace
120 * selector, sans the MediaWiki namespace
122 * @param string|null $namespace Pre-select namespace
125 protected function getNamespaceMenu( $namespace = null ) {
127 'class' => 'HTMLSelectNamespace',
128 'name' => 'namespace',
130 'cssclass' => 'namespaceselector',
131 'selected' => $namespace,
133 'label' => $this->msg( 'namespace' )->text(),
138 * @param bool $indefOnly
141 protected function getExpiryCheck( $indefOnly ) {
144 'label' => $this->msg( 'protectedpages-indef' )->text(),
145 'name' => 'indefonly',
147 'value' => $indefOnly
152 * @param bool $cascadeOnly
155 protected function getCascadeCheck( $cascadeOnly ) {
158 'label' => $this->msg( 'protectedpages-cascade' )->text(),
159 'name' => 'cascadeonly',
160 'id' => 'cascadeonly',
161 'value' => $cascadeOnly
166 * @param bool $noRedirect
169 protected function getRedirectCheck( $noRedirect ) {
172 'label' => $this->msg( 'protectedpages-noredirect' )->text(),
173 'name' => 'noredirect',
174 'id' => 'noredirect',
175 'value' => $noRedirect,
180 * @param string $sizetype "min" or "max"
184 protected function getSizeLimit( $sizetype, $size ) {
185 $max = $sizetype === 'max';
188 'class' => 'HTMLSizeFilterField',
194 * Creates the input label of the restriction type
195 * @param string $pr_type Protection type
198 protected function getTypeMenu( $pr_type ) {
199 $m = []; // Temporary array
202 // First pass to load the log names
203 foreach ( Title
::getFilteredRestrictionTypes( true ) as $type ) {
204 // Messages: restriction-edit, restriction-move, restriction-create, restriction-upload
205 $text = $this->msg( "restriction-$type" )->text();
209 // Third pass generates sorted XHTML content
210 foreach ( $m as $text => $type ) {
211 $options[$text] = $type;
216 'options' => $options,
218 'label' => $this->msg( 'restriction-type' )->text(),
219 'name' => $this->IdType
,
220 'id' => $this->IdType
,
225 * Creates the input label of the restriction level
226 * @param string $pr_level Protection level
229 protected function getLevelMenu( $pr_level ) {
231 $m = [ $this->msg( 'restriction-level-all' )->text() => 0 ];
234 // First pass to load the log names
235 foreach ( $this->getConfig()->get( 'RestrictionLevels' ) as $type ) {
236 // Messages used can be 'restriction-level-sysop' and 'restriction-level-autoconfirmed'
237 if ( $type != '' && $type != '*' ) {
238 $text = $this->msg( "restriction-level-$type" )->text();
243 // Third pass generates sorted XHTML content
244 foreach ( $m as $text => $type ) {
245 $options[$text] = $type;
250 'options' => $options,
251 'value' => $pr_level,
252 'label' => $this->msg( 'restriction-level' )->text(),
253 'name' => $this->IdLevel
,
254 'id' => $this->IdLevel
258 protected function getGroupName() {
259 return 'maintenance';