diff options
author | Vincent Petry <pvince81@owncloud.com> | 2016-06-21 16:07:44 +0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2016-06-21 16:07:44 +0200 |
commit | ddd4f367c30114a22bab875408dbbc54388a6767 (patch) | |
tree | 4626446d08a540ba2d2dfb464130cc367e53f1f4 /apps | |
parent | bf7a08f62dafd24932b93ffd213f4e40f151ced0 (diff) | |
parent | fa9ba64552a43448d7394d3e11a60997b00eca48 (diff) | |
download | nextcloud-server-ddd4f367c30114a22bab875408dbbc54388a6767.tar.gz nextcloud-server-ddd4f367c30114a22bab875408dbbc54388a6767.zip |
Merge pull request #25199 from owncloud/shared-mount-catch-9
[9.0] Catch exceptions while creating shared mounts
Diffstat (limited to 'apps')
-rw-r--r-- | apps/files_sharing/appinfo/application.php | 3 | ||||
-rw-r--r-- | apps/files_sharing/lib/mountprovider.php | 33 |
2 files changed, 25 insertions, 11 deletions
diff --git a/apps/files_sharing/appinfo/application.php b/apps/files_sharing/appinfo/application.php index 64c7517456d..311250ce195 100644 --- a/apps/files_sharing/appinfo/application.php +++ b/apps/files_sharing/appinfo/application.php @@ -111,7 +111,8 @@ class Application extends App { /** @var \OCP\IServerContainer $server */ $server = $c->query('ServerContainer'); return new MountProvider( - $server->getConfig() + $server->getConfig(), + $server->getLogger() ); }); diff --git a/apps/files_sharing/lib/mountprovider.php b/apps/files_sharing/lib/mountprovider.php index 4a60e44bb26..d1d54a21ab3 100644 --- a/apps/files_sharing/lib/mountprovider.php +++ b/apps/files_sharing/lib/mountprovider.php @@ -27,6 +27,7 @@ use OC\User\NoUserException; use OCP\Files\Config\IMountProvider; use OCP\Files\Storage\IStorageFactory; use OCP\IConfig; +use OCP\ILogger; use OCP\IUser; class MountProvider implements IMountProvider { @@ -36,10 +37,17 @@ class MountProvider implements IMountProvider { protected $config; /** + * @var ILogger + */ + protected $logger; + + /** * @param \OCP\IConfig $config + * @param ILogger $logger */ - public function __construct(IConfig $config) { + public function __construct(IConfig $config, ILogger $logger) { $this->config = $config; + $this->logger = $logger; } @@ -57,15 +65,20 @@ class MountProvider implements IMountProvider { }); $shares = array_map(function ($share) use ($user, $storageFactory) { - return new SharedMount( - '\OC\Files\Storage\Shared', - '/' . $user->getUID() . '/' . $share['file_target'], - array( - 'share' => $share, - 'user' => $user->getUID() - ), - $storageFactory - ); + try { + return new SharedMount( + '\OC\Files\Storage\Shared', + '/' . $user->getUID() . '/' . $share['file_target'], + array( + 'share' => $share, + 'user' => $user->getUID() + ), + $storageFactory + ); + } catch (\Exception $e) { + $this->logger->logException($e); + $this->logger->error('Error while trying to create shared mount'); + } }, $shares); // array_filter removes the null values from the array return array_filter($shares); |