mirror of
				https://github.com/prasathmani/tinyfilemanager.git
				synced 2025-10-26 07:46:22 +01:00 
			
		
		
		
	Allow hiding files/folders by full path (#1092)
This commit is contained in:
		| @@ -97,7 +97,7 @@ $allowed_upload_extensions = ''; | |||||||
| $favicon_path = ''; | $favicon_path = ''; | ||||||
|  |  | ||||||
| // Files and folders to excluded from listing | // Files and folders to excluded from listing | ||||||
| // e.g. array('myfile.html', 'personal-folder', '*.php', ...) | // e.g. array('myfile.html', 'personal-folder', '*.php', '/path/to/folder', ...) | ||||||
| $exclude_items = array(); | $exclude_items = array(); | ||||||
|  |  | ||||||
| // Online office Docs Viewer | // Online office Docs Viewer | ||||||
| @@ -1334,7 +1334,7 @@ $objects = is_readable($path) ? scandir($path) : array(); | |||||||
| $folders = array(); | $folders = array(); | ||||||
| $files = array(); | $files = array(); | ||||||
| $current_path = array_slice(explode("/", $path), -1)[0]; | $current_path = array_slice(explode("/", $path), -1)[0]; | ||||||
| if (is_array($objects) && fm_is_exclude_items($current_path)) { | if (is_array($objects) && fm_is_exclude_items($current_path, $path)) { | ||||||
|     foreach ($objects as $file) { |     foreach ($objects as $file) { | ||||||
|         if ($file == '.' || $file == '..') { |         if ($file == '.' || $file == '..') { | ||||||
|             continue; |             continue; | ||||||
| @@ -1343,9 +1343,9 @@ if (is_array($objects) && fm_is_exclude_items($current_path)) { | |||||||
|             continue; |             continue; | ||||||
|         } |         } | ||||||
|         $new_path = $path . '/' . $file; |         $new_path = $path . '/' . $file; | ||||||
|         if (@is_file($new_path) && fm_is_exclude_items($file)) { |         if (@is_file($new_path) && fm_is_exclude_items($file, $new_path)) { | ||||||
|             $files[] = $file; |             $files[] = $file; | ||||||
|         } elseif (@is_dir($new_path) && $file != '.' && $file != '..' && fm_is_exclude_items($file)) { |         } elseif (@is_dir($new_path) && $file != '.' && $file != '..' && fm_is_exclude_items($file, $new_path)) { | ||||||
|             $folders[] = $file; |             $folders[] = $file; | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| @@ -1712,7 +1712,7 @@ if (isset($_GET['view'])) { | |||||||
|     $file = $_GET['view']; |     $file = $_GET['view']; | ||||||
|     $file = fm_clean_path($file, false); |     $file = fm_clean_path($file, false); | ||||||
|     $file = str_replace('/', '', $file); |     $file = str_replace('/', '', $file); | ||||||
|     if ($file == '' || !is_file($path . '/' . $file) || !fm_is_exclude_items($file)) { |     if ($file == '' || !is_file($path . '/' . $file) || !fm_is_exclude_items($file, $path . '/' . $file)) { | ||||||
|         fm_set_msg(lng('File not found'), 'error'); |         fm_set_msg(lng('File not found'), 'error'); | ||||||
|         $FM_PATH = FM_PATH; |         $FM_PATH = FM_PATH; | ||||||
|         fm_redirect(FM_SELF_URL . '?p=' . urlencode($FM_PATH)); |         fm_redirect(FM_SELF_URL . '?p=' . urlencode($FM_PATH)); | ||||||
| @@ -1917,7 +1917,7 @@ if (isset($_GET['edit']) && !FM_READONLY) { | |||||||
|     $file = $_GET['edit']; |     $file = $_GET['edit']; | ||||||
|     $file = fm_clean_path($file, false); |     $file = fm_clean_path($file, false); | ||||||
|     $file = str_replace('/', '', $file); |     $file = str_replace('/', '', $file); | ||||||
|     if ($file == '' || !is_file($path . '/' . $file) || !fm_is_exclude_items($file)) { |     if ($file == '' || !is_file($path . '/' . $file) || !fm_is_exclude_items($file, $path . '/' . $file)) { | ||||||
|         fm_set_msg(lng('File not found'), 'error'); |         fm_set_msg(lng('File not found'), 'error'); | ||||||
|         $FM_PATH = FM_PATH; |         $FM_PATH = FM_PATH; | ||||||
|         fm_redirect(FM_SELF_URL . '?p=' . urlencode($FM_PATH)); |         fm_redirect(FM_SELF_URL . '?p=' . urlencode($FM_PATH)); | ||||||
| @@ -2664,12 +2664,13 @@ function fm_get_display_path($file_path) | |||||||
|  |  | ||||||
| /** | /** | ||||||
|  * Check file is in exclude list |  * Check file is in exclude list | ||||||
|  * @param string $file |  * @param string $name The name of the file/folder | ||||||
|  |  * @param string $path The full path of the file/folder | ||||||
|  * @return bool |  * @return bool | ||||||
|  */ |  */ | ||||||
| function fm_is_exclude_items($file) | function fm_is_exclude_items($name, $path) | ||||||
| { | { | ||||||
|     $ext = strtolower(pathinfo($file, PATHINFO_EXTENSION)); |     $ext = strtolower(pathinfo($name, PATHINFO_EXTENSION)); | ||||||
|     if (isset($exclude_items) and sizeof($exclude_items)) { |     if (isset($exclude_items) and sizeof($exclude_items)) { | ||||||
|         unset($exclude_items); |         unset($exclude_items); | ||||||
|     } |     } | ||||||
| @@ -2678,7 +2679,7 @@ function fm_is_exclude_items($file) | |||||||
|     if (version_compare(PHP_VERSION, '7.0.0', '<')) { |     if (version_compare(PHP_VERSION, '7.0.0', '<')) { | ||||||
|         $exclude_items = unserialize($exclude_items); |         $exclude_items = unserialize($exclude_items); | ||||||
|     } |     } | ||||||
|     if (!in_array($file, $exclude_items) && !in_array("*.$ext", $exclude_items)) { |     if (!in_array($name, $exclude_items) && !in_array("*.$ext", $exclude_items) && !in_array($path, $exclude_items)) { | ||||||
|         return true; |         return true; | ||||||
|     } |     } | ||||||
|     return false; |     return false; | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user