304 Zeilen
Kein EOL
14 KiB
PHP
304 Zeilen
Kein EOL
14 KiB
PHP
<?php
|
|
include_once("inc/functions_restore.php");
|
|
include_once($config["files"]["parameter"]);
|
|
include_once("inc/mysql.php");
|
|
include_once("language/lang_".$config["language"].".php");
|
|
|
|
$relativ_path=($config["interface_browser_ie"]) ? "../../" : "./";
|
|
$aus=Array();
|
|
$aus1=$page_parameter="";
|
|
|
|
MSD_mysql_connect();
|
|
mysql_select_db($databases["db_actual"]) or die($lang["db_select_error"].$databases["db_actual"].$lang["db_select_error2"]);
|
|
|
|
$restore["num_table_fields"]=array(); // Array initialisieren
|
|
//Zeitzähler aktivieren
|
|
$restore["max_zeit"]=intval($config["max_execution_time"]*$config["time_buffer"]);
|
|
$restore["startzeit"]=time();
|
|
$restore["xtime"]=(isset($_GET['xtime'])) ? $_GET['xtime'] : time();
|
|
$restore["fileEOF"]=false; // Ende des Files erreicht?
|
|
$restore["actual_table"]= (!empty($_GET['actual_table'])) ? $_GET['actual_table'] : "unbekannt";
|
|
$restore["offset"]= (!empty($_GET['offset'])) ? $_GET['offset'] : 0;
|
|
$restore["aufruf"]= (!empty($_GET['aufruf'])) ? $_GET['aufruf'] : 0;
|
|
$restore["table_ready"]= (!empty($_GET['table_ready'])) ? $_GET['table_ready'] : 0;
|
|
$restore["part"]= (!empty($_GET['part'])) ? $_GET['part'] : "";
|
|
$restore["do_it"]= (isset($_GET['do_it'])) ? $_GET['do_it'] : false;
|
|
$restore["errors"]= (isset($_GET['err'])) ? $_GET['err'] : 0;
|
|
$restore["anzahl_eintraege"]=(isset($_GET["anzahl_eintraege"])) ? $_GET["anzahl_eintraege"] : 0;
|
|
$restore["anzahl_tabellen"]=(isset($_GET["anzahl_tabellen"])) ? $_GET["anzahl_tabellen"] : 0;
|
|
$restore["filename"]=(isset($_GET["filename"])) ? urldecode($_GET["filename"]) : "";
|
|
$restore["actual_fieldcount"]=(isset($_GET["actual_fieldcount"])) ? $_GET["actual_fieldcount"] : 0;
|
|
$restore["eintraege_ready"]=(isset($_GET["eintraege_ready"])) ? $_GET["eintraege_ready"] : 0;
|
|
$restore["anzahl_zeilen"]=(isset($_GET["anzahl_zeilen"])) ? $_GET["anzahl_zeilen"] : $config["minspeed"];
|
|
$restore["summe_eintraege"]=(isset($_GET["summe_eintraege"])) ? $_GET["summe_eintraege"] : 0;
|
|
|
|
//0=Datenbank 1=Struktur
|
|
$restore["kind"]=(!isset($_GET["kind"])) ? $_GET["kind"]:0;
|
|
if($restore["kind"]==0) $fpath=$config["paths"]["backup"]; else $fpath=$config["paths"]["structure"];
|
|
$restore["compressed"] = (substr(strtolower($restore["filename"]),-2)=="gz") ? 1 : 0;
|
|
|
|
$fmp=0;
|
|
//auf Multipart überprüfen
|
|
if(strlen($restore["filename"])>20)
|
|
{
|
|
$fname=substr($restore["filename"],-20);
|
|
$pp=strpos($fname,"part");
|
|
$fmp=($pp>0);
|
|
if(($fmp>0) && $restore["offset"]==0 && $restore["part"]=="")
|
|
{
|
|
//ersten Part erzeugen
|
|
$restore["filename"]=NextPart($restore["filename"],1);
|
|
}
|
|
}
|
|
//die($restore["filename"]);
|
|
|
|
// Datei oeffnen
|
|
$restore["filehandle"] = ($restore["compressed"]) ? gzopen($fpath.$restore["filename"],"r") : fopen($fpath.$restore["filename"],"r");
|
|
if ($restore["filehandle"])
|
|
{
|
|
//nur am Anfang Logeintrag
|
|
if($restore["offset"]==0)
|
|
{
|
|
if($fmp>0)
|
|
WriteLog("Start Multipart-Restore '".$restore["filename"]."'");
|
|
else
|
|
WriteLog("Start Restore '".$restore["filename"]."'");
|
|
// Statuszeile auslesen
|
|
if ($restore["compressed"])
|
|
{
|
|
//$fp = gzopen ($fpath.$restore["filename"], "r");
|
|
$statusline=gzgets($restore["filehandle"],40960);
|
|
//gzclose ($fp);
|
|
}
|
|
else
|
|
{
|
|
//$fp = fopen ($fpath.$restore["filename"], "r");
|
|
$statusline=fgets($restore["filehandle"],500);
|
|
//fclose ($fp);
|
|
}
|
|
$sline=ReadStatusline($statusline);
|
|
$restore["anzahl_tabellen"]=$sline[0];
|
|
$restore["anzahl_eintraege"]=$sline[1];
|
|
$restore["part"]=($sline[2]=="") ? 0 : substr($sline[2],3);
|
|
|
|
if($config["empty_db_before_restore"]==1 && $restore["part"]==0) EmptyDB($databases["db_actual"]);
|
|
|
|
}
|
|
// Wenn GZ-Komprimierung aus ist, koennen wir mit Hilfe der Filegroesse
|
|
// ausrechnen, wieviel Prozent der Datei fertig sind.
|
|
// Bei GZ=1 geht es nicht, weil sich der Offset auf die ungepackte Groesse
|
|
// bezieht und somit nicht ins Verhältnis zur Dateigroesse gestellt werden kann.
|
|
|
|
if ($restore["compressed"]==0) $filegroesse=filesize($fpath.$restore["filename"]);
|
|
|
|
// Dateizeiger an die richtige Stelle setzen
|
|
($restore["compressed"]) ? gzseek($restore["filehandle"],$restore["offset"]) : fseek($restore["filehandle"],$restore["offset"]);
|
|
|
|
// Jetzt basteln wir uns mal unsere Befehle zusammen...
|
|
$a=0;
|
|
|
|
//print_r($restore);echo "<hr>";
|
|
|
|
$dauer=0;
|
|
WHILE ( ($a<$restore["anzahl_zeilen"] ) && (!$restore["fileEOF"]) && ($dauer<$restore["max_zeit"]) )
|
|
{
|
|
$sql_command=get_sqlbefehl();
|
|
if($sql_command!="") $res=mysql_query($sql_command,$config["dbconnection"]);
|
|
// Bei MySQL-Fehlern sofort abbrechen und Info ausgeben
|
|
$meldung=mysql_error($config["dbconnection"]);
|
|
if ($meldung!="")
|
|
{
|
|
//Errorlog("RESTORE",$databases["db_actual"],$sql_command,$meldung);
|
|
//$restore["errors"]++;
|
|
///die($meldung."<br>-------<br>$sql_command");
|
|
}
|
|
|
|
$a++;
|
|
$dauer=time()-$restore["startzeit"];
|
|
|
|
|
|
}
|
|
$eingetragen=$a-1;
|
|
|
|
$restore["offset"]= ($restore["compressed"]) ? gztell($restore["filehandle"]) : ftell($restore["filehandle"]);
|
|
if ($restore["compressed"]) gzclose($restore["filehandle"]); else fclose($restore["filehandle"]);
|
|
|
|
if (!$restore["fileEOF"])
|
|
{
|
|
$restore["aufruf"]++;
|
|
if (!$restore["compressed"]) $prozent=($restore["offset"]*100)/$filegroesse;
|
|
else
|
|
{
|
|
if ($restore["anzahl_eintraege"]>0) $prozent=$restore["eintraege_ready"]*100/$restore["anzahl_eintraege"];
|
|
else $prozent=0;
|
|
}
|
|
if ($prozent>100) $prozent=100;
|
|
$aus[]= '<h3>'.$lang["restore"].'</h3>';
|
|
if($aus1!="") $aus[]= '<br>'.$aus1.'<br><br>';
|
|
$aus[]= $lang["restore_db"].$databases["db_actual"].$lang["restore_db1"].$config["dbhost"].$lang["restore_db2"].'<br>Backup-File: <b>'.$restore["filename"].'</b> ';
|
|
if($fmp>0) $aus[]= '<br>Multipart File '.$restore["part"].'';
|
|
$aus[]= '<br><br><b>';
|
|
if ($restore["table_ready"]>0) $aus[]= $restore["table_ready"]-1; else $aus[]= '0';
|
|
if ($restore["anzahl_tabellen"]!=-1) $aus[]= '</b> '.$lang["of"].' <b>'.$restore["anzahl_tabellen"].'</b> ';
|
|
$aus[]= $lang["restore_complete"].$lang["restore_run1"].number_format($restore["eintraege_ready"],0,",",".").'</b> ';
|
|
if ($restore["anzahl_eintraege"]>0) $aus[]= $lang["of"].' <b>'.(number_format($restore["anzahl_eintraege"],0,",",".")).'</b> ';
|
|
|
|
$prozentbalken=(round($prozent,0)*3);
|
|
$aus[]= $lang["restore_run2"].'<br>';
|
|
|
|
$aus[]= $lang["restore_run3"].$restore["actual_table"].$lang["restore_run4"].'<br>'.$lang["progress_over_all"].': ';
|
|
|
|
//Fortschrittsbalken
|
|
if ($restore["anzahl_eintraege"]>0)
|
|
{
|
|
$aus[]= '<table border="0" width="440"><tr>';
|
|
if ($prozentbalken>=3) $aus[]= '<td width="'.$prozentbalken.'" nowrap>
|
|
<img src="'.$relativ_path.'images/fbr.gif" name="restorebalken" alt="" width="'.$prozentbalken.'" height="16" border="0"></td>';
|
|
$aus[]= '<td width="'.(round(100-$prozent,0)*3).'"> </td>'
|
|
.'<td width="80" align="right" nowrap><b>'.(number_format($prozent,2,",",".")).' %</b></td></tr></table>';
|
|
}
|
|
else $aus[]= ' <b>unknown count of records</b><br><br>';
|
|
|
|
//Speed-Anzeige
|
|
$fw=($config["maxspeed"]==$config["minspeed"]) ? 300 : round(($restore["anzahl_zeilen"]-$config["minspeed"])/($config["maxspeed"]-$config["minspeed"])*300,0);
|
|
$aus[]='<br><table border="0" cellpadding="0" cellspacing="0"><tr bgcolor="#e9e9e9" nowrap>';
|
|
$aus[]='<td class="nomargin" width="60" valign="top" align="center" style="color:#990000; font-size:10px;" >';
|
|
$aus[]='<strong>Speed</strong><br>'.$restore["anzahl_zeilen"].'</td><td class="nomargin" width="300">';
|
|
$aus[]='<table border="0" width="100%" cellpadding="0" cellspacing="0"><tr nowrap>';
|
|
$aus[]='<td class="nomargin" align="left"class="small" width="300" bgcolor="#e9e9e9" nowrap>';
|
|
$aus[]='<img src="'.$relativ_path.'images/fbs.gif" name="speedbalken" alt="" width="'.$fw.'" height="12" border="0" vspace="0" hspace="0">';
|
|
$aus[]='</td></tr></table><table border="0" width="100%" cellpadding="0" cellspacing="0">';
|
|
$aus[]='<tr nowrap><td class="nomargin" align="left" width="50%" nowrap style="font-size:10px;" >'.$config["minspeed"].'</td>';
|
|
$aus[]='<td class="nomargin" align="right" width="50%" nowrap style="font-size:10px;" >'.$config["maxspeed"].'</td>';
|
|
$aus[]='</tr></table></td></tr></table>';
|
|
|
|
//Status-Text
|
|
$aus[]= '<p class="small">'.zeit_format(time()-$restore["xtime"]).', '.$restore["aufruf"].' pages'; //, speed '.$anzahl_zeilen;
|
|
$aus[]= ($fmp>0) ? ', file '.$restore["part"] : '';
|
|
$aus[]= ($restore["errors"]>0) ? ', <span style="color:red;">'.$restore["errors"].' errors</span>' : '';
|
|
$aus[]= '</p>';
|
|
|
|
|
|
$restore["summe_eintraege"]+=$eingetragen;
|
|
|
|
//Zeitanpassung
|
|
if($config["direct_connection"]==1) {
|
|
if ($dauer<$restore["max_zeit"])
|
|
{
|
|
$restore["anzahl_zeilen"]=$restore["anzahl_zeilen"]*$config["tuning_add"];
|
|
}
|
|
else
|
|
{
|
|
$restore["anzahl_zeilen"]=$restore["anzahl_zeilen"]*$config["tuning_sub"];
|
|
}
|
|
$restore["anzahl_zeilen"]=round($restore["anzahl_zeilen"],0);
|
|
if($config["minspeed"]>0) {if ($restore["anzahl_zeilen"]<$config["minspeed"]) $restore["anzahl_zeilen"]=$config["minspeed"];}
|
|
if($config["maxspeed"]>0) {if($restore["anzahl_zeilen"]>$config["maxspeed"]) $restore["anzahl_zeilen"]=$config["maxspeed"];}
|
|
}
|
|
|
|
$page_parameter='offset='.$restore["offset"].'&aufruf='.$restore["aufruf"].'&actual_table='.$restore["actual_table"];
|
|
$page_parameter.="&filename=".urlencode($restore["filename"])."&kind=".$restore["kind"]."&xtime=".$restore["xtime"];
|
|
$page_parameter.= "&table_ready=".$restore["table_ready"]."&eintraege_ready=".$restore["eintraege_ready"];
|
|
$page_parameter.= "&anzahl_tabellen=".$restore["anzahl_tabellen"]."&anzahl_eintraege=".$restore["anzahl_eintraege"];
|
|
$page_parameter.= "&actual_fieldcount=".$restore["actual_fieldcount"]."&part=".$restore["part"];
|
|
$page_parameter.= "&anzahl_zeilen=".$restore["anzahl_zeilen"];
|
|
$page_parameter.= "&summe_eintraege=".$restore["summe_eintraege"]."&do_it=".$restore["do_it"]."&err=".$restore["errors"];
|
|
|
|
|
|
}
|
|
else
|
|
{
|
|
if(($restore["part"]=="") || ($restore["table_ready"]==$restore["anzahl_tabellen"] && $restore["eintraege_ready"]==$restore["anzahl_eintraege"])) {
|
|
// Uff, geschafft! Jetzt darf die Leitung wieder abkuehlen. :-)
|
|
|
|
$restore["xtime"]=time()-$restore["xtime"];
|
|
WriteLog("Restore '".$restore["filename"]."' finished in ".zeit_format($restore["xtime"]).".");
|
|
|
|
$aus[]= '<h3>'.$lang["restore"].'</h3>';
|
|
$aus[]= $lang["restore_db"].'`'.$databases["db_actual"].'`'.$lang['restore_db1'].'`'.$config["dbhost"].'`'.$lang['restore_db2'];
|
|
$aus[]= $lang["restore_total_complete"]."<br>";
|
|
$aus[]= '<br><b>'.$restore["table_ready"].'</b>'. $lang["restore_complete"]."<br>";
|
|
$aus[]= '<b>'.(number_format($restore["eintraege_ready"],0,",",".")).'</b> '.$lang['restore_run2'].'<br>';
|
|
$aus[]= '<p class="small">'.zeit_format($restore["xtime"]).", ".$restore["aufruf"]." pages</p>";
|
|
if($restore["errors"]>0) $aus[]='<p class="warnung">Es sind '.$restore["errors"].' Fehler aufgetreten: <a href="'.$relativ_path.'log.php?r=3">ansehen</a></p>';
|
|
} else {
|
|
//Multipart-Restore
|
|
$nextfile=NextPart($restore["filename"]);
|
|
if(!file_exists($config["paths"]["backup"].$nextfile)) {
|
|
$aus[]= '<h3>'.$lang["restore"].'</h3>';
|
|
$aus[]= $lang["restore_db"];
|
|
$aus[]= '<p class="warning">Multipart-Backup: Missing File \''.$nextfile.'\' !</p>';
|
|
$aus[]= '<b>'.(number_format($restore["eintraege_ready"],0,",",".")).'</b> '.$lang['restore_run2'].'<br>';
|
|
$aus[]= '<p class="small">'.zeit_format($restore["xtime"]).", ".$restore["aufruf"]." pages</p>";
|
|
if($restore["errors"]>0) $aus[]='<p class="warnung">'.$lang['errors_occured'].': <a href="'.$relativ_path.'log.php?r=3">'.$lang['view'].'</a></p>';
|
|
|
|
} else {
|
|
//Selbstaufruf mit nächstem File
|
|
|
|
|
|
$page_parameter="offset=0&aufruf=".$restore["aufruf"]."&actual_table=".$restore["actual_table"];
|
|
$page_parameter.= "&filename=".urlencode($nextfile)."&kind=".$restore["kind"]."&xtime=".$restore["xtime"];
|
|
$page_parameter.= "&table_ready=".$restore["table_ready"]."&eintraege_ready=".$restore["eintraege_ready"];
|
|
$page_parameter.= "&anzahl_tabellen=".$restore["anzahl_tabellen"]."&anzahl_eintraege=".$restore["anzahl_eintraege"];
|
|
$page_parameter.= "&actual_fieldcount=".$restore["actual_fieldcount"]."&part=".++$restore["part"];
|
|
$page_parameter.= "&anzahl_zeilen=".$restore["anzahl_zeilen"];
|
|
$page_parameter.= "&summe_eintraege=".$restore["summe_eintraege"]."&do_it=".$restore["do_it"]."&err=".$restore["errors"];
|
|
|
|
|
|
}
|
|
|
|
}
|
|
}
|
|
}
|
|
else $aus[]=$fpath.$restore["filename"]." : ".$lang["file_open_error"];
|
|
|
|
|
|
|
|
//=====================================================================
|
|
//================= Anzeige ===========================================
|
|
//=====================================================================
|
|
|
|
//Seite basteln
|
|
|
|
//DEBUGGER
|
|
$debugausgabe="";
|
|
//$debugausgabe="<hr>".$page_parameter;
|
|
|
|
$sc=headline();
|
|
|
|
if($config["interface_browser_ie"]) {
|
|
|
|
$js_aufruf_automatisch=($page_parameter=="") ? ">" : "onload=\"restart_restore()\">";
|
|
$js_aufruf_manuell=($page_parameter=="") ? ">" : '><input type="Button" value="weitermachen" onclick="restart_restore()"><br><br>';
|
|
|
|
|
|
$s="\n<script type=\"text/javascript\">\n";
|
|
$s.="function restart_restore()\n{\n";
|
|
$s.="parent.msd_action.location.href=\"".$relativ_path."restore.php?".$page_parameter."\";\n";
|
|
$s.="\n}\n";
|
|
$s.="</script>";
|
|
$pageheader='<html><head>'.$meta.'<title>MySqlDump</title><link rel="stylesheet" type="text/css" href="'.$relativ_path.'styles.css">'.$s.'</head>
|
|
<body bgcolor="#F5F5F5" '.$js_aufruf_automatisch.$sc;
|
|
$pagefooter='</body></html>';
|
|
$complete_page=$pageheader.implode("\n",$aus).$debugausgabe.$pagefooter;
|
|
// und raus
|
|
$f=fopen("work/log/out.html","w");
|
|
fwrite($f,$complete_page);
|
|
fclose($f);
|
|
flush();
|
|
echo '<script type="text/javascript">parent.msd_ausgabe.location.href="./work/log/out.html";</script>';
|
|
|
|
} else {
|
|
$pageheader='<html><head>'.$meta.'<title>MySqlDump</title><link rel="stylesheet" type="text/css" href="styles.css"></head><body bgcolor="#F5F5F5">'.$sc;
|
|
$pagefooter='</body></html>';
|
|
$js_aufruf_automatisch='<script language="javascript">self.location="restore.php?'.$page_parameter.'";</script>';
|
|
$js_aufruf_manuell='<input type="Button" value="weitermachen" onclick="self.location.href=\'restore.php?'.$page_parameter.'\'">';
|
|
$selbstaufruf=($page_parameter=="") ? "" : $js_aufruf_automatisch;
|
|
$complete_page=$pageheader.(($aus!="") ? implode("\n",$aus) : "").$debugausgabe.$selbstaufruf.$pagefooter;
|
|
// und raus
|
|
echo $complete_page;
|
|
flush();
|
|
}
|
|
|
|
|
|
?>
|