ACL: introduce the concept of command ID.

This commit is contained in:
antirez 2019-01-09 17:20:47 +01:00
parent 42271cff2d
commit 91f1d8026b
2 changed files with 207 additions and 201 deletions

View File

@ -90,6 +90,7 @@ volatile unsigned long lru_clock; /* Server global current LRU time. */
* in MSET the step is two since arguments are key,val,key,val,...
* microseconds: microseconds of total execution time for this command.
* calls: total number of calls of this command.
* id: command bit identifier for ACLs.
*
* The flags, microseconds and calls fields are computed by Redis and should
* always be set to zero.
@ -125,207 +126,207 @@ volatile unsigned long lru_clock; /* Server global current LRU time. */
* are not fast commands.
*/
struct redisCommand redisCommandTable[] = {
{"module",moduleCommand,-2,"as",0,NULL,0,0,0,0,0},
{"get",getCommand,2,"rF",0,NULL,1,1,1,0,0},
{"set",setCommand,-3,"wm",0,NULL,1,1,1,0,0},
{"setnx",setnxCommand,3,"wmF",0,NULL,1,1,1,0,0},
{"setex",setexCommand,4,"wm",0,NULL,1,1,1,0,0},
{"psetex",psetexCommand,4,"wm",0,NULL,1,1,1,0,0},
{"append",appendCommand,3,"wm",0,NULL,1,1,1,0,0},
{"strlen",strlenCommand,2,"rF",0,NULL,1,1,1,0,0},
{"del",delCommand,-2,"w",0,NULL,1,-1,1,0,0},
{"unlink",unlinkCommand,-2,"wF",0,NULL,1,-1,1,0,0},
{"exists",existsCommand,-2,"rF",0,NULL,1,-1,1,0,0},
{"setbit",setbitCommand,4,"wm",0,NULL,1,1,1,0,0},
{"getbit",getbitCommand,3,"rF",0,NULL,1,1,1,0,0},
{"bitfield",bitfieldCommand,-2,"wm",0,NULL,1,1,1,0,0},
{"setrange",setrangeCommand,4,"wm",0,NULL,1,1,1,0,0},
{"getrange",getrangeCommand,4,"r",0,NULL,1,1,1,0,0},
{"substr",getrangeCommand,4,"r",0,NULL,1,1,1,0,0},
{"incr",incrCommand,2,"wmF",0,NULL,1,1,1,0,0},
{"decr",decrCommand,2,"wmF",0,NULL,1,1,1,0,0},
{"mget",mgetCommand,-2,"rF",0,NULL,1,-1,1,0,0},
{"rpush",rpushCommand,-3,"wmF",0,NULL,1,1,1,0,0},
{"lpush",lpushCommand,-3,"wmF",0,NULL,1,1,1,0,0},
{"rpushx",rpushxCommand,-3,"wmF",0,NULL,1,1,1,0,0},
{"lpushx",lpushxCommand,-3,"wmF",0,NULL,1,1,1,0,0},
{"linsert",linsertCommand,5,"wm",0,NULL,1,1,1,0,0},
{"rpop",rpopCommand,2,"wF",0,NULL,1,1,1,0,0},
{"lpop",lpopCommand,2,"wF",0,NULL,1,1,1,0,0},
{"brpop",brpopCommand,-3,"ws",0,NULL,1,-2,1,0,0},
{"brpoplpush",brpoplpushCommand,4,"wms",0,NULL,1,2,1,0,0},
{"blpop",blpopCommand,-3,"ws",0,NULL,1,-2,1,0,0},
{"llen",llenCommand,2,"rF",0,NULL,1,1,1,0,0},
{"lindex",lindexCommand,3,"r",0,NULL,1,1,1,0,0},
{"lset",lsetCommand,4,"wm",0,NULL,1,1,1,0,0},
{"lrange",lrangeCommand,4,"r",0,NULL,1,1,1,0,0},
{"ltrim",ltrimCommand,4,"w",0,NULL,1,1,1,0,0},
{"lrem",lremCommand,4,"w",0,NULL,1,1,1,0,0},
{"rpoplpush",rpoplpushCommand,3,"wm",0,NULL,1,2,1,0,0},
{"sadd",saddCommand,-3,"wmF",0,NULL,1,1,1,0,0},
{"srem",sremCommand,-3,"wF",0,NULL,1,1,1,0,0},
{"smove",smoveCommand,4,"wF",0,NULL,1,2,1,0,0},
{"sismember",sismemberCommand,3,"rF",0,NULL,1,1,1,0,0},
{"scard",scardCommand,2,"rF",0,NULL,1,1,1,0,0},
{"spop",spopCommand,-2,"wRF",0,NULL,1,1,1,0,0},
{"srandmember",srandmemberCommand,-2,"rR",0,NULL,1,1,1,0,0},
{"sinter",sinterCommand,-2,"rS",0,NULL,1,-1,1,0,0},
{"sinterstore",sinterstoreCommand,-3,"wm",0,NULL,1,-1,1,0,0},
{"sunion",sunionCommand,-2,"rS",0,NULL,1,-1,1,0,0},
{"sunionstore",sunionstoreCommand,-3,"wm",0,NULL,1,-1,1,0,0},
{"sdiff",sdiffCommand,-2,"rS",0,NULL,1,-1,1,0,0},
{"sdiffstore",sdiffstoreCommand,-3,"wm",0,NULL,1,-1,1,0,0},
{"smembers",sinterCommand,2,"rS",0,NULL,1,1,1,0,0},
{"sscan",sscanCommand,-3,"rR",0,NULL,1,1,1,0,0},
{"zadd",zaddCommand,-4,"wmF",0,NULL,1,1,1,0,0},
{"zincrby",zincrbyCommand,4,"wmF",0,NULL,1,1,1,0,0},
{"zrem",zremCommand,-3,"wF",0,NULL,1,1,1,0,0},
{"zremrangebyscore",zremrangebyscoreCommand,4,"w",0,NULL,1,1,1,0,0},
{"zremrangebyrank",zremrangebyrankCommand,4,"w",0,NULL,1,1,1,0,0},
{"zremrangebylex",zremrangebylexCommand,4,"w",0,NULL,1,1,1,0,0},
{"zunionstore",zunionstoreCommand,-4,"wm",0,zunionInterGetKeys,0,0,0,0,0},
{"zinterstore",zinterstoreCommand,-4,"wm",0,zunionInterGetKeys,0,0,0,0,0},
{"zrange",zrangeCommand,-4,"r",0,NULL,1,1,1,0,0},
{"zrangebyscore",zrangebyscoreCommand,-4,"r",0,NULL,1,1,1,0,0},
{"zrevrangebyscore",zrevrangebyscoreCommand,-4,"r",0,NULL,1,1,1,0,0},
{"zrangebylex",zrangebylexCommand,-4,"r",0,NULL,1,1,1,0,0},
{"zrevrangebylex",zrevrangebylexCommand,-4,"r",0,NULL,1,1,1,0,0},
{"zcount",zcountCommand,4,"rF",0,NULL,1,1,1,0,0},
{"zlexcount",zlexcountCommand,4,"rF",0,NULL,1,1,1,0,0},
{"zrevrange",zrevrangeCommand,-4,"r",0,NULL,1,1,1,0,0},
{"zcard",zcardCommand,2,"rF",0,NULL,1,1,1,0,0},
{"zscore",zscoreCommand,3,"rF",0,NULL,1,1,1,0,0},
{"zrank",zrankCommand,3,"rF",0,NULL,1,1,1,0,0},
{"zrevrank",zrevrankCommand,3,"rF",0,NULL,1,1,1,0,0},
{"zscan",zscanCommand,-3,"rR",0,NULL,1,1,1,0,0},
{"zpopmin",zpopminCommand,-2,"wF",0,NULL,1,1,1,0,0},
{"zpopmax",zpopmaxCommand,-2,"wF",0,NULL,1,1,1,0,0},
{"bzpopmin",bzpopminCommand,-2,"wsF",0,NULL,1,-2,1,0,0},
{"bzpopmax",bzpopmaxCommand,-2,"wsF",0,NULL,1,-2,1,0,0},
{"hset",hsetCommand,-4,"wmF",0,NULL,1,1,1,0,0},
{"hsetnx",hsetnxCommand,4,"wmF",0,NULL,1,1,1,0,0},
{"hget",hgetCommand,3,"rF",0,NULL,1,1,1,0,0},
{"hmset",hsetCommand,-4,"wmF",0,NULL,1,1,1,0,0},
{"hmget",hmgetCommand,-3,"rF",0,NULL,1,1,1,0,0},
{"hincrby",hincrbyCommand,4,"wmF",0,NULL,1,1,1,0,0},
{"hincrbyfloat",hincrbyfloatCommand,4,"wmF",0,NULL,1,1,1,0,0},
{"hdel",hdelCommand,-3,"wF",0,NULL,1,1,1,0,0},
{"hlen",hlenCommand,2,"rF",0,NULL,1,1,1,0,0},
{"hstrlen",hstrlenCommand,3,"rF",0,NULL,1,1,1,0,0},
{"hkeys",hkeysCommand,2,"rS",0,NULL,1,1,1,0,0},
{"hvals",hvalsCommand,2,"rS",0,NULL,1,1,1,0,0},
{"hgetall",hgetallCommand,2,"rR",0,NULL,1,1,1,0,0},
{"hexists",hexistsCommand,3,"rF",0,NULL,1,1,1,0,0},
{"hscan",hscanCommand,-3,"rR",0,NULL,1,1,1,0,0},
{"incrby",incrbyCommand,3,"wmF",0,NULL,1,1,1,0,0},
{"decrby",decrbyCommand,3,"wmF",0,NULL,1,1,1,0,0},
{"incrbyfloat",incrbyfloatCommand,3,"wmF",0,NULL,1,1,1,0,0},
{"getset",getsetCommand,3,"wm",0,NULL,1,1,1,0,0},
{"mset",msetCommand,-3,"wm",0,NULL,1,-1,2,0,0},
{"msetnx",msetnxCommand,-3,"wm",0,NULL,1,-1,2,0,0},
{"randomkey",randomkeyCommand,1,"rR",0,NULL,0,0,0,0,0},
{"select",selectCommand,2,"lF",0,NULL,0,0,0,0,0},
{"swapdb",swapdbCommand,3,"wF",0,NULL,0,0,0,0,0},
{"move",moveCommand,3,"wF",0,NULL,1,1,1,0,0},
{"rename",renameCommand,3,"w",0,NULL,1,2,1,0,0},
{"renamenx",renamenxCommand,3,"wF",0,NULL,1,2,1,0,0},
{"expire",expireCommand,3,"wF",0,NULL,1,1,1,0,0},
{"expireat",expireatCommand,3,"wF",0,NULL,1,1,1,0,0},
{"pexpire",pexpireCommand,3,"wF",0,NULL,1,1,1,0,0},
{"pexpireat",pexpireatCommand,3,"wF",0,NULL,1,1,1,0,0},
{"keys",keysCommand,2,"rS",0,NULL,0,0,0,0,0},
{"scan",scanCommand,-2,"rR",0,NULL,0,0,0,0,0},
{"dbsize",dbsizeCommand,1,"rF",0,NULL,0,0,0,0,0},
{"auth",authCommand,2,"sltF",0,NULL,0,0,0,0,0},
{"ping",pingCommand,-1,"tF",0,NULL,0,0,0,0,0},
{"echo",echoCommand,2,"F",0,NULL,0,0,0,0,0},
{"save",saveCommand,1,"as",0,NULL,0,0,0,0,0},
{"bgsave",bgsaveCommand,-1,"as",0,NULL,0,0,0,0,0},
{"bgrewriteaof",bgrewriteaofCommand,1,"as",0,NULL,0,0,0,0,0},
{"shutdown",shutdownCommand,-1,"aslt",0,NULL,0,0,0,0,0},
{"lastsave",lastsaveCommand,1,"RF",0,NULL,0,0,0,0,0},
{"type",typeCommand,2,"rF",0,NULL,1,1,1,0,0},
{"multi",multiCommand,1,"sF",0,NULL,0,0,0,0,0},
{"exec",execCommand,1,"sM",0,NULL,0,0,0,0,0},
{"discard",discardCommand,1,"sF",0,NULL,0,0,0,0,0},
{"sync",syncCommand,1,"ars",0,NULL,0,0,0,0,0},
{"psync",syncCommand,3,"ars",0,NULL,0,0,0,0,0},
{"replconf",replconfCommand,-1,"aslt",0,NULL,0,0,0,0,0},
{"flushdb",flushdbCommand,-1,"w",0,NULL,0,0,0,0,0},
{"flushall",flushallCommand,-1,"w",0,NULL,0,0,0,0,0},
{"sort",sortCommand,-2,"wm",0,sortGetKeys,1,1,1,0,0},
{"info",infoCommand,-1,"ltR",0,NULL,0,0,0,0,0},
{"monitor",monitorCommand,1,"as",0,NULL,0,0,0,0,0},
{"ttl",ttlCommand,2,"rFR",0,NULL,1,1,1,0,0},
{"touch",touchCommand,-2,"rF",0,NULL,1,1,1,0,0},
{"pttl",pttlCommand,2,"rFR",0,NULL,1,1,1,0,0},
{"persist",persistCommand,2,"wF",0,NULL,1,1,1,0,0},
{"slaveof",replicaofCommand,3,"ast",0,NULL,0,0,0,0,0},
{"replicaof",replicaofCommand,3,"ast",0,NULL,0,0,0,0,0},
{"role",roleCommand,1,"lst",0,NULL,0,0,0,0,0},
{"debug",debugCommand,-2,"as",0,NULL,0,0,0,0,0},
{"config",configCommand,-2,"last",0,NULL,0,0,0,0,0},
{"subscribe",subscribeCommand,-2,"pslt",0,NULL,0,0,0,0,0},
{"unsubscribe",unsubscribeCommand,-1,"pslt",0,NULL,0,0,0,0,0},
{"psubscribe",psubscribeCommand,-2,"pslt",0,NULL,0,0,0,0,0},
{"punsubscribe",punsubscribeCommand,-1,"pslt",0,NULL,0,0,0,0,0},
{"publish",publishCommand,3,"pltF",0,NULL,0,0,0,0,0},
{"pubsub",pubsubCommand,-2,"pltR",0,NULL,0,0,0,0,0},
{"watch",watchCommand,-2,"sF",0,NULL,1,-1,1,0,0},
{"unwatch",unwatchCommand,1,"sF",0,NULL,0,0,0,0,0},
{"cluster",clusterCommand,-2,"a",0,NULL,0,0,0,0,0},
{"restore",restoreCommand,-4,"wm",0,NULL,1,1,1,0,0},
{"restore-asking",restoreCommand,-4,"wmk",0,NULL,1,1,1,0,0},
{"migrate",migrateCommand,-6,"wR",0,migrateGetKeys,0,0,0,0,0},
{"asking",askingCommand,1,"F",0,NULL,0,0,0,0,0},
{"readonly",readonlyCommand,1,"F",0,NULL,0,0,0,0,0},
{"readwrite",readwriteCommand,1,"F",0,NULL,0,0,0,0,0},
{"dump",dumpCommand,2,"rR",0,NULL,1,1,1,0,0},
{"object",objectCommand,-2,"rR",0,NULL,2,2,1,0,0},
{"memory",memoryCommand,-2,"rR",0,NULL,0,0,0,0,0},
{"client",clientCommand,-2,"as",0,NULL,0,0,0,0,0},
{"hello",helloCommand,-2,"sF",0,NULL,0,0,0,0,0},
{"eval",evalCommand,-3,"s",0,evalGetKeys,0,0,0,0,0},
{"evalsha",evalShaCommand,-3,"s",0,evalGetKeys,0,0,0,0,0},
{"slowlog",slowlogCommand,-2,"aR",0,NULL,0,0,0,0,0},
{"script",scriptCommand,-2,"s",0,NULL,0,0,0,0,0},
{"time",timeCommand,1,"RF",0,NULL,0,0,0,0,0},
{"bitop",bitopCommand,-4,"wm",0,NULL,2,-1,1,0,0},
{"bitcount",bitcountCommand,-2,"r",0,NULL,1,1,1,0,0},
{"bitpos",bitposCommand,-3,"r",0,NULL,1,1,1,0,0},
{"wait",waitCommand,3,"s",0,NULL,0,0,0,0,0},
{"command",commandCommand,0,"ltR",0,NULL,0,0,0,0,0},
{"geoadd",geoaddCommand,-5,"wm",0,NULL,1,1,1,0,0},
{"georadius",georadiusCommand,-6,"w",0,georadiusGetKeys,1,1,1,0,0},
{"georadius_ro",georadiusroCommand,-6,"r",0,georadiusGetKeys,1,1,1,0,0},
{"georadiusbymember",georadiusbymemberCommand,-5,"w",0,georadiusGetKeys,1,1,1,0,0},
{"georadiusbymember_ro",georadiusbymemberroCommand,-5,"r",0,georadiusGetKeys,1,1,1,0,0},
{"geohash",geohashCommand,-2,"r",0,NULL,1,1,1,0,0},
{"geopos",geoposCommand,-2,"r",0,NULL,1,1,1,0,0},
{"geodist",geodistCommand,-4,"r",0,NULL,1,1,1,0,0},
{"pfselftest",pfselftestCommand,1,"a",0,NULL,0,0,0,0,0},
{"pfadd",pfaddCommand,-2,"wmF",0,NULL,1,1,1,0,0},
{"pfcount",pfcountCommand,-2,"r",0,NULL,1,-1,1,0,0},
{"pfmerge",pfmergeCommand,-2,"wm",0,NULL,1,-1,1,0,0},
{"pfdebug",pfdebugCommand,-3,"w",0,NULL,0,0,0,0,0},
{"xadd",xaddCommand,-5,"wmFR",0,NULL,1,1,1,0,0},
{"xrange",xrangeCommand,-4,"r",0,NULL,1,1,1,0,0},
{"xrevrange",xrevrangeCommand,-4,"r",0,NULL,1,1,1,0,0},
{"xlen",xlenCommand,2,"rF",0,NULL,1,1,1,0,0},
{"xread",xreadCommand,-4,"rs",0,xreadGetKeys,1,1,1,0,0},
{"xreadgroup",xreadCommand,-7,"ws",0,xreadGetKeys,1,1,1,0,0},
{"xgroup",xgroupCommand,-2,"wm",0,NULL,2,2,1,0,0},
{"xsetid",xsetidCommand,3,"wmF",0,NULL,1,1,1,0,0},
{"xack",xackCommand,-4,"wF",0,NULL,1,1,1,0,0},
{"xpending",xpendingCommand,-3,"rR",0,NULL,1,1,1,0,0},
{"xclaim",xclaimCommand,-6,"wRF",0,NULL,1,1,1,0,0},
{"xinfo",xinfoCommand,-2,"rR",0,NULL,2,2,1,0,0},
{"xdel",xdelCommand,-3,"wF",0,NULL,1,1,1,0,0},
{"xtrim",xtrimCommand,-2,"wFR",0,NULL,1,1,1,0,0},
{"post",securityWarningCommand,-1,"lt",0,NULL,0,0,0,0,0},
{"host:",securityWarningCommand,-1,"lt",0,NULL,0,0,0,0,0},
{"latency",latencyCommand,-2,"aslt",0,NULL,0,0,0,0,0},
{"lolwut",lolwutCommand,-1,"r",0,NULL,0,0,0,0,0}
{"module",moduleCommand,-2,"as",0,NULL,0,0,0,0,0,0},
{"get",getCommand,2,"rF",0,NULL,1,1,1,0,0,0},
{"set",setCommand,-3,"wm",0,NULL,1,1,1,0,0,0},
{"setnx",setnxCommand,3,"wmF",0,NULL,1,1,1,0,0,0},
{"setex",setexCommand,4,"wm",0,NULL,1,1,1,0,0,0},
{"psetex",psetexCommand,4,"wm",0,NULL,1,1,1,0,0,0},
{"append",appendCommand,3,"wm",0,NULL,1,1,1,0,0,0},
{"strlen",strlenCommand,2,"rF",0,NULL,1,1,1,0,0,0},
{"del",delCommand,-2,"w",0,NULL,1,-1,1,0,0,0},
{"unlink",unlinkCommand,-2,"wF",0,NULL,1,-1,1,0,0,0},
{"exists",existsCommand,-2,"rF",0,NULL,1,-1,1,0,0,0},
{"setbit",setbitCommand,4,"wm",0,NULL,1,1,1,0,0,0},
{"getbit",getbitCommand,3,"rF",0,NULL,1,1,1,0,0,0},
{"bitfield",bitfieldCommand,-2,"wm",0,NULL,1,1,1,0,0,0},
{"setrange",setrangeCommand,4,"wm",0,NULL,1,1,1,0,0,0},
{"getrange",getrangeCommand,4,"r",0,NULL,1,1,1,0,0,0},
{"substr",getrangeCommand,4,"r",0,NULL,1,1,1,0,0,0},
{"incr",incrCommand,2,"wmF",0,NULL,1,1,1,0,0,0},
{"decr",decrCommand,2,"wmF",0,NULL,1,1,1,0,0,0},
{"mget",mgetCommand,-2,"rF",0,NULL,1,-1,1,0,0,0},
{"rpush",rpushCommand,-3,"wmF",0,NULL,1,1,1,0,0,0},
{"lpush",lpushCommand,-3,"wmF",0,NULL,1,1,1,0,0,0},
{"rpushx",rpushxCommand,-3,"wmF",0,NULL,1,1,1,0,0,0},
{"lpushx",lpushxCommand,-3,"wmF",0,NULL,1,1,1,0,0,0},
{"linsert",linsertCommand,5,"wm",0,NULL,1,1,1,0,0,0},
{"rpop",rpopCommand,2,"wF",0,NULL,1,1,1,0,0,0},
{"lpop",lpopCommand,2,"wF",0,NULL,1,1,1,0,0,0},
{"brpop",brpopCommand,-3,"ws",0,NULL,1,-2,1,0,0,0},
{"brpoplpush",brpoplpushCommand,4,"wms",0,NULL,1,2,1,0,0,0},
{"blpop",blpopCommand,-3,"ws",0,NULL,1,-2,1,0,0,0},
{"llen",llenCommand,2,"rF",0,NULL,1,1,1,0,0,0},
{"lindex",lindexCommand,3,"r",0,NULL,1,1,1,0,0,0},
{"lset",lsetCommand,4,"wm",0,NULL,1,1,1,0,0,0},
{"lrange",lrangeCommand,4,"r",0,NULL,1,1,1,0,0,0},
{"ltrim",ltrimCommand,4,"w",0,NULL,1,1,1,0,0,0},
{"lrem",lremCommand,4,"w",0,NULL,1,1,1,0,0,0},
{"rpoplpush",rpoplpushCommand,3,"wm",0,NULL,1,2,1,0,0,0},
{"sadd",saddCommand,-3,"wmF",0,NULL,1,1,1,0,0,0},
{"srem",sremCommand,-3,"wF",0,NULL,1,1,1,0,0,0},
{"smove",smoveCommand,4,"wF",0,NULL,1,2,1,0,0,0},
{"sismember",sismemberCommand,3,"rF",0,NULL,1,1,1,0,0,0},
{"scard",scardCommand,2,"rF",0,NULL,1,1,1,0,0,0},
{"spop",spopCommand,-2,"wRF",0,NULL,1,1,1,0,0,0},
{"srandmember",srandmemberCommand,-2,"rR",0,NULL,1,1,1,0,0,0},
{"sinter",sinterCommand,-2,"rS",0,NULL,1,-1,1,0,0,0},
{"sinterstore",sinterstoreCommand,-3,"wm",0,NULL,1,-1,1,0,0,0},
{"sunion",sunionCommand,-2,"rS",0,NULL,1,-1,1,0,0,0},
{"sunionstore",sunionstoreCommand,-3,"wm",0,NULL,1,-1,1,0,0,0},
{"sdiff",sdiffCommand,-2,"rS",0,NULL,1,-1,1,0,0,0},
{"sdiffstore",sdiffstoreCommand,-3,"wm",0,NULL,1,-1,1,0,0,0},
{"smembers",sinterCommand,2,"rS",0,NULL,1,1,1,0,0,0},
{"sscan",sscanCommand,-3,"rR",0,NULL,1,1,1,0,0,0},
{"zadd",zaddCommand,-4,"wmF",0,NULL,1,1,1,0,0,0},
{"zincrby",zincrbyCommand,4,"wmF",0,NULL,1,1,1,0,0,0},
{"zrem",zremCommand,-3,"wF",0,NULL,1,1,1,0,0,0},
{"zremrangebyscore",zremrangebyscoreCommand,4,"w",0,NULL,1,1,1,0,0,0},
{"zremrangebyrank",zremrangebyrankCommand,4,"w",0,NULL,1,1,1,0,0,0},
{"zremrangebylex",zremrangebylexCommand,4,"w",0,NULL,1,1,1,0,0,0},
{"zunionstore",zunionstoreCommand,-4,"wm",0,zunionInterGetKeys,0,0,0,0,0,0},
{"zinterstore",zinterstoreCommand,-4,"wm",0,zunionInterGetKeys,0,0,0,0,0,0},
{"zrange",zrangeCommand,-4,"r",0,NULL,1,1,1,0,0,0},
{"zrangebyscore",zrangebyscoreCommand,-4,"r",0,NULL,1,1,1,0,0,0},
{"zrevrangebyscore",zrevrangebyscoreCommand,-4,"r",0,NULL,1,1,1,0,0,0},
{"zrangebylex",zrangebylexCommand,-4,"r",0,NULL,1,1,1,0,0,0},
{"zrevrangebylex",zrevrangebylexCommand,-4,"r",0,NULL,1,1,1,0,0,0},
{"zcount",zcountCommand,4,"rF",0,NULL,1,1,1,0,0,0},
{"zlexcount",zlexcountCommand,4,"rF",0,NULL,1,1,1,0,0,0},
{"zrevrange",zrevrangeCommand,-4,"r",0,NULL,1,1,1,0,0,0},
{"zcard",zcardCommand,2,"rF",0,NULL,1,1,1,0,0,0},
{"zscore",zscoreCommand,3,"rF",0,NULL,1,1,1,0,0,0},
{"zrank",zrankCommand,3,"rF",0,NULL,1,1,1,0,0,0},
{"zrevrank",zrevrankCommand,3,"rF",0,NULL,1,1,1,0,0,0},
{"zscan",zscanCommand,-3,"rR",0,NULL,1,1,1,0,0,0},
{"zpopmin",zpopminCommand,-2,"wF",0,NULL,1,1,1,0,0,0},
{"zpopmax",zpopmaxCommand,-2,"wF",0,NULL,1,1,1,0,0,0},
{"bzpopmin",bzpopminCommand,-2,"wsF",0,NULL,1,-2,1,0,0,0},
{"bzpopmax",bzpopmaxCommand,-2,"wsF",0,NULL,1,-2,1,0,0,0},
{"hset",hsetCommand,-4,"wmF",0,NULL,1,1,1,0,0,0},
{"hsetnx",hsetnxCommand,4,"wmF",0,NULL,1,1,1,0,0,0},
{"hget",hgetCommand,3,"rF",0,NULL,1,1,1,0,0,0},
{"hmset",hsetCommand,-4,"wmF",0,NULL,1,1,1,0,0,0},
{"hmget",hmgetCommand,-3,"rF",0,NULL,1,1,1,0,0,0},
{"hincrby",hincrbyCommand,4,"wmF",0,NULL,1,1,1,0,0,0},
{"hincrbyfloat",hincrbyfloatCommand,4,"wmF",0,NULL,1,1,1,0,0,0},
{"hdel",hdelCommand,-3,"wF",0,NULL,1,1,1,0,0,0},
{"hlen",hlenCommand,2,"rF",0,NULL,1,1,1,0,0,0},
{"hstrlen",hstrlenCommand,3,"rF",0,NULL,1,1,1,0,0,0},
{"hkeys",hkeysCommand,2,"rS",0,NULL,1,1,1,0,0,0},
{"hvals",hvalsCommand,2,"rS",0,NULL,1,1,1,0,0,0},
{"hgetall",hgetallCommand,2,"rR",0,NULL,1,1,1,0,0,0},
{"hexists",hexistsCommand,3,"rF",0,NULL,1,1,1,0,0,0},
{"hscan",hscanCommand,-3,"rR",0,NULL,1,1,1,0,0,0},
{"incrby",incrbyCommand,3,"wmF",0,NULL,1,1,1,0,0,0},
{"decrby",decrbyCommand,3,"wmF",0,NULL,1,1,1,0,0,0},
{"incrbyfloat",incrbyfloatCommand,3,"wmF",0,NULL,1,1,1,0,0,0},
{"getset",getsetCommand,3,"wm",0,NULL,1,1,1,0,0,0},
{"mset",msetCommand,-3,"wm",0,NULL,1,-1,2,0,0,0},
{"msetnx",msetnxCommand,-3,"wm",0,NULL,1,-1,2,0,0,0},
{"randomkey",randomkeyCommand,1,"rR",0,NULL,0,0,0,0,0,0},
{"select",selectCommand,2,"lF",0,NULL,0,0,0,0,0,0},
{"swapdb",swapdbCommand,3,"wF",0,NULL,0,0,0,0,0,0},
{"move",moveCommand,3,"wF",0,NULL,1,1,1,0,0,0},
{"rename",renameCommand,3,"w",0,NULL,1,2,1,0,0,0},
{"renamenx",renamenxCommand,3,"wF",0,NULL,1,2,1,0,0,0},
{"expire",expireCommand,3,"wF",0,NULL,1,1,1,0,0,0},
{"expireat",expireatCommand,3,"wF",0,NULL,1,1,1,0,0,0},
{"pexpire",pexpireCommand,3,"wF",0,NULL,1,1,1,0,0,0},
{"pexpireat",pexpireatCommand,3,"wF",0,NULL,1,1,1,0,0,0},
{"keys",keysCommand,2,"rS",0,NULL,0,0,0,0,0,0},
{"scan",scanCommand,-2,"rR",0,NULL,0,0,0,0,0,0},
{"dbsize",dbsizeCommand,1,"rF",0,NULL,0,0,0,0,0,0},
{"auth",authCommand,2,"sltF",0,NULL,0,0,0,0,0,0},
{"ping",pingCommand,-1,"tF",0,NULL,0,0,0,0,0,0},
{"echo",echoCommand,2,"F",0,NULL,0,0,0,0,0,0},
{"save",saveCommand,1,"as",0,NULL,0,0,0,0,0,0},
{"bgsave",bgsaveCommand,-1,"as",0,NULL,0,0,0,0,0,0},
{"bgrewriteaof",bgrewriteaofCommand,1,"as",0,NULL,0,0,0,0,0,0},
{"shutdown",shutdownCommand,-1,"aslt",0,NULL,0,0,0,0,0,0},
{"lastsave",lastsaveCommand,1,"RF",0,NULL,0,0,0,0,0,0},
{"type",typeCommand,2,"rF",0,NULL,1,1,1,0,0,0},
{"multi",multiCommand,1,"sF",0,NULL,0,0,0,0,0,0},
{"exec",execCommand,1,"sM",0,NULL,0,0,0,0,0,0},
{"discard",discardCommand,1,"sF",0,NULL,0,0,0,0,0,0},
{"sync",syncCommand,1,"ars",0,NULL,0,0,0,0,0,0},
{"psync",syncCommand,3,"ars",0,NULL,0,0,0,0,0,0},
{"replconf",replconfCommand,-1,"aslt",0,NULL,0,0,0,0,0,0},
{"flushdb",flushdbCommand,-1,"w",0,NULL,0,0,0,0,0,0},
{"flushall",flushallCommand,-1,"w",0,NULL,0,0,0,0,0,0},
{"sort",sortCommand,-2,"wm",0,sortGetKeys,1,1,1,0,0,0},
{"info",infoCommand,-1,"ltR",0,NULL,0,0,0,0,0,0},
{"monitor",monitorCommand,1,"as",0,NULL,0,0,0,0,0,0},
{"ttl",ttlCommand,2,"rFR",0,NULL,1,1,1,0,0,0},
{"touch",touchCommand,-2,"rF",0,NULL,1,1,1,0,0,0},
{"pttl",pttlCommand,2,"rFR",0,NULL,1,1,1,0,0,0},
{"persist",persistCommand,2,"wF",0,NULL,1,1,1,0,0,0},
{"slaveof",replicaofCommand,3,"ast",0,NULL,0,0,0,0,0,0},
{"replicaof",replicaofCommand,3,"ast",0,NULL,0,0,0,0,0,0},
{"role",roleCommand,1,"lst",0,NULL,0,0,0,0,0,0},
{"debug",debugCommand,-2,"as",0,NULL,0,0,0,0,0,0},
{"config",configCommand,-2,"last",0,NULL,0,0,0,0,0,0},
{"subscribe",subscribeCommand,-2,"pslt",0,NULL,0,0,0,0,0,0},
{"unsubscribe",unsubscribeCommand,-1,"pslt",0,NULL,0,0,0,0,0,0},
{"psubscribe",psubscribeCommand,-2,"pslt",0,NULL,0,0,0,0,0,0},
{"punsubscribe",punsubscribeCommand,-1,"pslt",0,NULL,0,0,0,0,0,0},
{"publish",publishCommand,3,"pltF",0,NULL,0,0,0,0,0,0},
{"pubsub",pubsubCommand,-2,"pltR",0,NULL,0,0,0,0,0,0},
{"watch",watchCommand,-2,"sF",0,NULL,1,-1,1,0,0,0},
{"unwatch",unwatchCommand,1,"sF",0,NULL,0,0,0,0,0,0},
{"cluster",clusterCommand,-2,"a",0,NULL,0,0,0,0,0,0},
{"restore",restoreCommand,-4,"wm",0,NULL,1,1,1,0,0,0},
{"restore-asking",restoreCommand,-4,"wmk",0,NULL,1,1,1,0,0,0},
{"migrate",migrateCommand,-6,"wR",0,migrateGetKeys,0,0,0,0,0,0},
{"asking",askingCommand,1,"F",0,NULL,0,0,0,0,0,0},
{"readonly",readonlyCommand,1,"F",0,NULL,0,0,0,0,0,0},
{"readwrite",readwriteCommand,1,"F",0,NULL,0,0,0,0,0,0},
{"dump",dumpCommand,2,"rR",0,NULL,1,1,1,0,0,0},
{"object",objectCommand,-2,"rR",0,NULL,2,2,1,0,0,0},
{"memory",memoryCommand,-2,"rR",0,NULL,0,0,0,0,0,0},
{"client",clientCommand,-2,"as",0,NULL,0,0,0,0,0,0},
{"hello",helloCommand,-2,"sF",0,NULL,0,0,0,0,0,0},
{"eval",evalCommand,-3,"s",0,evalGetKeys,0,0,0,0,0,0},
{"evalsha",evalShaCommand,-3,"s",0,evalGetKeys,0,0,0,0,0,0},
{"slowlog",slowlogCommand,-2,"aR",0,NULL,0,0,0,0,0,0},
{"script",scriptCommand,-2,"s",0,NULL,0,0,0,0,0,0},
{"time",timeCommand,1,"RF",0,NULL,0,0,0,0,0,0},
{"bitop",bitopCommand,-4,"wm",0,NULL,2,-1,1,0,0,0},
{"bitcount",bitcountCommand,-2,"r",0,NULL,1,1,1,0,0,0},
{"bitpos",bitposCommand,-3,"r",0,NULL,1,1,1,0,0,0},
{"wait",waitCommand,3,"s",0,NULL,0,0,0,0,0,0},
{"command",commandCommand,0,"ltR",0,NULL,0,0,0,0,0,0},
{"geoadd",geoaddCommand,-5,"wm",0,NULL,1,1,1,0,0,0},
{"georadius",georadiusCommand,-6,"w",0,georadiusGetKeys,1,1,1,0,0,0},
{"georadius_ro",georadiusroCommand,-6,"r",0,georadiusGetKeys,1,1,1,0,0,0},
{"georadiusbymember",georadiusbymemberCommand,-5,"w",0,georadiusGetKeys,1,1,1,0,0,0},
{"georadiusbymember_ro",georadiusbymemberroCommand,-5,"r",0,georadiusGetKeys,1,1,1,0,0,0},
{"geohash",geohashCommand,-2,"r",0,NULL,1,1,1,0,0,0},
{"geopos",geoposCommand,-2,"r",0,NULL,1,1,1,0,0,0},
{"geodist",geodistCommand,-4,"r",0,NULL,1,1,1,0,0,0},
{"pfselftest",pfselftestCommand,1,"a",0,NULL,0,0,0,0,0,0},
{"pfadd",pfaddCommand,-2,"wmF",0,NULL,1,1,1,0,0,0},
{"pfcount",pfcountCommand,-2,"r",0,NULL,1,-1,1,0,0,0},
{"pfmerge",pfmergeCommand,-2,"wm",0,NULL,1,-1,1,0,0,0},
{"pfdebug",pfdebugCommand,-3,"w",0,NULL,0,0,0,0,0,0},
{"xadd",xaddCommand,-5,"wmFR",0,NULL,1,1,1,0,0,0},
{"xrange",xrangeCommand,-4,"r",0,NULL,1,1,1,0,0,0},
{"xrevrange",xrevrangeCommand,-4,"r",0,NULL,1,1,1,0,0,0},
{"xlen",xlenCommand,2,"rF",0,NULL,1,1,1,0,0,0},
{"xread",xreadCommand,-4,"rs",0,xreadGetKeys,1,1,1,0,0,0},
{"xreadgroup",xreadCommand,-7,"ws",0,xreadGetKeys,1,1,1,0,0,0},
{"xgroup",xgroupCommand,-2,"wm",0,NULL,2,2,1,0,0,0},
{"xsetid",xsetidCommand,3,"wmF",0,NULL,1,1,1,0,0,0},
{"xack",xackCommand,-4,"wF",0,NULL,1,1,1,0,0,0},
{"xpending",xpendingCommand,-3,"rR",0,NULL,1,1,1,0,0,0},
{"xclaim",xclaimCommand,-6,"wRF",0,NULL,1,1,1,0,0,0},
{"xinfo",xinfoCommand,-2,"rR",0,NULL,2,2,1,0,0,0},
{"xdel",xdelCommand,-3,"wF",0,NULL,1,1,1,0,0,0},
{"xtrim",xtrimCommand,-2,"wFR",0,NULL,1,1,1,0,0,0},
{"post",securityWarningCommand,-1,"lt",0,NULL,0,0,0,0,0,0},
{"host:",securityWarningCommand,-1,"lt",0,NULL,0,0,0,0,0,0},
{"latency",latencyCommand,-2,"aslt",0,NULL,0,0,0,0,0,0},
{"lolwut",lolwutCommand,-1,"r",0,NULL,0,0,0,0,0,0}
};
/*============================ Utility functions ============================ */

View File

@ -1305,6 +1305,11 @@ struct redisCommand {
int lastkey; /* The last argument that's a key */
int keystep; /* The step between first and last key */
long long microseconds, calls;
int id; /* Command ID. This is a progressive ID starting from 0 that
is assigned at runtime, and is used in order to check
ACLs. A connection is able to execute a given command if
the user associated to the connection has this command
bit set in the bitmap of allowed commands. */
};
struct redisFunctionSym {