12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724172517261727172817291730173117321733173417351736173717381739174017411742174317441745174617471748174917501751175217531754175517561757175817591760176117621763176417651766176717681769177017711772177317741775177617771778177917801781178217831784178517861787178817891790179117921793179417951796179717981799180018011802180318041805180618071808180918101811181218131814181518161817181818191820182118221823182418251826182718281829183018311832183318341835183618371838183918401841184218431844184518461847184818491850185118521853185418551856185718581859186018611862186318641865186618671868186918701871187218731874187518761877187818791880188118821883188418851886188718881889189018911892189318941895189618971898189919001901190219031904190519061907190819091910191119121913191419151916191719181919192019211922192319241925192619271928192919301931193219331934193519361937193819391940194119421943194419451946194719481949195019511952195319541955195619571958195919601961196219631964196519661967196819691970197119721973197419751976197719781979198019811982198319841985198619871988198919901991199219931994199519961997199819992000200120022003200420052006200720082009201020112012201320142015201620172018201920202021202220232024202520262027202820292030203120322033203420352036203720382039204020412042204320442045204620472048204920502051205220532054205520562057205820592060206120622063206420652066206720682069207020712072207320742075207620772078207920802081208220832084208520862087208820892090209120922093209420952096209720982099210021012102210321042105210621072108210921102111211221132114211521162117211821192120212121222123212421252126212721282129213021312132213321342135213621372138213921402141214221432144214521462147214821492150215121522153215421552156215721582159216021612162216321642165216621672168216921702171217221732174217521762177217821792180218121822183218421852186218721882189219021912192219321942195219621972198219922002201220222032204220522062207220822092210221122122213221422152216221722182219222022212222222322242225222622272228222922302231223222332234223522362237223822392240224122422243224422452246224722482249225022512252225322542255225622572258225922602261226222632264226522662267226822692270227122722273227422752276227722782279228022812282228322842285228622872288228922902291229222932294229522962297229822992300230123022303230423052306230723082309231023112312231323142315231623172318231923202321232223232324232523262327232823292330233123322333233423352336233723382339234023412342234323442345234623472348234923502351235223532354235523562357235823592360236123622363236423652366236723682369237023712372237323742375237623772378237923802381238223832384238523862387238823892390239123922393239423952396239723982399240024012402240324042405240624072408240924102411241224132414241524162417241824192420242124222423242424252426242724282429243024312432243324342435243624372438243924402441244224432444244524462447244824492450245124522453245424552456245724582459246024612462246324642465246624672468246924702471247224732474247524762477247824792480248124822483248424852486248724882489249024912492249324942495249624972498249925002501250225032504250525062507250825092510251125122513251425152516251725182519252025212522252325242525252625272528252925302531253225332534253525362537253825392540254125422543254425452546254725482549255025512552255325542555255625572558255925602561256225632564256525662567256825692570257125722573257425752576257725782579258025812582258325842585258625872588258925902591259225932594259525962597259825992600260126022603260426052606260726082609261026112612261326142615261626172618261926202621262226232624262526262627262826292630263126322633263426352636263726382639264026412642264326442645264626472648264926502651265226532654265526562657265826592660266126622663266426652666266726682669267026712672267326742675267626772678267926802681268226832684268526862687268826892690269126922693269426952696269726982699270027012702270327042705270627072708270927102711271227132714271527162717271827192720272127222723272427252726272727282729273027312732273327342735273627372738273927402741274227432744274527462747274827492750275127522753275427552756275727582759276027612762276327642765276627672768276927702771277227732774277527762777277827792780278127822783278427852786278727882789279027912792279327942795279627972798279928002801280228032804280528062807280828092810281128122813281428152816281728182819282028212822282328242825282628272828282928302831283228332834283528362837283828392840284128422843284428452846284728482849285028512852285328542855285628572858285928602861286228632864286528662867286828692870287128722873287428752876287728782879288028812882288328842885288628872888288928902891289228932894289528962897289828992900290129022903290429052906290729082909291029112912291329142915291629172918291929202921292229232924292529262927292829292930293129322933293429352936293729382939294029412942294329442945294629472948294929502951295229532954295529562957295829592960296129622963296429652966296729682969297029712972297329742975297629772978297929802981298229832984298529862987298829892990299129922993299429952996299729982999300030013002300330043005300630073008300930103011301230133014301530163017301830193020302130223023302430253026302730283029303030313032303330343035303630373038303930403041304230433044304530463047304830493050305130523053305430553056305730583059306030613062306330643065306630673068306930703071307230733074307530763077307830793080308130823083308430853086308730883089309030913092309330943095309630973098309931003101310231033104310531063107310831093110311131123113311431153116311731183119312031213122312331243125312631273128312931303131313231333134313531363137313831393140314131423143314431453146314731483149315031513152315331543155315631573158315931603161316231633164316531663167316831693170317131723173317431753176317731783179318031813182318331843185318631873188318931903191319231933194319531963197319831993200320132023203320432053206320732083209321032113212321332143215321632173218321932203221322232233224322532263227322832293230323132323233323432353236323732383239324032413242324332443245324632473248324932503251325232533254325532563257325832593260326132623263326432653266326732683269327032713272327332743275327632773278327932803281328232833284328532863287328832893290329132923293329432953296329732983299330033013302330333043305330633073308330933103311331233133314331533163317331833193320332133223323332433253326332733283329333033313332333333343335333633373338333933403341334233433344334533463347334833493350335133523353335433553356335733583359336033613362336333643365336633673368336933703371337233733374337533763377337833793380338133823383338433853386338733883389339033913392339333943395339633973398339934003401340234033404340534063407340834093410341134123413341434153416341734183419342034213422342334243425342634273428342934303431343234333434343534363437343834393440344134423443344434453446344734483449345034513452345334543455345634573458345934603461346234633464346534663467346834693470347134723473347434753476347734783479348034813482348334843485348634873488348934903491349234933494349534963497349834993500350135023503350435053506350735083509351035113512351335143515351635173518351935203521352235233524352535263527352835293530353135323533353435353536353735383539354035413542354335443545354635473548354935503551355235533554355535563557355835593560356135623563 |
- <?php
- /**
- * Helper autocomplete for php redis cluster extension.
- * Based on the phpredis-phpdoc by Max Kamashev (https://github.com/ukko/phpredis-phpdoc)
- *
- * @author Tommy Zheng <tommy@vlv.pw>
- * @link https://github.com/zgb7mtr/phpredis_cluster_phpdoc
- *
- * @method mixed eval($script, $args = array(), $numKeys = 0)
- *
- */
- class RedisCluster {
- 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_SLAVE_FAILOVER = 5;
- /**
- * 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;
- /**
- * Serializers
- */
- const SERIALIZER_NONE = 0;
- const SERIALIZER_PHP = 1;
- const SERIALIZER_IGBINARY = 2;
- const SERIALIZER_MSGPACK = 3;
- const SERIALIZER_JSON = 4;
- /**
- * 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;
- /**
- * Creates a Redis Cluster client
- *
- * @param string|null $name
- * @param array $seeds
- * @param float $timeout
- * @param float $readTimeout
- * @param bool $persistent
- * @param string|null $auth
- * @throws RedisClusterException
- *
- * @example
- * <pre>
- * // Declaring a cluster with an array of seeds
- * $redisCluster = new RedisCluster(null,['127.0.0.1:6379']);
- *
- * // Loading a cluster configuration by name
- * // In order to load a named array, one must first define the seed nodes in redis.ini.
- * // The following lines would define the cluster 'mycluster', and be loaded automatically by phpredis.
- *
- * // # In redis.ini
- * // redis.clusters.seeds = "mycluster[]=localhost:7000&test[]=localhost:7001"
- * // redis.clusters.timeout = "mycluster=5"
- * // redis.clusters.read_timeout = "mycluster=10"
- *
- * //Then, this cluster can be loaded by doing the following
- *
- * $redisClusterPro = new RedisCluster('mycluster');
- * $redisClusterDev = new RedisCluster('test');
- * </pre>
- */
- public function __construct($name, $seeds, $timeout = null, $readTimeout = null, $persistent = false, $auth = null) { }
- /**
- * Disconnects from the Redis instance, except when pconnect is used.
- */
- public function close() { }
- /**
- * Get the value related to the specified key
- *
- * @param string $key
- *
- * @return string|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>
- * $redisCluster->get('key');
- * </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 $value
- * @param int|array $timeout If you pass an integer, phpredis will redirect to SETEX, and will try to use Redis
- * >= 2.6.12 extended options if you pass an array with valid values.
- *
- * @return bool TRUE if the command is successful.
- *
- * @link https://redis.io/commands/set
- * @example
- * <pre>
- * // Simple key -> value set
- * $redisCluster->set('key', 'value');
- *
- * // Will redirect, and actually make an SETEX call
- * $redisCluster->set('key','value', 10);
- *
- * // Will set the key, if it doesn't exist, with a ttl of 10 seconds
- * $redisCluster->set('key', 'value', Array('nx', 'ex'=>10));
- *
- * // Will set a key, if it does exist, with a ttl of 1000 milliseconds
- * $redisCluster->set('key', 'value', Array('xx', 'px'=>1000));
- * </pre>
- */
- public function set($key, $value, $timeout = null) { }
- /**
- * 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>
- * $redisCluster->del('x', 'y', 'z', 'h'); // remove x y z
- * $redisCluster->mset(array('x' => 'a', 'y' => 'b', 'z' => 'c'));
- * $redisCluster->hset('h', 'field', 'value');
- * var_dump($redisCluster->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) { }
- /**
- * 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>
- * $redisCluster->mset(array('key0' => 'value0', 'key1' => 'value1'));
- * var_dump($redisCluster->get('key0'));
- * var_dump($redisCluster->get('key1'));
- * // Output:
- * // string(6) "value0"
- * // string(6) "value1"
- * </pre>
- */
- public function mset(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) { }
- /**
- * 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>
- * $redisCluster->set('key1', 'val1');
- * $redisCluster->set('key2', 'val2');
- * $redisCluster->set('key3', 'val3');
- * $redisCluster->set('key4', 'val4');
- * $redisCluster->del('key1', 'key2'); // return 2
- * $redisCluster->del(array('key3', 'key4')); // return 2
- * </pre>
- */
- public function del($key1, ...$otherKeys) { }
- /**
- * Set the string value in argument as value of the key, with a time to live.
- *
- * @param string $key
- * @param int $ttl
- * @param string $value
- *
- * @return bool TRUE if the command is successful.
- * @link https://redis.io/commands/setex
- * @example
- * <pre>
- * $redisCluster->setex('key', 3600, 'value'); // sets key → value, with 1h TTL.
- * </pre>
- */
- public function setex($key, $ttl, $value) { }
- /**
- * PSETEX works exactly like SETEX with the sole difference that the expire time is specified in milliseconds
- * instead of seconds.
- *
- * @param string $key
- * @param int $ttl
- * @param string $value
- *
- * @return bool TRUE if the command is successful.
- * @link https://redis.io/commands/psetex
- * @example
- * <pre>
- * $redisCluster->psetex('key', 1000, 'value'); // sets key → value, with 1s TTL.
- * </pre>
- */
- 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 $value
- *
- * @return bool TRUE in case of success, FALSE in case of failure.
- * @link https://redis.io/commands/setnx
- * @example
- * <pre>
- * $redisCluster->setnx('key', 'value'); // return TRUE
- * $redisCluster->setnx('key', 'value'); // return FALSE
- * </pre>
- */
- public function setnx($key, $value) { }
- /**
- * Sets a value and returns the previous entry at that key.
- *
- * @param string $key
- * @param string $value
- *
- * @return string A string, the previous value located at this key.
- * @link https://redis.io/commands/getset
- * @example
- * <pre>
- * $redisCluster->set('x', '42');
- * $exValue = $redisCluster->getSet('x', 'lol'); // return '42', replaces x by 'lol'
- * $newValue = $redisCluster->get('x'); // return 'lol'
- * </pre>
- */
- public function getSet($key, $value) { }
- /**
- * Verify if the specified key exists.
- *
- * @param string $key
- *
- * @return bool If the key exists, return TRUE, otherwise return FALSE.
- * @link https://redis.io/commands/exists
- * @example
- * <pre>
- * $redisCluster->set('key', 'value');
- * $redisCluster->exists('key'); // TRUE
- * $redisCluster->exists('NonExistingKey'); // FALSE
- * </pre>
- */
- public function exists($key) { }
- /**
- * Returns the keys that match a certain pattern.
- *
- * @param string $pattern pattern, using '*' as a wildcard.
- *
- * @return array of STRING: The keys that match a certain pattern.
- * @link https://redis.io/commands/keys
- * @example
- * <pre>
- * $allKeys = $redisCluster->keys('*'); // all keys will match this.
- * $keyWithUserPrefix = $redisCluster->keys('user*');
- * </pre>
- */
- public function keys($pattern) { }
- /**
- * 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: RedisCluster::REDIS_STRING
- * - set: RedisCluster::REDIS_SET
- * - list: RedisCluster::REDIS_LIST
- * - zset: RedisCluster::REDIS_ZSET
- * - hash: RedisCluster::REDIS_HASH
- * - other: RedisCluster::REDIS_NOT_FOUND
- * @link https://redis.io/commands/type
- * @example $redisCluster->type('key');
- */
- public function type($key) { }
- /**
- * Returns and removes the first element of the list.
- *
- * @param string $key
- *
- * @return string|false if command executed successfully BOOL FALSE in case of failure (empty list)
- * @link https://redis.io/commands/lpop
- * @example
- * <pre>
- * $redisCluster->rPush('key1', 'A');
- * $redisCluster->rPush('key1', 'B');
- * $redisCluster->rPush('key1', 'C');
- * var_dump( $redisCluster->lRange('key1', 0, -1) );
- * // Output:
- * // array(3) {
- * // [0]=> string(1) "A"
- * // [1]=> string(1) "B"
- * // [2]=> string(1) "C"
- * // }
- * $redisCluster->lPop('key1');
- * var_dump( $redisCluster->lRange('key1', 0, -1) );
- * // Output:
- * // array(2) {
- * // [0]=> string(1) "B"
- * // [1]=> string(1) "C"
- * // }
- * </pre>
- */
- public function lPop($key) { }
- /**
- * Returns and removes the last element of the list.
- *
- * @param string $key
- *
- * @return string|false if command executed successfully BOOL FALSE in case of failure (empty list)
- * @link https://redis.io/commands/rpop
- * @example
- * <pre>
- * $redisCluster->rPush('key1', 'A');
- * $redisCluster->rPush('key1', 'B');
- * $redisCluster->rPush('key1', 'C');
- * var_dump( $redisCluster->lRange('key1', 0, -1) );
- * // Output:
- * // array(3) {
- * // [0]=> string(1) "A"
- * // [1]=> string(1) "B"
- * // [2]=> string(1) "C"
- * // }
- * $redisCluster->rPop('key1');
- * var_dump( $redisCluster->lRange('key1', 0, -1) );
- * // Output:
- * // array(2) {
- * // [0]=> string(1) "A"
- * // [1]=> string(1) "B"
- * // }
- * </pre>
- */
- public function rPop($key) { }
- /**
- * 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>
- * $redisCluster->rPush('key1', 'A');
- * $redisCluster->rPush('key1', 'B');
- * $redisCluster->rPush('key1', 'C'); // key1 => [ 'A', 'B', 'C' ]
- * $redisCluster->lGet('key1', 0); // 'A'
- * $redisCluster->lSet('key1', 0, 'X');
- * $redisCluster->lGet('key1', 0); // 'X'
- * </pre>
- */
- public function lSet($key, $index, $value) { }
- /**
- * Removes and returns a random element from the set value at Key.
- *
- * @param string $key
- *
- * @return string "popped" value
- * bool FALSE if set identified by key is empty or doesn't exist.
- * @link https://redis.io/commands/spop
- * @example
- * <pre>
- * $redisCluster->sAdd('key1' , 'set1');
- * $redisCluster->sAdd('key1' , 'set2');
- * $redisCluster->sAdd('key1' , 'set3');
- * var_dump($redisCluster->sMembers('key1'));// 'key1' => {'set3', 'set1', 'set2'}
- * $redisCluster->sPop('key1');// 'set1'
- * var_dump($redisCluster->sMembers('key1'));// 'key1' => {'set3', 'set2'}
- * $redisCluster->sPop('key1');// 'set3',
- * var_dump($redisCluster->sMembers('key1'));// 'key1' => {'set2'}
- * </pre>
- */
- public function sPop($key) { }
- /**
- * 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 $value1 String, value to push in key
- * @param string $value2 Optional
- * @param string $valueN Optional
- *
- * @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>
- * $redisCluster->lPush('l', 'v1', 'v2', 'v3', 'v4') // int(4)
- * var_dump( $redisCluster->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, $value2 = null, $valueN = null) { }
- /**
- * 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 $value1 String, value to push in key
- * @param string $value2 Optional
- * @param string $valueN Optional
- *
- * @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>
- * $redisCluster->rPush('r', 'v1', 'v2', 'v3', 'v4'); // int(4)
- * var_dump( $redisCluster->lRange('r', 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, $value2 = null, $valueN = null) { }
- /**
- * BLPOP is a blocking list pop primitive.
- * It is the blocking version of LPOP because it blocks the connection when
- * there are no elements to pop from any of the given lists.
- * An element is popped from the head of the first list that is non-empty,
- * with the given keys being checked in the order that they are given.
- *
- * @param array $keys Array containing the keys of the lists
- * Or STRING Key1 STRING Key2 STRING Key3 ... STRING Keyn
- * @param int $timeout Timeout
- *
- * @return array array('listName', 'element')
- * @link https://redis.io/commands/blpop
- * @example
- * <pre>
- * // Non blocking feature
- * $redisCluster->lPush('key1', 'A');
- * $redisCluster->del('key2');
- *
- * $redisCluster->blPop('key1', 'key2', 10); // array('key1', 'A')
- * // OR
- * $redisCluster->blPop(array('key1', 'key2'), 10); // array('key1', 'A')
- *
- * $redisCluster->brPop('key1', 'key2', 10); // array('key1', 'A')
- * // OR
- * $redisCluster->brPop(array('key1', 'key2'), 10); // array('key1', 'A')
- *
- * // Blocking feature
- *
- * // process 1
- * $redisCluster->del('key1');
- * $redisCluster->blPop('key1', 10);
- * // blocking for 10 seconds
- *
- * // process 2
- * $redisCluster->lPush('key1', 'A');
- *
- * // process 1
- * // array('key1', 'A') is returned
- * </pre>
- */
- public function blPop(array $keys, $timeout) { }
- /**
- * BRPOP is a blocking list pop primitive.
- * It is the blocking version of RPOP because it blocks the connection when
- * there are no elements to pop from any of the given lists.
- * An element is popped from the tail of the first list that is non-empty,
- * with the given keys being checked in the order that they are given.
- * See the BLPOP documentation(https://redis.io/commands/blpop) for the exact semantics,
- * since BRPOP is identical to BLPOP with the only difference being that
- * it pops elements from the tail of a list instead of popping from the head.
- *
- * @param array $keys Array containing the keys of the lists
- * Or STRING Key1 STRING Key2 STRING Key3 ... STRING Keyn
- * @param int $timeout Timeout
- *
- * @return array array('listName', 'element')
- * @link https://redis.io/commands/brpop
- * @example
- * <pre>
- * // Non blocking feature
- * $redisCluster->lPush('key1', 'A');
- * $redisCluster->del('key2');
- *
- * $redisCluster->blPop('key1', 'key2', 10); // array('key1', 'A')
- * // OR
- * $redisCluster->blPop(array('key1', 'key2'), 10); // array('key1', 'A')
- *
- * $redisCluster->brPop('key1', 'key2', 10); // array('key1', 'A')
- * // OR
- * $redisCluster->brPop(array('key1', 'key2'), 10); // array('key1', 'A')
- *
- * // Blocking feature
- *
- * // process 1
- * $redisCluster->del('key1');
- * $redisCluster->blPop('key1', 10);
- * // blocking for 10 seconds
- *
- * // process 2
- * $redisCluster->lPush('key1', 'A');
- *
- * // process 1
- * // array('key1', 'A') is returned
- * </pre>
- */
- public function brPop(array $keys, $timeout) { }
- /**
- * 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 $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>
- * $redisCluster->del('key1');
- * $redisCluster->rPushx('key1', 'A'); // returns 0
- * $redisCluster->rPush('key1', 'A'); // returns 1
- * $redisCluster->rPushx('key1', 'B'); // returns 2
- * $redisCluster->rPushx('key1', 'C'); // returns 3
- * // key1 now points to the following list: [ 'A', 'B', 'C' ]
- * </pre>
- */
- public function rPushx($key, $value) { }
- /**
- * Adds the string value to the head (left) of the list if the list exists.
- *
- * @param string $key
- * @param string $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>
- * $redisCluster->del('key1');
- * $redisCluster->lPushx('key1', 'A'); // returns 0
- * $redisCluster->lPush('key1', 'A'); // returns 1
- * $redisCluster->lPushx('key1', 'B'); // returns 2
- * $redisCluster->lPushx('key1', 'C'); // returns 3
- * // key1 now points to the following list: [ 'C', 'B', 'A' ]
- * </pre>
- */
- public function lPushx($key, $value) { }
- /**
- * 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 RedisCluster::BEFORE | RedisCluster::AFTER
- * @param string $pivot
- * @param string $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>
- * $redisCluster->del('key1');
- * $redisCluster->lInsert('key1', RedisCluster::AFTER, 'A', 'X'); // 0
- *
- * $redisCluster->lPush('key1', 'A');
- * $redisCluster->lPush('key1', 'B');
- * $redisCluster->lPush('key1', 'C');
- *
- * $redisCluster->lInsert('key1', RedisCluster::BEFORE, 'C', 'X'); // 4
- * $redisCluster->lRange('key1', 0, -1); // array('X', 'C', 'B', 'A')
- *
- * $redisCluster->lInsert('key1', RedisCluster::AFTER, 'C', 'Y'); // 5
- * $redisCluster->lRange('key1', 0, -1); // array('X', 'C', 'Y', 'B', 'A')
- *
- * $redisCluster->lInsert('key1', RedisCluster::AFTER, 'W', 'value'); // -1
- * </pre>
- */
- public function lInsert($key, $position, $pivot, $value) { }
- /**
- * 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 string|false 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>
- * $redisCluster->rPush('key1', 'A');
- * $redisCluster->rPush('key1', 'B');
- * $redisCluster->rPush('key1', 'C'); // key1 => [ 'A', 'B', 'C' ]
- * $redisCluster->lGet('key1', 0); // 'A'
- * $redisCluster->lGet('key1', -1); // 'C'
- * $redisCluster->lGet('key1', 10); // `FALSE`
- * </pre>
- */
- public function lIndex($key, $index) { }
- /**
- * 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 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>
- * $redisCluster->lPush('key1', 'A');
- * $redisCluster->lPush('key1', 'B');
- * $redisCluster->lPush('key1', 'C');
- * $redisCluster->lPush('key1', 'A');
- * $redisCluster->lPush('key1', 'A');
- *
- * $redisCluster->lRange('key1', 0, -1); // array('A', 'A', 'C', 'B', 'A')
- * $redisCluster->lRem('key1', 'A', 2); // 2
- * $redisCluster->lRange('key1', 0, -1); // array('C', 'B', 'A')
- * </pre>
- */
- public function lRem($key, $value, $count) { }
- /**
- * A blocking version of rpoplpush, with an integral timeout in the third parameter.
- *
- * @param string $srcKey
- * @param string $dstKey
- * @param int $timeout
- *
- * @return string|false 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) { }
- /**
- * 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.2
- *
- * @param string $srcKey
- * @param string $dstKey
- *
- * @return string|false The element that was moved in case of success, FALSE in case of failure.
- * @link https://redis.io/commands/rpoplpush
- * @example
- * <pre>
- * $redisCluster->del('x', 'y');
- *
- * $redisCluster->lPush('x', 'abc');
- * $redisCluster->lPush('x', 'def');
- * $redisCluster->lPush('y', '123');
- * $redisCluster->lPush('y', '456');
- *
- * // move the last of x to the front of y.
- * var_dump($redisCluster->rpoplpush('x', 'y'));
- * var_dump($redisCluster->lRange('x', 0, -1));
- * var_dump($redisCluster->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) { }
- /**
- * 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 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>
- * $redisCluster->rPush('key1', 'A');
- * $redisCluster->rPush('key1', 'B');
- * $redisCluster->rPush('key1', 'C'); // key1 => [ 'A', 'B', 'C' ]
- * $redisCluster->lLen('key1'); // 3
- * $redisCluster->rPop('key1');
- * $redisCluster->lLen('key1'); // 2
- * </pre>
- */
- public function lLen($key) { }
- /**
- * Returns the set cardinality (number of elements) of the set stored at key.
- *
- * @param string $key
- *
- * @return int the cardinality (number of elements) of the set, or 0 if key does not exist.
- * @link https://redis.io/commands/scard
- * @example
- * <pre>
- * $redisCluster->sAdd('key1' , 'set1');
- * $redisCluster->sAdd('key1' , 'set2');
- * $redisCluster->sAdd('key1' , 'set3'); // 'key1' => {'set1', 'set2', 'set3'}
- * $redisCluster->sCard('key1'); // 3
- * $redisCluster->sCard('keyX'); // 0
- * </pre>
- */
- public function sCard($key) { }
- /**
- * Returns all the members of the set value stored at key.
- * This has the same effect as running SINTER with one argument key.
- *
- * @param string $key
- *
- * @return array All elements of the set.
- * @link https://redis.io/commands/smembers
- * @example
- * <pre>
- * $redisCluster->del('s');
- * $redisCluster->sAdd('s', 'a');
- * $redisCluster->sAdd('s', 'b');
- * $redisCluster->sAdd('s', 'a');
- * $redisCluster->sAdd('s', 'c');
- * var_dump($redisCluster->sMembers('s'));
- *
- * ////Output:
- * //
- * //array(3) {
- * // [0]=>
- * // string(1) "b"
- * // [1]=>
- * // string(1) "c"
- * // [2]=>
- * // string(1) "a"
- * //}
- * // The order is random and corresponds to redis' own internal representation of the set structure.
- * </pre>
- */
- public function sMembers($key) { }
- /**
- * Returns if member is a member of the set stored at key.
- *
- * @param string $key
- * @param string $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>
- * $redisCluster->sAdd('key1' , 'set1');
- * $redisCluster->sAdd('key1' , 'set2');
- * $redisCluster->sAdd('key1' , 'set3'); // 'key1' => {'set1', 'set2', 'set3'}
- *
- * $redisCluster->sIsMember('key1', 'set1'); // TRUE
- * $redisCluster->sIsMember('key1', 'setX'); // FALSE
- * </pre>
- */
- public function sIsMember($key, $value) { }
- /**
- * Adds a values to the set value stored at key.
- * If this value is already in the set, FALSE is returned.
- *
- * @param string $key Required key
- * @param string $value1 Required value
- * @param string $value2 Optional value
- * @param string $valueN Optional value
- *
- * @return int|false The number of elements added to the set
- * @link https://redis.io/commands/sadd
- * @example
- * <pre>
- * $redisCluster->sAdd('k', 'v1'); // int(1)
- * $redisCluster->sAdd('k', 'v1', 'v2', 'v3'); // int(2)
- * </pre>
- */
- public function sAdd($key, $value1, $value2 = null, $valueN = null) { }
- /**
- * Adds a values to the set value stored at key.
- * If this value is already in the set, FALSE is returned.
- *
- * @param string $key Required key
- * @param array $valueArray
- *
- * @return int|false The number of elements added to the set
- * @example
- * <pre>
- * $redisCluster->sAddArray('k', ['v1', 'v2', 'v3']);
- * //This is a feature in php only. Same as $redisCluster->sAdd('k', 'v1', 'v2', 'v3');
- * </pre>
- */
- public function sAddArray($key, array $valueArray) { }
- /**
- * Removes the specified members from the set value stored at key.
- *
- * @param string $key
- * @param string $member1
- * @param string $member2
- * @param string $memberN
- *
- * @return int The number of elements removed from the set.
- * @link https://redis.io/commands/srem
- * @example
- * <pre>
- * var_dump( $redisCluster->sAdd('k', 'v1', 'v2', 'v3') ); // int(3)
- * var_dump( $redisCluster->sRem('k', 'v2', 'v3') ); // int(2)
- * var_dump( $redisCluster->sMembers('k') );
- * //// Output:
- * // array(1) {
- * // [0]=> string(2) "v1"
- * // }
- * </pre>
- */
- public function sRem($key, $member1, $member2 = null, $memberN = null) { }
- /**
- * Performs the union between N sets and returns it.
- *
- * @param string $key1 Any number of keys corresponding to sets in redis.
- * @param string $key2 ...
- * @param string $keyN ...
- *
- * @return array of strings: The union of all these sets.
- * @link https://redis.io/commands/sunionstore
- * @example
- * <pre>
- * $redisCluster->del('s0', 's1', 's2');
- *
- * $redisCluster->sAdd('s0', '1');
- * $redisCluster->sAdd('s0', '2');
- * $redisCluster->sAdd('s1', '3');
- * $redisCluster->sAdd('s1', '1');
- * $redisCluster->sAdd('s2', '3');
- * $redisCluster->sAdd('s2', '4');
- *
- * var_dump($redisCluster->sUnion('s0', 's1', 's2'));
- *
- * //// Output:
- * //
- * //array(4) {
- * // [0]=>
- * // string(1) "3"
- * // [1]=>
- * // string(1) "4"
- * // [2]=>
- * // string(1) "1"
- * // [3]=>
- * // string(1) "2"
- * //}
- * </pre>
- */
- public function sUnion($key1, $key2, $keyN = null) { }
- /**
- * 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 Any number of keys corresponding to sets in redis.
- * @param string $key2 ...
- * @param string $keyN ...
- *
- * @return int Any number of keys corresponding to sets in redis.
- * @link https://redis.io/commands/sunionstore
- * @example
- * <pre>
- * $redisCluster->del('s0', 's1', 's2');
- *
- * $redisCluster->sAdd('s0', '1');
- * $redisCluster->sAdd('s0', '2');
- * $redisCluster->sAdd('s1', '3');
- * $redisCluster->sAdd('s1', '1');
- * $redisCluster->sAdd('s2', '3');
- * $redisCluster->sAdd('s2', '4');
- *
- * var_dump($redisCluster->sUnionStore('dst', 's0', 's1', 's2'));
- * var_dump($redisCluster->sMembers('dst'));
- *
- * //// Output:
- * //
- * //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, $key2, $keyN = null) { }
- /**
- * 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 $key2 ...
- * @param string $keyN ...
- *
- * @return array 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/sinterstore
- * @example
- * <pre>
- * $redisCluster->sAdd('key1', 'val1');
- * $redisCluster->sAdd('key1', 'val2');
- * $redisCluster->sAdd('key1', 'val3');
- * $redisCluster->sAdd('key1', 'val4');
- *
- * $redisCluster->sAdd('key2', 'val3');
- * $redisCluster->sAdd('key2', 'val4');
- *
- * $redisCluster->sAdd('key3', 'val3');
- * $redisCluster->sAdd('key3', 'val4');
- *
- * var_dump($redisCluster->sInter('key1', 'key2', 'key3'));
- *
- * // Output:
- * //
- * //array(2) {
- * // [0]=>
- * // string(4) "val4"
- * // [1]=>
- * // string(4) "val3"
- * //}
- * </pre>
- */
- public function sInter($key1, $key2, $keyN = null) { }
- /**
- * 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 are intersected as in sInter.
- * @param string $key2 ...
- * @param string $keyN ...
- *
- * @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>
- * $redisCluster->sAdd('key1', 'val1');
- * $redisCluster->sAdd('key1', 'val2');
- * $redisCluster->sAdd('key1', 'val3');
- * $redisCluster->sAdd('key1', 'val4');
- *
- * $redisCluster->sAdd('key2', 'val3');
- * $redisCluster->sAdd('key2', 'val4');
- *
- * $redisCluster->sAdd('key3', 'val3');
- * $redisCluster->sAdd('key3', 'val4');
- *
- * var_dump($redisCluster->sInterStore('output', 'key1', 'key2', 'key3'));
- * var_dump($redisCluster->sMembers('output'));
- *
- * //// Output:
- * //
- * //int(2)
- * //array(2) {
- * // [0]=>
- * // string(4) "val4"
- * // [1]=>
- * // string(4) "val3"
- * //}
- * </pre>
- */
- public function sInterStore($dstKey, $key1, $key2, $keyN = null) { }
- /**
- * Performs the difference between N sets and returns it.
- *
- * @param string $key1 Any number of keys corresponding to sets in redis.
- * @param string $key2 ...
- * @param string $keyN ...
- *
- * @return array of strings: The difference of the first set will all the others.
- * @link https://redis.io/commands/sdiff
- * @example
- * <pre>
- * $redisCluster->del('s0', 's1', 's2');
- *
- * $redisCluster->sAdd('s0', '1');
- * $redisCluster->sAdd('s0', '2');
- * $redisCluster->sAdd('s0', '3');
- * $redisCluster->sAdd('s0', '4');
- *
- * $redisCluster->sAdd('s1', '1');
- * $redisCluster->sAdd('s2', '3');
- *
- * var_dump($redisCluster->sDiff('s0', 's1', 's2'));
- *
- * //// Output:
- * //
- * //array(2) {
- * // [0]=>
- * // string(1) "4"
- * // [1]=>
- * // string(1) "2"
- * //}
- * </pre>
- */
- public function sDiff($key1, $key2, $keyN = null) { }
- /**
- * 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 Any number of keys corresponding to sets in redis
- * @param string $key2 ...
- * @param string $keyN ...
- *
- * @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>
- * $redisCluster->del('s0', 's1', 's2');
- *
- * $redisCluster->sAdd('s0', '1');
- * $redisCluster->sAdd('s0', '2');
- * $redisCluster->sAdd('s0', '3');
- * $redisCluster->sAdd('s0', '4');
- *
- * $redisCluster->sAdd('s1', '1');
- * $redisCluster->sAdd('s2', '3');
- *
- * var_dump($redisCluster->sDiffStore('dst', 's0', 's1', 's2'));
- * var_dump($redisCluster->sMembers('dst'));
- *
- * //// Output:
- * //
- * //int(2)
- * //array(2) {
- * // [0]=>
- * // string(1) "4"
- * // [1]=>
- * // string(1) "2"
- * //}
- * </pre>
- */
- public function sDiffStore($dstKey, $key1, $key2, $keyN = null) { }
- /**
- * Returns a random element(s) from the set value at Key, without removing it.
- *
- * @param string $key
- * @param int $count [optional]
- *
- * @return string|array 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>
- * $redisCluster->sAdd('key1' , 'one');
- * $redisCluster->sAdd('key1' , 'two');
- * $redisCluster->sAdd('key1' , 'three'); // 'key1' => {'one', 'two', 'three'}
- *
- * var_dump( $redisCluster->sRandMember('key1') ); // 'key1' => {'one', 'two', 'three'}
- *
- * // string(5) "three"
- *
- * var_dump( $redisCluster->sRandMember('key1', 2) ); // 'key1' => {'one', 'two', 'three'}
- *
- * // array(2) {
- * // [0]=> string(2) "one"
- * // [1]=> string(2) "three"
- * // }
- * </pre>
- */
- public function sRandMember($key, $count = null) { }
- /**
- * Get the length of a string value.
- *
- * @param string $key
- *
- * @return int
- * @link https://redis.io/commands/strlen
- * @example
- * <pre>
- * $redisCluster->set('key', 'value');
- * $redisCluster->strlen('key'); // 5
- * </pre>
- */
- public function strlen($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 $redisCluster->persist('key');
- */
- public function persist($key) { }
- /**
- * Returns the remaining time to live of a key that has a timeout.
- * This introspection capability allows a Redis client to check how many seconds a given key will continue to be
- * part of the dataset. In Redis 2.6 or older the command returns -1 if the key does not exist or if the key exist
- * but has no associated expire. Starting with Redis 2.8 the return value in case of error changed: Returns -2 if
- * the key does not exist. Returns -1 if the key exists but has no associated expire.
- *
- * @param string $key
- *
- * @return int the time left to live in seconds.
- * @link https://redis.io/commands/ttl
- * @example $redisCluster->ttl('key');
- */
- public function ttl($key) { }
- /**
- * Returns the remaining time to live of a key that has an expire set,
- * with the sole difference that TTL returns the amount of remaining time in seconds while PTTL returns it in
- * milliseconds. In Redis 2.6 or older the command returns -1 if the key does not exist or if the key exist but has
- * no associated expire. Starting with Redis 2.8 the return value in case of error changed: Returns -2 if the key
- * does not exist. Returns -1 if the key exists but has no associated expire.
- *
- * @param string $key
- *
- * @return int the time left to live in milliseconds.
- * @link https://redis.io/commands/pttl
- * @example $redisCluster->pttl('key');
- */
- public function pttl($key) { }
- /**
- * Returns the cardinality of an ordered set.
- *
- * @param string $key
- *
- * @return int the set's cardinality
- * @link https://redis.io/commands/zsize
- * @example
- * <pre>
- * $redisCluster->zAdd('key', 0, 'val0');
- * $redisCluster->zAdd('key', 2, 'val2');
- * $redisCluster->zAdd('key', 10, 'val10');
- * $redisCluster->zCard('key'); // 3
- * </pre>
- */
- public function zCard($key) { }
- /**
- * 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>
- * $redisCluster->zAdd('key', 0, 'val0');
- * $redisCluster->zAdd('key', 2, 'val2');
- * $redisCluster->zAdd('key', 10, 'val10');
- * $redisCluster->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>
- * $redisCluster->zAdd('key', 0, 'val0');
- * $redisCluster->zAdd('key', 2, 'val2');
- * $redisCluster->zAdd('key', 10, 'val10');
- * $redisCluster->zRemRangeByScore('key', 0, 3); // 2
- * </pre>
- */
- public function zRemRangeByScore($key, $start, $end) { }
- /**
- * Returns the score of a given member in the specified sorted set.
- *
- * @param string $key
- * @param string $member
- *
- * @return float
- * @link https://redis.io/commands/zscore
- * @example
- * <pre>
- * $redisCluster->zAdd('key', 2.5, 'val2');
- * $redisCluster->zScore('key', 'val2'); // 2.5
- * </pre>
- */
- public function zScore($key, $member) { }
- /**
- * Adds the specified member with a given score to the sorted set stored at key.
- *
- * @param string $key Required key
- * @param float $score1 Required score
- * @param string $value1 Required value
- * @param float $score2 Optional score
- * @param string $value2 Optional value
- * @param float $scoreN Optional score
- * @param string $valueN Optional value
- *
- * @return int Number of values added
- * @link https://redis.io/commands/zadd
- * @example
- * <pre>
- * $redisCluster->zAdd('z', 1, 'v2', 2, 'v2', 3, 'v3', 4, 'v4' ); // int(3)
- * $redisCluster->zRem('z', 'v2', 'v3'); // int(2)
- * var_dump( $redisCluster->zRange('z', 0, -1) );
- *
- * //// Output:
- * // array(1) {
- * // [0]=> string(2) "v4"
- * // }
- * </pre>
- */
- public function zAdd($key, $score1, $value1, $score2 = null, $value2 = null, $scoreN = null, $valueN = null) { }
- /**
- * 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>
- * $redisCluster->del('key');
- * $redisCluster->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
- * $redisCluster->zIncrBy('key', 1, 'member1'); // 3.5
- * </pre>
- */
- public function zIncrBy($key, $value, $member) { }
- /**
- * 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>
- * $redisCluster->del('h');
- * $redisCluster->hSet('h', 'key1', 'hello');
- * $redisCluster->hSet('h', 'key2', 'plop');
- * $redisCluster->hLen('h'); // returns 2
- * </pre>
- */
- public function hLen($key) { }
- /**
- * 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>
- * $redisCluster->del('h');
- * $redisCluster->hSet('h', 'a', 'x');
- * $redisCluster->hSet('h', 'b', 'y');
- * $redisCluster->hSet('h', 'c', 'z');
- * $redisCluster->hSet('h', 'd', 't');
- * var_dump($redisCluster->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>
- * $redisCluster->del('h');
- * $redisCluster->hSet('h', 'a', 'x');
- * $redisCluster->hSet('h', 'b', 'y');
- * $redisCluster->hSet('h', 'c', 'z');
- * $redisCluster->hSet('h', 'd', 't');
- * var_dump($redisCluster->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) { }
- /**
- * 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
- * @example
- * <pre>
- * $redisCluster->del('h');
- * $redisCluster->hSet('h', 'a', 'x');
- * $redisCluster->hGet('h', 'a'); // 'X'
- * </pre>
- */
- public function hGet($key, $hashKey) { }
- /**
- * 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>
- * $redisCluster->del('h');
- * $redisCluster->hSet('h', 'a', 'x');
- * $redisCluster->hSet('h', 'b', 'y');
- * $redisCluster->hSet('h', 'c', 'z');
- * $redisCluster->hSet('h', 'd', 't');
- * var_dump($redisCluster->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>
- * $redisCluster->hSet('h', 'a', 'x');
- * $redisCluster->hExists('h', 'a'); // TRUE
- * $redisCluster->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>
- * $redisCluster->del('h');
- * $redisCluster->hIncrBy('h', 'x', 2); // returns 2: h[x] = 2 now.
- * $redisCluster->hIncrBy('h', 'x', 1); // h[x] ← 2 + 1. Returns 3
- * </pre>
- */
- public function hIncrBy($key, $hashKey, $value) { }
- /**
- * 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
- * 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>
- * $redisCluster->del('h')
- * $redisCluster->hSet('h', 'key1', 'hello'); // 1, 'key1' => 'hello' in the hash at "h"
- * $redisCluster->hGet('h', 'key1'); // returns "hello"
- *
- * $redisCluster->hSet('h', 'key1', 'plop'); // 0, value was replaced.
- * $redisCluster->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>
- * $redisCluster->del('h')
- * $redisCluster->hSetNx('h', 'key1', 'hello'); // TRUE, 'key1' => 'hello' in the hash at "h"
- * $redisCluster->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) { }
- /**
- * Retirieve 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>
- * $redisCluster->del('h');
- * $redisCluster->hSet('h', 'field1', 'value1');
- * $redisCluster->hSet('h', 'field2', 'value2');
- * $redisCluster->hMGet('h', array('field1', 'field2')); // returns array('field1' => 'value1', 'field2' =>
- * 'value2')
- * </pre>
- */
- public function hMGet($key, $hashKeys) { }
- /**
- * 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>
- * $redisCluster->del('user:1');
- * $redisCluster->hMSet('user:1', array('name' => 'Joe', 'salary' => 2000));
- * $redisCluster->hIncrBy('user:1', 'salary', 100); // Joe earns 100 more now.
- * </pre>
- */
- public function hMSet($key, $hashKeys) { }
- /**
- * 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 $hashKey2
- * @param string $hashKeyN
- *
- * @return int Number of deleted fields
- * @link https://redis.io/commands/hdel
- * @example
- * <pre>
- * $redisCluster->hMSet('h',
- * array(
- * 'f1' => 'v1',
- * 'f2' => 'v2',
- * 'f3' => 'v3',
- * 'f4' => 'v4',
- * ));
- *
- * var_dump( $redisCluster->hDel('h', 'f1') ); // int(1)
- * var_dump( $redisCluster->hDel('h', 'f2', 'f3') ); // int(2)
- *
- * var_dump( $redisCluster->hGetAll('h') );
- *
- * //// Output:
- * //
- * // array(1) {
- * // ["f4"]=> string(2) "v4"
- * // }
- * </pre>
- */
- public function hDel($key, $hashKey1, $hashKey2 = null, $hashKeyN = null) { }
- /**
- * 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>
- * $redisCluster->hset('h', 'float', 3);
- * $redisCluster->hset('h', 'int', 3);
- * var_dump( $redisCluster->hIncrByFloat('h', 'float', 1.5) ); // float(4.5)
- *
- * var_dump( $redisCluster->hGetAll('h') );
- *
- * //// Output:
- * //
- * // array(2) {
- * // ["float"]=>
- * // string(3) "4.5"
- * // ["int"]=>
- * // string(1) "3"
- * // }
- * </pre>
- */
- public function hIncrByFloat($key, $field, $increment) { }
- /**
- * 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>
- * $redisCluster->set('foo', 'bar');
- * $val = $redisCluster->dump('foo'); // $val will be the Redis encoded key value
- * </pre>
- */
- public function dump($key) { }
- /**
- * 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 $member
- *
- * @return int the item's score.
- * @link https://redis.io/commands/zrank
- * @example
- * <pre>
- * $redisCluster->del('z');
- * $redisCluster->zAdd('key', 1, 'one');
- * $redisCluster->zAdd('key', 2, 'two');
- * $redisCluster->zRank('key', 'one'); // 0
- * $redisCluster->zRank('key', 'two'); // 1
- * $redisCluster->zRevRank('key', 'one'); // 1
- * $redisCluster->zRevRank('key', 'two'); // 0
- * </pre>
- */
- public function zRank($key, $member) { }
- /**
- * @see zRank()
- *
- * @param string $key
- * @param string $member
- *
- * @return int the item's score
- * @link https://redis.io/commands/zrevrank
- */
- public function zRevRank($key, $member) { }
- /**
- * Increment the number stored at key by one.
- *
- * @param string $key
- *
- * @return int the new value
- * @link https://redis.io/commands/incr
- * @example
- * <pre>
- * $redisCluster->incr('key1'); // key1 didn't exists, set to 0 before the increment and now has the value 1
- * $redisCluster->incr('key1'); // 2
- * $redisCluster->incr('key1'); // 3
- * $redisCluster->incr('key1'); // 4
- * </pre>
- */
- public function incr($key) { }
- /**
- * Decrement the number stored at key by one.
- *
- * @param string $key
- *
- * @return int the new value
- * @link https://redis.io/commands/decr
- * @example
- * <pre>
- * $redisCluster->decr('key1'); // key1 didn't exists, set to 0 before the increment and now has the value -1
- * $redisCluster->decr('key1'); // -2
- * $redisCluster->decr('key1'); // -3
- * </pre>
- */
- public function decr($key) { }
- /**
- * 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>
- * $redisCluster->incr('key1'); // key1 didn't exists, set to 0 before the increment and now has the value 1
- * $redisCluster->incr('key1'); // 2
- * $redisCluster->incr('key1'); // 3
- * $redisCluster->incr('key1'); // 4
- * $redisCluster->incrBy('key1', 10); // 14
- * </pre>
- */
- public function incrBy($key, $value) { }
- /**
- * 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>
- * $redisCluster->decr('key1'); // key1 didn't exists, set to 0 before the increment and now has the value -1
- * $redisCluster->decr('key1'); // -2
- * $redisCluster->decr('key1'); // -3
- * $redisCluster->decrBy('key1', 10); // -13
- * </pre>
- */
- public function decrBy($key, $value) { }
- /**
- * 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>
- * $redisCluster->set('x', 3);
- * var_dump( $redisCluster->incrByFloat('x', 1.5) ); // float(4.5)
- *
- * var_dump( $redisCluster->get('x') ); // string(3) "4.5"
- * </pre>
- */
- public function incrByFloat($key, $increment) { }
- /**
- * 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>
- * $redisCluster->set('x', '42');
- * $redisCluster->expire('x', 3); // x will disappear in 3 seconds.
- * sleep(5); // wait 5 seconds
- * $redisCluster->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>
- * $redisCluster->set('x', '42');
- * $redisCluster->pExpire('x', 11500); // x will disappear in 11500 milliseconds.
- * $redisCluster->ttl('x'); // 12
- * $redisCluster->pttl('x'); // 11500
- * </pre>
- */
- public function pExpire($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>
- * $redisCluster->set('x', '42');
- * $now = time(); // current timestamp
- * $redisCluster->expireAt('x', $now + 3); // x will disappear in 3 seconds.
- * sleep(5); // wait 5 seconds
- * $redisCluster->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>
- * $redisCluster->set('x', '42');
- * $redisCluster->pExpireAt('x', 1555555555005);
- * $redisCluster->ttl('x'); // 218270121
- * $redisCluster->pttl('x'); // 218270120575
- * </pre>
- */
- public function pExpireAt($key, $timestamp) { }
- /**
- * Append specified string to the string stored in specified key.
- *
- * @param string $key
- * @param string $value
- *
- * @return int Size of the value after the append
- * @link https://redis.io/commands/append
- * @example
- * <pre>
- * $redisCluster->set('key', 'value1');
- * $redisCluster->append('key', 'value2'); // 12
- * $redisCluster->get('key'); // 'value1value2'
- * </pre>
- */
- public function append($key, $value) { }
- /**
- * 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>
- * $redisCluster->set('key', "\x7f"); // this is 0111 1111
- * $redisCluster->getBit('key', 0); // 0
- * $redisCluster->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>
- * $redisCluster->set('key', "*"); // ord("*") = 42 = 0x2f = "0010 1010"
- * $redisCluster->setBit('key', 5, 1); // returns 0
- * $redisCluster->setBit('key', 7, 1); // returns 0
- * $redisCluster->get('key'); // chr(0x2f) = "/" = b("0010 1111")
- * </pre>
- */
- public function setBit($key, $offset, $value) { }
- /**
- * Bitwise operation on multiple keys.
- *
- * @param string $operation either "AND", "OR", "NOT", "XOR"
- * @param string $retKey return key
- * @param string $key1
- * @param string $key2
- * @param string $key3
- *
- * @return int The size of the string stored in the destination key.
- * @link https://redis.io/commands/bitop
- * @example
- * <pre>
- * $redisCluster->set('bit1', '1'); // 11 0001
- * $redisCluster->set('bit2', '2'); // 11 0010
- *
- * $redisCluster->bitOp('AND', 'bit', 'bit1', 'bit2'); // bit = 110000
- * $redisCluster->bitOp('OR', 'bit', 'bit1', 'bit2'); // bit = 110011
- * $redisCluster->bitOp('NOT', 'bit', 'bit1', 'bit2'); // bit = 110011
- * $redisCluster->bitOp('XOR', 'bit', 'bit1', 'bit2'); // bit = 11
- * </pre>
- */
- public function bitOp($operation, $retKey, $key1, $key2, $key3 = null) { }
- /**
- * 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>
- * $redisCluster->set('key', '\xff\xff');
- * $redisCluster->bitpos('key', 1); // int(0)
- * $redisCluster->bitpos('key', 1, 1); // int(8)
- * $redisCluster->bitpos('key', 1, 3); // int(-1)
- * $redisCluster->bitpos('key', 0); // int(16)
- * $redisCluster->bitpos('key', 0, 1); // int(16)
- * $redisCluster->bitpos('key', 0, 1, 5); // int(-1)
- * </pre>
- */
- public function bitpos($key, $bit, $start = 0, $end = null) { }
- /**
- * 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>
- * $redisCluster->set('bit', '345'); // // 11 0011 0011 0100 0011 0101
- * var_dump( $redisCluster->bitCount('bit', 0, 0) ); // int(4)
- * var_dump( $redisCluster->bitCount('bit', 1, 1) ); // int(3)
- * var_dump( $redisCluster->bitCount('bit', 2, 2) ); // int(4)
- * var_dump( $redisCluster->bitCount('bit', 0, 2) ); // int(11)
- * </pre>
- */
- public function bitCount($key) { }
- /**
- * @see lIndex()
- *
- * @param string $key
- * @param int $index
- *
- * @link https://redis.io/commands/lindex
- */
- public function lGet($key, $index) { }
- /**
- * 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>
- * $redisCluster->set('key', 'string value');
- * $redisCluster->getRange('key', 0, 5); // 'string'
- * $redisCluster->getRange('key', -5, -1); // 'value'
- * </pre>
- */
- public function getRange($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>
- * $redisCluster->rPush('key1', 'A');
- * $redisCluster->rPush('key1', 'B');
- * $redisCluster->rPush('key1', 'C');
- * $redisCluster->lRange('key1', 0, -1); // array('A', 'B', 'C')
- * $redisCluster->lTrim('key1', 0, 1);
- * $redisCluster->lRange('key1', 0, -1); // array('A', 'B')
- * </pre>
- */
- public function lTrim($key, $start, $stop) { }
- /**
- * 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>
- * $redisCluster->rPush('key1', 'A');
- * $redisCluster->rPush('key1', 'B');
- * $redisCluster->rPush('key1', 'C');
- * $redisCluster->lRange('key1', 0, -1); // array('A', 'B', 'C')
- * </pre>
- */
- public function lRange($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>
- * $redisCluster->zAdd('key', 1, 'one');
- * $redisCluster->zAdd('key', 2, 'two');
- * $redisCluster->zAdd('key', 3, 'three');
- * $redisCluster->zRemRangeByRank('key', 0, 1); // 2
- * $redisCluster->zRange('key', 0, -1, true); // array('three' => 3)
- * </pre>
- */
- public function zRemRangeByRank($key, $start, $end) { }
- /**
- * 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
- *
- * @link https://redis.io/commands/publish
- * @return int Number of clients that received the message
- * @example $redisCluster->publish('chan-1', 'hello, world!'); // send message.
- */
- public function publish($channel, $message) { }
- /**
- * 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>
- * $redisCluster->set('x', '42');
- * $redisCluster->rename('x', 'y');
- * $redisCluster->get('y'); // → 42
- * $redisCluster->get('x'); // → `FALSE`
- * </pre>
- */
- public function rename($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>
- * $redisCluster->set('x', '42');
- * $redisCluster->renameNx('x', 'y');
- * $redisCluster->get('y'); // → 42
- * $redisCluster->get('x'); // → `FALSE`
- * </pre>
- */
- public function renameNx($srcKey, $dstKey) { }
- /**
- * 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>
- * $redisCluster->pfAdd('key1', array('elem1', 'elem2'));
- * $redisCluster->pfAdd('key2', array('elem3', 'elem2'));
- * $redisCluster->pfCount('key1'); // int(2)
- * $redisCluster->pfCount(array('key1', 'key2')); // int(3)
- */
- public function pfCount($key) { }
- /**
- * 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 $redisCluster->pfAdd('key', array('elem1', 'elem2'))
- */
- public function pfAdd($key, array $elements) { }
- /**
- * 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>
- * $redisCluster->pfAdd('key1', array('elem1', 'elem2'));
- * $redisCluster->pfAdd('key2', array('elem3', 'elem2'));
- * $redisCluster->pfMerge('key3', array('key1', 'key2'));
- * $redisCluster->pfCount('key3'); // int(3)
- */
- public function pfMerge($destKey, array $sourceKeys) { }
- /**
- * Changes a substring of a larger string.
- *
- * @param string $key
- * @param int $offset
- * @param string $value
- *
- * @return string the length of the string after it was modified.
- * @link https://redis.io/commands/setrange
- * @example
- * <pre>
- * $redisCluster->set('key', 'Hello world');
- * $redisCluster->setRange('key', 6, "redis"); // returns 11
- * $redisCluster->get('key'); // "Hello redis"
- * </pre>
- */
- public function setRange($key, $offset, $value) { }
- /**
- * 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>
- * $redisCluster->set('foo', 'bar');
- * $val = $redisCluster->dump('foo');
- * $redisCluster->restore('bar', 0, $val); // The key 'bar', will now be equal to the key 'foo'
- * </pre>
- */
- public function restore($key, $ttl, $value) { }
- /**
- * Moves the specified member from the set at srcKey to the set at dstKey.
- *
- * @param string $srcKey
- * @param string $dstKey
- * @param string $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>
- * $redisCluster->sAdd('key1' , 'set11');
- * $redisCluster->sAdd('key1' , 'set12');
- * $redisCluster->sAdd('key1' , 'set13'); // 'key1' => {'set11', 'set12', 'set13'}
- * $redisCluster->sAdd('key2' , 'set21');
- * $redisCluster->sAdd('key2' , 'set22'); // 'key2' => {'set21', 'set22'}
- * $redisCluster->sMove('key1', 'key2', 'set13'); // 'key1' => {'set11', 'set12'}
- * // 'key2' => {'set21', 'set22', 'set13'}
- * </pre>
- */
- public function sMove($srcKey, $dstKey, $member) { }
- /**
- * 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>
- * $redisCluster->zAdd('key1', 0, 'val0');
- * $redisCluster->zAdd('key1', 2, 'val2');
- * $redisCluster->zAdd('key1', 10, 'val10');
- * $redisCluster->zRange('key1', 0, -1); // array('val0', 'val2', 'val10')
- * // with scores
- * $redisCluster->zRange('key1', 0, -1, true); // array('val0' => 0, 'val2' => 2, 'val10' => 10)
- * </pre>
- */
- public function zRange($key, $start, $end, $withscores = null) { }
- /**
- * 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>
- * $redisCluster->zAdd('key', 0, 'val0');
- * $redisCluster->zAdd('key', 2, 'val2');
- * $redisCluster->zAdd('key', 10, 'val10');
- * $redisCluster->zRevRange('key', 0, -1); // array('val10', 'val2', 'val0')
- *
- * // with scores
- * $redisCluster->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>
- * $redisCluster->zAdd('key', 0, 'val0');
- * $redisCluster->zAdd('key', 2, 'val2');
- * $redisCluster->zAdd('key', 10, 'val10');
- * $redisCluster->zRangeByScore('key', 0, 3);
- * // array('val0', 'val2')
- * $redisCluster->zRangeByScore('key', 0, 3, array('withscores' => TRUE);
- * // array('val0' => 0, 'val2' => 2)
- * $redisCluster->zRangeByScore('key', 0, 3, array('limit' => array(1, 1));
- * // array('val2' => 2)
- * $redisCluster->zRangeByScore('key', 0, 3, array('limit' => array(1, 1));
- * // array('val2')
- * $redisCluster->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 range of members in a sorted set, by lexicographical range
- *
- * @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 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 $k => $char) {
- * $redisCluster->zAdd('key', $k, $char);
- * }
- *
- * $redisCluster->zRangeByLex('key', '-', '[c'); // array('a', 'b', 'c')
- * $redisCluster->zRangeByLex('key', '-', '(c'); // array('a', 'b')
- * $redisCluster->zRevRangeByLex('key', '(c','-'); // array('b', 'a')
- * </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) { }
- /**
- * Count the number of members in a sorted set between a given lexicographical range.
- *
- * @param string $key
- * @param int $min
- * @param int $max
- *
- * @return int The number of elements in the specified score range.
- * @link https://redis.io/commands/zlexcount
- * @example
- * <pre>
- * foreach (array('a', 'b', 'c', 'd', 'e', 'f', 'g') as $k => $char) {
- * $redisCluster->zAdd('key', $k, $char);
- * }
- * $redisCluster->zLexCount('key', '[b', '[f'); // 5
- * </pre>
- */
- public function zLexCount($key, $min, $max) { }
- /**
- * Remove all members in a sorted set between the given lexicographical range.
- *
- * @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.
- *
- * @return array the number of elements removed.
- * @link https://redis.io/commands/zremrangebylex
- * @example
- * <pre>
- * foreach (array('a', 'b', 'c', 'd', 'e', 'f', 'g') as $k => $char) {
- * $redisCluster->zAdd('key', $k, $char);
- * }
- * $redisCluster->zRemRangeByLex('key', '(b','[d'); // 2 , remove element 'c' and 'd'
- * $redisCluster->zRange('key',0,-1);// array('a','b','e','f','g')
- * </pre>
- */
- public function zRemRangeByLex($key, $min, $max) {
- }
- /**
- * Add multiple sorted sets and store the resulting sorted set in a new key
- *
- * @param string $Output
- * @param array $ZSetKeys
- * @param array $Weights
- * @param string $aggregateFunction Either "SUM", "MIN", or "MAX": defines the behaviour to use on
- * duplicate entries during the zUnion.
- *
- * @return int The number of values in the new sorted set.
- * @link https://redis.io/commands/zunionstore
- * @example
- * <pre>
- * $redisCluster->del('k1');
- * $redisCluster->del('k2');
- * $redisCluster->del('k3');
- * $redisCluster->del('ko1');
- * $redisCluster->del('ko2');
- * $redisCluster->del('ko3');
- *
- * $redisCluster->zAdd('k1', 0, 'val0');
- * $redisCluster->zAdd('k1', 1, 'val1');
- *
- * $redisCluster->zAdd('k2', 2, 'val2');
- * $redisCluster->zAdd('k2', 3, 'val3');
- *
- * $redisCluster->zUnionStore('ko1', array('k1', 'k2')); // 4, 'ko1' => array('val0', 'val1', 'val2', 'val3')
- *
- * // Weighted zUnionStore
- * $redisCluster->zUnionStore('ko2', array('k1', 'k2'), array(1, 1)); // 4, 'ko2' => array('val0', 'val1', 'val2','val3')
- * $redisCluster->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') { }
- /**
- * Intersect multiple sorted sets and store the resulting sorted set in a new key
- *
- * @param string $Output
- * @param array $ZSetKeys
- * @param 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>
- * $redisCluster->del('k1');
- * $redisCluster->del('k2');
- * $redisCluster->del('k3');
- *
- * $redisCluster->del('ko1');
- * $redisCluster->del('ko2');
- * $redisCluster->del('ko3');
- * $redisCluster->del('ko4');
- *
- * $redisCluster->zAdd('k1', 0, 'val0');
- * $redisCluster->zAdd('k1', 1, 'val1');
- * $redisCluster->zAdd('k1', 3, 'val3');
- *
- * $redisCluster->zAdd('k2', 2, 'val1');
- * $redisCluster->zAdd('k2', 3, 'val3');
- *
- * $redisCluster->zInterStore('ko1', array('k1', 'k2')); // 2, 'ko1' => array('val1', 'val3')
- * $redisCluster->zInterStore('ko2', array('k1', 'k2'), array(1, 1)); // 2, 'ko2' => array('val1', 'val3')
- *
- * // Weighted zInterStore
- * $redisCluster->zInterStore('ko3', array('k1', 'k2'), array(1, 5), 'min'); // 2, 'ko3' => array('val1', 'val3')
- * $redisCluster->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') { }
- /**
- * Deletes a specified member from the ordered set.
- *
- * @param string $key
- * @param string $member1
- * @param string $member2
- * @param string $memberN
- *
- * @return int Number of deleted values
- * @link https://redis.io/commands/zrem
- * @example
- * <pre>
- * $redisCluster->zAdd('z', 1, 'v1', 2, 'v2', 3, 'v3', 4, 'v4' ); // int(2)
- * $redisCluster->zRem('z', 'v2', 'v3'); // int(2)
- * var_dump( $redisCluster->zRange('z', 0, -1) );
- * //// Output:
- * //
- * // array(2) {
- * // [0]=> string(2) "v1"
- * // [1]=> string(2) "v4"
- * // }
- * </pre>
- */
- public function zRem($key, $member1, $member2 = null, $memberN = null) { }
- /**
- * 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>
- * $redisCluster->del('s');
- * $redisCluster->sadd('s', 5);
- * $redisCluster->sadd('s', 4);
- * $redisCluster->sadd('s', 2);
- * $redisCluster->sadd('s', 1);
- * $redisCluster->sadd('s', 3);
- *
- * var_dump($redisCluster->sort('s')); // 1,2,3,4,5
- * var_dump($redisCluster->sort('s', array('sort' => 'desc'))); // 5,4,3,2,1
- * var_dump($redisCluster->sort('s', array('sort' => 'desc', 'store' => 'out'))); // (int)5
- * </pre>
- */
- public function sort($key, $option = 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|false for "encoding", int for "refcount" and "idletime", FALSE if the key doesn't exist.
- * @link https://redis.io/commands/object
- * @example
- * <pre>
- * $redisCluster->object("encoding", "l"); // → ziplist
- * $redisCluster->object("refcount", "l"); // → 1
- * $redisCluster->object("idletime", "l"); // → 400 (in seconds, with a precision of 10 seconds).
- * </pre>
- */
- public function object($string = '', $key = '') { }
- /**
- * Subscribe to channels. Warning: this function will probably change in the future.
- *
- * @param array $channels an array of channels to subscribe to
- * @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 Any non-null return value in the callback will be returned to the caller.
- * @link https://redis.io/commands/subscribe
- * @example
- * <pre>
- * function f($redisCluster, $chan, $msg) {
- * switch($chan) {
- * case 'chan-1':
- * ...
- * break;
- *
- * case 'chan-2':
- * ...
- * break;
- *
- * case 'chan-2':
- * ...
- * break;
- * }
- * }
- *
- * $redisCluster->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 The number of elements removed from the set.
- * @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)
- *
- * @return 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($redisCluster, $pattern, $chan, $msg) {
- * echo "Pattern: $pattern\n";
- * echo "Channel: $chan\n";
- * echo "Payload: $msg\n";
- * }
- * </pre>
- */
- public function psubscribe($patterns, $callback) { }
- /**
- * Unsubscribes the client from the given channels, or from all of them if none is given.
- *
- * @param $channels
- * @param $callback
- */
- public function unSubscribe($channels, $callback) { }
- /**
- * Unsubscribes the client from the given patterns, or from all of them if none is given.
- *
- * @param $channels
- * @param $callback
- */
- public function punSubscribe($channels, $callback) { }
- /**
- * 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 = $redisCluster->script('load', $script);
- * $redisCluster->evalSha($sha); // Returns 1
- * </pre>
- */
- public function evalSha($scriptSha, $args = array(), $numKeys = 0) { }
- /**
- * Scan the keyspace for keys.
- *
- * @param int &$iterator Iterator, initialized to NULL.
- * @param string|array $node Node identified by key or host/port array
- * @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($keys = $redisCluster->scan($iterator)) {
- * foreach($keys as $key) {
- * echo $key . PHP_EOL;
- * }
- * }
- * </pre>
- */
- public function scan(&$iterator, $node, $pattern = null, $count = 0) { }
- /**
- * Scan a set for members.
- *
- * @param string $key The set to search.
- * @param int $iterator LONG (reference) to the iterator as we go.
- * @param null $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 = $redisCluster->sScan('set', $iterator)) {
- * foreach ($members as $member) {
- * echo $member . PHP_EOL;
- * }
- * }
- * </pre>
- */
- public function sScan($key, &$iterator, $pattern = null, $count = 0) { }
- /**
- * 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) { }
- /**
- * 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 = $redisCluster->hscan('hash', $iterator)) {
- * foreach($elements as $key => $value) {
- * echo $key . ' => ' . $value . PHP_EOL;
- * }
- * }
- * </pre>
- */
- public function hScan($key, &$iterator, $pattern = null, $count = 0) { }
- /**
- * Detect whether we're in ATOMIC/MULTI/PIPELINE mode.
- *
- * @return int Either RedisCluster::ATOMIC, RedisCluster::MULTI or RedisCluster::PIPELINE
- * @example $redisCluster->getMode();
- */
- public function getMode() { }
- /**
- * 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>
- * $redisCluster->eval('this-is-not-lua');
- * $err = $redisCluster->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>
- * $redisCluster->set('x', 'a');
- * $redisCluster->incr('x');
- * $err = $redisCluster->getLastError();
- * // "ERR value is not an integer or out of range"
- * $redisCluster->clearLastError();
- * $err = $redisCluster->getLastError();
- * // NULL
- * </pre>
- */
- public function clearLastError() { }
- /**
- * Get client option
- *
- * @param string $name parameter name
- *
- * @return int Parameter value.
- * @example
- * // return RedisCluster::SERIALIZER_NONE, RedisCluster::SERIALIZER_PHP, or RedisCluster::SERIALIZER_IGBINARY.
- * $redisCluster->getOption(RedisCluster::OPT_SERIALIZER);
- */
- public function getOption($name) { }
- /**
- * Set client option.
- *
- * @param string $name parameter name
- * @param string $value parameter value
- *
- * @return bool TRUE on success, FALSE on error.
- * @example
- * <pre>
- * $redisCluster->setOption(RedisCluster::OPT_SERIALIZER, RedisCluster::SERIALIZER_NONE); // don't serialize data
- * $redisCluster->setOption(RedisCluster::OPT_SERIALIZER, RedisCluster::SERIALIZER_PHP); // use built-in serialize/unserialize
- * $redisCluster->setOption(RedisCluster::OPT_SERIALIZER, RedisCluster::SERIALIZER_IGBINARY); // use igBinary serialize/unserialize
- * $redisCluster->setOption(RedisCluster::OPT_PREFIX, 'myAppName:'); // use custom prefix on all keys
- * </pre>
- */
- public function setOption($name, $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>
- * $redisCluster->setOption(RedisCluster::OPT_PREFIX, 'my-prefix:');
- * $redisCluster->_prefix('my-value'); // Will return 'my-prefix:my-value'
- * </pre>
- */
- public function _prefix($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>
- * $redisCluster->setOption(RedisCluster::OPT_SERIALIZER, RedisCluster::SERIALIZER_NONE);
- * $redisCluster->_serialize("foo"); // returns "foo"
- * $redisCluster->_serialize(Array()); // Returns "Array"
- * $redisCluster->_serialize(new stdClass()); // Returns "Object"
- *
- * $redisCluster->setOption(RedisCluster::OPT_SERIALIZER, RedisCluster::SERIALIZER_PHP);
- * $redisCluster->_serialize("foo"); // Returns 's:3:"foo";'
- * </pre>
- */
- public function _serialize($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>
- * $redisCluster->setOption(RedisCluster::OPT_SERIALIZER, RedisCluster::SERIALIZER_PHP);
- * $redisCluster->_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) { }
- /**
- * Return all redis master nodes
- *
- * @return array
- * @example
- * <pre>
- * $redisCluster->_masters(); // Will return [[0=>'127.0.0.1','6379'],[0=>'127.0.0.1','6380']]
- * </pre>
- */
- public function _masters() { }
- /**
- * Enter and exit transactional mode.
- *
- * @param int $mode RedisCluster::MULTI|RedisCluster::PIPELINE
- * Defaults to RedisCluster::MULTI.
- * A RedisCluster::MULTI block of commands runs as a single transaction;
- * a RedisCluster::PIPELINE block is simply transmitted faster to the server, but without any guarantee
- * of atomicity. discard cancels a transaction.
- *
- * @return Redis 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 = $redisCluster->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 = RedisCluster::MULTI) { }
- /**
- * @see multi()
- * @return void|array
- * @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|array $key : a list of keys
- *
- * @return void
- * @link https://redis.io/commands/watch
- * @example
- * <pre>
- * $redisCluster->watch('x');
- * // long code here during the execution of which other clients could well modify `x`
- * $ret = $redisCluster->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() { }
- /**
- * Performs a synchronous save at a specific node.
- *
- * @param string|array $nodeParams key or [host,port]
- *
- * @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
- * $redisCluster->save('x'); //key
- * $redisCluster->save(['127.0.0.1',6379]); //[host,port]
- */
- public function save($nodeParams) { }
- /**
- * Performs a background save at a specific node.
- *
- * @param string|array $nodeParams key or [host,port]
- *
- * @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
- */
- public function bgsave($nodeParams) { }
- /**
- * Removes all entries from the current database at a specific node.
- *
- * @param string|array $nodeParams key or [host,port]
- *
- * @return bool Always TRUE.
- * @link https://redis.io/commands/flushdb
- */
- public function flushDB($nodeParams) { }
- /**
- * Removes all entries from all databases at a specific node.
- *
- * @param string|array $nodeParams key or [host,port]
- *
- * @return bool Always TRUE.
- * @link https://redis.io/commands/flushall
- */
- public function flushAll($nodeParams) { }
- /**
- * Returns the current database's size at a specific node.
- *
- * @param string|array $nodeParams key or [host,port]
- *
- * @return int DB size, in number of keys.
- * @link https://redis.io/commands/dbsize
- * @example
- * <pre>
- * $count = $redisCluster->dbSize('x');
- * echo "Redis has $count keys\n";
- * </pre>
- */
- public function dbSize($nodeParams) { }
- /**
- * Starts the background rewrite of AOF (Append-Only File) at a specific node.
- *
- * @param string|array $nodeParams key or [host,port]
- *
- * @return bool TRUE in case of success, FALSE in case of failure.
- * @link https://redis.io/commands/bgrewriteaof
- * @example $redisCluster->bgrewriteaof('x');
- */
- public function bgrewriteaof($nodeParams) { }
- /**
- * Returns the timestamp of the last disk save at a specific node.
- *
- * @param string|array $nodeParams key or [host,port]
- *
- * @return int timestamp.
- * @link https://redis.io/commands/lastsave
- * @example $redisCluster->lastSave('x');
- */
- public function lastSave($nodeParams) { }
- /**
- * 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
- * - 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>
- * $redisCluster->info();
- *
- * or
- *
- * $redisCluster->info("COMMANDSTATS"); //Information on the commands that have been run (>=2.6 only)
- * $redisCluster->info("CPU"); // just CPU information from Redis INFO
- * </pre>
- */
- public function info($option = null) { }
- /**
- * @since redis >= 2.8.12.
- * Returns the role of the instance in the context of replication
- *
- * @param string|array $nodeParams key or [host,port]
- *
- * @return array
- * @link https://redis.io/commands/role
- * @example
- * <pre>
- * $redisCluster->role(['127.0.0.1',6379]);
- * // [ 0=>'master',1 => 3129659, 2 => [ ['127.0.0.1','9001','3129242'], ['127.0.0.1','9002','3129543'] ] ]
- * </pre>
- */
- public function role($nodeParams) { }
- /**
- * Returns a random key at the specified node
- *
- * @param string|array $nodeParams key or [host,port]
- *
- * @return string an existing key in redis.
- * @link https://redis.io/commands/randomkey
- * @example
- * <pre>
- * $key = $redisCluster->randomKey('x');
- * $surprise = $redisCluster->get($key); // who knows what's in there.
- * </pre>
- */
- public function randomKey($nodeParams) { }
- /**
- * Return the specified node server time.
- *
- * @param string|array $nodeParams key or [host,port]
- *
- * @return array If successfully, 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( $redisCluster->time('x') );
- * //// Output:
- * //
- * // array(2) {
- * // [0] => string(10) "1342364352"
- * // [1] => string(6) "253002"
- * // }
- * </pre>
- */
- public function time($nodeParams) { }
- /**
- * Check the specified node status
- *
- * @param string|array $nodeParams key or [host,port]
- *
- * @return string STRING: +PONG on success. Throws a RedisException object on connectivity error, as described
- * above.
- * @link https://redis.io/commands/ping
- */
- public function ping($nodeParams) { }
- /**
- * Returns message.
- *
- * @param string|array $nodeParams key or [host,port]
- * @param string $msg
- *
- * @return mixed
- */
- public function echo ($nodeParams, $msg) { }
- /**
- * Returns Array reply of details about all Redis Cluster commands.
- *
- * @return mixed array | bool
- */
- public function command() { }
- /**
- * Send arbitrary things to the redis server at the specified node
- *
- * @param string|array $nodeParams key or [host,port]
- * @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
- */
- public function rawCommand($nodeParams, $command, $arguments) { }
- /**
- * @since redis >= 3.0
- * Executes cluster command
- *
- * @param string|array $nodeParams key or [host,port]
- * @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
- * @link https://redis.io/commands#cluster
- * @example
- * <pre>
- * $redisCluster->cluster(['127.0.0.1',6379],'INFO');
- * </pre>
- */
- public function cluster($nodeParams, $command, $arguments) { }
- /**
- * Allows you to get information of the cluster client
- *
- * @param string|array $nodeParams key or [host,port]
- * @param string $subCmd can be: 'LIST', 'KILL', 'GETNAME', or 'SETNAME'
- * @param string $args optional arguments
- */
- public function client($nodeParams, $subCmd, $args) { }
- /**
- * Get or Set the redis config keys.
- *
- * @param string|array $nodeParams key or [host,port]
- * @param string $operation either `GET` or `SET`
- * @param string $key for `SET`, glob-pattern for `GET`. See https://redis.io/commands/config-get for examples.
- * @param string $value optional string (only for `SET`)
- *
- * @return array Associative array for `GET`, key -> value
- * @link https://redis.io/commands/config-get
- * @link https://redis.io/commands/config-set
- * @example
- * <pre>
- * $redisCluster->config(['127.0.0.1',6379], "GET", "*max-*-entries*");
- * $redisCluster->config(['127.0.0.1',6379], "SET", "dir", "/var/run/redis/dumps/");
- * </pre>
- */
- public function config($nodeParams, $operation, $key, $value) { }
- /**
- * A command allowing you to get information on the Redis pub/sub system.
- *
- * @param string|array $nodeParams key or [host,port]
- *
- * @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>
- * $redisCluster->pubsub(['127.0.0.1',6379], 'channels'); // All channels
- * $redisCluster->pubsub(['127.0.0.1',6379], 'channels', '*pattern*'); // Just channels matching your pattern
- * $redisCluster->pubsub(['127.0.0.1',6379], 'numsub', array('chan1', 'chan2')); // Get subscriber counts for
- * 'chan1' and 'chan2'
- * $redisCluster->pubsub(['127.0.0.1',6379], 'numpat'); // Get the number of pattern subscribers
- * </pre>
- */
- public function pubsub($nodeParams, $keyword, $argument) { }
- /**
- * Execute the Redis SCRIPT command to perform various operations on the scripting subsystem.
- *
- * @param string|array $nodeParams key or [host,port]
- * @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>
- * $redisCluster->script(['127.0.0.1',6379], 'load', $script);
- * $redisCluster->script(['127.0.0.1',6379], 'flush');
- * $redisCluster->script(['127.0.0.1',6379], 'kill');
- * $redisCluster->script(['127.0.0.1',6379], '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($nodeParams, $command, $script) { }
- /**
- * This function is used in order to read and reset the Redis slow queries log.
- *
- * @param string|array $nodeParams key or [host,port]
- * @param string $command
- * @param mixed $argument
- *
- * @link https://redis.io/commands/slowlog
- * @example
- * <pre>
- * $redisCluster->slowLog(['127.0.0.1',6379],'get','2');
- * </pre>
- */
- public function slowLog($nodeParams, $command, $argument) { }
- /**
- * Add one or more geospatial items in the geospatial index represented using a sorted set
- *
- * @param string $key
- * @param float $longitude
- * @param float $latitude
- * @param string $member
- *
- * @link https://redis.io/commands/geoadd
- * @example
- * <pre>
- * $redisCluster->geoAdd('Sicily', 13.361389, 38.115556, 'Palermo'); // int(1)
- * $redisCluster->geoAdd('Sicily', 15.087269, 37.502669, "Catania"); // int(1)
- * </pre>
- */
- public function geoAdd($key, $longitude, $latitude, $member) { }
- /**
- * Returns members of a geospatial index as standard geohash strings
- *
- * @param $key string
- * @param $member1 string
- * @param $member2 string
- * @param $memberN string
- *
- * @example
- * <pre>
- * $redisCluster->geoAdd('Sicily', 13.361389, 38.115556, 'Palermo'); // int(1)
- * $redisCluster->geoAdd('Sicily', 15.087269, 37.502669, "Catania"); // int(1)
- * $redisCluster->geohash('Sicily','Palermo','Catania');//['sqc8b49rny0','sqdtr74hyu0']
- * </pre>
- */
- public function geohash($key, $member1, $member2 = null, $memberN = null) { }
- /**
- * Returns longitude and latitude of members of a geospatial index
- *
- * @param $key string
- * @param $member1 string
- * @param $member2 string
- * @param $memberN string
- *
- * @example
- * <pre>
- * $redisCluster->geoAdd('Sicily', 15.087269, 37.502669, "Catania"); // int(1)
- * $redisCluster->geopos('Sicily','Palermo');//[['13.36138933897018433','38.11555639549629859']]
- * </pre>
- */
- public function geopos($key, $member1, $member2 = null, $memberN = null) { }
- /**
- *
- * Returns the distance between two members of a geospatial index
- *
- * @param string $key
- * @param string $member1
- * @param string $member2
- * @param string $unit The unit must be one of the following, and defaults to meters:
- * m for meters.
- * km for kilometers.
- * mi for miles.
- * ft for feet.
- *
- * @link https://redis.io/commands/geoadd
- * @example
- * <pre>
- * $redisCluster->geoAdd('Sicily', 13.361389, 38.115556, 'Palermo'); // int(1)
- * $redisCluster->geoAdd('Sicily', 15.087269, 37.502669, "Catania"); // int(1)
- * $redisCluster->geoDist('Sicily', 'Palermo' ,'Catania'); // float(166274.1516)
- * $redisCluster->geoDist('Sicily', 'Palermo','Catania', 'km'); // float(166.2742)
- * </pre>
- */
- public function geoDist($key, $member1, $member2, $unit = 'm') { }
- /**
- * Query a sorted set representing a geospatial index to fetch members matching a given maximum distance from a point
- *
- * @param string $key
- * @param float $longitude
- * @param float $latitude
- * @param float $radius
- * @param string $radiusUnit String can be: "m" for meters; "km" for kilometers , "mi" for miles, or "ft" for feet.
- * @param array $options
- *
- * @link https://redis.io/commands/georadius
- * @example
- * <pre>
- * $redisCluster->del('Sicily');
- * $redisCluster->geoAdd('Sicily', 12.361389, 35.115556, 'Palermo'); // int(1)
- * $redisCluster->geoAdd('Sicily', 15.087269, 37.502669, "Catania"); // int(1)
- * $redisCluster->geoAdd('Sicily', 13.3585, 35.330022, "Agrigento"); // int(1)
- *
- * var_dump( $redisCluster->geoRadius('Sicily',13.3585, 35.330022, 300, 'km', ['WITHDIST' ,'DESC']) );
- *
- * array(3) {
- * [0]=>
- * array(2) {
- * [0]=>
- * string(7) "Catania"
- * [1]=>
- * string(8) "286.9362"
- * }
- * [1]=>
- * array(2) {
- * [0]=>
- * string(7) "Palermo"
- * [1]=>
- * string(7) "93.6874"
- * }
- * [2]=>
- * array(2) {
- * [0]=>
- * string(9) "Agrigento"
- * [1]=>
- * string(6) "0.0002"
- * }
- * }
- * var_dump( $redisCluster->geoRadiusByMember('Sicily','Agrigento', 100, 'km', ['WITHDIST' ,'DESC']) );
- *
- * * array(2) {
- * [0]=>
- * array(2) {
- * [0]=>
- * string(7) "Palermo"
- * [1]=>
- * string(7) "93.6872"
- * }
- * [1]=>
- * array(2) {
- * [0]=>
- * string(9) "Agrigento"
- * [1]=>
- * string(6) "0.0000"
- * }
- * }
- *
- * <pre>
- */
- public function geoRadius($key, $longitude, $latitude, $radius, $radiusUnit, array $options) { }
- /**
- * Query a sorted set representing a geospatial index to fetch members matching a given maximum distance from a member
- *
- * @see geoRadius
- *
- * @param string $key
- * @param string $member
- * @param float $radius
- * @param string $radiusUnit
- * @param array $options
- */
- public function geoRadiusByMember($key, $member, $radius, $radiusUnit, array $options) { }
- }
- class RedisClusterException extends Exception {}
|