2016-10-13 08:14:18 +00:00
|
|
|
<?php
|
|
|
|
/**
|
|
|
|
* This program is free software; you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU General Public License as published by
|
|
|
|
* the Free Software Foundation; either version 2 of the License, or
|
|
|
|
* (at your option) any later version.
|
|
|
|
*
|
|
|
|
* This program is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License along
|
|
|
|
* with this program; if not, write to the Free Software Foundation, Inc.,
|
|
|
|
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
|
|
* http://www.gnu.org/copyleft/gpl.html
|
|
|
|
*
|
|
|
|
* @file
|
|
|
|
*/
|
|
|
|
|
|
|
|
namespace MediaWiki\Linter;
|
|
|
|
|
|
|
|
use Html;
|
2020-01-10 10:06:26 +00:00
|
|
|
use HTMLForm;
|
2017-04-28 20:04:45 +00:00
|
|
|
use MediaWiki\MediaWikiServices;
|
2016-10-13 08:14:18 +00:00
|
|
|
use SpecialPage;
|
2021-09-30 23:20:01 +00:00
|
|
|
use Title;
|
2016-10-13 08:14:18 +00:00
|
|
|
|
|
|
|
class SpecialLintErrors extends SpecialPage {
|
|
|
|
|
2021-04-06 16:54:41 +00:00
|
|
|
/**
|
2021-09-30 23:20:01 +00:00
|
|
|
* @var string|null
|
2021-04-06 16:54:41 +00:00
|
|
|
*/
|
2016-10-13 08:14:18 +00:00
|
|
|
private $category;
|
|
|
|
|
|
|
|
public function __construct() {
|
|
|
|
parent::__construct( 'LintErrors' );
|
|
|
|
}
|
|
|
|
|
2021-04-06 16:54:41 +00:00
|
|
|
/**
|
|
|
|
* @param int|null $ns
|
|
|
|
* @param bool $nsinvert
|
|
|
|
*/
|
2019-08-25 03:47:40 +00:00
|
|
|
protected function showNamespaceFilterForm( $ns, $nsinvert ) {
|
2017-04-14 03:49:21 +00:00
|
|
|
$fields = [
|
|
|
|
'namespace' => [
|
|
|
|
'type' => 'namespaceselect',
|
|
|
|
'name' => 'namespace',
|
|
|
|
'label-message' => 'linter-form-namespace',
|
|
|
|
'default' => $ns,
|
|
|
|
'id' => 'namespace',
|
|
|
|
'all' => '',
|
|
|
|
'cssclass' => 'namespaceselector',
|
|
|
|
],
|
2019-08-25 03:47:40 +00:00
|
|
|
'nsinvert' => [
|
|
|
|
'type' => 'check',
|
|
|
|
'name' => 'invert',
|
|
|
|
'label-message' => 'invert',
|
|
|
|
'default' => $nsinvert,
|
|
|
|
'tooltip' => 'invert',
|
|
|
|
],
|
2022-03-04 20:21:04 +00:00
|
|
|
'titleprefix' => [
|
|
|
|
'type' => 'text',
|
|
|
|
'name' => 'titleprefix',
|
|
|
|
'label-message' => 'linter-form-title-prefix',
|
|
|
|
'default' => '',
|
|
|
|
'id' => 'titleprefix',
|
|
|
|
'size' => 255,
|
|
|
|
],
|
2017-04-14 03:49:21 +00:00
|
|
|
];
|
|
|
|
$form = HTMLForm::factory( 'ooui', $fields, $this->getContext() );
|
|
|
|
$form->setWrapperLegend( true );
|
2017-10-05 03:16:26 +00:00
|
|
|
$form->addHeaderText( $this->msg( "linter-category-{$this->category}-desc" )->parse() );
|
2017-04-14 03:49:21 +00:00
|
|
|
$form->setMethod( 'get' );
|
|
|
|
$form->prepareForm()->displayForm( false );
|
|
|
|
}
|
|
|
|
|
2021-09-30 23:20:01 +00:00
|
|
|
/**
|
|
|
|
*/
|
|
|
|
protected function showPageNameFilterForm() {
|
|
|
|
$fields = [
|
|
|
|
'pagename' => [
|
2022-02-12 20:05:23 +00:00
|
|
|
'type' => 'title',
|
2021-09-30 23:20:01 +00:00
|
|
|
'name' => 'pagename',
|
2022-01-11 17:44:01 +00:00
|
|
|
'label-message' => 'linter-pager-title-header',
|
2022-02-12 20:05:23 +00:00
|
|
|
'exists' => true,
|
|
|
|
'required' => false,
|
2021-09-30 23:20:01 +00:00
|
|
|
]
|
|
|
|
];
|
|
|
|
$form = HTMLForm::factory( 'ooui', $fields, $this->getContext() );
|
|
|
|
$form->setWrapperLegend( true );
|
|
|
|
$form->setMethod( 'get' );
|
|
|
|
$form->prepareForm()->displayForm( false );
|
|
|
|
}
|
|
|
|
|
2021-04-06 16:54:41 +00:00
|
|
|
/**
|
|
|
|
* @param string|null $par
|
|
|
|
*/
|
2016-10-13 08:14:18 +00:00
|
|
|
public function execute( $par ) {
|
2022-01-10 20:21:20 +00:00
|
|
|
$this->setHeaders();
|
|
|
|
$this->outputHeader();
|
|
|
|
|
2022-02-09 15:33:48 +00:00
|
|
|
// If the request contains a `pagename` parameter, then the user entered a pagename
|
2021-09-30 23:20:01 +00:00
|
|
|
// and pressed the Submit button to display of all lints for a single page.
|
2022-02-09 15:33:48 +00:00
|
|
|
$params = $this->getRequest()->getQueryValues();
|
|
|
|
if ( $par === null && isset( $params['pagename'] ) ) {
|
|
|
|
// Use getText to ensure a string val
|
|
|
|
$pageName = $this->getRequest()->getText( 'pagename', '' );
|
|
|
|
|
2021-09-30 23:20:01 +00:00
|
|
|
$out = $this->getOutput();
|
2022-01-10 20:16:04 +00:00
|
|
|
$out->setPageTitle( $this->msg( 'linterrors-subpage', $pageName ) );
|
2021-09-30 23:20:01 +00:00
|
|
|
|
|
|
|
$title = Title::newFromText( $pageName );
|
|
|
|
if ( $title !== null ) {
|
|
|
|
$pageArticleID = $title->getArticleID();
|
|
|
|
if ( $pageArticleID !== 0 ) {
|
|
|
|
$ns = $title->getNamespace();
|
|
|
|
$catManager = new CategoryManager();
|
|
|
|
$pager = new LintErrorsPager(
|
|
|
|
$this->getContext(), null, $this->getLinkRenderer(),
|
|
|
|
$catManager, $ns, false, $pageArticleID
|
|
|
|
);
|
|
|
|
$out->addParserOutput( $pager->getFullOutput() );
|
|
|
|
return;
|
|
|
|
}
|
2022-02-09 15:33:48 +00:00
|
|
|
// No $pageArticleID or no $title go through
|
2021-09-30 23:20:01 +00:00
|
|
|
}
|
|
|
|
|
2022-02-09 15:33:48 +00:00
|
|
|
$out->addHTML(
|
|
|
|
Html::element( 'span', [ 'class' => 'error' ],
|
|
|
|
$this->msg( "linter-invalid-title" )->text() )
|
|
|
|
);
|
2021-09-30 23:20:01 +00:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2016-12-15 01:07:40 +00:00
|
|
|
$catManager = new CategoryManager();
|
|
|
|
if ( in_array( $par, $catManager->getVisibleCategories() ) ) {
|
2016-10-13 08:14:18 +00:00
|
|
|
$this->category = $par;
|
|
|
|
}
|
|
|
|
|
|
|
|
if ( !$this->category ) {
|
|
|
|
$this->addHelpLink( 'Help:Extension:Linter' );
|
2016-12-15 01:07:40 +00:00
|
|
|
$this->showCategoryListings( $catManager );
|
2016-10-13 08:14:18 +00:00
|
|
|
} else {
|
|
|
|
$this->addHelpLink( "Help:Extension:Linter/{$this->category}" );
|
|
|
|
$out = $this->getOutput();
|
|
|
|
$out->setPageTitle(
|
|
|
|
$this->msg( 'linterrors-subpage',
|
|
|
|
$this->msg( "linter-category-{$this->category}" )->text()
|
|
|
|
)
|
|
|
|
);
|
|
|
|
$out->addBacklinkSubtitle( $this->getPageTitle() );
|
2017-04-14 03:49:21 +00:00
|
|
|
$ns = $this->getRequest()->getIntOrNull( 'namespace' );
|
2019-08-25 03:47:40 +00:00
|
|
|
$nsinvert = $this->getRequest()->getBool( 'invert' );
|
2022-03-04 20:21:04 +00:00
|
|
|
|
|
|
|
$titlePrefix = $this->getRequest()->getText( 'titleprefix', '' );
|
|
|
|
// SQL injection risk is handled in LintErrorsPager.php, getQueryInfo( using buildLike( db function
|
|
|
|
|
2019-08-25 03:47:40 +00:00
|
|
|
$this->showNamespaceFilterForm( $ns, $nsinvert );
|
2016-10-13 08:14:18 +00:00
|
|
|
$pager = new LintErrorsPager(
|
2016-12-15 01:07:40 +00:00
|
|
|
$this->getContext(), $this->category, $this->getLinkRenderer(),
|
2022-03-04 20:21:04 +00:00
|
|
|
$catManager, $ns, $nsinvert, null, $titlePrefix
|
2016-10-13 08:14:18 +00:00
|
|
|
);
|
|
|
|
$out->addParserOutput( $pager->getFullOutput() );
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-04-26 22:11:23 +00:00
|
|
|
/**
|
|
|
|
* @param string $priority
|
|
|
|
* @param int[] $totals name => count
|
|
|
|
* @param string[] $categories
|
|
|
|
*/
|
|
|
|
private function displayList( $priority, $totals, array $categories ) {
|
|
|
|
$out = $this->getOutput();
|
|
|
|
$msgName = 'linter-heading-' . $priority . '-priority';
|
|
|
|
$out->addHTML( Html::element( 'h2', [], $this->msg( $msgName )->text() ) );
|
|
|
|
$out->addHTML( $this->buildCategoryList( $categories, $totals ) );
|
|
|
|
}
|
|
|
|
|
2021-09-30 23:20:01 +00:00
|
|
|
/**
|
|
|
|
*/
|
|
|
|
private function displaySearchPage() {
|
|
|
|
$out = $this->getOutput();
|
|
|
|
$out->addHTML( Html::element( 'h2', [],
|
|
|
|
$this->msg( "linter-lints-for-single-page-desc" )->text() ) );
|
|
|
|
$this->showPageNameFilterForm();
|
|
|
|
}
|
|
|
|
|
2021-04-06 16:54:41 +00:00
|
|
|
/**
|
|
|
|
* @param CategoryManager $catManager
|
|
|
|
*/
|
2016-12-15 01:07:40 +00:00
|
|
|
private function showCategoryListings( CategoryManager $catManager ) {
|
2017-04-28 20:04:45 +00:00
|
|
|
$lookup = new TotalsLookup(
|
|
|
|
$catManager,
|
|
|
|
MediaWikiServices::getInstance()->getMainWANObjectCache()
|
|
|
|
);
|
|
|
|
$totals = $lookup->getTotals();
|
2016-12-15 01:07:40 +00:00
|
|
|
|
2017-04-26 22:11:23 +00:00
|
|
|
// Display lint issues by priority
|
|
|
|
$this->displayList( 'high', $totals, $catManager->getHighPriority() );
|
|
|
|
$this->displayList( 'medium', $totals, $catManager->getMediumPriority() );
|
|
|
|
$this->displayList( 'low', $totals, $catManager->getLowPriority() );
|
2021-09-30 23:20:01 +00:00
|
|
|
|
|
|
|
$this->displaySearchPage();
|
2016-12-15 01:07:40 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @param string[] $cats
|
|
|
|
* @param int[] $totals name => count
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
private function buildCategoryList( array $cats, array $totals ) {
|
2016-10-13 08:14:18 +00:00
|
|
|
$linkRenderer = $this->getLinkRenderer();
|
|
|
|
$html = Html::openElement( 'ul' ) . "\n";
|
|
|
|
foreach ( $cats as $cat ) {
|
|
|
|
$html .= Html::rawElement( 'li', [], $linkRenderer->makeKnownLink(
|
|
|
|
$this->getPageTitle( $cat ),
|
|
|
|
$this->msg( "linter-category-$cat" )->text()
|
2017-04-14 08:43:37 +00:00
|
|
|
) . ' ' . Html::element( 'bdi', [],
|
|
|
|
$this->msg( "linter-numerrors" )->numParams( $totals[$cat] )->text()
|
|
|
|
) ) . "\n";
|
2016-10-13 08:14:18 +00:00
|
|
|
}
|
|
|
|
$html .= Html::closeElement( 'ul' );
|
2016-12-15 01:07:40 +00:00
|
|
|
|
|
|
|
return $html;
|
2016-10-13 08:14:18 +00:00
|
|
|
}
|
|
|
|
|
2021-04-06 16:54:41 +00:00
|
|
|
/** @inheritDoc */
|
2016-10-13 08:14:18 +00:00
|
|
|
public function getGroupName() {
|
|
|
|
return 'maintenance';
|
|
|
|
}
|
|
|
|
|
2021-04-06 16:54:41 +00:00
|
|
|
/**
|
|
|
|
* @return string[]
|
|
|
|
*/
|
2016-11-22 09:16:28 +00:00
|
|
|
protected function getSubpagesForPrefixSearch() {
|
|
|
|
return ( new CategoryManager() )->getVisibleCategories();
|
|
|
|
}
|
|
|
|
|
2016-10-13 08:14:18 +00:00
|
|
|
}
|