| 
									
										
										
										
											2013-12-02 15:45:15 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-12-02 15:46:25 -05:00
										 |  |  | (function(module) { | 
					
						
							|  |  |  | 	'use strict'; | 
					
						
							| 
									
										
										
										
											2013-12-02 16:19:30 -05:00
										 |  |  | 	var redisClient, | 
					
						
							| 
									
										
										
										
											2013-12-02 15:46:25 -05:00
										 |  |  | 		redis = require('redis'), | 
					
						
							|  |  |  | 		winston = require('winston'), | 
					
						
							|  |  |  | 		nconf = require('nconf'), | 
					
						
							| 
									
										
										
										
											2013-12-02 22:33:55 -05:00
										 |  |  | 		express = require('express'), | 
					
						
							|  |  |  | 		connectRedis = require('connect-redis')(express), | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-12-02 15:46:25 -05:00
										 |  |  | 		redis_socket_or_host = nconf.get('redis:host'), | 
					
						
							| 
									
										
										
										
											2013-12-02 16:19:30 -05:00
										 |  |  | 		utils = require('./../../public/src/utils.js'); | 
					
						
							| 
									
										
										
										
											2013-12-02 15:46:25 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-12-03 14:21:08 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-12-02 15:46:25 -05:00
										 |  |  | 	if (redis_socket_or_host && redis_socket_or_host.indexOf('/')>=0) { | 
					
						
							|  |  |  | 		/* If redis.host contains a path name character, use the unix dom sock connection. ie, /tmp/redis.sock */ | 
					
						
							| 
									
										
										
										
											2013-12-02 16:19:30 -05:00
										 |  |  | 		redisClient = redis.createClient(nconf.get('redis:host')); | 
					
						
							| 
									
										
										
										
											2013-12-02 15:46:25 -05:00
										 |  |  | 	} else { | 
					
						
							|  |  |  | 		/* Else, connect over tcp/ip */ | 
					
						
							| 
									
										
										
										
											2013-12-02 16:19:30 -05:00
										 |  |  | 		redisClient = redis.createClient(nconf.get('redis:port'), nconf.get('redis:host')); | 
					
						
							| 
									
										
										
										
											2013-12-02 15:46:25 -05:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-12-03 14:21:08 -05:00
										 |  |  | 	module.client = redisClient; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-12-02 22:33:55 -05:00
										 |  |  | 	module.sessionStore = new connectRedis({ | 
					
						
							|  |  |  | 		client: redisClient, | 
					
						
							|  |  |  | 		ttl: 60 * 60 * 24 * 30 | 
					
						
							|  |  |  | 	}); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-12-02 15:46:25 -05:00
										 |  |  | 	if (nconf.get('redis:password')) { | 
					
						
							| 
									
										
										
										
											2013-12-02 16:19:30 -05:00
										 |  |  | 		redisClient.auth(nconf.get('redis:password')); | 
					
						
							| 
									
										
										
										
											2013-12-02 15:46:25 -05:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	var db = parseInt(nconf.get('redis:database'), 10); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (db){ | 
					
						
							| 
									
										
										
										
											2013-12-02 16:19:30 -05:00
										 |  |  | 		redisClient.select(db, function(error) { | 
					
						
							|  |  |  | 			if(error) { | 
					
						
							| 
									
										
										
										
											2013-12-02 15:46:25 -05:00
										 |  |  | 				winston.error("NodeBB could not connect to your Redis database. Redis returned the following error: " + error.message); | 
					
						
							|  |  |  | 				process.exit(); | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		}); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-12-03 14:21:08 -05:00
										 |  |  | 	module.init = function(callback) { | 
					
						
							|  |  |  | 		callback(null); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-12-02 15:46:25 -05:00
										 |  |  | 	/* | 
					
						
							|  |  |  | 	 * A possibly more efficient way of doing multiple sismember calls | 
					
						
							|  |  |  | 	 */ | 
					
						
							| 
									
										
										
										
											2013-12-02 16:19:30 -05:00
										 |  |  | 	function sismembers(key, needles, callback) { | 
					
						
							| 
									
										
										
										
											2013-12-02 15:46:25 -05:00
										 |  |  | 		var tempkey = key + ':temp:' + utils.generateUUID(); | 
					
						
							| 
									
										
										
										
											2013-12-02 16:19:30 -05:00
										 |  |  | 		redisClient.sadd(tempkey, needles, function() { | 
					
						
							|  |  |  | 			redisClient.sinter(key, tempkey, function(err, data) { | 
					
						
							|  |  |  | 				redisClient.del(tempkey); | 
					
						
							| 
									
										
										
										
											2013-12-02 15:46:25 -05:00
										 |  |  | 				callback(err, data); | 
					
						
							|  |  |  | 			}); | 
					
						
							|  |  |  | 		}); | 
					
						
							|  |  |  | 	}; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-12-02 16:19:30 -05:00
										 |  |  | 	//
 | 
					
						
							|  |  |  | 	// Exported functions
 | 
					
						
							|  |  |  | 	//
 | 
					
						
							| 
									
										
										
										
											2013-12-02 16:23:14 -05:00
										 |  |  | 	module.getFileName = function(callback) { | 
					
						
							|  |  |  | 		var multi = redisClient.multi(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		multi.config('get', 'dir'); | 
					
						
							|  |  |  | 		multi.config('get', 'dbfilename'); | 
					
						
							|  |  |  | 		multi.exec(function (err, results) { | 
					
						
							|  |  |  | 			if (err) { | 
					
						
							|  |  |  | 				return callback(err); | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			results = results.reduce(function (memo, config) { | 
					
						
							|  |  |  | 				memo[config[0]] = config[1]; | 
					
						
							|  |  |  | 				return memo; | 
					
						
							|  |  |  | 			}, {}); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			var dbFile = path.join(results.dir, results.dbfilename); | 
					
						
							|  |  |  | 			callback(null, dbFile); | 
					
						
							|  |  |  | 		}); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-12-02 21:20:55 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	module.info = function(callback) { | 
					
						
							|  |  |  | 		redisClient.info(function (err, data) { | 
					
						
							|  |  |  | 			if(err) { | 
					
						
							|  |  |  | 				return callback(err); | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			data = data.split("\r\n"); | 
					
						
							|  |  |  | 			var finalData = {}; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			for (var i in data) { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 				if (data[i].indexOf(':') == -1 || !data[i]) | 
					
						
							|  |  |  | 					continue; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 				try { | 
					
						
							|  |  |  | 					data[i] = data[i].replace(/:/, "\":\""); | 
					
						
							|  |  |  | 					var json = "{\"" + data[i] + "\"}"; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 					var jsonObject = JSON.parse(json); | 
					
						
							|  |  |  | 					for (var key in jsonObject) { | 
					
						
							|  |  |  | 						finalData[key] = jsonObject[key]; | 
					
						
							|  |  |  | 					} | 
					
						
							|  |  |  | 				} catch (err) { | 
					
						
							|  |  |  | 					winston.warn('can\'t parse redis status variable, ignoring', i, data[i], err); | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			callback(null, finalData); | 
					
						
							|  |  |  | 		}); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-12-02 19:40:11 -05:00
										 |  |  | 	// key
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	module.exists = function(key, callback) { | 
					
						
							|  |  |  | 		redisClient.exists(key, function(err, exists) { | 
					
						
							|  |  |  | 			callback(err, exists === 1); | 
					
						
							|  |  |  | 		}); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	module.delete = function(key, callback) { | 
					
						
							|  |  |  | 		redisClient.del(key, callback); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-12-02 21:20:55 -05:00
										 |  |  | 	module.get = function(key, callback) { | 
					
						
							|  |  |  | 		redisClient.get(key, callback); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	module.set = function(key, callback) { | 
					
						
							|  |  |  | 		redisClient.get(key, callback); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-12-03 17:43:12 -05:00
										 |  |  | 	module.keys = function(key, callback) { | 
					
						
							| 
									
										
										
										
											2013-12-03 17:48:18 -05:00
										 |  |  | 		redisClient.keys(key, callback); | 
					
						
							| 
									
										
										
										
											2013-12-03 17:43:12 -05:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-12-02 19:40:11 -05:00
										 |  |  | 	//hashes
 | 
					
						
							| 
									
										
										
										
											2013-12-02 16:23:14 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-12-02 16:19:30 -05:00
										 |  |  | 	module.setObject = function(key, data, callback) { | 
					
						
							| 
									
										
										
										
											2013-12-02 21:58:37 -05:00
										 |  |  | 		// TODO: this crashes if callback isnt supplied -baris
 | 
					
						
							|  |  |  | 		redisClient.hmset(key, data, function(err, res) { | 
					
						
							|  |  |  | 			if(callback) { | 
					
						
							|  |  |  | 				callback(err, res); | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		}); | 
					
						
							| 
									
										
										
										
											2013-12-02 16:19:30 -05:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2013-12-02 15:46:25 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-12-02 19:40:11 -05:00
										 |  |  | 	module.setObjectField = function(key, field, value, callback) { | 
					
						
							|  |  |  | 		redisClient.hset(key, field, value, callback) | 
					
						
							| 
									
										
										
										
											2013-12-02 16:19:30 -05:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	module.getObject = function(key, callback) { | 
					
						
							| 
									
										
										
										
											2013-12-02 21:20:55 -05:00
										 |  |  | 		redisClient.hgetall(key, callback); | 
					
						
							| 
									
										
										
										
											2013-12-02 16:19:30 -05:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	module.getObjectField = function(key, field, callback) { | 
					
						
							|  |  |  | 		module.getObjectFields(key, [field], function(err, data) { | 
					
						
							|  |  |  | 			if(err) { | 
					
						
							|  |  |  | 				return callback(err); | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			callback(null, data[field]); | 
					
						
							|  |  |  | 		}); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	module.getObjectFields = function(key, fields, callback) { | 
					
						
							|  |  |  | 		redisClient.hmget(key, fields, function(err, data) { | 
					
						
							| 
									
										
										
										
											2013-12-02 15:46:25 -05:00
										 |  |  | 			if(err) { | 
					
						
							|  |  |  | 				return callback(err, null); | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			var returnData = {}; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			for (var i = 0, ii = fields.length; i < ii; ++i) { | 
					
						
							|  |  |  | 				returnData[fields[i]] = data[i]; | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			callback(null, returnData); | 
					
						
							|  |  |  | 		}); | 
					
						
							| 
									
										
										
										
											2013-12-02 16:19:30 -05:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-12-02 19:40:11 -05:00
										 |  |  | 	module.getObjectValues = function(key, callback) { | 
					
						
							|  |  |  | 		redisClient.hvals(key, callback); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	module.isObjectField = function(key, field, callback) { | 
					
						
							|  |  |  | 		redisClient.hexists(key, field, function(err, exists) { | 
					
						
							|  |  |  | 			callback(err, exists === 1); | 
					
						
							|  |  |  | 		}); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-12-02 16:19:30 -05:00
										 |  |  | 	module.deleteObjectField = function(key, field, callback) { | 
					
						
							|  |  |  | 		redisClient.hdel(key, field, callback); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-12-02 17:10:26 -05:00
										 |  |  | 	module.incrObjectField = function(key, field, callback) { | 
					
						
							|  |  |  | 		redisClient.hincrby(key, field, 1, callback); | 
					
						
							| 
									
										
										
										
											2013-12-02 16:19:30 -05:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-12-02 21:20:55 -05:00
										 |  |  | 	module.decrObjectField = function(key, field, callback) { | 
					
						
							|  |  |  | 		redisClient.hincrby(key, field, -1, callback); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-12-02 17:10:26 -05:00
										 |  |  | 	module.incrObjectFieldBy = function(key, field, value, callback) { | 
					
						
							|  |  |  | 		redisClient.hincrby(key, field, value, callback); | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2013-12-02 16:19:30 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-12-02 19:40:11 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	// sets
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-12-02 16:35:32 -05:00
										 |  |  | 	module.setAdd = function(key, value, callback) { | 
					
						
							|  |  |  | 		redisClient.sadd(key, value, callback); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	module.setRemove = function(key, value, callback) { | 
					
						
							|  |  |  | 		redisClient.srem(key, value, callback); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	module.isSetMember = function(key, value, callback) { | 
					
						
							|  |  |  | 		redisClient.sismember(key, value, callback); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-12-02 21:20:55 -05:00
										 |  |  | 	module.isMemberOfSets = function(sets, value, callback) { | 
					
						
							|  |  |  | 		var batch = redisClient.multi(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		for (var i = 0, ii = sets.length; i < ii; i++) { | 
					
						
							|  |  |  | 			batch.sismember(sets[i], value); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		batch.exec(callback); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-12-02 16:35:32 -05:00
										 |  |  | 	module.getSetMembers = function(key, callback) { | 
					
						
							|  |  |  | 		redisClient.smembers(key, callback); | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2013-12-02 15:46:25 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-12-02 19:40:11 -05:00
										 |  |  | 	module.setCount = function(key, callback) { | 
					
						
							|  |  |  | 		redisClient.scard(key, callback); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-12-02 21:20:55 -05:00
										 |  |  | 	module.setRemoveRandom = function(key, callback) { | 
					
						
							|  |  |  | 		redisClient.spop(key, callback); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-12-02 19:40:11 -05:00
										 |  |  | 	// sorted sets
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-12-02 17:10:26 -05:00
										 |  |  | 	module.sortedSetAdd = function(key, score, value, callback) { | 
					
						
							|  |  |  | 		redisClient.zadd(key, score, value, callback); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	module.sortedSetRemove = function(key, value, callback) { | 
					
						
							|  |  |  | 		redisClient.zrem(key, value, callback); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-12-02 19:40:11 -05:00
										 |  |  | 	module.getSortedSetRange = function(key, start, stop, callback) { | 
					
						
							| 
									
										
										
										
											2013-12-02 21:20:55 -05:00
										 |  |  | 		redisClient.zrange(key, start, stop, callback); | 
					
						
							| 
									
										
										
										
											2013-12-02 19:40:11 -05:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	module.getSortedSetRevRange = function(key, start, stop, callback) { | 
					
						
							| 
									
										
										
										
											2013-12-02 21:20:55 -05:00
										 |  |  | 		redisClient.zrevrange(key, start, stop, callback); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	module.getSortedSetRevRangeByScore = function(args, callback) { | 
					
						
							|  |  |  | 		redisClient.zrevrangebyscore(args, callback); | 
					
						
							| 
									
										
										
										
											2013-12-02 19:40:11 -05:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	module.sortedSetCount = function(key, min, max, callback) { | 
					
						
							|  |  |  | 		redisClient.zcount(key, min, max, callback); | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2013-12-02 17:10:26 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-12-02 19:40:11 -05:00
										 |  |  | 	// lists
 | 
					
						
							|  |  |  | 	module.listPrepend = function(key, value, callback) { | 
					
						
							|  |  |  | 		redisClient.lpush(key, value, callback); | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2013-12-02 17:10:26 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-12-02 19:40:11 -05:00
										 |  |  | 	module.listAppend = function(key, value, callback) { | 
					
						
							|  |  |  | 		redisClient.rpush(key, value, callback); | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2013-12-02 15:46:25 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-12-02 19:40:11 -05:00
										 |  |  | 	module.getListRange = function(key, start, stop, callback) { | 
					
						
							|  |  |  | 		redisClient.lrange(key, start, stop, callback); | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2013-12-02 15:46:25 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-12-02 21:20:55 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-12-02 15:46:25 -05:00
										 |  |  | }(exports)); | 
					
						
							| 
									
										
										
										
											2013-12-02 15:45:15 -05:00
										 |  |  | 
 |