summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJoas Schilling <coding@schilljs.com>2017-04-11 14:16:17 +0200
committerRoeland Jago Douma <roeland@famdouma.nl>2017-04-13 12:58:53 +0200
commit29f2088a7b83a2346ec440d7ffd4e577558fdd23 (patch)
treeafcc4c1315c8dc9c6757f4398e672f987b8058f1
parent7d416ac1ddb158a18ac1473677773417d59e509c (diff)
downloadnextcloud-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.php83
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;