2018-07-04 17:37:22 -04:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace Friendica\Core\Cache;
|
|
|
|
|
|
|
|
/**
|
2018-07-05 01:59:56 -04:00
|
|
|
* This interface defines methods for Memory-Caches only
|
2018-07-04 17:37:22 -04:00
|
|
|
*
|
2019-08-04 04:26:53 -04:00
|
|
|
* Interface IMemoryCache
|
2018-07-04 17:37:22 -04:00
|
|
|
*
|
|
|
|
* @package Friendica\Core\Cache
|
|
|
|
*/
|
2019-08-04 04:26:53 -04:00
|
|
|
interface IMemoryCache extends ICache
|
2018-07-04 17:37:22 -04:00
|
|
|
{
|
|
|
|
/**
|
2018-07-05 01:59:56 -04:00
|
|
|
* Sets a value if it's not already stored
|
2018-07-04 17:37:22 -04:00
|
|
|
*
|
|
|
|
* @param string $key The cache key
|
|
|
|
* @param mixed $value The old value we know from the cache
|
|
|
|
* @param int $ttl The cache lifespan, must be one of the Cache constants
|
|
|
|
* @return bool
|
|
|
|
*/
|
2019-08-04 09:58:53 -04:00
|
|
|
public function add($key, $value, $ttl = Cache::FIVE_MINUTES);
|
2018-07-04 17:37:22 -04:00
|
|
|
|
|
|
|
/**
|
2018-07-05 01:59:56 -04:00
|
|
|
* Compares if the old value is set and sets the new value
|
2018-07-04 17:37:22 -04:00
|
|
|
*
|
|
|
|
* @param string $key The cache key
|
|
|
|
* @param mixed $oldValue The old value we know from the cache
|
|
|
|
* @param mixed $newValue The new value we want to set
|
2018-10-29 05:16:07 -04:00
|
|
|
* @param int $ttl The cache lifespan, must be one of the Cache constants
|
2018-07-04 17:37:22 -04:00
|
|
|
*
|
|
|
|
* @return bool
|
|
|
|
*/
|
2019-08-04 09:58:53 -04:00
|
|
|
public function compareSet($key, $oldValue, $newValue, $ttl = Cache::FIVE_MINUTES);
|
2018-07-04 17:37:22 -04:00
|
|
|
|
|
|
|
/**
|
2018-07-05 01:59:56 -04:00
|
|
|
* Compares if the old value is set and removes it
|
2018-07-04 17:37:22 -04:00
|
|
|
*
|
|
|
|
* @param string $key The cache key
|
|
|
|
* @param mixed $value The old value we know and want to delete
|
|
|
|
* @return bool
|
|
|
|
*/
|
|
|
|
public function compareDelete($key, $value);
|
2018-07-05 01:59:56 -04:00
|
|
|
}
|