Qware_core/lib/package/backup/mysqlbackupdb.php

315 lines
8.3 KiB
PHP
Executable File

<?php
/**-----------------------------------------------
*
* Rooty, 2018 <rooty@rooty.me>
*
*
* 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 <www.rooty.me|rooty@rooty.me>
* @since 2005/03/11
* @link www.rooty.me
* @version 0.3
* @package package
* @subpackage BackupDb
* @copyright Copyright &copy; 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.<br>";
} 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.<br>";
} 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;
}
}
}
?>