BUGFIX #5326: Fix installation when using _ss_environment.php

git-svn-id: svn://svn.silverstripe.com/silverstripe/open/phpinstaller/branches/2.4@102087 467b73ca-7a2a-4603-9d3b-597d59a354a9
This commit is contained in:
sminnee 2010-04-06 00:24:38 +00:00 committed by Sam Minnee
parent 40520e1127
commit 62810d39c2

View File

@ -84,7 +84,9 @@ foreach(DatabaseAdapterRegistry::get_adapters() as $class => $details) {
// Load database config // Load database config
if(isset($_REQUEST['db'])) { if(isset($_REQUEST['db'])) {
$type = (isset($_REQUEST['db']['type'])) ? $_REQUEST['db']['type'] : "MySQLDatabase"; if(isset($_REQUEST['db']['type'])) $type = $_REQUEST['db']['type'];
else $type = $_REQUEST['db']['type'] = defined('SS_DATABASE_CLASS') ? SS_DATABASE_CLASS : 'MySQLDatabase';
// Disabled inputs don't submit anything - we need to use the environment (except the database name) // Disabled inputs don't submit anything - we need to use the environment (except the database name)
if($usingEnv) { if($usingEnv) {
$_REQUEST['db'][$type] = $databaseConfig = array( $_REQUEST['db'][$type] = $databaseConfig = array(
@ -94,6 +96,7 @@ if(isset($_REQUEST['db'])) {
"password" => defined('SS_DATABASE_PASSWORD') ? SS_DATABASE_PASSWORD : "", "password" => defined('SS_DATABASE_PASSWORD') ? SS_DATABASE_PASSWORD : "",
"database" => $_REQUEST['db'][$type]['database'], "database" => $_REQUEST['db'][$type]['database'],
); );
} else { } else {
// Normal behaviour without the environment // Normal behaviour without the environment
$databaseConfig = $_REQUEST['db'][$type]; $databaseConfig = $_REQUEST['db'][$type];
@ -901,10 +904,17 @@ class Installer extends InstallRequirements {
$locale = isset($_POST['locale']) ? $_POST['locale'] : 'en_US'; $locale = isset($_POST['locale']) ? $_POST['locale'] : 'en_US';
$type = $config['db']['type']; $type = $config['db']['type'];
$dbConfig = $config['db'][$type]; $dbConfig = $config['db'][$type];
if(!$dbConfig) {
echo "<p style=\"color: red\">Bad config submitted</p><pre>";
print_r($config);
echo "</pre>";
die();
}
// Write the config file // Write the config file
global $usingEnv; global $usingEnv;
if($usingEnv) { if($usingEnv) {
$this->statusMessage("Setting up 'mysite/_config.php' for use with _ss_environment.php..."); $this->statusMessage("Setting up 'mysite/_config.php' for use with _ss_environment.php...");
$this->writeToFile("mysite/_config.php", <<<PHP $this->writeToFile("mysite/_config.php", <<<PHP
<?php <?php
@ -931,7 +941,6 @@ SiteTree::enable_nested_urls();
PHP PHP
); );
} else { } else {
$this->statusMessage("Setting up 'mysite/_config.php'..."); $this->statusMessage("Setting up 'mysite/_config.php'...");
$escapedPassword = addslashes($dbConfig['password']); $escapedPassword = addslashes($dbConfig['password']);