| 
									
										
										
										
											2010-03-05 18:41:02 +00:00
										 |  |  | <?php | 
					
						
							|  |  |  | /** | 
					
						
							|  |  |  |  * @copyright NetMonsters <team@netmonsters.ru> | 
					
						
							|  |  |  |  * @link http://netmonsters.ru | 
					
						
							|  |  |  |  * @package Majestic | 
					
						
							|  |  |  |  * @subpackage Cache | 
					
						
							|  |  |  |  * @since 2010-03-04 | 
					
						
							|  |  |  |  * @version SVN: $Id$ | 
					
						
							|  |  |  |  * @filesource $URL$ | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | class MemcacheCache extends Cache | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |      | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @var Memcache | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     protected $connection = null; | 
					
						
							|  |  |  |      | 
					
						
							| 
									
										
										
										
											2010-03-13 23:33:46 +00:00
										 |  |  |     protected $key_salt = null; | 
					
						
							|  |  |  |      | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * One hour to live default | 
					
						
							|  |  |  |      *  | 
					
						
							|  |  |  |      * @var int | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     protected $expire = 3600; | 
					
						
							|  |  |  |      | 
					
						
							|  |  |  |      | 
					
						
							| 
									
										
										
										
											2010-03-05 18:41:02 +00:00
										 |  |  |     public function __construct($config) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $this->connection = new Memcache(); | 
					
						
							|  |  |  |          | 
					
						
							| 
									
										
										
										
											2010-03-13 23:33:46 +00:00
										 |  |  |         if (isset($config['key_salt'])) { | 
					
						
							|  |  |  |             $this->key_salt = $config['key_salt']; | 
					
						
							|  |  |  |             unset($config['key_salt']); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |          | 
					
						
							| 
									
										
										
										
											2010-03-05 18:41:02 +00:00
										 |  |  |         $required = array('hostname', 'port'); | 
					
						
							|  |  |  |         foreach ($config as $c) { | 
					
						
							|  |  |  |             foreach ($required as $option) { | 
					
						
							|  |  |  |                 if (!isset($c[$option])) { | 
					
						
							|  |  |  |                     throw new Exception('Configuration must have a "' . $option . '".'); | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             $this->connection->addServer($c['hostname'], $c['port']); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |      | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * Add an item to the cache | 
					
						
							|  |  |  |      *  | 
					
						
							|  |  |  |      * @param string $key | 
					
						
							|  |  |  |      * @param mixed $value | 
					
						
							|  |  |  |      * @param int $expire | 
					
						
							|  |  |  |      * @return bool | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function add($key, $value, $expire = 0) | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2010-03-13 23:33:46 +00:00
										 |  |  |         return $this->connection->add($this->getKey($key), $value, null, $this->getExpire($expire)); | 
					
						
							| 
									
										
										
										
											2010-03-05 18:41:02 +00:00
										 |  |  |     } | 
					
						
							|  |  |  |      | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * Decrement item's value | 
					
						
							|  |  |  |      *  | 
					
						
							|  |  |  |      * @param string $key | 
					
						
							|  |  |  |      * @param int $decrement | 
					
						
							|  |  |  |      * @return bool | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function decrement($key, $decrement = 1) | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2010-03-13 23:33:46 +00:00
										 |  |  |         return $this->connection->decrement($this->getKey($key), $decrement); | 
					
						
							| 
									
										
										
										
											2010-03-05 18:41:02 +00:00
										 |  |  |     } | 
					
						
							|  |  |  |      | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * Delete item from the cache | 
					
						
							|  |  |  |      *  | 
					
						
							|  |  |  |      * @param string $key | 
					
						
							|  |  |  |      * @param int $value | 
					
						
							|  |  |  |      * @return bool | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function del($key) | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2010-03-14 12:12:17 +00:00
										 |  |  |         return $this->connection->delete($this->getKey($key), 0); | 
					
						
							| 
									
										
										
										
											2010-03-05 18:41:02 +00:00
										 |  |  |     } | 
					
						
							|  |  |  |      | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * Flush all existing items | 
					
						
							|  |  |  |      *  | 
					
						
							|  |  |  |      * @return bool | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function flush() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return $this->connection->flush(); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |      | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * Retrieve item from the cache | 
					
						
							|  |  |  |      *  | 
					
						
							| 
									
										
										
										
											2010-03-13 23:33:46 +00:00
										 |  |  |      * @param string $key | 
					
						
							| 
									
										
										
										
											2010-03-05 18:41:02 +00:00
										 |  |  |      * @return mixed | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function get($key) | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2010-03-13 23:33:46 +00:00
										 |  |  |         return $this->connection->get($this->getKey($key)); | 
					
						
							| 
									
										
										
										
											2010-03-05 18:41:02 +00:00
										 |  |  |     } | 
					
						
							|  |  |  |      | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * Increment item's value | 
					
						
							|  |  |  |      *  | 
					
						
							|  |  |  |      * @param string $key | 
					
						
							|  |  |  |      * @param int $increment | 
					
						
							|  |  |  |      * @return bool | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function increment($key, $increment = 1) | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2010-03-13 23:33:46 +00:00
										 |  |  |         return $this->connection->increment($this->getKey($key), $increment); | 
					
						
							| 
									
										
										
										
											2010-03-05 18:41:02 +00:00
										 |  |  |     } | 
					
						
							|  |  |  |      | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * Replace value of the existing item | 
					
						
							|  |  |  |      *  | 
					
						
							|  |  |  |      * @param string $key | 
					
						
							|  |  |  |      * @param mixed $var | 
					
						
							|  |  |  |      * @param int $expire | 
					
						
							|  |  |  |      * @return bool | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function replace($key, $value, $expire = 0) | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2010-03-13 23:33:46 +00:00
										 |  |  |         return $this->connection->replace($this->getKey($key), $value, null, $this->getExpire($expire)); | 
					
						
							| 
									
										
										
										
											2010-03-05 18:41:02 +00:00
										 |  |  |     } | 
					
						
							|  |  |  |      | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * Store data in the cache | 
					
						
							|  |  |  |      *  | 
					
						
							|  |  |  |      * @param string $key | 
					
						
							|  |  |  |      * @param mixed $value | 
					
						
							|  |  |  |      * @param int $expire | 
					
						
							|  |  |  |      * @return bool | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function set($key, $value, $expire = 0) | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2010-03-13 23:33:46 +00:00
										 |  |  |         return $this->connection->set($this->getKey($key), $value, null, $this->getExpire($expire)); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |      | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @param string $key | 
					
						
							|  |  |  |      * @return string | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     protected function getKey($key) | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2010-07-19 15:06:01 +00:00
										 |  |  |         return md5($this->key_salt . $key); | 
					
						
							| 
									
										
										
										
											2010-03-13 23:33:46 +00:00
										 |  |  |     } | 
					
						
							|  |  |  |      | 
					
						
							|  |  |  |     public function getExpire($expire) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return ($expire > 0) ? $expire : $this->expire; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2010-03-05 18:41:02 +00:00
										 |  |  | } |