diff options
author | Joas Schilling <coding@schilljs.com> | 2017-04-11 14:16:17 +0200 |
---|---|---|
committer | Roeland Jago Douma <roeland@famdouma.nl> | 2017-04-13 12:58:53 +0200 |
commit | 29f2088a7b83a2346ec440d7ffd4e577558fdd23 (patch) | |
tree | afcc4c1315c8dc9c6757f4398e672f987b8058f1 | |
parent | 7d416ac1ddb158a18ac1473677773417d59e509c (diff) | |
download | nextcloud-server-29f2088a7b83a2346ec440d7ffd4e577558fdd23.tar.gz nextcloud-server-29f2088a7b83a2346ec440d7ffd4e577558fdd23.zip |
Catch exceptions and use as many results as possible
Signed-off-by: Joas Schilling <coding@schilljs.com>
-rw-r--r-- | lib/private/Share20/ShareHelper.php | 83 |
1 files changed, 59 insertions, 24 deletions
diff --git a/lib/private/Share20/ShareHelper.php b/lib/private/Share20/ShareHelper.php index 90992005017..65186634463 100644 --- a/lib/private/Share20/ShareHelper.php +++ b/lib/private/Share20/ShareHelper.php @@ -22,7 +22,10 @@ */ namespace OC\Share20; +use OCP\Files\InvalidPathException; use OCP\Files\Node; +use OCP\Files\NotFoundException; +use OCP\Files\NotPermittedException; use OCP\Share\IManager; use OCP\Share\IShareHelper; @@ -62,7 +65,11 @@ class ShareHelper implements IShareHelper { * @return array */ protected function getPathsForUsers(Node $node, array $users) { - $byId = $results = []; + /** @var array[] $byId */ + $byId = []; + /** @var array[] $results */ + $results = []; + foreach ($users as $uid => $info) { if (!isset($byId[$info['node_id']])) { $byId[$info['node_id']] = []; @@ -70,11 +77,17 @@ class ShareHelper implements IShareHelper { $byId[$info['node_id']][$uid] = $info['node_path']; } - if (isset($byId[$node->getId()])) { - foreach ($byId[$node->getId()] as $uid => $path) { - $results[$uid] = $path; + try { + if (isset($byId[$node->getId()])) { + foreach ($byId[$node->getId()] as $uid => $path) { + $results[$uid] = $path; + } + unset($byId[$node->getId()]); } - unset($byId[$node->getId()]); + } catch (NotFoundException $e) { + return $results; + } catch (InvalidPathException $e) { + return $results; } if (empty($byId)) { @@ -84,17 +97,25 @@ class ShareHelper implements IShareHelper { $item = $node; $appendix = '/' . $node->getName(); while (!empty($byId)) { - /** @var Node $item */ - $item = $item->getParent(); - - if (!empty($byId[$item->getId()])) { - foreach ($byId[$item->getId()] as $uid => $path) { - $results[$uid] = $path . $appendix; + try { + /** @var Node $item */ + $item = $item->getParent(); + + if (!empty($byId[$item->getId()])) { + foreach ($byId[$item->getId()] as $uid => $path) { + $results[$uid] = $path . $appendix; + } + unset($byId[$item->getId()]); } - unset($byId[$item->getId()]); - } - $appendix = '/' . $item->getName() . $appendix; + $appendix = '/' . $item->getName() . $appendix; + } catch (NotFoundException $e) { + return $results; + } catch (InvalidPathException $e) { + return $results; + } catch (NotPermittedException $e) { + return $results; + } } return $results; @@ -106,7 +127,11 @@ class ShareHelper implements IShareHelper { * @return array */ protected function getPathsForRemotes(Node $node, array $remotes) { - $byId = $results = []; + /** @var array[] $byId */ + $byId = []; + /** @var array[] $results */ + $results = []; + foreach ($remotes as $cloudId => $info) { if (!isset($byId[$info['node_id']])) { $byId[$info['node_id']] = []; @@ -116,17 +141,27 @@ class ShareHelper implements IShareHelper { $item = $node; while (!empty($byId)) { - if (!empty($byId[$item->getId()])) { - $path = $this->getMountedPath($item); - foreach ($byId[$item->getId()] as $uid => $token) { - $results[$uid] = [ - 'node_path' => $path, - 'token' => $token, - ]; + try { + if (!empty($byId[$item->getId()])) { + $path = $this->getMountedPath($item); + foreach ($byId[$item->getId()] as $uid => $token) { + $results[$uid] = [ + 'node_path' => $path, + 'token' => $token, + ]; + } + unset($byId[$item->getId()]); } - unset($byId[$item->getId()]); + + /** @var Node $item */ + $item = $item->getParent(); + } catch (NotFoundException $e) { + return $results; + } catch (InvalidPathException $e) { + return $results; + } catch (NotPermittedException $e) { + return $results; } - $item = $item->getParent(); } return $results; |