(function(RedisDB) { var redis = require('redis'), utils = require('./../public/src/utils.js'); RedisDB.exports = redis.createClient(global.nconf.get('redis').port, global.nconf.get('redis').host); if( global.nconf.get('redis').password ) { RedisDB.exports.auth(global.nconf.get('redis').password); } RedisDB.exports.handle = function(error) { if (error !== null) { if (global.env !== 'production') { console.log("################# ERROR LOG ####################"); console.log(error); console.log(arguments.callee.name); console.log("################# ERROR LOG ####################"); throw new Error(error); } else { console.log(error); } } } /* * A possibly more efficient way of doing multiple sismember calls */ RedisDB.exports.sismembers = function(key, needles, callback) { var tempkey = key + ':temp:' + utils.generateUUID(); RedisDB.exports.sadd(tempkey, needles, function() { RedisDB.exports.sinter(key, tempkey, function(err, data) { RedisDB.exports.del(tempkey); callback(err, data); }); }); }; /* * A lot of redis calls come back like this: * [key, value, key, value, key, value] * this is a simple utility fn to turn this into an object. */ RedisDB.exports.objectify = function(arr) { var obj = {}; for (var i = 0; i < arr.length; i += 2) { obj[arr[i]] = arr[i+1]; } return obj; }; /* * Similar to .objectify, this utility function splits the data array into two arrays */ RedisDB.exports.splitify = function(arr) { var arr1 = [], arr2 = []; for (var i = 0; i < arr.length; i += 2) { arr1.push(arr[i]); arr2.push(arr[i+1]); } return [arr1,arr2]; }; }(module));