wiki.techinc.nl/includes/parser/Parsoid/Config/PageConfig.php
Thiemo Kreuz e23b070b45 Make use of ?? and ?: operators where it makes sense
Change-Id: I1d9d62d80b17d1a05222c6e82f631cb801c311a8
2022-08-04 21:43:12 +02:00

237 lines
6.4 KiB
PHP

<?php
/**
* Copyright (C) 2011-2022 Wikimedia Foundation and others.
*
* 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.
*/
namespace MediaWiki\Parser\Parsoid\Config;
use Language;
use MediaWiki\MediaWikiServices;
use MediaWiki\Revision\RevisionRecord;
use MediaWiki\Revision\SlotRecord;
use MediaWiki\Revision\SlotRoleHandler;
use ParserOptions;
use Title;
use Wikimedia\Parsoid\Config\PageConfig as IPageConfig;
use Wikimedia\Parsoid\Config\PageContent as IPageContent;
/**
* Page-level configuration interface for Parsoid
*
* @todo We should probably deprecate ParserOptions somehow, using a version of
* this directly instead.
* @since 1.39
*/
class PageConfig extends IPageConfig {
/** @var ParserOptions */
private $parserOptions;
/** @var SlotRoleHandler */
private $slotRoleHandler;
/** @var Title */
private $title;
/** @var ?RevisionRecord */
private $revision;
/** @var string|null */
private $pagelanguage;
/** @var string|null */
private $pagelanguageDir;
/**
* @param ParserOptions $parserOptions
* @param SlotRoleHandler $slotRoleHandler
* @param Title $title Title being parsed
* @param ?RevisionRecord $revision
* @param ?string $pagelanguage
* @param ?string $pagelanguageDir
*/
public function __construct(
ParserOptions $parserOptions,
SlotRoleHandler $slotRoleHandler,
Title $title,
?RevisionRecord $revision = null,
?string $pagelanguage = null,
?string $pagelanguageDir = null
) {
$this->parserOptions = $parserOptions;
$this->slotRoleHandler = $slotRoleHandler;
$this->title = $title;
$this->revision = $revision;
$this->pagelanguage = $pagelanguage;
$this->pagelanguageDir = $pagelanguageDir;
}
/**
* Get content model
* @return string
*/
public function getContentModel(): string {
// @todo Check just the main slot, or all slots, or what?
$rev = $this->getRevision();
if ( $rev ) {
$content = $rev->getContent( SlotRecord::MAIN );
if ( $content ) {
return $content->getModel();
} else {
// The page does have a content model but we can't see it. Returning the
// default model is not really correct. But we can't see the content either
// so it won't matter much what we do here.
return $this->slotRoleHandler->getDefaultModel( $this->title );
}
} else {
return $this->slotRoleHandler->getDefaultModel( $this->title );
}
}
public function hasLintableContentModel(): bool {
// @todo Check just the main slot, or all slots, or what?
$content = $this->getRevisionContent();
$model = $content ? $content->getModel( SlotRecord::MAIN ) : null;
return $content && ( $model === CONTENT_MODEL_WIKITEXT || $model === 'proofread-page' );
}
/** @inheritDoc */
public function getTitle(): string {
return $this->title->getPrefixedText();
}
/** @inheritDoc */
public function getNs(): int {
return $this->title->getNamespace();
}
/** @inheritDoc */
public function getPageId(): int {
return $this->title->getArticleID();
}
/** @inheritDoc */
public function getPageLanguage(): string {
return $this->pagelanguage ??
$this->title->getPageLanguage()->getCode();
}
/**
* Helper function: get the Language object corresponding to
* PageConfig::getPageLanguage()
* @return Language
*/
private function getPageLanguageObject(): Language {
return $this->pagelanguage ?
MediaWikiServices::getInstance()->getLanguageFactory()
->getLanguage( $this->pagelanguage ) :
$this->title->getPageLanguage();
}
/** @inheritDoc */
public function getPageLanguageDir(): string {
return $this->pagelanguageDir ??
$this->getPageLanguageObject()->getDir();
}
/**
* @return ParserOptions
*/
public function getParserOptions(): ParserOptions {
return $this->parserOptions;
}
/**
* Use ParserOptions::getTemplateCallback() to fetch the correct
* (usually latest) RevisionRecord for the given title.
*
* @param Title $title
* @return ?RevisionRecord
*/
public function fetchRevisionRecordOfTemplate( Title $title ): ?RevisionRecord {
// See Parser::fetchTemplateAndTitle(), but stateless
// (Parsoid will track dependencies, etc, itself.)
// The callback defaults to Parser::statelessFetchTemplate()
$templateCb = $this->parserOptions->getTemplateCallback();
$stuff = $templateCb( $title, $this );
return $stuff['revision-record'] ?? null;
}
/**
* @return ?RevisionRecord
*/
private function getRevision(): ?RevisionRecord {
return $this->revision;
}
/** @inheritDoc */
public function getRevisionId(): ?int {
$rev = $this->getRevision();
return $rev ? $rev->getId() : null;
}
/** @inheritDoc */
public function getParentRevisionId(): ?int {
$rev = $this->getRevision();
return $rev ? $rev->getParentId() : null;
}
/** @inheritDoc */
public function getRevisionTimestamp(): ?string {
$rev = $this->getRevision();
return $rev ? $rev->getTimestamp() : null;
}
/** @inheritDoc */
public function getRevisionUser(): ?string {
$rev = $this->getRevision();
$user = $rev ? $rev->getUser() : null;
return $user ? $user->getName() : null;
}
/** @inheritDoc */
public function getRevisionUserId(): ?int {
$rev = $this->getRevision();
$user = $rev ? $rev->getUser() : null;
return $user ? $user->getId() : null;
}
/** @inheritDoc */
public function getRevisionSha1(): ?string {
$rev = $this->getRevision();
if ( $rev ) {
// This matches what the Parsoid/JS gets from the API
// FIXME: Maybe we don't need to do this in the future?
return \Wikimedia\base_convert( $rev->getSha1(), 36, 16, 40 );
} else {
return null;
}
}
/** @inheritDoc */
public function getRevisionSize(): ?int {
$rev = $this->getRevision();
return $rev ? $rev->getSize() : null;
}
/** @inheritDoc */
public function getRevisionContent(): ?IPageContent {
$rev = $this->getRevision();
return $rev ? new PageContent( $rev ) : null;
}
}