summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMorris Jobke <hey@morrisjobke.de>2016-04-14 11:49:11 +0200
committerMorris Jobke <hey@morrisjobke.de>2016-04-14 11:49:11 +0200
commitdfb98c31a35f985a36faee54a801d34c3e433faa (patch)
tree0d438f6752380ad251c852140ade4a16142750a1
parente39669171283ed191daeca50ea644de6b90e89e4 (diff)
parent79c17cdfa604d73f7f24ec25bdaf60eaf65fedc6 (diff)
downloadnextcloud-server-dfb98c31a35f985a36faee54a801d34c3e433faa.tar.gz
nextcloud-server-dfb98c31a35f985a36faee54a801d34c3e433faa.zip
Merge pull request #19615 from owncloud/issue-15858-mount-points-return-wrong-paths-for-getusersharingfiles
Fix Share::getUsersSharingFile() for mount points
-rw-r--r--lib/private/share/share.php21
1 files changed, 17 insertions, 4 deletions
diff --git a/lib/private/share/share.php b/lib/private/share/share.php
index c6f7258c536..2125767cabb 100644
--- a/lib/private/share/share.php
+++ b/lib/private/share/share.php
@@ -137,7 +137,7 @@ class Share extends Constants {
$publicShare = false;
$remoteShare = false;
$source = -1;
- $cache = false;
+ $cache = $mountPath = false;
$view = new \OC\Files\View('/' . $ownerUser . '/files');
$meta = $view->getFileInfo($path);
@@ -151,8 +151,14 @@ class Share extends Constants {
if($meta !== false) {
$source = $meta['fileid'];
$cache = new \OC\Files\Cache\Cache($meta['storage']);
+
+ $mountPath = $meta->getMountPoint()->getMountPoint();
+ if ($mountPath !== false) {
+ $mountPath = substr($mountPath, strlen('/' . $ownerUser . '/files'));
+ }
}
+ $paths = [];
while ($source !== -1) {
// Fetch all shares with another user
if (!$returnUserPaths) {
@@ -257,6 +263,7 @@ class Share extends Constants {
// let's get the parent for the next round
$meta = $cache->get((int)$source);
if ($recursive === true && $meta !== false) {
+ $paths[$source] = $meta['path'];
$source = (int)$meta['parent'];
} else {
$source = -1;
@@ -285,9 +292,15 @@ class Share extends Constants {
} else {
while ($row = $result->fetchRow()) {
foreach ($fileTargets[$row['fileid']] as $uid => $shareData) {
- $sharedPath = $shareData['file_target'];
- $sharedPath .= substr($path, strlen($row['path']) -5);
- $sharePaths[$uid] = $sharedPath;
+ if ($mountPath !== false) {
+ $sharedPath = $shareData['file_target'];
+ $sharedPath .= substr($path, strlen($mountPath) + strlen($paths[$row['fileid']]));
+ $sharePaths[$uid] = $sharedPath;
+ } else {
+ $sharedPath = $shareData['file_target'];
+ $sharedPath .= substr($path, strlen($row['path']) -5);
+ $sharePaths[$uid] = $sharedPath;
+ }
}
}
}