<?php use JetBrains\PhpStorm\Deprecated; /** * Helper autocomplete for php redis extension * * @author Max Kamashev <max.kamashev@gmail.com> * @link https://github.com/ukko/phpredis-phpdoc */ class Redis { const AFTER = 'after'; const BEFORE = 'before'; /** * Options */ const OPT_SERIALIZER = 1; const OPT_PREFIX = 2; const OPT_READ_TIMEOUT = 3; const OPT_SCAN = 4; const OPT_FAILOVER = 5; const OPT_TCP_KEEPALIVE = 6; const OPT_COMPRESSION = 7; const OPT_REPLY_LITERAL = 8; const OPT_COMPRESSION_LEVEL = 9; /** * Cluster options */ const FAILOVER_NONE = 0; const FAILOVER_ERROR = 1; const FAILOVER_DISTRIBUTE = 2; const FAILOVER_DISTRIBUTE_SLAVES = 3; /** * SCAN options */ const SCAN_NORETRY = 0; const SCAN_RETRY = 1; /** * @since 5.3.0 */ const SCAN_PREFIX = 2; /** * @since 5.3.0 */ const SCAN_NOPREFIX = 3; /** * Serializers */ const SERIALIZER_NONE = 0; const SERIALIZER_PHP = 1; const SERIALIZER_IGBINARY = 2; const SERIALIZER_MSGPACK = 3; const SERIALIZER_JSON = 4; /** * Compressions */ const COMPRESSION_NONE = 0; const COMPRESSION_LZF = 1; const COMPRESSION_ZSTD = 2; const COMPRESSION_LZ4 = 3; /** * Compression ZSTD levels */ const COMPRESSION_ZSTD_MIN = 1; const COMPRESSION_ZSTD_DEFAULT = 3; const COMPRESSION_ZSTD_MAX = 22; /** * Multi */ const ATOMIC = 0; const MULTI = 1; const PIPELINE = 2; /** * Type */ const REDIS_NOT_FOUND = 0; const REDIS_STRING = 1; const REDIS_SET = 2; const REDIS_LIST = 3; const REDIS_ZSET = 4; const REDIS_HASH = 5; const REDIS_STREAM = 6; /** * Creates a Redis client * * @example $redis = new Redis(); */ public function __construct() { } /** * Connects to a Redis instance. * * @param string $host can be a host, or the path to a unix domain socket * @param int $port optional * @param float $timeout value in seconds (optional, default is 0.0 meaning unlimited) * @param null $reserved should be null if $retryInterval is specified * @param int $retryInterval retry interval in milliseconds. * @param float $readTimeout value in seconds (optional, default is 0 meaning unlimited) * @param array $connectionParameters extra config to send to redis * * @return bool TRUE on success, FALSE on error * * @example * <pre> * $redis->connect('127.0.0.1', 6379); * $redis->connect('127.0.0.1'); // port 6379 by default * $redis->connect('127.0.0.1', 6379, 2.5); // 2.5 sec timeout. * $redis->connect('/tmp/redis.sock'); // unix domain socket. * </pre> */ public function connect( $host, $port = 6379, $timeout = 0.0, $reserved = null, $retryInterval = 0, $readTimeout = 0.0, $connectionParameters = [] ) { } /** * Connects to a Redis instance. * * @param string $host can be a host, or the path to a unix domain socket * @param int $port optional * @param float $timeout value in seconds (optional, default is 0.0 meaning unlimited) * @param null $reserved should be null if $retry_interval is specified * @param int $retryInterval retry interval in milliseconds. * @param float $readTimeout value in seconds (optional, default is 0 meaning unlimited) * * @return bool TRUE on success, FALSE on error */ #[Deprecated(replacement: '%class%->connect(%parametersList%)')] public function open( $host, $port = 6379, $timeout = 0.0, $reserved = null, $retryInterval = 0, $readTimeout = 0.0 ) { } /** * A method to determine if a phpredis object thinks it's connected to a server * * @return bool Returns TRUE if phpredis thinks it's connected and FALSE if not */ public function isConnected() { } /** * Retrieve our host or unix socket that we're connected to * * @return string|false The host or unix socket we're connected to or FALSE if we're not connected */ public function getHost() { } /** * Get the port we're connected to * * @return int|false Returns the port we're connected to or FALSE if we're not connected */ public function getPort() { } /** * Get the database number phpredis is pointed to * * @return int|bool Returns the database number (int) phpredis thinks it's pointing to * or FALSE if we're not connected */ public function getDbNum() { } /** * Get the (write) timeout in use for phpredis * * @return float|false The timeout (DOUBLE) specified in our connect call or FALSE if we're not connected */ public function getTimeout() { } /** * Get the read timeout specified to phpredis or FALSE if we're not connected * * @return float|bool Returns the read timeout (which can be set using setOption and Redis::OPT_READ_TIMEOUT) * or FALSE if we're not connected */ public function getReadTimeout() { } /** * Gets the persistent ID that phpredis is using * * @return string|null|bool Returns the persistent id phpredis is using * (which will only be set if connected with pconnect), * NULL if we're not using a persistent ID, * and FALSE if we're not connected */ public function getPersistentID() { } /** * Get the password used to authenticate the phpredis connection * * @return string|null|bool Returns the password used to authenticate a phpredis session or NULL if none was used, * and FALSE if we're not connected */ public function getAuth() { } /** * Connects to a Redis instance or reuse a connection already established with pconnect/popen. * * The connection will not be closed on close or end of request until the php process ends. * So be patient on to many open FD's (specially on redis server side) when using persistent connections on * many servers connecting to one redis server. * * Also more than one persistent connection can be made identified by either host + port + timeout * or host + persistentId or unix socket + timeout. * * This feature is not available in threaded versions. pconnect and popen then working like their non persistent * equivalents. * * @param string $host can be a host, or the path to a unix domain socket * @param int $port optional * @param float $timeout value in seconds (optional, default is 0 meaning unlimited) * @param string $persistentId identity for the requested persistent connection * @param int $retryInterval retry interval in milliseconds. * @param float $readTimeout value in seconds (optional, default is 0 meaning unlimited) * * @return bool TRUE on success, FALSE on ertcnror. * * @example * <pre> * $redis->pconnect('127.0.0.1', 6379); * * // port 6379 by default - same connection like before * $redis->pconnect('127.0.0.1'); * * // 2.5 sec timeout and would be another connection than the two before. * $redis->pconnect('127.0.0.1', 6379, 2.5); * * // x is sent as persistent_id and would be another connection than the three before. * $redis->pconnect('127.0.0.1', 6379, 2.5, 'x'); * * // unix domain socket - would be another connection than the four before. * $redis->pconnect('/tmp/redis.sock'); * </pre> */ public function pconnect( $host, $port = 6379, $timeout = 0.0, $persistentId = null, $retryInterval = 0, $readTimeout = 0.0 ) { } /** * @param string $host * @param int $port * @param float $timeout * @param string $persistentId * @param int $retryInterval * @param float $readTimeout * * @return bool */ #[Deprecated(replacement: '%class%->pconnect(%parametersList%)')] public function popen( $host, $port = 6379, $timeout = 0.0, $persistentId = '', $retryInterval = 0, $readTimeout = 0.0 ) { } /** * Disconnects from the Redis instance. * * Note: Closing a persistent connection requires PhpRedis >= 4.2.0 * * @since >= 4.2 Closing a persistent connection requires PhpRedis * * @return bool TRUE on success, FALSE on error */ public function close() { } /** * Swap one Redis database with another atomically * * Note: Requires Redis >= 4.0.0 * * @param int $db1 * @param int $db2 * * @return bool TRUE on success and FALSE on failure * * @link https://redis.io/commands/swapdb * @since >= 4.0 * @example * <pre> * // Swaps DB 0 with DB 1 atomically * $redis->swapdb(0, 1); * </pre> */ public function swapdb(int $db1, int $db2) { } /** * Set client option * * @param int $option option name * @param mixed $value option value * * @return bool TRUE on success, FALSE on error * * @example * <pre> * $redis->setOption(Redis::OPT_SERIALIZER, Redis::SERIALIZER_NONE); // don't serialize data * $redis->setOption(Redis::OPT_SERIALIZER, Redis::SERIALIZER_PHP); // use built-in serialize/unserialize * $redis->setOption(Redis::OPT_SERIALIZER, Redis::SERIALIZER_IGBINARY); // use igBinary serialize/unserialize * $redis->setOption(Redis::OPT_SERIALIZER, Redis::SERIALIZER_MSGPACK); // Use msgpack serialize/unserialize * $redis->setOption(Redis::OPT_SERIALIZER, Redis::SERIALIZER_JSON); // Use json serialize/unserialize * * $redis->setOption(Redis::OPT_PREFIX, 'myAppName:'); // use custom prefix on all keys * * // Options for the SCAN family of commands, indicating whether to abstract * // empty results from the user. If set to SCAN_NORETRY (the default), phpredis * // will just issue one SCAN command at a time, sometimes returning an empty * // array of results. If set to SCAN_RETRY, phpredis will retry the scan command * // until keys come back OR Redis returns an iterator of zero * $redis->setOption(Redis::OPT_SCAN, Redis::SCAN_NORETRY); * $redis->setOption(Redis::OPT_SCAN, Redis::SCAN_RETRY); * </pre> */ public function setOption($option, $value) { } /** * Get client option * * @param int $option parameter name * * @return mixed|null Parameter value * * @see setOption() * @example * // return option value * $redis->getOption(Redis::OPT_SERIALIZER); */ public function getOption($option) { } /** * Check the current connection status * * @param string $message [optional] * * @return bool|string TRUE if the command is successful or returns message * Throws a RedisException object on connectivity error, as described above. * @throws RedisException * @link https://redis.io/commands/ping */ public function ping($message = null) { } /** * Echo the given string * * @param string $message * * @return string Returns message * * @link https://redis.io/commands/echo */ public function echo($message) { } /** * Get the value related to the specified key * * @param string $key * * @return string|mixed|false If key didn't exist, FALSE is returned. * Otherwise, the value related to this key is returned * * @link https://redis.io/commands/get * @example * <pre> * $redis->set('key', 'hello'); * $redis->get('key'); * * // set and get with serializer * $redis->setOption(Redis::OPT_SERIALIZER, Redis::SERIALIZER_JSON); * * $redis->set('key', ['asd' => 'as', 'dd' => 123, 'b' => true]); * var_dump($redis->get('key')); * // Output: * array(3) { * 'asd' => string(2) "as" * 'dd' => int(123) * 'b' => bool(true) * } * </pre> */ public function get($key) { } /** * Set the string value in argument as value of the key. * * @since If you're using Redis >= 2.6.12, you can pass extended options as explained in example * * @param string $key * @param string|mixed $value string if not used serializer * @param int|array $timeout [optional] Calling setex() is preferred if you want a timeout.<br> * Since 2.6.12 it also supports different flags inside an array. Example ['NX', 'EX' => 60]<br> * - EX seconds -- Set the specified expire time, in seconds.<br> * - PX milliseconds -- Set the specified expire time, in milliseconds.<br> * - NX -- Only set the key if it does not already exist.<br> * - XX -- Only set the key if it already exist.<br> * <pre> * // Simple key -> value set * $redis->set('key', 'value'); * * // Will redirect, and actually make an SETEX call * $redis->set('key','value', 10); * * // Will set the key, if it doesn't exist, with a ttl of 10 seconds * $redis->set('key', 'value', ['nx', 'ex' => 10]); * * // Will set a key, if it does exist, with a ttl of 1000 milliseconds * $redis->set('key', 'value', ['xx', 'px' => 1000]); * </pre> * * @return bool TRUE if the command is successful * * @link https://redis.io/commands/set */ public function set($key, $value, $timeout = null) { } /** * Set the string value in argument as value of the key, with a time to live. * * @param string $key * @param int $ttl * @param string|mixed $value * * @return bool TRUE if the command is successful * * @link https://redis.io/commands/setex * @example $redis->setex('key', 3600, 'value'); // sets key → value, with 1h TTL. */ public function setex($key, $ttl, $value) { } /** * Set the value and expiration in milliseconds of a key. * * @see setex() * @param string $key * @param int $ttl, in milliseconds. * @param string|mixed $value * * @return bool TRUE if the command is successful * * @link https://redis.io/commands/psetex * @example $redis->psetex('key', 1000, 'value'); // sets key → value, with 1sec TTL. */ public function psetex($key, $ttl, $value) { } /** * Set the string value in argument as value of the key if the key doesn't already exist in the database. * * @param string $key * @param string|mixed $value * * @return bool TRUE in case of success, FALSE in case of failure * * @link https://redis.io/commands/setnx * @example * <pre> * $redis->setnx('key', 'value'); // return TRUE * $redis->setnx('key', 'value'); // return FALSE * </pre> */ public function setnx($key, $value) { } /** * Remove specified keys. * * @param int|string|array $key1 An array of keys, or an undefined number of parameters, each a key: key1 key2 key3 ... keyN * @param int|string ...$otherKeys * * @return int Number of keys deleted * * @link https://redis.io/commands/del * @example * <pre> * $redis->set('key1', 'val1'); * $redis->set('key2', 'val2'); * $redis->set('key3', 'val3'); * $redis->set('key4', 'val4'); * * $redis->del('key1', 'key2'); // return 2 * $redis->del(['key3', 'key4']); // return 2 * </pre> */ public function del($key1, ...$otherKeys) { } /** * @param string|string[] $key1 * @param string $key2 * @param string $key3 * * @return int Number of keys deleted */ #[Deprecated(replacement: "%class%->del(%parametersList%)")] public function delete($key1, $key2 = null, $key3 = null) { } /** * Delete a key asynchronously in another thread. Otherwise it is just as DEL, but non blocking. * * @see del() * @param string|string[] $key1 * @param string $key2 * @param string $key3 * * @return int Number of keys unlinked. * * @link https://redis.io/commands/unlink * @example * <pre> * $redis->set('key1', 'val1'); * $redis->set('key2', 'val2'); * $redis->set('key3', 'val3'); * $redis->set('key4', 'val4'); * $redis->unlink('key1', 'key2'); // return 2 * $redis->unlink(array('key3', 'key4')); // return 2 * </pre> */ public function unlink($key1, $key2 = null, $key3 = null) { } /** * Enter and exit transactional mode. * * @param int $mode Redis::MULTI|Redis::PIPELINE * Defaults to Redis::MULTI. * A Redis::MULTI block of commands runs as a single transaction; * a Redis::PIPELINE block is simply transmitted faster to the server, but without any guarantee of atomicity. * discard cancels a transaction. * * @return static returns the Redis instance and enters multi-mode. * Once in multi-mode, all subsequent method calls return the same object until exec() is called. * * @link https://redis.io/commands/multi * @example * <pre> * $ret = $redis->multi() * ->set('key1', 'val1') * ->get('key1') * ->set('key2', 'val2') * ->get('key2') * ->exec(); * * //$ret == array ( * // 0 => TRUE, * // 1 => 'val1', * // 2 => TRUE, * // 3 => 'val2'); * </pre> */ public function multi($mode = Redis::MULTI) { } /** * Returns a Redis instance which can simply transmitted faster to the server. * * @return Redis returns the Redis instance. * Once in pipeline-mode, all subsequent method calls return the same object until exec() is called. * Pay attention, that Pipeline is not a transaction, so you can get unexpected * results in case of big pipelines and small read/write timeouts. * * @link https://redis.io/topics/pipelining * @example * <pre> * $ret = $this->redis->pipeline() * ->ping() * ->multi()->set('x', 42)->incr('x')->exec() * ->ping() * ->multi()->get('x')->del('x')->exec() * ->ping() * ->exec(); * * //$ret == array ( * // 0 => '+PONG', * // 1 => [TRUE, 43], * // 2 => '+PONG', * // 3 => [43, 1], * // 4 => '+PONG'); * </pre> */ public function pipeline() { } /** * @return void|array * * @see multi() * @link https://redis.io/commands/exec */ public function exec() { } /** * @see multi() * @link https://redis.io/commands/discard */ public function discard() { } /** * Watches a key for modifications by another client. If the key is modified between WATCH and EXEC, * the MULTI/EXEC transaction will fail (return FALSE). unwatch cancels all the watching of all keys by this client. * @param string|string[] $key a list of keys * * @return void * * @link https://redis.io/commands/watch * @example * <pre> * $redis->watch('x'); * // long code here during the execution of which other clients could well modify `x` * $ret = $redis->multi() * ->incr('x') * ->exec(); * // $ret = FALSE if x has been modified between the call to WATCH and the call to EXEC. * </pre> */ public function watch($key) { } /** * @see watch() * @link https://redis.io/commands/unwatch */ public function unwatch() { } /** * Subscribe to channels. * * Warning: this function will probably change in the future. * * @param string[] $channels an array of channels to subscribe * @param string|array $callback either a string or an array($instance, 'method_name'). * The callback function receives 3 parameters: the redis instance, the channel name, and the message. * * @return mixed|null Any non-null return value in the callback will be returned to the caller. * * @link https://redis.io/commands/subscribe * @example * <pre> * function f($redis, $chan, $msg) { * switch($chan) { * case 'chan-1': * ... * break; * * case 'chan-2': * ... * break; * * case 'chan-2': * ... * break; * } * } * * $redis->subscribe(array('chan-1', 'chan-2', 'chan-3'), 'f'); // subscribe to 3 chans * </pre> */ public function subscribe($channels, $callback) { } /** * Subscribe to channels by pattern * * @param array $patterns an array of glob-style patterns to subscribe * @param string|array $callback Either a string or an array with an object and method. * The callback will get four arguments ($redis, $pattern, $channel, $message) * @param mixed Any non-null return value in the callback will be returned to the caller * * @link https://redis.io/commands/psubscribe * @example * <pre> * function psubscribe($redis, $pattern, $chan, $msg) { * echo "Pattern: $pattern\n"; * echo "Channel: $chan\n"; * echo "Payload: $msg\n"; * } * </pre> */ public function psubscribe($patterns, $callback) { } /** * Publish messages to channels. * * Warning: this function will probably change in the future. * * @param string $channel a channel to publish to * @param string $message string * * @return int Number of clients that received the message * * @link https://redis.io/commands/publish * @example $redis->publish('chan-1', 'hello, world!'); // send message. */ public function publish($channel, $message) { } /** * A command allowing you to get information on the Redis pub/sub system * * @param string $keyword String, which can be: "channels", "numsub", or "numpat" * @param string|array $argument Optional, variant. * For the "channels" subcommand, you can pass a string pattern. * For "numsub" an array of channel names * * @return array|int Either an integer or an array. * - channels Returns an array where the members are the matching channels. * - numsub Returns a key/value array where the keys are channel names and * values are their counts. * - numpat Integer return containing the number active pattern subscriptions * * @link https://redis.io/commands/pubsub * @example * <pre> * $redis->pubsub('channels'); // All channels * $redis->pubsub('channels', '*pattern*'); // Just channels matching your pattern * $redis->pubsub('numsub', array('chan1', 'chan2')); // Get subscriber counts for 'chan1' and 'chan2' * $redis->pubsub('numpat'); // Get the number of pattern subscribers * </pre> */ public function pubsub($keyword, $argument) { } /** * Stop listening for messages posted to the given channels. * * @param array $channels an array of channels to usubscribe * * @link https://redis.io/commands/unsubscribe */ public function unsubscribe($channels = null) { } /** * Stop listening for messages posted to the given channels. * * @param array $patterns an array of glob-style patterns to unsubscribe * * @link https://redis.io/commands/punsubscribe */ public function punsubscribe($patterns = null) { } /** * Verify if the specified key/keys exists * * This function took a single argument and returned TRUE or FALSE in phpredis versions < 4.0.0. * * @since >= 4.0 Returned int, if < 4.0 returned bool * * @param string|string[] $key * * @return int|bool The number of keys tested that do exist * * @link https://redis.io/commands/exists * @link https://github.com/phpredis/phpredis#exists * @example * <pre> * $redis->exists('key'); // 1 * $redis->exists('NonExistingKey'); // 0 * * $redis->mset(['foo' => 'foo', 'bar' => 'bar', 'baz' => 'baz']); * $redis->exists(['foo', 'bar', 'baz]); // 3 * $redis->exists('foo', 'bar', 'baz'); // 3 * </pre> */ public function exists($key) { } /** * Increment the number stored at key by one. * * @param string $key * * @return int the new value * * @link https://redis.io/commands/incr * @example * <pre> * $redis->incr('key1'); // key1 didn't exists, set to 0 before the increment and now has the value 1 * $redis->incr('key1'); // 2 * $redis->incr('key1'); // 3 * $redis->incr('key1'); // 4 * </pre> */ public function incr($key) { } /** * Increment the float value of a key by the given amount * * @param string $key * @param float $increment * * @return float * * @link https://redis.io/commands/incrbyfloat * @example * <pre> * $redis->set('x', 3); * $redis->incrByFloat('x', 1.5); // float(4.5) * $redis->get('x'); // float(4.5) * </pre> */ public function incrByFloat($key, $increment) { } /** * Increment the number stored at key by one. * If the second argument is filled, it will be used as the integer value of the increment. * * @param string $key key * @param int $value value that will be added to key (only for incrBy) * * @return int the new value * * @link https://redis.io/commands/incrby * @example * <pre> * $redis->incr('key1'); // key1 didn't exists, set to 0 before the increment and now has the value 1 * $redis->incr('key1'); // 2 * $redis->incr('key1'); // 3 * $redis->incr('key1'); // 4 * $redis->incrBy('key1', 10); // 14 * </pre> */ public function incrBy($key, $value) { } /** * Decrement the number stored at key by one. * * @param string $key * * @return int the new value * * @link https://redis.io/commands/decr * @example * <pre> * $redis->decr('key1'); // key1 didn't exists, set to 0 before the increment and now has the value -1 * $redis->decr('key1'); // -2 * $redis->decr('key1'); // -3 * </pre> */ public function decr($key) { } /** * Decrement the number stored at key by one. * If the second argument is filled, it will be used as the integer value of the decrement. * * @param string $key * @param int $value that will be subtracted to key (only for decrBy) * * @return int the new value * * @link https://redis.io/commands/decrby * @example * <pre> * $redis->decr('key1'); // key1 didn't exists, set to 0 before the increment and now has the value -1 * $redis->decr('key1'); // -2 * $redis->decr('key1'); // -3 * $redis->decrBy('key1', 10); // -13 * </pre> */ public function decrBy($key, $value) { } /** * Adds the string values to the head (left) of the list. * Creates the list if the key didn't exist. * If the key exists and is not a list, FALSE is returned. * * @param string $key * @param string|mixed ...$value1 Variadic list of values to push in key, if dont used serialized, used string * * @return int|false The new length of the list in case of success, FALSE in case of Failure * * @link https://redis.io/commands/lpush * @example * <pre> * $redis->lPush('l', 'v1', 'v2', 'v3', 'v4') // int(4) * var_dump( $redis->lRange('l', 0, -1) ); * // Output: * // array(4) { * // [0]=> string(2) "v4" * // [1]=> string(2) "v3" * // [2]=> string(2) "v2" * // [3]=> string(2) "v1" * // } * </pre> */ public function lPush($key, ...$value1) { } /** * Adds the string values to the tail (right) of the list. * Creates the list if the key didn't exist. * If the key exists and is not a list, FALSE is returned. * * @param string $key * @param string|mixed ...$value1 Variadic list of values to push in key, if dont used serialized, used string * * @return int|false The new length of the list in case of success, FALSE in case of Failure * * @link https://redis.io/commands/rpush * @example * <pre> * $redis->rPush('l', 'v1', 'v2', 'v3', 'v4'); // int(4) * var_dump( $redis->lRange('l', 0, -1) ); * // Output: * // array(4) { * // [0]=> string(2) "v1" * // [1]=> string(2) "v2" * // [2]=> string(2) "v3" * // [3]=> string(2) "v4" * // } * </pre> */ public function rPush($key, ...$value1) { } /** * Adds the string value to the head (left) of the list if the list exists. * * @param string $key * @param string|mixed $value String, value to push in key * * @return int|false The new length of the list in case of success, FALSE in case of Failure. * * @link https://redis.io/commands/lpushx * @example * <pre> * $redis->del('key1'); * $redis->lPushx('key1', 'A'); // returns 0 * $redis->lPush('key1', 'A'); // returns 1 * $redis->lPushx('key1', 'B'); // returns 2 * $redis->lPushx('key1', 'C'); // returns 3 * // key1 now points to the following list: [ 'A', 'B', 'C' ] * </pre> */ public function lPushx($key, $value) { } /** * Adds the string value to the tail (right) of the list if the ist exists. FALSE in case of Failure. * * @param string $key * @param string|mixed $value String, value to push in key * * @return int|false The new length of the list in case of success, FALSE in case of Failure. * * @link https://redis.io/commands/rpushx * @example * <pre> * $redis->del('key1'); * $redis->rPushx('key1', 'A'); // returns 0 * $redis->rPush('key1', 'A'); // returns 1 * $redis->rPushx('key1', 'B'); // returns 2 * $redis->rPushx('key1', 'C'); // returns 3 * // key1 now points to the following list: [ 'A', 'B', 'C' ] * </pre> */ public function rPushx($key, $value) { } /** * Returns and removes the first element of the list. * * @param string $key * * @return mixed|bool if command executed successfully BOOL FALSE in case of failure (empty list) * * @link https://redis.io/commands/lpop * @example * <pre> * $redis->rPush('key1', 'A'); * $redis->rPush('key1', 'B'); * $redis->rPush('key1', 'C'); // key1 => [ 'A', 'B', 'C' ] * $redis->lPop('key1'); // key1 => [ 'B', 'C' ] * </pre> */ public function lPop($key) { } /** * Returns and removes the last element of the list. * * @param string $key * * @return mixed|bool if command executed successfully BOOL FALSE in case of failure (empty list) * * @link https://redis.io/commands/rpop * @example * <pre> * $redis->rPush('key1', 'A'); * $redis->rPush('key1', 'B'); * $redis->rPush('key1', 'C'); // key1 => [ 'A', 'B', 'C' ] * $redis->rPop('key1'); // key1 => [ 'A', 'B' ] * </pre> */ public function rPop($key) { } /** * Is a blocking lPop primitive. If at least one of the lists contains at least one element, * the element will be popped from the head of the list and returned to the caller. * Il all the list identified by the keys passed in arguments are empty, blPop will block * during the specified timeout until an element is pushed to one of those lists. This element will be popped. * * @param string|string[] $keys String array containing the keys of the lists OR variadic list of strings * @param int $timeout Timeout is always the required final parameter * * @return array ['listName', 'element'] * * @link https://redis.io/commands/blpop * @example * <pre> * // Non blocking feature * $redis->lPush('key1', 'A'); * $redis->del('key2'); * * $redis->blPop('key1', 'key2', 10); // array('key1', 'A') * // OR * $redis->blPop(['key1', 'key2'], 10); // array('key1', 'A') * * $redis->brPop('key1', 'key2', 10); // array('key1', 'A') * // OR * $redis->brPop(['key1', 'key2'], 10); // array('key1', 'A') * * // Blocking feature * * // process 1 * $redis->del('key1'); * $redis->blPop('key1', 10); * // blocking for 10 seconds * * // process 2 * $redis->lPush('key1', 'A'); * * // process 1 * // array('key1', 'A') is returned * </pre> */ public function blPop($keys, $timeout) { } /** * Is a blocking rPop primitive. If at least one of the lists contains at least one element, * the element will be popped from the head of the list and returned to the caller. * Il all the list identified by the keys passed in arguments are empty, brPop will * block during the specified timeout until an element is pushed to one of those lists. T * his element will be popped. * * @param string|string[] $keys String array containing the keys of the lists OR variadic list of strings * @param int $timeout Timeout is always the required final parameter * * @return array ['listName', 'element'] * * @link https://redis.io/commands/brpop * @example * <pre> * // Non blocking feature * $redis->lPush('key1', 'A'); * $redis->del('key2'); * * $redis->blPop('key1', 'key2', 10); // array('key1', 'A') * // OR * $redis->blPop(array('key1', 'key2'), 10); // array('key1', 'A') * * $redis->brPop('key1', 'key2', 10); // array('key1', 'A') * // OR * $redis->brPop(array('key1', 'key2'), 10); // array('key1', 'A') * * // Blocking feature * * // process 1 * $redis->del('key1'); * $redis->blPop('key1', 10); * // blocking for 10 seconds * * // process 2 * $redis->lPush('key1', 'A'); * * // process 1 * // array('key1', 'A') is returned * </pre> */ public function brPop(array $keys, $timeout) { } /** * Returns the size of a list identified by Key. If the list didn't exist or is empty, * the command returns 0. If the data type identified by Key is not a list, the command return FALSE. * * @param string $key * * @return int|bool The size of the list identified by Key exists. * bool FALSE if the data type identified by Key is not list * * @link https://redis.io/commands/llen * @example * <pre> * $redis->rPush('key1', 'A'); * $redis->rPush('key1', 'B'); * $redis->rPush('key1', 'C'); // key1 => [ 'A', 'B', 'C' ] * $redis->lLen('key1'); // 3 * $redis->rPop('key1'); * $redis->lLen('key1'); // 2 * </pre> */ public function lLen($key) { } /** * @link https://redis.io/commands/llen * * @param string $key * * @return int The size of the list identified by Key exists */ #[Deprecated(replacement: '%class%->lLen(%parametersList%)')] public function lSize($key) { } /** * Return the specified element of the list stored at the specified key. * 0 the first element, 1 the second ... -1 the last element, -2 the penultimate ... * Return FALSE in case of a bad index or a key that doesn't point to a list. * * @param string $key * @param int $index * * @return mixed|bool the element at this index * * Bool FALSE if the key identifies a non-string data type, or no value corresponds to this index in the list Key. * * @link https://redis.io/commands/lindex * @example * <pre> * $redis->rPush('key1', 'A'); * $redis->rPush('key1', 'B'); * $redis->rPush('key1', 'C'); // key1 => [ 'A', 'B', 'C' ] * $redis->lIndex('key1', 0); // 'A' * $redis->lIndex('key1', -1); // 'C' * $redis->lIndex('key1', 10); // `FALSE` * </pre> */ public function lIndex($key, $index) { } /** * @link https://redis.io/commands/lindex * * @param string $key * @param int $index * @return mixed|bool the element at this index */ #[Deprecated(replacement: '%class%->lIndex(%parametersList%)')] public function lGet($key, $index) { } /** * Set the list at index with the new value. * * @param string $key * @param int $index * @param string $value * * @return bool TRUE if the new value is setted. * FALSE if the index is out of range, or data type identified by key is not a list. * * @link https://redis.io/commands/lset * @example * <pre> * $redis->rPush('key1', 'A'); * $redis->rPush('key1', 'B'); * $redis->rPush('key1', 'C'); // key1 => [ 'A', 'B', 'C' ] * $redis->lIndex('key1', 0); // 'A' * $redis->lSet('key1', 0, 'X'); * $redis->lIndex('key1', 0); // 'X' * </pre> */ public function lSet($key, $index, $value) { } /** * Returns the specified elements of the list stored at the specified key in * the range [start, end]. start and stop are interpretated as indices: 0 the first element, * 1 the second ... -1 the last element, -2 the penultimate ... * * @param string $key * @param int $start * @param int $end * * @return array containing the values in specified range. * * @link https://redis.io/commands/lrange * @example * <pre> * $redis->rPush('key1', 'A'); * $redis->rPush('key1', 'B'); * $redis->rPush('key1', 'C'); * $redis->lRange('key1', 0, -1); // array('A', 'B', 'C') * </pre> */ public function lRange($key, $start, $end) { } /** * @link https://redis.io/commands/lrange * * @param string $key * @param int $start * @param int $end * @return array */ #[Deprecated(replacement: '%class%->lRange(%parametersList%)')] public function lGetRange($key, $start, $end) { } /** * Trims an existing list so that it will contain only a specified range of elements. * * @param string $key * @param int $start * @param int $stop * * @return array|false Bool return FALSE if the key identify a non-list value * * @link https://redis.io/commands/ltrim * @example * <pre> * $redis->rPush('key1', 'A'); * $redis->rPush('key1', 'B'); * $redis->rPush('key1', 'C'); * $redis->lRange('key1', 0, -1); // array('A', 'B', 'C') * $redis->lTrim('key1', 0, 1); * $redis->lRange('key1', 0, -1); // array('A', 'B') * </pre> */ public function lTrim($key, $start, $stop) { } /** * @link https://redis.io/commands/ltrim * * @param string $key * @param int $start * @param int $stop */ #[Deprecated(replacement: '%class%->lTrim(%parametersList%)')] public function listTrim($key, $start, $stop) { } /** * Removes the first count occurrences of the value element from the list. * If count is zero, all the matching elements are removed. If count is negative, * elements are removed from tail to head. * * @param string $key * @param string $value * @param int $count * * @return int|bool the number of elements to remove * bool FALSE if the value identified by key is not a list. * * @link https://redis.io/commands/lrem * @example * <pre> * $redis->lPush('key1', 'A'); * $redis->lPush('key1', 'B'); * $redis->lPush('key1', 'C'); * $redis->lPush('key1', 'A'); * $redis->lPush('key1', 'A'); * * $redis->lRange('key1', 0, -1); // array('A', 'A', 'C', 'B', 'A') * $redis->lRem('key1', 'A', 2); // 2 * $redis->lRange('key1', 0, -1); // array('C', 'B', 'A') * </pre> */ public function lRem($key, $value, $count) { } /** * @link https://redis.io/commands/lremove * * @param string $key * @param string $value * @param int $count */ #[Deprecated(replacement: '%class%->lRem(%parametersList%)')] public function lRemove($key, $value, $count) { } /** * Insert value in the list before or after the pivot value. the parameter options * specify the position of the insert (before or after). If the list didn't exists, * or the pivot didn't exists, the value is not inserted. * * @param string $key * @param int $position Redis::BEFORE | Redis::AFTER * @param string $pivot * @param string|mixed $value * * @return int The number of the elements in the list, -1 if the pivot didn't exists. * * @link https://redis.io/commands/linsert * @example * <pre> * $redis->del('key1'); * $redis->lInsert('key1', Redis::AFTER, 'A', 'X'); // 0 * * $redis->lPush('key1', 'A'); * $redis->lPush('key1', 'B'); * $redis->lPush('key1', 'C'); * * $redis->lInsert('key1', Redis::BEFORE, 'C', 'X'); // 4 * $redis->lRange('key1', 0, -1); // array('A', 'B', 'X', 'C') * * $redis->lInsert('key1', Redis::AFTER, 'C', 'Y'); // 5 * $redis->lRange('key1', 0, -1); // array('A', 'B', 'X', 'C', 'Y') * * $redis->lInsert('key1', Redis::AFTER, 'W', 'value'); // -1 * </pre> */ public function lInsert($key, $position, $pivot, $value) { } /** * Adds a values to the set value stored at key. * * @param string $key Required key * @param string|mixed ...$value1 Variadic list of values * * @return int|bool The number of elements added to the set. * If this value is already in the set, FALSE is returned * * @link https://redis.io/commands/sadd * @example * <pre> * $redis->sAdd('k', 'v1'); // int(1) * $redis->sAdd('k', 'v1', 'v2', 'v3'); // int(2) * </pre> */ public function sAdd($key, ...$value1) { } /** * Removes the specified members from the set value stored at key. * * @param string $key * @param string|mixed ...$member1 Variadic list of members * * @return int The number of elements removed from the set * * @link https://redis.io/commands/srem * @example * <pre> * var_dump( $redis->sAdd('k', 'v1', 'v2', 'v3') ); // int(3) * var_dump( $redis->sRem('k', 'v2', 'v3') ); // int(2) * var_dump( $redis->sMembers('k') ); * //// Output: * // array(1) { * // [0]=> string(2) "v1" * // } * </pre> */ public function sRem($key, ...$member1) { } /** * @link https://redis.io/commands/srem * * @param string $key * @param string|mixed ...$member1 */ #[Deprecated(replacement: '%class%->sRem(%parametersList%)')] public function sRemove($key, ...$member1) { } /** * Moves the specified member from the set at srcKey to the set at dstKey. * * @param string $srcKey * @param string $dstKey * @param string|mixed $member * * @return bool If the operation is successful, return TRUE. * If the srcKey and/or dstKey didn't exist, and/or the member didn't exist in srcKey, FALSE is returned. * * @link https://redis.io/commands/smove * @example * <pre> * $redis->sAdd('key1' , 'set11'); * $redis->sAdd('key1' , 'set12'); * $redis->sAdd('key1' , 'set13'); // 'key1' => {'set11', 'set12', 'set13'} * $redis->sAdd('key2' , 'set21'); * $redis->sAdd('key2' , 'set22'); // 'key2' => {'set21', 'set22'} * $redis->sMove('key1', 'key2', 'set13'); // 'key1' => {'set11', 'set12'} * // 'key2' => {'set21', 'set22', 'set13'} * </pre> */ public function sMove($srcKey, $dstKey, $member) { } /** * Checks if value is a member of the set stored at the key key. * * @param string $key * @param string|mixed $value * * @return bool TRUE if value is a member of the set at key key, FALSE otherwise * * @link https://redis.io/commands/sismember * @example * <pre> * $redis->sAdd('key1' , 'set1'); * $redis->sAdd('key1' , 'set2'); * $redis->sAdd('key1' , 'set3'); // 'key1' => {'set1', 'set2', 'set3'} * * $redis->sIsMember('key1', 'set1'); // TRUE * $redis->sIsMember('key1', 'setX'); // FALSE * </pre> */ public function sIsMember($key, $value) { } /** * @link https://redis.io/commands/sismember * * @param string $key * @param string|mixed $value */ #[Deprecated(replacement: '%class%->sIsMember(%parametersList%)')] public function sContains($key, $value) { } /** * Returns the cardinality of the set identified by key. * * @param string $key * * @return int the cardinality of the set identified by key, 0 if the set doesn't exist. * * @link https://redis.io/commands/scard * @example * <pre> * $redis->sAdd('key1' , 'set1'); * $redis->sAdd('key1' , 'set2'); * $redis->sAdd('key1' , 'set3'); // 'key1' => {'set1', 'set2', 'set3'} * $redis->sCard('key1'); // 3 * $redis->sCard('keyX'); // 0 * </pre> */ public function sCard($key) { } /** * Removes and returns a random element from the set value at Key. * * @param string $key * @param int $count [optional] * * @return string|mixed|array|bool "popped" values * bool FALSE if set identified by key is empty or doesn't exist. * * @link https://redis.io/commands/spop * @example * <pre> * $redis->sAdd('key1' , 'set1'); * $redis->sAdd('key1' , 'set2'); * $redis->sAdd('key1' , 'set3'); // 'key1' => {'set3', 'set1', 'set2'} * $redis->sPop('key1'); // 'set1', 'key1' => {'set3', 'set2'} * $redis->sPop('key1'); // 'set3', 'key1' => {'set2'} * * // With count * $redis->sAdd('key2', 'set1', 'set2', 'set3'); * var_dump( $redis->sPop('key2', 3) ); // Will return all members but in no particular order * * // array(3) { * // [0]=> string(4) "set2" * // [1]=> string(4) "set3" * // [2]=> string(4) "set1" * // } * </pre> */ public function sPop($key, $count = 1) { } /** * Returns a random element(s) from the set value at Key, without removing it. * * @param string $key * @param int $count [optional] * * @return string|mixed|array|bool value(s) from the set * bool FALSE if set identified by key is empty or doesn't exist and count argument isn't passed. * * @link https://redis.io/commands/srandmember * @example * <pre> * $redis->sAdd('key1' , 'one'); * $redis->sAdd('key1' , 'two'); * $redis->sAdd('key1' , 'three'); // 'key1' => {'one', 'two', 'three'} * * var_dump( $redis->sRandMember('key1') ); // 'key1' => {'one', 'two', 'three'} * * // string(5) "three" * * var_dump( $redis->sRandMember('key1', 2) ); // 'key1' => {'one', 'two', 'three'} * * // array(2) { * // [0]=> string(2) "one" * // [1]=> string(5) "three" * // } * </pre> */ public function sRandMember($key, $count = 1) { } /** * Returns the members of a set resulting from the intersection of all the sets * held at the specified keys. If just a single key is specified, then this command * produces the members of this set. If one of the keys is missing, FALSE is returned. * * @param string $key1 keys identifying the different sets on which we will apply the intersection. * @param string ...$otherKeys variadic list of keys * * @return array|false contain the result of the intersection between those keys * If the intersection between the different sets is empty, the return value will be empty array. * * @link https://redis.io/commands/sinter * @example * <pre> * $redis->sAdd('key1', 'val1'); * $redis->sAdd('key1', 'val2'); * $redis->sAdd('key1', 'val3'); * $redis->sAdd('key1', 'val4'); * * $redis->sAdd('key2', 'val3'); * $redis->sAdd('key2', 'val4'); * * $redis->sAdd('key3', 'val3'); * $redis->sAdd('key3', 'val4'); * * var_dump($redis->sInter('key1', 'key2', 'key3')); * * //array(2) { * // [0]=> * // string(4) "val4" * // [1]=> * // string(4) "val3" * //} * </pre> */ public function sInter($key1, ...$otherKeys) { } /** * Performs a sInter command and stores the result in a new set. * * @param string $dstKey the key to store the diff into. * @param string $key1 keys identifying the different sets on which we will apply the intersection. * @param string ...$otherKeys variadic list of keys * * @return int|false The cardinality of the resulting set, or FALSE in case of a missing key * * @link https://redis.io/commands/sinterstore * @example * <pre> * $redis->sAdd('key1', 'val1'); * $redis->sAdd('key1', 'val2'); * $redis->sAdd('key1', 'val3'); * $redis->sAdd('key1', 'val4'); * * $redis->sAdd('key2', 'val3'); * $redis->sAdd('key2', 'val4'); * * $redis->sAdd('key3', 'val3'); * $redis->sAdd('key3', 'val4'); * * var_dump($redis->sInterStore('output', 'key1', 'key2', 'key3')); * var_dump($redis->sMembers('output')); * * //int(2) * // * //array(2) { * // [0]=> * // string(4) "val4" * // [1]=> * // string(4) "val3" * //} * </pre> */ public function sInterStore($dstKey, $key1, ...$otherKeys) { } /** * Performs the union between N sets and returns it. * * @param string $key1 first key for union * @param string ...$otherKeys variadic list of keys corresponding to sets in redis * * @return array string[] The union of all these sets * * @link https://redis.io/commands/sunionstore * @example * <pre> * $redis->sAdd('s0', '1'); * $redis->sAdd('s0', '2'); * $redis->sAdd('s1', '3'); * $redis->sAdd('s1', '1'); * $redis->sAdd('s2', '3'); * $redis->sAdd('s2', '4'); * * var_dump($redis->sUnion('s0', 's1', 's2')); * * array(4) { * // [0]=> * // string(1) "3" * // [1]=> * // string(1) "4" * // [2]=> * // string(1) "1" * // [3]=> * // string(1) "2" * //} * </pre> */ public function sUnion($key1, ...$otherKeys) { } /** * Performs the same action as sUnion, but stores the result in the first key * * @param string $dstKey the key to store the diff into. * @param string $key1 first key for union * @param string ...$otherKeys variadic list of keys corresponding to sets in redis * * @return int Any number of keys corresponding to sets in redis * * @link https://redis.io/commands/sunionstore * @example * <pre> * $redis->del('s0', 's1', 's2'); * * $redis->sAdd('s0', '1'); * $redis->sAdd('s0', '2'); * $redis->sAdd('s1', '3'); * $redis->sAdd('s1', '1'); * $redis->sAdd('s2', '3'); * $redis->sAdd('s2', '4'); * * var_dump($redis->sUnionStore('dst', 's0', 's1', 's2')); * var_dump($redis->sMembers('dst')); * * //int(4) * //array(4) { * // [0]=> * // string(1) "3" * // [1]=> * // string(1) "4" * // [2]=> * // string(1) "1" * // [3]=> * // string(1) "2" * //} * </pre> */ public function sUnionStore($dstKey, $key1, ...$otherKeys) { } /** * Performs the difference between N sets and returns it. * * @param string $key1 first key for diff * @param string ...$otherKeys variadic list of keys corresponding to sets in redis * * @return array string[] The difference of the first set will all the others * * @link https://redis.io/commands/sdiff * @example * <pre> * $redis->del('s0', 's1', 's2'); * * $redis->sAdd('s0', '1'); * $redis->sAdd('s0', '2'); * $redis->sAdd('s0', '3'); * $redis->sAdd('s0', '4'); * * $redis->sAdd('s1', '1'); * $redis->sAdd('s2', '3'); * * var_dump($redis->sDiff('s0', 's1', 's2')); * * //array(2) { * // [0]=> * // string(1) "4" * // [1]=> * // string(1) "2" * //} * </pre> */ public function sDiff($key1, ...$otherKeys) { } /** * Performs the same action as sDiff, but stores the result in the first key * * @param string $dstKey the key to store the diff into. * @param string $key1 first key for diff * @param string ...$otherKeys variadic list of keys corresponding to sets in redis * * @return int|false The cardinality of the resulting set, or FALSE in case of a missing key * * @link https://redis.io/commands/sdiffstore * @example * <pre> * $redis->del('s0', 's1', 's2'); * * $redis->sAdd('s0', '1'); * $redis->sAdd('s0', '2'); * $redis->sAdd('s0', '3'); * $redis->sAdd('s0', '4'); * * $redis->sAdd('s1', '1'); * $redis->sAdd('s2', '3'); * * var_dump($redis->sDiffStore('dst', 's0', 's1', 's2')); * var_dump($redis->sMembers('dst')); * * //int(2) * //array(2) { * // [0]=> * // string(1) "4" * // [1]=> * // string(1) "2" * //} * </pre> */ public function sDiffStore($dstKey, $key1, ...$otherKeys) { } /** * Returns the contents of a set. * * @param string $key * * @return array An array of elements, the contents of the set * * @link https://redis.io/commands/smembers * @example * <pre> * $redis->del('s'); * $redis->sAdd('s', 'a'); * $redis->sAdd('s', 'b'); * $redis->sAdd('s', 'a'); * $redis->sAdd('s', 'c'); * var_dump($redis->sMembers('s')); * * //array(3) { * // [0]=> * // string(1) "c" * // [1]=> * // string(1) "a" * // [2]=> * // string(1) "b" * //} * // The order is random and corresponds to redis' own internal representation of the set structure. * </pre> */ public function sMembers($key) { } /** * @link https://redis.io/commands/smembers * * @param string $key * @return array An array of elements, the contents of the set */ #[Deprecated(replacement: '%class%->sMembers(%parametersList%)')] public function sGetMembers($key) { } /** * Scan a set for members * * @param string $key The set to search. * @param int &$iterator LONG (reference) to the iterator as we go. * @param string $pattern String, optional pattern to match against. * @param int $count How many members to return at a time (Redis might return a different amount) * * @return array|false PHPRedis will return an array of keys or FALSE when we're done iterating * * @link https://redis.io/commands/sscan * @example * <pre> * $iterator = null; * while ($members = $redis->sScan('set', $iterator)) { * foreach ($members as $member) { * echo $member . PHP_EOL; * } * } * </pre> */ public function sScan($key, &$iterator, $pattern = null, $count = 0) { } /** * Sets a value and returns the previous entry at that key. * * @param string $key * @param string|mixed $value * * @return string|mixed A string (mixed, if used serializer), the previous value located at this key * * @link https://redis.io/commands/getset * @example * <pre> * $redis->set('x', '42'); * $exValue = $redis->getSet('x', 'lol'); // return '42', replaces x by 'lol' * $newValue = $redis->get('x')' // return 'lol' * </pre> */ public function getSet($key, $value) { } /** * Returns a random key * * @return string an existing key in redis * * @link https://redis.io/commands/randomkey * @example * <pre> * $key = $redis->randomKey(); * $surprise = $redis->get($key); // who knows what's in there. * </pre> */ public function randomKey() { } /** * Switches to a given database * * @param int $dbIndex * * @return bool TRUE in case of success, FALSE in case of failure * * @link https://redis.io/commands/select * @example * <pre> * $redis->select(0); // switch to DB 0 * $redis->set('x', '42'); // write 42 to x * $redis->move('x', 1); // move to DB 1 * $redis->select(1); // switch to DB 1 * $redis->get('x'); // will return 42 * </pre> */ public function select($dbIndex) { } /** * Moves a key to a different database. * * @param string $key * @param int $dbIndex * * @return bool TRUE in case of success, FALSE in case of failure * * @link https://redis.io/commands/move * @example * <pre> * $redis->select(0); // switch to DB 0 * $redis->set('x', '42'); // write 42 to x * $redis->move('x', 1); // move to DB 1 * $redis->select(1); // switch to DB 1 * $redis->get('x'); // will return 42 * </pre> */ public function move($key, $dbIndex) { } /** * Renames a key * * @param string $srcKey * @param string $dstKey * * @return bool TRUE in case of success, FALSE in case of failure * * @link https://redis.io/commands/rename * @example * <pre> * $redis->set('x', '42'); * $redis->rename('x', 'y'); * $redis->get('y'); // → 42 * $redis->get('x'); // → `FALSE` * </pre> */ public function rename($srcKey, $dstKey) { } /** * @link https://redis.io/commands/rename * * @param string $srcKey * @param string $dstKey */ #[Deprecated(replacement: '%class%->rename(%parametersList%)')] public function renameKey($srcKey, $dstKey) { } /** * Renames a key * * Same as rename, but will not replace a key if the destination already exists. * This is the same behaviour as setNx. * * @param string $srcKey * @param string $dstKey * * @return bool TRUE in case of success, FALSE in case of failure * * @link https://redis.io/commands/renamenx * @example * <pre> * $redis->set('x', '42'); * $redis->rename('x', 'y'); * $redis->get('y'); // → 42 * $redis->get('x'); // → `FALSE` * </pre> */ public function renameNx($srcKey, $dstKey) { } /** * Sets an expiration date (a timeout) on an item * * @param string $key The key that will disappear * @param int $ttl The key's remaining Time To Live, in seconds * * @return bool TRUE in case of success, FALSE in case of failure * * @link https://redis.io/commands/expire * @example * <pre> * $redis->set('x', '42'); * $redis->expire('x', 3); // x will disappear in 3 seconds. * sleep(5); // wait 5 seconds * $redis->get('x'); // will return `FALSE`, as 'x' has expired. * </pre> */ public function expire($key, $ttl) { } /** * Sets an expiration date (a timeout in milliseconds) on an item * * @param string $key The key that will disappear. * @param int $ttl The key's remaining Time To Live, in milliseconds * * @return bool TRUE in case of success, FALSE in case of failure * * @link https://redis.io/commands/pexpire * @example * <pre> * $redis->set('x', '42'); * $redis->pExpire('x', 11500); // x will disappear in 11500 milliseconds. * $redis->ttl('x'); // 12 * $redis->pttl('x'); // 11500 * </pre> */ public function pExpire($key, $ttl) { } /** * @link https://redis.io/commands/expire * * @param string $key * @param int $ttl * @return bool */ #[Deprecated(replacement: '%class%->expire(%parametersList%)')] public function setTimeout($key, $ttl) { } /** * Sets an expiration date (a timestamp) on an item. * * @param string $key The key that will disappear. * @param int $timestamp Unix timestamp. The key's date of death, in seconds from Epoch time. * * @return bool TRUE in case of success, FALSE in case of failure * * @link https://redis.io/commands/expireat * @example * <pre> * $redis->set('x', '42'); * $now = time(NULL); // current timestamp * $redis->expireAt('x', $now + 3); // x will disappear in 3 seconds. * sleep(5); // wait 5 seconds * $redis->get('x'); // will return `FALSE`, as 'x' has expired. * </pre> */ public function expireAt($key, $timestamp) { } /** * Sets an expiration date (a timestamp) on an item. Requires a timestamp in milliseconds * * @param string $key The key that will disappear * @param int $timestamp Unix timestamp. The key's date of death, in seconds from Epoch time * * @return bool TRUE in case of success, FALSE in case of failure * * @link https://redis.io/commands/pexpireat * @example * <pre> * $redis->set('x', '42'); * $redis->pExpireAt('x', 1555555555005); * echo $redis->ttl('x'); // 218270121 * echo $redis->pttl('x'); // 218270120575 * </pre> */ public function pExpireAt($key, $timestamp) { } /** * Returns the keys that match a certain pattern. * * @param string $pattern pattern, using '*' as a wildcard * * @return string[]|false The keys that match a certain pattern. * * @link https://redis.io/commands/keys * @example * <pre> * $allKeys = $redis->keys('*'); // all keys will match this. * $keyWithUserPrefix = $redis->keys('user*'); * </pre> */ public function keys($pattern) { } /** * @param string $pattern * @link https://redis.io/commands/keys */ #[Deprecated(replacement: '%class%->keys(%parametersList%)')] public function getKeys($pattern) { } /** * Returns the current database's size * * @return int DB size, in number of keys * * @link https://redis.io/commands/dbsize * @example * <pre> * $count = $redis->dbSize(); * echo "Redis has $count keys\n"; * </pre> */ public function dbSize() { } /** * Authenticate the connection using a password. * Warning: The password is sent in plain-text over the network. * * @param string|string[] $password * * @return bool TRUE if the connection is authenticated, FALSE otherwise * * @link https://redis.io/commands/auth * @example $redis->auth('foobared'); */ public function auth($password) { } /** * Starts the background rewrite of AOF (Append-Only File) * * @return bool TRUE in case of success, FALSE in case of failure * * @link https://redis.io/commands/bgrewriteaof * @example $redis->bgrewriteaof(); */ public function bgrewriteaof() { } /** * Changes the slave status * Either host and port, or no parameter to stop being a slave. * * @param string $host [optional] * @param int $port [optional] * * @return bool TRUE in case of success, FALSE in case of failure * * @link https://redis.io/commands/slaveof * @example * <pre> * $redis->slaveof('10.0.1.7', 6379); * // ... * $redis->slaveof(); * </pre> */ public function slaveof($host = '127.0.0.1', $port = 6379) { } /** * Access the Redis slowLog * * @param string $operation This can be either GET, LEN, or RESET * @param int|null $length If executing a SLOWLOG GET command, you can pass an optional length. * * @return mixed The return value of SLOWLOG will depend on which operation was performed. * - SLOWLOG GET: Array of slowLog entries, as provided by Redis * - SLOGLOG LEN: Integer, the length of the slowLog * - SLOWLOG RESET: Boolean, depending on success * * @example * <pre> * // Get ten slowLog entries * $redis->slowLog('get', 10); * // Get the default number of slowLog entries * * $redis->slowLog('get'); * // Reset our slowLog * $redis->slowLog('reset'); * * // Retrieve slowLog length * $redis->slowLog('len'); * </pre> * * @link https://redis.io/commands/slowlog */ public function slowLog(string $operation, int $length = null) { } /** * Describes the object pointed to by a key. * The information to retrieve (string) and the key (string). * Info can be one of the following: * - "encoding" * - "refcount" * - "idletime" * * @param string $string * @param string $key * * @return string|int|false for "encoding", int for "refcount" and "idletime", FALSE if the key doesn't exist. * * @link https://redis.io/commands/object * @example * <pre> * $redis->lPush('l', 'Hello, world!'); * $redis->object("encoding", "l"); // → ziplist * $redis->object("refcount", "l"); // → 1 * $redis->object("idletime", "l"); // → 400 (in seconds, with a precision of 10 seconds). * </pre> */ public function object($string = '', $key = '') { } /** * Performs a synchronous save. * * @return bool TRUE in case of success, FALSE in case of failure * If a save is already running, this command will fail and return FALSE. * * @link https://redis.io/commands/save * @example $redis->save(); */ public function save() { } /** * Performs a background save. * * @return bool TRUE in case of success, FALSE in case of failure * If a save is already running, this command will fail and return FALSE * * @link https://redis.io/commands/bgsave * @example $redis->bgSave(); */ public function bgsave() { } /** * Returns the timestamp of the last disk save. * * @return int timestamp * * @link https://redis.io/commands/lastsave * @example $redis->lastSave(); */ public function lastSave() { } /** * Blocks the current client until all the previous write commands are successfully transferred and * acknowledged by at least the specified number of slaves. * * @param int $numSlaves Number of slaves that need to acknowledge previous write commands. * @param int $timeout Timeout in milliseconds. * * @return int The command returns the number of slaves reached by all the writes performed in the * context of the current connection * * @link https://redis.io/commands/wait * @example $redis->wait(2, 1000); */ public function wait($numSlaves, $timeout) { } /** * Returns the type of data pointed by a given key. * * @param string $key * * @return int * Depending on the type of the data pointed by the key, * this method will return the following value: * - string: Redis::REDIS_STRING * - set: Redis::REDIS_SET * - list: Redis::REDIS_LIST * - zset: Redis::REDIS_ZSET * - hash: Redis::REDIS_HASH * - other: Redis::REDIS_NOT_FOUND * * @link https://redis.io/commands/type * @example $redis->type('key'); */ public function type($key) { } /** * Append specified string to the string stored in specified key. * * @param string $key * @param string|mixed $value * * @return int Size of the value after the append * * @link https://redis.io/commands/append * @example * <pre> * $redis->set('key', 'value1'); * $redis->append('key', 'value2'); // 12 * $redis->get('key'); // 'value1value2' * </pre> */ public function append($key, $value) { } /** * Return a substring of a larger string * * @param string $key * @param int $start * @param int $end * * @return string the substring * * @link https://redis.io/commands/getrange * @example * <pre> * $redis->set('key', 'string value'); * $redis->getRange('key', 0, 5); // 'string' * $redis->getRange('key', -5, -1); // 'value' * </pre> */ public function getRange($key, $start, $end) { } /** * Return a substring of a larger string * * @param string $key * @param int $start * @param int $end */ #[Deprecated] public function substr($key, $start, $end) { } /** * Changes a substring of a larger string. * * @param string $key * @param int $offset * @param string $value * * @return int the length of the string after it was modified * * @link https://redis.io/commands/setrange * @example * <pre> * $redis->set('key', 'Hello world'); * $redis->setRange('key', 6, "redis"); // returns 11 * $redis->get('key'); // "Hello redis" * </pre> */ public function setRange($key, $offset, $value) { } /** * Get the length of a string value. * * @param string $key * @return int * * @link https://redis.io/commands/strlen * @example * <pre> * $redis->set('key', 'value'); * $redis->strlen('key'); // 5 * </pre> */ public function strlen($key) { } /** * Return the position of the first bit set to 1 or 0 in a string. The position is returned, thinking of the * string as an array of bits from left to right, where the first byte's most significant bit is at position 0, * the second byte's most significant bit is at position 8, and so forth. * * @param string $key * @param int $bit * @param int $start * @param int $end * * @return int The command returns the position of the first bit set to 1 or 0 according to the request. * If we look for set bits (the bit argument is 1) and the string is empty or composed of just * zero bytes, -1 is returned. If we look for clear bits (the bit argument is 0) and the string * only contains bit set to 1, the function returns the first bit not part of the string on the * right. So if the string is three bytes set to the value 0xff the command BITPOS key 0 will * return 24, since up to bit 23 all the bits are 1. Basically, the function considers the right * of the string as padded with zeros if you look for clear bits and specify no range or the * start argument only. However, this behavior changes if you are looking for clear bits and * specify a range with both start and end. If no clear bit is found in the specified range, the * function returns -1 as the user specified a clear range and there are no 0 bits in that range. * * @link https://redis.io/commands/bitpos * @example * <pre> * $redis->set('key', '\xff\xff'); * $redis->bitpos('key', 1); // int(0) * $redis->bitpos('key', 1, 1); // int(8) * $redis->bitpos('key', 1, 3); // int(-1) * $redis->bitpos('key', 0); // int(16) * $redis->bitpos('key', 0, 1); // int(16) * $redis->bitpos('key', 0, 1, 5); // int(-1) * </pre> */ public function bitpos($key, $bit, $start = 0, $end = null) { } /** * Return a single bit out of a larger string * * @param string $key * @param int $offset * * @return int the bit value (0 or 1) * * @link https://redis.io/commands/getbit * @example * <pre> * $redis->set('key', "\x7f"); // this is 0111 1111 * $redis->getBit('key', 0); // 0 * $redis->getBit('key', 1); // 1 * </pre> */ public function getBit($key, $offset) { } /** * Changes a single bit of a string. * * @param string $key * @param int $offset * @param bool|int $value bool or int (1 or 0) * * @return int 0 or 1, the value of the bit before it was set * * @link https://redis.io/commands/setbit * @example * <pre> * $redis->set('key', "*"); // ord("*") = 42 = 0x2f = "0010 1010" * $redis->setBit('key', 5, 1); // returns 0 * $redis->setBit('key', 7, 1); // returns 0 * $redis->get('key'); // chr(0x2f) = "/" = b("0010 1111") * </pre> */ public function setBit($key, $offset, $value) { } /** * Count bits in a string * * @param string $key * * @return int The number of bits set to 1 in the value behind the input key * * @link https://redis.io/commands/bitcount * @example * <pre> * $redis->set('bit', '345'); // // 11 0011 0011 0100 0011 0101 * var_dump( $redis->bitCount('bit', 0, 0) ); // int(4) * var_dump( $redis->bitCount('bit', 1, 1) ); // int(3) * var_dump( $redis->bitCount('bit', 2, 2) ); // int(4) * var_dump( $redis->bitCount('bit', 0, 2) ); // int(11) * </pre> */ public function bitCount($key) { } /** * Bitwise operation on multiple keys. * * @param string $operation either "AND", "OR", "NOT", "XOR" * @param string $retKey return key * @param string $key1 first key * @param string ...$otherKeys variadic list of keys * * @return int The size of the string stored in the destination key * * @link https://redis.io/commands/bitop * @example * <pre> * $redis->set('bit1', '1'); // 11 0001 * $redis->set('bit2', '2'); // 11 0010 * * $redis->bitOp('AND', 'bit', 'bit1', 'bit2'); // bit = 110000 * $redis->bitOp('OR', 'bit', 'bit1', 'bit2'); // bit = 110011 * $redis->bitOp('NOT', 'bit', 'bit1', 'bit2'); // bit = 110011 * $redis->bitOp('XOR', 'bit', 'bit1', 'bit2'); // bit = 11 * </pre> */ public function bitOp($operation, $retKey, $key1, ...$otherKeys) { } /** * Removes all entries from the current database. * * @return bool Always TRUE * @link https://redis.io/commands/flushdb * @example $redis->flushDB(); */ public function flushDB() { } /** * Removes all entries from all databases. * * @return bool Always TRUE * * @link https://redis.io/commands/flushall * @example $redis->flushAll(); */ public function flushAll() { } /** * Sort * * @param string $key * @param array $option array(key => value, ...) - optional, with the following keys and values: * - 'by' => 'some_pattern_*', * - 'limit' => array(0, 1), * - 'get' => 'some_other_pattern_*' or an array of patterns, * - 'sort' => 'asc' or 'desc', * - 'alpha' => TRUE, * - 'store' => 'external-key' * * @return array * An array of values, or a number corresponding to the number of elements stored if that was used * * @link https://redis.io/commands/sort * @example * <pre> * $redis->del('s'); * $redis->sadd('s', 5); * $redis->sadd('s', 4); * $redis->sadd('s', 2); * $redis->sadd('s', 1); * $redis->sadd('s', 3); * * var_dump($redis->sort('s')); // 1,2,3,4,5 * var_dump($redis->sort('s', array('sort' => 'desc'))); // 5,4,3,2,1 * var_dump($redis->sort('s', array('sort' => 'desc', 'store' => 'out'))); // (int)5 * </pre> */ public function sort($key, $option = null) { } /** * Returns an associative array of strings and integers * * @param string $option Optional. The option to provide redis. * SERVER | CLIENTS | MEMORY | PERSISTENCE | STATS | REPLICATION | CPU | CLASTER | KEYSPACE | COMANDSTATS * * Returns an associative array of strings and integers, with the following keys: * - redis_version * - redis_git_sha1 * - redis_git_dirty * - arch_bits * - multiplexing_api * - process_id * - uptime_in_seconds * - uptime_in_days * - lru_clock * - used_cpu_sys * - used_cpu_user * - used_cpu_sys_children * - used_cpu_user_children * - connected_clients * - connected_slaves * - client_longest_output_list * - client_biggest_input_buf * - blocked_clients * - used_memory * - used_memory_human * - used_memory_peak * - used_memory_peak_human * - mem_fragmentation_ratio * - mem_allocator * - loading * - aof_enabled * - changes_since_last_save * - bgsave_in_progress * - last_save_time * - total_connections_received * - total_commands_processed * - expired_keys * - evicted_keys * - keyspace_hits * - keyspace_misses * - hash_max_zipmap_entries * - hash_max_zipmap_value * - pubsub_channels * - pubsub_patterns * - latest_fork_usec * - vm_enabled * - role * * @return array * * @link https://redis.io/commands/info * @example * <pre> * $redis->info(); * * or * * $redis->info("COMMANDSTATS"); //Information on the commands that have been run (>=2.6 only) * $redis->info("CPU"); // just CPU information from Redis INFO * </pre> */ public function info($option = null) { } /** * Resets the statistics reported by Redis using the INFO command (`info()` function). * These are the counters that are reset: * - Keyspace hits * - Keyspace misses * - Number of commands processed * - Number of connections received * - Number of expired keys * * @return bool `TRUE` in case of success, `FALSE` in case of failure. * * @example $redis->resetStat(); * @link https://redis.io/commands/config-resetstat */ public function resetStat() { } /** * Returns the time to live left for a given key, in seconds. If the key doesn't exist, FALSE is returned. * * @param string $key * * @return int|bool the time left to live in seconds * * @link https://redis.io/commands/ttl * @example * <pre> * $redis->setex('key', 123, 'test'); * $redis->ttl('key'); // int(123) * </pre> */ public function ttl($key) { } /** * Returns a time to live left for a given key, in milliseconds. * * If the key doesn't exist, FALSE is returned. * * @param string $key * * @return int|bool the time left to live in milliseconds * * @link https://redis.io/commands/pttl * @example * <pre> * $redis->setex('key', 123, 'test'); * $redis->pttl('key'); // int(122999) * </pre> */ public function pttl($key) { } /** * Remove the expiration timer from a key. * * @param string $key * * @return bool TRUE if a timeout was removed, FALSE if the key didn’t exist or didn’t have an expiration timer. * * @link https://redis.io/commands/persist * @example $redis->persist('key'); */ public function persist($key) { } /** * Sets multiple key-value pairs in one atomic command. * MSETNX only returns TRUE if all the keys were set (see SETNX). * * @param array $array Pairs: array(key => value, ...) * * @return bool TRUE in case of success, FALSE in case of failure * * @link https://redis.io/commands/mset * @example * <pre> * $redis->mset(array('key0' => 'value0', 'key1' => 'value1')); * var_dump($redis->get('key0')); * var_dump($redis->get('key1')); * // Output: * // string(6) "value0" * // string(6) "value1" * </pre> */ public function mset(array $array) { } /** * Get the values of all the specified keys. * If one or more keys dont exist, the array will contain FALSE at the position of the key. * * @param array $keys Array containing the list of the keys * * @return array Array containing the values related to keys in argument * * @example * <pre> * $redis->set('key1', 'value1'); * $redis->set('key2', 'value2'); * $redis->set('key3', 'value3'); * $redis->getMultiple(array('key1', 'key2', 'key3')); // array('value1', 'value2', 'value3'); * $redis->getMultiple(array('key0', 'key1', 'key5')); // array(`FALSE`, 'value2', `FALSE`); * </pre> */ #[Deprecated(replacement: '%class%->mGet(%parametersList%)')] public function getMultiple(array $keys) { } /** * Returns the values of all specified keys. * * For every key that does not hold a string value or does not exist, * the special value false is returned. Because of this, the operation never fails. * * @param array $array * * @return array * * @link https://redis.io/commands/mget * @example * <pre> * $redis->del('x', 'y', 'z', 'h'); // remove x y z * $redis->mset(array('x' => 'a', 'y' => 'b', 'z' => 'c')); * $redis->hset('h', 'field', 'value'); * var_dump($redis->mget(array('x', 'y', 'z', 'h'))); * // Output: * // array(3) { * // [0]=> string(1) "a" * // [1]=> string(1) "b" * // [2]=> string(1) "c" * // [3]=> bool(false) * // } * </pre> */ public function mget(array $array) { } /** * @see mset() * @param array $array * @return int 1 (if the keys were set) or 0 (no key was set) * * @link https://redis.io/commands/msetnx */ public function msetnx(array $array) { } /** * Pops a value from the tail of a list, and pushes it to the front of another list. * Also return this value. * * @since redis >= 1.1 * * @param string $srcKey * @param string $dstKey * * @return string|mixed|false The element that was moved in case of success, FALSE in case of failure. * * @link https://redis.io/commands/rpoplpush * @example * <pre> * $redis->del('x', 'y'); * * $redis->lPush('x', 'abc'); * $redis->lPush('x', 'def'); * $redis->lPush('y', '123'); * $redis->lPush('y', '456'); * * // move the last of x to the front of y. * var_dump($redis->rpoplpush('x', 'y')); * var_dump($redis->lRange('x', 0, -1)); * var_dump($redis->lRange('y', 0, -1)); * * //Output: * // * //string(3) "abc" * //array(1) { * // [0]=> * // string(3) "def" * //} * //array(3) { * // [0]=> * // string(3) "abc" * // [1]=> * // string(3) "456" * // [2]=> * // string(3) "123" * //} * </pre> */ public function rpoplpush($srcKey, $dstKey) { } /** * A blocking version of rpoplpush, with an integral timeout in the third parameter. * * @param string $srcKey * @param string $dstKey * @param int $timeout * * @return string|mixed|bool The element that was moved in case of success, FALSE in case of timeout * * @link https://redis.io/commands/brpoplpush */ public function brpoplpush($srcKey, $dstKey, $timeout) { } /** * Adds the specified member with a given score to the sorted set stored at key * * @param string $key Required key * @param array|float $options Options if needed or score if omitted * @param float|string|mixed $score1 Required score or value if options omitted * @param string|float|mixed $value1 Required value or optional score if options omitted * @param float|string|mixed $score2 Optional score or value if options omitted * @param string|float|mixed $value2 Optional value or score if options omitted * @param float|string|mixed $scoreN Optional score or value if options omitted * @param string|float|mixed $valueN Optional value or score if options omitted * * @return int Number of values added * * @link https://redis.io/commands/zadd * @example * <pre> * $redis->zAdd('z', 1, 'v1', 2, 'v2', 3, 'v3', 4, 'v4' ); // int(2) * $redis->zRem('z', 'v2', 'v3'); // int(2) * $redis->zAdd('z', ['NX'], 5, 'v5'); // int(1) * $redis->zAdd('z', ['NX'], 6, 'v5'); // int(0) * $redis->zAdd('z', 7, 'v6'); // int(1) * $redis->zAdd('z', 8, 'v6'); // int(0) * * var_dump( $redis->zRange('z', 0, -1) ); * // Output: * // array(4) { * // [0]=> string(2) "v1" * // [1]=> string(2) "v4" * // [2]=> string(2) "v5" * // [3]=> string(2) "v8" * // } * * var_dump( $redis->zRange('z', 0, -1, true) ); * // Output: * // array(4) { * // ["v1"]=> float(1) * // ["v4"]=> float(4) * // ["v5"]=> float(5) * // ["v6"]=> float(8) * </pre> */ public function zAdd($key, $options, $score1, $value1 = null, $score2 = null, $value2 = null, $scoreN = null, $valueN = null) { } /** * Returns a range of elements from the ordered set stored at the specified key, * with values in the range [start, end]. start and stop are interpreted as zero-based indices: * 0 the first element, * 1 the second ... * -1 the last element, * -2 the penultimate ... * * @param string $key * @param int $start * @param int $end * @param bool $withscores * * @return array Array containing the values in specified range. * * @link https://redis.io/commands/zrange * @example * <pre> * $redis->zAdd('key1', 0, 'val0'); * $redis->zAdd('key1', 2, 'val2'); * $redis->zAdd('key1', 10, 'val10'); * $redis->zRange('key1', 0, -1); // array('val0', 'val2', 'val10') * // with scores * $redis->zRange('key1', 0, -1, true); // array('val0' => 0, 'val2' => 2, 'val10' => 10) * </pre> */ public function zRange($key, $start, $end, $withscores = null) { } /** * Deletes a specified member from the ordered set. * * @param string $key * @param string|mixed $member1 * @param string|mixed ...$otherMembers * * @return int Number of deleted values * * @link https://redis.io/commands/zrem * @example * <pre> * $redis->zAdd('z', 1, 'v1', 2, 'v2', 3, 'v3', 4, 'v4' ); // int(2) * $redis->zRem('z', 'v2', 'v3'); // int(2) * var_dump( $redis->zRange('z', 0, -1) ); * //// Output: * // array(2) { * // [0]=> string(2) "v1" * // [1]=> string(2) "v4" * // } * </pre> */ public function zRem($key, $member1, ...$otherMembers) { } /** * @link https://redis.io/commands/zrem * * @param string $key * @param string|mixed $member1 * @param string|mixed ...$otherMembers * * @return int Number of deleted values */ #[Deprecated(replacement: '%class%->zRem(%parametersList%)')] public function zDelete($key, $member1, ...$otherMembers) { } /** * Returns the elements of the sorted set stored at the specified key in the range [start, end] * in reverse order. start and stop are interpretated as zero-based indices: * 0 the first element, * 1 the second ... * -1 the last element, * -2 the penultimate ... * * @param string $key * @param int $start * @param int $end * @param bool $withscore * * @return array Array containing the values in specified range. * * @link https://redis.io/commands/zrevrange * @example * <pre> * $redis->zAdd('key', 0, 'val0'); * $redis->zAdd('key', 2, 'val2'); * $redis->zAdd('key', 10, 'val10'); * $redis->zRevRange('key', 0, -1); // array('val10', 'val2', 'val0') * * // with scores * $redis->zRevRange('key', 0, -1, true); // array('val10' => 10, 'val2' => 2, 'val0' => 0) * </pre> */ public function zRevRange($key, $start, $end, $withscore = null) { } /** * Returns the elements of the sorted set stored at the specified key which have scores in the * range [start,end]. Adding a parenthesis before start or end excludes it from the range. * +inf and -inf are also valid limits. * * zRevRangeByScore returns the same items in reverse order, when the start and end parameters are swapped. * * @param string $key * @param int $start * @param int $end * @param array $options Two options are available: * - withscores => TRUE, * - and limit => array($offset, $count) * * @return array Array containing the values in specified range. * * @link https://redis.io/commands/zrangebyscore * @example * <pre> * $redis->zAdd('key', 0, 'val0'); * $redis->zAdd('key', 2, 'val2'); * $redis->zAdd('key', 10, 'val10'); * $redis->zRangeByScore('key', 0, 3); // array('val0', 'val2') * $redis->zRangeByScore('key', 0, 3, array('withscores' => TRUE); // array('val0' => 0, 'val2' => 2) * $redis->zRangeByScore('key', 0, 3, array('limit' => array(1, 1)); // array('val2') * $redis->zRangeByScore('key', 0, 3, array('withscores' => TRUE, 'limit' => array(1, 1)); // array('val2' => 2) * </pre> */ public function zRangeByScore($key, $start, $end, array $options = array()) { } /** * @see zRangeByScore() * @param string $key * @param int $start * @param int $end * @param array $options * * @return array */ public function zRevRangeByScore($key, $start, $end, array $options = array()) { } /** * Returns a lexigraphical range of members in a sorted set, assuming the members have the same score. The * min and max values are required to start with '(' (exclusive), '[' (inclusive), or be exactly the values * '-' (negative inf) or '+' (positive inf). The command must be called with either three *or* five * arguments or will return FALSE. * * @param string $key The ZSET you wish to run against. * @param int $min The minimum alphanumeric value you wish to get. * @param int $max The maximum alphanumeric value you wish to get. * @param int $offset Optional argument if you wish to start somewhere other than the first element. * @param int $limit Optional argument if you wish to limit the number of elements returned. * * @return array|false Array containing the values in the specified range. * * @link https://redis.io/commands/zrangebylex * @example * <pre> * foreach (array('a', 'b', 'c', 'd', 'e', 'f', 'g') as $char) { * $redis->zAdd('key', $char); * } * * $redis->zRangeByLex('key', '-', '[c'); // array('a', 'b', 'c') * $redis->zRangeByLex('key', '-', '(c'); // array('a', 'b') * $redis->zRangeByLex('key', '-', '[c'); // array('b', 'c') * </pre> */ public function zRangeByLex($key, $min, $max, $offset = null, $limit = null) { } /** * @see zRangeByLex() * @param string $key * @param int $min * @param int $max * @param int $offset * @param int $limit * * @return array * * @link https://redis.io/commands/zrevrangebylex */ public function zRevRangeByLex($key, $min, $max, $offset = null, $limit = null) { } /** * Returns the number of elements of the sorted set stored at the specified key which have * scores in the range [start,end]. Adding a parenthesis before start or end excludes it * from the range. +inf and -inf are also valid limits. * * @param string $key * @param string $start * @param string $end * * @return int the size of a corresponding zRangeByScore * * @link https://redis.io/commands/zcount * @example * <pre> * $redis->zAdd('key', 0, 'val0'); * $redis->zAdd('key', 2, 'val2'); * $redis->zAdd('key', 10, 'val10'); * $redis->zCount('key', 0, 3); // 2, corresponding to array('val0', 'val2') * </pre> */ public function zCount($key, $start, $end) { } /** * Deletes the elements of the sorted set stored at the specified key which have scores in the range [start,end]. * * @param string $key * @param float|string $start double or "+inf" or "-inf" string * @param float|string $end double or "+inf" or "-inf" string * * @return int The number of values deleted from the sorted set * * @link https://redis.io/commands/zremrangebyscore * @example * <pre> * $redis->zAdd('key', 0, 'val0'); * $redis->zAdd('key', 2, 'val2'); * $redis->zAdd('key', 10, 'val10'); * $redis->zRemRangeByScore('key', 0, 3); // 2 * </pre> */ public function zRemRangeByScore($key, $start, $end) { } /** * @param string $key * @param float $start * @param float $end */ #[Deprecated(replacement: '%class%->zRemRangeByScore(%parametersList%)')] public function zDeleteRangeByScore($key, $start, $end) { } /** * Deletes the elements of the sorted set stored at the specified key which have rank in the range [start,end]. * * @param string $key * @param int $start * @param int $end * * @return int The number of values deleted from the sorted set * * @link https://redis.io/commands/zremrangebyrank * @example * <pre> * $redis->zAdd('key', 1, 'one'); * $redis->zAdd('key', 2, 'two'); * $redis->zAdd('key', 3, 'three'); * $redis->zRemRangeByRank('key', 0, 1); // 2 * $redis->zRange('key', 0, -1, array('withscores' => TRUE)); // array('three' => 3) * </pre> */ public function zRemRangeByRank($key, $start, $end) { } /** * @link https://redis.io/commands/zremrangebyscore * * @param string $key * @param int $start * @param int $end */ #[Deprecated(replacement: '%class%->zRemRangeByRank(%parametersList%)')] public function zDeleteRangeByRank($key, $start, $end) { } /** * Returns the cardinality of an ordered set. * * @param string $key * * @return int the set's cardinality * * @link https://redis.io/commands/zsize * @example * <pre> * $redis->zAdd('key', 0, 'val0'); * $redis->zAdd('key', 2, 'val2'); * $redis->zAdd('key', 10, 'val10'); * $redis->zCard('key'); // 3 * </pre> */ public function zCard($key) { } /** * @param string $key * @return int */ #[Deprecated(replacement: '%class%->zCard(%parametersList%)')] public function zSize($key) { } /** * Returns the score of a given member in the specified sorted set. * * @param string $key * @param string|mixed $member * * @return float|bool false if member or key not exists * * @link https://redis.io/commands/zscore * @example * <pre> * $redis->zAdd('key', 2.5, 'val2'); * $redis->zScore('key', 'val2'); // 2.5 * </pre> */ public function zScore($key, $member) { } /** * Returns the rank of a given member in the specified sorted set, starting at 0 for the item * with the smallest score. zRevRank starts at 0 for the item with the largest score. * * @param string $key * @param string|mixed $member * * @return int|false the item's score, or false if key or member is not exists * * @link https://redis.io/commands/zrank * @example * <pre> * $redis->del('z'); * $redis->zAdd('key', 1, 'one'); * $redis->zAdd('key', 2, 'two'); * $redis->zRank('key', 'one'); // 0 * $redis->zRank('key', 'two'); // 1 * $redis->zRevRank('key', 'one'); // 1 * $redis->zRevRank('key', 'two'); // 0 * </pre> */ public function zRank($key, $member) { } /** * @see zRank() * @param string $key * @param string|mixed $member * * @return int|false the item's score, false - if key or member is not exists * * @link https://redis.io/commands/zrevrank */ public function zRevRank($key, $member) { } /** * Increments the score of a member from a sorted set by a given amount. * * @param string $key * @param float $value (double) value that will be added to the member's score * @param string $member * * @return float the new value * * @link https://redis.io/commands/zincrby * @example * <pre> * $redis->del('key'); * $redis->zIncrBy('key', 2.5, 'member1'); // key or member1 didn't exist, so member1's score is to 0 * // before the increment and now has the value 2.5 * $redis->zIncrBy('key', 1, 'member1'); // 3.5 * </pre> */ public function zIncrBy($key, $value, $member) { } /** * Creates an union of sorted sets given in second argument. * The result of the union will be stored in the sorted set defined by the first argument. * The third optionnel argument defines weights to apply to the sorted sets in input. * In this case, the weights will be multiplied by the score of each element in the sorted set * before applying the aggregation. The forth argument defines the AGGREGATE option which * specify how the results of the union are aggregated. * * @param string $output * @param array $zSetKeys * @param null|array $weights * @param string $aggregateFunction Either "SUM", "MIN", or "MAX": defines the behaviour to use on * duplicate entries during the zUnionStore * * @return int The number of values in the new sorted set * * @link https://redis.io/commands/zunionstore * @example * <pre> * $redis->del('k1'); * $redis->del('k2'); * $redis->del('k3'); * $redis->del('ko1'); * $redis->del('ko2'); * $redis->del('ko3'); * * $redis->zAdd('k1', 0, 'val0'); * $redis->zAdd('k1', 1, 'val1'); * * $redis->zAdd('k2', 2, 'val2'); * $redis->zAdd('k2', 3, 'val3'); * * $redis->zUnionStore('ko1', array('k1', 'k2')); // 4, 'ko1' => array('val0', 'val1', 'val2', 'val3') * * // Weighted zUnionStore * $redis->zUnionStore('ko2', array('k1', 'k2'), array(1, 1)); // 4, 'ko2' => array('val0', 'val1', 'val2', 'val3') * $redis->zUnionStore('ko3', array('k1', 'k2'), array(5, 1)); // 4, 'ko3' => array('val0', 'val2', 'val3', 'val1') * </pre> */ public function zUnionStore($output, $zSetKeys, ?array $weights = null, $aggregateFunction = 'SUM') { } /** * @param string $Output * @param array $ZSetKeys * @param array|null $Weights * @param string $aggregateFunction */ #[Deprecated(replacement: '%class%->zUnionStore(%parametersList%)')] public function zUnion($Output, $ZSetKeys, array $Weights = null, $aggregateFunction = 'SUM') { } /** * Creates an intersection of sorted sets given in second argument. * The result of the union will be stored in the sorted set defined by the first argument. * The third optional argument defines weights to apply to the sorted sets in input. * In this case, the weights will be multiplied by the score of each element in the sorted set * before applying the aggregation. The forth argument defines the AGGREGATE option which * specify how the results of the union are aggregated. * * @param string $output * @param array $zSetKeys * @param null|array $weights * @param string $aggregateFunction Either "SUM", "MIN", or "MAX": * defines the behaviour to use on duplicate entries during the zInterStore. * * @return int The number of values in the new sorted set. * * @link https://redis.io/commands/zinterstore * @example * <pre> * $redis->del('k1'); * $redis->del('k2'); * $redis->del('k3'); * * $redis->del('ko1'); * $redis->del('ko2'); * $redis->del('ko3'); * $redis->del('ko4'); * * $redis->zAdd('k1', 0, 'val0'); * $redis->zAdd('k1', 1, 'val1'); * $redis->zAdd('k1', 3, 'val3'); * * $redis->zAdd('k2', 2, 'val1'); * $redis->zAdd('k2', 3, 'val3'); * * $redis->zInterStore('ko1', array('k1', 'k2')); // 2, 'ko1' => array('val1', 'val3') * $redis->zInterStore('ko2', array('k1', 'k2'), array(1, 1)); // 2, 'ko2' => array('val1', 'val3') * * // Weighted zInterStore * $redis->zInterStore('ko3', array('k1', 'k2'), array(1, 5), 'min'); // 2, 'ko3' => array('val1', 'val3') * $redis->zInterStore('ko4', array('k1', 'k2'), array(1, 5), 'max'); // 2, 'ko4' => array('val3', 'val1') * </pre> */ public function zInterStore($output, $zSetKeys, array $weights = null, $aggregateFunction = 'SUM') { } /** * @param $Output * @param $ZSetKeys * @param array|null $Weights * @param string $aggregateFunction */ #[Deprecated(replacement: '%class%->zInterStore(%parametersList%)')] public function zInter($Output, $ZSetKeys, array $Weights = null, $aggregateFunction = 'SUM') { } /** * Scan a sorted set for members, with optional pattern and count * * @param string $key String, the set to scan. * @param int &$iterator Long (reference), initialized to NULL. * @param string $pattern String (optional), the pattern to match. * @param int $count How many keys to return per iteration (Redis might return a different number). * * @return array|false PHPRedis will return matching keys from Redis, or FALSE when iteration is complete * * @link https://redis.io/commands/zscan * @example * <pre> * $iterator = null; * while ($members = $redis-zscan('zset', $iterator)) { * foreach ($members as $member => $score) { * echo $member . ' => ' . $score . PHP_EOL; * } * } * </pre> */ public function zScan($key, &$iterator, $pattern = null, $count = 0) { } /** * Block until Redis can pop the highest or lowest scoring members from one or more ZSETs. * There are two commands (BZPOPMIN and BZPOPMAX for popping the lowest and highest scoring elements respectively.) * * @param string|array $key1 * @param string|array $key2 ... * @param int $timeout * * @return array Either an array with the key member and score of the highest or lowest element or an empty array * if the timeout was reached without an element to pop. * * @since >= 5.0 * @link https://redis.io/commands/bzpopmax * @example * <pre> * // Wait up to 5 seconds to pop the *lowest* scoring member from sets `zs1` and `zs2`. * $redis->bzPopMin(['zs1', 'zs2'], 5); * $redis->bzPopMin('zs1', 'zs2', 5); * * // Wait up to 5 seconds to pop the *highest* scoring member from sets `zs1` and `zs2` * $redis->bzPopMax(['zs1', 'zs2'], 5); * $redis->bzPopMax('zs1', 'zs2', 5); * </pre> */ public function bzPopMax($key1, $key2, $timeout) { } /** * @param string|array $key1 * @param string|array $key2 ... * @param int $timeout * * @return array Either an array with the key member and score of the highest or lowest element or an empty array * if the timeout was reached without an element to pop. * * @see bzPopMax * @since >= 5.0 * @link https://redis.io/commands/bzpopmin */ public function bzPopMin($key1, $key2, $timeout) { } /** * Can pop the highest scoring members from one ZSET. * * @param string $key * @param int $count * * @return array Either an array with the key member and score of the highest element or an empty array * if there is no element to pop. * * @since >= 5.0 * @link https://redis.io/commands/zpopmax * @example * <pre> * // Pop the *lowest* scoring member from set `zs1`. * $redis->zPopMax('zs1'); * // Pop the *lowest* 3 scoring member from set `zs1`. * $redis->zPopMax('zs1', 3); * </pre> */ public function zPopMax($key, $count = 1) { } /** * Can pop the lowest scoring members from one ZSET. * * @param string $key * @param int $count * * @return array Either an array with the key member and score of the lowest element or an empty array * if there is no element to pop. * * @since >= 5.0 * @link https://redis.io/commands/zpopmin * @example * <pre> * // Pop the *lowest* scoring member from set `zs1`. * $redis->zPopMin('zs1'); * // Pop the *lowest* 3 scoring member from set `zs1`. * $redis->zPopMin('zs1', 3); * </pre> */ public function zPopMin($key, $count = 1) { } /** * Adds a value to the hash stored at key. If this value is already in the hash, FALSE is returned. * * @param string $key * @param string $hashKey * @param string $value * * @return int|bool * - 1 if value didn't exist and was added successfully, * - 0 if the value was already present and was replaced, FALSE if there was an error. * * @link https://redis.io/commands/hset * @example * <pre> * $redis->del('h') * $redis->hSet('h', 'key1', 'hello'); // 1, 'key1' => 'hello' in the hash at "h" * $redis->hGet('h', 'key1'); // returns "hello" * * $redis->hSet('h', 'key1', 'plop'); // 0, value was replaced. * $redis->hGet('h', 'key1'); // returns "plop" * </pre> */ public function hSet($key, $hashKey, $value) { } /** * Adds a value to the hash stored at key only if this field isn't already in the hash. * * @param string $key * @param string $hashKey * @param string $value * * @return bool TRUE if the field was set, FALSE if it was already present. * * @link https://redis.io/commands/hsetnx * @example * <pre> * $redis->del('h') * $redis->hSetNx('h', 'key1', 'hello'); // TRUE, 'key1' => 'hello' in the hash at "h" * $redis->hSetNx('h', 'key1', 'world'); // FALSE, 'key1' => 'hello' in the hash at "h". No change since the field * wasn't replaced. * </pre> */ public function hSetNx($key, $hashKey, $value) { } /** * Gets a value from the hash stored at key. * If the hash table doesn't exist, or the key doesn't exist, FALSE is returned. * * @param string $key * @param string $hashKey * * @return string|false The value, if the command executed successfully BOOL FALSE in case of failure * * @link https://redis.io/commands/hget */ public function hGet($key, $hashKey) { } /** * Returns the length of a hash, in number of items * * @param string $key * * @return int|false the number of items in a hash, FALSE if the key doesn't exist or isn't a hash * * @link https://redis.io/commands/hlen * @example * <pre> * $redis->del('h') * $redis->hSet('h', 'key1', 'hello'); * $redis->hSet('h', 'key2', 'plop'); * $redis->hLen('h'); // returns 2 * </pre> */ public function hLen($key) { } /** * Removes a values from the hash stored at key. * If the hash table doesn't exist, or the key doesn't exist, FALSE is returned. * * @param string $key * @param string $hashKey1 * @param string ...$otherHashKeys * * @return int|bool Number of deleted fields * * @link https://redis.io/commands/hdel * @example * <pre> * $redis->hMSet('h', * array( * 'f1' => 'v1', * 'f2' => 'v2', * 'f3' => 'v3', * 'f4' => 'v4', * )); * * var_dump( $redis->hDel('h', 'f1') ); // int(1) * var_dump( $redis->hDel('h', 'f2', 'f3') ); // int(2) * s * var_dump( $redis->hGetAll('h') ); * //// Output: * // array(1) { * // ["f4"]=> string(2) "v4" * // } * </pre> */ public function hDel($key, $hashKey1, ...$otherHashKeys) { } /** * Returns the keys in a hash, as an array of strings. * * @param string $key * * @return array An array of elements, the keys of the hash. This works like PHP's array_keys(). * * @link https://redis.io/commands/hkeys * @example * <pre> * $redis->del('h'); * $redis->hSet('h', 'a', 'x'); * $redis->hSet('h', 'b', 'y'); * $redis->hSet('h', 'c', 'z'); * $redis->hSet('h', 'd', 't'); * var_dump($redis->hKeys('h')); * * // Output: * // array(4) { * // [0]=> * // string(1) "a" * // [1]=> * // string(1) "b" * // [2]=> * // string(1) "c" * // [3]=> * // string(1) "d" * // } * // The order is random and corresponds to redis' own internal representation of the set structure. * </pre> */ public function hKeys($key) { } /** * Returns the values in a hash, as an array of strings. * * @param string $key * * @return array An array of elements, the values of the hash. This works like PHP's array_values(). * * @link https://redis.io/commands/hvals * @example * <pre> * $redis->del('h'); * $redis->hSet('h', 'a', 'x'); * $redis->hSet('h', 'b', 'y'); * $redis->hSet('h', 'c', 'z'); * $redis->hSet('h', 'd', 't'); * var_dump($redis->hVals('h')); * * // Output * // array(4) { * // [0]=> * // string(1) "x" * // [1]=> * // string(1) "y" * // [2]=> * // string(1) "z" * // [3]=> * // string(1) "t" * // } * // The order is random and corresponds to redis' own internal representation of the set structure. * </pre> */ public function hVals($key) { } /** * Returns the whole hash, as an array of strings indexed by strings. * * @param string $key * * @return array An array of elements, the contents of the hash. * * @link https://redis.io/commands/hgetall * @example * <pre> * $redis->del('h'); * $redis->hSet('h', 'a', 'x'); * $redis->hSet('h', 'b', 'y'); * $redis->hSet('h', 'c', 'z'); * $redis->hSet('h', 'd', 't'); * var_dump($redis->hGetAll('h')); * * // Output: * // array(4) { * // ["a"]=> * // string(1) "x" * // ["b"]=> * // string(1) "y" * // ["c"]=> * // string(1) "z" * // ["d"]=> * // string(1) "t" * // } * // The order is random and corresponds to redis' own internal representation of the set structure. * </pre> */ public function hGetAll($key) { } /** * Verify if the specified member exists in a key. * * @param string $key * @param string $hashKey * * @return bool If the member exists in the hash table, return TRUE, otherwise return FALSE. * * @link https://redis.io/commands/hexists * @example * <pre> * $redis->hSet('h', 'a', 'x'); * $redis->hExists('h', 'a'); // TRUE * $redis->hExists('h', 'NonExistingKey'); // FALSE * </pre> */ public function hExists($key, $hashKey) { } /** * Increments the value of a member from a hash by a given amount. * * @param string $key * @param string $hashKey * @param int $value (integer) value that will be added to the member's value * * @return int the new value * * @link https://redis.io/commands/hincrby * @example * <pre> * $redis->del('h'); * $redis->hIncrBy('h', 'x', 2); // returns 2: h[x] = 2 now. * $redis->hIncrBy('h', 'x', 1); // h[x] ← 2 + 1. Returns 3 * </pre> */ public function hIncrBy($key, $hashKey, $value) { } /** * Increment the float value of a hash field by the given amount * * @param string $key * @param string $field * @param float $increment * * @return float * * @link https://redis.io/commands/hincrbyfloat * @example * <pre> * $redis = new Redis(); * $redis->connect('127.0.0.1'); * $redis->hset('h', 'float', 3); * $redis->hset('h', 'int', 3); * var_dump( $redis->hIncrByFloat('h', 'float', 1.5) ); // float(4.5) * * var_dump( $redis->hGetAll('h') ); * * // Output * array(2) { * ["float"]=> * string(3) "4.5" * ["int"]=> * string(1) "3" * } * </pre> */ public function hIncrByFloat($key, $field, $increment) { } /** * Fills in a whole hash. Non-string values are converted to string, using the standard (string) cast. * NULL values are stored as empty strings * * @param string $key * @param array $hashKeys key → value array * * @return bool * * @link https://redis.io/commands/hmset * @example * <pre> * $redis->del('user:1'); * $redis->hMSet('user:1', array('name' => 'Joe', 'salary' => 2000)); * $redis->hIncrBy('user:1', 'salary', 100); // Joe earns 100 more now. * </pre> */ public function hMSet($key, $hashKeys) { } /** * Retrieve the values associated to the specified fields in the hash. * * @param string $key * @param array $hashKeys * * @return array Array An array of elements, the values of the specified fields in the hash, * with the hash keys as array keys. * * @link https://redis.io/commands/hmget * @example * <pre> * $redis->del('h'); * $redis->hSet('h', 'field1', 'value1'); * $redis->hSet('h', 'field2', 'value2'); * $redis->hmGet('h', array('field1', 'field2')); // returns array('field1' => 'value1', 'field2' => 'value2') * </pre> */ public function hMGet($key, $hashKeys) { } /** * Scan a HASH value for members, with an optional pattern and count. * * @param string $key * @param int &$iterator * @param string $pattern Optional pattern to match against. * @param int $count How many keys to return in a go (only a sugestion to Redis). * * @return array An array of members that match our pattern. * * @link https://redis.io/commands/hscan * @example * <pre> * // $iterator = null; * // while($elements = $redis->hscan('hash', $iterator)) { * // foreach($elements as $key => $value) { * // echo $key . ' => ' . $value . PHP_EOL; * // } * // } * </pre> */ public function hScan($key, &$iterator, $pattern = null, $count = 0) { } /** * Get the string length of the value associated with field in the hash stored at key * * @param string $key * @param string $field * * @return int the string length of the value associated with field, or zero when field is not present in the hash * or key does not exist at all. * * @link https://redis.io/commands/hstrlen * @since >= 3.2 */ public function hStrLen(string $key, string $field) { } /** * Add one or more geospatial items to the specified key. * This function must be called with at least one longitude, latitude, member triplet. * * @param string $key * @param float $longitude * @param float $latitude * @param string $member * * @return int The number of elements added to the geospatial key * * @link https://redis.io/commands/geoadd * @since >= 3.2 * * @example * <pre> * $redis->del("myplaces"); * * // Since the key will be new, $result will be 2 * $result = $redis->geoAdd( * "myplaces", * -122.431, 37.773, "San Francisco", * -157.858, 21.315, "Honolulu" * ); // 2 * </pre> */ public function geoadd($key, $longitude, $latitude, $member) { } /** * Retrieve Geohash strings for one or more elements of a geospatial index. * @param string $key * @param string ...$member variadic list of members * * @return array One or more Redis Geohash encoded strings * * @link https://redis.io/commands/geohash * @since >= 3.2 * * @example * <pre> * $redis->geoAdd("hawaii", -157.858, 21.306, "Honolulu", -156.331, 20.798, "Maui"); * $hashes = $redis->geoHash("hawaii", "Honolulu", "Maui"); * var_dump($hashes); * // Output: array(2) { * // [0]=> * // string(11) "87z9pyek3y0" * // [1]=> * // string(11) "8e8y6d5jps0" * // } * </pre> */ public function geohash($key, ...$member) { } /** * Return longitude, latitude positions for each requested member. * * @param string $key * @param string $member * @return array One or more longitude/latitude positions * * @link https://redis.io/commands/geopos * @since >= 3.2 * * @example * <pre> * $redis->geoAdd("hawaii", -157.858, 21.306, "Honolulu", -156.331, 20.798, "Maui"); * $positions = $redis->geoPos("hawaii", "Honolulu", "Maui"); * var_dump($positions); * * // Output: * array(2) { * [0]=> array(2) { * [0]=> string(22) "-157.85800248384475708" * [1]=> string(19) "21.3060004581273077" * } * [1]=> array(2) { * [0]=> string(22) "-156.33099943399429321" * [1]=> string(20) "20.79799924753607598" * } * } * </pre> */ public function geopos(string $key, string $member) { } /** * Return the distance between two members in a geospatial set. * * If units are passed it must be one of the following values: * - 'm' => Meters * - 'km' => Kilometers * - 'mi' => Miles * - 'ft' => Feet * * @param string $key * @param string $member1 * @param string $member2 * @param string|null $unit * * @return float The distance between the two passed members in the units requested (meters by default) * * @link https://redis.io/commands/geodist * @since >= 3.2 * * @example * <pre> * $redis->geoAdd("hawaii", -157.858, 21.306, "Honolulu", -156.331, 20.798, "Maui"); * * $meters = $redis->geoDist("hawaii", "Honolulu", "Maui"); * $kilometers = $redis->geoDist("hawaii", "Honolulu", "Maui", 'km'); * $miles = $redis->geoDist("hawaii", "Honolulu", "Maui", 'mi'); * $feet = $redis->geoDist("hawaii", "Honolulu", "Maui", 'ft'); * * echo "Distance between Honolulu and Maui:\n"; * echo " meters : $meters\n"; * echo " kilometers: $kilometers\n"; * echo " miles : $miles\n"; * echo " feet : $feet\n"; * * // Bad unit * $inches = $redis->geoDist("hawaii", "Honolulu", "Maui", 'in'); * echo "Invalid unit returned:\n"; * var_dump($inches); * * // Output * Distance between Honolulu and Maui: * meters : 168275.204 * kilometers: 168.2752 * miles : 104.5616 * feet : 552084.0028 * Invalid unit returned: * bool(false) * </pre> */ public function geodist($key, $member1, $member2, $unit = null) { } /** * Return members of a set with geospatial information that are within the radius specified by the caller. * * @param $key * @param $longitude * @param $latitude * @param $radius * @param $unit * @param array|null $options * <pre> * |Key |Value |Description | * |------------|---------------|---------------------------------------------------| * |COUNT |integer > 0 |Limit how many results are returned | * | |WITHCOORD |Return longitude and latitude of matching members | * | |WITHDIST |Return the distance from the center | * | |WITHHASH |Return the raw geohash-encoded score | * | |ASC |Sort results in ascending order | * | |DESC |Sort results in descending order | * |STORE |key |Store results in key | * |STOREDIST |key |Store the results as distances in key | * </pre> * Note: It doesn't make sense to pass both ASC and DESC options but if both are passed * the last one passed will be used. * Note: When using STORE[DIST] in Redis Cluster, the store key must has to the same slot as * the query key or you will get a CROSSLOT error. * @return mixed When no STORE option is passed, this function returns an array of results. * If it is passed this function returns the number of stored entries. * * @link https://redis.io/commands/georadius * @since >= 3.2 * @example * <pre> * // Add some cities * $redis->geoAdd("hawaii", -157.858, 21.306, "Honolulu", -156.331, 20.798, "Maui"); * * echo "Within 300 miles of Honolulu:\n"; * var_dump($redis->geoRadius("hawaii", -157.858, 21.306, 300, 'mi')); * * echo "\nWithin 300 miles of Honolulu with distances:\n"; * $options = ['WITHDIST']; * var_dump($redis->geoRadius("hawaii", -157.858, 21.306, 300, 'mi', $options)); * * echo "\nFirst result within 300 miles of Honolulu with distances:\n"; * $options['count'] = 1; * var_dump($redis->geoRadius("hawaii", -157.858, 21.306, 300, 'mi', $options)); * * echo "\nFirst result within 300 miles of Honolulu with distances in descending sort order:\n"; * $options[] = 'DESC'; * var_dump($redis->geoRadius("hawaii", -157.858, 21.306, 300, 'mi', $options)); * * // Output * Within 300 miles of Honolulu: * array(2) { * [0]=> string(8) "Honolulu" * [1]=> string(4) "Maui" * } * * Within 300 miles of Honolulu with distances: * array(2) { * [0]=> * array(2) { * [0]=> * string(8) "Honolulu" * [1]=> * string(6) "0.0002" * } * [1]=> * array(2) { * [0]=> * string(4) "Maui" * [1]=> * string(8) "104.5615" * } * } * * First result within 300 miles of Honolulu with distances: * array(1) { * [0]=> * array(2) { * [0]=> * string(8) "Honolulu" * [1]=> * string(6) "0.0002" * } * } * * First result within 300 miles of Honolulu with distances in descending sort order: * array(1) { * [0]=> * array(2) { * [0]=> * string(4) "Maui" * [1]=> * string(8) "104.5615" * } * } * </pre> */ public function georadius($key, $longitude, $latitude, $radius, $unit, array $options = null) { } /** * This method is identical to geoRadius except that instead of passing a longitude and latitude as the "source" * you pass an existing member in the geospatial set * * @param string $key * @param string $member * @param $radius * @param $units * @param array|null $options see georadius * * @return array The zero or more entries that are close enough to the member given the distance and radius specified * * @link https://redis.io/commands/georadiusbymember * @since >= 3.2 * @see georadius * @example * <pre> * $redis->geoAdd("hawaii", -157.858, 21.306, "Honolulu", -156.331, 20.798, "Maui"); * * echo "Within 300 miles of Honolulu:\n"; * var_dump($redis->geoRadiusByMember("hawaii", "Honolulu", 300, 'mi')); * * echo "\nFirst match within 300 miles of Honolulu:\n"; * var_dump($redis->geoRadiusByMember("hawaii", "Honolulu", 300, 'mi', ['count' => 1])); * * // Output * Within 300 miles of Honolulu: * array(2) { * [0]=> string(8) "Honolulu" * [1]=> string(4) "Maui" * } * * First match within 300 miles of Honolulu: * array(1) { * [0]=> string(8) "Honolulu" * } * </pre> */ public function georadiusbymember($key, $member, $radius, $units, array $options = null) { } /** * Get or Set the redis config keys. * * @param string $operation either `GET` or `SET` * @param string $key for `SET`, glob-pattern for `GET` * @param string|mixed $value optional string (only for `SET`) * * @return array Associative array for `GET`, key -> value * * @link https://redis.io/commands/config-get * @example * <pre> * $redis->config("GET", "*max-*-entries*"); * $redis->config("SET", "dir", "/var/run/redis/dumps/"); * </pre> */ public function config($operation, $key, $value) { } /** * Evaluate a LUA script serverside * * @param string $script * @param array $args * @param int $numKeys * * @return mixed What is returned depends on what the LUA script itself returns, which could be a scalar value * (int/string), or an array. Arrays that are returned can also contain other arrays, if that's how it was set up in * your LUA script. If there is an error executing the LUA script, the getLastError() function can tell you the * message that came back from Redis (e.g. compile error). * * @link https://redis.io/commands/eval * @example * <pre> * $redis->eval("return 1"); // Returns an integer: 1 * $redis->eval("return {1,2,3}"); // Returns Array(1,2,3) * $redis->del('mylist'); * $redis->rpush('mylist','a'); * $redis->rpush('mylist','b'); * $redis->rpush('mylist','c'); * // Nested response: Array(1,2,3,Array('a','b','c')); * $redis->eval("return {1,2,3,redis.call('lrange','mylist',0,-1)}}"); * </pre> */ public function eval($script, $args = array(), $numKeys = 0) { } /** * @param string $script * @param array $args * @param int $numKeys * @return mixed @see eval() */ #[Deprecated(replacement: '%class%->eval(%parametersList%)')] public function evaluate($script, $args = array(), $numKeys = 0) { } /** * Evaluate a LUA script serverside, from the SHA1 hash of the script instead of the script itself. * In order to run this command Redis will have to have already loaded the script, either by running it or via * the SCRIPT LOAD command. * * @param string $scriptSha * @param array $args * @param int $numKeys * * @return mixed @see eval() * * @see eval() * @link https://redis.io/commands/evalsha * @example * <pre> * $script = 'return 1'; * $sha = $redis->script('load', $script); * $redis->evalSha($sha); // Returns 1 * </pre> */ public function evalSha($scriptSha, $args = array(), $numKeys = 0) { } /** * @param string $scriptSha * @param array $args * @param int $numKeys */ #[Deprecated(replacement: '%class%->evalSha(%parametersList%)')] public function evaluateSha($scriptSha, $args = array(), $numKeys = 0) { } /** * Execute the Redis SCRIPT command to perform various operations on the scripting subsystem. * @param string $command load | flush | kill | exists * @param string $script * * @return mixed * * @link https://redis.io/commands/script-load * @link https://redis.io/commands/script-kill * @link https://redis.io/commands/script-flush * @link https://redis.io/commands/script-exists * @example * <pre> * $redis->script('load', $script); * $redis->script('flush'); * $redis->script('kill'); * $redis->script('exists', $script1, [$script2, $script3, ...]); * </pre> * * SCRIPT LOAD will return the SHA1 hash of the passed script on success, and FALSE on failure. * SCRIPT FLUSH should always return TRUE * SCRIPT KILL will return true if a script was able to be killed and false if not * SCRIPT EXISTS will return an array with TRUE or FALSE for each passed script */ public function script($command, $script) { } /** * The last error message (if any) * * @return string|null A string with the last returned script based error message, or NULL if there is no error * * @example * <pre> * $redis->eval('this-is-not-lua'); * $err = $redis->getLastError(); * // "ERR Error compiling script (new function): user_script:1: '=' expected near '-'" * </pre> */ public function getLastError() { } /** * Clear the last error message * * @return bool true * * @example * <pre> * $redis->set('x', 'a'); * $redis->incr('x'); * $err = $redis->getLastError(); * // "ERR value is not an integer or out of range" * $redis->clearLastError(); * $err = $redis->getLastError(); * // NULL * </pre> */ public function clearLastError() { } /** * Issue the CLIENT command with various arguments. * The Redis CLIENT command can be used in four ways: * - CLIENT LIST * - CLIENT GETNAME * - CLIENT SETNAME [name] * - CLIENT KILL [ip:port] * * @param string $command * @param string $value * @return mixed This will vary depending on which client command was executed: * - CLIENT LIST will return an array of arrays with client information. * - CLIENT GETNAME will return the client name or false if none has been set * - CLIENT SETNAME will return true if it can be set and false if not * - CLIENT KILL will return true if the client can be killed, and false if not * * Note: phpredis will attempt to reconnect so you can actually kill your own connection but may not notice losing it! * * @link https://redis.io/commands/client-list * @link https://redis.io/commands/client-getname * @link https://redis.io/commands/client-setname * @link https://redis.io/commands/client-kill * * @example * <pre> * $redis->client('list'); // Get a list of clients * $redis->client('getname'); // Get the name of the current connection * $redis->client('setname', 'somename'); // Set the name of the current connection * $redis->client('kill', <ip:port>); // Kill the process at ip:port * </pre> */ public function client($command, $value = '') { } /** * A utility method to prefix the value with the prefix setting for phpredis. * * @param mixed $value The value you wish to prefix * * @return string If a prefix is set up, the value now prefixed. * If there is no prefix, the value will be returned unchanged. * * @example * <pre> * $redis->setOption(Redis::OPT_PREFIX, 'my-prefix:'); * $redis->_prefix('my-value'); // Will return 'my-prefix:my-value' * </pre> */ public function _prefix($value) { } /** * A utility method to unserialize data with whatever serializer is set up. If there is no serializer set, the * value will be returned unchanged. If there is a serializer set up, and the data passed in is malformed, an * exception will be thrown. This can be useful if phpredis is serializing values, and you return something from * redis in a LUA script that is serialized. * * @param string $value The value to be unserialized * * @return mixed * @example * <pre> * $redis->setOption(Redis::OPT_SERIALIZER, Redis::SERIALIZER_PHP); * $redis->_unserialize('a:3:{i:0;i:1;i:1;i:2;i:2;i:3;}'); // Will return Array(1,2,3) * </pre> */ public function _unserialize($value) { } /** * A utility method to serialize values manually. This method allows you to serialize a value with whatever * serializer is configured, manually. This can be useful for serialization/unserialization of data going in * and out of EVAL commands as phpredis can't automatically do this itself. Note that if no serializer is * set, phpredis will change Array values to 'Array', and Objects to 'Object'. * * @param mixed $value The value to be serialized. * * @return mixed * @example * <pre> * $redis->setOption(Redis::OPT_SERIALIZER, Redis::SERIALIZER_NONE); * $redis->_serialize("foo"); // returns "foo" * $redis->_serialize(Array()); // Returns "Array" * $redis->_serialize(new stdClass()); // Returns "Object" * * $redis->setOption(Redis::OPT_SERIALIZER, Redis::SERIALIZER_PHP); * $redis->_serialize("foo"); // Returns 's:3:"foo";' * </pre> */ public function _serialize($value) { } /** * Dump a key out of a redis database, the value of which can later be passed into redis using the RESTORE command. * The data that comes out of DUMP is a binary representation of the key as Redis stores it. * @param string $key * * @return string|false The Redis encoded value of the key, or FALSE if the key doesn't exist * * @link https://redis.io/commands/dump * @example * <pre> * $redis->set('foo', 'bar'); * $val = $redis->dump('foo'); // $val will be the Redis encoded key value * </pre> */ public function dump($key) { } /** * Restore a key from the result of a DUMP operation. * * @param string $key The key name * @param int $ttl How long the key should live (if zero, no expire will be set on the key) * @param string $value (binary). The Redis encoded key value (from DUMP) * * @return bool * * @link https://redis.io/commands/restore * @example * <pre> * $redis->set('foo', 'bar'); * $val = $redis->dump('foo'); * $redis->restore('bar', 0, $val); // The key 'bar', will now be equal to the key 'foo' * </pre> */ public function restore($key, $ttl, $value) { } /** * Migrates a key to a different Redis instance. * * @param string $host The destination host * @param int $port The TCP port to connect to. * @param string $key The key to migrate. * @param int $db The target DB. * @param int $timeout The maximum amount of time given to this transfer. * @param bool $copy Should we send the COPY flag to redis. * @param bool $replace Should we send the REPLACE flag to redis. * * @return bool * * @link https://redis.io/commands/migrate * @example * <pre> * $redis->migrate('backup', 6379, 'foo', 0, 3600); * </pre> */ public function migrate($host, $port, $key, $db, $timeout, $copy = false, $replace = false) { } /** * Return the current Redis server time. * * @return array If successful, the time will come back as an associative array with element zero being the * unix timestamp, and element one being microseconds. * * @link https://redis.io/commands/time * @example * <pre> * var_dump( $redis->time() ); * // array(2) { * // [0] => string(10) "1342364352" * // [1] => string(6) "253002" * // } * </pre> */ public function time() { } /** * Scan the keyspace for keys * * @param int &$iterator Iterator, initialized to NULL. * @param string $pattern Pattern to match. * @param int $count Count of keys per iteration (only a suggestion to Redis). * * @return array|false This function will return an array of keys or FALSE if there are no more keys. * * @link https://redis.io/commands/scan * @example * <pre> * $iterator = null; * while(false !== ($keys = $redis->scan($iterator))) { * foreach($keys as $key) { * echo $key . PHP_EOL; * } * } * </pre> */ public function scan(&$iterator, $pattern = null, $count = 0) { } /** * Adds all the element arguments to the HyperLogLog data structure stored at the key. * * @param string $key * @param array $elements * * @return bool * * @link https://redis.io/commands/pfadd * @example $redis->pfAdd('key', array('elem1', 'elem2')) */ public function pfAdd($key, array $elements) { } /** * When called with a single key, returns the approximated cardinality computed by the HyperLogLog data * structure stored at the specified variable, which is 0 if the variable does not exist. * * @param string|array $key * * @return int * * @link https://redis.io/commands/pfcount * @example * <pre> * $redis->pfAdd('key1', array('elem1', 'elem2')); * $redis->pfAdd('key2', array('elem3', 'elem2')); * $redis->pfCount('key1'); // int(2) * $redis->pfCount(array('key1', 'key2')); // int(3) * </pre> */ public function pfCount($key) { } /** * Merge multiple HyperLogLog values into an unique value that will approximate the cardinality * of the union of the observed Sets of the source HyperLogLog structures. * * @param string $destKey * @param array $sourceKeys * * @return bool * * @link https://redis.io/commands/pfmerge * @example * <pre> * $redis->pfAdd('key1', array('elem1', 'elem2')); * $redis->pfAdd('key2', array('elem3', 'elem2')); * $redis->pfMerge('key3', array('key1', 'key2')); * $redis->pfCount('key3'); // int(3) * </pre> */ public function pfMerge($destKey, array $sourceKeys) { } /** * Send arbitrary things to the redis server. * * @param string $command Required command to send to the server. * @param mixed $arguments Optional variable amount of arguments to send to the server. * * @return mixed * * @example * <pre> * $redis->rawCommand('SET', 'key', 'value'); // bool(true) * $redis->rawCommand('GET", 'key'); // string(5) "value" * </pre> */ public function rawCommand($command, $arguments) { } /** * Detect whether we're in ATOMIC/MULTI/PIPELINE mode. * * @return int Either Redis::ATOMIC, Redis::MULTI or Redis::PIPELINE * * @example $redis->getMode(); */ public function getMode() { } /** * Acknowledge one or more messages on behalf of a consumer group. * * @param string $stream * @param string $group * @param array $messages * * @return int The number of messages Redis reports as acknowledged. * * @link https://redis.io/commands/xack * @example * <pre> * $redis->xAck('stream', 'group1', ['1530063064286-0', '1530063064286-1']); * </pre> */ public function xAck($stream, $group, $messages) { } /** * Add a message to a stream * * @param string $key * @param string $id * @param array $messages * @param int $maxLen * @param bool $isApproximate * * @return string The added message ID. * * @link https://redis.io/commands/xadd * @example * <pre> * $redis->xAdd('mystream', "*", ['field' => 'value']); * $redis->xAdd('mystream', "*", ['field' => 'value'], 10); * $redis->xAdd('mystream', "*", ['field' => 'value'], 10, true); * </pre> */ public function xAdd($key, $id, $messages, $maxLen = 0, $isApproximate = false) { } /** * Claim ownership of one or more pending messages * * @param string $key * @param string $group * @param string $consumer * @param int $minIdleTime * @param array $ids * @param array $options ['IDLE' => $value, 'TIME' => $value, 'RETRYCOUNT' => $value, 'FORCE', 'JUSTID'] * * @return array Either an array of message IDs along with corresponding data, or just an array of IDs * (if the 'JUSTID' option was passed). * * @link https://redis.io/commands/xclaim * @example * <pre> * $ids = ['1530113681011-0', '1530113681011-1', '1530113681011-2']; * * // Without any options * $redis->xClaim('mystream', 'group1', 'myconsumer1', 0, $ids); * * // With options * $redis->xClaim( * 'mystream', 'group1', 'myconsumer2', 0, $ids, * [ * 'IDLE' => time() * 1000, * 'RETRYCOUNT' => 5, * 'FORCE', * 'JUSTID' * ] * ); * </pre> */ public function xClaim($key, $group, $consumer, $minIdleTime, $ids, $options = []) { } /** * Delete one or more messages from a stream * * @param string $key * @param array $ids * * @return int The number of messages removed * * @link https://redis.io/commands/xdel * @example * <pre> * $redis->xDel('mystream', ['1530115304877-0', '1530115305731-0']); * </pre> */ public function xDel($key, $ids) { } /** * @param string $operation e.g.: 'HELP', 'SETID', 'DELGROUP', 'CREATE', 'DELCONSUMER' * @param string $key * @param string $group * @param string $msgId * @param bool $mkStream * * @return mixed This command returns different types depending on the specific XGROUP command executed. * * @link https://redis.io/commands/xgroup * @example * <pre> * $redis->xGroup('CREATE', 'mystream', 'mygroup', 0); * $redis->xGroup('CREATE', 'mystream', 'mygroup', 0, true); // create stream * $redis->xGroup('DESTROY', 'mystream', 'mygroup'); * </pre> */ public function xGroup($operation, $key, $group, $msgId = '', $mkStream = false) { } /** * Get information about a stream or consumer groups * * @param string $operation e.g.: 'CONSUMERS', 'GROUPS', 'STREAM', 'HELP' * @param string $stream * @param string $group * * @return mixed This command returns different types depending on which subcommand is used. * * @link https://redis.io/commands/xinfo * @example * <pre> * $redis->xInfo('STREAM', 'mystream'); * </pre> */ public function xInfo($operation, $stream, $group) { } /** * Get the length of a given stream. * * @param string $stream * * @return int The number of messages in the stream. * * @link https://redis.io/commands/xlen * @example * <pre> * $redis->xLen('mystream'); * </pre> */ public function xLen($stream) { } /** * Get information about pending messages in a given stream * * @param string $stream * @param string $group * @param string $start * @param string $end * @param int $count * @param string $consumer * * @return array Information about the pending messages, in various forms depending on * the specific invocation of XPENDING. * * @link https://redis.io/commands/xpending * @example * <pre> * $redis->xPending('mystream', 'mygroup'); * $redis->xPending('mystream', 'mygroup', '-', '+', 1, 'consumer-1'); * </pre> */ public function xPending($stream, $group, $start = null, $end = null, $count = null, $consumer = null) { } /** * Get a range of messages from a given stream * * @param string $stream * @param string $start * @param string $end * @param int $count * * @return array The messages in the stream within the requested range. * * @link https://redis.io/commands/xrange * @example * <pre> * // Get everything in this stream * $redis->xRange('mystream', '-', '+'); * // Only the first two messages * $redis->xRange('mystream', '-', '+', 2); * </pre> */ public function xRange($stream, $start, $end, $count = null) { } /** * Read data from one or more streams and only return IDs greater than sent in the command. * * @param array $streams * @param int|string $count * @param int|string $block * * @return array The messages in the stream newer than the IDs passed to Redis (if any) * * @link https://redis.io/commands/xread * @example * <pre> * $redis->xRead(['stream1' => '1535222584555-0', 'stream2' => '1535222584555-0']); * </pre> */ public function xRead($streams, $count = null, $block = null) { } /** * This method is similar to xRead except that it supports reading messages for a specific consumer group. * * @param string $group * @param string $consumer * @param array $streams * @param int|null $count * @param int|null $block * * @return array The messages delivered to this consumer group (if any). * * @link https://redis.io/commands/xreadgroup * @example * <pre> * // Consume messages for 'mygroup', 'consumer1' * $redis->xReadGroup('mygroup', 'consumer1', ['s1' => 0, 's2' => 0]); * // Read a single message as 'consumer2' for up to a second until a message arrives. * $redis->xReadGroup('mygroup', 'consumer2', ['s1' => 0, 's2' => 0], 1, 1000); * </pre> */ public function xReadGroup($group, $consumer, $streams, $count = null, $block = null) { } /** * This is identical to xRange except the results come back in reverse order. * Also note that Redis reverses the order of "start" and "end". * * @param string $stream * @param string $end * @param string $start * @param int $count * * @return array The messages in the range specified * * @link https://redis.io/commands/xrevrange * @example * <pre> * $redis->xRevRange('mystream', '+', '-'); * </pre> */ public function xRevRange($stream, $end, $start, $count = null) { } /** * Trim the stream length to a given maximum. * If the "approximate" flag is pasesed, Redis will use your size as a hint but only trim trees in whole nodes * (this is more efficient) * * @param string $stream * @param int $maxLen * @param bool $isApproximate * * @return int The number of messages trimed from the stream. * * @link https://redis.io/commands/xtrim * @example * <pre> * // Trim to exactly 100 messages * $redis->xTrim('mystream', 100); * // Let Redis approximate the trimming * $redis->xTrim('mystream', 100, true); * </pre> */ public function xTrim($stream, $maxLen, $isApproximate) { } /** * Adds a values to the set value stored at key. * * @param string $key Required key * @param array $values Required values * * @return int|bool The number of elements added to the set. * If this value is already in the set, FALSE is returned * * @link https://redis.io/commands/sadd * @link https://github.com/phpredis/phpredis/commit/3491b188e0022f75b938738f7542603c7aae9077 * @since phpredis 2.2.8 * @example * <pre> * $redis->sAddArray('k', array('v1')); // boolean * $redis->sAddArray('k', array('v1', 'v2', 'v3')); // boolean * </pre> */ public function sAddArray($key, array $values) { } } class RedisException extends Exception { } /** * @mixin \Redis */ class RedisArray { /** * Constructor * * @param string|string[] $hosts Name of the redis array from redis.ini or array of hosts to construct the array with * @param null|array $opts Array of options * * @link https://github.com/nicolasff/phpredis/blob/master/arrays.markdown */ public function __construct($hosts, ?array $opts = null) { } /** * @return array list of hosts for the selected array */ public function _hosts() { } /** * @return string the name of the function used to extract key parts during consistent hashing */ public function _function() { } /** * @param string $key The key for which you want to lookup the host * * @return string the host to be used for a certain key */ public function _target($key) { } /** * @param string $host The host you want to retrieve the instance for * * @return Redis a redis instance connected to a specific node */ public function _instance($host) { } /** * Use this function when a new node is added and keys need to be rehashed. */ public function _rehash() { } /** * Returns an associative array of strings and integers, with the following keys: * - redis_version * - redis_git_sha1 * - redis_git_dirty * - redis_build_id * - redis_mode * - os * - arch_bits * - multiplexing_api * - atomicvar_api * - gcc_version * - process_id * - run_id * - tcp_port * - uptime_in_seconds * - uptime_in_days * - hz * - lru_clock * - executable * - config_file * - connected_clients * - client_longest_output_list * - client_biggest_input_buf * - blocked_clients * - used_memory * - used_memory_human * - used_memory_rss * - used_memory_rss_human * - used_memory_peak * - used_memory_peak_human * - used_memory_peak_perc * - used_memory_peak * - used_memory_overhead * - used_memory_startup * - used_memory_dataset * - used_memory_dataset_perc * - total_system_memory * - total_system_memory_human * - used_memory_lua * - used_memory_lua_human * - maxmemory * - maxmemory_human * - maxmemory_policy * - mem_fragmentation_ratio * - mem_allocator * - active_defrag_running * - lazyfree_pending_objects * - mem_fragmentation_ratio * - loading * - rdb_changes_since_last_save * - rdb_bgsave_in_progress * - rdb_last_save_time * - rdb_last_bgsave_status * - rdb_last_bgsave_time_sec * - rdb_current_bgsave_time_sec * - rdb_last_cow_size * - aof_enabled * - aof_rewrite_in_progress * - aof_rewrite_scheduled * - aof_last_rewrite_time_sec * - aof_current_rewrite_time_sec * - aof_last_bgrewrite_status * - aof_last_write_status * - aof_last_cow_size * - changes_since_last_save * - aof_current_size * - aof_base_size * - aof_pending_rewrite * - aof_buffer_length * - aof_rewrite_buffer_length * - aof_pending_bio_fsync * - aof_delayed_fsync * - loading_start_time * - loading_total_bytes * - loading_loaded_bytes * - loading_loaded_perc * - loading_eta_seconds * - total_connections_received * - total_commands_processed * - instantaneous_ops_per_sec * - total_net_input_bytes * - total_net_output_bytes * - instantaneous_input_kbps * - instantaneous_output_kbps * - rejected_connections * - maxclients * - sync_full * - sync_partial_ok * - sync_partial_err * - expired_keys * - evicted_keys * - keyspace_hits * - keyspace_misses * - pubsub_channels * - pubsub_patterns * - latest_fork_usec * - migrate_cached_sockets * - slave_expires_tracked_keys * - active_defrag_hits * - active_defrag_misses * - active_defrag_key_hits * - active_defrag_key_misses * - role * - master_replid * - master_replid2 * - master_repl_offset * - second_repl_offset * - repl_backlog_active * - repl_backlog_size * - repl_backlog_first_byte_offset * - repl_backlog_histlen * - master_host * - master_port * - master_link_status * - master_last_io_seconds_ago * - master_sync_in_progress * - slave_repl_offset * - slave_priority * - slave_read_only * - master_sync_left_bytes * - master_sync_last_io_seconds_ago * - master_link_down_since_seconds * - connected_slaves * - min-slaves-to-write * - min-replicas-to-write * - min_slaves_good_slaves * - used_cpu_sys * - used_cpu_user * - used_cpu_sys_children * - used_cpu_user_children * - cluster_enabled * * @link https://redis.io/commands/info * @return array * @example * <pre> * $redis->info(); * </pre> */ public function info() { } }