thelounge/src/log.js

45 lines
998 B
JavaScript
Raw Normal View History

2014-09-16 21:47:01 +02:00
var config = require("../config");
var fs = require("fs");
var mkdirp = require("mkdirp");
var moment = require("moment");
var Helper = require("./helper");
module.exports = {
2014-09-16 22:06:13 +02:00
write: function(user, network, chan, msg) {
var path = Helper.resolveHomePath("users", user, "logs", network);
2014-09-16 21:47:01 +02:00
try {
mkdirp.sync(path);
} catch(e) {
return;
}
var format = (config.logs || {}).format || "YYYY-MM-DD HH:mm:ss";
var tz = (config.logs || {}).timezone || "UTC+00:00";
var time = moment().zone(tz).format(format);
var line = "[" + time + "] ";
if (msg.type == "message") {
// Format:
// [2014-01-01 00:00:00] <Arnold> Put that cookie down.. Now!!
line += "<" + msg.from + "> " + msg.text;
} else {
// Format:
// [2014-01-01 00:00:00] * Arnold quit
line += "* " + msg.from + " " + msg.type;
if (msg.text) {
line += " " + msg.text;
}
}
try {
fs.appendFile(
2014-09-16 22:06:13 +02:00
path + "/" + chan + ".log",
2014-09-16 21:47:01 +02:00
line + "\n"
);
} catch(e) {
return;
}
}
};