mirror of
https://github.com/NodeBB/NodeBB.git
synced 2025-11-01 19:46:01 +01:00
started dbal
This commit is contained in:
6
src/database.js
Normal file
6
src/database.js
Normal file
@@ -0,0 +1,6 @@
|
|||||||
|
|
||||||
|
|
||||||
|
var nconf = require('nconf');
|
||||||
|
db = require('./databases/' + nconf.get('database'));
|
||||||
|
|
||||||
|
module.exports = db;
|
||||||
0
src/database/mongo.js
Normal file
0
src/database/mongo.js
Normal file
5
src/database/redis.js
Normal file
5
src/database/redis.js
Normal file
@@ -0,0 +1,5 @@
|
|||||||
|
var RDB = require('redis');
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
(function()
|
||||||
78
src/redis.js
78
src/redis.js
@@ -1,78 +0,0 @@
|
|||||||
(function(module) {
|
|
||||||
'use strict';
|
|
||||||
|
|
||||||
var RedisDB,
|
|
||||||
redis = require('redis'),
|
|
||||||
utils = require('./../public/src/utils.js'),
|
|
||||||
winston = require('winston'),
|
|
||||||
nconf = require('nconf'),
|
|
||||||
redis_socket_or_host = nconf.get('redis:host');
|
|
||||||
|
|
||||||
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 */
|
|
||||||
RedisDB = redis.createClient(nconf.get('redis:host'));
|
|
||||||
} else {
|
|
||||||
/* Else, connect over tcp/ip */
|
|
||||||
RedisDB = redis.createClient(nconf.get('redis:port'), nconf.get('redis:host'));
|
|
||||||
}
|
|
||||||
|
|
||||||
if (nconf.get('redis:password')) {
|
|
||||||
RedisDB.auth(nconf.get('redis:password'));
|
|
||||||
}
|
|
||||||
|
|
||||||
var db = parseInt(nconf.get('redis:database'), 10);
|
|
||||||
if (db){
|
|
||||||
RedisDB.select(db, function(error){
|
|
||||||
if(error !== null){
|
|
||||||
winston.error("NodeBB could not connect to your Redis database. Redis returned the following error: " + error.message);
|
|
||||||
process.exit();
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
RedisDB.handle = function(error) {
|
|
||||||
if (error !== null) {
|
|
||||||
winston.err(error);
|
|
||||||
if (global.env !== 'production') {
|
|
||||||
throw new Error(error);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
/*
|
|
||||||
* A possibly more efficient way of doing multiple sismember calls
|
|
||||||
*/
|
|
||||||
RedisDB.sismembers = function(key, needles, callback) {
|
|
||||||
var tempkey = key + ':temp:' + utils.generateUUID();
|
|
||||||
RedisDB.sadd(tempkey, needles, function() {
|
|
||||||
RedisDB.sinter(key, tempkey, function(err, data) {
|
|
||||||
RedisDB.del(tempkey);
|
|
||||||
callback(err, data);
|
|
||||||
});
|
|
||||||
});
|
|
||||||
};
|
|
||||||
|
|
||||||
/*
|
|
||||||
* gets fields of a hash as an object instead of an array
|
|
||||||
*/
|
|
||||||
RedisDB.hmgetObject = function(key, fields, callback) {
|
|
||||||
RedisDB.hmget(key, fields, function(err, data) {
|
|
||||||
|
|
||||||
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);
|
|
||||||
});
|
|
||||||
};
|
|
||||||
|
|
||||||
module.exports = RedisDB;
|
|
||||||
|
|
||||||
}(module));
|
|
||||||
Reference in New Issue
Block a user