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

82 lines
1.9 KiB
JavaScript

11 years ago
var fs = require('fs'),
path = require('path'),
nconf = require('nconf'),
user = require('./user');
(function(events) {
var logFileName = 'events.log';
11 years ago
events.logPasswordChange = function(uid) {
logWithUser(uid, 'changed password');
11 years ago
}
events.logPasswordReset = function(uid) {
logWithUser(uid, 'reset password');
11 years ago
}
events.logEmailChange = function(uid, oldEmail, newEmail) {
logWithUser(uid,'changed email from "' + oldEmail + '" to "' + newEmail +'"');
11 years ago
}
events.logUsernameChange = function(uid, oldUsername, newUsername) {
logWithUser(uid,'changed username from "' + oldUsername + '" to "' + newUsername +'"');
}
11 years ago
events.logAdminLogin = function(uid) {
logWithUser(uid, 'logged into admin panel');
11 years ago
}
events.logPostEdit = function(uid, pid) {
logWithUser(uid, 'edited post (pid ' + pid + ')');
11 years ago
}
events.logPostDelete = function(uid, pid) {
logWithUser(uid, 'deleted post (pid ' + pid + ')');
11 years ago
}
events.logPostRestore = function(uid, pid) {
logWithUser(uid, 'restored post (pid ' + pid + ')');
11 years ago
}
events.logTopicDelete = function(uid, tid) {
logWithUser(uid, 'deleted topic (tid ' + tid + ')');
11 years ago
}
events.logTopicRestore = function(uid, tid) {
logWithUser(uid, 'restored topic (tid ' + tid + ')');
11 years ago
}
function logWithUser(uid, string) {
11 years ago
user.getUserField(uid, 'username', function(err, username) {
if(err) {
winston.error('Error logging event. ' + err.message);
return;
}
var msg = '[' + new Date().toUTCString() + '] - ' + username + '(uid ' + uid + ') ' + string;
log(msg);
});
}
11 years ago
events.log = function(msg) {
var logFile = path.join(nconf.get('base_dir'), logFileName);
11 years ago
fs.appendFile(logFile, msg + '\n', function(err) {
if(err) {
winston.error('Error logging event. ' + err.message);
return;
}
11 years ago
});
}
11 years ago
events.getLog = function(callback) {
var logFile = path.join(nconf.get('base_dir'), logFileName);
11 years ago
fs.readFile(logFile, callback);
11 years ago
}
}(module.exports));