2017-11-09 16:05:18 +00:00
|
|
|
<?php
|
|
|
|
/**
|
|
|
|
* @file src/Core/Cache.php
|
|
|
|
*/
|
|
|
|
namespace Friendica\Core;
|
|
|
|
|
2018-06-28 20:57:17 +00:00
|
|
|
use Friendica\Core\Cache\CacheDriverFactory;
|
2017-12-17 20:24:57 +00:00
|
|
|
|
2017-11-09 16:05:18 +00:00
|
|
|
/**
|
|
|
|
* @brief Class for storing data for a short time
|
|
|
|
*/
|
2018-03-01 05:33:56 +00:00
|
|
|
class Cache extends \Friendica\BaseObject
|
2017-11-09 16:05:18 +00:00
|
|
|
{
|
2018-03-07 02:34:00 +00:00
|
|
|
const MONTH = 2592000;
|
|
|
|
const WEEK = 604800;
|
|
|
|
const DAY = 86400;
|
|
|
|
const HOUR = 3600;
|
|
|
|
const HALF_HOUR = 1800;
|
|
|
|
const QUARTER_HOUR = 900;
|
|
|
|
const FIVE_MINUTES = 300;
|
|
|
|
const MINUTE = 60;
|
2018-10-29 09:21:10 +00:00
|
|
|
const INFINITE = 0;
|
2018-03-01 04:48:09 +00:00
|
|
|
|
2017-11-09 16:05:18 +00:00
|
|
|
/**
|
2018-03-01 04:48:09 +00:00
|
|
|
* @var Cache\ICacheDriver
|
2017-11-09 16:05:18 +00:00
|
|
|
*/
|
2018-09-26 02:58:04 +00:00
|
|
|
private static $driver = null;
|
|
|
|
public static $driver_class = null;
|
|
|
|
public static $driver_name = null;
|
2017-11-09 16:05:18 +00:00
|
|
|
|
2018-03-01 04:48:09 +00:00
|
|
|
public static function init()
|
|
|
|
{
|
2018-09-26 02:58:04 +00:00
|
|
|
self::$driver_name = Config::get('system', 'cache_driver', 'database');
|
|
|
|
self::$driver = CacheDriverFactory::create(self::$driver_name);
|
|
|
|
self::$driver_class = get_class(self::$driver);
|
2017-11-09 16:05:18 +00:00
|
|
|
}
|
|
|
|
|
2018-03-01 04:48:09 +00:00
|
|
|
/**
|
|
|
|
* Returns the current cache driver
|
|
|
|
*
|
|
|
|
* @return Cache\ICacheDriver
|
|
|
|
*/
|
|
|
|
private static function getDriver()
|
|
|
|
{
|
|
|
|
if (self::$driver === null) {
|
|
|
|
self::init();
|
|
|
|
}
|
|
|
|
|
|
|
|
return self::$driver;
|
|
|
|
}
|
|
|
|
|
2018-09-26 02:52:32 +00:00
|
|
|
/**
|
|
|
|
* @brief Returns all the cache keys sorted alphabetically
|
|
|
|
*
|
2018-10-06 22:27:54 +00:00
|
|
|
* @param string $prefix Prefix of the keys (optional)
|
|
|
|
*
|
2018-10-07 20:14:05 +00:00
|
|
|
* @return array Empty if the driver doesn't support this feature
|
2019-01-06 21:06:53 +00:00
|
|
|
* @throws \Exception
|
2018-09-26 02:52:32 +00:00
|
|
|
*/
|
2018-10-06 22:27:54 +00:00
|
|
|
public static function getAllKeys($prefix = null)
|
2018-09-26 02:52:32 +00:00
|
|
|
{
|
|
|
|
$time = microtime(true);
|
|
|
|
|
2018-10-06 22:27:54 +00:00
|
|
|
$return = self::getDriver()->getAllKeys($prefix);
|
2018-09-26 02:52:32 +00:00
|
|
|
|
2018-10-09 17:58:58 +00:00
|
|
|
self::getApp()->saveTimestamp($time, 'cache');
|
2018-09-26 02:52:32 +00:00
|
|
|
|
|
|
|
return $return;
|
|
|
|
}
|
|
|
|
|
2017-11-09 16:05:18 +00:00
|
|
|
/**
|
|
|
|
* @brief Fetch cached data according to the key
|
|
|
|
*
|
|
|
|
* @param string $key The key to the cached data
|
|
|
|
*
|
|
|
|
* @return mixed Cached $value or "null" if not found
|
2019-01-06 21:06:53 +00:00
|
|
|
* @throws \Exception
|
2017-11-09 16:05:18 +00:00
|
|
|
*/
|
|
|
|
public static function get($key)
|
|
|
|
{
|
2018-03-01 05:33:56 +00:00
|
|
|
$time = microtime(true);
|
|
|
|
|
|
|
|
$return = self::getDriver()->get($key);
|
|
|
|
|
2018-10-09 17:58:58 +00:00
|
|
|
self::getApp()->saveTimestamp($time, 'cache');
|
2018-03-01 05:33:56 +00:00
|
|
|
|
|
|
|
return $return;
|
2017-11-09 16:05:18 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Put data in the cache according to the key
|
|
|
|
*
|
|
|
|
* The input $value can have multiple formats.
|
|
|
|
*
|
|
|
|
* @param string $key The key to the cached data
|
|
|
|
* @param mixed $value The value that is about to be stored
|
|
|
|
* @param integer $duration The cache lifespan
|
2017-11-19 19:15:25 +00:00
|
|
|
*
|
2018-03-01 04:48:09 +00:00
|
|
|
* @return bool
|
2019-01-06 21:06:53 +00:00
|
|
|
* @throws \Exception
|
2017-11-09 16:05:18 +00:00
|
|
|
*/
|
2018-03-01 04:48:09 +00:00
|
|
|
public static function set($key, $value, $duration = self::MONTH)
|
2017-11-09 16:05:18 +00:00
|
|
|
{
|
2018-03-01 05:33:56 +00:00
|
|
|
$time = microtime(true);
|
|
|
|
|
|
|
|
$return = self::getDriver()->set($key, $value, $duration);
|
|
|
|
|
2018-10-09 17:58:58 +00:00
|
|
|
self::getApp()->saveTimestamp($time, 'cache_write');
|
2018-03-01 05:33:56 +00:00
|
|
|
|
|
|
|
return $return;
|
2017-11-09 16:05:18 +00:00
|
|
|
}
|
|
|
|
|
2018-03-17 01:57:58 +00:00
|
|
|
/**
|
|
|
|
* @brief Delete a value from the cache
|
|
|
|
*
|
|
|
|
* @param string $key The key to the cached data
|
|
|
|
*
|
|
|
|
* @return bool
|
2019-01-06 21:06:53 +00:00
|
|
|
* @throws \Exception
|
2018-03-17 01:57:58 +00:00
|
|
|
*/
|
|
|
|
public static function delete($key)
|
|
|
|
{
|
|
|
|
$time = microtime(true);
|
|
|
|
|
|
|
|
$return = self::getDriver()->delete($key);
|
|
|
|
|
2018-10-09 17:58:58 +00:00
|
|
|
self::getApp()->saveTimestamp($time, 'cache_write');
|
2018-03-17 01:57:58 +00:00
|
|
|
|
|
|
|
return $return;
|
|
|
|
}
|
|
|
|
|
2017-11-09 16:05:18 +00:00
|
|
|
/**
|
|
|
|
* @brief Remove outdated data from the cache
|
|
|
|
*
|
2018-09-26 02:46:45 +00:00
|
|
|
* @param boolean $outdated just remove outdated values
|
2017-11-19 19:15:25 +00:00
|
|
|
*
|
2019-01-06 21:06:53 +00:00
|
|
|
* @return bool
|
2017-11-09 16:05:18 +00:00
|
|
|
*/
|
2018-09-26 02:46:45 +00:00
|
|
|
public static function clear($outdated = true)
|
2017-11-09 16:05:18 +00:00
|
|
|
{
|
2018-09-26 02:46:45 +00:00
|
|
|
return self::getDriver()->clear($outdated);
|
2017-11-09 16:05:18 +00:00
|
|
|
}
|
|
|
|
}
|