mirror of
https://gerrit.wikimedia.org/r/mediawiki/extensions/Linter
synced 2024-11-27 09:10:05 +00:00
Update lint errors via the job queue
The job queue will allow us to have better flood control and rate limiting instead of trying to do all the database writes as soon as parsoid contacts MediaWiki. On the downside, this means it may take longer for changes to be reflected in the database and to users, but we already have no promise for that, so it seems okay. Note that if you don't have a job queue runner set up, you'll need to run the runJobs.php script every time to have the jobs execute. Change-Id: I25fd54734aca4dab09711e7f6aee027654931300
This commit is contained in:
parent
ad14ea3d98
commit
9ecf62ead3
|
@ -14,6 +14,7 @@
|
|||
"MediaWiki\\Linter\\LintError": "includes/LintError.php",
|
||||
"MediaWiki\\Linter\\ApiRecordLint": "includes/ApiRecordLint.php",
|
||||
"MediaWiki\\Linter\\ApiQueryLintErrors": "includes/ApiQueryLintErrors.php",
|
||||
"MediaWiki\\Linter\\RecordLintJob": "includes/RecordLintJob.php",
|
||||
"MediaWiki\\Linter\\SpecialLintErrors": "includes/SpecialLintErrors.php",
|
||||
"MediaWiki\\Linter\\LintErrorsPager": "includes/LintErrorsPager.php"
|
||||
},
|
||||
|
@ -33,6 +34,9 @@
|
|||
"SpecialPages": {
|
||||
"LintErrors": "MediaWiki\\Linter\\SpecialLintErrors"
|
||||
},
|
||||
"JobClasses": {
|
||||
"RecordLintJob": "MediaWiki\\Linter\\RecordLintJob"
|
||||
},
|
||||
"ResourceModules": {
|
||||
"ext.linter.edit": {
|
||||
"scripts": "ext.linter.edit.js",
|
||||
|
|
|
@ -23,6 +23,7 @@ namespace MediaWiki\Linter;
|
|||
use ApiBase;
|
||||
use FormatJson;
|
||||
use IPSet\IPSet;
|
||||
use JobQueueGroup;
|
||||
use Title;
|
||||
|
||||
/**
|
||||
|
@ -61,15 +62,15 @@ class ApiRecordLint extends ApiBase {
|
|||
if ( isset( $info['templateInfo'] ) && $info['templateInfo'] ) {
|
||||
$info['params']['templateInfo'] = $info['templateInfo'];
|
||||
}
|
||||
$errors[] = new LintError(
|
||||
$info['type'],
|
||||
$info['params']
|
||||
);
|
||||
$errors[] = $info;
|
||||
}
|
||||
|
||||
$lintDb = new Database( $title->getArticleID() );
|
||||
$result = $lintDb->setForPage( $errors );
|
||||
$this->getResult()->addValue( $this->getModuleName(), 'success', $result );
|
||||
$job = new RecordLintJob( $title, [
|
||||
'errors' => $errors,
|
||||
'revision' => $params['revision'],
|
||||
] );
|
||||
JobQueueGroup::singleton()->push( $job );
|
||||
$this->getResult()->addValue( $this->getModuleName(), 'success', true );
|
||||
}
|
||||
|
||||
public function isInternal() {
|
||||
|
|
54
includes/RecordLintJob.php
Normal file
54
includes/RecordLintJob.php
Normal file
|
@ -0,0 +1,54 @@
|
|||
<?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 Title;
|
||||
|
||||
class RecordLintJob extends Job {
|
||||
/**
|
||||
* RecordLintJob constructor.
|
||||
* @param Title $title
|
||||
* @param array $params
|
||||
*/
|
||||
public function __construct( Title $title, array $params ) {
|
||||
parent::__construct( 'RecordLintJob', $title, $params );
|
||||
}
|
||||
|
||||
public function run() {
|
||||
if ( $this->title->getLatestRevID() != $this->params['revision'] ) {
|
||||
// Outdated now, let a later job handle it
|
||||
return true;
|
||||
}
|
||||
|
||||
$errors = [];
|
||||
foreach ( $this->params['errors'] as $error ) {
|
||||
$errors[] = new LintError(
|
||||
$error['type'],
|
||||
$error['params']
|
||||
);
|
||||
}
|
||||
$lintDb = new Database( $this->title->getArticleID() );
|
||||
$lintDb->setForPage( $errors );
|
||||
return true;
|
||||
}
|
||||
|
||||
}
|
Loading…
Reference in a new issue