From 1f5c010dfc55d216397eb77fd3d598bc0a0bd504 Mon Sep 17 00:00:00 2001 From: eddydu44 Date: Tue, 26 Dec 2017 16:05:40 +0100 Subject: [PATCH 01/12] add link to file manager page --- index.html | 8 +++++++- 1 file changed, 7 insertions(+), 1 deletion(-) diff --git a/index.html b/index.html index d59693ea..53a0c0b4 100644 --- a/index.html +++ b/index.html @@ -299,7 +299,13 @@ - + From 942f829d7aaf031cb6d758e28eb5788581e151a2 Mon Sep 17 00:00:00 2001 From: eddydu44 Date: Tue, 26 Dec 2017 16:07:20 +0100 Subject: [PATCH 02/12] Add files via upload --- file-manager.php | 464 +++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 464 insertions(+) create mode 100644 file-manager.php diff --git a/file-manager.php b/file-manager.php new file mode 100644 index 00000000..9deffcb7 --- /dev/null +++ b/file-manager.php @@ -0,0 +1,464 @@ +
PASSWORD:
'; + exit; + } +} + +// must be in UTF-8 or `basename` doesn't work +setlocale(LC_ALL,'en_US.UTF-8'); + +$tmp_dir = dirname($_SERVER['SCRIPT_FILENAME']); +if(DIRECTORY_SEPARATOR==='\\') $tmp_dir = str_replace('/',DIRECTORY_SEPARATOR,$tmp_dir); +$tmp = get_absolute_path($tmp_dir . '/' .$_REQUEST['file']); + +if($tmp === false) + err(404,'File or Directory Not Found'); +if(substr($tmp, 0,strlen($tmp_dir)) !== $tmp_dir) + err(403,"Forbidden"); +if(strpos($_REQUEST['file'], DIRECTORY_SEPARATOR) === 0) + err(403,"Forbidden"); + + +if(!$_COOKIE['_sfm_xsrf']) + setcookie('_sfm_xsrf',bin2hex(openssl_random_pseudo_bytes(16))); +if($_POST) { + if($_COOKIE['_sfm_xsrf'] !== $_POST['xsrf'] || !$_POST['xsrf']) + err(403,"XSRF Failure"); +} + +$file = $_REQUEST['file'] ?: '.'; +if($_GET['do'] == 'list') { + if (is_dir($file)) { + $directory = $file; + $result = []; + $files = array_diff(scandir($directory), ['.','..']); + foreach($files as $entry) if($entry !== basename(__FILE__) && !in_array(strtolower(pathinfo($entry, PATHINFO_EXTENSION)), $hidden_extensions)) { + $i = $directory . '/' . $entry; + $stat = stat($i); + $result[] = [ + 'mtime' => $stat['mtime'], + 'size' => $stat['size'], + 'name' => basename($i), + 'path' => preg_replace('@^\./@', '', $i), + 'is_dir' => is_dir($i), + 'is_deleteable' => $allow_delete && ((!is_dir($i) && is_writable($directory)) || + (is_dir($i) && is_writable($directory) && is_recursively_deleteable($i))), + 'is_readable' => is_readable($i), + 'is_writable' => is_writable($i), + 'is_executable' => is_executable($i), + ]; + } + } else { + err(412,"Not a Directory"); + } + echo json_encode(['success' => true, 'is_writable' => is_writable($file), 'results' =>$result]); + exit; +} elseif ($_POST['do'] == 'delete') { + if($allow_delete) { + rmrf($file); + } + exit; +} elseif ($_POST['do'] == 'mkdir' && $allow_create_folder== true) { + // don't allow actions outside root. we also filter out slashes to catch args like './../outside' + $dir = $_POST['name']; + $dir = str_replace('/', '', $dir); + if(substr($dir, 0, 2) === '..') + exit; + chdir($file); + @mkdir($_POST['name']); + exit; +} elseif ($_POST['do'] == 'upload' && $allow_upload == true) { + var_dump($_POST); + var_dump($_FILES); + var_dump($_FILES['file_data']['tmp_name']); + foreach($disallowed_extensions as $ext) + if(preg_match(sprintf('/\.%s$/',preg_quote($ext)), $_FILES['file_data']['name'])) + err(403,"Files of this type are not allowed."); + + var_dump(move_uploaded_file($_FILES['file_data']['tmp_name'], $file.'/'.$_FILES['file_data']['name'])); + exit; +} elseif ($_GET['do'] == 'download') { + $filename = basename($file); + header('Content-Type: ' . mime_content_type($file)); + header('Content-Length: '. filesize($file)); + header(sprintf('Content-Disposition: attachment; filename=%s', + strpos('MSIE',$_SERVER['HTTP_REFERER']) ? rawurlencode($filename) : "\"$filename\"" )); + ob_flush(); + readfile($file); + exit; +} +function rmrf($dir) { + if(is_dir($dir)) { + $files = array_diff(scandir($dir), ['.','..']); + foreach ($files as $file) + rmrf("$dir/$file"); + rmdir($dir); + } else { + unlink($dir); + } +} +function is_recursively_deleteable($d) { + $stack = [$d]; + while($dir = array_pop($stack)) { + if(!is_readable($dir) || !is_writable($dir)) + return false; + $files = array_diff(scandir($dir), ['.','..']); + foreach($files as $file) if(is_dir($file)) { + $stack[] = "$dir/$file"; + } + } + return true; +} + +// from: http://php.net/manual/en/function.realpath.php#84012 +function get_absolute_path($path) { + $path = str_replace(['/', '\\'], DIRECTORY_SEPARATOR, $path); + $parts = explode(DIRECTORY_SEPARATOR, $path); + $absolutes = []; + foreach ($parts as $part) { + if ('.' == $part) continue; + if ('..' == $part) { + array_pop($absolutes); + } else { + $absolutes[] = $part; + } + } + return implode(DIRECTORY_SEPARATOR, $absolutes); + } + +function err($code,$msg) { + http_response_code($code); + echo json_encode(['error' => ['code'=>intval($code), 'msg' => $msg]]); + exit; +} + +function asBytes($ini_v) { + $ini_v = trim($ini_v); + $s = ['g'=> 1<<30, 'm' => 1<<20, 'k' => 1<<10]; + return intval($ini_v) * ($s[strtolower(substr($ini_v,-1))] ?: 1); +} +$MAX_UPLOAD_SIZE = min(asBytes(ini_get('post_max_size')), asBytes(ini_get('upload_max_filesize'))); +?> + + + + + + + + +
+ +
+ + +
+ + + + + +
+ Drag Files Here To Upload + or + +
+ + +
+ +
+ + + + + + + + +
NameSizeModifiedPermissionsActions
+ + From 359e131d9b3d3dca56b22d1157861f58343c376e Mon Sep 17 00:00:00 2001 From: eddydu44 Date: Tue, 26 Dec 2017 16:29:12 +0100 Subject: [PATCH 03/12] Add files via upload --- tinyfilemanager.php | 2246 +++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 2246 insertions(+) create mode 100644 tinyfilemanager.php diff --git a/tinyfilemanager.php b/tinyfilemanager.php new file mode 100644 index 00000000..6c9451e6 --- /dev/null +++ b/tinyfilemanager.php @@ -0,0 +1,2246 @@ + 'Password', 'Username2' => 'Password2', ...), Password has to encripted into MD5 +$auth_users = array( + 'admin' => '21232f297a57a5a743894a0e4a801fc3', //admin + 'user' => '827ccb0eea8a706c4c34a16891f84e7b', //12345 +); + +// Readonly users (usernames array) +$readonly_users = array( + 'user' +); + +// Show or hide files and folders that starts with a dot +$show_hidden_files = true; + +// Enable highlight.js (https://highlightjs.org/) on view's page +$use_highlightjs = true; + +// highlight.js style +$highlightjs_style = 'vs'; + +// Enable ace.js (https://ace.c9.io/) on view's page +$edit_files = true; + +// Send files though mail +$send_mail = false; + +// Send files though mail +$toMailId = ""; //yourmailid@mail.com + +// Default timezone for date() and time() - http://php.net/manual/en/timezones.php +$default_timezone = 'Etc/UTC'; // UTC + +// Root path for file manager +$root_path = $_SERVER['DOCUMENT_ROOT']; + +// 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']; + +// input encoding for iconv +$iconv_input_encoding = 'UTF-8'; + +// date() format for file modification date +$datetime_format = 'd.m.y H:i'; + +// allowed upload file extensions +$upload_extensions = ''; // 'gif,png,jpg' + +// show or hide the left side tree view +$show_tree_view = true; + +//Array of folders excluded from listing +$GLOBALS['exclude_folders'] = array( +); + +// include user config php file +if (defined('FM_CONFIG') && is_file(FM_CONFIG) ) { + include(FM_CONFIG); +} + +//--- EDIT BELOW CAREFULLY OR DO NOT EDIT AT ALL + +// if fm included +if (defined('FM_EMBED')) { + $use_auth = 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('filemanager'); + session_start(); +} + +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'; + +// clean and check $root_path +$root_path = rtrim($root_path, '\\/'); +$root_path = str_replace('\\', '/', $root_path); +if (!@is_dir($root_path)) { + echo "

Root path \"{$root_path}\" not found!

"; + exit; +} + +// clean $root_url +$root_url = fm_clean_path($root_url); + +// abs path for site +defined('FM_SHOW_HIDDEN') || define('FM_SHOW_HIDDEN', $show_hidden_files); +defined('FM_ROOT_PATH') || define('FM_ROOT_PATH', $root_path); +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['logged']); + fm_redirect(FM_SELF_URL); +} + +// Show image here +if (isset($_GET['img'])) { + fm_show_image($_GET['img']); +} + +// Auth +if ($use_auth) { + if (isset($_SESSION['logged'], $auth_users[$_SESSION['logged']])) { + // Logged + } elseif (isset($_POST['fm_usr'], $_POST['fm_pwd'])) { + // Logging In + sleep(1); + if (isset($auth_users[$_POST['fm_usr']]) && md5($_POST['fm_pwd']) === $auth_users[$_POST['fm_usr']]) { + $_SESSION['logged'] = $_POST['fm_usr']; + fm_set_msg('You are logged in'); + fm_redirect(FM_SELF_URL . '?p='); + } else { + unset($_SESSION['logged']); + fm_set_msg('Wrong password', 'error'); + fm_redirect(FM_SELF_URL); + } + } else { + // Form + unset($_SESSION['logged']); + fm_show_header_login(); + fm_show_message(); + ?> + + %s deleted' : 'File %s deleted'; + fm_set_msg(sprintf($msg, fm_enc($del))); + } else { + $msg = $is_dir ? 'Folder %s not deleted' : 'File %s not deleted'; + fm_set_msg(sprintf($msg, fm_enc($del)), 'error'); + } + } else { + fm_set_msg('Wrong 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) { + $new = strip_tags($_GET['new']); + $type = $_GET['type']; + $new = fm_clean_path($new); + $new = str_replace('/', '', $new); + if ($new != '' && $new != '..' && $new != '.') { + $path = FM_ROOT_PATH; + if (FM_PATH != '') { + $path .= '/' . FM_PATH; + } + if($_GET['type']=="file") { + if(!file_exists($path . '/' . $new)) { + @fopen($path . '/' . $new, 'w') or die('Cannot open file: '.$new); + fm_set_msg(sprintf('File %s created', fm_enc($new))); + } else { + fm_set_msg(sprintf('File %s already exists', fm_enc($new)), 'alert'); + } + } else { + if (fm_mkdir($path . '/' . $new, false) === true) { + fm_set_msg(sprintf('Folder %s created', $new)); + } elseif (fm_mkdir($path . '/' . $new, false) === $path . '/' . $new) { + fm_set_msg(sprintf('Folder %s already exists', fm_enc($new)), 'alert'); + } else { + fm_set_msg(sprintf('Folder %s not created', fm_enc($new)), 'error'); + } + } + } else { + fm_set_msg('Wrong 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 + if ($from != $dest) { + $msg_from = trim(FM_PATH . '/' . basename($from), '/'); + if ($move) { + $rename = fm_rename($from, $dest); + if ($rename) { + fm_set_msg(sprintf('Moved from %s to %s', 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 %s to %s', fm_enc($copy), fm_enc($msg_from)), 'error'); + } + } else { + if (fm_rcopy($from, $dest)) { + fm_set_msg(sprintf('Copyied from %s to %s', fm_enc($copy), fm_enc($msg_from))); + } else { + fm_set_msg(sprintf('Error while copying from %s to %s', fm_enc($copy), fm_enc($msg_from)), '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($new); + $new = str_replace('/', '', $new); + // path + $path = FM_ROOT_PATH; + if (FM_PATH != '') { + $path .= '/' . FM_PATH; + } + // rename + if ($old != '' && $new != '') { + if (fm_rename($path . '/' . $old, $path . '/' . $new)) { + fm_set_msg(sprintf('Renamed from %s to %s', fm_enc($old), fm_enc($new))); + } else { + fm_set_msg(sprintf('Error while renaming from %s to %s', fm_enc($old), fm_enc($new)), 'error'); + } + } else { + fm_set_msg('Names not set', '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)) { + header('Content-Description: File Transfer'); + header('Content-Type: application/octet-stream'); + header('Content-Disposition: attachment; filename="' . basename($path . '/' . $dl) . '"'); + header('Content-Transfer-Encoding: binary'); + header('Connection: Keep-Alive'); + header('Expires: 0'); + header('Cache-Control: must-revalidate, post-check=0, pre-check=0'); + header('Pragma: public'); + header('Content-Length: ' . filesize($path . '/' . $dl)); + readfile($path . '/' . $dl); + exit; + } else { + fm_set_msg('File not found', 'error'); + fm_redirect(FM_SELF_URL . '?p=' . urlencode(FM_PATH)); + } +} + +// Upload +if (isset($_POST['upl']) && !FM_READONLY) { + $path = FM_ROOT_PATH; + if (FM_PATH != '') { + $path .= '/' . FM_PATH; + } + + $errors = 0; + $uploads = 0; + $total = count($_FILES['upload']['name']); + $allowed = (FM_EXTENSION) ? explode(',', FM_EXTENSION) : false; + + for ($i = 0; $i < $total; $i++) { + $filename = $_FILES['upload']['name'][$i]; + $tmp_name = $_FILES['upload']['tmp_name'][$i]; + $ext = pathinfo($filename, PATHINFO_EXTENSION); + $isFileAllowed = ($allowed) ? in_array($ext,$allowed) : true; + if (empty($_FILES['upload']['error'][$i]) && !empty($tmp_name) && $tmp_name != 'none' && $isFileAllowed) { + if (move_uploaded_file($tmp_name, $path . '/' . $_FILES['upload']['name'][$i])) { + $uploads++; + } else { + $errors++; + } + } + } + + if ($errors == 0 && $uploads > 0) { + fm_set_msg(sprintf('All files uploaded to %s', fm_enc($path))); + } elseif ($errors == 0 && $uploads == 0) { + fm_set_msg('Nothing uploaded', 'alert'); + } else { + fm_set_msg(sprintf('Error while uploading files. Uploaded files: %s', $uploads), 'error'); + } + fm_redirect(FM_SELF_URL . '?p=' . urlencode(FM_PATH)); +} + +// 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'], $_POST['zip']) && !FM_READONLY) { + $path = FM_ROOT_PATH; + if (FM_PATH != '') { + $path .= '/' . FM_PATH; + } + + if (!class_exists('ZipArchive')) { + 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') . '.zip'; + } else { + $zipname = 'archive_' . date('ymd_His') . '.zip'; + } + + $zipper = new FM_Zipper(); + $res = $zipper->create($zipname, $files); + + if ($res) { + fm_set_msg(sprintf('Archive %s 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); + + $path = FM_ROOT_PATH; + if (FM_PATH != '') { + $path .= '/' . FM_PATH; + } + + if (!class_exists('ZipArchive')) { + fm_set_msg('Operations with archives are not available', 'error'); + fm_redirect(FM_SELF_URL . '?p=' . urlencode(FM_PATH)); + } + + if ($unzip != '' && is_file($path . '/' . $unzip)) { + $zip_path = $path . '/' . $unzip; + + //to folder + $tofolder = ''; + if (isset($_GET['tofolder'])) { + $tofolder = pathinfo($zip_path, PATHINFO_FILENAME); + if (fm_mkdir($path . '/' . $tofolder, true)) { + $path .= '/' . $tofolder; + } + } + + $zipper = new FM_Zipper(); + $res = $zipper->unzip($zip_path, $path); + + 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(); +if (is_array($objects)) { + foreach ($objects as $file) { + if ($file == '.' || $file == '..' && in_array($file, $GLOBALS['exclude_folders'])) { + continue; + } + if (!FM_SHOW_HIDDEN && substr($file, 0, 1) === '.') { + continue; + } + $new_path = $path . '/' . $file; + if (is_file($new_path)) { + $files[] = $file; + } elseif (is_dir($new_path) && $file != '.' && $file != '..' && !in_array($file, $GLOBALS['exclude_folders'])) { + $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 + ?> +
+

Uploading files

+

Destination folder:

+
+ + +
+
+
+
+
+
+

+   + Cancel +

+
+
+ +
+

Copying

+
+ + + ' . PHP_EOL; + } + ?> +

Files: , ', $copy_files) ?>

+

Source folder:
+ + / +

+

+

+   + Cancel +

+ +
+ +
+

Copying

+

+ Source path:
+ Destination folder: +

+

+ Copy   + Move   + Cancel +

+

Select folder

+ +
+ +
+

""

+

+ Full path:
+ File size: = 1000): ?> ()
+ MIME-type:
+ + Files in archive:
+ Total size:
+ Size in archive:
+ Compression: %
+ '; + } + // 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') . '
'; + } + ?> +

+

+ Download   + Open   + + UnZip   + + UnZip to folder   + + Edit   + Advanced Edit   + + Mail   + + Back +

+ '; + foreach ($filenames as $fn) { + if ($fn['folder']) { + echo '' . fm_enc($fn['name']) . '
'; + } else { + echo $fn['name'] . ' (' . fm_get_filesize($fn['filesize']) . ')
'; + } + } + echo ''; + } else { + echo '

Error while fetching archive info

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

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

'; + } elseif ($is_video) { + // Video content + echo '
'; + } elseif ($is_text) { + if (FM_USE_HIGHLIGHTJS) { + // highlight + $hljs_classes = array( + 'shtml' => 'xml', + 'htaccess' => 'apache', + 'phtml' => 'php', + 'lock' => 'json', + 'svg' => 'xml', + ); + $hljs_class = isset($hljs_classes[$ext]) ? 'lang-' . $hljs_classes[$ext] : 'lang-' . $ext; + if (empty($ext) || in_array(strtolower($file), fm_get_text_names()) || preg_match('#\.min\.(css|js)$#i', $file)) { + $hljs_class = 'nohighlight'; + } + $content = '
' . fm_enc($content) . '
'; + } elseif (in_array($ext, array('php', 'php4', 'php5', 'phtml', 'phps'))) { + // php highlight + $content = highlight_string($content, true); + } else { + $content = '
' . fm_enc($content) . '
'; + } + echo $content; + } + ?> +
+ +
+
+ Cancel + Backup + + + Advanced Editor + + + Plain Editor + + + +
+ '. htmlspecialchars($content) .''; + } elseif ($is_text) { + echo '
'. htmlspecialchars($content) .'
'; + } else { + fm_set_msg('FILE EXTENSION HAS NOT SUPPORTED', 'error'); + } + ?> +
+ +
+

+

+
+

+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + +
OwnerGroupOther
Read
Write
Execute
+ +

+   + Cancel +

+ +
+ +
+ +
+ + + +
+
Browse
+ +
+ + + + + + + + + + '?'); + $group = array('name' => '?'); + } + ?> + + + + + + + + + + '?'); + $group = array('name' => '?'); + } + ?> + + + + + + + + + + + + + + + +
NameSizeModifiedPermsOwnerActions
..
' . readlink($path . '/' . $f) . '' : '') ?>
Folder + + + + + +
' . readlink($path . '/' . $f) . '' : '') ?>
+ + + + + + + +
+Full size: , +files: , +folders: +
+ + + +
+ += $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; +} + +/** + * Clean path + * @param string $path + * @return string + */ +function fm_clean_path($path) +{ + $path = trim($path); + $path = trim($path, '\\/'); + $path = str_replace(array('../', '..\\'), '', $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; +} + +/** + * Get nice filesize + * @param int $size + * @return string + */ +function fm_get_filesize($size) +{ + if ($size < 1000) { + return sprintf('%s B', $size); + } elseif (($size / 1024) < 1000) { + return sprintf('%s KiB', round(($size / 1024), 2)); + } elseif (($size / 1024 / 1024) < 1000) { + return sprintf('%s MiB', round(($size / 1024 / 1024), 2)); + } elseif (($size / 1024 / 1024 / 1024) < 1000) { + return sprintf('%s GiB', round(($size / 1024 / 1024 / 1024), 2)); + } else { + return sprintf('%s TiB', round(($size / 1024 / 1024 / 1024 / 1024), 2)); + } +} + +/** + * Get info about zip archive + * @param string $path + * @return array|bool + */ +function fm_get_zif_info($path) +{ + if (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; + } + } + return false; +} + +/** + * Encode html entities + * @param string $text + * @return string + */ +function fm_enc($text) +{ + return htmlspecialchars($text, ENT_QUOTES, 'UTF-8'); +} + +/** + * This function scans the files folder recursively, and builds a large array + * @param string $dir + * @return json + */ +function scan($dir){ + $files = array(); + $_dir = $dir; + $dir = FM_ROOT_PATH.'/'.$dir; + // Is there actually such a folder/file? + if(file_exists($dir)){ + foreach(scandir($dir) as $f) { + if(!$f || $f[0] == '.') { + continue; // Ignore hidden files + } + + if(is_dir($dir . '/' . $f)) { + // The path is a folder + $files[] = array( + "name" => $f, + "type" => "folder", + "path" => $_dir.'/'.$f, + "items" => scan($dir . '/' . $f), // Recursively get the contents of the folder + ); + } else { + // It is a file + $files[] = array( + "name" => $f, + "type" => "file", + "path" => $_dir, + "size" => filesize($dir . '/' . $f) // Gets the size of this file + ); + } + } + } + return $files; +} + +/** +* Scan directory and return tree view +* @param string $directory +* @param boolean $first_call +*/ +function php_file_tree_dir($directory, $first_call = true) { + // Recursive function called by php_file_tree() to list directories/files + + $php_file_tree = ""; + // Get and sort directories/files + if( function_exists("scandir") ) $file = scandir($directory); + natcasesort($file); + // Make directories first + $files = $dirs = array(); + foreach($file as $this_file) { + if( is_dir("$directory/$this_file" ) ) { + if(!in_array($this_file, $GLOBALS['exclude_folders'])){ + $dirs[] = $this_file; + } + } else { + $files[] = $this_file; + } + } + $file = array_merge($dirs, $files); + + if( count($file) > 2 ) { // Use 2 instead of 0 to account for . and .. "directories" + $php_file_tree = "" . htmlspecialchars($this_file) . ""; + $php_file_tree .= php_file_tree_dir("$directory/$this_file", false); + $php_file_tree .= ""; + } else { + // File + $ext = fm_get_file_icon_class($this_file); + $path = str_replace($_SERVER['DOCUMENT_ROOT'],"",$directory); + $link = "?p="."$path" ."&view=".urlencode($this_file); + $php_file_tree .= "
  • " . htmlspecialchars($this_file) . "
  • "; + } + } + } + $php_file_tree .= ""; + } + return $php_file_tree; +} + +/** + * Scan directory and render tree view + * @param string $directory + */ +function php_file_tree($directory) { + // Remove trailing slash + $code = ""; + if( substr($directory, -1) == "/" ) $directory = substr($directory, 0, strlen($directory) - 1); + if(function_exists('php_file_tree_dir')) { + $code .= php_file_tree_dir($directory); + return $code; + } +} + +/** + * Save message in session + * @param string $msg + * @param string $status + */ +function fm_set_msg($msg, $status = 'ok') +{ + $_SESSION['message'] = $msg; + $_SESSION['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; +} + +/** + * 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': + $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': + $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'); +} + +/** + * Get video files extensions + * @return array + */ +function fm_get_video_exts() +{ + return array('webm', 'mp4', 'm4v', 'ogm', 'ogv', 'mov'); +} + +/** + * 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', + ); +} + +/** + * 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', + ); +} + +/** + * 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; + } +} + +//--- templates functions + +/** + * Show nav block + * @param string $path + */ +function fm_show_nav_path($path) +{ + global $lang; + ?> + +' . $_SESSION['message'] . '

    '; + unset($_SESSION['message']); + unset($_SESSION['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; + ?> + + + + +H3K | File Manager + + + + + + + +
    + + +
    + + + + + + + +H3K | File Manager + + + + + + + + + + +
    +
    X

    Create New Item

    + File Folder

    +

    +
    X + +

    Search Results

    +
    +
    + +
    + + + + + + + + + + + + 'iVBORw0KGgoAAAANSUhEUgAAABAAAAAQCAYAAAAf8/9hAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJ +bWFnZVJlYWR5ccllPAAAAZVJREFUeNqkk79Lw0AUx1+uidTQim4Waxfpnl1BcHMR6uLkIF0cpYOI +f4KbOFcRwbGTc0HQSVQQXCqlFIXgFkhIyvWS870LaaPYH9CDy8vdfb+fey930aSUMEvT6VHVzw8x +rKUX3N3Hj/8M+cZ6GcOtBPl6KY5iAA7KJzfVWrfbhUKhALZtQ6myDf1+X5nsuzjLUmUOnpa+v5r1 +Z4ZDDfsLiwER45xDEATgOI6KntfDd091GidzC8vZ4vH1QQ09+4MSMAMWRREKPMhmsyr6voYmrnb2 +PKEizdEabUaeFCDKCCHAdV0wTVNFznMgpVqGlZ2cipzHGtKSZwCIZJgJwxB38KHT6Sjx21V75Jcn +LXmGAKTRpGVZUx2dAqQzSEqw9kqwuGqONTufPrw37D8lQFxCvjgPXIixANLEGfwuQacMOC4kZz+q +GdhJS550BjpRCdCbAJCMJRkMASEIg+4Bxz4JwAwDSEueAYDLIM+QrOk6GHiRxjXSkJY8KUCvdXZ6 +kbuvNx+mOcbN9taGBlpLAWf9nX8EGADoCfqkKWV/cgAAAABJRU5ErkJggg==', + 'sprites' => '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 +RK5CYII=', + ); +} +?> From 8e035d245e8826504df59d7e8ccd63b2e69b3561 Mon Sep 17 00:00:00 2001 From: eddydu44 Date: Tue, 26 Dec 2017 16:34:24 +0100 Subject: [PATCH 04/12] add file manager Add the button to access to it and the file written in php --- index.html | 4 ++-- tinyfilemanager.php | 4 ++-- 2 files changed, 4 insertions(+), 4 deletions(-) diff --git a/index.html b/index.html index 53a0c0b4..29df46d4 100644 --- a/index.html +++ b/index.html @@ -302,8 +302,8 @@ diff --git a/tinyfilemanager.php b/tinyfilemanager.php index 6c9451e6..f363b88a 100644 --- a/tinyfilemanager.php +++ b/tinyfilemanager.php @@ -7,10 +7,10 @@ */ // Default language -$lang = 'en'; +$lang = 'fr'; // Auth with login/password (set true/false to enable/disable it) -$use_auth = true; +$use_auth = false; // Users: array('Username' => 'Password', 'Username2' => 'Password2', ...), Password has to encripted into MD5 $auth_users = array( From 5e6da3a64da31240e88aaf6acc62044321cb8f9c Mon Sep 17 00:00:00 2001 From: eddydu44 Date: Tue, 26 Dec 2017 16:39:06 +0100 Subject: [PATCH 05/12] change the FM FM by John Campbell is best --- file-manager.php => file-manager/index.php | 0 1 file changed, 0 insertions(+), 0 deletions(-) rename file-manager.php => file-manager/index.php (100%) diff --git a/file-manager.php b/file-manager/index.php similarity index 100% rename from file-manager.php rename to file-manager/index.php From 3ad56c3d64d60cbf3f5480b0ba371627cb99bd10 Mon Sep 17 00:00:00 2001 From: eddydu44 Date: Tue, 26 Dec 2017 16:40:46 +0100 Subject: [PATCH 06/12] upload --- index.html | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/index.html b/index.html index 29df46d4..b1036721 100644 --- a/index.html +++ b/index.html @@ -302,7 +302,7 @@ From b0adcdec9dd43292f26d9e010802904e2cebc844 Mon Sep 17 00:00:00 2001 From: eddydu44 Date: Tue, 26 Dec 2017 16:43:57 +0100 Subject: [PATCH 07/12] new readme --- README.md | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/README.md b/README.md index e3e1cb0b..9af5d3f4 100644 --- a/README.md +++ b/README.md @@ -22,6 +22,10 @@ Tips ==== 1. You can always select which files to download in case of torrents or metalinks. Just pause a download and a list icon should appear next to the settings button. To select which files to download before starting the download, give the flag --pause-metadata to aria2. See [link](https://aria2.github.io/manual/en/html/aria2c.html#cmdoption--pause-metadata) +File Manager +============= +To use this option, you need to create symbolinc links into the file-manager folder in order to acces them. + Configuration ============= Read and edit [configuration.js](configuration.js). From b0c68d633d73ff9a3bf0897849bda99d5b01807c Mon Sep 17 00:00:00 2001 From: eddydu44 Date: Tue, 26 Dec 2017 17:03:34 +0100 Subject: [PATCH 08/12] try to make FM in iframe --- index.html | 17 +++++++++++++++-- js/ctrls/modal.js | 4 ++-- js/ctrls/nav.js | 12 ++++++++++++ 3 files changed, 29 insertions(+), 4 deletions(-) diff --git a/index.html b/index.html index b1036721..0f3ed204 100644 --- a/index.html +++ b/index.html @@ -302,8 +302,7 @@ @@ -1302,6 +1301,20 @@

    {{ 'About and contribute' | translate }}

    + + + diff --git a/js/ctrls/modal.js b/js/ctrls/modal.js index 55d9c6d5..900a867b 100644 --- a/js/ctrls/modal.js +++ b/js/ctrls/modal.js @@ -246,7 +246,7 @@ angular }; }); - _.each(["about", "server_info"], function(name) { + _.each(["about", "server_info", "fm"], function(name) { scope[name] = { open: function() { var self = this; @@ -270,7 +270,7 @@ angular _.each([ 'getUris', 'getTorrents', 'getMetalinks', 'selectFiles', - 'settings', 'connection', 'server_info', 'about' + 'settings', 'connection', 'server_info', 'about', 'fm' ], function(name) { modals.register(name, function() { if (scope[name].inst) { diff --git a/js/ctrls/nav.js b/js/ctrls/nav.js index affe3f61..aec44f3b 100644 --- a/js/ctrls/nav.js +++ b/js/ctrls/nav.js @@ -45,6 +45,12 @@ angular 'getUris', _.bind(rhelpers.addUris, rhelpers) ); }; + + scope.fileManager = function() { + modals.invoke( + 'getUris', _.bind(rhelpers.addUris, rhelpers) + ); + }; scope.addMetalinks = function() { modals.invoke( @@ -128,6 +134,12 @@ angular 'server_info' ); }; + + scope.showFileManager = function() { + modals.invoke( + 'fm' + ); + }; scope.showAbout = function() { modals.invoke( From f76c76a2559c238c9bb352b35863b5646250cf9e Mon Sep 17 00:00:00 2001 From: eddydu44 Date: Tue, 26 Dec 2017 17:05:12 +0100 Subject: [PATCH 09/12] upload --- index.html | 8 +++++++- 1 file changed, 7 insertions(+), 1 deletion(-) diff --git a/index.html b/index.html index 0f3ed204..baff39ce 100644 --- a/index.html +++ b/index.html @@ -302,7 +302,13 @@ + From 003ef3c2192c2506636faf1712cd7168b32d3564 Mon Sep 17 00:00:00 2001 From: eddydu44 Date: Tue, 26 Dec 2017 17:10:38 +0100 Subject: [PATCH 10/12] upload --- index.html | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/index.html b/index.html index baff39ce..034e28d6 100644 --- a/index.html +++ b/index.html @@ -1314,7 +1314,7 @@

    {{ 'About and contribute' | translate }}

    {{ 'File Manager' | translate }}