The service locator, MediaWikiServices, is intended to facilitate "manual" dependency injection in static entry points. See also the Dependency Injection RFC T384 and Service Locator RFC T124792 for details. The following key points were implemented according the discussion surrounding these RFCs: * a configurable DI container that allows extensions to add and replace services. * no auto-wiring, since it's prone to add confusion in large and complex applications. * no 3rd party framework, since they typically do too much. The following services in MediaWiki core are made accessible via the service locator mechanism to showcase the bootstrapping mechanism: * ConfigFactory and MainConfig * SiteLookup and SiteStore However, the implementation of these services was not yet converted to using proper DI throughout the code. Bug: T124792 Change-Id: I3c25c0ac17300d3dd13e1cf5100558a605eee15f
54 lines
1.3 KiB
PHP
54 lines
1.3 KiB
PHP
<?php
|
|
|
|
$basePath = getenv( 'MW_INSTALL_PATH' ) !== false ? getenv( 'MW_INSTALL_PATH' ) : __DIR__ . '/..';
|
|
|
|
require_once $basePath . '/maintenance/Maintenance.php';
|
|
|
|
/**
|
|
* Maintenance script for importing site definitions from XML into the sites table.
|
|
*
|
|
* @since 1.25
|
|
*
|
|
* @license GNU GPL v2+
|
|
* @author Daniel Kinzler
|
|
*/
|
|
class ImportSites extends Maintenance {
|
|
|
|
public function __construct() {
|
|
$this->addDescription( 'Imports site definitions from XML into the sites table.' );
|
|
|
|
$this->addArg( 'file', 'An XML file containing site definitions (see docs/sitelist.txt). ' .
|
|
'Use "php://stdin" to read from stdin.', true
|
|
);
|
|
|
|
parent::__construct();
|
|
}
|
|
|
|
/**
|
|
* Do the import.
|
|
*/
|
|
public function execute() {
|
|
$file = $this->getArg( 0 );
|
|
|
|
$siteStore = \MediaWiki\MediaWikiServices::getInstance()->getSiteStore();
|
|
$importer = new SiteImporter( $siteStore );
|
|
$importer->setExceptionCallback( [ $this, 'reportException' ] );
|
|
|
|
$importer->importFromFile( $file );
|
|
|
|
$this->output( "Done.\n" );
|
|
}
|
|
|
|
/**
|
|
* Outputs a message via the output() method.
|
|
*
|
|
* @param Exception $ex
|
|
*/
|
|
public function reportException( Exception $ex ) {
|
|
$msg = $ex->getMessage();
|
|
$this->output( "$msg\n" );
|
|
}
|
|
}
|
|
|
|
$maintClass = 'ImportSites';
|
|
require_once RUN_MAINTENANCE_IF_MAIN;
|