4111 lines
172 KiB
PHP
4111 lines
172 KiB
PHP
<?php
|
|
require(__DIR__.'/login.php');
|
|
//Default Configuration
|
|
$CONFIG = '{"lang":"en","error_reporting":false,"show_hidden":false,"hide_Cols":false,"calc_folder":false}';
|
|
|
|
//TFM version
|
|
define('VERSION', '1.4.3');
|
|
|
|
//Application Title
|
|
define('APP_TITLE', 'Netcloud Video File Manager');
|
|
|
|
// Auth with login/password
|
|
// set true/false to enable/disable it
|
|
// Is independent from IP white- and blacklisting
|
|
$use_auth = true;
|
|
|
|
// Login user name and password
|
|
// Users: array('Username' => 'Password', 'Username2' => 'Password2', ...)
|
|
$auth_users = array(
|
|
'admin' => '$2y$10$HFP49dcc1ZDL3kqIknYGFOykI7HxIk3eW7BMtyUn03D8m56R/4pLe' //,
|
|
//'user' => '$2y$10$Fg6Dz8oH9fPoZ2jJan5tZuv6Z4Kp7avtQ9bDfrdRntXtPeiMAZyGO'
|
|
);
|
|
|
|
//set application theme
|
|
//options - 'light' and 'dark'
|
|
$theme = 'light';
|
|
|
|
// Readonly users
|
|
// e.g. array('users', 'guest', ...)
|
|
$readonly_users = array(
|
|
'user'
|
|
);
|
|
|
|
// Enable highlight.js (https://highlightjs.org/) on view's page
|
|
$use_highlightjs = false;
|
|
|
|
// highlight.js style
|
|
// for dark theme use 'ir-black'
|
|
$highlightjs_style = 'vs';
|
|
|
|
// Enable ace.js (https://ace.c9.io/) on view's page
|
|
$edit_files = false;
|
|
|
|
// Default timezone for date() and time()
|
|
// Doc - http://php.net/manual/en/timezones.php
|
|
$default_timezone = 'Europe/Zurich'; // UTC
|
|
|
|
// Root path for file manager
|
|
// use absolute path of directory i.e: '/var/www/folder' or $_SERVER['DOCUMENT_ROOT'].'/folder'
|
|
$root_path = $_SERVER['DOCUMENT_ROOT'].'Home';
|
|
|
|
// Root url for links in file manager.Relative to $http_host. Variants: '', 'path/to/subfolder'
|
|
// Will not working if $root_path will be outside of server document root
|
|
$root_url = '';
|
|
|
|
// Server hostname. Can set manually if wrong
|
|
$http_host = $_SERVER['HTTP_HOST'];
|
|
|
|
// user specific directories
|
|
// array('Username' => 'Directory path', 'Username2' => 'Directory path', ...)
|
|
$directories_users = array();
|
|
|
|
// input encoding for iconv
|
|
$iconv_input_encoding = 'UTF-8';
|
|
|
|
// date() format for file modification date
|
|
// Doc - https://www.php.net/manual/en/function.date.php
|
|
$datetime_format = 'Y-m-d H:i';
|
|
|
|
// Allowed file extensions for create and rename files
|
|
// e.g. 'txt,html,css,js'
|
|
$allowed_file_extensions = '';
|
|
|
|
// Allowed file extensions for upload files
|
|
// e.g. 'gif,png,jpg,html,txt'
|
|
$allowed_upload_extensions = '';
|
|
|
|
// Favicon path. This can be either a full url to an .PNG image, or a path based on the document root.
|
|
// full path, e.g http://example.com/favicon.png
|
|
// local path, e.g images/icons/favicon.png
|
|
$favicon_path = 'favicon.ico';
|
|
|
|
// Files and folders to excluded from listing
|
|
// e.g. array('myfile.html', 'personal-folder', '*.php', ...)
|
|
$exclude_items = array();
|
|
|
|
// Online office Docs Viewer
|
|
// Availabe rules are 'google', 'microsoft' or false
|
|
// google => View documents using Google Docs Viewer
|
|
// microsoft => View documents using Microsoft Web Apps Viewer
|
|
// false => disable online doc viewer
|
|
$online_viewer = 'false';
|
|
|
|
// Sticky Nav bar
|
|
// true => enable sticky header
|
|
// false => disable sticky header
|
|
$sticky_navbar = true;
|
|
|
|
// Maximum file upload size
|
|
// Increase the following values in php.ini to work properly
|
|
// memory_limit, upload_max_filesize, post_max_size
|
|
$max_upload_size_bytes = 6000;
|
|
|
|
// Possible rules are 'OFF', 'AND' or 'OR'
|
|
// OFF => Don't check connection IP, defaults to OFF
|
|
// AND => Connection must be on the whitelist, and not on the blacklist
|
|
// OR => Connection must be on the whitelist, or not on the blacklist
|
|
$ip_ruleset = 'OFF';
|
|
|
|
// Should users be notified of their block?
|
|
$ip_silent = true;
|
|
|
|
// IP-addresses, both ipv4 and ipv6
|
|
$ip_whitelist = array(
|
|
'127.0.0.1', // local ipv4
|
|
'::1' // local ipv6
|
|
);
|
|
|
|
// IP-addresses, both ipv4 and ipv6
|
|
$ip_blacklist = array(
|
|
'0.0.0.0', // non-routable meta ipv4
|
|
'::' // non-routable meta ipv6
|
|
);
|
|
|
|
// if User has the customized config file, try to use it to override the default config above
|
|
$config_file = './config.php';
|
|
if (is_readable($config_file)) {
|
|
@include($config_file);
|
|
}
|
|
|
|
// --- EDIT BELOW CAREFULLY OR DO NOT EDIT AT ALL ---
|
|
|
|
// max upload file size
|
|
define('MAX_UPLOAD_SIZE', $max_upload_size_bytes);
|
|
|
|
define('FM_THEME', $theme);
|
|
|
|
// private key and session name to store to the session
|
|
if ( !defined( 'FM_SESSION_ID')) {
|
|
define('FM_SESSION_ID', 'filemanager');
|
|
}
|
|
|
|
// Configuration
|
|
$cfg = new FM_Config();
|
|
|
|
// Default language
|
|
$lang = isset($cfg->data['lang']) ? $cfg->data['lang'] : 'en';
|
|
|
|
// Show or hide files and folders that starts with a dot
|
|
$show_hidden_files = isset($cfg->data['show_hidden']) ? $cfg->data['show_hidden'] : true;
|
|
|
|
// PHP error reporting - false = Turns off Errors, true = Turns on Errors
|
|
$report_errors = isset($cfg->data['error_reporting']) ? $cfg->data['error_reporting'] : true;
|
|
|
|
// Hide Permissions and Owner cols in file-listing
|
|
$hide_Cols = isset($cfg->data['hide_Cols']) ? $cfg->data['hide_Cols'] : true;
|
|
|
|
// Show directory size: true or speedup output: false
|
|
$calc_folder = isset($cfg->data['calc_folder']) ? $cfg->data['calc_folder'] : true;
|
|
|
|
//available languages
|
|
$lang_list = array(
|
|
'en' => 'English'
|
|
);
|
|
|
|
if ($report_errors == true) {
|
|
@ini_set('error_reporting', E_ALL);
|
|
@ini_set('display_errors', 1);
|
|
} else {
|
|
@ini_set('error_reporting', E_ALL);
|
|
@ini_set('display_errors', 0);
|
|
}
|
|
|
|
// if fm included
|
|
if (defined('FM_EMBED')) {
|
|
$use_auth = false;
|
|
$sticky_navbar = false;
|
|
} else {
|
|
@set_time_limit(600);
|
|
|
|
date_default_timezone_set($default_timezone);
|
|
|
|
ini_set('default_charset', 'UTF-8');
|
|
if (version_compare(PHP_VERSION, '5.6.0', '<') && function_exists('mb_internal_encoding')) {
|
|
mb_internal_encoding('UTF-8');
|
|
}
|
|
if (function_exists('mb_regex_encoding')) {
|
|
mb_regex_encoding('UTF-8');
|
|
}
|
|
|
|
session_cache_limiter('');
|
|
session_name(FM_SESSION_ID );
|
|
function session_error_handling_function($code, $msg, $file, $line) {
|
|
// Permission denied for default session, try to create a new one
|
|
if ($code == 2) {
|
|
session_abort();
|
|
session_id(session_create_id());
|
|
@session_start();
|
|
}
|
|
}
|
|
set_error_handler('session_error_handling_function');
|
|
session_start();
|
|
restore_error_handler();
|
|
}
|
|
|
|
if (empty($auth_users)) {
|
|
$use_auth = false;
|
|
}
|
|
|
|
$is_https = isset($_SERVER['HTTPS']) && ($_SERVER['HTTPS'] == 'on' || $_SERVER['HTTPS'] == 1)
|
|
|| isset($_SERVER['HTTP_X_FORWARDED_PROTO']) && $_SERVER['HTTP_X_FORWARDED_PROTO'] == 'https';
|
|
|
|
// update $root_url based on user specific directories
|
|
if (isset($_SESSION[FM_SESSION_ID]['logged']) && !empty($directories_users[$_SESSION[FM_SESSION_ID]['logged']])) {
|
|
$wd = fm_clean_path(dirname($_SERVER['PHP_SELF']));
|
|
$root_url = $root_url.$wd.DIRECTORY_SEPARATOR.$directories_users[$_SESSION[FM_SESSION_ID]['logged']];
|
|
}
|
|
// clean $root_url
|
|
$root_url = fm_clean_path($root_url);
|
|
|
|
// abs path for site
|
|
defined('FM_ROOT_URL') || define('FM_ROOT_URL', ($is_https ? 'https' : 'http') . '://' . $http_host . (!empty($root_url) ? '/' . $root_url : ''));
|
|
defined('FM_SELF_URL') || define('FM_SELF_URL', ($is_https ? 'https' : 'http') . '://' . $http_host . $_SERVER['PHP_SELF']);
|
|
|
|
// logout
|
|
if (isset($_GET['logout'])) {
|
|
unset($_SESSION[FM_SESSION_ID]['logged']);
|
|
fm_redirect(FM_SELF_URL);
|
|
}
|
|
|
|
// Show image here
|
|
if (isset($_GET['img'])) {
|
|
fm_show_image($_GET['img']);
|
|
}
|
|
|
|
// Validate connection IP
|
|
if($ip_ruleset != 'OFF'){
|
|
$clientIp = $_SERVER['REMOTE_ADDR'];
|
|
|
|
$proceed = false;
|
|
|
|
$whitelisted = in_array($clientIp, $ip_whitelist);
|
|
$blacklisted = in_array($clientIp, $ip_blacklist);
|
|
|
|
if($ip_ruleset == 'AND'){
|
|
if($whitelisted == true && $blacklisted == false){
|
|
$proceed = true;
|
|
}
|
|
} else
|
|
if($ip_ruleset == 'OR'){
|
|
if($whitelisted == true || $blacklisted == false){
|
|
$proceed = true;
|
|
}
|
|
}
|
|
|
|
if($proceed == false){
|
|
trigger_error('User connection denied from: ' . $clientIp, E_USER_WARNING);
|
|
|
|
if($ip_silent == false){
|
|
fm_set_msg('Access denied. IP restriction applicable', 'error');
|
|
fm_show_header_login();
|
|
fm_show_message();
|
|
}
|
|
|
|
exit();
|
|
}
|
|
}
|
|
|
|
// Auth
|
|
if ($use_auth) {
|
|
if (isset($_SESSION[FM_SESSION_ID]['logged'], $auth_users[$_SESSION[FM_SESSION_ID]['logged']])) {
|
|
// Logged
|
|
} elseif (isset($_POST['fm_usr'], $_POST['fm_pwd'])) {
|
|
// Logging In
|
|
sleep(1);
|
|
if(function_exists('password_verify')) {
|
|
if (isset($auth_users[$_POST['fm_usr']]) && isset($_POST['fm_pwd']) && password_verify($_POST['fm_pwd'], $auth_users[$_POST['fm_usr']])) {
|
|
$_SESSION[FM_SESSION_ID]['logged'] = $_POST['fm_usr'];
|
|
fm_set_msg(lng('You are logged in'));
|
|
fm_redirect(FM_SELF_URL . '?p=');
|
|
} else {
|
|
unset($_SESSION[FM_SESSION_ID]['logged']);
|
|
fm_set_msg(lng('Login failed. Invalid username or password'), 'error');
|
|
fm_redirect(FM_SELF_URL);
|
|
}
|
|
} else {
|
|
fm_set_msg(lng('password_hash not supported, Upgrade PHP version'), 'error');;
|
|
}
|
|
} else {
|
|
// Form
|
|
unset($_SESSION[FM_SESSION_ID]['logged']);
|
|
fm_show_header_login();
|
|
?>
|
|
<section class="h-100">
|
|
<div class="container h-100">
|
|
<div class="row justify-content-md-center h-100">
|
|
<div class="card-wrapper">
|
|
<div class="card fat <?php echo fm_get_theme(); ?>">
|
|
<div class="card-body">
|
|
<form class="form-signin" action="" method="post" autocomplete="off">
|
|
<div class="form-group">
|
|
<div class="brand">
|
|
<div class="netcloud-logo"></div>
|
|
</div>
|
|
<div class="text-center">
|
|
<h1 class="card-title"><?php echo APP_TITLE; ?></h1>
|
|
</div>
|
|
</div>
|
|
<hr />
|
|
<div class="form-group">
|
|
<label for="fm_usr"><?php echo lng('Username'); ?></label>
|
|
<input type="text" class="form-control" id="fm_usr" name="fm_usr" required autofocus>
|
|
</div>
|
|
|
|
<div class="form-group">
|
|
<label for="fm_pwd"><?php echo lng('Password'); ?></label>
|
|
<input type="password" class="form-control" id="fm_pwd" name="fm_pwd" required>
|
|
</div>
|
|
|
|
<div class="form-group">
|
|
<?php fm_show_message(); ?>
|
|
</div>
|
|
|
|
<div class="form-group">
|
|
<button type="submit" class="btn btn-success btn-block mt-4" role="button">
|
|
<?php echo lng('Login'); ?>
|
|
</button>
|
|
</div>
|
|
</form>
|
|
</div>
|
|
</div>
|
|
<div class="footer text-center">
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</section>
|
|
|
|
<?php
|
|
fm_show_footer_login();
|
|
exit;
|
|
}
|
|
}
|
|
|
|
// update root path
|
|
if ($use_auth && isset($_SESSION[FM_SESSION_ID]['logged'])) {
|
|
$root_path = isset($directories_users[$_SESSION[FM_SESSION_ID]['logged']]) ? $directories_users[$_SESSION[FM_SESSION_ID]['logged']] : $root_path;
|
|
}
|
|
|
|
// clean and check $root_path
|
|
$root_path = rtrim($root_path, '\\/');
|
|
$root_path = str_replace('\\', '/', $root_path);
|
|
if (!@is_dir($root_path)) {
|
|
echo "<h1>Root path \"{$root_path}\" not found!</h1>";
|
|
exit;
|
|
}
|
|
|
|
defined('FM_SHOW_HIDDEN') || define('FM_SHOW_HIDDEN', $show_hidden_files);
|
|
defined('FM_ROOT_PATH') || define('FM_ROOT_PATH', $root_path);
|
|
defined('FM_LANG') || define('FM_LANG', $lang);
|
|
defined('FM_FILE_EXTENSION') || define('FM_FILE_EXTENSION', $allowed_file_extensions);
|
|
defined('FM_UPLOAD_EXTENSION') || define('FM_UPLOAD_EXTENSION', $allowed_upload_extensions);
|
|
defined('FM_EXCLUDE_ITEMS') || define('FM_EXCLUDE_ITEMS', $exclude_items);
|
|
defined('FM_DOC_VIEWER') || define('FM_DOC_VIEWER', $online_viewer);
|
|
define('FM_READONLY', $use_auth && !empty($readonly_users) && isset($_SESSION[FM_SESSION_ID]['logged']) && in_array($_SESSION[FM_SESSION_ID]['logged'], $readonly_users));
|
|
define('FM_IS_WIN', DIRECTORY_SEPARATOR == '\\');
|
|
|
|
// always use ?p=
|
|
if (!isset($_GET['p']) && empty($_FILES)) {
|
|
fm_redirect(FM_SELF_URL . '?p=');
|
|
}
|
|
|
|
// get path
|
|
$p = isset($_GET['p']) ? $_GET['p'] : (isset($_POST['p']) ? $_POST['p'] : '');
|
|
|
|
// clean path
|
|
$p = fm_clean_path($p);
|
|
|
|
// for ajax request - save
|
|
$input = file_get_contents('php://input');
|
|
$_POST = (strpos($input, 'ajax') != FALSE && strpos($input, 'save') != FALSE) ? json_decode($input, true) : $_POST;
|
|
|
|
// instead globals vars
|
|
define('FM_PATH', $p);
|
|
define('FM_USE_AUTH', $use_auth);
|
|
define('FM_EDIT_FILE', $edit_files);
|
|
defined('FM_ICONV_INPUT_ENC') || define('FM_ICONV_INPUT_ENC', $iconv_input_encoding);
|
|
defined('FM_USE_HIGHLIGHTJS') || define('FM_USE_HIGHLIGHTJS', $use_highlightjs);
|
|
defined('FM_HIGHLIGHTJS_STYLE') || define('FM_HIGHLIGHTJS_STYLE', $highlightjs_style);
|
|
defined('FM_DATETIME_FORMAT') || define('FM_DATETIME_FORMAT', $datetime_format);
|
|
|
|
unset($p, $use_auth, $iconv_input_encoding, $use_highlightjs, $highlightjs_style);
|
|
|
|
/*************************** ACTIONS ***************************/
|
|
|
|
// AJAX Request
|
|
if (isset($_POST['ajax']) && !FM_READONLY) {
|
|
|
|
// save
|
|
if (isset($_POST['type']) && $_POST['type'] == "save") {
|
|
// get current path
|
|
$path = FM_ROOT_PATH;
|
|
if (FM_PATH != '') {
|
|
$path .= '/' . FM_PATH;
|
|
}
|
|
// check path
|
|
if (!is_dir($path)) {
|
|
fm_redirect(FM_SELF_URL . '?p=');
|
|
}
|
|
$file = $_GET['edit'];
|
|
$file = fm_clean_path($file);
|
|
$file = str_replace('/', '', $file);
|
|
if ($file == '' || !is_file($path . '/' . $file)) {
|
|
fm_set_msg('File not found', 'error');
|
|
fm_redirect(FM_SELF_URL . '?p=' . urlencode(FM_PATH));
|
|
}
|
|
header('X-XSS-Protection:0');
|
|
$file_path = $path . '/' . $file;
|
|
|
|
$writedata = $_POST['content'];
|
|
$fd = fopen($file_path, "w");
|
|
$write_results = @fwrite($fd, $writedata);
|
|
fclose($fd);
|
|
if ($write_results === false){
|
|
header("HTTP/1.1 500 Internal Server Error");
|
|
die("Could Not Write File! - Check Permissions / Ownership");
|
|
}
|
|
die(true);
|
|
}
|
|
|
|
//search : get list of files from the current folder
|
|
if(isset($_POST['type']) && $_POST['type']=="search") {
|
|
$dir = FM_ROOT_PATH;
|
|
$response = scan(fm_clean_path($_POST['path']), $_POST['content']);
|
|
echo json_encode($response);
|
|
exit();
|
|
}
|
|
|
|
// backup files
|
|
if (isset($_POST['type']) && $_POST['type'] == "backup" && !empty($_POST['file'])) {
|
|
$fileName = $_POST['file'];
|
|
$fullPath = FM_ROOT_PATH . '/';
|
|
if (!empty($_POST['path'])) {
|
|
$relativeDirPath = fm_clean_path($_POST['path']);
|
|
$fullPath .= "{$relativeDirPath}/";
|
|
}
|
|
$date = date("dMy-His");
|
|
$newFileName = "{$fileName}-{$date}.bak";
|
|
$fullyQualifiedFileName = $fullPath . $fileName;
|
|
try {
|
|
if (!file_exists($fullyQualifiedFileName)) {
|
|
throw new Exception("File {$fileName} not found");
|
|
}
|
|
if (copy($fullyQualifiedFileName, $fullPath . $newFileName)) {
|
|
echo "Backup {$newFileName} created";
|
|
} else {
|
|
throw new Exception("Could not copy file {$fileName}");
|
|
}
|
|
} catch (Exception $e) {
|
|
echo $e->getMessage();
|
|
}
|
|
}
|
|
|
|
// Save Config
|
|
if (isset($_POST['type']) && $_POST['type'] == "settings") {
|
|
global $cfg, $lang, $report_errors, $show_hidden_files, $lang_list, $hide_Cols, $calc_folder;
|
|
$newLng = $_POST['js-language'];
|
|
fm_get_translations([]);
|
|
if (!array_key_exists($newLng, $lang_list)) {
|
|
$newLng = 'en';
|
|
}
|
|
|
|
$erp = isset($_POST['js-error-report']) && $_POST['js-error-report'] == "true" ? true : false;
|
|
$shf = isset($_POST['js-show-hidden']) && $_POST['js-show-hidden'] == "true" ? true : false;
|
|
$hco = isset($_POST['js-hide-cols']) && $_POST['js-hide-cols'] == "true" ? true : false;
|
|
$caf = isset($_POST['js-calc-folder']) && $_POST['js-calc-folder'] == "true" ? true : false;
|
|
|
|
if ($cfg->data['lang'] != $newLng) {
|
|
$cfg->data['lang'] = $newLng;
|
|
$lang = $newLng;
|
|
}
|
|
if ($cfg->data['error_reporting'] != $erp) {
|
|
$cfg->data['error_reporting'] = $erp;
|
|
$report_errors = $erp;
|
|
}
|
|
if ($cfg->data['show_hidden'] != $shf) {
|
|
$cfg->data['show_hidden'] = $shf;
|
|
$show_hidden_files = $shf;
|
|
}
|
|
if ($cfg->data['show_hidden'] != $shf) {
|
|
$cfg->data['show_hidden'] = $shf;
|
|
$show_hidden_files = $shf;
|
|
}
|
|
if ($cfg->data['hide_Cols'] != $hco) {
|
|
$cfg->data['hide_Cols'] = $hco;
|
|
$hide_Cols = $hco;
|
|
}
|
|
if ($cfg->data['calc_folder'] != $caf) {
|
|
$cfg->data['calc_folder'] = $caf;
|
|
$calc_folder = $caf;
|
|
}
|
|
$cfg->save();
|
|
echo true;
|
|
}
|
|
|
|
// new password hash
|
|
if (isset($_POST['type']) && $_POST['type'] == "pwdhash") {
|
|
$res = isset($_POST['inputPassword2']) && !empty($_POST['inputPassword2']) ? password_hash($_POST['inputPassword2'], PASSWORD_DEFAULT) : '';
|
|
echo $res;
|
|
}
|
|
|
|
//upload using url
|
|
if(isset($_POST['type']) && $_POST['type'] == "upload" && !empty($_REQUEST["uploadurl"])) {
|
|
$path = FM_ROOT_PATH;
|
|
if (FM_PATH != '') {
|
|
$path .= '/' . FM_PATH;
|
|
}
|
|
|
|
$url = !empty($_REQUEST["uploadurl"]) && preg_match("|^http(s)?://.+$|", stripslashes($_REQUEST["uploadurl"])) ? stripslashes($_REQUEST["uploadurl"]) : null;
|
|
$use_curl = false;
|
|
$temp_file = tempnam(sys_get_temp_dir(), "upload-");
|
|
$fileinfo = new stdClass();
|
|
$fileinfo->name = trim(basename($url), ".\x00..\x20");
|
|
|
|
$allowed = (FM_UPLOAD_EXTENSION) ? explode(',', FM_UPLOAD_EXTENSION) : false;
|
|
$ext = strtolower(pathinfo($fileinfo->name, PATHINFO_EXTENSION));
|
|
$isFileAllowed = ($allowed) ? in_array($ext, $allowed) : true;
|
|
|
|
function event_callback ($message) {
|
|
global $callback;
|
|
echo json_encode($message);
|
|
}
|
|
|
|
function get_file_path () {
|
|
global $path, $fileinfo, $temp_file;
|
|
return $path."/".basename($fileinfo->name);
|
|
}
|
|
|
|
$err = false;
|
|
|
|
if(!$isFileAllowed) {
|
|
$err = array("message" => "File extension is not allowed");
|
|
event_callback(array("fail" => $err));
|
|
exit();
|
|
}
|
|
|
|
if (!$url) {
|
|
$success = false;
|
|
} else if ($use_curl) {
|
|
@$fp = fopen($temp_file, "w");
|
|
@$ch = curl_init($url);
|
|
curl_setopt($ch, CURLOPT_NOPROGRESS, false );
|
|
curl_setopt($ch, CURLOPT_FOLLOWLOCATION, true);
|
|
curl_setopt($ch, CURLOPT_FILE, $fp);
|
|
@$success = curl_exec($ch);
|
|
$curl_info = curl_getinfo($ch);
|
|
if (!$success) {
|
|
$err = array("message" => curl_error($ch));
|
|
}
|
|
@curl_close($ch);
|
|
fclose($fp);
|
|
$fileinfo->size = $curl_info["size_download"];
|
|
$fileinfo->type = $curl_info["content_type"];
|
|
} else {
|
|
$ctx = stream_context_create();
|
|
@$success = copy($url, $temp_file, $ctx);
|
|
if (!$success) {
|
|
$err = error_get_last();
|
|
}
|
|
}
|
|
|
|
if ($success) {
|
|
$success = rename($temp_file, get_file_path());
|
|
}
|
|
|
|
if ($success) {
|
|
event_callback(array("done" => $fileinfo));
|
|
} else {
|
|
unlink($temp_file);
|
|
if (!$err) {
|
|
$err = array("message" => "Invalid url parameter");
|
|
}
|
|
event_callback(array("fail" => $err));
|
|
}
|
|
}
|
|
|
|
exit();
|
|
}
|
|
|
|
// Delete file / folder
|
|
if (isset($_GET['del']) && !FM_READONLY) {
|
|
$del = str_replace( '/', '', fm_clean_path( $_GET['del'] ) );
|
|
if ($del != '' && $del != '..' && $del != '.') {
|
|
$path = FM_ROOT_PATH;
|
|
if (FM_PATH != '') {
|
|
$path .= '/' . FM_PATH;
|
|
}
|
|
$is_dir = is_dir($path . '/' . $del);
|
|
if (fm_rdelete($path . '/' . $del)) {
|
|
$msg = $is_dir ? 'Folder <b>%s</b> deleted' : 'File <b>%s</b> deleted';
|
|
fm_set_msg(sprintf($msg, fm_enc($del)));
|
|
} else {
|
|
$msg = $is_dir ? 'Folder <b>%s</b> not deleted' : 'File <b>%s</b> not deleted';
|
|
fm_set_msg(sprintf($msg, fm_enc($del)), 'error');
|
|
}
|
|
} else {
|
|
fm_set_msg('Invalid file or folder name', 'error');
|
|
}
|
|
fm_redirect(FM_SELF_URL . '?p=' . urlencode(FM_PATH));
|
|
}
|
|
|
|
// Create folder
|
|
if (isset($_GET['new']) && isset($_GET['type']) && !FM_READONLY) {
|
|
$type = $_GET['type'];
|
|
$new = str_replace( '/', '', fm_clean_path( strip_tags( $_GET['new'] ) ) );
|
|
if (fm_isvalid_filename($new) && $new != '' && $new != '..' && $new != '.') {
|
|
$path = FM_ROOT_PATH;
|
|
if (FM_PATH != '') {
|
|
$path .= '/' . FM_PATH;
|
|
}
|
|
if ($_GET['type'] == "file") {
|
|
if (!file_exists($path . '/' . $new)) {
|
|
if(fm_is_valid_ext($new)) {
|
|
@fopen($path . '/' . $new, 'w') or die('Cannot open file: ' . $new);
|
|
fm_set_msg(sprintf(lng('File').' <b>%s</b> '.lng('Created'), fm_enc($new)));
|
|
} else {
|
|
fm_set_msg('File extension is not allowed', 'error');
|
|
}
|
|
} else {
|
|
fm_set_msg(sprintf('File <b>%s</b> already exists', fm_enc($new)), 'alert');
|
|
}
|
|
} else {
|
|
if (fm_mkdir($path . '/' . $new, false) === true) {
|
|
fm_set_msg(sprintf(lng('Folder').' <b>%s</b> '.lng('Created'), $new));
|
|
} elseif (fm_mkdir($path . '/' . $new, false) === $path . '/' . $new) {
|
|
fm_set_msg(sprintf('Folder <b>%s</b> already exists', fm_enc($new)), 'alert');
|
|
} else {
|
|
fm_set_msg(sprintf('Folder <b>%s</b> not created', fm_enc($new)), 'error');
|
|
}
|
|
}
|
|
} else {
|
|
fm_set_msg('Invalid characters in file or folder name', 'error');
|
|
}
|
|
fm_redirect(FM_SELF_URL . '?p=' . urlencode(FM_PATH));
|
|
}
|
|
|
|
// Copy folder / file
|
|
if (isset($_GET['copy'], $_GET['finish']) && !FM_READONLY) {
|
|
// from
|
|
$copy = $_GET['copy'];
|
|
$copy = fm_clean_path($copy);
|
|
// empty path
|
|
if ($copy == '') {
|
|
fm_set_msg('Source path not defined', 'error');
|
|
fm_redirect(FM_SELF_URL . '?p=' . urlencode(FM_PATH));
|
|
}
|
|
// abs path from
|
|
$from = FM_ROOT_PATH . '/' . $copy;
|
|
// abs path to
|
|
$dest = FM_ROOT_PATH;
|
|
if (FM_PATH != '') {
|
|
$dest .= '/' . FM_PATH;
|
|
}
|
|
$dest .= '/' . basename($from);
|
|
// move?
|
|
$move = isset($_GET['move']);
|
|
// copy/move/duplicate
|
|
if ($from != $dest) {
|
|
$msg_from = trim(FM_PATH . '/' . basename($from), '/');
|
|
if ($move) { // Move and to != from so just perform move
|
|
$rename = fm_rename($from, $dest);
|
|
if ($rename) {
|
|
fm_set_msg(sprintf('Moved from <b>%s</b> to <b>%s</b>', fm_enc($copy), fm_enc($msg_from)));
|
|
} elseif ($rename === null) {
|
|
fm_set_msg('File or folder with this path already exists', 'alert');
|
|
|
|
} else {
|
|
fm_set_msg(sprintf('Error while moving from <b>%s</b> to <b>%s</b>', fm_enc($copy), fm_enc($msg_from)), 'error');
|
|
}
|
|
} else { // Not move and to != from so copy with original name
|
|
if (fm_rcopy($from, $dest)) {
|
|
fm_set_msg(sprintf('Copied from <b>%s</b> to <b>%s</b>', fm_enc($copy), fm_enc($msg_from)));
|
|
} else {
|
|
fm_set_msg(sprintf('Error while copying from <b>%s</b> to <b>%s</b>', fm_enc($copy), fm_enc($msg_from)), 'error');
|
|
}
|
|
}
|
|
} else {
|
|
if (!$move){ //Not move and to = from so duplicate
|
|
$msg_from = trim(FM_PATH . '/' . basename($from), '/');
|
|
$fn_parts = pathinfo($from);
|
|
$extension_suffix = '';
|
|
if(!is_dir($from)){
|
|
$extension_suffix = '.'.$fn_parts['extension'];
|
|
}
|
|
//Create new name for duplicate
|
|
$fn_duplicate = $fn_parts['dirname'].'/'.$fn_parts['filename'].'-'.date('YmdHis').$extension_suffix;
|
|
$loop_count = 0;
|
|
$max_loop = 1000;
|
|
// Check if a file with the duplicate name already exists, if so, make new name (edge case...)
|
|
while(file_exists($fn_duplicate) & $loop_count < $max_loop){
|
|
$fn_parts = pathinfo($fn_duplicate);
|
|
$fn_duplicate = $fn_parts['dirname'].'/'.$fn_parts['filename'].'-copy'.$extension_suffix;
|
|
$loop_count++;
|
|
}
|
|
if (fm_rcopy($from, $fn_duplicate, False)) {
|
|
fm_set_msg(sprintf('Copyied from <b>%s</b> to <b>%s</b>', fm_enc($copy), fm_enc($fn_duplicate)));
|
|
} else {
|
|
fm_set_msg(sprintf('Error while copying from <b>%s</b> to <b>%s</b>', fm_enc($copy), fm_enc($fn_duplicate)), 'error');
|
|
}
|
|
}
|
|
else{
|
|
fm_set_msg('Paths must be not equal', 'alert');
|
|
}
|
|
}
|
|
fm_redirect(FM_SELF_URL . '?p=' . urlencode(FM_PATH));
|
|
}
|
|
|
|
// Mass copy files/ folders
|
|
if (isset($_POST['file'], $_POST['copy_to'], $_POST['finish']) && !FM_READONLY) {
|
|
// from
|
|
$path = FM_ROOT_PATH;
|
|
if (FM_PATH != '') {
|
|
$path .= '/' . FM_PATH;
|
|
}
|
|
// to
|
|
$copy_to_path = FM_ROOT_PATH;
|
|
$copy_to = fm_clean_path($_POST['copy_to']);
|
|
if ($copy_to != '') {
|
|
$copy_to_path .= '/' . $copy_to;
|
|
}
|
|
if ($path == $copy_to_path) {
|
|
fm_set_msg('Paths must be not equal', 'alert');
|
|
fm_redirect(FM_SELF_URL . '?p=' . urlencode(FM_PATH));
|
|
}
|
|
if (!is_dir($copy_to_path)) {
|
|
if (!fm_mkdir($copy_to_path, true)) {
|
|
fm_set_msg('Unable to create destination folder', 'error');
|
|
fm_redirect(FM_SELF_URL . '?p=' . urlencode(FM_PATH));
|
|
}
|
|
}
|
|
// move?
|
|
$move = isset($_POST['move']);
|
|
// copy/move
|
|
$errors = 0;
|
|
$files = $_POST['file'];
|
|
if (is_array($files) && count($files)) {
|
|
foreach ($files as $f) {
|
|
if ($f != '') {
|
|
// abs path from
|
|
$from = $path . '/' . $f;
|
|
// abs path to
|
|
$dest = $copy_to_path . '/' . $f;
|
|
// do
|
|
if ($move) {
|
|
$rename = fm_rename($from, $dest);
|
|
if ($rename === false) {
|
|
$errors++;
|
|
}
|
|
} else {
|
|
if (!fm_rcopy($from, $dest)) {
|
|
$errors++;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
if ($errors == 0) {
|
|
$msg = $move ? 'Selected files and folders moved' : 'Selected files and folders copied';
|
|
fm_set_msg($msg);
|
|
} else {
|
|
$msg = $move ? 'Error while moving items' : 'Error while copying items';
|
|
fm_set_msg($msg, 'error');
|
|
}
|
|
} else {
|
|
fm_set_msg('Nothing selected', 'alert');
|
|
}
|
|
fm_redirect(FM_SELF_URL . '?p=' . urlencode(FM_PATH));
|
|
}
|
|
|
|
// Rename
|
|
if (isset($_GET['ren'], $_GET['to']) && !FM_READONLY) {
|
|
// old name
|
|
$old = $_GET['ren'];
|
|
$old = fm_clean_path($old);
|
|
$old = str_replace('/', '', $old);
|
|
// new name
|
|
$new = $_GET['to'];
|
|
$new = fm_clean_path(strip_tags($new));
|
|
$new = str_replace('/', '', $new);
|
|
// path
|
|
$path = FM_ROOT_PATH;
|
|
if (FM_PATH != '') {
|
|
$path .= '/' . FM_PATH;
|
|
}
|
|
// rename
|
|
if (fm_isvalid_filename($new) && $old != '' && $new != '') {
|
|
if (fm_rename($path . '/' . $old, $path . '/' . $new)) {
|
|
fm_set_msg(sprintf('Renamed from <b>%s</b> to <b>%s</b>', fm_enc($old), fm_enc($new)));
|
|
} else {
|
|
fm_set_msg(sprintf('Error while renaming from <b>%s</b> to <b>%s</b>', fm_enc($old), fm_enc($new)), 'error');
|
|
}
|
|
} else {
|
|
fm_set_msg('Invalid characters in file name', 'error');
|
|
}
|
|
fm_redirect(FM_SELF_URL . '?p=' . urlencode(FM_PATH));
|
|
}
|
|
|
|
// Download
|
|
if (isset($_GET['dl'])) {
|
|
$dl = $_GET['dl'];
|
|
$dl = fm_clean_path($dl);
|
|
$dl = str_replace('/', '', $dl);
|
|
$path = FM_ROOT_PATH;
|
|
if (FM_PATH != '') {
|
|
$path .= '/' . FM_PATH;
|
|
}
|
|
if ($dl != '' && is_file($path . '/' . $dl)) {
|
|
fm_download_file($path . '/' . $dl, $dl, 1024);
|
|
exit;
|
|
} else {
|
|
fm_set_msg('File not found', 'error');
|
|
fm_redirect(FM_SELF_URL . '?p=' . urlencode(FM_PATH));
|
|
}
|
|
}
|
|
|
|
// Upload
|
|
if (!empty($_FILES) && !FM_READONLY) {
|
|
$override_file_name = false;
|
|
$f = $_FILES;
|
|
$path = FM_ROOT_PATH;
|
|
$ds = DIRECTORY_SEPARATOR;
|
|
if (FM_PATH != '') {
|
|
$path .= '/' . FM_PATH;
|
|
}
|
|
|
|
$errors = 0;
|
|
$uploads = 0;
|
|
$allowed = (FM_UPLOAD_EXTENSION) ? explode(',', FM_UPLOAD_EXTENSION) : false;
|
|
$response = array (
|
|
'status' => 'error',
|
|
'info' => 'Oops! Try again'
|
|
);
|
|
|
|
$filename = $f['file']['name'];
|
|
$tmp_name = $f['file']['tmp_name'];
|
|
$ext = strtolower(pathinfo($filename, PATHINFO_EXTENSION));
|
|
$isFileAllowed = ($allowed) ? in_array($ext, $allowed) : true;
|
|
|
|
$targetPath = $path . $ds;
|
|
if ( is_writable($targetPath) ) {
|
|
$fullPath = $path . '/' . $_REQUEST['fullpath'];
|
|
$folder = substr($fullPath, 0, strrpos($fullPath, "/"));
|
|
|
|
if(file_exists ($fullPath) && !$override_file_name) {
|
|
$ext_1 = $ext ? '.'.$ext : '';
|
|
$fullPath = str_replace($ext_1, '', $fullPath) .'_'. date('ymdHis'). $ext_1;
|
|
}
|
|
|
|
if (!is_dir($folder)) {
|
|
$old = umask(0);
|
|
mkdir($folder, 0777, true);
|
|
umask($old);
|
|
}
|
|
|
|
if (empty($f['file']['error']) && !empty($tmp_name) && $tmp_name != 'none' && $isFileAllowed) {
|
|
if (move_uploaded_file($tmp_name, $fullPath)) {
|
|
// Be sure that the file has been uploaded
|
|
if ( file_exists($fullPath) ) {
|
|
$response = array (
|
|
'status' => 'success',
|
|
'info' => "file upload successful"
|
|
);
|
|
} else {
|
|
$response = array (
|
|
'status' => 'error',
|
|
'info' => 'Couldn\'t upload the requested file.'
|
|
);
|
|
}
|
|
} else {
|
|
$response = array (
|
|
'status' => 'error',
|
|
'info' => "Error while uploading files. Uploaded files $uploads",
|
|
);
|
|
}
|
|
}
|
|
} else {
|
|
$response = array (
|
|
'status' => 'error',
|
|
'info' => 'The specified folder for upload isn\'t writeable.'
|
|
);
|
|
}
|
|
// Return the response
|
|
echo json_encode($response);
|
|
exit();
|
|
}
|
|
|
|
// Mass deleting
|
|
if (isset($_POST['group'], $_POST['delete']) && !FM_READONLY) {
|
|
$path = FM_ROOT_PATH;
|
|
if (FM_PATH != '') {
|
|
$path .= '/' . FM_PATH;
|
|
}
|
|
|
|
$errors = 0;
|
|
$files = $_POST['file'];
|
|
if (is_array($files) && count($files)) {
|
|
foreach ($files as $f) {
|
|
if ($f != '') {
|
|
$new_path = $path . '/' . $f;
|
|
if (!fm_rdelete($new_path)) {
|
|
$errors++;
|
|
}
|
|
}
|
|
}
|
|
if ($errors == 0) {
|
|
fm_set_msg('Selected files and folder deleted');
|
|
} else {
|
|
fm_set_msg('Error while deleting items', 'error');
|
|
}
|
|
} else {
|
|
fm_set_msg('Nothing selected', 'alert');
|
|
}
|
|
|
|
fm_redirect(FM_SELF_URL . '?p=' . urlencode(FM_PATH));
|
|
}
|
|
|
|
// Pack files
|
|
if (isset($_POST['group']) && (isset($_POST['zip']) || isset($_POST['tar'])) && !FM_READONLY) {
|
|
$path = FM_ROOT_PATH;
|
|
$ext = 'zip';
|
|
if (FM_PATH != '') {
|
|
$path .= '/' . FM_PATH;
|
|
}
|
|
|
|
//set pack type
|
|
$ext = isset($_POST['tar']) ? 'tar' : 'zip';
|
|
|
|
|
|
if (($ext == "zip" && !class_exists('ZipArchive')) || ($ext == "tar" && !class_exists('PharData'))) {
|
|
fm_set_msg('Operations with archives are not available', 'error');
|
|
fm_redirect(FM_SELF_URL . '?p=' . urlencode(FM_PATH));
|
|
}
|
|
|
|
$files = $_POST['file'];
|
|
if (!empty($files)) {
|
|
chdir($path);
|
|
|
|
if (count($files) == 1) {
|
|
$one_file = reset($files);
|
|
$one_file = basename($one_file);
|
|
$zipname = $one_file . '_' . date('ymd_His') . '.'.$ext;
|
|
} else {
|
|
$zipname = 'archive_' . date('ymd_His') . '.'.$ext;
|
|
}
|
|
|
|
if($ext == 'zip') {
|
|
$zipper = new FM_Zipper();
|
|
$res = $zipper->create($zipname, $files);
|
|
} elseif ($ext == 'tar') {
|
|
$tar = new FM_Zipper_Tar();
|
|
$res = $tar->create($zipname, $files);
|
|
}
|
|
|
|
if ($res) {
|
|
fm_set_msg(sprintf('Archive <b>%s</b> created', fm_enc($zipname)));
|
|
} else {
|
|
fm_set_msg('Archive not created', 'error');
|
|
}
|
|
} else {
|
|
fm_set_msg('Nothing selected', 'alert');
|
|
}
|
|
|
|
fm_redirect(FM_SELF_URL . '?p=' . urlencode(FM_PATH));
|
|
}
|
|
|
|
// Unpack
|
|
if (isset($_GET['unzip']) && !FM_READONLY) {
|
|
$unzip = $_GET['unzip'];
|
|
$unzip = fm_clean_path($unzip);
|
|
$unzip = str_replace('/', '', $unzip);
|
|
$isValid = false;
|
|
|
|
$path = FM_ROOT_PATH;
|
|
if (FM_PATH != '') {
|
|
$path .= '/' . FM_PATH;
|
|
}
|
|
|
|
if ($unzip != '' && is_file($path . '/' . $unzip)) {
|
|
$zip_path = $path . '/' . $unzip;
|
|
$ext = pathinfo($zip_path, PATHINFO_EXTENSION);
|
|
$isValid = true;
|
|
} else {
|
|
fm_set_msg('File not found', 'error');
|
|
}
|
|
|
|
|
|
if (($ext == "zip" && !class_exists('ZipArchive')) || ($ext == "tar" && !class_exists('PharData'))) {
|
|
fm_set_msg('Operations with archives are not available', 'error');
|
|
fm_redirect(FM_SELF_URL . '?p=' . urlencode(FM_PATH));
|
|
}
|
|
|
|
if ($isValid) {
|
|
//to folder
|
|
$tofolder = '';
|
|
if (isset($_GET['tofolder'])) {
|
|
$tofolder = pathinfo($zip_path, PATHINFO_FILENAME);
|
|
if (fm_mkdir($path . '/' . $tofolder, true)) {
|
|
$path .= '/' . $tofolder;
|
|
}
|
|
}
|
|
|
|
if($ext == "zip") {
|
|
$zipper = new FM_Zipper();
|
|
$res = $zipper->unzip($zip_path, $path);
|
|
} elseif ($ext == "tar") {
|
|
try {
|
|
$gzipper = new PharData($zip_path);
|
|
if (@$gzipper->extractTo($path,null, true)) {
|
|
$res = true;
|
|
} else {
|
|
$res = false;
|
|
}
|
|
} catch (Exception $e) {
|
|
//TODO:: need to handle the error
|
|
$res = true;
|
|
}
|
|
}
|
|
|
|
if ($res) {
|
|
fm_set_msg('Archive unpacked');
|
|
} else {
|
|
fm_set_msg('Archive not unpacked', 'error');
|
|
}
|
|
|
|
} else {
|
|
fm_set_msg('File not found', 'error');
|
|
}
|
|
fm_redirect(FM_SELF_URL . '?p=' . urlencode(FM_PATH));
|
|
}
|
|
|
|
// Change Perms (not for Windows)
|
|
if (isset($_POST['chmod']) && !FM_READONLY && !FM_IS_WIN) {
|
|
$path = FM_ROOT_PATH;
|
|
if (FM_PATH != '') {
|
|
$path .= '/' . FM_PATH;
|
|
}
|
|
|
|
$file = $_POST['chmod'];
|
|
$file = fm_clean_path($file);
|
|
$file = str_replace('/', '', $file);
|
|
if ($file == '' || (!is_file($path . '/' . $file) && !is_dir($path . '/' . $file))) {
|
|
fm_set_msg('File not found', 'error');
|
|
fm_redirect(FM_SELF_URL . '?p=' . urlencode(FM_PATH));
|
|
}
|
|
|
|
$mode = 0;
|
|
if (!empty($_POST['ur'])) {
|
|
$mode |= 0400;
|
|
}
|
|
if (!empty($_POST['uw'])) {
|
|
$mode |= 0200;
|
|
}
|
|
if (!empty($_POST['ux'])) {
|
|
$mode |= 0100;
|
|
}
|
|
if (!empty($_POST['gr'])) {
|
|
$mode |= 0040;
|
|
}
|
|
if (!empty($_POST['gw'])) {
|
|
$mode |= 0020;
|
|
}
|
|
if (!empty($_POST['gx'])) {
|
|
$mode |= 0010;
|
|
}
|
|
if (!empty($_POST['or'])) {
|
|
$mode |= 0004;
|
|
}
|
|
if (!empty($_POST['ow'])) {
|
|
$mode |= 0002;
|
|
}
|
|
if (!empty($_POST['ox'])) {
|
|
$mode |= 0001;
|
|
}
|
|
|
|
if (@chmod($path . '/' . $file, $mode)) {
|
|
fm_set_msg('Permissions changed');
|
|
} else {
|
|
fm_set_msg('Permissions not changed', 'error');
|
|
}
|
|
|
|
fm_redirect(FM_SELF_URL . '?p=' . urlencode(FM_PATH));
|
|
}
|
|
|
|
/*************************** /ACTIONS ***************************/
|
|
|
|
// get current path
|
|
$path = FM_ROOT_PATH;
|
|
if (FM_PATH != '') {
|
|
$path .= '/' . FM_PATH;
|
|
}
|
|
|
|
// check path
|
|
if (!is_dir($path)) {
|
|
fm_redirect(FM_SELF_URL . '?p=');
|
|
}
|
|
|
|
// get parent folder
|
|
$parent = fm_get_parent_path(FM_PATH);
|
|
|
|
$objects = is_readable($path) ? scandir($path) : array();
|
|
$folders = array();
|
|
$files = array();
|
|
$current_path = array_slice(explode("/",$path), -1)[0];
|
|
if (is_array($objects) && fm_is_exclude_items($current_path)) {
|
|
foreach ($objects as $file) {
|
|
if ($file == '.' || $file == '..') {
|
|
continue;
|
|
}
|
|
if (!FM_SHOW_HIDDEN && substr($file, 0, 1) === '.') {
|
|
continue;
|
|
}
|
|
$new_path = $path . '/' . $file;
|
|
if (@is_file($new_path) && fm_is_exclude_items($file)) {
|
|
$files[] = $file;
|
|
} elseif (@is_dir($new_path) && $file != '.' && $file != '..' && fm_is_exclude_items($file)) {
|
|
$folders[] = $file;
|
|
}
|
|
}
|
|
}
|
|
|
|
if (!empty($files)) {
|
|
natcasesort($files);
|
|
}
|
|
if (!empty($folders)) {
|
|
natcasesort($folders);
|
|
}
|
|
|
|
// upload form
|
|
if (isset($_GET['upload']) && !FM_READONLY) {
|
|
fm_show_header(); // HEADER
|
|
fm_show_nav_path(FM_PATH); // current path
|
|
//get the allowed file extensions
|
|
function getUploadExt() {
|
|
$extArr = explode(',', FM_UPLOAD_EXTENSION);
|
|
if(FM_UPLOAD_EXTENSION && $extArr) {
|
|
array_walk($extArr, function(&$x) {$x = ".$x";});
|
|
return implode(',', $extArr);
|
|
}
|
|
return '';
|
|
}
|
|
?>
|
|
|
|
<link href="https://cdnjs.cloudflare.com/ajax/libs/dropzone/5.5.1/min/dropzone.min.css" rel="stylesheet">
|
|
<div class="path">
|
|
|
|
<div class="card mb-2 fm-upload-wrapper <?php echo fm_get_theme(); ?>">
|
|
<div class="card-header">
|
|
<ul class="nav nav-tabs card-header-tabs">
|
|
<li class="nav-item">
|
|
<a class="nav-link active" href="#fileUploader" data-target="#fileUploader"><i class="fa fa-arrow-circle-o-up"></i> <?php echo lng('UploadingFiles') ?></a>
|
|
</li>
|
|
<li class="nav-item">
|
|
<a class="nav-link" href="#urlUploader" class="js-url-upload" data-target="#urlUploader"><i class="fa fa-link"></i> Upload from URL</a>
|
|
</li>
|
|
</ul>
|
|
</div>
|
|
<div class="card-body">
|
|
<p class="card-text">
|
|
<a href="?p=<?php echo FM_PATH ?>" class="float-right"><i class="fa fa-chevron-circle-left go-back"></i> <?php echo lng('Back')?></a>
|
|
<?php echo lng('DestinationFolder') ?>: <?php echo fm_enc(fm_convert_win(FM_ROOT_PATH . '/' . FM_PATH)) ?>
|
|
</p>
|
|
|
|
<form action="<?php echo htmlspecialchars(FM_SELF_URL) . '?p=' . fm_enc(FM_PATH) ?>" class="dropzone card-tabs-container" id="fileUploader" enctype="multipart/form-data">
|
|
<input type="hidden" name="p" value="<?php echo fm_enc(FM_PATH) ?>">
|
|
<input type="hidden" name="fullpath" id="fullpath" value="<?php echo fm_enc(FM_PATH) ?>">
|
|
<div class="fallback">
|
|
<input name="file" type="file" multiple/>
|
|
</div>
|
|
</form>
|
|
|
|
<div class="upload-url-wrapper card-tabs-container hidden" id="urlUploader">
|
|
<form id="js-form-url-upload" class="form-inline" onsubmit="return upload_from_url(this);" method="POST" action="">
|
|
<input type="hidden" name="type" value="upload" aria-label="hidden" aria-hidden="true">
|
|
<input type="url" placeholder="URL" name="uploadurl" required class="form-control" style="width: 80%">
|
|
<button type="submit" class="btn btn-primary ml-3"><?php echo lng('Upload') ?></button>
|
|
<div class="lds-facebook"><div></div><div></div><div></div></div>
|
|
</form>
|
|
<div id="js-url-upload__list" class="col-9 mt-3"></div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<script src="https://cdnjs.cloudflare.com/ajax/libs/dropzone/5.5.1/min/dropzone.min.js"></script>
|
|
<script>
|
|
Dropzone.options.fileUploader = {
|
|
timeout: 180000,
|
|
maxFilesize: <?php echo MAX_UPLOAD_SIZE; ?>,
|
|
acceptedFiles : "<?php echo getUploadExt() ?>",
|
|
init: function () {
|
|
this.on("sending", function (file, xhr, formData) {
|
|
let _path = (file.fullPath) ? file.fullPath : file.name;
|
|
document.getElementById("fullpath").value = _path;
|
|
xhr.ontimeout = (function() {
|
|
toast('Error: Server Timeout');
|
|
});
|
|
}).on("success", function (res) {
|
|
let _response = JSON.parse(res.xhr.response);
|
|
if(_response.status == "error") {
|
|
toast(_response.info);
|
|
}
|
|
}).on("error", function(file, response) {
|
|
toast(response);
|
|
});
|
|
}
|
|
}
|
|
</script>
|
|
<?php
|
|
fm_show_footer();
|
|
exit;
|
|
}
|
|
|
|
// copy form POST
|
|
if (isset($_POST['copy']) && !FM_READONLY) {
|
|
$copy_files = isset($_POST['file']) ? $_POST['file'] : null;
|
|
if (!is_array($copy_files) || empty($copy_files)) {
|
|
fm_set_msg('Nothing selected', 'alert');
|
|
fm_redirect(FM_SELF_URL . '?p=' . urlencode(FM_PATH));
|
|
}
|
|
|
|
fm_show_header(); // HEADER
|
|
fm_show_nav_path(FM_PATH); // current path
|
|
?>
|
|
<div class="path">
|
|
<div class="card <?php echo fm_get_theme(); ?>">
|
|
<div class="card-header">
|
|
<h6><?php echo lng('Copying') ?></h6>
|
|
</div>
|
|
<div class="card-body">
|
|
<form action="" method="post">
|
|
<input type="hidden" name="p" value="<?php echo fm_enc(FM_PATH) ?>">
|
|
<input type="hidden" name="finish" value="1">
|
|
<?php
|
|
foreach ($copy_files as $cf) {
|
|
echo '<input type="hidden" name="file[]" value="' . fm_enc($cf) . '">' . PHP_EOL;
|
|
}
|
|
?>
|
|
<p class="break-word"><?php echo lng('Files') ?>: <b><?php echo implode('</b>, <b>', $copy_files) ?></b></p>
|
|
<p class="break-word"><?php echo lng('SourceFolder') ?>: <?php echo fm_enc(fm_convert_win(FM_ROOT_PATH . '/' . FM_PATH)) ?><br>
|
|
<label for="inp_copy_to"><?php echo lng('DestinationFolder') ?>:</label>
|
|
<?php echo FM_ROOT_PATH ?>/<input type="text" name="copy_to" id="inp_copy_to" value="<?php echo fm_enc(FM_PATH) ?>">
|
|
</p>
|
|
<p class="custom-checkbox custom-control"><input type="checkbox" name="move" value="1" id="js-move-files" class="custom-control-input"><label for="js-move-files" class="custom-control-label" style="vertical-align: sub"> <?php echo lng('Move') ?></label></p>
|
|
<p>
|
|
<button type="submit" class="btn btn-success"><i class="fa fa-check-circle"></i> <?php echo lng('Copy') ?></button>
|
|
<b><a href="?p=<?php echo urlencode(FM_PATH) ?>" class="btn btn-outline-primary"><i class="fa fa-times-circle"></i> <?php echo lng('Cancel') ?></a></b>
|
|
</p>
|
|
</form>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<?php
|
|
fm_show_footer();
|
|
exit;
|
|
}
|
|
|
|
// copy form
|
|
if (isset($_GET['copy']) && !isset($_GET['finish']) && !FM_READONLY) {
|
|
$copy = $_GET['copy'];
|
|
$copy = fm_clean_path($copy);
|
|
if ($copy == '' || !file_exists(FM_ROOT_PATH . '/' . $copy)) {
|
|
fm_set_msg('File not found', 'error');
|
|
fm_redirect(FM_SELF_URL . '?p=' . urlencode(FM_PATH));
|
|
}
|
|
|
|
fm_show_header(); // HEADER
|
|
fm_show_nav_path(FM_PATH); // current path
|
|
?>
|
|
<div class="path">
|
|
<p><b>Copying</b></p>
|
|
<p class="break-word">
|
|
Source path: <?php echo fm_enc(fm_convert_win(FM_ROOT_PATH . '/' . $copy)) ?><br>
|
|
Destination folder: <?php echo fm_enc(fm_convert_win(FM_ROOT_PATH . '/' . FM_PATH)) ?>
|
|
</p>
|
|
<p>
|
|
<b><a href="?p=<?php echo urlencode(FM_PATH) ?>&copy=<?php echo urlencode($copy) ?>&finish=1"><i class="fa fa-check-circle"></i> Copy</a></b>
|
|
<b><a href="?p=<?php echo urlencode(FM_PATH) ?>&copy=<?php echo urlencode($copy) ?>&finish=1&move=1"><i class="fa fa-check-circle"></i> Move</a></b>
|
|
<b><a href="?p=<?php echo urlencode(FM_PATH) ?>"><i class="fa fa-times-circle"></i> Cancel</a></b>
|
|
</p>
|
|
<p><i>Select folder</i></p>
|
|
<ul class="folders break-word">
|
|
<?php
|
|
if ($parent !== false) {
|
|
?>
|
|
<li><a href="?p=<?php echo urlencode($parent) ?>&copy=<?php echo urlencode($copy) ?>"><i class="fa fa-chevron-circle-left"></i> ..</a></li>
|
|
<?php
|
|
}
|
|
foreach ($folders as $f) {
|
|
?>
|
|
<li>
|
|
<a href="?p=<?php echo urlencode(trim(FM_PATH . '/' . $f, '/')) ?>&copy=<?php echo urlencode($copy) ?>"><i class="fa fa-folder-o"></i> <?php echo fm_convert_win($f) ?></a></li>
|
|
<?php
|
|
}
|
|
?>
|
|
</ul>
|
|
</div>
|
|
<?php
|
|
fm_show_footer();
|
|
exit;
|
|
}
|
|
|
|
if (isset($_GET['settings']) && !FM_READONLY) {
|
|
fm_show_header(); // HEADER
|
|
fm_show_nav_path(FM_PATH); // current path
|
|
global $cfg, $lang, $lang_list;
|
|
?>
|
|
|
|
<div class="col-md-8 offset-md-2 pt-3">
|
|
<div class="card mb-2 <?php echo fm_get_theme(); ?>">
|
|
<h6 class="card-header">
|
|
<i class="fa fa-cog"></i> <?php echo lng('Settings') ?>
|
|
<a href="?p=<?php echo FM_PATH ?>" class="float-right"><i class="fa fa-window-close"></i> <?php echo lng('Cancel')?></a>
|
|
</h6>
|
|
<div class="card-body">
|
|
<form id="js-settings-form" action="" method="post" data-type="ajax" onsubmit="return save_settings(this)">
|
|
<input type="hidden" name="type" value="settings" aria-label="hidden" aria-hidden="true">
|
|
<div class="form-group row">
|
|
<label for="js-language" class="col-sm-3 col-form-label"><?php echo lng('Language') ?></label>
|
|
<div class="col-sm-5">
|
|
<select class="form-control" id="js-language" name="js-language">
|
|
<?php
|
|
function getSelected($l) {
|
|
global $lang;
|
|
return ($lang == $l) ? 'selected' : '';
|
|
}
|
|
foreach ($lang_list as $k => $v) {
|
|
echo "<option value='$k' ".getSelected($k).">$v</option>";
|
|
}
|
|
?>
|
|
</select>
|
|
</div>
|
|
</div>
|
|
<?php
|
|
//get ON/OFF and active class
|
|
function getChecked($conf, $val, $txt) {
|
|
if($conf== 1 && $val ==1) {
|
|
return $txt;
|
|
} else if($conf == '' && $val == '') {
|
|
return $txt;
|
|
} else {
|
|
return '';
|
|
}
|
|
}
|
|
?>
|
|
<div class="form-group row">
|
|
<label for="js-err-rpt-1" class="col-sm-3 col-form-label"><?php echo lng('ErrorReporting') ?></label>
|
|
<div class="col-sm-9">
|
|
<div class="btn-group btn-group-toggle" data-toggle="buttons">
|
|
<label class="btn btn-secondary <?php echo getChecked($report_errors, 1, 'active') ?>">
|
|
<input type="radio" name="js-error-report" id="js-err-rpt-1" autocomplete="off" value="true" <?php echo getChecked($report_errors, 1, 'checked') ?> > ON
|
|
</label>
|
|
<label class="btn btn-secondary <?php echo getChecked($report_errors, '', 'active') ?>">
|
|
<input type="radio" name="js-error-report" id="js-err-rpt-0" autocomplete="off" value="false" <?php echo getChecked($report_errors, '', 'checked') ?> > OFF
|
|
</label>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<div class="form-group row">
|
|
<label for="js-hdn-1" class="col-sm-3 col-form-label"><?php echo lng('ShowHiddenFiles') ?></label>
|
|
<div class="col-sm-9">
|
|
<div class="btn-group btn-group-toggle" data-toggle="buttons">
|
|
<label class="btn btn-secondary <?php echo getChecked($show_hidden_files, 1, 'active') ?>">
|
|
<input type="radio" name="js-show-hidden" id="js-hdn-1" autocomplete="off" value="true" <?php echo getChecked($show_hidden_files, 1, 'checked') ?> > ON
|
|
</label>
|
|
<label class="btn btn-secondary <?php echo getChecked($show_hidden_files, '', 'active') ?>">
|
|
<input type="radio" name="js-show-hidden" id="js-hdn-0" autocomplete="off" value="false" <?php echo getChecked($show_hidden_files, '', 'checked') ?> > OFF
|
|
</label>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<div class="form-group row">
|
|
<label for="js-hid-1" class="col-sm-3 col-form-label"><?php echo lng('HideColumns') ?></label>
|
|
<div class="col-sm-9">
|
|
<div class="btn-group btn-group-toggle" data-toggle="buttons">
|
|
<label class="btn btn-secondary <?php echo getChecked($hide_Cols, 1, 'active') ?>">
|
|
<input type="radio" name="js-hide-cols" id="js-hid-1" autocomplete="off" value="true" <?php echo getChecked($hide_Cols, 1, 'checked') ?> > ON
|
|
</label>
|
|
<label class="btn btn-secondary <?php echo getChecked($hide_Cols, '', 'active') ?>">
|
|
<input type="radio" name="js-hide-cols" id="js-hid-0" autocomplete="off" value="false" <?php echo getChecked($hide_Cols, '', 'checked') ?> > OFF
|
|
</label>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<div class="form-group row">
|
|
<label for="js-dir-1" class="col-sm-3 col-form-label"><?php echo lng('CalculateFolderSize') ?></label>
|
|
<div class="col-sm-9">
|
|
<div class="btn-group btn-group-toggle" data-toggle="buttons">
|
|
<label class="btn btn-secondary <?php echo getChecked($calc_folder, 1, 'active') ?>">
|
|
<input type="radio" name="js-calc-folder" id="js-dir-1" autocomplete="off" value="true" <?php echo getChecked($calc_folder, 1, 'checked') ?> > ON
|
|
</label>
|
|
<label class="btn btn-secondary <?php echo getChecked($calc_folder, '', 'active') ?>">
|
|
<input type="radio" name="js-calc-folder" id="js-dir-0" autocomplete="off" value="false" <?php echo getChecked($calc_folder, '', 'checked') ?> > OFF
|
|
</label>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<div class="form-group row">
|
|
<div class="col-sm-10">
|
|
<button type="submit" class="btn btn-success"> <i class="fa fa-check-circle"></i> <?php echo lng('Save'); ?></button>
|
|
</div>
|
|
</div>
|
|
|
|
</form>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<?php
|
|
fm_show_footer();
|
|
exit;
|
|
}
|
|
|
|
if (isset($_GET['help'])) {
|
|
fm_show_header(); // HEADER
|
|
fm_show_nav_path(FM_PATH); // current path
|
|
global $cfg, $lang;
|
|
?>
|
|
|
|
<div class="col-md-8 offset-md-2 pt-3">
|
|
<div class="card mb-2 <?php echo fm_get_theme(); ?>">
|
|
<h6 class="card-header">
|
|
<i class="fa fa-exclamation-circle"></i> <?php echo lng('Help') ?>
|
|
<a href="?p=<?php echo FM_PATH ?>" class="float-right"><i class="fa fa-window-close"></i> <?php echo lng('Cancel')?></a>
|
|
</h6>
|
|
<div class="card-body">
|
|
<div class="row">
|
|
<div class="col-xs-12 col-sm-6">
|
|
<p><h4>Netcloud Learning Manager</h4></p>
|
|
<p>Provides learning videos for internal use.</p>
|
|
<p>by Netcloud AG</p>
|
|
</div>
|
|
<div class="col-xs-12 col-sm-6">
|
|
<div class="card">
|
|
<ul class="list-group list-group-flush">
|
|
<li class="list-group-item"><a href="https://git.netcloud.local/reber/netcloud-learning-manager/" target="_blank"><i class="fa fa-git"></i>Netcloud Git Project</a></li>
|
|
<li class="list-group-item"><a href="https://wiki.netcloud.local/interne-it/iit-netcloud-learning/" target="_blank"><i class="fa fa-git"></i>Documentation</a></li>
|
|
<li class="list-group-item"><a href="https://ocp-console.netcloud.local:8443/console/project/netcloud-learning-manager/overview" target="_blank"><i class="fa fa-git"></i>OpenShift Production Instance</a></li>
|
|
<?php if(!FM_READONLY) { ?>
|
|
<li class="list-group-item"><a href="javascript:show_new_pwd();"><i class="fa fa-lock"></i> <?php echo lng('Generate new password hash') ?></a></li>
|
|
<?php } ?>
|
|
</ul>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<div class="row js-new-pwd hidden mt-2">
|
|
<div class="col-12">
|
|
<form class="form-inline" onsubmit="return new_password_hash(this)" method="POST" action="">
|
|
<input type="hidden" name="type" value="pwdhash" aria-label="hidden" aria-hidden="true">
|
|
<div class="form-group mb-2">
|
|
<label for="staticEmail2"><?php echo lng('Generate new password hash') ?></label>
|
|
</div>
|
|
<div class="form-group mx-sm-3 mb-2">
|
|
<label for="inputPassword2" class="sr-only"><?php echo lng('Password') ?></label>
|
|
<input type="text" class="form-control btn-sm" id="inputPassword2" name="inputPassword2" placeholder="Password" required>
|
|
</div>
|
|
<button type="submit" class="btn btn-success btn-sm mb-2"><?php echo lng('Generate') ?></button>
|
|
</form>
|
|
<textarea class="form-control" rows="2" readonly id="js-pwd-result"></textarea>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<?php
|
|
fm_show_footer();
|
|
exit;
|
|
}
|
|
|
|
// file viewer
|
|
if (isset($_GET['view'])) {
|
|
$file = $_GET['view'];
|
|
$quickView = (isset($_GET['quickView']) && $_GET['quickView'] == 1) ? true : false;
|
|
$file = fm_clean_path($file, false);
|
|
$file = str_replace('/', '', $file);
|
|
if ($file == '' || !is_file($path . '/' . $file) || in_array($file, $GLOBALS['exclude_items'])) {
|
|
fm_set_msg('File not found', 'error');
|
|
fm_redirect(FM_SELF_URL . '?p=' . urlencode(FM_PATH));
|
|
}
|
|
|
|
if(!$quickView) {
|
|
fm_show_header(); // HEADER
|
|
fm_show_nav_path(FM_PATH); // current path
|
|
}
|
|
|
|
$file_url = FM_ROOT_URL . fm_convert_win((FM_PATH != '' ? '/' . FM_PATH : '') . '/' . $file);
|
|
$file_path = $path . '/' . $file;
|
|
|
|
$ext = strtolower(pathinfo($file_path, PATHINFO_EXTENSION));
|
|
$mime_type = fm_get_mime_type($file_path);
|
|
$filesize_raw = fm_get_size($file_path);
|
|
$filesize = fm_get_filesize($filesize_raw);
|
|
|
|
$is_zip = false;
|
|
$is_gzip = false;
|
|
$is_image = false;
|
|
$is_audio = false;
|
|
$is_video = false;
|
|
$is_text = false;
|
|
$is_onlineViewer = false;
|
|
|
|
$view_title = 'File';
|
|
$filenames = false; // for zip
|
|
$content = ''; // for text
|
|
$online_viewer = strtolower(FM_DOC_VIEWER);
|
|
|
|
if($online_viewer && $online_viewer !== 'false' && in_array($ext, fm_get_onlineViewer_exts())){
|
|
$is_onlineViewer = true;
|
|
}
|
|
elseif ($ext == 'zip' || $ext == 'tar') {
|
|
$is_zip = true;
|
|
$view_title = 'Archive';
|
|
$filenames = fm_get_zif_info($file_path, $ext);
|
|
} elseif (in_array($ext, fm_get_image_exts())) {
|
|
$is_image = true;
|
|
$view_title = 'Image';
|
|
} elseif (in_array($ext, fm_get_audio_exts())) {
|
|
$is_audio = true;
|
|
$view_title = 'Audio';
|
|
} elseif (in_array($ext, fm_get_video_exts())) {
|
|
$is_video = true;
|
|
$view_title = 'Video';
|
|
} elseif (in_array($ext, fm_get_text_exts()) || substr($mime_type, 0, 4) == 'text' || in_array($mime_type, fm_get_text_mimes())) {
|
|
$is_text = true;
|
|
$content = file_get_contents($file_path);
|
|
}
|
|
|
|
?>
|
|
<div class="row">
|
|
<div class="col-12">
|
|
<?php if(!$quickView) { ?>
|
|
<p class="break-word"><b><?php echo $view_title ?> "<?php echo fm_enc(fm_convert_win($file)) ?>"</b></p>
|
|
<p class="break-word">
|
|
Full path: <?php echo fm_enc(fm_convert_win($file_path)) ?><br>
|
|
File size: <?php echo ($filesize_raw <= 1000) ? "$filesize_raw bytes" : $filesize; ?><br>
|
|
MIME-type: <?php echo $mime_type ?><br>
|
|
<?php
|
|
// ZIP info
|
|
if (($is_zip || $is_gzip) && $filenames !== false) {
|
|
$total_files = 0;
|
|
$total_comp = 0;
|
|
$total_uncomp = 0;
|
|
foreach ($filenames as $fn) {
|
|
if (!$fn['folder']) {
|
|
$total_files++;
|
|
}
|
|
$total_comp += $fn['compressed_size'];
|
|
$total_uncomp += $fn['filesize'];
|
|
}
|
|
?>
|
|
Files in archive: <?php echo $total_files ?><br>
|
|
Total size: <?php echo fm_get_filesize($total_uncomp) ?><br>
|
|
Size in archive: <?php echo fm_get_filesize($total_comp) ?><br>
|
|
Compression: <?php echo round(($total_comp / $total_uncomp) * 100) ?>%<br>
|
|
<?php
|
|
}
|
|
// Image info
|
|
if ($is_image) {
|
|
$image_size = getimagesize($file_path);
|
|
echo 'Image sizes: ' . (isset($image_size[0]) ? $image_size[0] : '0') . ' x ' . (isset($image_size[1]) ? $image_size[1] : '0') . '<br>';
|
|
}
|
|
// Text info
|
|
if ($is_text) {
|
|
$is_utf8 = fm_is_utf8($content);
|
|
if (function_exists('iconv')) {
|
|
if (!$is_utf8) {
|
|
$content = iconv(FM_ICONV_INPUT_ENC, 'UTF-8//IGNORE', $content);
|
|
}
|
|
}
|
|
echo 'Charset: ' . ($is_utf8 ? 'utf-8' : '8 bit') . '<br>';
|
|
}
|
|
?>
|
|
</p>
|
|
<p>
|
|
<b><a href="?p=<?php echo urlencode(FM_PATH) ?>&dl=<?php echo urlencode($file) ?>"><i class="fa fa-cloud-download"></i> <?php echo lng('Download') ?></a></b>
|
|
<b><a href="<?php echo fm_enc($file_url) ?>" target="_blank"><i class="fa fa-external-link-square"></i> <?php echo lng('Open') ?></a></b>
|
|
|
|
<?php
|
|
// ZIP actions
|
|
if (!FM_READONLY && ($is_zip || $is_gzip) && $filenames !== false) {
|
|
$zip_name = pathinfo($file_path, PATHINFO_FILENAME);
|
|
?>
|
|
<b><a href="?p=<?php echo urlencode(FM_PATH) ?>&unzip=<?php echo urlencode($file) ?>"><i class="fa fa-check-circle"></i> <?php echo lng('UnZip') ?></a></b>
|
|
<b><a href="?p=<?php echo urlencode(FM_PATH) ?>&unzip=<?php echo urlencode($file) ?>&tofolder=1" title="UnZip to <?php echo fm_enc($zip_name) ?>"><i class="fa fa-check-circle"></i>
|
|
<?php echo lng('UnZipToFolder') ?></a></b>
|
|
<?php
|
|
}
|
|
if ($is_text && !FM_READONLY) {
|
|
?>
|
|
<b><a href="?p=<?php echo urlencode(trim(FM_PATH)) ?>&edit=<?php echo urlencode($file) ?>" class="edit-file"><i class="fa fa-pencil-square"></i> <?php echo lng('Edit') ?>
|
|
</a></b>
|
|
<b><a href="?p=<?php echo urlencode(trim(FM_PATH)) ?>&edit=<?php echo urlencode($file) ?>&env=ace"
|
|
class="edit-file"><i class="fa fa-pencil-square-o"></i> <?php echo lng('AdvancedEditor') ?>
|
|
</a></b>
|
|
<?php } ?>
|
|
<b><a href="?p=<?php echo urlencode(FM_PATH) ?>"><i class="fa fa-chevron-circle-left go-back"></i> <?php echo lng('Back') ?></a></b>
|
|
</p>
|
|
<?php
|
|
}
|
|
if($is_onlineViewer) {
|
|
if($online_viewer == 'google') {
|
|
echo '<iframe src="https://docs.google.com/viewer?embedded=true&hl=en&url=' . fm_enc($file_url) . '" frameborder="no" style="width:100%;min-height:460px"></iframe>';
|
|
} else if($online_viewer == 'microsoft') {
|
|
echo '<iframe src="https://view.officeapps.live.com/op/embed.aspx?src=' . fm_enc($file_url) . '" frameborder="no" style="width:100%;min-height:460px"></iframe>';
|
|
}
|
|
} elseif ($is_zip) {
|
|
// ZIP content
|
|
if ($filenames !== false) {
|
|
echo '<code class="maxheight">';
|
|
foreach ($filenames as $fn) {
|
|
if ($fn['folder']) {
|
|
echo '<b>' . fm_enc($fn['name']) . '</b><br>';
|
|
} else {
|
|
echo $fn['name'] . ' (' . fm_get_filesize($fn['filesize']) . ')<br>';
|
|
}
|
|
}
|
|
echo '</code>';
|
|
} else {
|
|
echo '<p>Error while fetching archive info</p>';
|
|
}
|
|
} elseif ($is_image) {
|
|
// Image content
|
|
if (in_array($ext, array('gif', 'jpg', 'jpeg', 'png', 'bmp', 'ico', 'svg'))) {
|
|
echo '<p><img src="' . fm_enc($file_url) . '" alt="" class="preview-img"></p>';
|
|
}
|
|
} elseif ($is_audio) {
|
|
// Audio content
|
|
echo '<p><audio src="' . fm_enc($file_url) . '" controls preload="metadata"></audio></p>';
|
|
} elseif ($is_video) {
|
|
// Video content
|
|
echo '<div class="preview-video"><video src="' . fm_enc($file_url) . '" width="640" height="360" controls preload="metadata"></video></div>';
|
|
} elseif ($is_text) {
|
|
if (FM_USE_HIGHLIGHTJS) {
|
|
// highlight
|
|
$hljs_classes = array(
|
|
'shtml' => 'xml',
|
|
'htaccess' => 'apache',
|
|
'phtml' => 'php',
|
|
'lock' => 'json',
|
|
'svg' => 'xml',
|
|
);
|
|
$hljs_class = isset($hljs_classes[$ext]) ? 'lang-' . $hljs_classes[$ext] : 'lang-' . $ext;
|
|
if (empty($ext) || in_array(strtolower($file), fm_get_text_names()) || preg_match('#\.min\.(css|js)$#i', $file)) {
|
|
$hljs_class = 'nohighlight';
|
|
}
|
|
$content = '<pre class="with-hljs"><code class="' . $hljs_class . '">' . fm_enc($content) . '</code></pre>';
|
|
} elseif (in_array($ext, array('php', 'php4', 'php5', 'phtml', 'phps'))) {
|
|
// php highlight
|
|
$content = highlight_string($content, true);
|
|
} else {
|
|
$content = '<pre>' . fm_enc($content) . '</pre>';
|
|
}
|
|
echo $content;
|
|
}
|
|
?>
|
|
</div>
|
|
</div>
|
|
<?php
|
|
if(!$quickView) {
|
|
fm_show_footer();
|
|
}
|
|
exit;
|
|
}
|
|
|
|
// file editor
|
|
if (isset($_GET['edit'])) {
|
|
$file = $_GET['edit'];
|
|
$file = fm_clean_path($file, false);
|
|
$file = str_replace('/', '', $file);
|
|
if ($file == '' || !is_file($path . '/' . $file)) {
|
|
fm_set_msg('File not found', 'error');
|
|
fm_redirect(FM_SELF_URL . '?p=' . urlencode(FM_PATH));
|
|
}
|
|
header('X-XSS-Protection:0');
|
|
fm_show_header(); // HEADER
|
|
fm_show_nav_path(FM_PATH); // current path
|
|
|
|
$file_url = FM_ROOT_URL . fm_convert_win((FM_PATH != '' ? '/' . FM_PATH : '') . '/' . $file);
|
|
$file_path = $path . '/' . $file;
|
|
|
|
// normal editer
|
|
$isNormalEditor = true;
|
|
if (isset($_GET['env'])) {
|
|
if ($_GET['env'] == "ace") {
|
|
$isNormalEditor = false;
|
|
}
|
|
}
|
|
|
|
// Save File
|
|
if (isset($_POST['savedata'])) {
|
|
$writedata = $_POST['savedata'];
|
|
$fd = fopen($file_path, "w");
|
|
@fwrite($fd, $writedata);
|
|
fclose($fd);
|
|
fm_set_msg('File Saved Successfully');
|
|
}
|
|
|
|
$ext = strtolower(pathinfo($file_path, PATHINFO_EXTENSION));
|
|
$mime_type = fm_get_mime_type($file_path);
|
|
$filesize = filesize($file_path);
|
|
$is_text = false;
|
|
$content = ''; // for text
|
|
|
|
if (in_array($ext, fm_get_text_exts()) || substr($mime_type, 0, 4) == 'text' || in_array($mime_type, fm_get_text_mimes())) {
|
|
$is_text = true;
|
|
$content = file_get_contents($file_path);
|
|
}
|
|
|
|
?>
|
|
<div class="path">
|
|
<div class="row">
|
|
<div class="col-xs-12 col-sm-5 col-lg-6 pt-1">
|
|
<div class="btn-toolbar" role="toolbar">
|
|
<?php if (!$isNormalEditor) { ?>
|
|
<div class="btn-group js-ace-toolbar">
|
|
<button data-cmd="none" data-option="fullscreen" class="btn btn-sm btn-outline-secondary" id="js-ace-fullscreen" title="Fullscreen"><i class="fa fa-expand" title="Fullscreen"></i></button>
|
|
<button data-cmd="find" class="btn btn-sm btn-outline-secondary" id="js-ace-search" title="Search"><i class="fa fa-search" title="Search"></i></button>
|
|
<button data-cmd="undo" class="btn btn-sm btn-outline-secondary" id="js-ace-undo" title="Undo"><i class="fa fa-undo" title="Undo"></i></button>
|
|
<button data-cmd="redo" class="btn btn-sm btn-outline-secondary" id="js-ace-redo" title="Redo"><i class="fa fa-repeat" title="Redo"></i></button>
|
|
<button data-cmd="none" data-option="wrap" class="btn btn-sm btn-outline-secondary" id="js-ace-wordWrap" title="Word Wrap"><i class="fa fa-text-width" title="Word Wrap"></i></button>
|
|
<button data-cmd="none" data-option="help" class="btn btn-sm btn-outline-secondary" id="js-ace-goLine" title="Help"><i class="fa fa-question" title="Help"></i></button>
|
|
<select id="js-ace-mode" data-type="mode" title="Select Document Type" class="btn-outline-secondary border-left-0 d-none d-md-block"><option>-- Select Mode --</option></select>
|
|
<select id="js-ace-theme" data-type="theme" title="Select Theme" class="btn-outline-secondary border-left-0 d-none d-lg-block"><option>-- Select Theme --</option></select>
|
|
<select id="js-ace-fontSize" data-type="fontSize" title="Selct Font Size" class="btn-outline-secondary border-left-0 d-none d-lg-block"><option>-- Select Font Size --</option></select>
|
|
</div>
|
|
<?php } ?>
|
|
</div>
|
|
</div>
|
|
<div class="edit-file-actions col-xs-12 col-sm-7 col-lg-6 text-right pt-1">
|
|
<a title="Back" class="btn btn-sm btn-outline-primary" href="?p=<?php echo urlencode(trim(FM_PATH)) ?>&view=<?php echo urlencode($file) ?>"><i class="fa fa-reply-all"></i> <?php echo lng('Back') ?></a>
|
|
<a title="Backup" class="btn btn-sm btn-outline-primary" href="javascript:void(0);" onclick="backup('<?php echo urlencode(trim(FM_PATH)) ?>','<?php echo urlencode($file) ?>')"><i class="fa fa-database"></i> <?php echo lng('BackUp') ?></a>
|
|
<?php if ($is_text) { ?>
|
|
<?php if ($isNormalEditor) { ?>
|
|
<a title="Advanced" class="btn btn-sm btn-outline-primary" href="?p=<?php echo urlencode(trim(FM_PATH)) ?>&edit=<?php echo urlencode($file) ?>&env=ace"><i class="fa fa-pencil-square-o"></i> <?php echo lng('AdvancedEditor') ?></a>
|
|
<button type="button" class="btn btn-sm btn-outline-primary name="Save" data-url="<?php echo fm_enc($file_url) ?>" onclick="edit_save(this,'nrl')"><i class="fa fa-floppy-o"></i> Save
|
|
</button>
|
|
<?php } else { ?>
|
|
<a title="Plain Editor" class="btn btn-sm btn-outline-primary" href="?p=<?php echo urlencode(trim(FM_PATH)) ?>&edit=<?php echo urlencode($file) ?>"><i class="fa fa-text-height"></i> <?php echo lng('NormalEditor') ?></a>
|
|
<button type="button" class="btn btn-sm btn-outline-primary" name="Save" data-url="<?php echo fm_enc($file_url) ?>" onclick="edit_save(this,'ace')"><i class="fa fa-floppy-o"></i> <?php echo lng('Save') ?>
|
|
</button>
|
|
<?php } ?>
|
|
<?php } ?>
|
|
</div>
|
|
</div>
|
|
<?php
|
|
if ($is_text && $isNormalEditor) {
|
|
echo '<textarea class="mt-2" id="normal-editor" rows="33" cols="120" style="width: 99.5%;">' . htmlspecialchars($content) . '</textarea>';
|
|
} elseif ($is_text) {
|
|
echo '<div id="editor" contenteditable="true">' . htmlspecialchars($content) . '</div>';
|
|
} else {
|
|
fm_set_msg('FILE EXTENSION HAS NOT SUPPORTED', 'error');
|
|
}
|
|
?>
|
|
</div>
|
|
<?php
|
|
fm_show_footer();
|
|
exit;
|
|
}
|
|
|
|
// chmod (not for Windows)
|
|
if (isset($_GET['chmod']) && !FM_READONLY && !FM_IS_WIN) {
|
|
$file = $_GET['chmod'];
|
|
$file = fm_clean_path($file);
|
|
$file = str_replace('/', '', $file);
|
|
if ($file == '' || (!is_file($path . '/' . $file) && !is_dir($path . '/' . $file))) {
|
|
fm_set_msg('File not found', 'error');
|
|
fm_redirect(FM_SELF_URL . '?p=' . urlencode(FM_PATH));
|
|
}
|
|
|
|
fm_show_header(); // HEADER
|
|
fm_show_nav_path(FM_PATH); // current path
|
|
|
|
$file_url = FM_ROOT_URL . (FM_PATH != '' ? '/' . FM_PATH : '') . '/' . $file;
|
|
$file_path = $path . '/' . $file;
|
|
|
|
$mode = fileperms($path . '/' . $file);
|
|
|
|
?>
|
|
<div class="path">
|
|
<div class="card mb-2 <?php echo fm_get_theme(); ?>">
|
|
<h6 class="card-header">
|
|
<?php echo lng('ChangePermissions') ?>
|
|
</h6>
|
|
<div class="card-body">
|
|
<p class="card-text">
|
|
Full path: <?php echo $file_path ?><br>
|
|
</p>
|
|
<form action="" method="post">
|
|
<input type="hidden" name="p" value="<?php echo fm_enc(FM_PATH) ?>">
|
|
<input type="hidden" name="chmod" value="<?php echo fm_enc($file) ?>">
|
|
|
|
<table class="table compact-table <?php echo fm_get_theme(); ?>">
|
|
<tr>
|
|
<td></td>
|
|
<td><b><?php echo lng('Owner') ?></b></td>
|
|
<td><b><?php echo lng('Group') ?></b></td>
|
|
<td><b><?php echo lng('Other') ?></b></td>
|
|
</tr>
|
|
<tr>
|
|
<td style="text-align: right"><b><?php echo lng('Read') ?></b></td>
|
|
<td><label><input type="checkbox" name="ur" value="1"<?php echo ($mode & 00400) ? ' checked' : '' ?>></label></td>
|
|
<td><label><input type="checkbox" name="gr" value="1"<?php echo ($mode & 00040) ? ' checked' : '' ?>></label></td>
|
|
<td><label><input type="checkbox" name="or" value="1"<?php echo ($mode & 00004) ? ' checked' : '' ?>></label></td>
|
|
</tr>
|
|
<tr>
|
|
<td style="text-align: right"><b><?php echo lng('Write') ?></b></td>
|
|
<td><label><input type="checkbox" name="uw" value="1"<?php echo ($mode & 00200) ? ' checked' : '' ?>></label></td>
|
|
<td><label><input type="checkbox" name="gw" value="1"<?php echo ($mode & 00020) ? ' checked' : '' ?>></label></td>
|
|
<td><label><input type="checkbox" name="ow" value="1"<?php echo ($mode & 00002) ? ' checked' : '' ?>></label></td>
|
|
</tr>
|
|
<tr>
|
|
<td style="text-align: right"><b><?php echo lng('Execute') ?></b></td>
|
|
<td><label><input type="checkbox" name="ux" value="1"<?php echo ($mode & 00100) ? ' checked' : '' ?>></label></td>
|
|
<td><label><input type="checkbox" name="gx" value="1"<?php echo ($mode & 00010) ? ' checked' : '' ?>></label></td>
|
|
<td><label><input type="checkbox" name="ox" value="1"<?php echo ($mode & 00001) ? ' checked' : '' ?>></label></td>
|
|
</tr>
|
|
</table>
|
|
|
|
<p>
|
|
<button type="submit" class="btn btn-success"><i class="fa fa-check-circle"></i> <?php echo lng('Change') ?></button>
|
|
<b><a href="?p=<?php echo urlencode(FM_PATH) ?>" class="btn btn-outline-primary"><i class="fa fa-times-circle"></i> <?php echo lng('Cancel') ?></a></b>
|
|
</p>
|
|
</form>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<?php
|
|
fm_show_footer();
|
|
exit;
|
|
}
|
|
|
|
//--- FILEMANAGER MAIN
|
|
fm_show_header(); // HEADER
|
|
fm_show_nav_path(FM_PATH); // current path
|
|
|
|
// messages
|
|
fm_show_message();
|
|
|
|
$num_files = count($files);
|
|
$num_folders = count($folders);
|
|
$all_files_size = 0;
|
|
$tableTheme = (FM_THEME == "dark") ? "text-white bg-dark table-dark" : "bg-white";
|
|
?>
|
|
<form action="" method="post" class="pt-3">
|
|
<input type="hidden" name="p" value="<?php echo fm_enc(FM_PATH) ?>">
|
|
<input type="hidden" name="group" value="1">
|
|
<div class="table-responsive">
|
|
<table class="table table-bordered table-hover table-sm <?php echo $tableTheme; ?>" id="main-table">
|
|
<thead class="thead-white">
|
|
<tr>
|
|
<?php if (!FM_READONLY): ?>
|
|
<th style="width:3%" class="custom-checkbox-header">
|
|
<div class="custom-control custom-checkbox">
|
|
<input type="checkbox" class="custom-control-input" id="js-select-all-items" onclick="checkbox_toggle()">
|
|
<label class="custom-control-label" for="js-select-all-items"></label>
|
|
</div>
|
|
</th><?php endif; ?>
|
|
<th><?php echo lng('Name') ?></th>
|
|
<th><?php echo lng('Size') ?></th>
|
|
<th><?php echo lng('Modified') ?></th>
|
|
<?php if (!FM_IS_WIN && !$hide_Cols): ?>
|
|
<th><?php echo lng('Perms') ?></th>
|
|
<th><?php echo lng('Owner') ?></th><?php endif; ?>
|
|
<th><?php echo lng('Actions') ?></th>
|
|
</tr>
|
|
</thead>
|
|
<?php
|
|
// link to parent folder
|
|
if ($parent !== false) {
|
|
?>
|
|
<tr><?php if (!FM_READONLY): ?>
|
|
<td class="nosort"></td><?php endif; ?>
|
|
<td class="border-0"><a href="?p=<?php echo urlencode($parent) ?>"><i class="fa fa-chevron-circle-left go-back"></i> ..</a></td>
|
|
<td class="border-0"></td>
|
|
<td class="border-0"></td>
|
|
<td class="border-0"></td>
|
|
<?php if (!FM_IS_WIN && !$hide_Cols) { ?>
|
|
<td class="border-0"></td>
|
|
<td class="border-0"></td>
|
|
<?php } ?>
|
|
</tr>
|
|
<?php
|
|
}
|
|
$ii = 3399;
|
|
foreach ($folders as $f) {
|
|
$is_link = is_link($path . '/' . $f);
|
|
$img = $is_link ? 'icon-link_folder' : 'fa fa-folder-o';
|
|
$modif_raw = filemtime($path . '/' . $f);
|
|
$modif = date(FM_DATETIME_FORMAT, $modif_raw);
|
|
if ($calc_folder) {
|
|
$filesize_raw = fm_get_directorysize($path . '/' . $f);
|
|
$filesize = fm_get_filesize($filesize_raw);
|
|
}
|
|
else {
|
|
$filesize_raw = "";
|
|
$filesize = lng('Folder');
|
|
}
|
|
$perms = substr(decoct(fileperms($path . '/' . $f)), -4);
|
|
if (function_exists('posix_getpwuid') && function_exists('posix_getgrgid')) {
|
|
$owner = posix_getpwuid(fileowner($path . '/' . $f));
|
|
$group = posix_getgrgid(filegroup($path . '/' . $f));
|
|
} else {
|
|
$owner = array('name' => '?');
|
|
$group = array('name' => '?');
|
|
}
|
|
?>
|
|
<tr>
|
|
<?php if (!FM_READONLY): ?>
|
|
<td class="custom-checkbox-td">
|
|
<div class="custom-control custom-checkbox">
|
|
<input type="checkbox" class="custom-control-input" id="<?php echo $ii ?>" name="file[]" value="<?php echo fm_enc($f) ?>">
|
|
<label class="custom-control-label" for="<?php echo $ii ?>"></label>
|
|
</div>
|
|
</td><?php endif; ?>
|
|
<td>
|
|
<div class="filename"><a href="?p=<?php echo urlencode(trim(FM_PATH . '/' . $f, '/')) ?>"><i class="<?php echo $img ?>"></i> <?php echo fm_convert_win(fm_enc($f)) ?>
|
|
</a><?php echo($is_link ? ' → <i>' . readlink($path . '/' . $f) . '</i>' : '') ?></div>
|
|
</td>
|
|
<td data-sort="a-<?php echo str_pad($filesize_raw, 18, "0", STR_PAD_LEFT);?>">
|
|
<?php echo $filesize; ?>
|
|
</td>
|
|
<td data-sort="a-<?php echo $modif_raw;?>"><?php echo $modif ?></td>
|
|
<?php if (!FM_IS_WIN && !$hide_Cols): ?>
|
|
<td><?php if (!FM_READONLY): ?><a title="Change Permissions" href="?p=<?php echo urlencode(FM_PATH) ?>&chmod=<?php echo urlencode($f) ?>"><?php echo $perms ?></a><?php else: ?><?php echo $perms ?><?php endif; ?>
|
|
</td>
|
|
<td><?php echo $owner['name'] . ':' . $group['name'] ?></td>
|
|
<?php endif; ?>
|
|
<td class="inline-actions"><?php if (!FM_READONLY): ?>
|
|
<a title="<?php echo lng('Delete')?>" href="?p=<?php echo urlencode(FM_PATH) ?>&del=<?php echo urlencode($f) ?>" onclick="return confirm('<?php echo lng('Delete').' '.lng('Folder').'?'; ?>\n \n ( <?php echo urlencode($f) ?> )');"> <i class="fa fa-trash-o" aria-hidden="true"></i></a>
|
|
<a title="<?php echo lng('Rename')?>" href="#" onclick="rename('<?php echo fm_enc(FM_PATH) ?>', '<?php echo fm_enc(addslashes($f)) ?>');return false;"><i class="fa fa-pencil-square-o" aria-hidden="true"></i></a>
|
|
<a title="<?php echo lng('CopyTo')?>..." href="?p=&copy=<?php echo urlencode(trim(FM_PATH . '/' . $f, '/')) ?>"><i class="fa fa-files-o" aria-hidden="true"></i></a>
|
|
<?php endif; ?>
|
|
<a title="<?php echo lng('DirectLink')?>" href="<?php echo fm_enc(FM_ROOT_URL . (FM_PATH != '' ? '/' . FM_PATH : '') . '/' . $f . '/') ?>" target="_blank"><i class="fa fa-link" aria-hidden="true"></i></a>
|
|
</td>
|
|
</tr>
|
|
<?php
|
|
flush();
|
|
$ii++;
|
|
}
|
|
$ik = 6070;
|
|
foreach ($files as $f) {
|
|
$is_link = is_link($path . '/' . $f);
|
|
$img = $is_link ? 'fa fa-file-text-o' : fm_get_file_icon_class($path . '/' . $f);
|
|
$modif_raw = filemtime($path . '/' . $f);
|
|
$modif = date(FM_DATETIME_FORMAT, $modif_raw);
|
|
$filesize_raw = fm_get_size($path . '/' . $f);
|
|
$filesize = fm_get_filesize($filesize_raw);
|
|
$filelink = '?p=' . urlencode(FM_PATH) . '&view=' . urlencode($f);
|
|
$all_files_size += $filesize_raw;
|
|
$perms = substr(decoct(fileperms($path . '/' . $f)), -4);
|
|
if (function_exists('posix_getpwuid') && function_exists('posix_getgrgid')) {
|
|
$owner = posix_getpwuid(fileowner($path . '/' . $f));
|
|
$group = posix_getgrgid(filegroup($path . '/' . $f));
|
|
} else {
|
|
$owner = array('name' => '?');
|
|
$group = array('name' => '?');
|
|
}
|
|
?>
|
|
<tr>
|
|
<?php if (!FM_READONLY): ?>
|
|
<td class="custom-checkbox-td">
|
|
<div class="custom-control custom-checkbox">
|
|
<input type="checkbox" class="custom-control-input" id="<?php echo $ik ?>" name="file[]" value="<?php echo fm_enc($f) ?>">
|
|
<label class="custom-control-label" for="<?php echo $ik ?>"></label>
|
|
</div>
|
|
</td><?php endif; ?>
|
|
<td>
|
|
<div class="filename">
|
|
<?php
|
|
if (in_array(strtolower(pathinfo($f, PATHINFO_EXTENSION)), array('gif', 'jpg', 'jpeg', 'png', 'bmp', 'ico', 'svg'))): ?>
|
|
<?php $imagePreview = fm_enc(FM_ROOT_URL . (FM_PATH != '' ? '/' . FM_PATH : '') . '/' . $f); ?>
|
|
<a href="<?php echo $filelink ?>" data-preview-image="<?php echo $imagePreview ?>" title="<?php echo $f ?>">
|
|
<?php else: ?>
|
|
<a href="<?php echo $filelink ?>" title="<?php echo $f ?>">
|
|
<?php endif; ?>
|
|
<i class="<?php echo $img ?>"></i> <?php echo fm_convert_win($f) ?>
|
|
</a>
|
|
<?php echo($is_link ? ' → <i>' . readlink($path . '/' . $f) . '</i>' : '') ?>
|
|
</div>
|
|
</td>
|
|
<td data-sort=b-"<?php echo str_pad($filesize_raw, 18, "0", STR_PAD_LEFT); ?>"><span title="<?php printf('%s bytes', $filesize_raw) ?>">
|
|
<?php echo $filesize; ?>
|
|
</span></td>
|
|
<td data-sort="b-<?php echo $modif_raw;?>"><?php echo $modif ?></td>
|
|
<?php if (!FM_IS_WIN && !$hide_Cols): ?>
|
|
<td><?php if (!FM_READONLY): ?><a title="<?php echo 'Change Permissions' ?>" href="?p=<?php echo urlencode(FM_PATH) ?>&chmod=<?php echo urlencode($f) ?>"><?php echo $perms ?></a><?php else: ?><?php echo $perms ?><?php endif; ?>
|
|
</td>
|
|
<td><?php echo fm_enc($owner['name'] . ':' . $group['name']) ?></td>
|
|
<?php endif; ?>
|
|
<td class="inline-actions">
|
|
<a title="<?php echo lng('Preview') ?>" href="<?php echo $filelink.'&quickView=1'; ?>" data-toggle="lightbox" data-gallery="tiny-gallery" data-title="<?php echo fm_convert_win($f) ?>" data-max-width="100%" data-width="100%"><i class="fa fa-eye"></i></a>
|
|
<?php if (!FM_READONLY): ?>
|
|
<a title="<?php echo lng('Delete') ?>" href="?p=<?php echo urlencode(FM_PATH) ?>&del=<?php echo urlencode($f) ?>" onclick="return confirm('<?php echo lng('Delete').' '.lng('File').'?'; ?>\n \n ( <?php echo urlencode($f) ?> )');"> <i class="fa fa-trash-o"></i></a>
|
|
<a title="<?php echo lng('Rename') ?>" href="#" onclick="rename('<?php echo fm_enc(FM_PATH) ?>', '<?php echo fm_enc(addslashes($f)) ?>');return false;"><i class="fa fa-pencil-square-o"></i></a>
|
|
<a title="<?php echo lng('CopyTo') ?>..."
|
|
href="?p=<?php echo urlencode(FM_PATH) ?>&copy=<?php echo urlencode(trim(FM_PATH . '/' . $f, '/')) ?>"><i class="fa fa-files-o"></i></a>
|
|
<?php endif; ?>
|
|
<a title="<?php echo lng('DirectLink') ?>" href="<?php echo fm_enc(FM_ROOT_URL . (FM_PATH != '' ? '/' . FM_PATH : '') . '/' . $f) ?>" target="_blank"><i class="fa fa-link"></i></a>
|
|
<a title="<?php echo lng('Download') ?>" href="?p=<?php echo urlencode(FM_PATH) ?>&dl=<?php echo urlencode($f) ?>"><i class="fa fa-download"></i></a>
|
|
</td>
|
|
</tr>
|
|
<?php
|
|
flush();
|
|
$ik++;
|
|
}
|
|
|
|
if (empty($folders) && empty($files)) {
|
|
?>
|
|
<tfoot>
|
|
<tr><?php if (!FM_READONLY): ?>
|
|
<td></td><?php endif; ?>
|
|
<td colspan="<?php echo (!FM_IS_WIN && !$hide_Cols) ? '6' : '4' ?>"><em><?php echo 'Folder is empty' ?></em></td>
|
|
</tr>
|
|
</tfoot>
|
|
<?php
|
|
} else {
|
|
?>
|
|
<tfoot>
|
|
<tr><?php if (!FM_READONLY): ?>
|
|
<td class="gray"></td><?php endif; ?>
|
|
<td class="gray" colspan="<?php echo (!FM_IS_WIN && !$hide_Cols) ? '6' : '4' ?>">
|
|
<?php echo lng('FullSize').': <span class="badge badge-light">'.fm_get_filesize($all_files_size).'</span>' ?>
|
|
<?php echo lng('File').': <span class="badge badge-light">'.$num_files.'</span>' ?>
|
|
<?php echo lng('Folder').': <span class="badge badge-light">'.$num_folders.'</span>' ?>
|
|
<?php echo lng('MemoryUsed').': <span class="badge badge-light">'.fm_get_filesize(@memory_get_usage(true)).'</span>' ?>
|
|
<?php echo lng('PartitionSize').': <span class="badge badge-light">'.fm_get_filesize(@disk_free_space($path)) .'</span> '.lng('FreeOf').' <span class="badge badge-light">'.fm_get_filesize(@disk_total_space($path)).'</span>'; ?>
|
|
</td>
|
|
</tr>
|
|
</tfoot>
|
|
<?php
|
|
}
|
|
?>
|
|
</table>
|
|
</div>
|
|
|
|
<div class="row">
|
|
<?php if (!FM_READONLY): ?>
|
|
<div class="col-xs-12 col-sm-9">
|
|
<ul class="list-inline footer-action">
|
|
<li class="list-inline-item"> <a href="#/select-all" class="btn btn-small btn-outline-primary btn-2" onclick="select_all();return false;"><i class="fa fa-check-square"></i> <?php echo lng('SelectAll') ?> </a></li>
|
|
<li class="list-inline-item"><a href="#/unselect-all" class="btn btn-small btn-outline-primary btn-2" onclick="unselect_all();return false;"><i class="fa fa-window-close"></i> <?php echo lng('UnSelectAll') ?> </a></li>
|
|
<li class="list-inline-item"><a href="#/invert-all" class="btn btn-small btn-outline-primary btn-2" onclick="invert_all();return false;"><i class="fa fa-th-list"></i> <?php echo lng('InvertSelection') ?> </a></li>
|
|
<li class="list-inline-item"><input type="submit" class="hidden" name="delete" id="a-delete" value="Delete" onclick="return confirm('Delete selected files and folders?')">
|
|
<a href="javascript:document.getElementById('a-delete').click();" class="btn btn-small btn-outline-primary btn-2"><i class="fa fa-trash"></i> <?php echo lng('Delete') ?> </a></li>
|
|
<li class="list-inline-item"><input type="submit" class="hidden" name="zip" id="a-zip" value="zip" onclick="return confirm('Create archive?')">
|
|
<a href="javascript:document.getElementById('a-zip').click();" class="btn btn-small btn-outline-primary btn-2"><i class="fa fa-file-archive-o"></i> <?php echo lng('Zip') ?> </a></li>
|
|
<li class="list-inline-item"><input type="submit" class="hidden" name="tar" id="a-tar" value="tar" onclick="return confirm('Create archive?')">
|
|
<a href="javascript:document.getElementById('a-tar').click();" class="btn btn-small btn-outline-primary btn-2"><i class="fa fa-file-archive-o"></i> <?php echo lng('Tar') ?> </a></li>
|
|
<li class="list-inline-item"><input type="submit" class="hidden" name="copy" id="a-copy" value="Copy">
|
|
<a href="javascript:document.getElementById('a-copy').click();" class="btn btn-small btn-outline-primary btn-2"><i class="fa fa-files-o"></i> <?php echo lng('Copy') ?> </a></li>
|
|
</ul>
|
|
</div>
|
|
<?php else: ?>
|
|
<?php endif; ?>
|
|
</div>
|
|
|
|
</form>
|
|
|
|
<?php
|
|
fm_show_footer();
|
|
|
|
//--- END
|
|
|
|
// Functions
|
|
|
|
/**
|
|
* Check if the filename is allowed.
|
|
* @param string $filename
|
|
* @return bool
|
|
*/
|
|
function fm_is_file_allowed($filename)
|
|
{
|
|
// By default, no file is allowed
|
|
$allowed = false;
|
|
|
|
if (FM_EXTENSION) {
|
|
$ext = strtolower(pathinfo($filename, PATHINFO_EXTENSION));
|
|
|
|
if (in_array($ext, explode(',', strtolower(FM_EXTENSION)))) {
|
|
$allowed = true;
|
|
}
|
|
}
|
|
|
|
return $allowed;
|
|
}
|
|
|
|
/**
|
|
* Delete file or folder (recursively)
|
|
* @param string $path
|
|
* @return bool
|
|
*/
|
|
function fm_rdelete($path)
|
|
{
|
|
if (is_link($path)) {
|
|
return unlink($path);
|
|
} elseif (is_dir($path)) {
|
|
$objects = scandir($path);
|
|
$ok = true;
|
|
if (is_array($objects)) {
|
|
foreach ($objects as $file) {
|
|
if ($file != '.' && $file != '..') {
|
|
if (!fm_rdelete($path . '/' . $file)) {
|
|
$ok = false;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
return ($ok) ? rmdir($path) : false;
|
|
} elseif (is_file($path)) {
|
|
return unlink($path);
|
|
}
|
|
return false;
|
|
}
|
|
|
|
/**
|
|
* Recursive chmod
|
|
* @param string $path
|
|
* @param int $filemode
|
|
* @param int $dirmode
|
|
* @return bool
|
|
* @todo Will use in mass chmod
|
|
*/
|
|
function fm_rchmod($path, $filemode, $dirmode)
|
|
{
|
|
if (is_dir($path)) {
|
|
if (!chmod($path, $dirmode)) {
|
|
return false;
|
|
}
|
|
$objects = scandir($path);
|
|
if (is_array($objects)) {
|
|
foreach ($objects as $file) {
|
|
if ($file != '.' && $file != '..') {
|
|
if (!fm_rchmod($path . '/' . $file, $filemode, $dirmode)) {
|
|
return false;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
return true;
|
|
} elseif (is_link($path)) {
|
|
return true;
|
|
} elseif (is_file($path)) {
|
|
return chmod($path, $filemode);
|
|
}
|
|
return false;
|
|
}
|
|
|
|
/**
|
|
* Check the file extension which is allowed or not
|
|
* @param string $filename
|
|
* @return bool
|
|
*/
|
|
function fm_is_valid_ext($filename)
|
|
{
|
|
$allowed = (FM_FILE_EXTENSION) ? explode(',', FM_FILE_EXTENSION) : false;
|
|
|
|
$ext = pathinfo($filename, PATHINFO_EXTENSION);
|
|
$isFileAllowed = ($allowed) ? in_array($ext, $allowed) : true;
|
|
|
|
return ($isFileAllowed) ? true : false;
|
|
}
|
|
|
|
/**
|
|
* Safely rename
|
|
* @param string $old
|
|
* @param string $new
|
|
* @return bool|null
|
|
*/
|
|
function fm_rename($old, $new)
|
|
{
|
|
$isFileAllowed = fm_is_valid_ext($new);
|
|
|
|
if(!$isFileAllowed) return false;
|
|
|
|
return (!file_exists($new) && file_exists($old)) ? rename($old, $new) : null;
|
|
}
|
|
|
|
/**
|
|
* Copy file or folder (recursively).
|
|
* @param string $path
|
|
* @param string $dest
|
|
* @param bool $upd Update files
|
|
* @param bool $force Create folder with same names instead file
|
|
* @return bool
|
|
*/
|
|
function fm_rcopy($path, $dest, $upd = true, $force = true)
|
|
{
|
|
if (is_dir($path)) {
|
|
if (!fm_mkdir($dest, $force)) {
|
|
return false;
|
|
}
|
|
$objects = scandir($path);
|
|
$ok = true;
|
|
if (is_array($objects)) {
|
|
foreach ($objects as $file) {
|
|
if ($file != '.' && $file != '..') {
|
|
if (!fm_rcopy($path . '/' . $file, $dest . '/' . $file)) {
|
|
$ok = false;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
return $ok;
|
|
} elseif (is_file($path)) {
|
|
return fm_copy($path, $dest, $upd);
|
|
}
|
|
return false;
|
|
}
|
|
|
|
/**
|
|
* Safely create folder
|
|
* @param string $dir
|
|
* @param bool $force
|
|
* @return bool
|
|
*/
|
|
function fm_mkdir($dir, $force)
|
|
{
|
|
if (file_exists($dir)) {
|
|
if (is_dir($dir)) {
|
|
return $dir;
|
|
} elseif (!$force) {
|
|
return false;
|
|
}
|
|
unlink($dir);
|
|
}
|
|
return mkdir($dir, 0777, true);
|
|
}
|
|
|
|
/**
|
|
* Safely copy file
|
|
* @param string $f1
|
|
* @param string $f2
|
|
* @param bool $upd Indicates if file should be updated with new content
|
|
* @return bool
|
|
*/
|
|
function fm_copy($f1, $f2, $upd)
|
|
{
|
|
$time1 = filemtime($f1);
|
|
if (file_exists($f2)) {
|
|
$time2 = filemtime($f2);
|
|
if ($time2 >= $time1 && $upd) {
|
|
return false;
|
|
}
|
|
}
|
|
$ok = copy($f1, $f2);
|
|
if ($ok) {
|
|
touch($f2, $time1);
|
|
}
|
|
return $ok;
|
|
}
|
|
|
|
/**
|
|
* Get mime type
|
|
* @param string $file_path
|
|
* @return mixed|string
|
|
*/
|
|
function fm_get_mime_type($file_path)
|
|
{
|
|
if (function_exists('finfo_open')) {
|
|
$finfo = finfo_open(FILEINFO_MIME_TYPE);
|
|
$mime = finfo_file($finfo, $file_path);
|
|
finfo_close($finfo);
|
|
return $mime;
|
|
} elseif (function_exists('mime_content_type')) {
|
|
return mime_content_type($file_path);
|
|
} elseif (!stristr(ini_get('disable_functions'), 'shell_exec')) {
|
|
$file = escapeshellarg($file_path);
|
|
$mime = shell_exec('file -bi ' . $file);
|
|
return $mime;
|
|
} else {
|
|
return '--';
|
|
}
|
|
}
|
|
|
|
/**
|
|
* HTTP Redirect
|
|
* @param string $url
|
|
* @param int $code
|
|
*/
|
|
function fm_redirect($url, $code = 302)
|
|
{
|
|
header('Location: ' . $url, true, $code);
|
|
exit;
|
|
}
|
|
|
|
/**
|
|
* Path traversal prevention and clean the url
|
|
* It replaces (consecutive) occurrences of / and \\ with whatever is in DIRECTORY_SEPARATOR, and processes /. and /.. fine.
|
|
* @param $path
|
|
* @return string
|
|
*/
|
|
function get_absolute_path($path) {
|
|
$path = str_replace(array('/', '\\'), DIRECTORY_SEPARATOR, $path);
|
|
$parts = array_filter(explode(DIRECTORY_SEPARATOR, $path), 'strlen');
|
|
$absolutes = array();
|
|
foreach ($parts as $part) {
|
|
if ('.' == $part) continue;
|
|
if ('..' == $part) {
|
|
array_pop($absolutes);
|
|
} else {
|
|
$absolutes[] = $part;
|
|
}
|
|
}
|
|
return implode(DIRECTORY_SEPARATOR, $absolutes);
|
|
}
|
|
|
|
/**
|
|
* Clean path
|
|
* @param string $path
|
|
* @return string
|
|
*/
|
|
function fm_clean_path($path, $trim = true)
|
|
{
|
|
$path = $trim ? trim($path) : $path;
|
|
$path = trim($path, '\\/');
|
|
$path = str_replace(array('../', '..\\'), '', $path);
|
|
$path = get_absolute_path($path);
|
|
if ($path == '..') {
|
|
$path = '';
|
|
}
|
|
return str_replace('\\', '/', $path);
|
|
}
|
|
|
|
/**
|
|
* Get parent path
|
|
* @param string $path
|
|
* @return bool|string
|
|
*/
|
|
function fm_get_parent_path($path)
|
|
{
|
|
$path = fm_clean_path($path);
|
|
if ($path != '') {
|
|
$array = explode('/', $path);
|
|
if (count($array) > 1) {
|
|
$array = array_slice($array, 0, -1);
|
|
return implode('/', $array);
|
|
}
|
|
return '';
|
|
}
|
|
return false;
|
|
}
|
|
|
|
/**
|
|
* Check file is in exclude list
|
|
* @param string $file
|
|
* @return bool
|
|
*/
|
|
function fm_is_exclude_items($file) {
|
|
$ext = strtolower(pathinfo($file, PATHINFO_EXTENSION));
|
|
if(!in_array($file, FM_EXCLUDE_ITEMS) && !in_array("*.$ext", FM_EXCLUDE_ITEMS)) {
|
|
return true;
|
|
}
|
|
return false;
|
|
}
|
|
|
|
/**
|
|
* get language translations from json file
|
|
* @param int $tr
|
|
* @return array
|
|
*/
|
|
function fm_get_translations($tr) {
|
|
try {
|
|
$content = @file_get_contents('translation.json');
|
|
if($content !== FALSE) {
|
|
$lng = json_decode($content, TRUE);
|
|
global $lang_list;
|
|
foreach ($lng["language"] as $key => $value)
|
|
{
|
|
$code = $value["code"];
|
|
$lang_list[$code] = $value["name"];
|
|
if ($tr)
|
|
$tr[$code] = $value["translation"];
|
|
}
|
|
return $tr;
|
|
}
|
|
|
|
}
|
|
catch (Exception $e) {
|
|
echo $e;
|
|
}
|
|
}
|
|
|
|
/**
|
|
* @param $file
|
|
* Recover all file sizes larger than > 2GB.
|
|
* Works on php 32bits and 64bits and supports linux
|
|
* @return int|string
|
|
*/
|
|
function fm_get_size($file)
|
|
{
|
|
static $iswin;
|
|
static $isdarwin;
|
|
if (!isset($iswin)) {
|
|
$iswin = (strtoupper(substr(PHP_OS, 0, 3)) == 'WIN');
|
|
}
|
|
if (!isset($isdarwin)) {
|
|
$isdarwin = (strtoupper(substr(PHP_OS, 0)) == "DARWIN");
|
|
}
|
|
|
|
static $exec_works;
|
|
if (!isset($exec_works)) {
|
|
$exec_works = (function_exists('exec') && !ini_get('safe_mode') && @exec('echo EXEC') == 'EXEC');
|
|
}
|
|
|
|
// try a shell command
|
|
if ($exec_works) {
|
|
$arg = escapeshellarg($file);
|
|
$cmd = ($iswin) ? "for %F in (\"$file\") do @echo %~zF" : ($isdarwin ? "stat -f%z $arg" : "stat -c%s $arg");
|
|
@exec($cmd, $output);
|
|
if (is_array($output) && ctype_digit($size = trim(implode("\n", $output)))) {
|
|
return $size;
|
|
}
|
|
}
|
|
|
|
// try the Windows COM interface
|
|
if ($iswin && class_exists("COM")) {
|
|
try {
|
|
$fsobj = new COM('Scripting.FileSystemObject');
|
|
$f = $fsobj->GetFile( realpath($file) );
|
|
$size = $f->Size;
|
|
} catch (Exception $e) {
|
|
$size = null;
|
|
}
|
|
if (ctype_digit($size)) {
|
|
return $size;
|
|
}
|
|
}
|
|
|
|
// if all else fails
|
|
return filesize($file);
|
|
}
|
|
|
|
/**
|
|
* Get nice filesize
|
|
* @param int $size
|
|
* @return string
|
|
*/
|
|
function fm_get_filesize($size)
|
|
{
|
|
$size = (float) $size;
|
|
$units = array('B', 'KB', 'MB', 'GB', 'TB', 'PB', 'EB', 'ZB', 'YB');
|
|
$power = $size > 0 ? floor(log($size, 1024)) : 0;
|
|
return sprintf('%s %s', round($size / pow(1024, $power), 2), $units[$power]);
|
|
}
|
|
|
|
/**
|
|
* Get director total size
|
|
* @param string $directory
|
|
* @return int
|
|
*/
|
|
function fm_get_directorysize($directory) {
|
|
global $calc_folder;
|
|
if ($calc_folder==true) { // Slower output
|
|
$size = 0; $count= 0; $dirCount= 0;
|
|
foreach(new RecursiveIteratorIterator(new RecursiveDirectoryIterator($directory)) as $file)
|
|
if ($file->isFile())
|
|
{ $size+=$file->getSize();
|
|
$count++;
|
|
}
|
|
else if ($file->isDir()) { $dirCount++; }
|
|
// return [$size, $count, $dirCount];
|
|
return $size;
|
|
}
|
|
else return 'Folder'; // Quick output
|
|
}
|
|
|
|
/**
|
|
* Get info about zip archive
|
|
* @param string $path
|
|
* @return array|bool
|
|
*/
|
|
function fm_get_zif_info($path, $ext) {
|
|
if ($ext == 'zip' && function_exists('zip_open')) {
|
|
$arch = zip_open($path);
|
|
if ($arch) {
|
|
$filenames = array();
|
|
while ($zip_entry = zip_read($arch)) {
|
|
$zip_name = zip_entry_name($zip_entry);
|
|
$zip_folder = substr($zip_name, -1) == '/';
|
|
$filenames[] = array(
|
|
'name' => $zip_name,
|
|
'filesize' => zip_entry_filesize($zip_entry),
|
|
'compressed_size' => zip_entry_compressedsize($zip_entry),
|
|
'folder' => $zip_folder
|
|
//'compression_method' => zip_entry_compressionmethod($zip_entry),
|
|
);
|
|
}
|
|
zip_close($arch);
|
|
return $filenames;
|
|
}
|
|
} elseif($ext == 'tar' && class_exists('PharData')) {
|
|
$archive = new PharData($path);
|
|
$filenames = array();
|
|
foreach(new RecursiveIteratorIterator($archive) as $file) {
|
|
$parent_info = $file->getPathInfo();
|
|
$zip_name = str_replace("phar://".$path, '', $file->getPathName());
|
|
$zip_name = substr($zip_name, ($pos = strpos($zip_name, '/')) !== false ? $pos + 1 : 0);
|
|
$zip_folder = $parent_info->getFileName();
|
|
$zip_info = new SplFileInfo($file);
|
|
$filenames[] = array(
|
|
'name' => $zip_name,
|
|
'filesize' => $zip_info->getSize(),
|
|
'compressed_size' => $file->getCompressedSize(),
|
|
'folder' => $zip_folder
|
|
);
|
|
}
|
|
return $filenames;
|
|
}
|
|
return false;
|
|
}
|
|
|
|
/**
|
|
* Encode html entities
|
|
* @param string $text
|
|
* @return string
|
|
*/
|
|
function fm_enc($text)
|
|
{
|
|
return htmlspecialchars($text, ENT_QUOTES, 'UTF-8');
|
|
}
|
|
|
|
/**
|
|
* Prevent XSS attacks
|
|
* @param string $text
|
|
* @return string
|
|
*/
|
|
function fm_isvalid_filename($text) {
|
|
return (strpbrk($text, '/?%*:|"<>') === FALSE) ? true : false;
|
|
}
|
|
|
|
/**
|
|
* Save message in session
|
|
* @param string $msg
|
|
* @param string $status
|
|
*/
|
|
function fm_set_msg($msg, $status = 'ok')
|
|
{
|
|
$_SESSION[FM_SESSION_ID]['message'] = $msg;
|
|
$_SESSION[FM_SESSION_ID]['status'] = $status;
|
|
}
|
|
|
|
/**
|
|
* Check if string is in UTF-8
|
|
* @param string $string
|
|
* @return int
|
|
*/
|
|
function fm_is_utf8($string)
|
|
{
|
|
return preg_match('//u', $string);
|
|
}
|
|
|
|
/**
|
|
* Convert file name to UTF-8 in Windows
|
|
* @param string $filename
|
|
* @return string
|
|
*/
|
|
function fm_convert_win($filename)
|
|
{
|
|
if (FM_IS_WIN && function_exists('iconv')) {
|
|
$filename = iconv(FM_ICONV_INPUT_ENC, 'UTF-8//IGNORE', $filename);
|
|
}
|
|
return $filename;
|
|
}
|
|
|
|
/**
|
|
* @param $obj
|
|
* @return array
|
|
*/
|
|
function fm_object_to_array($obj)
|
|
{
|
|
if (!is_object($obj) && !is_array($obj)) {
|
|
return $obj;
|
|
}
|
|
if (is_object($obj)) {
|
|
$obj = get_object_vars($obj);
|
|
}
|
|
return array_map('fm_object_to_array', $obj);
|
|
}
|
|
|
|
/**
|
|
* Get CSS classname for file
|
|
* @param string $path
|
|
* @return string
|
|
*/
|
|
function fm_get_file_icon_class($path)
|
|
{
|
|
// get extension
|
|
$ext = strtolower(pathinfo($path, PATHINFO_EXTENSION));
|
|
|
|
switch ($ext) {
|
|
case 'ico':
|
|
case 'gif':
|
|
case 'jpg':
|
|
case 'jpeg':
|
|
case 'jpc':
|
|
case 'jp2':
|
|
case 'jpx':
|
|
case 'xbm':
|
|
case 'wbmp':
|
|
case 'png':
|
|
case 'bmp':
|
|
case 'tif':
|
|
case 'tiff':
|
|
case 'svg':
|
|
$img = 'fa fa-picture-o';
|
|
break;
|
|
case 'passwd':
|
|
case 'ftpquota':
|
|
case 'sql':
|
|
case 'js':
|
|
case 'json':
|
|
case 'sh':
|
|
case 'config':
|
|
case 'twig':
|
|
case 'tpl':
|
|
case 'md':
|
|
case 'gitignore':
|
|
case 'c':
|
|
case 'cpp':
|
|
case 'cs':
|
|
case 'py':
|
|
case 'map':
|
|
case 'lock':
|
|
case 'dtd':
|
|
$img = 'fa fa-file-code-o';
|
|
break;
|
|
case 'txt':
|
|
case 'ini':
|
|
case 'conf':
|
|
case 'log':
|
|
case 'htaccess':
|
|
$img = 'fa fa-file-text-o';
|
|
break;
|
|
case 'css':
|
|
case 'less':
|
|
case 'sass':
|
|
case 'scss':
|
|
$img = 'fa fa-css3';
|
|
break;
|
|
case 'zip':
|
|
case 'rar':
|
|
case 'gz':
|
|
case 'tar':
|
|
case '7z':
|
|
$img = 'fa fa-file-archive-o';
|
|
break;
|
|
case 'php':
|
|
case 'php4':
|
|
case 'php5':
|
|
case 'phps':
|
|
case 'phtml':
|
|
$img = 'fa fa-code';
|
|
break;
|
|
case 'htm':
|
|
case 'html':
|
|
case 'shtml':
|
|
case 'xhtml':
|
|
$img = 'fa fa-html5';
|
|
break;
|
|
case 'xml':
|
|
case 'xsl':
|
|
$img = 'fa fa-file-excel-o';
|
|
break;
|
|
case 'wav':
|
|
case 'mp3':
|
|
case 'mp2':
|
|
case 'm4a':
|
|
case 'aac':
|
|
case 'ogg':
|
|
case 'oga':
|
|
case 'wma':
|
|
case 'mka':
|
|
case 'flac':
|
|
case 'ac3':
|
|
case 'tds':
|
|
$img = 'fa fa-music';
|
|
break;
|
|
case 'm3u':
|
|
case 'm3u8':
|
|
case 'pls':
|
|
case 'cue':
|
|
$img = 'fa fa-headphones';
|
|
break;
|
|
case 'avi':
|
|
case 'mpg':
|
|
case 'mpeg':
|
|
case 'mp4':
|
|
case 'm4v':
|
|
case 'flv':
|
|
case 'f4v':
|
|
case 'ogm':
|
|
case 'ogv':
|
|
case 'mov':
|
|
case 'mkv':
|
|
case '3gp':
|
|
case 'asf':
|
|
case 'wmv':
|
|
$img = 'fa fa-file-video-o';
|
|
break;
|
|
case 'eml':
|
|
case 'msg':
|
|
$img = 'fa fa-envelope-o';
|
|
break;
|
|
case 'xls':
|
|
case 'xlsx':
|
|
case 'ods':
|
|
$img = 'fa fa-file-excel-o';
|
|
break;
|
|
case 'csv':
|
|
$img = 'fa fa-file-text-o';
|
|
break;
|
|
case 'bak':
|
|
$img = 'fa fa-clipboard';
|
|
break;
|
|
case 'doc':
|
|
case 'docx':
|
|
case 'odt':
|
|
$img = 'fa fa-file-word-o';
|
|
break;
|
|
case 'ppt':
|
|
case 'pptx':
|
|
$img = 'fa fa-file-powerpoint-o';
|
|
break;
|
|
case 'ttf':
|
|
case 'ttc':
|
|
case 'otf':
|
|
case 'woff':
|
|
case 'woff2':
|
|
case 'eot':
|
|
case 'fon':
|
|
$img = 'fa fa-font';
|
|
break;
|
|
case 'pdf':
|
|
$img = 'fa fa-file-pdf-o';
|
|
break;
|
|
case 'psd':
|
|
case 'ai':
|
|
case 'eps':
|
|
case 'fla':
|
|
case 'swf':
|
|
$img = 'fa fa-file-image-o';
|
|
break;
|
|
case 'exe':
|
|
case 'msi':
|
|
$img = 'fa fa-file-o';
|
|
break;
|
|
case 'bat':
|
|
$img = 'fa fa-terminal';
|
|
break;
|
|
default:
|
|
$img = 'fa fa-info-circle';
|
|
}
|
|
|
|
return $img;
|
|
}
|
|
|
|
/**
|
|
* Get image files extensions
|
|
* @return array
|
|
*/
|
|
function fm_get_image_exts()
|
|
{
|
|
return array('ico', 'gif', 'jpg', 'jpeg', 'jpc', 'jp2', 'jpx', 'xbm', 'wbmp', 'png', 'bmp', 'tif', 'tiff', 'psd', 'svg');
|
|
}
|
|
|
|
/**
|
|
* Get video files extensions
|
|
* @return array
|
|
*/
|
|
function fm_get_video_exts()
|
|
{
|
|
return array('avi', 'webm', 'wmv', 'mp4', 'm4v', 'ogm', 'ogv', 'mov', 'mkv');
|
|
}
|
|
|
|
/**
|
|
* Get audio files extensions
|
|
* @return array
|
|
*/
|
|
function fm_get_audio_exts()
|
|
{
|
|
return array('wav', 'mp3', 'ogg', 'm4a');
|
|
}
|
|
|
|
/**
|
|
* Get text file extensions
|
|
* @return array
|
|
*/
|
|
function fm_get_text_exts()
|
|
{
|
|
return array(
|
|
'txt', 'css', 'ini', 'conf', 'log', 'htaccess', 'passwd', 'ftpquota', 'sql', 'js', 'json', 'sh', 'config',
|
|
'php', 'php4', 'php5', 'phps', 'phtml', 'htm', 'html', 'shtml', 'xhtml', 'xml', 'xsl', 'm3u', 'm3u8', 'pls', 'cue',
|
|
'eml', 'msg', 'csv', 'bat', 'twig', 'tpl', 'md', 'gitignore', 'less', 'sass', 'scss', 'c', 'cpp', 'cs', 'py',
|
|
'map', 'lock', 'dtd', 'svg', 'scss', 'asp', 'aspx', 'asx', 'asmx', 'ashx', 'jsx', 'jsp', 'jspx', 'cfm', 'cgi'
|
|
);
|
|
}
|
|
|
|
/**
|
|
* Get mime types of text files
|
|
* @return array
|
|
*/
|
|
function fm_get_text_mimes()
|
|
{
|
|
return array(
|
|
'application/xml',
|
|
'application/javascript',
|
|
'application/x-javascript',
|
|
'image/svg+xml',
|
|
'message/rfc822',
|
|
);
|
|
}
|
|
|
|
/**
|
|
* Get file names of text files w/o extensions
|
|
* @return array
|
|
*/
|
|
function fm_get_text_names()
|
|
{
|
|
return array(
|
|
'license',
|
|
'readme',
|
|
'authors',
|
|
'contributors',
|
|
'changelog',
|
|
);
|
|
}
|
|
|
|
/**
|
|
* Get online docs viewer supported files extensions
|
|
* @return array
|
|
*/
|
|
function fm_get_onlineViewer_exts()
|
|
{
|
|
return array('doc', 'docx', 'xls', 'xlsx', 'pdf', 'ppt', 'pptx', 'ai', 'psd', 'dxf', 'xps', 'rar', 'odt', 'ods');
|
|
}
|
|
|
|
function fm_get_file_mimes($extension)
|
|
{
|
|
$fileTypes['swf'] = 'application/x-shockwave-flash';
|
|
$fileTypes['pdf'] = 'application/pdf';
|
|
$fileTypes['exe'] = 'application/octet-stream';
|
|
$fileTypes['zip'] = 'application/zip';
|
|
$fileTypes['doc'] = 'application/msword';
|
|
$fileTypes['xls'] = 'application/vnd.ms-excel';
|
|
$fileTypes['ppt'] = 'application/vnd.ms-powerpoint';
|
|
$fileTypes['gif'] = 'image/gif';
|
|
$fileTypes['png'] = 'image/png';
|
|
$fileTypes['jpeg'] = 'image/jpg';
|
|
$fileTypes['jpg'] = 'image/jpg';
|
|
$fileTypes['rar'] = 'application/rar';
|
|
|
|
$fileTypes['ra'] = 'audio/x-pn-realaudio';
|
|
$fileTypes['ram'] = 'audio/x-pn-realaudio';
|
|
$fileTypes['ogg'] = 'audio/x-pn-realaudio';
|
|
|
|
$fileTypes['wav'] = 'video/x-msvideo';
|
|
$fileTypes['wmv'] = 'video/x-msvideo';
|
|
$fileTypes['avi'] = 'video/x-msvideo';
|
|
$fileTypes['asf'] = 'video/x-msvideo';
|
|
$fileTypes['divx'] = 'video/x-msvideo';
|
|
|
|
$fileTypes['mp3'] = 'audio/mpeg';
|
|
$fileTypes['mp4'] = 'audio/mpeg';
|
|
$fileTypes['mpeg'] = 'video/mpeg';
|
|
$fileTypes['mpg'] = 'video/mpeg';
|
|
$fileTypes['mpe'] = 'video/mpeg';
|
|
$fileTypes['mov'] = 'video/quicktime';
|
|
$fileTypes['swf'] = 'video/quicktime';
|
|
$fileTypes['3gp'] = 'video/quicktime';
|
|
$fileTypes['m4a'] = 'video/quicktime';
|
|
$fileTypes['aac'] = 'video/quicktime';
|
|
$fileTypes['m3u'] = 'video/quicktime';
|
|
|
|
$fileTypes['php'] = ['application/x-php'];
|
|
$fileTypes['html'] = ['text/html'];
|
|
$fileTypes['txt'] = ['text/plain'];
|
|
return $fileTypes[$extension];
|
|
}
|
|
|
|
/**
|
|
* This function scans the files and folder recursively, and return matching files
|
|
* @param string $dir
|
|
* @param string $filter
|
|
* @return json
|
|
*/
|
|
function scan($dir, $filter = '') {
|
|
$path = FM_ROOT_PATH.'/'.$dir;
|
|
if($dir) {
|
|
$ite = new RecursiveIteratorIterator(new RecursiveDirectoryIterator($path));
|
|
$rii = new RegexIterator($ite, "/(" . $filter . ")/i");
|
|
|
|
$files = array();
|
|
foreach ($rii as $file) {
|
|
if (!$file->isDir()) {
|
|
$fileName = $file->getFilename();
|
|
$location = str_replace(FM_ROOT_PATH, '', $file->getPath());
|
|
$files[] = array(
|
|
"name" => $fileName,
|
|
"type" => "file",
|
|
"path" => $location,
|
|
);
|
|
}
|
|
}
|
|
return $files;
|
|
}
|
|
}
|
|
|
|
/*
|
|
Parameters: downloadFile(File Location, File Name,
|
|
max speed, is streaming
|
|
If streaming - videos will show as videos, images as images
|
|
instead of download prompt
|
|
https://stackoverflow.com/a/13821992/1164642
|
|
*/
|
|
|
|
function fm_download_file($fileLocation, $fileName, $chunkSize = 1024)
|
|
{
|
|
if (connection_status() != 0)
|
|
return (false);
|
|
$extension = pathinfo($fileName, PATHINFO_EXTENSION);
|
|
|
|
$contentType = fm_get_file_mimes($extension);
|
|
header("Cache-Control: public");
|
|
header("Content-Transfer-Encoding: binary\n");
|
|
header('Content-Type: $contentType');
|
|
|
|
$contentDisposition = 'attachment';
|
|
|
|
|
|
if (strstr($_SERVER['HTTP_USER_AGENT'], "MSIE")) {
|
|
$fileName = preg_replace('/\./', '%2e', $fileName, substr_count($fileName, '.') - 1);
|
|
header("Content-Disposition: $contentDisposition;filename=\"$fileName\"");
|
|
} else {
|
|
header("Content-Disposition: $contentDisposition;filename=\"$fileName\"");
|
|
}
|
|
|
|
header("Accept-Ranges: bytes");
|
|
$range = 0;
|
|
$size = filesize($fileLocation);
|
|
|
|
if (isset($_SERVER['HTTP_RANGE'])) {
|
|
list($a, $range) = explode("=", $_SERVER['HTTP_RANGE']);
|
|
str_replace($range, "-", $range);
|
|
$size2 = $size - 1;
|
|
$new_length = $size - $range;
|
|
header("HTTP/1.1 206 Partial Content");
|
|
header("Content-Length: $new_length");
|
|
header("Content-Range: bytes $range$size2/$size");
|
|
} else {
|
|
$size2 = $size - 1;
|
|
header("Content-Range: bytes 0-$size2/$size");
|
|
header("Content-Length: " . $size);
|
|
}
|
|
|
|
if ($size == 0) {
|
|
die('Zero byte file! Aborting download');
|
|
}
|
|
@ini_set('magic_quotes_runtime', 0);
|
|
$fp = fopen("$fileLocation", "rb");
|
|
|
|
fseek($fp, $range);
|
|
|
|
while (!feof($fp) and (connection_status() == 0)) {
|
|
set_time_limit(0);
|
|
print(@fread($fp, 1024*$chunkSize));
|
|
flush();
|
|
ob_flush();
|
|
sleep(1);
|
|
}
|
|
fclose($fp);
|
|
|
|
return ((connection_status() == 0) and !connection_aborted());
|
|
}
|
|
|
|
function fm_get_theme() {
|
|
$result = '';
|
|
if(FM_THEME == "dark") {
|
|
$result = "text-white bg-dark";
|
|
}
|
|
return $result;
|
|
}
|
|
|
|
/**
|
|
* Class to work with zip files (using ZipArchive)
|
|
*/
|
|
class FM_Zipper
|
|
{
|
|
private $zip;
|
|
|
|
public function __construct()
|
|
{
|
|
$this->zip = new ZipArchive();
|
|
}
|
|
|
|
/**
|
|
* Create archive with name $filename and files $files (RELATIVE PATHS!)
|
|
* @param string $filename
|
|
* @param array|string $files
|
|
* @return bool
|
|
*/
|
|
public function create($filename, $files)
|
|
{
|
|
$res = $this->zip->open($filename, ZipArchive::CREATE);
|
|
if ($res !== true) {
|
|
return false;
|
|
}
|
|
if (is_array($files)) {
|
|
foreach ($files as $f) {
|
|
if (!$this->addFileOrDir($f)) {
|
|
$this->zip->close();
|
|
return false;
|
|
}
|
|
}
|
|
$this->zip->close();
|
|
return true;
|
|
} else {
|
|
if ($this->addFileOrDir($files)) {
|
|
$this->zip->close();
|
|
return true;
|
|
}
|
|
return false;
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Extract archive $filename to folder $path (RELATIVE OR ABSOLUTE PATHS)
|
|
* @param string $filename
|
|
* @param string $path
|
|
* @return bool
|
|
*/
|
|
public function unzip($filename, $path)
|
|
{
|
|
$res = $this->zip->open($filename);
|
|
if ($res !== true) {
|
|
return false;
|
|
}
|
|
if ($this->zip->extractTo($path)) {
|
|
$this->zip->close();
|
|
return true;
|
|
}
|
|
return false;
|
|
}
|
|
|
|
/**
|
|
* Add file/folder to archive
|
|
* @param string $filename
|
|
* @return bool
|
|
*/
|
|
private function addFileOrDir($filename)
|
|
{
|
|
if (is_file($filename)) {
|
|
return $this->zip->addFile($filename);
|
|
} elseif (is_dir($filename)) {
|
|
return $this->addDir($filename);
|
|
}
|
|
return false;
|
|
}
|
|
|
|
/**
|
|
* Add folder recursively
|
|
* @param string $path
|
|
* @return bool
|
|
*/
|
|
private function addDir($path)
|
|
{
|
|
if (!$this->zip->addEmptyDir($path)) {
|
|
return false;
|
|
}
|
|
$objects = scandir($path);
|
|
if (is_array($objects)) {
|
|
foreach ($objects as $file) {
|
|
if ($file != '.' && $file != '..') {
|
|
if (is_dir($path . '/' . $file)) {
|
|
if (!$this->addDir($path . '/' . $file)) {
|
|
return false;
|
|
}
|
|
} elseif (is_file($path . '/' . $file)) {
|
|
if (!$this->zip->addFile($path . '/' . $file)) {
|
|
return false;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
return true;
|
|
}
|
|
return false;
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Class to work with Tar files (using PharData)
|
|
*/
|
|
class FM_Zipper_Tar
|
|
{
|
|
private $tar;
|
|
|
|
public function __construct()
|
|
{
|
|
$this->tar = null;
|
|
}
|
|
|
|
/**
|
|
* Create archive with name $filename and files $files (RELATIVE PATHS!)
|
|
* @param string $filename
|
|
* @param array|string $files
|
|
* @return bool
|
|
*/
|
|
public function create($filename, $files)
|
|
{
|
|
$this->tar = new PharData($filename);
|
|
if (is_array($files)) {
|
|
foreach ($files as $f) {
|
|
if (!$this->addFileOrDir($f)) {
|
|
return false;
|
|
}
|
|
}
|
|
return true;
|
|
} else {
|
|
if ($this->addFileOrDir($files)) {
|
|
return true;
|
|
}
|
|
return false;
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Extract archive $filename to folder $path (RELATIVE OR ABSOLUTE PATHS)
|
|
* @param string $filename
|
|
* @param string $path
|
|
* @return bool
|
|
*/
|
|
public function unzip($filename, $path)
|
|
{
|
|
$res = $this->tar->open($filename);
|
|
if ($res !== true) {
|
|
return false;
|
|
}
|
|
if ($this->tar->extractTo($path)) {
|
|
return true;
|
|
}
|
|
return false;
|
|
}
|
|
|
|
/**
|
|
* Add file/folder to archive
|
|
* @param string $filename
|
|
* @return bool
|
|
*/
|
|
private function addFileOrDir($filename)
|
|
{
|
|
if (is_file($filename)) {
|
|
try {
|
|
$this->tar->addFile($filename);
|
|
return true;
|
|
} catch (Exception $e) {
|
|
return false;
|
|
}
|
|
} elseif (is_dir($filename)) {
|
|
return $this->addDir($filename);
|
|
}
|
|
return false;
|
|
}
|
|
|
|
/**
|
|
* Add folder recursively
|
|
* @param string $path
|
|
* @return bool
|
|
*/
|
|
private function addDir($path)
|
|
{
|
|
$objects = scandir($path);
|
|
if (is_array($objects)) {
|
|
foreach ($objects as $file) {
|
|
if ($file != '.' && $file != '..') {
|
|
if (is_dir($path . '/' . $file)) {
|
|
if (!$this->addDir($path . '/' . $file)) {
|
|
return false;
|
|
}
|
|
} elseif (is_file($path . '/' . $file)) {
|
|
try {
|
|
$this->tar->addFile($path . '/' . $file);
|
|
} catch (Exception $e) {
|
|
return false;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
return true;
|
|
}
|
|
return false;
|
|
}
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
* Save Configuration
|
|
*/
|
|
class FM_Config
|
|
{
|
|
var $data;
|
|
|
|
function __construct()
|
|
{
|
|
global $root_path, $root_url, $CONFIG;
|
|
$fm_url = $root_url.$_SERVER["PHP_SELF"];
|
|
$this->data = array(
|
|
'lang' => 'en',
|
|
'error_reporting' => true,
|
|
'show_hidden' => true
|
|
);
|
|
$data = false;
|
|
if (strlen($CONFIG)) {
|
|
$data = fm_object_to_array(json_decode($CONFIG));
|
|
} else {
|
|
$msg = 'Netcloud File Manager<br>Error: Cannot load configuration';
|
|
if (substr($fm_url, -1) == '/') {
|
|
$fm_url = rtrim($fm_url, '/');
|
|
$msg .= '<br>';
|
|
$msg .= '<br>Seems like you have a trailing slash on the URL.';
|
|
$msg .= '<br>Try this link: <a href="' . $fm_url . '">' . $fm_url . '</a>';
|
|
}
|
|
die($msg);
|
|
}
|
|
if (is_array($data) && count($data)) $this->data = $data;
|
|
else $this->save();
|
|
}
|
|
|
|
function save()
|
|
{
|
|
$fm_file = __FILE__;
|
|
$var_name = '$CONFIG';
|
|
$var_value = var_export(json_encode($this->data), true);
|
|
$config_string = "<?php" . chr(13) . chr(10) . "//Default Configuration".chr(13) . chr(10)."$var_name = $var_value;" . chr(13) . chr(10);
|
|
if (is_writable($fm_file)) {
|
|
$lines = file($fm_file);
|
|
if ($fh = @fopen($fm_file, "w")) {
|
|
@fputs($fh, $config_string, strlen($config_string));
|
|
for ($x = 3; $x < count($lines); $x++) {
|
|
@fputs($fh, $lines[$x], strlen($lines[$x]));
|
|
}
|
|
@fclose($fh);
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
|
|
|
|
//--- templates functions
|
|
|
|
/**
|
|
* Show nav block
|
|
* @param string $path
|
|
*/
|
|
function fm_show_nav_path($path)
|
|
{
|
|
global $lang, $sticky_navbar;
|
|
$isStickyNavBar = $sticky_navbar ? 'fixed-top' : '';
|
|
$getTheme = fm_get_theme();
|
|
$getTheme .= " navbar-light";
|
|
if(FM_THEME == "dark") {
|
|
$getTheme .= " navbar-dark";
|
|
} else {
|
|
$getTheme .= " bg-white";
|
|
}
|
|
?>
|
|
<nav class="navbar navbar-expand-lg <?php echo $getTheme; ?> mb-4 main-nav <?php echo $isStickyNavBar ?>">
|
|
<a class="navbar-brand" href=""> <?php echo lng('AppTitle') ?> </a>
|
|
<button class="navbar-toggler" type="button" data-toggle="collapse" data-target="#navbarSupportedContent" aria-controls="navbarSupportedContent" aria-expanded="false" aria-label="Toggle navigation">
|
|
<span class="navbar-toggler-icon"></span>
|
|
</button>
|
|
<div class="collapse navbar-collapse" id="navbarSupportedContent">
|
|
|
|
<?php
|
|
$path = fm_clean_path($path);
|
|
$root_url = "<a href='?p='><i class='fa fa-home' aria-hidden='true' title='" . FM_ROOT_PATH . "'></i></a>";
|
|
$sep = '<i class="bread-crumb"> / </i>';
|
|
if ($path != '') {
|
|
$exploded = explode('/', $path);
|
|
$count = count($exploded);
|
|
$array = array();
|
|
$parent = '';
|
|
for ($i = 0; $i < $count; $i++) {
|
|
$parent = trim($parent . '/' . $exploded[$i], '/');
|
|
$parent_enc = urlencode($parent);
|
|
$array[] = "<a href='?p={$parent_enc}'>" . fm_enc(fm_convert_win($exploded[$i])) . "</a>";
|
|
}
|
|
$root_url .= $sep . implode($sep, $array);
|
|
}
|
|
echo '<div class="col-xs-6 col-sm-5">' . $root_url . '</div>';
|
|
?>
|
|
|
|
<div class="col-xs-6 col-sm-7 text-right">
|
|
<ul class="navbar-nav mr-auto float-right <?php echo fm_get_theme(); ?>">
|
|
<li class="nav-item mr-2">
|
|
<div class="input-group input-group-sm mr-1" style="margin-top:4px;">
|
|
<input type="text" class="form-control" placeholder="<?php echo lng('Search') ?>" aria-label="<?php echo lng('Search') ?>" aria-describedby="search-addon2" id="search-addon">
|
|
<div class="input-group-append">
|
|
<span class="input-group-text" id="search-addon2"><i class="fa fa-search"></i></span>
|
|
</div>
|
|
<div class="input-group-append btn-group">
|
|
<span class="input-group-text dropdown-toggle" id="search-addon2" data-toggle="dropdown" aria-haspopup="true" aria-expanded="false"></span>
|
|
<div class="dropdown-menu dropdown-menu-right">
|
|
<a class="dropdown-item" href="<?php echo $path2 = $path ? $path : '.'; ?>" id="js-search-modal" data-toggle="modal" data-target="#searchModal">Advanced Search</a>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</li>
|
|
<?php if (!FM_READONLY): ?>
|
|
<li class="nav-item">
|
|
<a title="<?php echo lng('Upload') ?>" class="nav-link" href="?p=<?php echo urlencode(FM_PATH) ?>&upload"><i class="fa fa-cloud-upload" aria-hidden="true"></i> <?php echo lng('Upload') ?></a>
|
|
</li>
|
|
<li class="nav-item">
|
|
<a title="<?php echo lng('NewItem') ?>" class="nav-link" href="#createNewItem" data-toggle="modal" data-target="#createNewItem"><i class="fa fa-plus-square"></i> <?php echo lng('NewItem') ?></a>
|
|
</li>
|
|
<?php endif; ?>
|
|
<?php if (FM_USE_AUTH): ?>
|
|
<li class="nav-item avatar dropdown">
|
|
<a class="nav-link dropdown-toggle" id="navbarDropdownMenuLink-5" data-toggle="dropdown" aria-haspopup="true" aria-expanded="false"> <i class="fa fa-user-circle"></i> <?php if(isset($_SESSION[FM_SESSION_ID]['logged'])) { echo $_SESSION[FM_SESSION_ID]['logged']; } ?></a>
|
|
<div class="dropdown-menu dropdown-menu-right <?php echo fm_get_theme(); ?>" aria-labelledby="navbarDropdownMenuLink-5">
|
|
<?php if (!FM_READONLY): ?>
|
|
<a title="<?php echo lng('Settings') ?>" class="dropdown-item nav-link" href="?p=<?php echo urlencode(FM_PATH) ?>&settings=1"><i class="fa fa-cog" aria-hidden="true"></i> <?php echo lng('Settings') ?></a>
|
|
<?php endif ?>
|
|
<a title="<?php echo lng('Help') ?>" class="dropdown-item nav-link" href="?p=<?php echo urlencode(FM_PATH) ?>&help=2"><i class="fa fa-exclamation-circle" aria-hidden="true"></i> <?php echo lng('Help') ?></a>
|
|
<a title="<?php echo lng('Logout') ?>" class="dropdown-item nav-link" href="?logout=1"><i class="fa fa-sign-out" aria-hidden="true"></i> <?php echo lng('Logout') ?></a>
|
|
</div>
|
|
</li>
|
|
<?php else: ?>
|
|
<?php if (!FM_READONLY): ?>
|
|
<li class="nav-item">
|
|
<a title="<?php echo lng('Settings') ?>" class="dropdown-item nav-link" href="?p=<?php echo urlencode(FM_PATH) ?>&settings=1"><i class="fa fa-cog" aria-hidden="true"></i> <?php echo lng('Settings') ?></a>
|
|
</li>
|
|
<?php endif; ?>
|
|
<?php endif; ?>
|
|
</ul>
|
|
</div>
|
|
</div>
|
|
</nav>
|
|
<?php
|
|
}
|
|
|
|
/**
|
|
* Show message from session
|
|
*/
|
|
function fm_show_message()
|
|
{
|
|
if (isset($_SESSION[FM_SESSION_ID]['message'])) {
|
|
$class = isset($_SESSION[FM_SESSION_ID]['status']) ? $_SESSION[FM_SESSION_ID]['status'] : 'ok';
|
|
echo '<p class="message ' . $class . '">' . $_SESSION[FM_SESSION_ID]['message'] . '</p>';
|
|
unset($_SESSION[FM_SESSION_ID]['message']);
|
|
unset($_SESSION[FM_SESSION_ID]['status']);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Show page header in Login Form
|
|
*/
|
|
function fm_show_header_login()
|
|
{
|
|
$sprites_ver = '20160315';
|
|
header("Content-Type: text/html; charset=utf-8");
|
|
header("Expires: Sat, 26 Jul 1997 05:00:00 GMT");
|
|
header("Cache-Control: no-store, no-cache, must-revalidate, post-check=0, pre-check=0");
|
|
header("Pragma: no-cache");
|
|
|
|
global $lang, $root_url, $favicon_path;
|
|
?>
|
|
<!DOCTYPE html>
|
|
<html lang="en">
|
|
<head>
|
|
<meta charset="utf-8">
|
|
<meta name="viewport" content="width=device-width, initial-scale=1, shrink-to-fit=no">
|
|
<meta name="robots" content="noindex, nofollow">
|
|
<meta name="googlebot" content="noindex">
|
|
<link rel="icon" href="<?php echo fm_enc($favicon_path) ?>" type="image/png">
|
|
<title><?php echo fm_enc(APP_TITLE) ?></title>
|
|
<link rel="stylesheet" href="https://stackpath.bootstrapcdn.com/bootstrap/4.5.0/css/bootstrap.min.css">
|
|
<style>
|
|
body.fm-login-page{ background-color:#f7f9fb;font-size:14px;background-color:#f7f9fb;background-image:url("assets/images/MITbg.jpg");}
|
|
.fm-login-page .brand{ width:121px;overflow:hidden;margin:0 auto;position:relative;z-index:1}
|
|
.fm-login-page .brand img{ width:100%}
|
|
.netcloud-logo {
|
|
background-image: url(assets/images/Netcloud-Logo_Weiss.png);
|
|
height: 60px;
|