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);