From 3c1365c0d12a626e8c2b8e1ab35b105f4b88ad2e Mon Sep 17 00:00:00 2001 From: Joas Schilling Date: Tue, 28 Mar 2017 17:06:26 +0200 Subject: Fix returned paths for remote shares Signed-off-by: Joas Schilling --- lib/private/Share20/ShareHelper.php | 29 +++++++++-------------------- lib/public/Share/IManager.php | 2 +- lib/public/Share/IShareHelper.php | 2 +- lib/public/Share/IShareProvider.php | 2 +- 4 files changed, 12 insertions(+), 23 deletions(-) (limited to 'lib') diff --git a/lib/private/Share20/ShareHelper.php b/lib/private/Share20/ShareHelper.php index b5640d04552..ba3f64dbc1a 100644 --- a/lib/private/Share20/ShareHelper.php +++ b/lib/private/Share20/ShareHelper.php @@ -37,7 +37,7 @@ class ShareHelper implements IShareHelper { /** * @param Node $node - * @return array [ users => [Mapping $uid => $path], remotes => [Mapping $cloudId => $path]] + * @return array [ users => [Mapping $uid => $pathForUser], remotes => [Mapping $cloudId => $pathToMountRoot]] */ public function getPathsForAccessList(Node $node) { $result = [ @@ -103,26 +103,10 @@ class ShareHelper implements IShareHelper { $byId[$info['node_id']][$cloudId] = $info['token']; } - if (isset($byId[$node->getId()])) { - foreach ($byId[$node->getId()] as $cloudId => $token) { - $results[$cloudId] = [ - 'node_path' => '/' . $node->getName(), - 'token' => $token, - ]; - } - unset($byId[$node->getId()]); - } - - if (empty($byId)) { - return $results; - } - $item = $node; - $path = '/' . $node->getName(); while (!empty($byId)) { - $item = $item->getParent(); - if (!empty($byId[$item->getId()])) { + $path = $this->getMountedPath($item); foreach ($byId[$item->getId()] as $uid => $token) { $results[$uid] = [ 'node_path' => $path, @@ -131,10 +115,15 @@ class ShareHelper implements IShareHelper { } unset($byId[$item->getId()]); } - - $path = '/' . $item->getName() . $path; + $item = $item->getParent(); } return $results; } + + protected function getMountedPath(Node $node) { + $path = $node->getPath(); + $sections = explode('/', $path, 4); + return '/' . $sections[3]; + } } diff --git a/lib/public/Share/IManager.php b/lib/public/Share/IManager.php index 1cbb27cb618..5f02e1d9804 100644 --- a/lib/public/Share/IManager.php +++ b/lib/public/Share/IManager.php @@ -208,7 +208,7 @@ interface IManager { * Then the access list will to '/folder1/folder2/fileA' is: * [ * users => ['user1' => ['node_id' => 42, 'node_path' => '/path'], 'user2' => [...]], - * remote => ['user1' => ['node_id' => 42, 'node_path' => '/path'], 'user2' => [...]], + * remote => ['user1' => ['node_id' => 42, 'token' => 'ShareToken'], 'user2' => [...]], * public => bool * mail => bool * ] diff --git a/lib/public/Share/IShareHelper.php b/lib/public/Share/IShareHelper.php index 01202cf477b..4ec62830c52 100644 --- a/lib/public/Share/IShareHelper.php +++ b/lib/public/Share/IShareHelper.php @@ -34,7 +34,7 @@ interface IShareHelper { /** * @param Node $node - * @return array [ users => [Mapping $uid => $path], remotes => [Mapping $cloudId => $path]] + * @return array [ users => [Mapping $uid => $pathForUser], remotes => [Mapping $cloudId => $pathToMountRoot]] * @since 12 */ public function getPathsForAccessList(Node $node); diff --git a/lib/public/Share/IShareProvider.php b/lib/public/Share/IShareProvider.php index fba432f31e7..bac1a5d87f0 100644 --- a/lib/public/Share/IShareProvider.php +++ b/lib/public/Share/IShareProvider.php @@ -197,7 +197,7 @@ interface IShareProvider { * * [ * users => ['user1' => ['node_id' => 42, 'node_path' => '/path'], 'user2' => [...]], - * remote => ['user1' => ['node_id' => 42, 'node_path' => '/path'], 'user2' => [...]], + * remote => ['user1' => ['node_id' => 42, 'token' => 'ShareToken'], 'user2' => [...]], * mail => bool * public => bool * ] -- cgit v1.2.3