You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
nodebb/src/redis.js

78 lines
2.9 KiB
JavaScript

(function(RedisDB) {
var PRODUCTION = false,
ERROR_LOGS = true,
redis = require('redis'),
db = redis.createClient();
// todo (holy cow): append,auth,bgrewriteaof,bgsave,bitcount,bitop,blpop,brpop,brpoplpush,client kill,client list,client getname,client setname,config get,config set,config resetstat,dbsize,debug object,debug segfault,decrby,del,discard,dump,echo,eval,evalsha,exec,exists,expire,expireat,flushall,flushdb,getbit,getrange,getset,hdel,hexists,hget,hgetall,hincrby,hincrbyfloat,hkeys,hlen,hmget,hmset,hset,hsetnx,hvals,incrby,incrbyfloat,info,keys,lastsave,lindex,linsert,llen,lpop,lpush,lpushx,lrange,lrem,lset,ltrim,mget,migrate,monitor,move,mset,msetnx,multi,object,persist,pexpire,pexpireat,ping,psetex,psubscribe,pttl,publish,punsubscribe,quit,randomkey,rename,renamenx,restore,rpop,rpoplpush,rpush,rpushx,sadd,save,scard,script exists,script flush,script kill,script load,sdiff,sdiffstore,select,setbit,setex,setnx,setrange,shutdown,sinter,sinterstore,sismember,slaveof,slowlog,smembers,smove,sort,spop,srandmember,srem,strlen,subscribe,sunion,sunionstore,sync,time,ttl,type,unsubscribe,unwatch,watch,zadd,zcard,zcount,zincrby,zinterstore,zrange,zrangebyscore,zrank,zrem,zremrangebyrank,zremrangebyscore,zrevrange,zrevrangebyscore,zrevrank,zscore,zunionstore
// done :^) get, set, incr, decr
function return_handler(error, data, callback, error_handler) {
if (error !== null) {
if (error_handler !== null) {
error_handler(error);
} else if (PRODUCTION === false) {
throw new Exception('RedisDB Error: ' + error);
} else if (ERROR_LOGS === true) {
console.log('RedisDB Error: ' + error);
}
} else {
callback(data);
}
}
RedisDB.set = function(key, value, expiry) {
db.set(key, value);
if (expiry !== undefined) RedisDB.expire(key, expiry);
};
RedisDB.get = function(key, callback, error_handler) {
db.get(key, function(error, data) {
return_handler(error, data, callback, error_handler);
});
};
RedisDB.mget = function(keys, callback, error_handler) {
db.mget(keys, function(error, data) {
return_handler(error, data, callback, error_handler);
});
};
RedisDB.multi = function() {
return db.multi();
}
RedisDB.del = function(key, callback) {
db.del(key);
}
RedisDB.expire = function(key, expiry) {
db.expire(key, expiry);
}
// Atomic Operations
RedisDB.incr = function(key, callback, error_handler) {
db.incr(key, function(error, data) {
if (callback) {
return_handler(error, data, callback, error_handler);
}
});
};
RedisDB.decr = function(key) {
db.decr(key);
};
// Lists
RedisDB.lpush = function(key, item) {
db.lpush(key, item);
}
RedisDB.lrange = function(key, start, end, callback, error_handler) {
db.lrange(key, start, end, function(error, data) {
return_handler(error, data, callback, error_handler);
});
}
}(exports));