do not explode when getting permissions from a FailedStorage
for instance if a user of an external user backend is not available currently, the whole Files UI would be frozen. Signed-off-by: Arthur Schiwon <blizzz@arthur-schiwon.de>
This commit is contained in:
parent
2f45045c96
commit
c526cdf8ab
1 changed files with 9 additions and 1 deletions
|
@ -32,6 +32,7 @@ use OC\Files\Cache\FailedCache;
|
|||
use OC\Files\Cache\Wrapper\CacheJail;
|
||||
use OC\Files\Storage\Wrapper\Jail;
|
||||
use OCP\Files\Cache\ICacheEntry;
|
||||
use OCP\Files\StorageNotAvailableException;
|
||||
|
||||
/**
|
||||
* Metadata cache for shared files
|
||||
|
@ -142,7 +143,14 @@ class Cache extends CacheJail {
|
|||
} else {
|
||||
$entry['path'] = $path;
|
||||
}
|
||||
$sharePermissions = $this->storage->getPermissions($entry['path']);
|
||||
|
||||
try {
|
||||
$sharePermissions = $this->storage->getPermissions($entry['path']);
|
||||
} catch (StorageNotAvailableException $e) {
|
||||
// thrown by FailedStorage e.g. when the sharer does not exist anymore
|
||||
// (IDE may say the exception is never thrown – false negative)
|
||||
$sharePermissions = 0;
|
||||
}
|
||||
if (isset($entry['permissions'])) {
|
||||
$entry['permissions'] &= $sharePermissions;
|
||||
} else {
|
||||
|
|
Loading…
Reference in a new issue