2017-06-24 00:58:56 +03:00
|
|
|
|
<?php
|
|
|
|
|
|
|
|
|
|
/**
|
2018-03-26 10:33:20 +03:00
|
|
|
|
* AVE.cms
|
2017-06-24 00:58:56 +03:00
|
|
|
|
*
|
2018-03-26 10:33:20 +03:00
|
|
|
|
* Класс, предназначенный для создания и восстановления дампов БД через Панель управления
|
2017-06-24 00:58:56 +03:00
|
|
|
|
*
|
2018-03-26 10:33:20 +03:00
|
|
|
|
* @package AVE.cms
|
|
|
|
|
* @version 3.x
|
|
|
|
|
* @filesource
|
|
|
|
|
* @copyright © 2007-2014 AVE.cms, http://www.ave-cms.ru
|
2017-06-24 00:58:56 +03:00
|
|
|
|
*
|
|
|
|
|
*/
|
|
|
|
|
|
2018-03-26 10:33:20 +03:00
|
|
|
|
class AVE_DB_Service
|
|
|
|
|
{
|
|
|
|
|
/**
|
|
|
|
|
* Метка-разделитель SQL-запросов
|
|
|
|
|
*
|
|
|
|
|
* @public string
|
|
|
|
|
*/
|
|
|
|
|
public $_delimiter = '#####systemdump#####';
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Дамп базы данных
|
|
|
|
|
*
|
|
|
|
|
* @public string
|
|
|
|
|
*/
|
|
|
|
|
public $_database_dump = '';
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Метод, предназначенный для формирования файла дампа базы данных
|
|
|
|
|
*
|
|
|
|
|
* @return boolean
|
|
|
|
|
*/
|
|
|
|
|
function _databaseDumpCreate()
|
|
|
|
|
{
|
|
|
|
|
global $AVE_DB;
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-03-26 10:33:20 +03:00
|
|
|
|
if (! (! empty($_REQUEST['ta']) && is_array($_REQUEST['ta'])))
|
|
|
|
|
return false;
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-03-26 10:33:20 +03:00
|
|
|
|
$search = array("\x00", "\x0a", "\x0d", "\x1a");
|
|
|
|
|
$replace = array('\0', '\n', '\r', '\Z');
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-03-26 10:33:20 +03:00
|
|
|
|
$this->_database_dump = '';
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-03-26 10:33:20 +03:00
|
|
|
|
// Циклически обрабатываем каждую таблицу
|
|
|
|
|
foreach ($_REQUEST['ta'] as $table)
|
2017-06-24 00:58:56 +03:00
|
|
|
|
{
|
2017-11-17 12:02:05 +03:00
|
|
|
|
if (! DB_EXPORT_PREFIX)
|
2018-03-26 10:33:20 +03:00
|
|
|
|
$table_export = preg_replace('/^' . PREFIX . '/', '%%PRFX%%', $table);
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-03-26 10:33:20 +03:00
|
|
|
|
// Если таблица имеет корректный префикс
|
|
|
|
|
if (preg_match('/^' . preg_quote(PREFIX) . '_/', $table))
|
|
|
|
|
{
|
|
|
|
|
$row = $AVE_DB->Query("SHOW CREATE TABLE " . $table)->FetchArray();
|
|
|
|
|
// Сохраняем CREATE и DROP запросы
|
|
|
|
|
$this->_database_dump .= "DROP TABLE IF EXISTS `" . (! DB_EXPORT_PREFIX ? $table_export : $table) . "`;" . $this->_delimiter . "\n";
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-03-26 10:33:20 +03:00
|
|
|
|
if (! DB_EXPORT_PREFIX)
|
|
|
|
|
$this->_database_dump .= str_replace('CREATE TABLE `' . PREFIX . '_', 'CREATE TABLE `%%PRFX%%_', $row[1]) . ";" . $this->_delimiter . "\n\n";
|
|
|
|
|
else
|
|
|
|
|
$this->_database_dump .= $row[1] . ";" . $this->_delimiter . "\n\n";
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-03-26 10:33:20 +03:00
|
|
|
|
$nums = 0;
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-03-26 10:33:20 +03:00
|
|
|
|
// Получаем данные, которые в дальнейшем будут вставлены в INSERT запросы.
|
|
|
|
|
$sql = $AVE_DB->Query('SELECT * FROM `' . $table . '`');
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-03-26 10:33:20 +03:00
|
|
|
|
while ($row = $sql->FetchArray())
|
|
|
|
|
{
|
|
|
|
|
if ($nums == 0)
|
2017-06-24 00:58:56 +03:00
|
|
|
|
{
|
2018-03-26 10:33:20 +03:00
|
|
|
|
$nums = $sql->NumFields();
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-03-26 10:33:20 +03:00
|
|
|
|
$temp_array = array();
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-03-26 10:33:20 +03:00
|
|
|
|
for ($i = 0; $i < $nums; $i++)
|
|
|
|
|
{
|
|
|
|
|
$temp_array[] = $sql->FieldName($i);
|
|
|
|
|
}
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-03-26 10:33:20 +03:00
|
|
|
|
$table_list = '(`' . implode('`, `', $temp_array) . '`)';
|
2017-06-24 00:58:56 +03:00
|
|
|
|
}
|
2018-03-26 10:33:20 +03:00
|
|
|
|
|
|
|
|
|
$temp_array = array();
|
|
|
|
|
|
|
|
|
|
for ($i=0; $i<$nums; $i++)
|
2017-06-24 00:58:56 +03:00
|
|
|
|
{
|
2018-03-26 10:33:20 +03:00
|
|
|
|
if (! isset($row[$i]))
|
|
|
|
|
{
|
|
|
|
|
$temp_array[] = 'NULL';
|
|
|
|
|
}
|
|
|
|
|
elseif ($row[$i] != '')
|
|
|
|
|
{
|
|
|
|
|
$temp_array[] = "'" . str_replace($search, $replace, addslashes($row[$i])) . "'";
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
$temp_array[] = "''";
|
|
|
|
|
}
|
2017-06-24 00:58:56 +03:00
|
|
|
|
}
|
|
|
|
|
|
2018-03-26 10:33:20 +03:00
|
|
|
|
// Сохряняем INSERT запросы
|
|
|
|
|
$this->_database_dump .= 'INSERT INTO `' . (! DB_EXPORT_PREFIX ? $table_export : $table) . '` ' . $table_list . ' VALUES (' . implode(', ', $temp_array) . ");" . $this->_delimiter . "\n";
|
|
|
|
|
}
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-03-26 10:33:20 +03:00
|
|
|
|
$this->_database_dump .= "\n";
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-03-26 10:33:20 +03:00
|
|
|
|
$sql->Close();
|
|
|
|
|
}
|
2017-06-24 00:58:56 +03:00
|
|
|
|
}
|
|
|
|
|
|
2018-03-26 10:33:20 +03:00
|
|
|
|
return ! empty($this->_database_dump);
|
|
|
|
|
}
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
|
|
|
|
|
2018-03-26 10:33:20 +03:00
|
|
|
|
/**
|
|
|
|
|
* Метод, предназначенный для формирования файла дампа базы данных
|
|
|
|
|
*
|
|
|
|
|
* @return boolean
|
|
|
|
|
*/
|
|
|
|
|
function _databaseTopDumpCreate()
|
2017-06-24 00:58:56 +03:00
|
|
|
|
{
|
2018-03-26 10:33:20 +03:00
|
|
|
|
global $AVE_DB;
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-03-26 10:33:20 +03:00
|
|
|
|
$dbtables = array();
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-03-26 10:33:20 +03:00
|
|
|
|
$sql = $AVE_DB->Query("SHOW TABLES LIKE '" . PREFIX . "_%'");
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-03-26 10:33:20 +03:00
|
|
|
|
while ($row = $sql->FetchArray())
|
2017-06-24 00:58:56 +03:00
|
|
|
|
{
|
2018-03-26 10:33:20 +03:00
|
|
|
|
array_push($dbtables, $row[0]);
|
|
|
|
|
}
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-03-26 10:33:20 +03:00
|
|
|
|
$search = array("\x00", "\x0a", "\x0d", "\x1a");
|
|
|
|
|
$replace = array('\0', '\n', '\r', '\Z');
|
2017-11-17 12:02:05 +03:00
|
|
|
|
|
2018-03-26 10:33:20 +03:00
|
|
|
|
$this->_database_dump = '';
|
|
|
|
|
|
|
|
|
|
// Циклически обрабатываем каждую таблицу
|
|
|
|
|
foreach ($dbtables as $table)
|
|
|
|
|
{
|
2017-11-17 12:02:05 +03:00
|
|
|
|
if (! DB_EXPORT_PREFIX)
|
2018-03-26 10:33:20 +03:00
|
|
|
|
$table_export = preg_replace('/^' . PREFIX . '/', '%%PRFX%%', $table);
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-03-26 10:33:20 +03:00
|
|
|
|
// Если таблица имеет корректный префикс
|
|
|
|
|
if (preg_match('/^' . preg_quote(PREFIX) . '_/', $table))
|
|
|
|
|
{
|
|
|
|
|
$row = $AVE_DB->Query("SHOW CREATE TABLE " . $table)->FetchArray();
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-03-26 10:33:20 +03:00
|
|
|
|
// Сохраняем CREATE и DROP запросы
|
|
|
|
|
$this->_database_dump .= "DROP TABLE IF EXISTS `" . (! DB_EXPORT_PREFIX ? $table_export : $table) . "`;" . $this->_delimiter . "\n";
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-03-26 10:33:20 +03:00
|
|
|
|
if (! DB_EXPORT_PREFIX)
|
|
|
|
|
$this->_database_dump .= str_replace('CREATE TABLE `' . PREFIX . '_', 'CREATE TABLE `%%PRFX%%_', $row[1]) . ";" . $this->_delimiter . "\n\n";
|
|
|
|
|
else
|
|
|
|
|
$this->_database_dump .= $row[1] . ";" . $this->_delimiter . "\n\n";
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-03-26 10:33:20 +03:00
|
|
|
|
$nums = 0;
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-03-26 10:33:20 +03:00
|
|
|
|
// Получаем данные, которые в дальнейшем будут вставлены в INSERT запросы.
|
|
|
|
|
$sql = $AVE_DB->Query('SELECT * FROM `' . $table . '`');
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-03-26 10:33:20 +03:00
|
|
|
|
while ($row = $sql->FetchArray())
|
2017-06-24 00:58:56 +03:00
|
|
|
|
{
|
2018-03-26 10:33:20 +03:00
|
|
|
|
if ($nums==0)
|
2017-06-24 00:58:56 +03:00
|
|
|
|
{
|
2018-03-26 10:33:20 +03:00
|
|
|
|
$nums = $sql->NumFields();
|
|
|
|
|
|
|
|
|
|
$temp_array = array();
|
|
|
|
|
for ($i=0; $i<$nums; $i++)
|
|
|
|
|
{
|
|
|
|
|
$temp_array[] = $sql->FieldName($i);
|
|
|
|
|
}
|
|
|
|
|
$table_list = '(`' . implode('`, `', $temp_array) . '`)';
|
2017-06-24 00:58:56 +03:00
|
|
|
|
}
|
2018-03-26 10:33:20 +03:00
|
|
|
|
|
|
|
|
|
$temp_array = array();
|
|
|
|
|
|
|
|
|
|
for ($i=0; $i<$nums; $i++)
|
2017-06-24 00:58:56 +03:00
|
|
|
|
{
|
2018-03-26 10:33:20 +03:00
|
|
|
|
if (!isset($row[$i]))
|
|
|
|
|
{
|
|
|
|
|
$temp_array[] = 'NULL';
|
|
|
|
|
}
|
|
|
|
|
elseif ($row[$i] != '')
|
|
|
|
|
{
|
|
|
|
|
$temp_array[] = "'" . str_replace($search, $replace, addslashes($row[$i])) . "'";
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
$temp_array[] = "''";
|
|
|
|
|
}
|
2017-06-24 00:58:56 +03:00
|
|
|
|
}
|
|
|
|
|
|
2018-03-26 10:33:20 +03:00
|
|
|
|
// Сохряняем INSERT запросы
|
|
|
|
|
$this->_database_dump .= 'INSERT INTO `' . (! DB_EXPORT_PREFIX ? $table_export : $table) . '` ' . $table_list . ' VALUES (' . implode(', ', $temp_array) . ");" . $this->_delimiter . "\n";
|
|
|
|
|
}
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-03-26 10:33:20 +03:00
|
|
|
|
$this->_database_dump .= "\n";
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-03-26 10:33:20 +03:00
|
|
|
|
$sql->Close();
|
|
|
|
|
}
|
2017-06-24 00:58:56 +03:00
|
|
|
|
}
|
|
|
|
|
|
2018-03-26 10:33:20 +03:00
|
|
|
|
return ! empty($this->_database_dump);
|
|
|
|
|
}
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
2018-03-26 10:33:20 +03:00
|
|
|
|
* Внешние методы класса
|
2017-06-24 00:58:56 +03:00
|
|
|
|
*/
|
|
|
|
|
|
2018-03-26 10:33:20 +03:00
|
|
|
|
/**
|
|
|
|
|
* Метод, предназначенный для сохранения файла дампа базы данных на жеский диск
|
|
|
|
|
*
|
|
|
|
|
*/
|
|
|
|
|
function databaseDumpExport($top = 0, $exit = 0)
|
2017-06-24 00:58:56 +03:00
|
|
|
|
{
|
2018-03-26 10:33:20 +03:00
|
|
|
|
global $AVE_Template;
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-03-26 10:33:20 +03:00
|
|
|
|
// Если дамп не удалось создать, тогда завершаем работу
|
|
|
|
|
if ($top)
|
2017-06-24 00:58:56 +03:00
|
|
|
|
{
|
2018-03-26 10:33:20 +03:00
|
|
|
|
if (! $this->_databaseTopDumpCreate())
|
|
|
|
|
exit;
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
if (! $this->_databaseDumpCreate())
|
|
|
|
|
exit;
|
2017-06-24 00:58:56 +03:00
|
|
|
|
}
|
|
|
|
|
|
2018-03-26 10:33:20 +03:00
|
|
|
|
// Готовим шаблон имени файла
|
|
|
|
|
$file_name = preg_replace_ru(array("/%SERVER%/", "/%DATE%/", "/%TIME%/"), array($_SERVER['SERVER_NAME'], date('d.m.y'), date('H.i.s')), DB_EXPORT_TPL);
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-03-26 10:33:20 +03:00
|
|
|
|
$dump = (defined('DB_EXPORT_GZ') && DB_EXPORT_GZ
|
|
|
|
|
? gzencode($this->_database_dump)
|
|
|
|
|
: $this->_database_dump);
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-03-26 10:33:20 +03:00
|
|
|
|
if (isset($_REQUEST['server']) && $_REQUEST['server'] == 1)
|
|
|
|
|
{
|
2018-04-19 19:11:58 +03:00
|
|
|
|
if (! is_dir(BASE_DIR . '/tmp/backup/'))
|
2018-03-26 10:33:20 +03:00
|
|
|
|
{
|
2018-04-19 19:11:58 +03:00
|
|
|
|
@mkdir(BASE_DIR . '/tmp/backup/', 0777, true);
|
|
|
|
|
write_htaccess_deny(BASE_DIR . '/tmp/backup/');
|
2018-03-26 10:33:20 +03:00
|
|
|
|
}
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-04-19 19:11:58 +03:00
|
|
|
|
@file_put_contents(BASE_DIR . '/tmp/backup/'. $file_name . '.sql'. (defined('DB_EXPORT_GZ') && DB_EXPORT_GZ ? '.gz' : ''), $dump);
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-04-19 19:11:58 +03:00
|
|
|
|
@chmod(BASE_DIR . '/tmp/backup/'. $file_name . '.sql', 0777);
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-03-26 10:33:20 +03:00
|
|
|
|
if (! $exit)
|
|
|
|
|
header('Location:index.php?do=dbsettings&cp=' . SESSION);
|
|
|
|
|
else
|
2018-04-19 19:11:58 +03:00
|
|
|
|
return BASE_DIR . '/tmp/backup/'. $file_name . '.sql'. (defined('DB_EXPORT_GZ') && DB_EXPORT_GZ ? '.gz' : '');
|
2018-03-26 10:33:20 +03:00
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
// Формируем заголовок
|
|
|
|
|
header('Content-Type: text/plain');
|
|
|
|
|
header('Expires: ' . gmdate('D, d M Y H:i:s') . ' GMT');
|
|
|
|
|
header('Content-Disposition: attachment; filename=' . $file_name . '.sql'. (defined('DB_EXPORT_GZ') && DB_EXPORT_GZ ? '.gz' : ''));
|
|
|
|
|
header('Content-Length: ' . strlen($dump));
|
|
|
|
|
header('Cache-Control: must-revalidate, post-check=0, pre-check=0');
|
|
|
|
|
header('Pragma: public');
|
|
|
|
|
|
|
|
|
|
// Выводим данные
|
|
|
|
|
echo $dump;
|
|
|
|
|
|
|
|
|
|
$this->_database_dump = '';
|
|
|
|
|
}
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-03-26 10:33:20 +03:00
|
|
|
|
// Выполняем запись системного сообщения в журнал
|
|
|
|
|
reportLog($AVE_Template->get_config_vars('DB_REPORT_DUMP'));
|
|
|
|
|
exit;
|
|
|
|
|
}
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
|
|
|
|
|
2018-03-26 10:33:20 +03:00
|
|
|
|
/**
|
|
|
|
|
* Метод, предназначенный для сохранения файла дампа базы данных на жеский диск
|
|
|
|
|
*
|
|
|
|
|
*/
|
|
|
|
|
function databaseDumpFileSave($file = '')
|
|
|
|
|
{
|
|
|
|
|
global $AVE_Template;
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-04-19 19:11:58 +03:00
|
|
|
|
$file = BASE_DIR . '/tmp/backup/'. $file;
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-03-26 10:33:20 +03:00
|
|
|
|
// Если дамп не удалось создать, тогда завершаем работу
|
|
|
|
|
if (! is_file($file))
|
|
|
|
|
return false;
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-03-26 10:33:20 +03:00
|
|
|
|
header('Content-Description: File Transfer');
|
|
|
|
|
header('Content-Type: application/octet-stream');
|
|
|
|
|
header('Content-Disposition: attachment; filename=' . basename($file));
|
|
|
|
|
header('Content-Transfer-Encoding: binary');
|
|
|
|
|
header('Expires: 0');
|
|
|
|
|
header('Cache-Control: must-revalidate');
|
|
|
|
|
header('Pragma: public');
|
|
|
|
|
header('Content-Length: ' . filesize($file));
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-03-26 10:33:20 +03:00
|
|
|
|
ob_clean();
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-03-26 10:33:20 +03:00
|
|
|
|
flush();
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-03-26 10:33:20 +03:00
|
|
|
|
readfile($file);
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-03-26 10:33:20 +03:00
|
|
|
|
exit;
|
|
|
|
|
}
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
|
|
|
|
|
2018-03-26 10:33:20 +03:00
|
|
|
|
/**
|
|
|
|
|
* Метод, предназначенный для восстановления базы данных из дампа
|
|
|
|
|
*
|
|
|
|
|
* @param string $tempdir путь к папке в которую загружается файл дампа
|
|
|
|
|
*/
|
|
|
|
|
function databaseDumpImport($tempdir)
|
2017-06-24 00:58:56 +03:00
|
|
|
|
{
|
2018-03-26 10:33:20 +03:00
|
|
|
|
global $AVE_DB, $AVE_Template;
|
|
|
|
|
|
|
|
|
|
$insert = false;
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-03-26 10:33:20 +03:00
|
|
|
|
// Если файл не пустой
|
|
|
|
|
if ($_FILES['file']['size'] != 0)
|
2017-06-24 00:58:56 +03:00
|
|
|
|
{
|
2018-03-26 10:33:20 +03:00
|
|
|
|
// Получаем имя файла и его расширение (должно быть sql)
|
|
|
|
|
$fupload_name = $_FILES['file']['name'];
|
|
|
|
|
$gz = substr($fupload_name, -3)=='.gz';
|
|
|
|
|
$end = substr($fupload_name, -3);
|
|
|
|
|
|
|
|
|
|
// Если расширение sql, тогда
|
|
|
|
|
if ($gz || $end == 'sql')
|
|
|
|
|
{
|
|
|
|
|
// Если файл не удалось загрузить, формируем сообщение с ошибкой
|
|
|
|
|
if (! @move_uploaded_file($_FILES['file']['tmp_name'], $tempdir . $fupload_name))
|
|
|
|
|
die('Ошибка при загрузке файла!');
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-03-26 10:33:20 +03:00
|
|
|
|
// Устанавливаем права чтения, записи, выполнения на файл
|
|
|
|
|
@chmod($fupload_name, 0777);
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-03-26 10:33:20 +03:00
|
|
|
|
// Определяем флаг готовности к записи данных в БД
|
|
|
|
|
$insert = true;
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
// В противном случае, если расширение файла НЕ sql, формируем сообщение с ошибкой
|
|
|
|
|
$AVE_Template->assign('msg', '<li class="highlight red"><strong>Ошибка:</strong> ' . $AVE_Template->get_config_vars('MAIN_SQL_FILE_ERROR') . '</li>');
|
|
|
|
|
}
|
2017-06-24 00:58:56 +03:00
|
|
|
|
}
|
|
|
|
|
|
2018-03-26 10:33:20 +03:00
|
|
|
|
// Если флаг готовности записи установлен, тогда
|
|
|
|
|
if ($insert)
|
2017-06-24 00:58:56 +03:00
|
|
|
|
{
|
2018-03-26 10:33:20 +03:00
|
|
|
|
// Еще раз провреяем наличие загруженного файла
|
|
|
|
|
if ($fupload_name != '' && file_exists($tempdir . $fupload_name))
|
|
|
|
|
{
|
|
|
|
|
// Читаем данные из файла
|
|
|
|
|
$handle = @fopen($tempdir . $fupload_name, 'r');
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-03-26 10:33:20 +03:00
|
|
|
|
$db_q = @fread($handle, filesize($tempdir . $fupload_name));
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-03-26 10:33:20 +03:00
|
|
|
|
fclose($handle);
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-03-26 10:33:20 +03:00
|
|
|
|
if ($gz)
|
|
|
|
|
$db_q = gzdecode($db_q);
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-03-26 10:33:20 +03:00
|
|
|
|
$m_ok = 0;
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-03-26 10:33:20 +03:00
|
|
|
|
$m_fail = 0;
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-03-26 10:33:20 +03:00
|
|
|
|
// Формируем массив запросов ориентируясь по разделителю указанному в свойстве _delimiter
|
|
|
|
|
$querys = @explode($this->_delimiter, $db_q);
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-03-26 10:33:20 +03:00
|
|
|
|
// Циклически обрабатываем массив, выполняя каждый запрос
|
|
|
|
|
foreach ($querys as $val)
|
2017-06-24 00:58:56 +03:00
|
|
|
|
{
|
2018-03-26 10:33:20 +03:00
|
|
|
|
if (chop($val) != '')
|
2017-06-24 00:58:56 +03:00
|
|
|
|
{
|
2018-03-26 10:33:20 +03:00
|
|
|
|
$q = str_replace("\n",'',$val);
|
|
|
|
|
|
|
|
|
|
$q = $q . ';';
|
|
|
|
|
|
|
|
|
|
if ($AVE_DB->Query($q))
|
|
|
|
|
{
|
|
|
|
|
$m_ok++;
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
$m_fail++;
|
|
|
|
|
}
|
2017-06-24 00:58:56 +03:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2018-03-26 10:33:20 +03:00
|
|
|
|
// Удаляем файл дампа
|
|
|
|
|
@unlink($tempdir . $fupload_name);
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-03-26 10:33:20 +03:00
|
|
|
|
// Формируем сопроводительные сообщения
|
|
|
|
|
$msg = '<li class="highlight green"><strong>' . $AVE_Template->get_config_vars('MAIN_RESTORE_OK') . '</strong><br /><br />'
|
|
|
|
|
. $AVE_Template->get_config_vars('MAIN_TABLE_SUCC')
|
|
|
|
|
. '<strong>' . $m_ok . '</strong><br/> '
|
|
|
|
|
. $AVE_Template->get_config_vars('MAIN_TABLE_ERROR')
|
|
|
|
|
. '<strong><span style="color:red">' . $m_fail . '</span></strong></li>';
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-03-26 10:33:20 +03:00
|
|
|
|
$AVE_Template->assign('msg', $msg);
|
|
|
|
|
}
|
|
|
|
|
else // В противном случае, если файл не найден, формируем сообщение с ошибкой
|
|
|
|
|
{
|
|
|
|
|
$AVE_Template->assign('msg', '<li class="highlight red">'.$AVE_Template->get_config_vars('DB_REPORT_DUMP_ER').'</li>');
|
|
|
|
|
}
|
2017-06-24 00:58:56 +03:00
|
|
|
|
}
|
2018-03-26 10:33:20 +03:00
|
|
|
|
|
|
|
|
|
// Выполняем запись системного сообщения в журнал
|
|
|
|
|
reportLog($AVE_Template->get_config_vars('DB_REPORT_DUMP_RECOVER'));
|
2017-06-24 00:58:56 +03:00
|
|
|
|
}
|
|
|
|
|
|
2018-03-26 10:33:20 +03:00
|
|
|
|
/**
|
|
|
|
|
* Метод, предназначенный для удаления файла дампа на сервере
|
|
|
|
|
*
|
|
|
|
|
* @param string $file путь к файлу дампа
|
|
|
|
|
*/
|
|
|
|
|
function databaseDumpFileDelete($file = '')
|
|
|
|
|
{
|
|
|
|
|
global $AVE_DB, $AVE_Template;
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-03-26 10:33:20 +03:00
|
|
|
|
$file = BASE_DIR . '/backup/'. $file;
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-03-26 10:33:20 +03:00
|
|
|
|
if (! is_file($file))
|
|
|
|
|
return false;
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-03-26 10:33:20 +03:00
|
|
|
|
if (@unlink($file))
|
|
|
|
|
{
|
|
|
|
|
reportLog($AVE_Template->get_config_vars('DB_REPORT_DUMP_DEL_OK') . ' ('.basename($file).')');
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
reportLog($AVE_Template->get_config_vars('DB_REPORT_DUMP_DEL_ER') . ' ('.basename($file).')');
|
|
|
|
|
}
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-03-26 10:33:20 +03:00
|
|
|
|
header('Location:index.php?do=dbsettings&cp=' . SESSION);
|
2017-06-24 00:58:56 +03:00
|
|
|
|
}
|
|
|
|
|
|
2018-03-26 10:33:20 +03:00
|
|
|
|
/**
|
|
|
|
|
* Метод, предназначенный для восстановления базы данных из дампа на сервере
|
|
|
|
|
*
|
|
|
|
|
* @param string $file путь к файлу дампа
|
|
|
|
|
*/
|
|
|
|
|
function databaseDumpFileImport($file = '')
|
|
|
|
|
{
|
|
|
|
|
global $AVE_DB, $AVE_Template;
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-03-26 10:33:20 +03:00
|
|
|
|
$insert = false;
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-04-19 19:11:58 +03:00
|
|
|
|
$file = BASE_DIR . '/tmp/backup/'. $file;
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-03-26 10:33:20 +03:00
|
|
|
|
// Если дамп не удалось создать, тогда завершаем работу
|
|
|
|
|
if (! is_file($file)) $insert = false;
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-03-26 10:33:20 +03:00
|
|
|
|
// Если файл не пустой
|
|
|
|
|
if (filesize($file) != 0)
|
2017-06-24 00:58:56 +03:00
|
|
|
|
{
|
2018-03-26 10:33:20 +03:00
|
|
|
|
// Получаем имя файла и его расширение (должно быть sql)
|
|
|
|
|
$file_name = basename($file);
|
|
|
|
|
$gz = substr($file_name, -3)=='.gz';
|
|
|
|
|
$end = substr($file_name, -3);
|
|
|
|
|
|
|
|
|
|
// Если расширение sql, тогда
|
|
|
|
|
if ($gz || $end == 'sql')
|
|
|
|
|
{
|
|
|
|
|
// Определяем флаг готовности к записи данных в БД
|
|
|
|
|
$insert = true;
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
// В противном случае, если расширение файла НЕ sql, формируем сообщение с ошибкой
|
|
|
|
|
$AVE_Template->assign('msg', '<li class="highlight red"><strong>Ошибка:</strong> ' . $AVE_Template->get_config_vars('MAIN_SQL_FILE_ERROR') . '</li>');
|
|
|
|
|
}
|
2017-06-24 00:58:56 +03:00
|
|
|
|
}
|
|
|
|
|
|
2018-03-26 10:33:20 +03:00
|
|
|
|
// Если флаг готовности записи установлен, тогда
|
|
|
|
|
if ($insert)
|
2017-06-24 00:58:56 +03:00
|
|
|
|
{
|
2018-03-26 10:33:20 +03:00
|
|
|
|
// Еще раз провреяем наличие загруженного файла
|
|
|
|
|
if ($file_name != '' && file_exists($file))
|
|
|
|
|
{
|
|
|
|
|
// Читаем данные из файла
|
|
|
|
|
$handle = @fopen($file, 'r');
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-03-26 10:33:20 +03:00
|
|
|
|
$db_q = @fread($handle, filesize($file));
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-03-26 10:33:20 +03:00
|
|
|
|
fclose($handle);
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-03-26 10:33:20 +03:00
|
|
|
|
if($gz)$db_q=gzdecode($db_q);
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-03-26 10:33:20 +03:00
|
|
|
|
$m_ok = 0;
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-03-26 10:33:20 +03:00
|
|
|
|
$m_fail = 0;
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-03-26 10:33:20 +03:00
|
|
|
|
// Формируем массив запросов ориентируясь по разделителю указанному в свойстве _delimiter
|
|
|
|
|
$querys = @explode($this->_delimiter, $db_q);
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-03-26 10:33:20 +03:00
|
|
|
|
// Циклически обрабатываем массив, выполняя каждый запрос
|
|
|
|
|
foreach ($querys as $val)
|
2017-06-24 00:58:56 +03:00
|
|
|
|
{
|
2018-03-26 10:33:20 +03:00
|
|
|
|
if (chop($val) != '')
|
|
|
|
|
{
|
|
|
|
|
$q = str_replace("\n",'',$val);
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-03-26 10:33:20 +03:00
|
|
|
|
$q = $q . ';';
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-03-26 10:33:20 +03:00
|
|
|
|
@$q = str_replace('%%PRFX%%', PREFIX, $q);
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-03-26 10:33:20 +03:00
|
|
|
|
if ($AVE_DB->Query($q))
|
|
|
|
|
{
|
|
|
|
|
$m_ok++;
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
$m_fail++;
|
|
|
|
|
}
|
2017-06-24 00:58:56 +03:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2018-03-26 10:33:20 +03:00
|
|
|
|
// Формируем сопроводительные сообщения
|
|
|
|
|
$msg = '<li class="highlight green"><strong>' . $AVE_Template->get_config_vars('MAIN_RESTORE_OK') . '</strong><br /><br />'
|
|
|
|
|
. $AVE_Template->get_config_vars('MAIN_TABLE_SUCC')
|
|
|
|
|
. '<strong>' . $m_ok . '</strong><br/> '
|
|
|
|
|
. $AVE_Template->get_config_vars('MAIN_TABLE_ERROR')
|
|
|
|
|
. '<strong><span style="color:red">' . $m_fail . '</span></strong></li>';
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-03-26 10:33:20 +03:00
|
|
|
|
$AVE_Template->assign('msg', $msg);
|
|
|
|
|
}
|
|
|
|
|
else // В противном случае, если файл не найден, формируем сообщение с ошибкой
|
|
|
|
|
{
|
|
|
|
|
$AVE_Template->assign('msg', '<li class="highlight red">'.$AVE_Template->get_config_vars('DB_REPORT_DUMP_ER').'</li>');
|
|
|
|
|
}
|
2017-06-24 00:58:56 +03:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Выполняем запись системного сообщения в журнал
|
2018-03-26 10:33:20 +03:00
|
|
|
|
reportLog($AVE_Template->get_config_vars('DB_REPORT_DUMP_RECOVER') . ' ('.$file_name.')');
|
2017-06-24 00:58:56 +03:00
|
|
|
|
}
|
|
|
|
|
|
2018-03-26 10:33:20 +03:00
|
|
|
|
/**
|
|
|
|
|
* Метод, предназначенный для оптимизации таблиц базы данных
|
|
|
|
|
*
|
|
|
|
|
*/
|
|
|
|
|
function databaseTableOptimize()
|
2017-06-24 00:58:56 +03:00
|
|
|
|
{
|
2018-03-26 10:33:20 +03:00
|
|
|
|
global $AVE_DB, $AVE_Template;
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-03-26 10:33:20 +03:00
|
|
|
|
if (! empty($_POST['ta']) && is_array($_POST['ta']))
|
|
|
|
|
{
|
|
|
|
|
// Выполняем запрос на оптимизацию
|
|
|
|
|
$AVE_DB->Query("OPTIMIZE TABLE `" . implode("`, `", $_POST['ta']) . "`");
|
|
|
|
|
|
|
|
|
|
// Выполняем запись системного сообщения в журнал
|
|
|
|
|
reportLog($AVE_Template->get_config_vars('DB_REPORT_DUMP_OPTIM'));
|
|
|
|
|
}
|
2017-06-24 00:58:56 +03:00
|
|
|
|
}
|
|
|
|
|
|
2018-03-26 10:33:20 +03:00
|
|
|
|
/**
|
|
|
|
|
* Метод, предназначенный для восстановления повреждённых таблиц базы данных
|
|
|
|
|
*
|
|
|
|
|
*/
|
|
|
|
|
function databaseTableRepair()
|
|
|
|
|
{
|
|
|
|
|
global $AVE_DB, $AVE_Template;
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-03-26 10:33:20 +03:00
|
|
|
|
if (! empty($_POST['ta']) && is_array($_POST['ta']))
|
|
|
|
|
{
|
|
|
|
|
// Выполняем запрос на восстановление
|
|
|
|
|
$AVE_DB->Query("REPAIR TABLE `" . implode("`, `", $_POST['ta']) . "`");
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-03-26 10:33:20 +03:00
|
|
|
|
// Выполняем запись системного сообщения в журнал
|
|
|
|
|
reportLog($AVE_Template->get_config_vars('DB_REPORT_DUMP_TABLE'));
|
|
|
|
|
}
|
|
|
|
|
}
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-03-26 10:33:20 +03:00
|
|
|
|
/**
|
|
|
|
|
* Метод, предназначенный для формирования списка всех таблиц в БД
|
|
|
|
|
*
|
|
|
|
|
* @return string
|
|
|
|
|
*/
|
|
|
|
|
function databaseTableGet()
|
2017-06-24 00:58:56 +03:00
|
|
|
|
{
|
2018-03-26 10:33:20 +03:00
|
|
|
|
global $AVE_DB;
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-03-26 10:33:20 +03:00
|
|
|
|
$tables = '';
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-03-26 10:33:20 +03:00
|
|
|
|
// Получаем список всех таблиц, которые имею префикс, указанный в конфигурации системы
|
|
|
|
|
$sql = $AVE_DB->Query("SHOW TABLES LIKE '" . PREFIX . "_%'");
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-03-26 10:33:20 +03:00
|
|
|
|
while ($row = $sql->FetchArray())
|
|
|
|
|
{
|
|
|
|
|
$tables .= '<option value="' . $row[0] . '" selected="selected">' . substr($row[0], 1+strlen(PREFIX)) . '</option>';
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
$sql->Close();
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-03-26 10:33:20 +03:00
|
|
|
|
// Возвращаем полученный список
|
|
|
|
|
return $tables;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Метод, предназначенный для вывода всех sql файлов в папке backup
|
|
|
|
|
*
|
|
|
|
|
* @return string
|
|
|
|
|
*/
|
|
|
|
|
function databaseFilesGet()
|
2017-06-24 00:58:56 +03:00
|
|
|
|
{
|
2018-04-19 19:11:58 +03:00
|
|
|
|
$dir = BASE_DIR . '/tmp/backup/';
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
2018-03-26 10:33:20 +03:00
|
|
|
|
if($handle = opendir($dir))
|
2017-06-24 00:58:56 +03:00
|
|
|
|
{
|
2018-03-26 10:33:20 +03:00
|
|
|
|
$files = array();
|
|
|
|
|
|
|
|
|
|
while (false !== ($file = readdir($handle)))
|
2017-06-24 00:58:56 +03:00
|
|
|
|
{
|
2018-03-26 10:33:20 +03:00
|
|
|
|
if ($file != "." && $file != ".." && (substr($file, -3) == 'sql' || substr($file, -2) == 'gz'))
|
2017-06-24 00:58:56 +03:00
|
|
|
|
{
|
2018-03-26 10:33:20 +03:00
|
|
|
|
if(is_file($dir . '/' . $file))
|
|
|
|
|
{
|
|
|
|
|
$files[] = array(
|
|
|
|
|
'name' => $file,
|
|
|
|
|
'data' => (filectime($dir . '/' . $file)),
|
|
|
|
|
'size' => (filesize($dir . '/' . $file))
|
|
|
|
|
);
|
|
|
|
|
}
|
2017-06-24 00:58:56 +03:00
|
|
|
|
}
|
|
|
|
|
}
|
2018-03-26 10:33:20 +03:00
|
|
|
|
closedir($handle);
|
2017-06-24 00:58:56 +03:00
|
|
|
|
}
|
|
|
|
|
|
2018-03-26 10:33:20 +03:00
|
|
|
|
return msort($files, 'data', null, SORT_DESC);
|
|
|
|
|
}
|
2017-06-24 00:58:56 +03:00
|
|
|
|
}
|
2018-03-26 10:33:20 +03:00
|
|
|
|
?>
|