aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJoas Schilling <coding@schilljs.com>2017-03-09 11:58:26 +0100
committerJoas Schilling <coding@schilljs.com>2017-03-30 23:26:19 +0200
commit738730f7b280884cc89c272bbab2a21caa8a24dd (patch)
tree03f119fa57b392b65975c11aadf480a85b8bf1e3
parenta51e4dd2591b8c264846e7811605dd3f5d7a5c55 (diff)
downloadnextcloud-server-738730f7b280884cc89c272bbab2a21caa8a24dd.tar.gz
nextcloud-server-738730f7b280884cc89c272bbab2a21caa8a24dd.zip
Also add the root of external storages to the file id list
Signed-off-by: Joas Schilling <coding@schilljs.com>
-rw-r--r--apps/workflowengine/lib/Check/FileSystemTags.php18
1 files changed, 13 insertions, 5 deletions
diff --git a/apps/workflowengine/lib/Check/FileSystemTags.php b/apps/workflowengine/lib/Check/FileSystemTags.php
index e9b5a945967..4a2b87fd53e 100644
--- a/apps/workflowengine/lib/Check/FileSystemTags.php
+++ b/apps/workflowengine/lib/Check/FileSystemTags.php
@@ -23,6 +23,7 @@ namespace OCA\WorkflowEngine\Check;
use OCP\Files\Cache\ICache;
+use OCP\Files\IHomeStorage;
use OCP\Files\Storage\IStorage;
use OCP\IL10N;
use OCP\SystemTag\ISystemTagManager;
@@ -108,7 +109,7 @@ class FileSystemTags implements ICheck {
*/
protected function getSystemTags() {
$cache = $this->storage->getCache();
- $fileIds = $this->getFileIds($cache, $this->path);
+ $fileIds = $this->getFileIds($cache, $this->path, !$this->storage->instanceOfStorage(IHomeStorage::class));
$systemTags = [];
foreach ($fileIds as $i => $fileId) {
@@ -135,17 +136,19 @@ class FileSystemTags implements ICheck {
* Get the file ids of the given path and its parents
* @param ICache $cache
* @param string $path
+ * @param bool $isExternalStorage
* @return int[]
*/
- protected function getFileIds(ICache $cache, $path) {
+ protected function getFileIds(ICache $cache, $path, $isExternalStorage) {
$cacheId = $cache->getNumericStorageId();
if (isset($this->fileIds[$cacheId][$path])) {
return $this->fileIds[$cacheId][$path];
}
- if ($path !== dirname($path)) {
- $parentIds = $this->getFileIds($cache, dirname($path));
- } else {
+ $parentIds = [];
+ if ($path !== $this->dirname($path)) {
+ $parentIds = $this->getFileIds($cache, $this->dirname($path), $isExternalStorage);
+ } else if (!$isExternalStorage) {
return [];
}
@@ -158,4 +161,9 @@ class FileSystemTags implements ICheck {
return $parentIds;
}
+
+ protected function dirname($path) {
+ $dir = dirname($path);
+ return $dir === '.' ? '' : $dir;
+ }
}