diff options
author | Bart Visscher <bartv@thisnet.nl> | 2012-06-04 17:42:59 +0200 |
---|---|---|
committer | Bart Visscher <bartv@thisnet.nl> | 2012-06-04 22:24:17 +0200 |
commit | 091b343d5cc2766eb84d49b5f2c3c691b5d41a18 (patch) | |
tree | 51356b66b7a2341d8f271f7842a62ff53f47c228 /lib/cache/file.php | |
parent | dfc90021cacb5b9da3bf06e705133f18b13df583 (diff) | |
download | nextcloud-server-091b343d5cc2766eb84d49b5f2c3c691b5d41a18.tar.gz nextcloud-server-091b343d5cc2766eb84d49b5f2c3c691b5d41a18.zip |
Calendar & Contacts: Store import progress in OC_Cache
Convert calendar and contacts import to use a caching system
for storing the import progress percentage. OC_Cache can later
be made smarter about storing values.
Diffstat (limited to 'lib/cache/file.php')
-rw-r--r-- | lib/cache/file.php | 50 |
1 files changed, 50 insertions, 0 deletions
diff --git a/lib/cache/file.php b/lib/cache/file.php new file mode 100644 index 00000000000..02aad5187ee --- /dev/null +++ b/lib/cache/file.php @@ -0,0 +1,50 @@ +<?php +/** + * Copyright (c) 2012 Bart Visscher <bartv@thisnet.nl> + * This file is licensed under the Affero General Public License version 3 or + * later. + * See the COPYING-README file. + */ + + +class OC_Cache_File { + protected function getStorage() { + if(OC_User::isLoggedIn()){ + $subdir = 'cache'; + $view = new OC_FilesystemView('/'.OC_User::getUser()); + if(!$view->file_exists($subdir)) { + $view->mkdir($subdir); + } + return new OC_FilesystemView('/'.OC_User::getUser().'/'.$subdir); + }else{ + OC_Log::write('core','Can\'t get cache storage, user not logged in', OC_Log::ERROR); + return false; + } + } + + public function get($key) { + $storage = $this->getStorage(); + if ($storage->is_file($key)) { + $mtime = $storage->filemtime($key); + if ($mtime < time()) { + $storage->unlink($key); + return false; + } + return $storage->file_get_contents($key); + } + return false; + } + + public function set($key, $value, $ttl) { + $storage = $this->getStorage(); + if ($storage->file_put_contents($key, $value)) { + return $storage->touch($key, time() + $ttl); + } + return false; + } + + public function remove($key) { + $storage = $this->getStorage(); + return $storage->unlink($key); + } +} |