summaryrefslogtreecommitdiffstats
path: root/lib
diff options
context:
space:
mode:
authorRobin Appelman <robin@icewind.nl>2017-12-11 16:39:44 +0100
committerRobin Appelman <robin@icewind.nl>2017-12-11 16:56:10 +0100
commit05d2f61a592861ecbd517307de2b868d35566300 (patch)
tree5cb7aedc61891ece0261939017f81e669b3963b3 /lib
parent10aa287463b6888d2e418ad31fa3a390fbea359e (diff)
downloadnextcloud-server-05d2f61a592861ecbd517307de2b868d35566300.tar.gz
nextcloud-server-05d2f61a592861ecbd517307de2b868d35566300.zip
handle not found mounts when cleaning avatars
Signed-off-by: Robin Appelman <robin@icewind.nl>
Diffstat (limited to 'lib')
-rw-r--r--lib/private/Files/View.php6
-rw-r--r--lib/private/Server.php3
2 files changed, 9 insertions, 0 deletions
diff --git a/lib/private/Files/View.php b/lib/private/Files/View.php
index 58552be2609..592d4b717ce 100644
--- a/lib/private/Files/View.php
+++ b/lib/private/Files/View.php
@@ -1362,6 +1362,9 @@ class View {
$path = Filesystem::normalizePath($this->fakeRoot . '/' . $path);
$mount = Filesystem::getMountManager()->find($path);
+ if (!$mount) {
+ return false;
+ }
$storage = $mount->getStorage();
$internalPath = $mount->getInternalPath($path);
if ($storage) {
@@ -1411,6 +1414,9 @@ class View {
$path = $this->getAbsolutePath($directory);
$path = Filesystem::normalizePath($path);
$mount = $this->getMount($directory);
+ if (!$mount) {
+ return [];
+ }
$storage = $mount->getStorage();
$internalPath = $mount->getInternalPath($path);
if ($storage) {
diff --git a/lib/private/Server.php b/lib/private/Server.php
index 3f26f975f0f..0dfbcbb75ec 100644
--- a/lib/private/Server.php
+++ b/lib/private/Server.php
@@ -118,6 +118,7 @@ use OCP\Defaults;
use OCA\Theming\Util;
use OCP\Federation\ICloudIdManager;
use OCP\Authentication\LoginCredentials\IStore;
+use OCP\Files\NotFoundException;
use OCP\ICacheFactory;
use OCP\IDBConnection;
use OCP\IL10N;
@@ -1151,6 +1152,8 @@ class Server extends ServerContainer implements IServerContainer {
try {
$avatar = $manager->getAvatar($user->getUID());
$avatar->remove();
+ } catch (NotFoundException $e) {
+ // no avatar to remove
} catch (\Exception $e) {
// Ignore exceptions
$logger->info('Could not cleanup avatar of ' . $user->getUID());