Merge pull request #22171 from nextcloud/backport/21728/stable19

[stable19] Reuse cache for directory mtime/size if filesystem changes can be ignored
This commit is contained in:
Roeland Jago Douma 2020-08-11 15:18:52 +02:00 committed by GitHub
commit e55591b0f8
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
1 changed files with 6 additions and 0 deletions

View File

@ -45,6 +45,7 @@ use Aws\S3\S3Client;
use Icewind\Streams\CallbackWrapper; use Icewind\Streams\CallbackWrapper;
use Icewind\Streams\IteratorDirectory; use Icewind\Streams\IteratorDirectory;
use OC\Cache\CappedMemoryCache; use OC\Cache\CappedMemoryCache;
use OC\Files\Cache\CacheEntry;
use OC\Files\ObjectStore\S3ConnectionTrait; use OC\Files\ObjectStore\S3ConnectionTrait;
use OC\Files\ObjectStore\S3ObjectTrait; use OC\Files\ObjectStore\S3ObjectTrait;
use OCP\Constants; use OCP\Constants;
@ -374,6 +375,11 @@ class AmazonS3 extends \OC\Files\Storage\Common {
//folders don't really exist //folders don't really exist
$stat['size'] = -1; //unknown $stat['size'] = -1; //unknown
$stat['mtime'] = time(); $stat['mtime'] = time();
$cacheEntry = $this->getCache()->get($path);
if ($cacheEntry instanceof CacheEntry && $this->getMountOption('filesystem_check_changes', 1) !== 1) {
$stat['size'] = $cacheEntry->getSize();
$stat['mtime'] = $cacheEntry->getMTime();
}
} else { } else {
$stat['size'] = $this->getContentLength($path); $stat['size'] = $this->getContentLength($path);
$stat['mtime'] = strtotime($this->getLastModified($path)); $stat['mtime'] = strtotime($this->getLastModified($path));