]> source.dussan.org Git - nextcloud-server.git/commitdiff
Add background job for global file cache cleanup
authorBart Visscher <bartv@thisnet.nl>
Tue, 28 Aug 2012 20:39:05 +0000 (22:39 +0200)
committerBart Visscher <bartv@thisnet.nl>
Tue, 28 Aug 2012 21:07:28 +0000 (23:07 +0200)
lib/base.php
lib/cache/fileglobal.php

index b4f3e6671337bf4f434c04509d249b1cd3b1e8e9..af860027c1d37dce4c0bcb321c584d7d1667409d 100644 (file)
@@ -346,6 +346,9 @@ class OC{
                        }
                }
 
+               // register cache cleanup
+               OC_BackgroundJob_RegularTask::register('OC_Cache_FileGlobal', 'gc');
+
                // Check for blacklisted files
                OC_Hook::connect('OC_Filesystem','write','OC_Filesystem','isBlacklisted');
                OC_Hook::connect('OC_Filesystem', 'rename', 'OC_Filesystem', 'isBlacklisted');
index 1c2c9bdc82d293890296b750476ce22b5a91b9a5..d4336553c38d53353c3ff405fa01c48a1970d588 100644 (file)
@@ -8,7 +8,7 @@
 
 
 class OC_Cache_FileGlobal{
-       protected function getCacheDir() {
+       static protected function getCacheDir() {
                $cache_dir = get_temp_dir().'/owncloud-'.OC_Util::getInstanceId().'/';
                if (!is_dir($cache_dir)) {
                        mkdir($cache_dir);
@@ -23,7 +23,7 @@ class OC_Cache_FileGlobal{
        public function get($key) {
                $key = $this->fixKey($key);
                if ($this->hasKey($key)) {
-                       $cache_dir = $this->getCacheDir();
+                       $cache_dir = self::getCacheDir();
                        return file_get_contents($cache_dir.$key);
                }
                return null;
@@ -31,7 +31,7 @@ class OC_Cache_FileGlobal{
 
        public function set($key, $value, $ttl=0) {
                $key = $this->fixKey($key);
-               $cache_dir = $this->getCacheDir();
+               $cache_dir = self::getCacheDir();
                if ($cache_dir and file_put_contents($cache_dir.$key, $value)) {
                        if ($ttl === 0) {
                                $ttl = 86400; // 60*60*24
@@ -43,7 +43,7 @@ class OC_Cache_FileGlobal{
 
        public function hasKey($key) {
                $key = $this->fixKey($key);
-               $cache_dir = $this->getCacheDir();
+               $cache_dir = self::getCacheDir();
                if ($cache_dir && is_file($cache_dir.$key)) {
                        $mtime = filemtime($cache_dir.$key);
                        if ($mtime < time()) {
@@ -56,7 +56,7 @@ class OC_Cache_FileGlobal{
        }
 
        public function remove($key) {
-               $cache_dir = $this->getCacheDir();
+               $cache_dir = self::getCacheDir();
                if(!$cache_dir){
                        return false;
                }
@@ -65,7 +65,7 @@ class OC_Cache_FileGlobal{
        }
 
        public function clear(){
-               $cache_dir = $this->getCacheDir();
+               $cache_dir = self::getCacheDir();
                if($cache_dir and is_dir($cache_dir)){
                        $dh=opendir($cache_dir);
                        while($file=readdir($dh)){
@@ -75,4 +75,26 @@ class OC_Cache_FileGlobal{
                        }
                }
        }
+
+       static public function gc() {
+               $last_run = OC_AppConfig::getValue('core', 'global_cache_gc_lastrun', 0);
+               $now = time();
+               if (($now - $last_run) < 300) {
+                       // only do cleanup every 5 minutes
+                       return;
+               }
+               OC_AppConfig::setValue('core', 'global_cache_gc_lastrun', $now);
+               $cache_dir = self::getCacheDir();
+               if($cache_dir and is_dir($cache_dir)) {
+                       $dh=opendir($cache_dir);
+                       while($file=readdir($dh)) {
+                               if($file!='.' and $file!='..') {
+                                       $mtime = filemtime($cache_dir.$file);
+                                       if ($mtime < $now) {
+                                               unlink($cache_dir.$file);
+                                       }
+                               }
+                       }
+               }
+       }
 }