From c9d74f83dbed2d0f5eb06c89decc9059a2d9a56d Mon Sep 17 00:00:00 2001 From: Damian Mooyman Date: Tue, 12 May 2015 15:56:20 +1200 Subject: [PATCH] API Only invalidate cache when file is changed --- code/extensions/FileTextCache.php | 28 ++++++++++++++++++++++--- code/extensions/FileTextExtractable.php | 5 +++++ 2 files changed, 30 insertions(+), 3 deletions(-) diff --git a/code/extensions/FileTextCache.php b/code/extensions/FileTextCache.php index 0d885be..cd1d046 100644 --- a/code/extensions/FileTextCache.php +++ b/code/extensions/FileTextCache.php @@ -16,6 +16,14 @@ interface FileTextCache { * @param File $file */ public function load(File $file); + + /** + * Invalidate the cache for a given file. + * Invoked in onBeforeWrite on the file + * + * @param File $file + */ + public function invalidate(File $file); } /** @@ -34,6 +42,13 @@ class FileTextCache_Database implements FileTextCache { $file->write(); } + public function invalidate(File $file) { + // To prevent writing to the cache from invalidating it + if(!$file->isChanged('FileContentCache')) { + $file->FileContentCache = ''; + } + } + } /** @@ -42,12 +57,13 @@ class FileTextCache_Database implements FileTextCache { class FileTextCache_SSCache implements FileTextCache, Flushable { /** - * Default cache to 1 hour + * Lifetime of cache in seconds + * Null is indefinite * - * @var int + * @var int|null * @config */ - private static $lifetime = 3600; + private static $lifetime = null; /** * @return SS_Cache @@ -80,4 +96,10 @@ class FileTextCache_SSCache implements FileTextCache, Flushable { $cache->clean(); } + public function invalidate(File $file) { + $key = $this->getKey($file); + $cache = self::get_cache(); + return $cache->remove($key); + } + } diff --git a/code/extensions/FileTextExtractable.php b/code/extensions/FileTextExtractable.php index 453d876..16110e3 100644 --- a/code/extensions/FileTextExtractable.php +++ b/code/extensions/FileTextExtractable.php @@ -83,4 +83,9 @@ class FileTextExtractable extends DataExtension { return $text; } + + public function onBeforeWrite() { + // Clear cache before changing file + $this->getTextCache()->invalidate($this->owner); + } }