add OC_Cache::clear

remotes/origin/stable45
Robin Appelman 13 years ago
parent 10eef49c3c
commit e11bf460e0
  1. 7
      lib/cache.php
  2. 23
      lib/cache/file.php

@ -37,4 +37,11 @@ class OC_Cache {
return self::$cache->remove($key);
}
static public function clear() {
if (!self::$cache) {
self::init();
}
return self::$cache->clear();
}
}

23
lib/cache/file.php vendored

@ -7,7 +7,7 @@
*/
class OC_Cache_File extends OC_Cache {
class OC_Cache_File{
protected function getStorage() {
if(OC_User::isLoggedIn()){
$subdir = 'cache';
@ -24,7 +24,7 @@ class OC_Cache_File extends OC_Cache {
public function get($key) {
$storage = $this->getStorage();
if ($storage->is_file($key)) {
if ($storage and $storage->is_file($key)) {
$mtime = $storage->filemtime($key);
if ($mtime < time()) {
$storage->unlink($key);
@ -35,9 +35,9 @@ class OC_Cache_File extends OC_Cache {
return null;
}
public function set($key, $value, $ttl) {
public function set($key, $value, $ttl=0) {
$storage = $this->getStorage();
if ($storage->file_put_contents($key, $value)) {
if ($storage and $storage->file_put_contents($key, $value)) {
return $storage->touch($key, time() + $ttl);
}
return false;
@ -45,6 +45,21 @@ class OC_Cache_File extends OC_Cache {
public function remove($key) {
$storage = $this->getStorage();
if(!$storage){
return false;
}
return $storage->unlink($key);
}
public function clear(){
$storage = $this->getStorage();
if($storage and $storage->is_dir('/')){
$dh=$storage->opendir('/');
while($file=readdir($dh)){
if($file!='.' and $file!='..'){
$storage->unlink('/'.$file);
}
}
}
}
}

Loading…
Cancel
Save