<?php
+/**
+ * Core installer command line interface.
+ *
+ * @file
+ * @ingroup Deployment
+ */
/**
* Class for the core installer command line interface.
- *
+ *
+ * @ingroup Deployment
* @since 1.17
*/
-class CliInstaller extends CoreInstaller {
+class CliInstaller extends Installer {
+
private $optionMap = array(
'dbtype' => 'wgDBtype',
'dbserver' => 'wgDBserver',
'dbschema' => 'wgDBmwschema',
'dbts2schema' => 'wgDBts2schema',
'dbpath' => 'wgSQLiteDataDir',
+ 'scriptpath' => 'wgScriptPath',
+ 'upgrade' => 'cliUpgrade', /* As long as it isn't $confItems
+ * in LocalSettingsGenerator, we
+ * should be fine. */
);
- /** Constructor */
- function __construct( $siteName, $admin = null, $option = array() ) {
+ /**
+ * Constructor.
+ *
+ * @param $siteName
+ * @param $admin
+ * @param $option Array
+ */
+ function __construct( $siteName, $admin = null, array $option = array() ) {
parent::__construct();
foreach ( $this->optionMap as $opt => $global ) {
}
$this->setVar( 'wgSitename', $siteName );
+
if ( $admin ) {
$this->setVar( '_AdminName', $admin );
}
* Main entry point.
*/
public function execute() {
+ global $cliUpgrade;
+
+ $vars = $this->getExistingLocalSettings();
+ if( $vars && ( !isset( $cliUpgrade ) || $cliUpgrade !== "yes" ) ) {
+ $this->showStatusMessage(
+ Status::newFatal( "config-localsettings-cli-upgrade" )
+ );
+ }
+
$this->performInstallation(
- array( $this, 'startStage'),
+ array( $this, 'startStage' ),
array( $this, 'endStage' )
);
}
+ /**
+ * Write LocalSettings.php to a given path
+ *
+ * @param $path String Full path to write LocalSettings.php to
+ */
+ public function writeConfigurationFile( $path ) {
+ $ls = new LocalSettingsGenerator( $this );
+ $ls->writeFile( "$path/LocalSettings.php" );
+ }
+
public function startStage( $step ) {
- $this->showMessage( wfMsg( "config-install-$step") .
+ $this->showMessage( wfMsg( "config-install-$step" ) .
wfMsg( 'ellipsis' ) . wfMsg( 'word-separator' ) );
}
public function endStage( $step, $status ) {
- $warnings = $status->getWarningsArray();
- if ( !$status->isOk() ) {
- $this->showStatusMessage( $status );
- echo "\n";
- exit;
- } elseif ( count($warnings) !== 0 ) {
- foreach ( $status->getWikiTextArray( $warnings ) as $w ) {
- $this->showMessage( $w . wfMsg( 'ellipsis') .
- wfMsg( 'word-separator' ) );
- }
- }
- $this->showMessage( wfMsg( 'config-install-step-done' ) ."\n");
+ $this->showStatusMessage( $status );
+ $this->showMessage( wfMsg( 'config-install-step-done' ) . "\n" );
}
public function showMessage( $msg /*, ... */ ) {
- echo html_entity_decode( strip_tags( $msg ), ENT_QUOTES );
+ $params = func_get_args();
+ array_shift( $params );
+
+ /* parseinline has the nasty side-effect of putting encoded
+ * angle brackets, around the message, so the substr removes
+ * them. */
+ $text = substr( wfMsgExt( $msg, array( 'parseinline' ), $params ), 4, -4 );
+ $text = preg_replace( '/<a href="(.*?)".*?>(.*?)<\/a>/', '$2 <$1>', $text );
+ echo html_entity_decode( strip_tags( $text ), ENT_QUOTES ) . "\n";
flush();
}
public function showStatusMessage( Status $status ) {
- $this->showMessage( $status->getWikiText() );
- }
+ $warnings = array_merge( $status->getWarningsArray(),
+ $status->getErrorsArray() );
+
+ if ( count( $warnings ) !== 0 ) {
+ foreach ( $status->getWikiTextArray( $warnings ) as $w ) {
+ $this->showMessage( $w . wfMsg( 'ellipsis' ) .
+ wfMsg( 'word-separator' ) );
+ }
+ }
-}
\ No newline at end of file
+ if ( !$status->isOk() ) {
+ echo "\n";
+ exit;
+ }
+ }
+}