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.
70 lines
1.5 KiB
JavaScript
70 lines
1.5 KiB
JavaScript
|
|
|
|
var fs = require('fs'),
|
|
path = require('path'),
|
|
nconf = require('nconf'),
|
|
user = require('./user');
|
|
|
|
|
|
(function(events) {
|
|
events.logPasswordChange = function(uid) {
|
|
log(uid, 'changed password');
|
|
}
|
|
|
|
events.logPasswordReset = function(uid) {
|
|
log(uid, 'reset password');
|
|
}
|
|
|
|
events.logEmailChange = function(uid, oldEmail, newEmail) {
|
|
log(uid,'changed email from "' + oldEmail + '" to "' + newEmail +'"');
|
|
}
|
|
|
|
events.logAdminLogin = function(uid) {
|
|
log(uid, 'logged into admin panel');
|
|
}
|
|
|
|
events.logPostEdit = function(uid, pid) {
|
|
log(uid, 'edited post (pid ' + pid + ')');
|
|
}
|
|
|
|
events.logPostDelete = function(uid, pid) {
|
|
log(uid, 'deleted post (pid ' + pid + ')');
|
|
}
|
|
|
|
events.logPostRestore = function(uid, pid) {
|
|
log(uid, 'restored post (pid ' + pid + ')');
|
|
}
|
|
|
|
events.logTopicDelete = function(uid, tid) {
|
|
log(uid, 'deleted topic (tid ' + tid + ')');
|
|
}
|
|
|
|
events.logTopicRestore = function(uid, tid) {
|
|
log(uid, 'restored topic (tid ' + tid + ')');
|
|
}
|
|
|
|
function log(uid, string) {
|
|
|
|
user.getUserField(uid, 'username', function(err, username) {
|
|
if(err) {
|
|
winston.error('Error logging event. ' + err.message);
|
|
return;
|
|
}
|
|
|
|
var date = new Date().toUTCString();
|
|
|
|
var msg = '[' + date + '] - ' + username + '(uid ' + uid + ') ' + string + '\n';
|
|
var logFile = path.join(nconf.get('base_dir'), 'events.log');
|
|
|
|
fs.appendFile(logFile, msg, function(err) {
|
|
if(err) {
|
|
winston.error('Error logging event. ' + err.message);
|
|
return;
|
|
}
|
|
});
|
|
});
|
|
|
|
|
|
}
|
|
|
|
}(module.exports)); |