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/events.js

137 lines
3.3 KiB
JavaScript

11 years ago
'use strict';
11 years ago
var async = require('async');
var validator = require('validator');
var db = require('./database');
var batch = require('./batch');
var user = require('./user');
var utils = require('../public/src/utils');
11 years ago
(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);
11 years ago
}
], function (err, result) {
callback(err);
11 years ago
});
10 years ago
};
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) {
9 years ago
addUserData(eventsData, 'uid', 'user', next);
},
function (eventsData, next) {
9 years ago
addUserData(eventsData, 'targetUid', 'targetUser', next);
},
function (eventsData, next) {
eventsData.forEach(function (event) {
Object.keys(event).forEach(function (key) {
if (typeof event[key] === 'string') {
event[key] = validator.escape(String(event[key] || ''));
}
});
var e = utils.merge(event);
9 years ago
e.eid = e.uid = e.type = e.ip = e.user = undefined;
event.jsonString = JSON.stringify(e, null, 4);
event.timestampISO = new Date(parseInt(event.timestamp, 10)).toUTCString();
});
9 years ago
next(null, eventsData);
11 years ago
}
], callback);
10 years ago
};
11 years ago
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;
11 years ago
});
if (!uids.length) {
return callback(null, eventsData);
}
11 years ago
async.parallel({
isAdmin: function (next) {
user.isAdministrator(uids, next);
},
userData: function (next) {
9 years ago
user.getUsersFields(uids, ['username', 'userslug', 'picture'], next);
}
}, function (err, results) {
if (err) {
return callback(err);
10 years ago
}
var userData = results.userData;
10 years ago
var map = {};
userData.forEach(function (user, index) {
user.isAdmin = results.isAdmin[index];
map[user.uid] = user;
10 years ago
});
eventsData.forEach(function (event) {
if (map[event[field]]) {
event[objectName] = map[event[field]];
10 years ago
}
10 years ago
});
callback(null, eventsData);
});
}
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 () {};
10 years ago
batch.processSortedSet('events:time', function (eids, next) {
events.deleteEvents(eids, next);
}, {alwaysStartAt: 0}, callback);
};
11 years ago
}(module.exports));