167 lines
4.5 KiB
PHP
167 lines
4.5 KiB
PHP
<?php
|
|
/**
|
|
* 2007-2016 PrestaShop
|
|
*
|
|
* NOTICE OF LICENSE
|
|
*
|
|
* This source file is subject to the Open Software License (OSL 3.0)
|
|
* that is bundled with this package in the file LICENSE.txt.
|
|
* It is also available through the world-wide-web at this URL:
|
|
* http://opensource.org/licenses/osl-3.0.php
|
|
* If you did not receive a copy of the license and are unable to
|
|
* obtain it through the world-wide-web, please send an email
|
|
* to license@prestashop.com so we can send you a copy immediately.
|
|
*
|
|
* DISCLAIMER
|
|
*
|
|
* Do not edit or add to this file if you wish to upgrade PrestaShop to newer
|
|
* versions in the future. If you wish to customize PrestaShop for your
|
|
* needs please refer to http://www.prestashop.com for more information.
|
|
*
|
|
* @author PrestaShop SA <contact@prestashop.com>
|
|
* @copyright 2007-2016 PrestaShop SA
|
|
* @license http://opensource.org/licenses/osl-3.0.php Open Software License (OSL 3.0)
|
|
* International Registered Trademark & Property of PrestaShop SA
|
|
*/
|
|
|
|
/**
|
|
* This class requires the PECL APC extension or PECL APCu extension to be installed
|
|
*
|
|
* @since 1.5.0
|
|
*/
|
|
class CacheApcCore extends Cache
|
|
{
|
|
/** @var bool Whether APCu is enabled */
|
|
public $apcu;
|
|
|
|
/**
|
|
* CacheApcCore constructor.
|
|
*/
|
|
public function __construct()
|
|
{
|
|
if (!extension_loaded('apc') && !extension_loaded('apcu')) {
|
|
throw new PrestaShopException('APC cache has been enabled, but the APC or APCu extension is not available');
|
|
}
|
|
$this->apcu = extension_loaded('apcu');
|
|
}
|
|
|
|
/**
|
|
* Delete one or several data from cache (* joker can be used, but avoid it !)
|
|
* E.g.: delete('*'); delete('my_prefix_*'); delete('my_key_name');
|
|
*
|
|
* @param string $key Cache key
|
|
* @return bool Whether the key was deleted
|
|
*/
|
|
public function delete($key)
|
|
{
|
|
if ($key == '*') {
|
|
$this->flush();
|
|
} elseif (strpos($key, '*') === false) {
|
|
$this->_delete($key);
|
|
} else {
|
|
$pattern = str_replace('\\*', '.*', preg_quote($key));
|
|
|
|
$cache_info = (($this->apcu) ? apcu_cache_info('') : apc_cache_info(''));
|
|
foreach ($cache_info['cache_list'] as $entry) {
|
|
if (isset($entry['key'])) {
|
|
$key = $entry['key'];
|
|
} else {
|
|
$key = $entry['info'];
|
|
}
|
|
if (preg_match('#^'.$pattern.'$#', $key)) {
|
|
$this->_delete($key);
|
|
}
|
|
}
|
|
}
|
|
return true;
|
|
}
|
|
|
|
/**
|
|
* @see Cache::_set()
|
|
*/
|
|
protected function _set($key, $value, $ttl = 0)
|
|
{
|
|
return (($this->apcu) ? apcu_store($key, $value, $ttl) : apc_store($key, $value, $ttl));
|
|
}
|
|
|
|
/**
|
|
* @see Cache::_get()
|
|
*/
|
|
protected function _get($key)
|
|
{
|
|
return (($this->apcu) ? apcu_fetch($key) : apc_fetch($key));
|
|
}
|
|
|
|
/**
|
|
* @see Cache::_exists()
|
|
*/
|
|
protected function _exists($key)
|
|
{
|
|
if (!function_exists('apc_exists') && !function_exists('apcu_exists')) {
|
|
// We're dealing with APC < 3.1.4; use this boolean wrapper as a fallback:
|
|
return (bool)apc_fetch($key);
|
|
} else {
|
|
return (($this->apcu) ? apcu_exists($key) : apc_exists($key));
|
|
}
|
|
}
|
|
|
|
/**
|
|
* @see Cache::_delete()
|
|
*/
|
|
protected function _delete($key)
|
|
{
|
|
return (($this->apcu) ? apcu_delete($key) : apc_delete($key));
|
|
}
|
|
|
|
/**
|
|
* @see Cache::_writeKeys()
|
|
*/
|
|
protected function _writeKeys()
|
|
{
|
|
}
|
|
|
|
/**
|
|
* @see Cache::flush()
|
|
*/
|
|
public function flush()
|
|
{
|
|
return (($this->apcu) ? apcu_clear_cache() : apc_clear_cache());
|
|
}
|
|
|
|
/**
|
|
* Store data in the cache
|
|
*
|
|
* @param string $key Cache Key
|
|
* @param mixed $value Value
|
|
* @param int $ttl Time to live in the cache
|
|
* 0 = unlimited
|
|
* @return bool Whether the data was successfully stored
|
|
*/
|
|
public function set($key, $value, $ttl = 0)
|
|
{
|
|
return $this->_set($key, $value, $ttl);
|
|
}
|
|
|
|
/**
|
|
* Retrieve data from the cache
|
|
*
|
|
* @param string $key Cache key
|
|
* @return mixed Data
|
|
*/
|
|
public function get($key)
|
|
{
|
|
return $this->_get($key);
|
|
}
|
|
|
|
/**
|
|
* Check if data has been cached
|
|
*
|
|
* @param string $key Cache key
|
|
* @return bool Whether the data has been cached
|
|
*/
|
|
public function exists($key)
|
|
{
|
|
return $this->_exists($key);
|
|
}
|
|
}
|