wiki.techinc.nl/maintenance/importSites.php
daniel eb46307b00 Introduce top level service locator.
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
2016-04-02 18:07:28 +03:00

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;