From 287131565f0c9acb134117ae5e883094a0425825 Mon Sep 17 00:00:00 2001 From: Ralf Becker Date: Sat, 2 May 2009 14:00:31 +0000 Subject: [PATCH] Fixed follow option in find(): - if base is a symlink to a dir, this one is listed anyway - symlinks to dirs (beside the base) are only descended, if $options['follow'] is specified - links are returned for type 'f' --> removed follow option from find() in filemanager_ui::get_rows() --> no more infinit symlink loops in filemanager GUI --- filemanager/inc/class.filemanager_ui.inc.php | 1 - phpgwapi/inc/class.egw_vfs.inc.php | 8 ++++---- 2 files changed, 4 insertions(+), 5 deletions(-) diff --git a/filemanager/inc/class.filemanager_ui.inc.php b/filemanager/inc/class.filemanager_ui.inc.php index e697da8306..ffafce2427 100644 --- a/filemanager/inc/class.filemanager_ui.inc.php +++ b/filemanager/inc/class.filemanager_ui.inc.php @@ -570,7 +570,6 @@ class filemanager_ui 'limit' => (int)$query['num_rows'].','.(int)$query['start'], 'need_mime' => true, 'name_preg' => $namefilter, - 'follow' => true, // follow symlinks ),true) as $path => $row) { //echo $path; _debug_array($row); diff --git a/phpgwapi/inc/class.egw_vfs.inc.php b/phpgwapi/inc/class.egw_vfs.inc.php index dbe11c0479..7bece1291f 100644 --- a/phpgwapi/inc/class.egw_vfs.inc.php +++ b/phpgwapi/inc/class.egw_vfs.inc.php @@ -388,11 +388,11 @@ class egw_vfs extends vfs_stream_wrapper { if (!$url) $path = egw_vfs::PREFIX . $path; - $is_dir = is_dir($path) && ($options['follow'] || !is_link($path)); if (!isset($options['remove'])) { $options['remove'] = count($base) == 1 ? count(explode('/',$path))-3+(int)(substr($path,-1)!='/') : 0; } + $is_dir = is_dir($path); if ((int)$options['mindepth'] == 0 && (!$dirs_last || !$is_dir)) { self::_check_add($options,$path,$result); @@ -409,7 +409,8 @@ class egw_vfs extends vfs_stream_wrapper { self::_check_add($options,$file,$result); } - if (is_dir($file) && (!isset($options['maxdepth']) || $options['maxdepth'] > 1)) + // only descend into subdirs, if it's a real dir (no link to a dir) or we should follow symlinks + if (is_dir($file) && ($options['follow'] || !is_link($file)) && (!isset($options['maxdepth']) || $options['maxdepth'] > 1)) { $opts = $options; if ($opts['mindepth']) $opts['mindepth']--; @@ -509,7 +510,7 @@ class egw_vfs extends vfs_stream_wrapper { $type = $options['type']; // 'd' or 'f' - if ($type && ($type == 'd') !== is_dir($path)) + if ($type && ($type == 'd') !== (is_dir($path) && !is_link($path))) { return; // wrong type } @@ -525,7 +526,6 @@ class egw_vfs extends vfs_stream_wrapper { $stat['mime'] = self::mime_content_type($path); } - if (isset($options['name_preg']) && !preg_match($options['name_preg'],$stat['name']) || isset($options['path_preg']) && !preg_match($options['path_preg'],$path)) {