Вход Регистрация
Файл: system/inc/dumper.php
Строк: 501
<?php
/***************************************************************************
| Sypex Dumper Lite          version 1.0.8b                                 |
| (c)2003-2006 zapimir       zapimir@zapimir.net       http://sypex.net/    |
| (c)2005-2006 BINOVATOR     info@sypex.net                                 |
|---------------------------------------------------------------------------|
|     created: 2003.09.02 19:07              modified: 2006.10.27 03:30     |
|---------------------------------------------------------------------------|
***************************************************************************/

if(!defined('MOZG'))
    die(
'Hacking attempt!');

header('Content-type: text/html; charset=windows-1251');

$lang = array('dumper_1'                =>    "Бэкап БД успешно создан в папке /backup/",
'dumper_2'                =>    "Создается резервная копия БД",
'dumper_3'                =>    "ОШИБКА! Не указана база данных!",
'dumper_4'                =>    "Не удается выбрать базу данных.<br />",
'dumper_5'                =>    "Создание файла с резервной копией БД:",
'dumper_6'                =>    "Не удается изменить кодировку соединения.<br />",
'dumper_7'                =>    "Установлена кодировка соединения",
'dumper_8'                =>    "Кодировка соединения и таблицы не совпадает:",
'dumper_9'                =>    "Таблица",
'dumper_10'                =>    "соединение",
'dumper_11'                =>    "Обработка таблицы",
'dumper_12'                =>    "Резервная копия БД",
'dumper_13'                =>    "создана.",
'dumper_14'                =>    "Размер БД:",
'dumper_15'                =>    "Размер файла:",
'dumper_16'                =>    "Таблиц обработано:",
'dumper_17'                =>    "Строк обработано:",
'dumper_18'                =>    "Восстановление БД из резервной копии",
'dumper_19'                =>    "ОШИБКА! Не указана база данных!",
'dumper_20'                =>    "Подключение к БД",
'dumper_21'                =>    "ОШИБКА! Файл не найден!",
'dumper_22'                =>    "Чтение файла",
'dumper_23'                =>    "Неправильный запрос.",
'dumper_24'                =>    "БД восстановлена из резервной копии.",
'dumper_25'                =>    "Дата создания копии:",
'dumper_26'                =>    "Запросов к БД:",
'dumper_27'                =>    "Таблиц создано:",
'dumper_28'                =>    "Строк добавлено:",
'dumper_29'                =>    "Статус таблицы:",
'dumper_30'                =>    "Общий статус:",
'dumper_31'                =>    "Возникла ошибка!"
);

if(
$user_info['user_group'] !=1){ msgbox("error"'error''error'); }
ob_end_flush();

define('PATH'ROOT_DIR.'/backup/');
define('URL',  'backup/');
define('TIME_LIMIT'600);
define('LIMIT'1);
define('DBNAMES'DBNAME);
define('DBNUSER'DBUSER);
define('DBPREFIX',PREFIX);

// Кодировка соединения с MySQL
// auto - автоматический выбор (устанавливается кодировка таблицы), cp1251 - windows-1251, и т.п.
define('CHARSET''auto');

// Кодировка соединения с MySQL при восстановлении
// На случай переноса со старых версий MySQL (до 4.1), у которых не указана кодировка таблиц в дампе
// При добавлении 'forced->', к примеру 'forced->cp1251', кодировка таблиц при восстановлении будет принудительно заменена на cp1251
// Можно также указывать сравнение нужное к примеру 'cp1251_ukrainian_ci' или 'forced->cp1251_ukrainian_ci'
define('RESTORE_CHARSET''cp1251');

define('SC'0);
// Типы таблиц у которых сохраняется только структура, разделенные запятой
define('ONLY_CREATE''MRG_MyISAM,MERGE,HEAP,MEMORY');

$is_safe_mode ini_get('safe_mode') == '1' 0;
if (!
$is_safe_mode && function_exists('set_time_limit')) @set_time_limit(TIME_LIMIT);

$timer array_sum(explode(' 'microtime()));
ob_implicit_flush();

$auth 0;
$error '';

    if (@
mysql_connect(DBHOSTDBNUSERDBPASS)){
        
$auth 1;
    }
    else{
        
$error '#' mysql_errno() . ': ' mysql_error();
    }

if (!
file_exists(PATH)) {
    @
mkdir(PATH0777) || die("Не удалось создать каталог для бекапа");
    @
chmod (PATH0777);
}

$SK = new dumper();
define('C_DEFAULT'1);
define('C_RESULT'2);
define('C_ERROR'3);
define('C_WARNING'4);

$action = isset($_REQUEST['action']) ? $_REQUEST['action'] : '';

switch(
$action){
    case 
'backup':
        
$SK->backup();
        break;
    case 
'restore':
        
$SK->restore();
        break;
    default:
        
$SK->main();
}

mysql_close();

        if(!
defined('AUTOMODE'))
        {
            echo 
"<SCRIPT>document.getElementById('timer').innerHTML = '" round(array_sum(explode(' 'microtime())) - $timer4) . " sec.'</SCRIPT>";
        }

class 
dumper {
    function 
dumper() {

        
$this->SET['last_action'] = 0;
        
$this->SET['last_db_backup'] = '';
        
$this->SET['tables'] = '';
        
$this->SET['comp_method'] = 2;
        
$this->SET['comp_level']  = 7;
        
$this->SET['last_db_restore'] = '';
        
$this->tabs 0;
        
$this->records 0;
        
$this->size 0;
        
$this->comp 0;

        
// Версия MySQL вида 40101
        
preg_match("/^(d+).(d+).(d+)/"mysql_get_server_info(), $m);
        
$this->mysql_version sprintf("%d%02d%02d"$m[1], $m[2], $m[3]);

        
$this->only_create explode(','ONLY_CREATE);
        
$this->forced_charset  false;
        
$this->restore_charset $this->restore_collate '';
        if (
preg_match("/^(forced->)?(([a-z0-9]+)(_w+)?)$/"RESTORE_CHARSET$matches)) {
            
$this->forced_charset  $matches[1] == 'forced->';
            
$this->restore_charset $matches[3];
            
$this->restore_collate = !empty($matches[4]) ? ' COLLATE ' $matches[2] : '';
        }
    }

    function 
backup() {
        global 
$lang;
        if (!isset(
$_POST['comp_method'])) $_POST['comp_method'] = $_GET['comp_method'];

        @
set_error_handler("SXD_errorHandler"E_ALL E_NOTICE);
        
$buttons "<span ID=save STYLE='display: none;'>{$lang['dumper_1']}</span>";
        echo 
tpl_page(tpl_process($lang['dumper_2']), $buttons);

        
$this->SET['last_action']     = 0;
        
$this->SET['last_db_backup']  = DBNAMES;
        
$this->SET['tables_exclude']  = 0;
        
$this->SET['tables']          = DBPREFIX.'*';
        
$this->SET['comp_method']     = isset($_POST['comp_method']) ? intval($_POST['comp_method']) : 0;
        
$this->SET['comp_level']      = 5;

        
$this->SET['tables']          = explode(","$this->SET['tables']);

            foreach(
$this->SET['tables'] AS $table){
                
$table preg_replace("/[^w*?^]/"""$table);
                
$pattern = array( "/?/""/*/");
                
$replace = array( "."".*?");
                
$tbls[] = preg_replace($pattern$replace$table);
            }

        if (
$this->SET['comp_level'] == 0) {
            
$this->SET['comp_method'] = 0;
        }
        
$db $this->SET['last_db_backup'];

        if (!
$db) {
            echo 
tpl_l($lang['dumper_3'], C_ERROR);
            exit;
        }
        echo 
tpl_l("{$lang['dumper_20']} `{$db}`.");
        
mysql_select_db($db) or trigger_error ($lang['dumper_4'] . mysql_error(), E_USER_ERROR);
        
$tables = array();
        
$result mysql_query("SHOW TABLES");
        
$all 0;
        while(
$row mysql_fetch_array($result)) {
            
$status 0;
            if (!empty(
$tbls)) {
                foreach(
$tbls AS $table){
                    
$exclude preg_match("/^^/"$table) ? true false;
                    if (!
$exclude) {
                        if (
preg_match("/^{$table}$/i"$row[0])) {
                            
$status 1;
                        }
                        
$all 1;
                    }
                    if (
$exclude && preg_match("/{$table}$/i"$row[0])) {
                        
$status = -1;
                    }
                }
            }
            else {
                
$status 1;
            }
            if (
$status >= $all) {
                
$tables[] = $row[0];
            }
        }

        
$tabs count($tables);
        
// Определение размеров таблиц
        
$result mysql_query("SHOW TABLE STATUS");
        
$tabinfo = array();
        
$tab_charset = array();
        
$tab_type = array();
        
$tabinfo[0] = 0;
        
$info '';
        while(
$item mysql_fetch_assoc($result)){
            
//print_r($item);
            
if(in_array($item['Name'], $tables)) {
                
$item['Rows'] = empty($item['Rows']) ? $item['Rows'];
                
$tabinfo[0] += $item['Rows'];
                
$tabinfo[$item['Name']] = $item['Rows'];
                
$this->size += $item['Data_length'];
                
$tabsize[$item['Name']] = round(LIMIT 1048576 / ($item['Avg_row_length'] + 1));
                if(
$item['Rows']) $info .= "|" $item['Rows'];
                if (!empty(
$item['Collation']) && preg_match("/^([a-z0-9]+)_/i"$item['Collation'], $m)) {
                    
$tab_charset[$item['Name']] = $m[1];
                }
                
$tab_type[$item['Name']] = isset($item['Engine']) ? $item['Engine'] : $item['Type'];
            }
        }
        
$show 10 $tabinfo[0] / 50;
        
$info $tabinfo[0] . $info;

        
$salt "abchefghjkmnpqrstuvwxyz0123456789";
        
// srand((double)microtime()*1000000);
        
$rand "";

        for(
$i=0;$i 9$i++) {
            
$rand .= $salt{rand(0,33)};
        }

        if(!
defined('AUTOMODE'))
        {

          
$name $db '_' date("Y-m-d_H-i"). '_' substrmd5(date("Y-m-d_H-i").DBHOST DBNAME), 05);

        } else {

           
$name date("Y-m-d_H-i") . '_' $db '_' md5($rand);

        }


        
$fp $this->fn_open($name"w");
        echo 
tpl_l($lang['dumper_5']);
        
$this->fn_write($fp"#SKD101|{$db}|{$tabs}|" date("Y.m.d H:i:s") ."|{$info}nn");
        
$t=0;
        echo 
tpl_l(str_repeat("-"60));
        
$result mysql_query("SET SQL_QUOTE_SHOW_CREATE = 1");
        
// Кодировка соединения по умолчанию
        
if ($this->mysql_version 40101 && CHARSET != 'auto') {
            
mysql_query("SET NAMES '" CHARSET "'") or trigger_error ($lang['dumper_6'] . mysql_error(), E_USER_ERROR);
            
$last_charset CHARSET;
        }
        else{
            
$last_charset '';
        }
        foreach (
$tables AS $table){
            
// Выставляем кодировку соединения соответствующую кодировке таблицы
            
if ($this->mysql_version 40101 && $tab_charset[$table] != $last_charset) {
                if (
CHARSET == 'auto') {
                    
mysql_query("SET NAMES '" $tab_charset[$table] . "'") or trigger_error ($lang['dumper_6'] . mysql_error(), E_USER_ERROR);
                    echo 
tpl_l("{$lang['dumper_7']} `" $tab_charset[$table] . "`."C_WARNING);
                    
$last_charset $tab_charset[$table];
                }
                else{
                    echo 
tpl_l($lang['dumper_8'], C_ERROR);
                    echo 
tpl_l($lang['dumper_9'].' `'$table .'` -> ' $tab_charset[$table] . ' ('.$lang['dumper_10'].' '  CHARSET ')'C_ERROR);
                }
            }
            echo 
tpl_l("{$lang['dumper_11']} `{$table}` [" fn_int($tabinfo[$table]) . "].");
            
// Создание таблицы
            
$result mysql_query("SHOW CREATE TABLE `{$table}`");
            
$tab mysql_fetch_array($result);
            
$tab preg_replace('/(default CURRENT_TIMESTAMP on update CURRENT_TIMESTAMP|DEFAULT CHARSET=w+|COLLATE=w+|character set w+|collate w+)/i''/*!40101 \1 */'$tab);
            
$this->fn_write($fp"DROP TABLE IF EXISTS `{$table}`;n{$tab[1]};nn");
            
// Проверяем нужно ли дампить данные
            
if (in_array($tab_type[$table], $this->only_create)) {
                continue;
            }
            
// Опредеделяем типы столбцов
            
$NumericColumn = array();
            
$result mysql_query("SHOW COLUMNS FROM `{$table}`");
            
$field 0;
            while(
$col mysql_fetch_row($result)) {
                
$NumericColumn[$field++] = preg_match("/^(w*int|year)/"$col[1]) ? 0;
            }
            
$fields $field;
            
$from 0;
            
$limit $tabsize[$table];
            
$limit2 round($limit 3);
            if (
$tabinfo[$table] > 0) {
            if (
$tabinfo[$table] > $limit2) {
                echo 
tpl_s(0$t $tabinfo[0]);
            }
            
$i 0;
            
$this->fn_write($fp"INSERT INTO `{$table}` VALUES");
            while((
$result mysql_query("SELECT * FROM `{$table}` LIMIT {$from}{$limit}")) && ($total mysql_num_rows($result))){
                    while(
$row mysql_fetch_row($result)) {
                        
$i++;
                        
$t++;

                        for(
$k 0$k $fields$k++){
                            if (
$NumericColumn[$k])
                                
$row[$k] = isset($row[$k]) ? $row[$k] : "NULL";
                            else
                                
$row[$k] = isset($row[$k]) ? "'" mysql_escape_string($row[$k]) . "'" "NULL";
                        }

                        
$this->fn_write($fp, ($i == "" ",") . "n(" implode(", "$row) . ")");
                        if (
$i $limit2 == 0)
                            echo 
tpl_s($i $tabinfo[$table], $t $tabinfo[0]);
                       }
                    
mysql_free_result($result);
                    if (
$total $limit) {
                        break;
                    }
                    
$from += $limit;
            }

            
$this->fn_write($fp";nn");
            echo 
tpl_s(1$t $tabinfo[0]);}
        }
        
$this->tabs $tabs;
        
$this->records $tabinfo[0];
        
$this->comp $this->SET['comp_method'] * 10 $this->SET['comp_level'];
        echo 
tpl_s(11);
        echo 
tpl_l(str_repeat("-"60));
        
$this->fn_close($fp);
        echo 
tpl_l("{$lang['dumper_12']} `{$db}{$lang['dumper_13']}"C_RESULT);
        echo 
tpl_l("{$lang['dumper_14']}       " round($this->size 10485762) . " MB"C_RESULT);
        
$filesize round(filesize(PATH $this->filename) / 10485762) . " MB";
        echo 
tpl_l("{$lang['dumper_15']} {$filesize}"C_RESULT);
        echo 
tpl_l("{$lang['dumper_16']} {$tabs}"C_RESULT);
        echo 
tpl_l("{$lang['dumper_17']}   " fn_int($tabinfo[0]), C_RESULT);

        if(!
defined('AUTOMODE'))
        {
            echo 
"<SCRIPT>if (document.getElementById('save')) {document.getElementById('save').style.display = ''; }</SCRIPT>";
        }

    }

    function 
restore(){
        global 
$config$lang;

        if (!isset(
$_POST['file'])) $_POST['file'] = $_GET['file'];

        @
set_error_handler("SXD_errorHandler"E_ALL E_NOTICE);
        
$buttons "";
        echo 
tpl_page(tpl_process($lang['dumper_18']), $buttons);

        
$this->SET['last_action']     = 1;
        
$this->SET['last_db_restore'] = DBNAMES;
        
$file                          = isset($_POST['file']) ? $_POST['file'] : '';

        
$file str_replace"\", "/", $file );
        
$file = str_replace( "..", "", $file );
        
$file = str_replace( "/", "", $file );

        if( stripos ( 
$file, "php" ) !== false ) die("Hacking attempt!");

        
$db = $this->SET['last_db_restore'];

        if (!
$db) {
            echo tpl_l(
$lang['dumper_19'], C_ERROR);
            exit;
        }
        echo tpl_l("
{$lang['dumper_20']} `{$db}`.");
        mysql_select_db(
$db) or trigger_error ($lang['dumper_4'] . mysql_error(), E_USER_ERROR);

        // Определение формата файла
        if(preg_match("
/^(.+?).sql(.(bz2|gz))?$/", $file$matches)) {
            if (isset(
$matches[3]) && $matches[3] == 'bz2') {
                
$this->SET['comp_method'] = 2;
            }
            elseif (isset(
$matches[2]) &&$matches[3] == 'gz'){
                
$this->SET['comp_method'] = 1;
            }
            else{
                
$this->SET['comp_method'] = 0;
            }
            
$this->SET['comp_level'] = '';
            if (!file_exists(PATH . "
/{$file}")) {
                echo tpl_l(
$lang['dumper_21'], C_ERROR);
                exit;
            }
            echo tpl_l("
{$lang['dumper_22']} `{$file}`.");
            
$file = $matches[1];
        }
        else{
            echo tpl_l(
$lang['dumper_21'], C_ERROR);
            exit;
        }
        echo tpl_l(str_repeat("
-", 60));
        
$fp = $this->fn_open($file, "r");
        
$this->file_cache = $sql = $table = $insert = '';
        
$is_skd = $query_len = $execute = $q =$t = $i = $aff_rows = 0;
        
$limit = 300;
        
$index = 4;
        
$tabs = 0;
        
$cache = '';
        
$info = array();
        
$convert=false;

        // Установка кодировки соединения
        if (
$this->mysql_version > 40101 && (CHARSET != 'auto' || $this->forced_charset)) { // Кодировка по умолчанию, если в дампе не указана кодировка
            mysql_query("
SET NAMES '" . $this->restore_charset . "'") or trigger_error ($lang['dumper_6'] . mysql_error(), E_USER_ERROR);
            echo tpl_l("
{$lang['dumper_7']} `" . $this->restore_charset . "`.", C_WARNING);
            
$last_charset = $this->restore_charset;
        }
        else {
            
$last_charset = '';
        }
        
$last_showed = '';
        while((
$str = $this->fn_read_str($fp)) !== false){
            if (empty(
$str) || preg_match("/^(#|--)/", $str)) {
                
if (!$is_skd && preg_match("/^#SKD101|/"$str)) {
                    
$info explode("|"$str);
                    echo 
tpl_s(0$t $info[4]);
                    
$is_skd 1;
                }
                continue;
            }
            
$query_len += strlen($str);

            if (!
$insert && preg_match("/^(INSERT INTO `?([^` ]+)`? .*?VALUES)(.*)$/i"$str$m)) {
                if (
$table != $m[2]) {
                    
$table $m[2];
                    
$tabs++;
                    
$cache .= tpl_l("Таблица `{$table}`.");
                    
$last_showed $table;
                    
$i 0;
                    if (
$is_skd)
                        echo 
tpl_s(100 $t $info[4]);
                }
                
$insert $m[1] . ' ';
                
$sql .= $m[3];
                
$index++;
                
$info[$index] = isset($info[$index]) ? $info[$index] : 0;
                
$limit round($info[$index] / 20);
                
$limit $limit 300 300 $limit;
                if (
$info[$index] > $limit){
                    echo 
$cache;
                    
$cache '';
                    echo 
tpl_s($info[$index], $t $info[4]);
                }
            }
            else{
                
$sql .= $str;
                if (
$insert) {
                    
$i++;
                    
$t++;
                    if (
$is_skd && $info[$index] > $limit && $t $limit == 0){
                        echo 
tpl_s($i $info[$index], $t $info[4]);
                    }
                }
            }

            if (!
$insert && preg_match("/^CREATE TABLE (IF NOT EXISTS )?`?([^` ]+)`?/i"$str$m) && $table != $m[2]){
                
$table $m[2];
                
$insert '';
                
$tabs++;
                
$is_create true;
                
$i 0;
            }
            if (
$sql) {
                if (
preg_match("/;$/"$str)) {
                    
$sql rtrim($insert $sql";");
                    if (empty(
$insert)) {
                        if (
$this->mysql_version 40101) {
                            
$sql preg_replace("/ENGINEs?=/""TYPE="$sql);
                        }
                        elseif (
preg_match("/CREATE TABLE/i"$sql)){
                            
// Выставляем кодировку соединения
                            
if (preg_match("/(CHARACTER SET|CHARSET)[=s]+(w+)/i"$sql$charset)) {
                                if (!
$this->forced_charset && $charset[2] != $last_charset) {
                                    if (
CHARSET == 'auto') {

                                        if (
$config['charset'] == "utf-8" AND $charset[2] == "cp1251" ) { $convert=true$charset[2] = "utf8"$this->restore_charset "utf8"; }

                                        
mysql_query("SET NAMES '" $charset[2] . "'") or trigger_error ("{$lang['dumper_6']}{$sql}<BR>" mysql_error(), E_USER_ERROR);
                                        
$cache .= tpl_l("{$lang['dumper_7']} `" $charset[2] . "`."C_WARNING);
                                        
$last_charset $charset[2];
                                    }
                                    else{
                                        
$cache .= tpl_l($lang['dumper_8'], C_ERROR);
                                        
$cache .= tpl_l($lang['dumper_9'].' `'$table .'` -> ' $charset[2] . ' ('.$lang['dumper_10'].' '  $this->restore_charset ')'C_ERROR);
                                    }
                                }
                                
// Меняем кодировку если указано форсировать кодировку
                                
if ($this->forced_charset OR $convert) {
                                    
$sql preg_replace("/(/*!d+s)?((COLLATE)[=s]+)w+(s+*/)?/i"''$sql);
                                    
$sql preg_replace("/((CHARACTER SET|CHARSET)[=s]+)w+/i""\1" $this->restore_charset $this->restore_collate$sql);
                                }
                            }
                            elseif(
CHARSET == 'auto'){ // Вставляем кодировку для таблиц, если она не указана и установлена auto кодировка
                                
$sql .= ' DEFAULT CHARSET=' $this->restore_charset $this->restore_collate;
                                if (
$this->restore_charset != $last_charset) {
                                    
mysql_query("SET NAMES '" $this->restore_charset "'") or trigger_error ("{$lang['dumper_6']}{$sql}<BR>" mysql_error(), E_USER_ERROR);
                                    
$cache .= tpl_l("{$lang['dumper_7']} `" $this->restore_charset "`."C_WARNING);
                                    
$last_charset $this->restore_charset;
                                }
                            }
                        }
                        if (
$last_showed != $table) {$cache .= tpl_l("{$lang['dumper_9']} `{$table}`."); $last_showed $table;}
                    }
                    elseif(
$this->mysql_version 40101 && empty($last_charset)) { // Устанавливаем кодировку на случай если отсутствует CREATE TABLE
                        
mysql_query("SET $this->restore_charset '" $this->restore_charset "'") or trigger_error ("{$lang['dumper_6']}{$sql}<BR>" mysql_error(), E_USER_ERROR);
                        echo 
tpl_l("{$lang['dumper_7']} `" $this->restore_charset "`."C_WARNING);
                        
$last_charset $this->restore_charset;
                    }
                    
$insert '';
                    
$execute 1;
                }
                if (
$query_len >= 65536 && preg_match("/,$/"$str)) {
                    
$sql rtrim($insert $sql",");
                    
$execute 1;
                }
                if (
$execute) {
                    
$q++;
                    if (
$convert$sql iconv'WINDOWS-1251''UTF-8//IGNORE'$sql );
                    
mysql_query($sql) or trigger_error ($lang['dumper_23'] . mysql_error(), E_USER_ERROR);
                    if (
preg_match("/^insert/i"$sql)) {
                        
$aff_rows += mysql_affected_rows();
                    }
                    
$sql '';
                    
$query_len 0;
                    
$execute 0;
                }
            }
        }
        echo 
$cache;
        echo 
tpl_s(1);
        echo 
tpl_l(str_repeat("-"60));
        echo 
tpl_l($lang['dumper_24'], C_RESULT);
        if (isset(
$info[3])) echo tpl_l("{$lang['dumper_25']} {$info[3]}"C_RESULT);
        echo 
tpl_l("{$lang['dumper_26']} {$q}"C_RESULT);
        echo 
tpl_l("{$lang['dumper_27']} {$tabs}"C_RESULT);
        echo 
tpl_l("{$lang['dumper_28']} {$aff_rows}"C_RESULT);

        
$this->tabs $tabs;
        
$this->records $aff_rows;
        
$this->size filesize(PATH $this->filename);
        
$this->comp $this->SET['comp_method'] * 10 $this->SET['comp_level'];

        
$this->fn_close($fp);
    }

    function 
main(){
        die(
"Hacking attempt!");
    }

    function 
db_select(){
        if (
DBNAMES != '') {
            
$items explode(','trim(DBNAMES));
            foreach(
$items AS $item){
                if (
mysql_select_db($item)) {
                    
$tables mysql_query("SHOW TABLES");
                    if (
$tables) {
                          
$tabs mysql_num_rows($tables);
                          
$dbs[$item] = "{$item} ({$tabs})";
                      }
                }
            }
        }
        else {
            
$result mysql_query("SHOW DATABASES");
            
$dbs = array();
            while(
$item mysql_fetch_array($result)){
                if (
mysql_select_db($item[0])) {
                    
$tables mysql_query("SHOW TABLES");
                    if (
$tables) {
                          
$tabs mysql_num_rows($tables);
                          
$dbs[$item[0]] = "{$item[0]} ({$tabs})";
                      }
                }
            }
        }
        return 
$dbs;
    }

    function 
file_select(){
        
$files = array('' => ' ');
        if (
is_dir(PATH) && $handle opendir(PATH)) {
            while (
false !== ($file readdir($handle))) {
                if (
preg_match("/^.+?.sql(.(gz|bz2))?$/"$file)) {
                    
$files[$file] = $file;
                }
            }
            
closedir($handle);
        }
        
ksort($files);
        return 
$files;
    }

    function 
fn_open($name$mode){
        if (
$this->SET['comp_method'] == 2) {
            
$this->filename "{$name}.sql.bz2";
            return 
bzopen(PATH $this->filename"{$mode}");
        }
        elseif (
$this->SET['comp_method'] == 1) {
            
$this->filename "{$name}.sql.gz";
            return 
gzopen(PATH $this->filename"{$mode}b{$this->SET['comp_level']}");
        }
        else{
            
$this->filename "{$name}.sql";
            return 
fopen(PATH $this->filename"{$mode}b");
        }
    }

    function 
fn_write($fp$str){
        if (
$this->SET['comp_method'] == 2) {
            
bzwrite($fp$str);
        }
        elseif (
$this->SET['comp_method'] == 1) {
            
gzwrite($fp$str);
        }
        else{
            
fwrite($fp$str);
        }
    }

    function 
fn_read($fp){
        if (
$this->SET['comp_method'] == 2) {
            return 
bzread($fp4096);
        }
        elseif (
$this->SET['comp_method'] == 1) {
            return 
gzread($fp4096);
        }
        else{
            return 
fread($fp4096);
        }
    }

    function 
fn_read_str($fp){
        
$string '';
        
$this->file_cache ltrim($this->file_cache);
        
$pos strpos($this->file_cache"n"0);
        if (
$pos 1) {
            while (!
$string && ($str $this->fn_read($fp))){
                
$pos strpos($str"n"0);
                if (
$pos === false) {
                    
$this->file_cache .= $str;
                }
                else{
                    
$string $this->file_cache substr($str0$pos);
                    
$this->file_cache substr($str$pos 1);
                }
            }
            if (!
$str) {
                if (
$this->file_cache) {
                    
$string $this->file_cache;
                    
$this->file_cache '';
                    return 
trim($string);
                }
                return 
false;
            }
        }
        else {
              
$string substr($this->file_cache0$pos);
              
$this->file_cache substr($this->file_cache$pos 1);
        }
        return 
trim($string);
    }

    function 
fn_close($fp){
        if (
$this->SET['comp_method'] == 2) {
            
bzclose($fp);
        }
        elseif (
$this->SET['comp_method'] == 1) {
            
gzclose($fp);
        }
        else{
            
fclose($fp);
        }
        @
chmod(PATH $this->filename0666);
        
$this->fn_index();
    }

    function 
fn_select($items$selected){
        
$select '';
        foreach(
$items AS $key => $value){
            
$select .= $key == $selected "<OPTION VALUE='{$key}' SELECTED>{$value}"<OPTION VALUE='{$key}'>{$value}";
        }
        return 
$select;
    }

    function 
fn_save(){
        return;
    }

    function 
fn_index(){
        if (!
file_exists(PATH 'index.html')) {
            
$fh fopen(PATH 'index.html''wb');
            
fwrite($fhtpl_backup_index());
            
fclose($fh);
        }
    }
}

function 
fn_int($num){
    return 
number_format($num0','' ');
}

function 
fn_arr2str($array) {
    
$str "array(n";
    foreach (
$array as $key => $value) {
        if (
is_array($value)) {
            
$str .= "'$key' => " fn_arr2str($value) . ",nn";
        }
        else {
            
$str .= "'$key' => '" str_replace("'""'"$value) . "',n";
        }
    }
    return 
$str ")";
}

// Шаблоны

function tpl_page($content ''$buttons ''){
    global 
$config;

    if(
defined('AUTOMODE'))
    {
    
      return;
    
    }

return <<<HTML
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="ru" lang="ru">
<head>
<META HTTP-EQUIV=Content-Type CONTENT="text/html; charset=
{$config['charset']}">
<meta http-equiv="X-UA-Compatible" content="IE=7" />

<STYLE TYPE="TEXT/CSS">
<!--
body{
    overflow: auto;
}
form {
margin:0px;
padding: 0px;
}

table{
border:0px;
border-collapse:collapse;
}

table td{
padding:0px;
font-size: 11px;
font-family: tahoma;
}

input, select, div {
    font: 11px tahoma, verdana, arial;
}
input.text, select {
    width: 100%;
}
fieldset {
    margin-bottom: 10px;
}
.unterline {
    background: url(engine/skins/images/line_bg.gif);
    width: 100%;
    height: 9px;
    font-size: 3px;
    font-family: tahoma;
    margin-bottom: 4px;
}
.hr_line {
    background: url(engine/skins/images/line.gif);
    width: 100%;
    height: 7px;
    font-size: 3px;
    font-family: tahoma;
    margin-top: 4px;
    margin-bottom: 4px;
}
-->
</STYLE>
</head>
<body>

<table width="100%">
    <tr>
        <td>
<TD VALIGN=TOP STYLE="padding: 8px 8px;">
{$content}
<TABLE WIDTH=100% BORDER=0 CELLSPACING=0 CELLPADDING=2>
<TR>
<TD STYLE='color: #CECECE' ID=timer></TD>
<TD ALIGN=RIGHT>
{$buttons}</TD>
</TR>
</TABLE></TD>
</td>
    </tr>
</table>



</body>
</HTML>
HTML;
}

function 
tpl_process($title){
    global 
$lang;

    if(
defined('AUTOMODE'))
    {
    
      return;
    
    }

return <<<HTML
<TABLE WIDTH=100% BORDER=0 CELLSPACING=0 CELLPADDING=2>
<TR><TD COLSPAN=2 style="padding:2px;"><DIV ID=logarea STYLE="width: 99%; height: 140px; border: 1px solid #7F9DB9; padding: 3px; overflow: auto;"></DIV></TD></TR>
<TR><TD WIDTH=31% style="padding:2px; width:100px;">
{$lang['dumper_29']}</TD><TD><TABLE WIDTH=100% style="border: 1px solid #7F9DB9;" CELLPADDING=0 CELLSPACING=0>
<TR><TD BGCOLOR=#FFFFFF><TABLE WIDTH=1 BORDER=0 CELLPADDING=0 CELLSPACING=0 BGCOLOR=#5555CC ID=st_tab
STYLE="background: #5c9ccc url(system/inc/images/ui-bg_gloss-wave_55_5c9ccc_500x100.png) 50% 50% repeat-x;";
border-right: 1px solid #AAAAAA"><TR><TD HEIGHT=12></TD></TR></TABLE></TD></TR></TABLE></TD></TR>
<TR><TD style="padding:2px; width:100px;">
{$lang['dumper_30']}</TD><TD><TABLE WIDTH=100% style="border: 1px solid #7F9DB9;" CELLSPACING=0 CELLPADDING=0>
<TR><TD BGCOLOR=#FFFFFF><TABLE WIDTH=1 BORDER=0 CELLPADDING=0 CELLSPACING=0 BGCOLOR=#00AA00 ID=so_tab
STYLE="background: #5c9ccc url(system/inc/images/ui-bg_gloss-wave_55_5c9ccc_500x100.png) 50% 50% repeat-x;";
border-right: 1px solid #AAAAAA"><TR><TD HEIGHT=12></TD></TR></TABLE></TD>
</TR></TABLE></TD></TR></TABLE>
<SCRIPT>
var WidthLocked = false;
function s(st, so){
    document.getElementById('st_tab').width = st ? st + '%' : '1';
    document.getElementById('so_tab').width = so ? so + '%' : '1';
}
function l(str, color){
    switch(color){
        case 2: color = 'navy'; break;
        case 3: color = 'red'; break;
        case 4: color = 'maroon'; break;
        default: color = 'black';
    }
    with(document.getElementById('logarea')){
        if (!WidthLocked){
            style.width = clientWidth;
            WidthLocked = true;
        }
        str = '<FONT COLOR=' + color + '>' + str + '</FONT>';
        innerHTML += innerHTML ? "<BR>\n" + str : str;
        scrollTop += 14;
    }
}
</SCRIPT>
HTML;
}

function 
tpl_l($str$color C_DEFAULT){

if(
defined('AUTOMODE'))
{

  return;

}

$str preg_replace("/s{2}/"" &nbsp;"$str);
return <<<HTML
<SCRIPT>l('{$str}', $color);</SCRIPT>

HTML;
}

function 
tpl_s($st$so){

if(
defined('AUTOMODE'))
{

  return;

}

$st round($st 100);
$st $st 100 100 $st;
$so round($so 100);
$so $so 100 100 $so;
return <<<HTML
<SCRIPT>s({$st},{$so});</SCRIPT>

HTML;
}

function 
tpl_backup_index(){

if(
defined('AUTOMODE'))
{

  return;

}

return <<<HTML
<CENTER>
<H1>access denied</H1>
</CENTER>

HTML;
}

function 
tpl_error($error){

if(
defined('AUTOMODE'))
{

  return;

}

return <<<HTML
<TABLE WIDTH=100% BORDER=0 CELLSPACING=0 CELLPADDING=2>
<TR>
<TD ALIGN=center>
{$error}</TD>
</TR>
</TABLE>
HTML;
}

function 
SXD_errorHandler($errno$errmsg$filename$linenum$vars) {
    global 
$lang;
    if (
$errno == 2048) return true;
    if (
strpos $errmsg"chmod():" ) !== false) return true;
    
$dt date("Y.m.d H:i:s");
    
$errmsg addslashes($errmsg);

    echo 
tpl_l("{$dt}<BR><B>{$lang['dumper_31']}</B>"C_ERROR);
    echo 
tpl_l("{$errmsg} ({$errno})"C_ERROR);
    die();
}
?>
Онлайн: 1
Реклама