diff options
author | Morris Jobke <hey@morrisjobke.de> | 2016-04-14 11:49:11 +0200 |
---|---|---|
committer | Morris Jobke <hey@morrisjobke.de> | 2016-04-14 11:49:11 +0200 |
commit | dfb98c31a35f985a36faee54a801d34c3e433faa (patch) | |
tree | 0d438f6752380ad251c852140ade4a16142750a1 /lib | |
parent | e39669171283ed191daeca50ea644de6b90e89e4 (diff) | |
parent | 79c17cdfa604d73f7f24ec25bdaf60eaf65fedc6 (diff) | |
download | nextcloud-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
Diffstat (limited to 'lib')
-rw-r--r-- | lib/private/share/share.php | 21 |
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; + } } } } |