2012-07-04 05:23:08 +00:00
|
|
|
<?php
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Memcache CacheResource
|
|
|
|
* CacheResource Implementation based on the KeyValueStore API to use
|
|
|
|
* memcache as the storage resource for Smarty's output caching.
|
|
|
|
* Note that memcache has a limitation of 256 characters per cache-key.
|
|
|
|
* To avoid complications all cache-keys are translated to a sha1 hash.
|
|
|
|
*
|
|
|
|
* @package CacheResource-examples
|
2014-09-07 11:38:28 +00:00
|
|
|
* @author Rodney Rehm
|
2012-07-04 05:23:08 +00:00
|
|
|
*/
|
2014-09-07 11:38:28 +00:00
|
|
|
class Smarty_CacheResource_Memcache extends Smarty_CacheResource_KeyValueStore
|
|
|
|
{
|
2012-07-04 05:23:08 +00:00
|
|
|
/**
|
|
|
|
* memcache instance
|
2014-09-07 11:38:28 +00:00
|
|
|
*
|
2012-07-04 05:23:08 +00:00
|
|
|
* @var Memcache
|
|
|
|
*/
|
|
|
|
protected $memcache = null;
|
2014-09-07 11:38:28 +00:00
|
|
|
|
2012-07-04 05:23:08 +00:00
|
|
|
public function __construct()
|
|
|
|
{
|
|
|
|
$this->memcache = new Memcache();
|
2014-09-07 11:38:28 +00:00
|
|
|
$this->memcache->addServer('127.0.0.1', 11211);
|
2012-07-04 05:23:08 +00:00
|
|
|
}
|
2014-09-07 11:38:28 +00:00
|
|
|
|
2012-07-04 05:23:08 +00:00
|
|
|
/**
|
|
|
|
* Read values for a set of keys from cache
|
|
|
|
*
|
2014-09-07 11:38:28 +00:00
|
|
|
* @param array $keys list of keys to fetch
|
|
|
|
*
|
|
|
|
* @return array list of values with the given keys used as indexes
|
2012-07-04 05:23:08 +00:00
|
|
|
* @return boolean true on success, false on failure
|
|
|
|
*/
|
|
|
|
protected function read(array $keys)
|
|
|
|
{
|
|
|
|
$_keys = $lookup = array();
|
|
|
|
foreach ($keys as $k) {
|
|
|
|
$_k = sha1($k);
|
|
|
|
$_keys[] = $_k;
|
|
|
|
$lookup[$_k] = $k;
|
|
|
|
}
|
|
|
|
$_res = array();
|
|
|
|
$res = $this->memcache->get($_keys);
|
|
|
|
foreach ($res as $k => $v) {
|
|
|
|
$_res[$lookup[$k]] = $v;
|
|
|
|
}
|
2014-09-07 11:38:28 +00:00
|
|
|
|
2012-07-04 05:23:08 +00:00
|
|
|
return $_res;
|
|
|
|
}
|
2014-09-07 11:38:28 +00:00
|
|
|
|
2012-07-04 05:23:08 +00:00
|
|
|
/**
|
|
|
|
* Save values for a set of keys to cache
|
|
|
|
*
|
2014-09-07 11:38:28 +00:00
|
|
|
* @param array $keys list of values to save
|
|
|
|
* @param int $expire expiration time
|
|
|
|
*
|
2012-07-04 05:23:08 +00:00
|
|
|
* @return boolean true on success, false on failure
|
|
|
|
*/
|
2014-09-07 11:38:28 +00:00
|
|
|
protected function write(array $keys, $expire = null)
|
2012-07-04 05:23:08 +00:00
|
|
|
{
|
|
|
|
foreach ($keys as $k => $v) {
|
|
|
|
$k = sha1($k);
|
|
|
|
$this->memcache->set($k, $v, 0, $expire);
|
|
|
|
}
|
2014-09-07 11:38:28 +00:00
|
|
|
|
2012-07-04 05:23:08 +00:00
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Remove values from cache
|
|
|
|
*
|
2014-09-07 11:38:28 +00:00
|
|
|
* @param array $keys list of keys to delete
|
|
|
|
*
|
2012-07-04 05:23:08 +00:00
|
|
|
* @return boolean true on success, false on failure
|
|
|
|
*/
|
|
|
|
protected function delete(array $keys)
|
|
|
|
{
|
|
|
|
foreach ($keys as $k) {
|
|
|
|
$k = sha1($k);
|
|
|
|
$this->memcache->delete($k);
|
|
|
|
}
|
2014-09-07 11:38:28 +00:00
|
|
|
|
2012-07-04 05:23:08 +00:00
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Remove *all* values from cache
|
|
|
|
*
|
|
|
|
* @return boolean true on success, false on failure
|
|
|
|
*/
|
|
|
|
protected function purge()
|
|
|
|
{
|
2014-09-07 11:38:28 +00:00
|
|
|
$this->memcache->flush();
|
2012-07-04 05:23:08 +00:00
|
|
|
}
|
|
|
|
}
|