2018-07-04 17:37:22 -04:00
|
|
|
<?php
|
2020-02-09 09:45:36 -05:00
|
|
|
/**
|
|
|
|
* @copyright Copyright (C) 2020, Friendica
|
|
|
|
*
|
|
|
|
* @license GNU AGPL version 3 or any later version
|
|
|
|
*
|
|
|
|
* This program is free software: you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU Affero General Public License as
|
|
|
|
* published by the Free Software Foundation, either version 3 of the
|
|
|
|
* License, or (at your option) any later version.
|
|
|
|
*
|
|
|
|
* This program is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU Affero General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU Affero General Public License
|
|
|
|
* along with this program. If not, see <https://www.gnu.org/licenses/>.
|
|
|
|
*
|
|
|
|
*/
|
2018-07-04 17:37:22 -04:00
|
|
|
|
|
|
|
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 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
|
|
|
|
*/
|
2020-01-18 09:41:19 -05:00
|
|
|
public function add($key, $value, $ttl = Duration::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
|
|
|
|
*/
|
2020-01-18 09:41:19 -05:00
|
|
|
public function compareSet($key, $oldValue, $newValue, $ttl = Duration::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
|
|
|
}
|