mirror of
https://github.com/nextcloud/server.git
synced 2024-12-28 07:58:42 +00:00
20dbb6c7e8
Signed-off-by: Robin Appelman <robin@icewind.nl>
93 lines
2.3 KiB
PHP
93 lines
2.3 KiB
PHP
<?php
|
|
|
|
/**
|
|
* SPDX-FileCopyrightText: 2016-2024 Nextcloud GmbH and Nextcloud contributors
|
|
* SPDX-FileCopyrightText: 2016 ownCloud, Inc.
|
|
* SPDX-License-Identifier: AGPL-3.0-only
|
|
*/
|
|
// use OCP namespace for all classes that are considered public.
|
|
// This means that they should be used by apps instead of the internal Nextcloud classes
|
|
|
|
namespace OCP;
|
|
|
|
/**
|
|
* This interface defines method for accessing the file based user cache.
|
|
*
|
|
* @since 8.1.0
|
|
*/
|
|
interface IMemcache extends ICache {
|
|
/**
|
|
* Set a value in the cache if it's not already stored
|
|
*
|
|
* @param string $key
|
|
* @param mixed $value
|
|
* @param int $ttl Time To Live in seconds. Defaults to 60*60*24
|
|
* @return bool
|
|
* @since 8.1.0
|
|
*/
|
|
public function add($key, $value, $ttl = 0);
|
|
|
|
/**
|
|
* Increase a stored number
|
|
*
|
|
* If no value is stored with the key, it will behave as if a 0 was stored.
|
|
* If a non-numeric value is stored, the operation will fail and `false` is returned.
|
|
*
|
|
* @param string $key
|
|
* @param int $step
|
|
* @return int | bool
|
|
* @since 8.1.0
|
|
*/
|
|
public function inc($key, $step = 1);
|
|
|
|
/**
|
|
* Decrease a stored number
|
|
*
|
|
* If no value is stored with the key, the operation will fail and `false` is returned.
|
|
* If a non-numeric value is stored, the operation will fail and `false` is returned.
|
|
*
|
|
* @param string $key
|
|
* @param int $step
|
|
* @return int | bool
|
|
* @since 8.1.0
|
|
*/
|
|
public function dec($key, $step = 1);
|
|
|
|
/**
|
|
* Compare and set
|
|
*
|
|
* Set $key to $new only if it's current value is $new
|
|
*
|
|
* @param string $key
|
|
* @param mixed $old
|
|
* @param mixed $new
|
|
* @return bool true if the value was successfully set or false if $key wasn't set to $old
|
|
* @since 8.1.0
|
|
*/
|
|
public function cas($key, $old, $new);
|
|
|
|
/**
|
|
* Compare and delete
|
|
*
|
|
* Delete $key if the stored value is equal to $old
|
|
*
|
|
* @param string $key
|
|
* @param mixed $old
|
|
* @return bool true if the value was successfully deleted or false if $key wasn't set to $old
|
|
* @since 8.1.0
|
|
*/
|
|
public function cad($key, $old);
|
|
|
|
/**
|
|
* Negative compare and delete
|
|
*
|
|
* Delete $key if the stored value is not equal to $old
|
|
*
|
|
* @param string $key
|
|
* @param mixed $old
|
|
* @return bool true if the value was successfully deleted or false if $key was set to $old or is not set
|
|
* @since 30.0.0
|
|
*/
|
|
public function ncad(string $key, mixed $old): bool;
|
|
}
|