Seditio Source
Root |
./othercms/slaed_cms_6.2_pro/plugins/sxd/info.php
<?php
// Sypex Dumper 2
header("Content-Type: text/html; charset=utf-8");
error_reporting(0);
set_error_handler("sxd_error");
if(!empty(
$_POST['ajax']['job']) && preg_match("/^[\w-]+$/", $_POST['ajax']['job'])){
   
$d = date("'Y.m.d H:i:s'");
    if(!empty(
$_COOKIE['sxd'])) {
        include(
'ses.php');
        if(!empty(
$SES[$_COOKIE['sxd']])) {
           
$CFG = &$SES[$_COOKIE['sxd']]['cfg'];
            include(
load_lang($SES[$_COOKIE['sxd']]['lng']));
        }
    }
    if(empty(
$LNG)) {
        include(
'cfg.php');
        include(
load_lang($CFG['lang']));
        if(!empty(
$CFG['auth'])) {echo "sxd.log.add({$d},[" . esc($LNG['stop_5']) . " (1)]);sxd.hideLoading();"; exit;}
    }
   
$job_name = $_POST['ajax']['job'];
   
$log_seek = !empty($_POST['ajax']['lseek']) ? (int) $_POST['ajax']['lseek'] : 0;
   
$job_file = "{$CFG['backup_path']}{$job_name}.job.php";
    if (!
file_exists($job_file)) exit;
    include(
$job_file);
    switch(
$_POST['ajax']['act']) {
        case
'info':
            if (!
file_exists($JOB['file_rtl'])) exit;
           
$fh = fopen($JOB['file_rtl'], 'r+b');
           
$time = time();
           
$f = explode("\t", fgets($fh));
            if(empty(
$f[0])) $f[0] = $time;
           
$pt = !empty($f[2]) ? round(100 * $f[10] / $f[2], 2) : 100;
           
$pc = !empty($f[8]) ? round(100 * $f[7] / $f[8], 2) : 100;
           
$lh = fopen($JOB['file_log'], 'rb');
           
fseek($lh, $log_seek);
           
$rawlog = fread($lh, 8192);
           
$log = '';
           
$old_time = '';
           
$logs = array();
            if(!empty(
$rawlog)){
               
$temp = explode("\n", $rawlog);
                foreach(
$temp AS $l){
                    if(empty(
$l)) continue;
                   
$t = explode("\t", $l);
                    if(
count($t) < 3) continue;
                    if(
$t[0] != $old_time){
                        if(!empty(
$logs)) $log .= "sxd.log.add('{$old_time}',[" . implode(',', $logs) . "]);";
                       
$old_time = $t[0];
                       
$logs = array();
                    }
                   
$logs[] = esc($t[2]);    
                }
                if(!empty(
$logs)) $log .= "sxd.log.add('{$old_time}',[" . implode(',', $logs) . "]);";
            }
           
$log_seek = ftell($lh);
            echo
$log . "sxd.job.log_seek = {$log_seek};";
           
// Читаем лог
           
if($f[4] == 'EOJ') {
               
$pt = $pc = 100;
               
fclose($lh);
               
fclose($fh);
                if (
function_exists('usleep')) usleep(400000);
                else
sleep(1);
                if(
$JOB['act'] == 'backup') $f[3] = filesize(file_exists($JOB['file_name']) ? $JOB['file_name'] : $JOB['file_tmp']);
               
// Обновляем список файлов
               
if($JOB['act'] == 'backup') print "sxd.actions.filelist(); z('btn_down').file = '{$JOB['file']}'; z('btn_down').style.display = '';";
                echo
"sxd.timer.set({$f[0]},{$f[1]},{$pt});sxd.progress.current.set({$pc}, 0, {$f[8]}, {$f[8]});sxd.progress.total.set({$pt},{$f[3]});";
                echo
"sxd.log.add({$d},['{$LNG['job_done']}', '{$LNG['js']['records']}: {$f[10]}', '{$LNG['file_size']}: ' + sxd.formatSize({$f[3]},2), '{$LNG['job_time']}: {$f[5]} {$LNG['seconds']}']);sxd.hideLoading();";
               
unlink($JOB['file_log']);
               
unlink($JOB['file_rtl']);
               
unlink($job_file);
            }
            else if(
$f[9] > 0){
                echo
"sxd.log.add({$d},[" . esc($LNG['stop_' . $f[9]]) . "]);" . (($f[9] == 3 || $f[9] == 4) ? 'sxd.resumeJob();' : 'sxd.hideLoading();');
            }
            else{
                if(
$JOB['act'] == 'backup') $f[3] = filesize(file_exists($JOB['file_name']) ? $JOB['file_name'] : $JOB['file_tmp']);
                if(
$f[4] != 'EK' && time() > $f[1] + 45) {
                   
fopen($JOB['file_stp'],'w');
                   
$f[9] = 0;
                   
$f[1] = $time;
                   
fwrite($fh, implode("\t", $f) . "\n");
                    echo
"sxd.log.add({$d},[" . esc($LNG['job_freeze']) . "]);sxd.hideLoading();z('btn_resume').style.display = '';z('btn_pause').style.display = 'none';";
                }
                echo
"sxd.timer.set({$f[0]},{$time},{$pt});sxd.progress.current.set({$pc},0,{$f[7]}, {$f[8]});sxd.progress.total.set({$pt},{$f[3]});";    
            }
        break;
        case
'stop':
           
$fs = fopen($JOB['file_stp'],'w');
           
fwrite($fs, 1);
            echo
"sxd.log.add({$d},[" . esc($LNG['stop_job']) . "]);";
        break;
        case
'pause':
           
fopen($JOB['file_stp'],'w');
            echo
"sxd.log.add({$d},[" . esc($LNG['stop_job']) . "]);";
        break;
    }
}
else echo
"sxd.hideLoading();";    

function
load_lang($lng_name = 'auto'){
    if(
$lng_name == 'auto'){
        include(
'lang/list.php');
       
$lng = 'en';
        if(
preg_match_all('/[a-z]{2}(-[a-z]{2})?/', $_SERVER['HTTP_ACCEPT_LANGUAGE'], $m)) {
            foreach(
$m[0] AS $l){
                if(isset(
$langs[$l])){
                   
$lng_name = $l;
                    break;
                }
            }
        }
    }
    if(
file_exists("lang/lng_{$lng_name}.php")) return "lang/lng_{$lng_name}.php";
    else return
"lang/lng_en.php";
}
function
esc($str){
    return
"'" . addcslashes($str, "\\\0\n\r\t\'") . "'";
}

function
sxd_error($errno, $errmsg, $filename, $linenum, $vars){
    global
$JOB;
    if(
$errno == 8192) return;
    if(
strpos($errmsg, 'timezone settings')) return;
    if(!empty(
$JOB['file_stp'])) fopen($JOB['file_stp'],'w');
   
$errortype = array(1 => 'Error', 2 => 'Warning', 4 => 'Parsing Error', 8 => 'Notice', 16 => 'Core Error', 32 => 'Core Warning', 64 => 'Compile Error',
                       
128 => 'Compile Warning', 256 => 'User Error', 512 => 'User Warning', 1024 => 'User Notice');
   
$str = "{$errortype[$errno]}: {$errmsg} ({$filename}:{$linenum})";
   
//error_log("[info.php]\n{$str}\n", 3, "error.log");
   
if($errno == 8 || $errno == 1024) {
        echo
"sxd.log.add('" . date("Y.m.d H:i:s") . "',[" . esc($str) . "], 4);sxd.hideLoading();";
    }
    elseif(
$errno < 1024) {
        echo
"sxd.log.add('" . date("Y.m.d H:i:s") . "',[" . esc($str) . "], 4);sxd.hideLoading();";
        die;
    }
}