* Copyright (C) 2004-2005 Laurent Destailleur * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * * $Id$ * $Source$ */ /** \file htdocs/install/etape2.php \brief Crée les tables, clés primaires, clés étrangères, index et fonctions en base puis charge les données de référence \version $Revision$ */ include_once("./inc.php"); $etape = 2; $ok = 0; // Cette page peut etre longue. On augmente le délai par défaut de 30 à 60. // Ne fonctionne que si on est pas en safe_mode. $err=error_reporting(); error_reporting(0); set_time_limit(90); error_reporting($err); $setuplang=isset($_POST["selectlang"])?$_POST["selectlang"]:(isset($_GET["selectlang"])?$_GET["selectlang"]:'auto'); $langs->setDefaultLang($setuplang); $langs->load("admin"); $langs->load("install"); pHeader($langs->trans("CreateDatabaseObjects"),"etape4"); if (file_exists($conffile)) { include_once($conffile); } if($dolibarr_main_db_type == "mysql") { require_once($dolibarr_main_document_root . "/lib/mysql.lib.php"); $choix=1; } else { require_once($dolibarr_main_document_root . "/lib/pgsql.lib.php"); $choix=2; } require_once($dolibarr_main_document_root . "/conf/conf.class.php"); if ($_POST["action"] == "set") { print '

'.$langs->trans("Database").'

'; print ''; $error=0; $conf = new Conf();// on pourrait s'en passer $conf->db->type = $dolibarr_main_db_type; $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; $db = new DoliDb($conf->db->type,$conf->db->host,$conf->db->user,$conf->db->pass,$conf->db->name); if ($db->connected == 1) { print ""; $ok = 1 ; } else { print ""; } if ($ok) { if($db->database_selected == 1) { dolibarr_syslog("Connexion réussie à la base : $dolibarr_main_db_name"); } else { $ok = 0 ; } } // Affiche version if ($ok) { $version=$db->getVersion(); print ''; } /************************************************************************************** * * Chargement fichiers tables/*.sql (non *.key.sql) * A faire avant les fichiers *.key.sql * ***************************************************************************************/ if ($ok) { if ($choix==1) $dir = "../../mysql/tables/"; else $dir = "../../pgsql/tables/"; $ok = 0; $handle=opendir($dir); $table_exists = 0; while (($file = readdir($handle))!==false) { if (substr($file, strlen($file) - 4) == '.sql' && substr($file,0,4) == 'llx_' && substr($file, -8) <> '.key.sql') { $name = substr($file, 0, strlen($file) - 4); $buffer = ''; $fp = fopen($dir.$file,"r"); if ($fp) { while (!feof ($fp)) { $buf = fgets($fp, 4096); if (substr($buf, 0, 2) <> '--') { $buffer .= $buf; } } fclose($fp); } //print ""; } else { if ($db->errno() == 'DB_ERROR_TABLE_ALREADY_EXISTS') { //print ""; $table_exists = 1; } else { print ""; print ""; $error++; } } } } closedir($handle); if ($error == 0) { print ''; $ok = 1; } } /*************************************************************************************** * * Chargement fichiers tables/*.key.sql * A faire après les fichiers *.sql * ***************************************************************************************/ if ($ok) { if ($choix==1) $dir = "../../mysql/tables/"; else $dir = "../../pgsql/tables/"; $okkeys = 0; $handle=opendir($dir); $table_exists = 0; while (($file = readdir($handle))!==false) { if (substr($file, strlen($file) - 4) == '.sql' && substr($file,0,4) == 'llx_' && substr($file, -8) == '.key.sql') { $name = substr($file, 0, strlen($file) - 4); //print ""; $buffer = ''; $fp = fopen($dir.$file,"r"); if ($fp) { while (!feof ($fp)) { $buf = fgets($fp, 4096); // Cas special de lignes autorisees pour certaines versions uniquement if (eregi('^-- V([0-9]+)',$buf,$reg)) { if ($reg[1] && $reg[1] <= $version) { $buf=eregi_replace('^-- V([0-9]+)','',$buf); //print $buf.'
'; } } // Ajout ligne si non commentaire if (! eregi('^--',$buf)) $buffer .= $buf; } fclose($fp); } // Si plusieurs requetes, on boucle sur chaque $listesql=split(';',$buffer); foreach ($listesql as $buffer) { if (trim($buffer)) { //print ""; if ($db->query(trim($buffer))) { //print ""; } else { if ($db->errno() == 'DB_ERROR_KEY_NAME_ALREADY_EXISTS' || $db->errno() == 'DB_ERROR_CANNOT_CREATE' || eregi('duplicate key name',$db->error())) { //print ""; $key_exists = 1; } else { print ""; print ""; $error++; } } } } } } closedir($handle); if ($error == 0) { print ''; $okkeys = 1; } } /*************************************************************************************** * * Positionnement des droits * ***************************************************************************************/ if ($ok) { // Droits sur les tables $grant_query=$db->getGrantForUserQuery($dolibarr_main_db_user); if ($grant_query) // Seules les bases qui en ont besoin le definisse { if ($db->query($grant_query)) { print ""; } } } /*************************************************************************************** * * Chargement fichier functions.sql * ***************************************************************************************/ if ($ok) { if ($choix==1) $dir = "../../mysql/functions/"; else $dir = "../../pgsql/functions/"; // Création données $file = "functions.sql"; if (file_exists($dir.$file)) { $fp = fopen($dir.$file,"r"); if ($fp) { while (!feof ($fp)) { $buffer = fgets($fp, 4096); if (substr($buf, 0, 2) <> '--') { $buffer .= $buf; } } fclose($fp); } // Si plusieurs requetes, on boucle sur chaque $listesql=split('§',eregi_replace(";';",";'§",$buffer)); foreach ($listesql as $buffer) { if (trim($buffer)) { if ($db->query(trim($buffer))) { $ok = 1; } else { if ($db->errno() == 'DB_ERROR_RECORD_ALREADY_EXISTS') { // print ""; if ($ok) { print ""; } else { print ""; $ok = 1 ; } } } /*************************************************************************************** * * Chargement fichier data.sql * ***************************************************************************************/ if ($ok) { if ($choix==1) $dir = "../../mysql/data/"; else $dir = "../../pgsql/data/"; // Création données $file = "data.sql"; $fp = fopen($dir.$file,"r"); if ($fp) { while (!feof ($fp)) { $buffer = fgets($fp, 4096); if (strlen(trim(ereg_replace("--","",$buffer)))) { if ($db->query($buffer)) { $ok = 1; } else { if ($db->errno() == 'DB_ERROR_RECORD_ALREADY_EXISTS') { // print ""; if ($ok) { print ""; } else { print ""; $ok = 1 ; } } /*************************************************************************************** * * Les variables qui ecrase le chemin par defaut sont redéfinies * ***************************************************************************************/ if ($ok == 1) { $sql[0] = "UPDATE llx_const SET value = '".$dolibarr_main_data_root."/facture', type = 'chaine', visible = 0 where name ='FAC_OUTPUTDIR';" ; $sql[1] = "UPDATE llx_const SET value = '".$dolibarr_main_data_root."/propale', type = 'chaine', visible = 0 where name = 'PROPALE_OUTPUTDIR';" ; $sql[2] = "UPDATE llx_const SET value = '".$dolibarr_main_data_root."/ficheinter', type = 'chaine', visible = 0 where name = 'FICHEINTER_OUTPUTDIR';" ; $sql[3] = "UPDATE llx_const SET value='".$dolibarr_main_data_root."/societe', type = 'chaine', visible = 0 where name = 'SOCIETE_OUTPUTDIR';" ; $sql[4] = "DELETE from llx_const where name like '%_OUTPUT_URL';"; $sql[5] = "UPDATE llx_const SET value='".$langs->defaultlang."', type = 'chaine', visible = 0 where name = 'MAIN_LANG_DEFAULT';" ; $result = 0; for ($i=0; $i < sizeof($sql);$i++) { if ($db->query($sql[$i])) { $result++; } } } print '
"; print $langs->trans("ServerConnection")." : $dolibarr_main_db_host".$langs->trans("OK")."
Erreur lors de la création de : $dolibarr_main_db_name".$langs->trans("Error")."
'; print $langs->trans("DatabaseVersion").''.$version.'
Création de la table $name/td>"; if ($db->query($buffer)) { //print "OK requete ==== $buffer
Déjà existante
".$langs->trans("CreateTableAndPrimaryKey",$name)."".$langs->trans("Error")." ".$db->errno()." ".$db->error()."
'; print $langs->trans("TablesAndPrimaryKeysCreation").''.$langs->trans("OK").'
Création de la table $name
Création des clés et index de la table $name: '$buffer'OK requete ==== $buffer
Déjà existante
".$langs->trans("CreateOtherKeysForTable",$name)."".$langs->trans("Error")." ".$db->errno()." ".$db->error()."
'; print $langs->trans("OtherKeysCreation").''.$langs->trans("OK").'
Grant User".$langs->trans("OK")."
Insertion ligne : $buffer } else { $ok = 0; print $langs->trans("ErrorSQL")." : ".$db->errno()." - '$buffer' - ".$db->error()."
"; } } } } print "
".$langs->trans("FunctionsCreation")."".$langs->trans("OK")."
".$langs->trans("Error")."
Insertion ligne : $buffer } else { $ok = 0; print $langs->trans("ErrorSQL")." : ".$db->errno()." - '$buffer' - ".$db->error()."
"; } } } } fclose($fp); } print "
".$langs->trans("ReferenceDataLoading")."".$langs->trans("OK")."
".$langs->trans("Error")."
'; $db->close(); } pFooter(!$ok,$setuplang); ?>