summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMichael Gapczynski <GapczynskiM@gmail.com>2011-07-23 14:41:01 -0400
committerMichael Gapczynski <GapczynskiM@gmail.com>2011-07-23 14:41:01 -0400
commit4993fb46654749646bc156bde350e3af4bf6879d (patch)
treed77310c446037e13f2f77642d8e93b35df9cd4d6
parente6e673d7c0b5cf9476aa394d35e24ca65d07d24a (diff)
downloadnextcloud-server-4993fb46654749646bc156bde350e3af4bf6879d.tar.gz
nextcloud-server-4993fb46654749646bc156bde350e3af4bf6879d.zip
Filter out files you unshare from yourself in opendir()
-rw-r--r--apps/files_sharing/lib_share.php23
-rw-r--r--apps/files_sharing/sharedstorage.php12
2 files changed, 22 insertions, 13 deletions
diff --git a/apps/files_sharing/lib_share.php b/apps/files_sharing/lib_share.php
index 43821fc7199..6e43e203b2f 100644
--- a/apps/files_sharing/lib_share.php
+++ b/apps/files_sharing/lib_share.php
@@ -108,20 +108,21 @@ class OC_SHARE {
/**
* Get the items within a shared folder that have their own entry for the purpose of name, location, or permissions that differ from the folder itself
*
- * Also can be used for getting all items shared with you e.g. pass '/MTGap/files'
+ * Works for both target and source folders. Can be used for getting all items shared with you e.g. pass '/MTGap/files'
*
- * @param $targetFolder The target folder of the items to look for
- * @return An array with all items in the database that are in the target folder
+ * @param $folder The folder of the items to look for
+ * @return An array with all items in the database that are in the folder
*/
- public static function getItemsInFolder($targetFolder) {
+ public static function getItemsInFolder($folder) {
// Append '/' in order to filter out the folder itself if not already there
- if (substr($targetFolder, -1) !== "/") {
- $targetFolder .= "/";
+ if (substr($folder, -1) !== "/") {
+ $folder .= "/";
}
// Remove any duplicate '/'
- $targetFolder = preg_replace('{(/)\1+}', "/", $targetFolder);
- $query = OC_DB::prepare("SELECT uid_owner, source, target FROM *PREFIX*sharing WHERE SUBSTR(target, 1, ?) = ? AND uid_shared_with = ?");
- return $query->execute(array(strlen($targetFolder), $targetFolder, OC_USER::getUser()))->fetchAll();
+ $folder = preg_replace('{(/)\1+}', "/", $folder);
+ $length = strlen($folder);
+ $query = OC_DB::prepare("SELECT uid_owner, source, target FROM *PREFIX*sharing WHERE SUBSTR(source, 1, ?) = ? OR SUBSTR(target, 1, ?) = ? AND uid_shared_with = ?");
+ return $query->execute(array($length, $folder, $length, $folder, OC_USER::getUser()))->fetchAll();
}
/**
@@ -133,13 +134,13 @@ class OC_SHARE {
// Remove any duplicate or trailing '/'
$target = rtrim($target, "/");
$target = preg_replace('{(/)\1+}', "/", $target);
- $query = OC_DB::prepare("SELECT source FROM *PREFIX*sharing WHERE SUBSTR(target, 1, ?) = ? AND uid_shared_with = ? LIMIT 1");
+ $query = OC_DB::prepare("SELECT source FROM *PREFIX*sharing WHERE target = ? AND uid_shared_with = ? LIMIT 1");
// Prevent searching for user directory e.g. '/MTGap/files'
$userDirectory = substr($target, 0, strpos($target, "files") + 5);
while ($target != "" && $target != "/" && $target != "." && $target != $userDirectory) {
// Check if the parent directory of this target location is shared
$target = dirname($target);
- $result = $query->execute(array(strlen($target), $target, OC_USER::getUser()))->fetchAll();
+ $result = $query->execute(array($target, OC_USER::getUser()))->fetchAll();
if (count($result) > 0) {
break;
}
diff --git a/apps/files_sharing/sharedstorage.php b/apps/files_sharing/sharedstorage.php
index 5fc2cc67b74..c26423594fc 100644
--- a/apps/files_sharing/sharedstorage.php
+++ b/apps/files_sharing/sharedstorage.php
@@ -93,7 +93,7 @@ class OC_FILESTORAGE_SHARED extends OC_FILESTORAGE {
// Remove any duplicate or trailing '/'
$path = rtrim($this->datadir.$path, "/");
$path = preg_replace('{(/)\1+}', "/", $path);
- $modifiedItems = OC_SHARE::getItemsInFolder($path);
+ $modifiedItems = OC_SHARE::getItemsInFolder($source);
if ($modifiedItems && $dh) {
global $FAKEDIRS;
$sources = array();
@@ -103,6 +103,10 @@ class OC_FILESTORAGE_SHARED extends OC_FILESTORAGE {
if (dirname($item['target']) == $path && basename($item['source']) != basename($item['target'])) {
$sources[] = basename($item['source']);
$targets[] = basename($item['target']);
+ // If the item was unshared from self, add it it to the arrays
+ } elseif ($item['target'] == "/") {
+ $sources[] = basename($item['source']);
+ $targets[] = "";
}
}
// Don't waste time if there aren't any modified items in the current directory
@@ -116,7 +120,11 @@ class OC_FILESTORAGE_SHARED extends OC_FILESTORAGE {
$files[] = $filename;
// The file has a different name than the source and is added to the fakedirs
} else {
- $files[] = $targets[array_search($filename, $sources)];
+ $target = $targets[array_search($filename, $sources)];
+ // Don't add the file if it was unshared from self by the user
+ if ($target != "") {
+ $files[] = $target;
+ }
}
}
}