mirror of
https://gerrit.wikimedia.org/r/mediawiki/extensions/Linter
synced 2024-12-18 02:40:41 +00:00
6c07b92097
Additional debug logging allows us to verify the upcoming changes in If53841ee583ce in production. Bug: T361013 Change-Id: I261aacc1c9fa6483d88e94424d1f77d861f1a990
94 lines
2.4 KiB
PHP
94 lines
2.4 KiB
PHP
<?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 Job;
|
|
use MediaWiki\Logger\LoggerFactory;
|
|
use MediaWiki\Page\PageReference;
|
|
|
|
class RecordLintJob extends Job {
|
|
private TotalsLookup $totalsLookup;
|
|
private Database $database;
|
|
|
|
/**
|
|
* RecordLintJob constructor.
|
|
* @param PageReference $page
|
|
* @param array $params
|
|
* @param TotalsLookup $totalsLookup
|
|
* @param Database $database
|
|
*/
|
|
public function __construct(
|
|
PageReference $page,
|
|
array $params,
|
|
TotalsLookup $totalsLookup,
|
|
Database $database
|
|
) {
|
|
parent::__construct( 'RecordLintJob', $page, $params );
|
|
$this->totalsLookup = $totalsLookup;
|
|
$this->database = $database;
|
|
}
|
|
|
|
public function run() {
|
|
if ( $this->title->getLatestRevID() != $this->params['revision'] ) {
|
|
// Outdated now, let a later job handle it
|
|
return true;
|
|
}
|
|
|
|
// [ 'id' => LintError ]
|
|
$errors = [];
|
|
foreach ( $this->params['errors'] as $errorInfo ) {
|
|
if ( $errorInfo['type'] === 'inline-media-caption' ) {
|
|
// Drop lints of this type for now
|
|
continue;
|
|
}
|
|
$error = new LintError(
|
|
$errorInfo['type'],
|
|
$errorInfo['location'],
|
|
$errorInfo['params'],
|
|
$errorInfo['dbid']
|
|
);
|
|
// Use unique id as key to get rid of exact dupes
|
|
// (e.g. same category of error in same template)
|
|
$errors[$error->id()] = $error;
|
|
}
|
|
|
|
LoggerFactory::getInstance( 'Linter' )->debug(
|
|
'{method}: Recording {numErrors} errors for {page}',
|
|
[
|
|
'method' => __METHOD__,
|
|
'numErrors' => count( $errors ),
|
|
'page' => $this->title->getPrefixedDBkey()
|
|
]
|
|
);
|
|
|
|
$this->totalsLookup->updateStats(
|
|
$this->database->setForPage(
|
|
$this->title->getArticleID(),
|
|
$this->title->getNamespace(),
|
|
$errors
|
|
)
|
|
);
|
|
|
|
return true;
|
|
}
|
|
|
|
}
|