diff options
Diffstat (limited to 'lib/public/IMemcache.php')
-rw-r--r-- | lib/public/IMemcache.php | 92 |
1 files changed, 92 insertions, 0 deletions
diff --git a/lib/public/IMemcache.php b/lib/public/IMemcache.php new file mode 100644 index 00000000000..991af1a8d4f --- /dev/null +++ b/lib/public/IMemcache.php @@ -0,0 +1,92 @@ +<?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; +} |