mediawiki-extensions-Linter/includes/LintUpdate.php
C. Scott Ananian ba41d323f9 LintUpdate: use content handler instead of directly invoking ParsoidParser
We don't need to directly handle the ParsoidParserFactory in the
LintUpdate job; use the existing ContentHandler pathways to reduce
dependencies.

Change-Id: I64a4556a74da4f735a5b562070c21310ecda36d1
2024-09-17 16:44:37 -04:00

92 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\Renderer\ContentParseParams;
use MediaWiki\Content\TextContent;
use MediaWiki\Deferred\DataUpdate;
use MediaWiki\Logger\LoggerFactory;
use MediaWiki\Page\WikiPageFactory;
use MediaWiki\Revision\RenderedRevision;
use MediaWiki\Revision\RevisionRecord;
use MediaWiki\Revision\SlotRecord;
class LintUpdate extends DataUpdate {
private WikiPageFactory $wikiPageFactory;
private RenderedRevision $renderedRevision;
public function __construct(
WikiPageFactory $wikiPageFactory,
RenderedRevision $renderedRevision
) {
parent::__construct();
$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.
$cpoParams = new ContentParseParams(
$rev->getPage(),
$rev->getId(),
$pOptions,
// no need to generate HTML
false,
// XXX no previous output available
null
);
$content->getContentHandler()->getParserOutput( $content, $cpoParams );
}
}