summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorRobin Appelman <robin@icewind.nl>2019-10-31 14:57:39 +0100
committerRobin Appelman <robin@icewind.nl>2019-11-13 12:39:46 +0100
commit066faaec058ba487f214463d1b53603aaeaad646 (patch)
tree6425d460f912302a34f691b2b381b794ebd225e5
parent43fa746ad9eeb8c4596a33aa5b0d9a423dee4da4 (diff)
downloadnextcloud-server-066faaec058ba487f214463d1b53603aaeaad646.tar.gz
nextcloud-server-066faaec058ba487f214463d1b53603aaeaad646.zip
fix folder delete
Signed-off-by: Robin Appelman <robin@icewind.nl>
-rw-r--r--lib/private/Files/Cache/Cache.php12
-rw-r--r--tests/lib/Files/Cache/CacheTest.php2
2 files changed, 11 insertions, 3 deletions
diff --git a/lib/private/Files/Cache/Cache.php b/lib/private/Files/Cache/Cache.php
index dd063903058..f3081e7b18b 100644
--- a/lib/private/Files/Cache/Cache.php
+++ b/lib/private/Files/Cache/Cache.php
@@ -548,8 +548,14 @@ class Cache implements ICache {
* @throws \OC\DatabaseException
*/
private function removeChildren(ICacheEntry $entry) {
- $subFolders = $this->getSubFolders($entry);
- foreach ($subFolders as $folder) {
+ $children = $this->getFolderContentsById($entry->getId());
+ $childIds = array_map(function(ICacheEntry $cacheEntry) {
+ return $cacheEntry->getId();
+ }, $children);
+ $childFolders = array_filter($children, function ($child) {
+ return $child->getMimeType() == FileInfo::MIMETYPE_FOLDER;
+ });
+ foreach ($childFolders as $folder) {
$this->removeChildren($folder);
}
@@ -560,7 +566,7 @@ class Cache implements ICache {
$query = $this->getQueryBuilder();
$query->delete('filecache_extended')
- ->whereParent($entry->getId());
+ ->where($query->expr()->in('fileid', $query->createNamedParameter($childIds, IQueryBuilder::PARAM_INT_ARRAY)));
$query->execute();
}
diff --git a/tests/lib/Files/Cache/CacheTest.php b/tests/lib/Files/Cache/CacheTest.php
index f6794cfa2f0..ccdfbbd065b 100644
--- a/tests/lib/Files/Cache/CacheTest.php
+++ b/tests/lib/Files/Cache/CacheTest.php
@@ -773,6 +773,8 @@ class CacheTest extends \Test\TestCase {
$this->assertEquals(0, $entry->getCreationTime());
$this->assertEquals(25, $entry->getUploadTime());
$this->assertEquals(null, $entry->getMetadataEtag());
+
+ $this->cache->remove("sub");
}
protected function tearDown() {