X-Git-Url: https://git.heureux-cyclage.org/?p=lhc%2Fweb%2Fwiklou.git;a=blobdiff_plain;f=includes%2FServiceWiring.php;h=740377c027733beaf97b4609245e9a8c8b74a75e;hp=78609e56ea418d829681c5fb1feaa15748e5dc61;hb=e390198c4e4be7632b01173e42050061f1cc346a;hpb=178d312eb80718c148e3e5774d116358c6e302f8 diff --git a/includes/ServiceWiring.php b/includes/ServiceWiring.php index 78609e56ea..740377c027 100644 --- a/includes/ServiceWiring.php +++ b/includes/ServiceWiring.php @@ -45,14 +45,16 @@ use MediaWiki\Block\BlockRestrictionStore; use MediaWiki\Config\ConfigRepository; use MediaWiki\Config\ServiceOptions; use MediaWiki\FileBackend\FSFile\TempFSFileFactory; +use MediaWiki\FileBackend\LockManager\LockManagerGroupFactory; use MediaWiki\Http\HttpRequestFactory; use MediaWiki\Interwiki\ClassicInterwikiLookup; use MediaWiki\Interwiki\InterwikiLookup; -use MediaWiki\Languages\LanguageNameUtils; use MediaWiki\Linker\LinkRenderer; use MediaWiki\Linker\LinkRendererFactory; use MediaWiki\Logger\LoggerFactory; use MediaWiki\MediaWikiServices; +use Wikimedia\Message\IMessageFormatterFactory; +use MediaWiki\Message\MessageFormatterFactory; use MediaWiki\Page\MovePageFactory; use MediaWiki\Permissions\PermissionManager; use MediaWiki\Preferences\PreferencesFactory; @@ -257,13 +259,6 @@ return [ ); }, - 'LanguageNameUtils' => function ( MediaWikiServices $services ) : LanguageNameUtils { - return new LanguageNameUtils( new ServiceOptions( - LanguageNameUtils::$constructorOptions, - $services->getMainConfig() - ) ); - }, - 'LinkCache' => function ( MediaWikiServices $services ) : LinkCache { return new LinkCache( $services->getTitleFormatter(), @@ -290,61 +285,19 @@ return [ ); }, - 'LocalisationCache' => function ( MediaWikiServices $services ) : LocalisationCache { - $conf = $services->getMainConfig()->get( 'LocalisationCacheConf' ); - - $logger = LoggerFactory::getInstance( 'localisation' ); - - // Figure out what class to use for the LCStore - $storeArg = []; - $storeArg['directory'] = - $conf['storeDirectory'] ?? $services->getMainConfig()->get( 'CacheDirectory' ); - - if ( !empty( $conf['storeClass'] ) ) { - $storeClass = $conf['storeClass']; - } elseif ( $conf['store'] === 'files' || $conf['store'] === 'file' || - ( $conf['store'] === 'detect' && $storeArg['directory'] ) - ) { - $storeClass = LCStoreCDB::class; - } elseif ( $conf['store'] === 'db' || $conf['store'] === 'detect' ) { - $storeClass = LCStoreDB::class; - $storeArg['server'] = $conf['storeServer'] ?? []; - } elseif ( $conf['store'] === 'array' ) { - $storeClass = LCStoreStaticArray::class; - } else { - throw new MWException( - 'Please set $wgLocalisationCacheConf[\'store\'] to something sensible.' - ); - } - $logger->debug( "LocalisationCache: using store $storeClass" ); - - return new $conf['class']( - new ServiceOptions( - LocalisationCache::$constructorOptions, - // Two of the options are stored in $wgLocalisationCacheConf - $conf, - // In case someone set that config variable and didn't reset all keys, set defaults. - [ - 'forceRecache' => false, - 'manualRecache' => false, - ], - // Some other options come from config itself - $services->getMainConfig() - ), - new $storeClass( $storeArg ), - $logger, - [ function () use ( $services ) { - $services->getResourceLoader()->getMessageBlobStore()->clear(); - } ], - $services->getLanguageNameUtils() - ); - }, - 'LocalServerObjectCache' => function ( MediaWikiServices $services ) : BagOStuff { $config = $services->getMainConfig(); - $cacheId = \ObjectCache::detectLocalServerCache(); + $cacheId = ObjectCache::detectLocalServerCache(); - return \ObjectCache::newFromParams( $config->get( 'ObjectCaches' )[$cacheId] ); + return ObjectCache::newFromParams( $config->get( 'ObjectCaches' )[$cacheId] ); + }, + + 'LockManagerGroupFactory' => function ( MediaWikiServices $services ) : LockManagerGroupFactory { + return new LockManagerGroupFactory( + WikiMap::getCurrentWikiDbDomain()->getId(), + $services->getMainConfig()->get( 'LockManagers' ), + $services->getDBLoadBalancerFactory() + ); }, 'MagicWordFactory' => function ( MediaWikiServices $services ) : MagicWordFactory { @@ -365,7 +318,7 @@ return [ "Cache type \"$id\" is not present in \$wgObjectCaches." ); } - return \ObjectCache::newFromParams( $mainConfig->get( 'ObjectCaches' )[$id] ); + return ObjectCache::newFromParams( $mainConfig->get( 'ObjectCaches' )[$id] ); }, 'MainWANObjectCache' => function ( MediaWikiServices $services ) : WANObjectCache { @@ -385,7 +338,7 @@ return [ } $params['store'] = $mainConfig->get( 'ObjectCaches' )[$objectCacheId]; - return \ObjectCache::newWANCacheFromParams( $params ); + return ObjectCache::newWANCacheFromParams( $params ); }, 'MediaHandlerFactory' => function ( MediaWikiServices $services ) : MediaHandlerFactory { @@ -407,6 +360,12 @@ return [ ); }, + 'MessageFormatterFactory' => + function ( MediaWikiServices $services ) : IMessageFormatterFactory { + // @phan-suppress-next-line PhanAccessMethodInternal + return new MessageFormatterFactory(); + }, + 'MimeAnalyzer' => function ( MediaWikiServices $services ) : MimeAnalyzer { $logger = LoggerFactory::getInstance( 'Mime' ); $mainConfig = $services->getMainConfig(); @@ -535,8 +494,7 @@ return [ // 'class' and 'preprocessorClass' $services->getMainConfig()->get( 'ParserConf' ), // Make sure to have defaults in case someone overrode ParserConf with something silly - [ 'class' => Parser::class, - 'preprocessorClass' => Parser::getDefaultPreprocessorClass() ], + [ 'class' => Parser::class, 'preprocessorClass' => Preprocessor_Hash::class ], // Plus a buch of actual config options $services->getMainConfig() ); @@ -872,6 +830,7 @@ return [ }, '_SqlBlobStore' => function ( MediaWikiServices $services ) : SqlBlobStore { + // @phan-suppress-next-line PhanAccessMethodInternal return $services->getBlobStoreFactory()->newSqlBlobStore(); },