API Only invalidate cache when file is changed

This commit is contained in:
Damian Mooyman 2015-05-12 15:56:20 +12:00
parent 6cf09f26c8
commit c9d74f83db
2 changed files with 30 additions and 3 deletions

View File

@ -16,6 +16,14 @@ interface FileTextCache {
* @param File $file * @param File $file
*/ */
public function load(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(); $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 { 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 * @config
*/ */
private static $lifetime = 3600; private static $lifetime = null;
/** /**
* @return SS_Cache * @return SS_Cache
@ -80,4 +96,10 @@ class FileTextCache_SSCache implements FileTextCache, Flushable {
$cache->clean(); $cache->clean();
} }
public function invalidate(File $file) {
$key = $this->getKey($file);
$cache = self::get_cache();
return $cache->remove($key);
}
} }

View File

@ -83,4 +83,9 @@ class FileTextExtractable extends DataExtension {
return $text; return $text;
} }
public function onBeforeWrite() {
// Clear cache before changing file
$this->getTextCache()->invalidate($this->owner);
}
} }