forked from GNUsocial/gnu-social
		
	
		
			
				
	
	
		
			107 lines
		
	
	
		
			2.7 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			107 lines
		
	
	
		
			2.7 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| /**
 | |
|  * Phergie
 | |
|  *
 | |
|  * PHP version 5
 | |
|  *
 | |
|  * LICENSE
 | |
|  *
 | |
|  * This source file is subject to the new BSD license that is bundled
 | |
|  * with this package in the file LICENSE.
 | |
|  * It is also available through the world-wide-web at this URL:
 | |
|  * http://phergie.org/license
 | |
|  *
 | |
|  * @category  Phergie
 | |
|  * @package   Phergie_Plugin_Cache
 | |
|  * @author    Phergie Development Team <team@phergie.org>
 | |
|  * @copyright 2008-2010 Phergie Development Team (http://phergie.org)
 | |
|  * @license   http://phergie.org/license New BSD License
 | |
|  * @link      http://pear.phergie.org/package/Phergie_Plugin_Cache
 | |
|  */
 | |
| 
 | |
| /**
 | |
|  * Implements a generic cache to be used by other plugins.
 | |
|  *
 | |
|  * @category Phergie
 | |
|  * @package  Phergie_Plugin_Cache
 | |
|  * @author   Phergie Development Team <team@phergie.org>
 | |
|  * @license  http://phergie.org/license New BSD License
 | |
|  * @link     http://pear.phergie.org/package/Phergie_Plugin_Cache
 | |
|  */
 | |
| class Phergie_Plugin_Cache extends Phergie_Plugin_Abstract
 | |
| {
 | |
|     /**
 | |
|      * Key-value data storage for the cache 
 | |
|      * 
 | |
|      * @var array 
 | |
|      */
 | |
|     protected $cache = array();
 | |
| 
 | |
|     /**
 | |
|      * Stores a value in the cache. 
 | |
|      *
 | |
|      * @param string   $key       Key to associate with the value 
 | |
|      * @param mixed    $data      Data to be stored
 | |
|      * @param int|null $ttl       Time to live in seconds or NULL for forever
 | |
|      * @param bool     $overwrite TRUE to overwrite any existing value 
 | |
|      *        associated with the specified key
 | |
|      *
 | |
|      * @return bool
 | |
|      */
 | |
|     public function store($key, $data, $ttl = 3600, $overwrite = true)
 | |
|     {
 | |
|         if (!$overwrite && isset($this->cache[$key])) {
 | |
|             return false;
 | |
|         }
 | |
| 
 | |
|         if ($ttl) {
 | |
|             $expires = time()+$ttl;
 | |
|         } else {
 | |
|             $expires = null;
 | |
|         }
 | |
| 
 | |
|         $this->cache[$key] = array('data' => $data, 'expires' => $expires);
 | |
|         return true;
 | |
| 
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Fetches a previously stored value. 
 | |
|      *
 | |
|      * @param string $key Key associated with the value 
 | |
|      *
 | |
|      * @return mixed Stored value or FALSE if no value or an expired value 
 | |
|      *         is associated with the specified key 
 | |
|      */
 | |
|     public function fetch($key)
 | |
|     {
 | |
|         if (!isset($this->cache[$key])) {
 | |
|             return false;
 | |
|         }
 | |
| 
 | |
|         $item = $this->cache[$key];
 | |
|         if (!is_null($item['expires']) && $item['expires'] < time()) {
 | |
|             $this->expire($key);
 | |
|             return false;
 | |
|         }
 | |
| 
 | |
|         return $item['data'];
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Expires a value that has exceeded its time to live.
 | |
|      *
 | |
|      * @param string $key Key associated with the value to expire 
 | |
|      *
 | |
|      * @return bool
 | |
|      */
 | |
|     protected function expire($key)
 | |
|     {
 | |
|         if (!isset($this->cache[$key])) {
 | |
|             return false;
 | |
|         }
 | |
|         unset($this->cache[$key]);
 | |
|         return true;
 | |
|     }
 | |
| }
 |