diff --git a/htdocs/install/etape1.php b/htdocs/install/etape1.php index 3b839d817e3..51941d88a6c 100644 --- a/htdocs/install/etape1.php +++ b/htdocs/install/etape1.php @@ -36,12 +36,6 @@ $langs->setDefaultLang($setuplang); $langs->load("admin"); $langs->load("install"); -// Recuparation des information de connexion -$userroot=isset($_POST["db_user_root"])?$_POST["db_user_root"]:""; -$passroot=isset($_POST["db_pass_root"])?$_POST["db_pass_root"]:""; -// Repertoire des pages dolibarr -$main_dir=isset($_POST["main_dir"])?trim($_POST["main_dir"]):''; - // Init "forced values" to nothing. "forced values" are used after an doliwamp install wizard. $useforcedwizard=false; if (file_exists("./install.forced.php")) { $useforcedwizard=true; include_once("./install.forced.php"); } @@ -49,14 +43,11 @@ else if (file_exists("/etc/dolibarr/install.forced.php")) { $useforcedwizard=inc dolibarr_install_syslog("--- etape1: Entering etape1.php page"); -$error = 0; - /* * View */ - pHeader($langs->trans("ConfigurationFile"),"etape2"); // Test if we can run a first install process @@ -67,34 +58,10 @@ if (! is_writable($conffile)) exit; } +$error = 0; -// Check parameters -if (empty($_POST["db_type"])) -{ - print '
'.$langs->trans("ErrorFieldRequired",$langs->transnoentities("DatabaseType")).'
'; - $error++; -} -if (empty($_POST["db_host"])) -{ - print '
'.$langs->trans("ErrorFieldRequired",$langs->transnoentities("Server")).'
'; - $error++; -} -if (empty($_POST["db_name"])) -{ - print '
'.$langs->trans("ErrorFieldRequired",$langs->transnoentities("DatabaseName")).'
'; - $error++; -} -if (empty($_POST["db_user"])) -{ - print '
'.$langs->trans("ErrorFieldRequired",$langs->transnoentities("Login")).'
'; - $error++; -} -if (! empty($_POST["db_port"]) && ! is_numeric($_POST["db_port"])) -{ - print '
'.$langs->trans("ErrorBadValueForParameter",$_POST["db_port"],$langs->transnoentities("Port")).'
'; - $error++; -} - +// Repertoire des pages dolibarr +$main_dir=isset($_POST["main_dir"])?trim($_POST["main_dir"]):''; // Remove last / into dans main_dir if (substr($main_dir, dol_strlen($main_dir) -1) == "/") @@ -113,139 +80,7 @@ $main_data_dir=isset($_POST["main_data_dir"])?$_POST["main_data_dir"]:''; if (! $main_data_dir) { $main_data_dir="$main_dir/documents"; } -// Test database connexion -if (! $error) -{ - $result=@include_once($main_dir."/lib/databases/".$_POST["db_type"].".lib.php"); - if ($result) - { - // If we ask database or user creation we need to connect as root - if (! empty($_POST["db_create_database"]) && ! $userroot) - { - print '
'.$langs->trans("YouAskDatabaseCreationSoDolibarrNeedToConnect",$_POST["db_name"]).'
'; - print '
'; - if (empty($db->connected)) print $langs->trans("BecauseConnectionFailedParametersMayBeWrong").'

'; - print $langs->trans("ErrorGoBackAndCorrectParameters"); - $error++; - } - if (! empty($_POST["db_create_user"]) && ! $userroot) - { - print '
'.$langs->trans("YouAskLoginCreationSoDolibarrNeedToConnect",$_POST["db_user"]).'
'; - print '
'; - if (! $db->connected) print $langs->trans("BecauseConnectionFailedParametersMayBeWrong").'

'; - print $langs->trans("ErrorGoBackAndCorrectParameters"); - $error++; - } - - // If we need root access - if (! $error && (! empty($_POST["db_create_database"]) || ! empty($_POST["db_create_user"]))) - { - $databasefortest=$_POST["db_name"]; - if (! empty($_POST["db_create_database"])) - { - if ($_POST["db_type"] == 'mysql' || $_POST["db_type"] == 'mysqli') - { - $databasefortest='mysql'; - } - elseif ($_POST["db_type"] == 'pgsql') - { - $databasefortest='postgres'; - } - else - { - $databasefortest='mssql'; - } - } - //print $_POST["db_type"].",".$_POST["db_host"].",$userroot,$passroot,$databasefortest,".$_POST["db_port"]; - $db = new DoliDb($_POST["db_type"],$_POST["db_host"],$userroot,$passroot,$databasefortest,$_POST["db_port"]); - - dol_syslog("databasefortest=".$databasefortest." connected=".$db->connected." database_selected=".$db->database_selected, LOG_DEBUG); - //print "databasefortest=".$databasefortest." connected=".$db->connected." database_selected=".$db->database_selected; - - if (empty($_POST["db_create_database"]) && $db->connected && ! $db->database_selected) - { - print '
'.$langs->trans("ErrorConnectedButDatabaseNotFound",$_POST["db_name"]).'
'; - print '
'; - if (! $db->connected) print $langs->trans("IfDatabaseNotExistsGoBackAndUncheckCreate").'

'; - print $langs->trans("ErrorGoBackAndCorrectParameters"); - $error++; - } - elseif ($db->error && ! (! empty($_POST["db_create_database"]) && $db->connected)) - { - print '
'.$db->error.'
'; - if (! $db->connected) print $langs->trans("BecauseConnectionFailedParametersMayBeWrong").'

'; - print $langs->trans("ErrorGoBackAndCorrectParameters"); - $error++; - } - } - // If we need simple access - if (! $error && (empty($_POST["db_create_database"]) && empty($_POST["db_create_user"]))) - { - $db = new DoliDb($_POST["db_type"],$_POST["db_host"],$_POST["db_user"],$_POST["db_pass"],$_POST["db_name"],$_POST["db_port"]); - if ($db->error) - { - print '
'.$db->error.'
'; - if (! $db->connected) print $langs->trans("BecauseConnectionFailedParametersMayBeWrong").'

'; - print $langs->trans("ErrorGoBackAndCorrectParameters"); - $error++; - } - } - } - else - { - print "
\nFailed to include_once(\"".$main_dir."/lib/databases/".$_POST["db_type"].".lib.php\")
\n"; - print '
'.$langs->trans("ErrorWrongValueForParameter",$langs->transnoentities("WebPagesDirectory")).'
'; - print $langs->trans("ErrorGoBackAndCorrectParameters"); - $error++; - } -} - -else -{ - if (isset($db)) print $db->lasterror(); - if (isset($db) && ! $db->connected) print '
'.$langs->trans("BecauseConnectionFailedParametersMayBeWrong").'

'; - print $langs->trans("ErrorGoBackAndCorrectParameters"); - $error++; -} - -if (! $error && $db->connected) -{ - if (! empty($_POST["db_create_database"])) - { - $result=$db->select_db($_POST["db_name"]); - if ($result) - { - print '
'.$langs->trans("ErrorDatabaseAlreadyExists",$_POST["db_name"]).'
'; - print $langs->trans("IfDatabaseExistsGoBackAndCheckCreate").'

'; - print $langs->trans("ErrorGoBackAndCorrectParameters"); - $error++; - } - } -} - -// Define $defaultCharacterSet and $defaultCollationConnection -if (! $error && $db->connected) -{ - if (! empty($_POST["db_create_database"])) // If we create database, we force default value - { - $defaultCharacterSet=$db->forcecharset; - $defaultCollationConnection=$db->forcecollate; - } - else // If already created, we take current value - { - $defaultCharacterSet=$db->getDefaultCharacterSetDatabase(); - $defaultCollationConnection=$db->getDefaultCollationDatabase(); - } - - print ''; - print ''; - $_POST['dolibarr_main_db_character_set']=$defaultCharacterSet; - $_POST['dolibarr_main_db_collation']=$defaultCollationConnection; -} - - -// Create config file -if (! $error && $db->connected && $action == "set") +if ($action == "set") { umask(0); foreach($_POST as $cle=>$valeur) @@ -275,7 +110,7 @@ if (! $error && $db->connected && $action == "set") } } - // Load database driver + // Chargement driver acces bases if (! $error) { dolibarr_install_syslog("etape1: Directory '".$main_dir."' exists"); @@ -284,13 +119,17 @@ if (! $error && $db->connected && $action == "set") } + /*************************************************************************** + * Create directories + ***************************************************************************/ + // Create subdirectory main_data_dir if (! $error) { // Create directory for documents if (! is_dir($main_data_dir)) { - dol_mkdir($main_data_dir); + create_exdir($main_data_dir); } if (! is_dir($main_data_dir)) @@ -375,7 +214,9 @@ if (! $error && $db->connected && $action == "set") // Alternative root directory name $main_alt_dir_name = ( (GETPOST("main_alt_dir_name") && GETPOST("main_alt_dir_name") != '') ? GETPOST("main_alt_dir_name") : 'custom'); - // Write conf file on disk + /** + * Write conf file on disk + */ if (! $error) { // Save old conf file on disk @@ -390,11 +231,15 @@ if (! $error && $db->connected && $action == "set") $error+=write_conf_file($conffile); } - // Write main.inc.php and master.inc.php into documents/custom dir + /** + * Write main.inc.php and master.inc.php into documents/custom dir + */ $error+=write_main_file($main_data_dir.'/custom/main.inc.php',$main_dir); $error+=write_master_file($main_data_dir.'/custom/master.inc.php',$main_dir); - // Create database and admin user database + /** + * Create database and admin user database + */ if (! $error) { // We reload configuration file @@ -410,7 +255,9 @@ if (! $error && $db->connected && $action == "set") $passroot=isset($_POST["db_pass_root"])?$_POST["db_pass_root"]:""; - // Si creation utilisateur admin demandee, on le cree + /** + * Si creation utilisateur admin demandee, on le cree + */ if (isset($_POST["db_create_user"]) && $_POST["db_create_user"] == "on") { dolibarr_install_syslog("etape1: Create database user: ".$dolibarr_main_db_user); @@ -502,7 +349,9 @@ if (! $error && $db->connected && $action == "set") } // Fin si "creation utilisateur" - // If database creation is asked, we create it + /* + * If database creation is asked, we create it + */ if (! $error && (isset($_POST["db_create_database"]) && $_POST["db_create_database"] == "on")) { dolibarr_install_syslog("etape1: Create database : ".$dolibarr_main_db_name, LOG_DEBUG); @@ -563,7 +412,9 @@ if (! $error && $db->connected && $action == "set") } // Fin si "creation database" - // We testOn test maintenant l'acces par le user base dolibarr + /* + * We testOn test maintenant l'acces par le user base dolibarr + */ if (! $error) { dolibarr_install_syslog("etape1: connexion de type=".$conf->db->type." sur host=".$conf->db->host." port=".$conf->db->port." user=".$conf->db->user." name=".$conf->db->name, LOG_DEBUG);