Files
NodeBB/src/events.js

129 lines
2.9 KiB
JavaScript
Raw Normal View History

2013-12-21 19:42:21 -05:00
'use strict';
2013-12-21 19:42:21 -05:00
2015-02-01 19:11:58 -05:00
var async = require('async'),
2013-12-21 19:42:21 -05:00
2015-02-01 19:11:58 -05:00
db = require('./database'),
batch = require('./batch'),
user = require('./user'),
utils = require('../public/src/utils');
2013-12-21 19:42:21 -05:00
2015-02-01 19:11:58 -05:00
(function(events) {
events.log = function(data, callback) {
callback = callback || function() {};
async.waterfall([
function(next) {
db.incrObjectField('global', 'nextEid', next);
},
function(eid, next) {
data.timestamp = Date.now();
data.eid = eid;
async.parallel([
function(next) {
db.sortedSetAdd('events:time', data.timestamp, eid, next);
},
function(next) {
db.setObject('event:' + eid, data, next);
}
], next);
2014-02-19 13:30:31 -05:00
}
2015-02-01 19:11:58 -05:00
], function(err, result) {
callback(err);
2014-02-19 13:30:31 -05:00
});
2014-10-10 15:44:02 -04:00
};
2015-02-01 19:11:58 -05:00
events.getEvents = function(start, stop, callback) {
async.waterfall([
function(next) {
db.getSortedSetRevRange('events:time', start, stop, next);
},
function(eids, next) {
var keys = eids.map(function(eid) {
return 'event:' + eid;
});
db.getObjects(keys, next);
},
function(eventsData, next) {
eventsData.forEach(function(event) {
var e = utils.merge(event);
e.eid = e.uid = e.type = e.ip = undefined;
event.jsonString = JSON.stringify(e, null, 4);
event.timestampISO = new Date(parseInt(event.timestamp, 10)).toUTCString();
});
addUserData(eventsData, 'uid', 'user', next);
},
function(eventsData, next) {
addUserData(eventsData, 'targetUid', 'targetUser', next);
2013-12-21 19:42:21 -05:00
}
2015-02-01 19:11:58 -05:00
], callback);
2014-10-08 12:11:06 -04:00
};
2013-12-21 19:42:21 -05:00
2015-02-01 19:11:58 -05:00
function addUserData(eventsData, field, objectName, callback) {
var uids = eventsData.map(function(event) {
return event && event[field];
}).filter(function(uid, index, array) {
return uid && array.indexOf(uid) === index;
2013-12-21 19:42:21 -05:00
});
2015-02-01 19:11:58 -05:00
if (!uids.length) {
return callback(null, eventsData);
}
2013-12-21 19:42:21 -05:00
2015-02-01 19:11:58 -05:00
async.parallel({
isAdmin: function(next) {
user.isAdministrator(uids, next);
},
userData: function(next) {
2015-09-25 17:38:58 -04:00
user.getUsersFields(uids, ['username', 'userslug', 'picture'], next);
}
2015-02-01 19:11:58 -05:00
}, function(err, results) {
if (err) {
return callback(err);
2014-10-06 18:19:33 -04:00
}
2015-02-01 19:11:58 -05:00
var userData = results.userData;
2014-10-06 18:19:33 -04:00
2015-02-01 19:11:58 -05:00
var map = {};
userData.forEach(function(user, index) {
user.isAdmin = results.isAdmin[index];
map[user.uid] = user;
2014-10-06 18:19:33 -04:00
});
2015-02-01 19:11:58 -05:00
eventsData.forEach(function(event) {
if (map[event[field]]) {
event[objectName] = map[event[field]];
2014-10-06 18:19:33 -04:00
}
2014-10-08 12:11:06 -04:00
});
2015-02-01 19:11:58 -05:00
callback(null, eventsData);
});
2015-02-01 19:11:58 -05:00
}
events.deleteEvents = function(eids, callback) {
callback = callback || function() {};
async.parallel([
function(next) {
var keys = eids.map(function(eid) {
return 'event:' + eid;
});
db.deleteAll(keys, next);
},
function(next) {
db.sortedSetRemove('events:time', eids, next);
}
], callback);
};
events.deleteAll = function(callback) {
callback = callback || function() {};
2014-10-06 18:19:33 -04:00
2015-02-01 19:11:58 -05:00
batch.processSortedSet('events:time', function(eids, next) {
events.deleteEvents(eids, callback);
}, {alwaysStartAt: 0}, callback);
};
2013-12-21 19:42:21 -05:00
2015-02-01 19:11:58 -05:00
2014-04-10 20:31:57 +01:00
}(module.exports));