* * * This software is protected by copyright, please * read the file COPYRIGHT. * 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. Please * read the file LICENCE. * * Ce fichier contient la gestion de BackupDb (Factory+Modéle) * * @author Rooty * @since 2005/03/11 * @link www.rooty.me * @version 0.3 * @package package * @subpackage BackupDb * @copyright Copyright © 2009-2018, Rooty */ if ( !defined('SYSTEM_IN') ) { die("Hacking attempt"); } /** * Inclusion des éléments de parsage sql (sqlParse) */ include_once($GLOBALS["CONF_LIB_PATH"]."lib/system/system_data_source/database/sql_parse.php"); /** * Classe MysqlBackupDb *classe de gestion des BackupDb (BD) pour mysql * @package package * @subpackage BackupDb */ class MysqlBackUpDb extends CommonBackupDb { // // Constructeur (non surchargé!!) // /** * Liste les tables pour une BD * @param chaine nom de la BD */ function getListTables($db) { $i = 0; $nbtab = $GLOBALS["SYSTEM_DATABASE_CONN"]->sql_query("show tables"); while ($row = $nbtab->fetch(PDO::FETCH_NUM)) { $tb_names[$i] = $row[0]; $i++; } return $tb_names; } /** * Récupération des données pour une table * @param chaine nom de la table * @param entier pointeur de fichier */ function getTableData($table, $fd) { $tableau = array (); $j = 0; $resultat = $GLOBALS["SYSTEM_DATABASE_CONN"]->sql_query("select * from $table"); if ($resultat == FALSE) { return "La requete dans la table '".$table."' a echoue.
"; } else { while ($valeurs = $resultat->fetch(PDO::FETCH_NUM)) { $this->writeLine($valeurs, $table, $fd); } return $valeurs; } } /** * recuperation de la structure de la table * @param chaine nom de la table * @param entier pointeur de fichier */ function getTableStructure($struct, $fd) { $requete = $GLOBALS["SYSTEM_DATABASE_CONN"]->sql_query("show create table $struct"); if ($requete == FALSE) { return "la recuperation de la structure '".$struct."' a echoue.
"; } else { $structure = $GLOBALS["SYSTEM_DATABASE_CONN"]->sql_fetchrow(); $ligne = 0; return $structure[1]; } } /** * recuperation de la structure de la table * @param chaine chaine sql de création de table * @param chaine nom de la table * @param entier pointeur de fichier */ function putStructIntoFile ($structure, $nom_table, $fd) { $struct = "#\n# Structure de la table ".$nom_table."\n#\n\n"; # Ajout de l'énnonçé DROP TABLE... $struct .="DROP TABLE IF EXISTS `".$nom_table."`;\n"; $struct .= $structure; $struct .= ";\n\n"; $ecriture = fwrite ($fd, $struct, strlen ($struct)); if ($ecriture == 0) { return "erreur lors de l'ecriture de la strucuture dans le fichier de sauvgarde."; } else{ return $fd; } } /** * integre les donnees dans un fichier * @param chaine données à insérer * @param chaine nom de la table * @param entier pointeur de fichier */ function putDataIntoFile ($donnees, $nom_table, $fd) { $lignes = 0; $infos = "#\n# donnees de la table ".$nom_table ."\n#\n\n"; fwrite ($fd, $infos, strlen ($infos)); while (isset ($donnees[$lignes])) { $appel_fonction = $this->writeLine($donnees[$lignes], $nom_table, $fd); $lignes++; } return $fd; } /** * écrit une ligne de données * @param chaine données à insérer * @param chaine nom de la table * @param entier pointeur de fichier */ function writeLine ($donnees, $nom_table, $fd) { $case = 1; $debut = "INSERT INTO `".$nom_table."` VALUES ('".$donnees[0]."'"; fwrite ($fd, $debut, strlen ($debut)); while (isset ($donnees[$case])){ fwrite ($fd, ", '".addslashes($donnees[$case])."'", strlen (", '".addslashes($donnees[$case])."'")); $case++; } $fin = ");\n\n\n"; fwrite ($fd, $fin, strlen ($fin)); } /** * Création d'une sauvegarde * @todo ne gére pas les enregistrement dont un champs peut être null :-( * @return booleen */ function backup() { # Récupération des paramètres $host=$this->host; $login=$this->login; $password=$this->passwd; $chemin=$this->path; $nom_fichier=$this->file; $db=$this->db; $emplacement = $chemin."/".$nom_fichier; if (!isset ($chemin) || !is_dir ($chemin)){ addError(2,"MysqlBackupDb", " $chemin n'est pas un repertoire ou n'existe pas.", __line__, __file__); return false; } if (file_exists ($nom_fichier)){ addError(2,"MysqlBackupDb","Impossible de faire la sauvegarde, le fichier $nom_fichier existe deja.", __line__, __file__); return false; }else{ $list = $this->getListTables ($db); $tab = 0; $fd = fopen ($emplacement, "w+"); while (isset ($list[$tab])) { $structure = $this->getTableStructure ($list[$tab], $fd); $backup = $this->putStructIntoFile ($structure, $list[$tab], $fd); $query = $this->getTableData ($list[$tab], $fd); $backup_suite = $this->putDataIntoFile ($query, $list[$tab], $fd); $tab++; } fclose ($fd); chmod($emplacement, $this->perm); $directory = $chemin."/"; $name_zip = substr ( $nom_fichier, 0,strpos($nom_fichier, ".")); $name = $nom_fichier; return true; } } /** * Réstauration d'une sauvegarde * @return booleen */ function restore() { # Récupération des paramètres $host=$this->host; $login=$this->login; $password=$this->passwd; $chemin=$this->path; $nom_fichier=$this->file; $db=$this->db; $emplacement = $chemin."/".$nom_fichier; if (!isset ($chemin) || !is_dir ($chemin)){ addError(2,"MysqlBackupDb", " $chemin n'est pas un repertoire ou n'existe pas.", __line__, __file__); return false; } if (!file_exists ($emplacement)){ addError(2,"MysqlBackupDb","Impossible d'executer le fichier $nom_fichier n'existe pas.", __line__, __file__); return false; }else{ // $connect = mysql_connect($host, $login, $password); // mysql_select_db($db, $connect); $dbselect = true; try { $bd_connect = new PDO("mysql:host=$host;port=$port;dbname=$db;charset=utf8", "$login", "$password"); // PDO Connection } catch (PDOException $e) { // $e->getCode = 1049 = Unknown database if( $e->getCode() == '1049' ) $dbselect = false; } if($dbselect) { // $sql_query = @fread(@fopen($emplacement, 'r'), @filesize($emplacement)); $sql_query = file_get_contents($emplacement); $sql_query = preg_replace('/{_DATABASE_}/', DATA_SOURCE_DB_DATABASE, $sql_query); $sql_query = preg_replace('/{_PREFIX_}/', DATA_ACCES_TABLE_PREFIX, $sql_query); // $sql_query = remove_remarks($sql_query); // $sql_query = split_sql_file($sql_query, ";"); // for ($i = 0; $i < sizeof($sql_query); $i++) // { // if (trim($sql_query[$i]) != '') // { // if ($result = $bd_connect->exec($sql_query[$i])) // { // addError(2,"MysqlBackupDb","Échec de la requête SQL: ".$sql_query[$i]." / ".$result, __line__, __file__); // return false; // } else { // addError(2,"MysqlBackupDb","Succès de la requête SQL: ".$sql_query[$i], __line__, __file__); // } // } // } $stmt = $bd_connect->prepare($sql_query); if ($stmt->execute()){ addError(2,"MysqlBackupDb","Succès de la requête SQL: ".$sql_query); }else{ addError(2,"MysqlBackupDb","Échec de la requête SQL: ".$sql_query, __line__, __file__); return false; } } else { echo "Connexion à la base de données échouée !!!"; exit(0); } // $sql_query = @fread(@fopen($emplacement, 'r'), @filesize($emplacement)); // $sql_query = remove_remarks($sql_query); // $sql_query = split_sql_file($sql_query, ";"); // $sql_query = make_path($sql_query); // // for ($i = 0; $i < sizeof($sql_query); $i++) // { // if (trim($sql_query[$i]) != '') // { // // if (!($result = mysql_query($sql_query[$i],$connect))) // var_dump($sql_query[$i]); // $result = $GLOBALS["SYSTEM_DATABASE_CONN"]->sql_query($sql_query[$i].";"); // var_dump($result); // if ($result == FALSE); // { // addError(2,"MysqlBackupDb","Échec de la requête SQL: ".$sql_query[$i], __line__, __file__); // return false; // } // } // } // exit(0); return true; } } } ?>