summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorVarun Patil <varunpatil@ucla.edu>2023-05-09 11:04:32 -0700
committerbackportbot-nextcloud[bot] <backportbot-nextcloud[bot]@users.noreply.github.com>2023-05-31 07:13:21 +0000
commit24875c02dbad1b413067e001f5f1a5945d4310ac (patch)
tree83fdc2c79ce924d1d46a195be0e1618016fde4be
parent5b137a24988b9439626b5d3228fc613776605057 (diff)
downloadnextcloud-server-24875c02dbad1b413067e001f5f1a5945d4310ac.tar.gz
nextcloud-server-24875c02dbad1b413067e001f5f1a5945d4310ac.zip
redis: move lua scripts to class and add type hints
Signed-off-by: Varun Patil <varunpatil@ucla.edu>
-rw-r--r--lib/private/Memcache/Redis.php40
-rw-r--r--tests/lib/Memcache/RedisTest.php4
2 files changed, 21 insertions, 23 deletions
diff --git a/lib/private/Memcache/Redis.php b/lib/private/Memcache/Redis.php
index 4c8151b9d6c..bde25a3385a 100644
--- a/lib/private/Memcache/Redis.php
+++ b/lib/private/Memcache/Redis.php
@@ -31,23 +31,23 @@ namespace OC\Memcache;
use OCP\IMemcacheTTL;
-/** name => [script, sha1] */
-const LUA_SCRIPTS = [
- 'dec' => [
- 'if redis.call("exists", KEYS[1]) == 1 then return redis.call("decrby", KEYS[1], ARGV[1]) else return "NEX" end',
- '720b40cb66cef1579f2ef16ec69b3da8c85510e9',
- ],
- 'cas' => [
- 'if redis.call("get", KEYS[1]) == ARGV[1] then redis.call("set", KEYS[1], ARGV[2]) return 1 else return 0 end',
- '94eac401502554c02b811e3199baddde62d976d4',
- ],
- 'cad' => [
- 'if redis.call("get", KEYS[1]) == ARGV[1] then return redis.call("del", KEYS[1]) else return 0 end',
- 'cf0e94b2e9ffc7e04395cf88f7583fc309985910',
- ],
-];
-
class Redis extends Cache implements IMemcacheTTL {
+ /** name => [script, sha1] */
+ public const LUA_SCRIPTS = [
+ 'dec' => [
+ 'if redis.call("exists", KEYS[1]) == 1 then return redis.call("decrby", KEYS[1], ARGV[1]) else return "NEX" end',
+ '720b40cb66cef1579f2ef16ec69b3da8c85510e9',
+ ],
+ 'cas' => [
+ 'if redis.call("get", KEYS[1]) == ARGV[1] then redis.call("set", KEYS[1], ARGV[2]) return 1 else return 0 end',
+ '94eac401502554c02b811e3199baddde62d976d4',
+ ],
+ 'cad' => [
+ 'if redis.call("get", KEYS[1]) == ARGV[1] then return redis.call("del", KEYS[1]) else return 0 end',
+ 'cf0e94b2e9ffc7e04395cf88f7583fc309985910',
+ ],
+ ];
+
/**
* @var \Redis|\RedisCluster $cache
*/
@@ -185,10 +185,10 @@ class Redis extends Cache implements IMemcacheTTL {
return \OC::$server->getGetRedisFactory()->isAvailable();
}
- protected function evalLua($scriptName, $keys, $args) {
+ protected function evalLua(string $scriptName, array $keys, array $args) {
$keys = array_map(fn ($key) => $this->getPrefix() . $key, $keys);
$args = array_merge($keys, $args);
- $script = LUA_SCRIPTS[$scriptName];
+ $script = self::LUA_SCRIPTS[$scriptName];
$result = $this->getCache()->evalSha($script[1], $args, count($keys));
if (false === $result) {
@@ -198,11 +198,11 @@ class Redis extends Cache implements IMemcacheTTL {
return $result;
}
- protected static function encodeValue($value) {
+ protected static function encodeValue(mixed $value): string {
return is_int($value) ? (string) $value : json_encode($value);
}
- protected static function decodeValue($value) {
+ protected static function decodeValue(string $value): mixed {
return is_numeric($value) ? (int) $value : json_decode($value, true);
}
}
diff --git a/tests/lib/Memcache/RedisTest.php b/tests/lib/Memcache/RedisTest.php
index 9e40698ec06..b94b69a5e6a 100644
--- a/tests/lib/Memcache/RedisTest.php
+++ b/tests/lib/Memcache/RedisTest.php
@@ -9,8 +9,6 @@
namespace Test\Memcache;
-use const OC\Memcache\LUA_SCRIPTS;
-
/**
* @group Memcache
* @group Redis
@@ -60,7 +58,7 @@ class RedisTest extends Cache {
}
public function testScriptHashes() {
- foreach (LUA_SCRIPTS as $script) {
+ foreach (\OC\Memcache\Redis::LUA_SCRIPTS as $script) {
$this->assertEquals(sha1($script[0]), $script[1]);
}
}