composer: * mediawiki/mediawiki-codesniffer: 36.0.0 → 37.0.0 The following sniffs now pass and were enabled: * Generic.ControlStructures.InlineControlStructure * MediaWiki.PHPUnit.AssertCount.NotUsed npm: * svgo: 2.3.0 → 2.3.1 * https://npmjs.com/advisories/1754 (CVE-2021-33587) Change-Id: I2a9bbee2fecbf7259876d335f565ece4b3622426
170 lines
4.5 KiB
PHP
170 lines
4.5 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
|
|
* @ingroup Cache Parser
|
|
*/
|
|
|
|
namespace MediaWiki\Parser;
|
|
|
|
use BagOStuff;
|
|
use IBufferingStatsdDataFactory;
|
|
use MediaWiki\Config\ServiceOptions;
|
|
use MediaWiki\HookContainer\HookContainer;
|
|
use MediaWiki\Json\JsonCodec;
|
|
use MediaWiki\Page\WikiPageFactory;
|
|
use ParserCache;
|
|
use Psr\Log\LoggerInterface;
|
|
use TitleFactory;
|
|
use WANObjectCache;
|
|
|
|
/**
|
|
* Returns an instance of the ParserCache by its name.
|
|
* @since 1.36
|
|
* @package MediaWiki\Parser
|
|
*/
|
|
class ParserCacheFactory {
|
|
|
|
/** @var string name of ParserCache for the default parser */
|
|
public const DEFAULT_NAME = 'pcache';
|
|
|
|
/** @var BagOStuff */
|
|
private $parserCacheBackend;
|
|
|
|
/** @var WANObjectCache */
|
|
private $revisionOutputCacheBackend;
|
|
|
|
/** @var HookContainer */
|
|
private $hookContainer;
|
|
|
|
/** @var JsonCodec */
|
|
private $jsonCodec;
|
|
|
|
/** @var IBufferingStatsdDataFactory */
|
|
private $stats;
|
|
|
|
/** @var LoggerInterface */
|
|
private $logger;
|
|
|
|
/** @var TitleFactory */
|
|
private $titleFactory;
|
|
|
|
/** @var WikiPageFactory */
|
|
private $wikiPageFactory;
|
|
|
|
/** @var ParserCache[] */
|
|
private $parserCaches = [];
|
|
|
|
/** @var RevisionOutputCache[] */
|
|
private $revisionOutputCaches = [];
|
|
|
|
/** @var ServiceOptions */
|
|
private $options;
|
|
|
|
/**
|
|
* @internal
|
|
*/
|
|
public const CONSTRUCTOR_OPTIONS = [
|
|
'ParserCacheUseJson', // Temporary feature flag, remove before 1.36 is released.
|
|
'CacheEpoch',
|
|
'OldRevisionParserCacheExpireTime',
|
|
];
|
|
|
|
/**
|
|
* @param BagOStuff $parserCacheBackend
|
|
* @param WANObjectCache $revisionOutputCacheBackend
|
|
* @param HookContainer $hookContainer
|
|
* @param JsonCodec $jsonCodec
|
|
* @param IBufferingStatsdDataFactory $stats
|
|
* @param LoggerInterface $logger
|
|
* @param ServiceOptions $options
|
|
* @param TitleFactory $titleFactory
|
|
* @param WikiPageFactory $wikiPageFactory
|
|
*/
|
|
public function __construct(
|
|
BagOStuff $parserCacheBackend,
|
|
WANObjectCache $revisionOutputCacheBackend,
|
|
HookContainer $hookContainer,
|
|
JsonCodec $jsonCodec,
|
|
IBufferingStatsdDataFactory $stats,
|
|
LoggerInterface $logger,
|
|
ServiceOptions $options,
|
|
TitleFactory $titleFactory,
|
|
WikiPageFactory $wikiPageFactory
|
|
) {
|
|
$this->parserCacheBackend = $parserCacheBackend;
|
|
$this->revisionOutputCacheBackend = $revisionOutputCacheBackend;
|
|
$this->hookContainer = $hookContainer;
|
|
$this->jsonCodec = $jsonCodec;
|
|
$this->stats = $stats;
|
|
$this->logger = $logger;
|
|
|
|
$options->assertRequiredOptions( self::CONSTRUCTOR_OPTIONS );
|
|
$this->options = $options;
|
|
$this->titleFactory = $titleFactory;
|
|
$this->wikiPageFactory = $wikiPageFactory;
|
|
}
|
|
|
|
/**
|
|
* Get a ParserCache instance by $name.
|
|
* @param string $name
|
|
* @return ParserCache
|
|
*/
|
|
public function getParserCache( string $name ): ParserCache {
|
|
if ( !isset( $this->parserCaches[$name] ) ) {
|
|
$this->logger->debug( "Creating ParserCache instance for {$name}" );
|
|
$cache = new ParserCache(
|
|
$name,
|
|
$this->parserCacheBackend,
|
|
$this->options->get( 'CacheEpoch' ),
|
|
$this->hookContainer,
|
|
$this->jsonCodec,
|
|
$this->stats,
|
|
$this->logger,
|
|
$this->titleFactory,
|
|
$this->wikiPageFactory,
|
|
$this->options->get( 'ParserCacheUseJson' )
|
|
);
|
|
|
|
$this->parserCaches[$name] = $cache;
|
|
}
|
|
return $this->parserCaches[$name];
|
|
}
|
|
|
|
/**
|
|
* Get a RevisionOutputCache instance by $name.
|
|
* @param string $name
|
|
* @return RevisionOutputCache
|
|
*/
|
|
public function getRevisionOutputCache( string $name ): RevisionOutputCache {
|
|
if ( !isset( $this->revisionOutputCaches[$name] ) ) {
|
|
$this->logger->debug( "Creating RevisionOutputCache instance for {$name}" );
|
|
$cache = new RevisionOutputCache(
|
|
$name,
|
|
$this->revisionOutputCacheBackend,
|
|
$this->options->get( 'OldRevisionParserCacheExpireTime' ),
|
|
$this->options->get( 'CacheEpoch' ),
|
|
$this->jsonCodec,
|
|
$this->stats,
|
|
$this->logger
|
|
);
|
|
|
|
$this->revisionOutputCaches[$name] = $cache;
|
|
}
|
|
return $this->revisionOutputCaches[$name];
|
|
}
|
|
}
|