workaround pour bug installation sous mysql

TODO: changer verification droits d'acces voir 362 / 373
This commit is contained in:
opensides 2004-08-27 00:23:30 +00:00
parent 6c2dc008f7
commit f40d055a42

View File

@ -34,10 +34,13 @@ $conffile = "../conf/conf.php";
// Répertoire des pages dolibarr
$main_dir=isset($_POST["main_dir"])?$_POST["main_dir"]:'';
// Répertoire des documents générés (factures, etc...)
$main_data_dir=isset($_POST["main_data_dir"])?$_POST["main_data_dir"]:'';
# En attendant que le main_data_dir soit géré de manière autonome,
# on le force à sa valeur fixe des anciennes versions.
if (! $main_data_dir) { $main_data_dir="$main_dir/document"; }
if ($_POST["action"] == "set")
@ -48,72 +51,73 @@ if ($_POST["action"] == "set")
print '<table cellspacing="0" width="100%" cellpadding="4" border="0">';
$error=0;
$fp = fopen("$conffile", "w");
if($fp)
{
if (substr($main_dir, strlen($main_dir) -1) == "/")
if($fp)
{
$main_dir = substr($main_dir, 0, strlen($main_dir)-1);
}
if (substr($_POST["main_url"], strlen($_POST["main_url"]) -1) == "/")
{
$_POST["main_url"] = substr($_POST["main_url"], 0, strlen($_POST["main_url"])-1);
}
clearstatcache();
fwrite($fp, '<?PHP');
fputs($fp,"\n");
fputs($fp, '$dolibarr_main_url_root="'.$_POST["main_url"].'";');
fputs($fp,"\n");
fputs($fp, '$dolibarr_main_document_root="'.$main_dir.'";');
fputs($fp,"\n");
fputs($fp, '$dolibarr_main_data_root="'.$main_data_dir.'";');
fputs($fp,"\n");
fputs($fp, '$dolibarr_main_db_host="'.$_POST["db_host"].'";');
fputs($fp,"\n");
fputs($fp, '$dolibarr_main_db_name="'.$_POST["db_name"].'";');
fputs($fp,"\n");
fputs($fp, '$dolibarr_main_db_user="'.$_POST["db_user"].'";');
fputs($fp,"\n");
fputs($fp, '$dolibarr_main_db_pass="'.$_POST["db_pass"].'";');
fputs($fp,"\n");
fputs($fp, '$dolibarr_main_db_type="'.$_POST["db_type"].'";');
fputs($fp,"\n");
fputs($fp, '?>');
fclose($fp);
if (file_exists("$conffile"))
{
include ("$conffile");
print "<tr><td>Configuration enregistrée</td><td>OK</td>";
$error = 0;
}
else
{
$error = 1;
}
}
if($dolibarr_main_db_type == "mysql")
if (substr($main_dir, strlen($main_dir) -1) == "/")
{
include_once("../lib/mysql.lib.php");
$choix=1;
$main_dir = substr($main_dir, 0, strlen($main_dir)-1);
}
if (substr($_POST["main_url"], strlen($_POST["main_url"]) -1) == "/")
{
$_POST["main_url"] = substr($_POST["main_url"], 0, strlen($_POST["main_url"])-1);
}
clearstatcache();
fwrite($fp, '<?PHP');
fputs($fp,"\n");
fputs($fp, '$dolibarr_main_url_root="'.$_POST["main_url"].'";');
fputs($fp,"\n");
fputs($fp, '$dolibarr_main_document_root="'.$main_dir.'";');
fputs($fp,"\n");
fputs($fp, '$dolibarr_main_data_root="'.$main_data_dir.'";');
fputs($fp,"\n");
fputs($fp, '$dolibarr_main_db_host="'.$_POST["db_host"].'";');
fputs($fp,"\n");
fputs($fp, '$dolibarr_main_db_name="'.$_POST["db_name"].'";');
fputs($fp,"\n");
fputs($fp, '$dolibarr_main_db_user="'.$_POST["db_user"].'";');
fputs($fp,"\n");
fputs($fp, '$dolibarr_main_db_pass="'.$_POST["db_pass"].'";');
fputs($fp,"\n");
fputs($fp, '$dolibarr_main_db_type="'.$_POST["db_type"].'";');
fputs($fp,"\n");
fputs($fp, '?>');
fclose($fp);
if (file_exists("$conffile"))
{
include ("$conffile");
print "<tr><td>Configuration enregistrée</td><td>OK</td>";
$error = 0;
}
else
{
include_once("../lib/pgsql.lib.php");
$choix=2;
$error = 1;
}
}
if($dolibarr_main_db_type == "mysql")
{
include_once("../lib/mysql.lib.php");
$choix=1;
}
else
{
include_once("../lib/pgsql.lib.php");
$choix=2;
}
/***************************************************************************
@ -122,8 +126,8 @@ if ($_POST["action"] == "set")
*
***************************************************************************/
if ($error == 0)
{
if ($error == 0)
{
$dir[0] = "$main_data_dir/facture";
$dir[1] = "$main_data_dir/propale";
@ -134,61 +138,65 @@ if ($_POST["action"] == "set")
$dir[6] = "$main_data_dir/images";
$dir[7] = "$main_data_dir/rsscache";
if (! is_dir($main_dir))
{
print "<tr><td>Le dossier '".$main_dir."' n'existe pas !</td><td>Erreur</td></tr>";
$error++;
}
else
{
dolibarr_syslog ("Le dossier '".$main_dir."' existe");
/*
* Répertoire des documents
*/
if (! is_dir($main_data_dir))
{
@mkdir($main_data_dir, 0755);
}
if (! is_dir($main_data_dir))
{
print "<tr><td>Le dossier '$main_data_dir' n'existe pas ! ";
print "Vous devez créer ce dossier et permettre au serveur web d'écrire dans celui-ci";
print '</td><td bgcolor="red">Erreur</td></tr>';
$error++;
}
else
{
for ($i = 0 ; $i < sizeof($dir) ; $i++)
if (! is_dir($main_dir))
{
if (is_dir($dir[$i]))
{
dolibarr_syslog ("Le dossier '".$dir[$i]."' existe");
}
else
{
if (! @mkdir($dir[$i], 0755))
{
print "<tr><td>Impossible de créer : ".$dir[$i]."</td><td bgcolor=\"red\">Erreur</td></tr>";
$error++;
}
else
{
dolibarr_syslog ("Le dossier '".$dir[$i]."' create ok");
}
}
print "<tr><td>Le dossier '".$main_dir."' n'existe pas !</td><td>Erreur</td></tr>";
$error++;
}
else
{
dolibarr_syslog ("Le dossier '".$main_dir."' existe");
/*
* Répertoire des documents
*/
if (! is_dir($main_data_dir))
{
@mkdir($main_data_dir, 0755);
}
if (! is_dir($main_data_dir))
{
print "<tr><td>Le dossier '$main_data_dir' n'existe pas ! ";
print "Vous devez créer ce dossier et permettre au serveur web d'écrire dans celui-ci";
print '</td><td bgcolor="red">Erreur</td></tr>';
$error++;
}
else
{
for ($i = 0 ; $i < sizeof($dir) ; $i++)
{
if (is_dir($dir[$i]))
{
dolibarr_syslog ("Le dossier '".$dir[$i]."' existe");
}
else
{
if (! @mkdir($dir[$i], 0755))
{
print "<tr><td>Impossible de créer : ".$dir[$i]."</td><td bgcolor=\"red\">Erreur</td></tr>";
$error++;
}
else
{
dolibarr_syslog ("Le dossier '".$dir[$i]."' a ete cree");
}
}
}
}
}
}
}
}
/*
* Base de données
*
*/
if ($error == 0)
{
include_once($dolibarr_main_document_root . "/conf/conf.class.php");
if ($error == 0)
{
include_once($dolibarr_main_document_root . "/conf/conf.class.php");
// TODO
// Il y a encore des pb ds la procédure d'install qui ne passe dans pas tous les cas
// (exemple, rien n'existe et on veut créer une base avec un compte admin != root)
@ -209,165 +217,176 @@ if ($_POST["action"] == "set")
// si compte admin n'existe pas deja et db_create_user non positionné, erreur compte admin inexistant "Veuillez cocher pour le créer"
// Si creation utilisateur admin demandée, on le crée
if (isset($_POST["db_create_user"]) && $_POST["db_create_user"] == "on")
{
dolibarr_syslog ("Creation de l'utilisateur : ".$dolibarr_main_db_user);
$conf = new Conf();
$conf->db->host = $dolibarr_main_db_host;
$conf->db->name = $dolibarr_main_db_name;
//$conf->db->name = "mysql";
//$conf->db->user = isset($_POST["db_user_root"])?$_POST["db_user_root"]:"";
//$conf->db->pass = isset($_POST["db_pass_root"])?$_POST["db_pass_root"]:"";
$conf->db->user = "postgres";
$conf->db->pass = "postgres";
//print $conf->db->host." , ".$conf->db->name." , ".$conf->db->user." , ".$conf->db->pass;
$db = new DoliDb();
if($choix==1)
if (isset($_POST["db_create_user"]) && $_POST["db_create_user"] == "on")
{
$sql = "INSERT INTO user ";
$sql .= "(Host,User,password)";
$sql .= " VALUES ('$dolibarr_main_db_host','$dolibarr_main_db_user',password('$dolibarr_main_db_pass'))";
dolibarr_syslog ("Creation de l'utilisateur : ".$dolibarr_main_db_user);
if($choix == 1)
{ //choix 1=mysql
$conf = new Conf();
$conf->db->host = $dolibarr_main_db_host;
$conf->db->name = $dolibarr_main_db_name;
$conf->db->name = $dolibarr_main_db_type;
$conf->db->user = isset($_POST["db_user_root"])?$_POST["db_user_root"]:"";
$conf->db->pass = isset($_POST["db_pass_root"])?$_POST["db_pass_root"]:"";
//print $conf->db->host." , ".$conf->db->name." , ".$conf->db->user." , ".$conf->db->pass;
$db = new DoliDb();
print $db->query($sql);
$sql = "INSERT INTO db ";
$sql .= "(Host,Db,User,Select_priv,Insert_priv,Update_priv,Delete_priv,Create_priv,Drop_priv,Index_Priv,Alter_priv)";
$sql .= " VALUES ('$dolibarr_main_db_host','$dolibarr_main_db_name','$dolibarr_main_db_user'";
$sql .= ",'Y','Y','Y','Y','Y','Y','Y','Y')";
$sql = "INSERT INTO user ";
$sql .= "(Host,User,password,elect_priv,Insert_priv,Update_priv,Delete_priv,Create_priv,Drop_priv,Index_Priv,Alter_priv)";
$sql .= " VALUES ('$dolibarr_main_db_host','$dolibarr_main_db_user',password('$dolibarr_main_db_pass')";
$sql .= ",'Y','Y','Y','Y','Y',Y','Y','Y');";
print $sql;
print $sql;
if ($db->query($sql))
{
dolibarr_syslog("flush privileges");
$db->query("flush privileges");
$db->query($sql);
$sql = "INSERT INTO db ";
$sql .= "(Host,Db,User,Select_priv,Insert_priv,Update_priv,Delete_priv,Create_priv,Drop_priv,Index_Priv,Alter_priv)";
$sql .= " VALUES ('$dolibarr_main_db_host','$dolibarr_main_db_name','$dolibarr_main_db_user'";
$sql .= ",'Y','Y','Y','Y','Y','Y','Y','Y');";
print $sql;
if ($db->query($sql))
{
dolibarr_syslog("flush privileges");
$db->query("flush privileges");
print "<tr><td>Création de l'utilisateur : $dolibarr_main_db_user</td><td>OK</td></tr>";
}
else
{
if ($db->errno() == 1062)
{
print "<tr><td>Création de l'utilisateur : $dolibarr_main_db_user</td><td>Deja existant</td></tr>";
}
else
{
print "<tr><td>Création de l'utilisateur : $dolibarr_main_db_user</td><td>ERREUR ".$db->error()."</td></tr>";
}
}
print "<tr><td>Création de l'utilisateur : $dolibarr_main_db_user</td><td>OK</td></tr>";
}
else
{
if ($db->errno() == 1062)
{
dolibarr_syslog("Utilisateur deja existant");
print "<tr><td>Création de l'utilisateur : $dolibarr_main_db_user</td><td>Deja existant</td></tr>";
}
else
{
dolibarr_syslog("impossible de creer l'utilisateur");
print "<tr><td>Création de l'utilisateur : $dolibarr_main_db_user</td><td>ERREUR ".$db->error()."</td></tr>";
}
}
$db->close();
} //choix==1
else
{
$nom = $dolibarr_main_db_user;
$con=pg_connect("host=localhost dbname=dolibarr user=postgres");
$query_str = "create user \"$nom\" with password '".$dolibarr_main_db_pass."';";
//print $query_str;
$ret = pg_query($con,$query_str);
if ($ret)
print "<tr><td>Création de l'utilisateur:\"$nom\"</td><td>OK</td></tr>";
else
print "<tr><td>Création de l'utilisateur:\"$nom\"</td><td>ERREUR</td></tr>";
}
$db->close();
}
else
{ //choix 2=postgresql
$nom = $dolibarr_main_db_user;
$con=pg_connect("host=localhost dbname=dolibarr user=postgres");
$query_str = "create user \"$nom\" with password '".$dolibarr_main_db_pass."';";
//print $query_str;
$ret = pg_query($con,$query_str);
if ($ret)
print "<tr><td>Création de l'utilisateur:\"$nom\"</td><td>OK</td></tr>";
else
print "<tr><td>Création de l'utilisateur:\"$nom\"</td><td>ERREUR</td></tr>";
}
}
}
// Tentative accès serveur et base par le user admin dolibarr
$conf = new Conf();
$conf->db->host = $dolibarr_main_db_host;
$conf->db->name = $dolibarr_main_db_name;
$conf->db->user = $dolibarr_main_db_user;
$conf->db->pass = $dolibarr_main_db_pass;
$conf = new Conf();
$conf->db->host = $dolibarr_main_db_host;
$conf->db->name = $dolibarr_main_db_name;
$conf->db->user = $dolibarr_main_db_user;
$conf->db->pass = $dolibarr_main_db_pass;
//print $conf->db->host.",".$conf->db->name.",".$conf->db->user.",".$conf->db->pass;
$db = new DoliDb();
$ok = 1;
$db = new DoliDb();
$ok = 1;
if ($db->connected == 1)
{
print "<tr><td>Connexion au serveur : $dolibarr_main_db_host</td><td>OK</td></tr>";
}
else
{
print "<tr><td>Connexion au serveur : $dolibarr_main_db_host</td><td>ERREUR</td></tr>";
$ok = 0;
}
if ($db->connected == 1)
{
dolibarr_syslog("la connexion au serveur est reussie");
print "<tr><td>Connexion au serveur : $dolibarr_main_db_host</td><td>OK</td></tr>";
}
else
{
dolibarr_syslog("la connection au serveur est rate");
print "<tr><td>Connexion au serveur : $dolibarr_main_db_host</td><td>ERREUR</td></tr>";
$ok = 0;
}
if ($ok)
{
if($db->database_selected == 1)
{
if ($ok)
{
if($db->database_selected == 1)
{
//
// Connexion base existante
//
print "<tr><td>Connexion à la base : $dolibarr_main_db_name</td><td>OK</td></tr>";
$ok = 1 ;
}
else
{
dolibarr_syslog("la connexion a la database est reussie");
print "<tr><td>Connexion à la base : $dolibarr_main_db_name</td><td>OK</td></tr>";
$ok = 1 ;
}
else
{
//
// Création de la base
//
print "<tr><td>Echec de connexion à la base : $dolibarr_main_db_name</td><td>Warning</td></tr>";
print '<tr><td colspan="2">Création de la base : '.$dolibarr_main_db_name.'</td></tr>';
dolibarr_syslog("la connexion a la database est rate");
print "<tr><td>Echec de connexion à la base : $dolibarr_main_db_name</td><td>Warning</td></tr>";
print '<tr><td colspan="2">Création de la base : '.$dolibarr_main_db_name.'</td></tr>';
$conf = new Conf();
$conf->db->host = $dolibarr_main_db_host;
//$conf->db->name = "mysql";
$conf = new Conf();
$conf->db->host = $dolibarr_main_db_host;
$conf->db->name = $dolibarr_main_db_name;
//$conf->db->user = "seb";
$conf->db->user = isset($_POST["db_user_root"])?$_POST["db_user_root"]:"";
$conf->db->pass = isset($_POST["db_pass_root"])?$_POST["db_pass_root"]:"";
$conf->db->user = isset($_POST["db_user_root"])?$_POST["db_user_root"]:"";
$conf->db->pass = isset($_POST["db_pass_root"])?$_POST["db_pass_root"]:"";
$dbt = new DoliDb(); // Ne pas prendre $db comme nom de variable car dejà pris pour connexion précédente et bug mémoire sur php windows dans ce cas
$dbt = new DoliDb(); // Ne pas prendre $db comme nom de variable car dejà pris pour connexion précédente et bug mémoire sur php windows dans ce cas
if ($ok)
{
if ($dbt->connected == 1)
{
print "<tr><td>Connexion au serveur : $dolibarr_main_db_host avec l'utilisateur : ".$_POST["db_user_root"]."</td><td>OK</td></tr>";
}
else
{
print "<tr><td>Connexion au serveur : $dolibarr_main_db_host avec l'utilisateur : ".$_POST["db_user_root"]."</td><td>ERREUR</td></tr>";
$ok = 0;
}
}
if ($ok)
{
if ($dbt->connected == 1)
{
dolibarr_syslog("la connexion au serveur avec l'utilisateur root reussi");
print "<tr><td>Connexion au serveur : $dolibarr_main_db_host avec l'utilisateur : ".$_POST["db_user_root"]."</td><td>OK</td></tr>";
}
else
{
dolibarr_syslog("la connexion au serveur avec l'utilisateur root rate");
print "<tr><td>Connexion au serveur : $dolibarr_main_db_host avec l'utilisateur : ".$_POST["db_user_root"]."</td><td>ERREUR</td></tr>";
$ok = 0;
}
}
if ($ok)
{
if($dbt->database_selected == 1)
{
}
else
{
print "<tr><td>Vérification des droits de création</td><td>ERREUR</td></tr>";
print '<tr><td colspna="2">-- Droits insuffissant</td></tr>';
$ok = 0;
}
}
if ($ok)
{
if($dbt->database_selected == 1)
{
}
else
{
print "<tr><td>Vérification des droits de création</td><td>ERREUR</td></tr>";
print '<tr><td colspna="2">-- Droits insuffissant</td></tr>';
//$ok = 0;
}
}
if ($ok)
{
if ($dbt->create_db ($dolibarr_main_db_name))
{
print "<tr><td>Création de la base : $dolibarr_main_db_name</td><td>OK</td></tr>";
}
else
{
print "<tr><td>Création de la base : $dolibarr_main_db_name</td><td>ERREUR</td></tr>";
$ok = 0;
}
}
}
}
}
if ($ok)
{
if ($dbt->create_db ($dolibarr_main_db_name))
{
print "<tr><td>Création de la base : $dolibarr_main_db_name</td><td>OK</td></tr>";
}
else
{
print "<tr><td>Création de la base : $dolibarr_main_db_name</td><td>ERREUR</td></tr>";
$ok = 0;
}
}
}
}
}
}
?>
</table>