mirror of
https://gerrit.wikimedia.org/r/mediawiki/extensions/Linter
synced 2024-11-11 16:59:40 +00:00
489fe5a912
I015fbe2ab613619c8805d12bfd397cc08450ef24 falsely assumed these were ending up in logstash already but, unless explicitly asked, logstash doesn't go below "info", regardless of the channel's level. Change-Id: I55884a2535e839ca92d5d679cc4dc7911050f298
93 lines
2.7 KiB
PHP
93 lines
2.7 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 MediaWiki\Content\TextContent;
|
|
use MediaWiki\Deferred\DataUpdate;
|
|
use MediaWiki\Logger\LoggerFactory;
|
|
use MediaWiki\Page\WikiPageFactory;
|
|
use MediaWiki\Parser\Parsoid\ParsoidParser;
|
|
use MediaWiki\Revision\RenderedRevision;
|
|
use MediaWiki\Revision\RevisionRecord;
|
|
use MediaWiki\Revision\SlotRecord;
|
|
|
|
class LintUpdate extends DataUpdate {
|
|
|
|
private ParsoidParser $parsoid;
|
|
private WikiPageFactory $wikiPageFactory;
|
|
private RenderedRevision $renderedRevision;
|
|
|
|
public function __construct(
|
|
ParsoidParser $parsoid,
|
|
WikiPageFactory $wikiPageFactory,
|
|
RenderedRevision $renderedRevision
|
|
) {
|
|
parent::__construct();
|
|
$this->parsoid = $parsoid;
|
|
$this->wikiPageFactory = $wikiPageFactory;
|
|
$this->renderedRevision = $renderedRevision;
|
|
}
|
|
|
|
public function doUpdate() {
|
|
$rev = $this->renderedRevision->getRevision();
|
|
$mainSlot = $rev->getSlot( SlotRecord::MAIN, RevisionRecord::RAW );
|
|
|
|
$page = $this->wikiPageFactory->newFromTitle( $rev->getPage() );
|
|
|
|
if ( $page->getLatest() !== $rev->getId() ) {
|
|
// The given revision is no longer the latest revision.
|
|
return;
|
|
}
|
|
|
|
$content = $mainSlot->getContent();
|
|
if ( !$content instanceof TextContent ) {
|
|
// Linting is only defined for text
|
|
return;
|
|
}
|
|
|
|
$pOptions = $page->makeParserOptions( 'canonical' );
|
|
$pOptions->setUseParsoid();
|
|
|
|
LoggerFactory::getInstance( 'Linter' )->debug(
|
|
'{method}: Parsing {page}',
|
|
[
|
|
'method' => __METHOD__,
|
|
'page' => $page->getTitle()->getPrefixedDBkey(),
|
|
'touched' => $page->getTouched()
|
|
]
|
|
);
|
|
|
|
// Don't update the parser cache, to avoid flooding it.
|
|
// This matches the behavior of RefreshLinksJob.
|
|
// However, unlike RefreshLinksJob, we don't parse if we already
|
|
// have the output in the cache. This avoids duplicating the effort
|
|
// of ParsoidCachePrewarmJob.
|
|
$this->parsoid->parse(
|
|
$content->getText(),
|
|
$rev->getPage(),
|
|
$pOptions,
|
|
true,
|
|
true,
|
|
$rev->getId()
|
|
);
|
|
}
|
|
}
|