forked from discord-relay-chat/drc
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathlogger.js
More file actions
67 lines (50 loc) · 1.8 KB
/
logger.js
File metadata and controls
67 lines (50 loc) · 1.8 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
const fs = require('fs');
const path = require('path');
const util = require('util');
const config = require('config');
const { NAME, VERSION } = require('./util');
const LEVELS = ['log', 'info', 'warn', 'error', 'debug'];
const enabledLevels = new Set(LEVELS);
function enableLevel (l) {
enabledLevels.add(l);
}
function disableLevel (l) {
enabledLevels.delete(l);
}
let logger;
function initialize (processName = process.title, overrideConsole = true, onlyToFile = false) {
if (!logger) {
if (!fs.existsSync(config.app.log.path)) {
fs.mkdirSync(config.app.log.path);
}
const APP_NAMEVER = [NAME, VERSION, processName, process.pid].join('/');
const dsMapper = (dsArr, colors = false) => dsArr.map(x => typeof x === 'string' ? x : util.inspect(x, { colors, depth: null })).join(' ');
const _outStream = fs.createWriteStream(path.join(config.app.log.path, `${processName}.log`));
const _console = LEVELS.reduce((a, x) => ({ [x]: console[x], ...a }), {});
const _emit = (level, ...a) => {
if (!enabledLevels.has(level)) {
return;
}
const dstrArr = [
new Date(),
'[' + (config.app.log.addNameVerPrefix || process.env.DRC_LOG_ADD_NAME ? `${APP_NAMEVER}/${level}` : level) + ']',
...a
];
_outStream.write(dsMapper([{ level }, ...dstrArr, '\n']));
if (!onlyToFile) {
_console[level](dsMapper(dstrArr, true));
}
};
logger = LEVELS.reduce((a, lvl) => ({ [lvl]: _emit.bind(logger, lvl), ...a }), { APP_NAMEVER });
if (overrideConsole) {
LEVELS.forEach(level => (console[level] = logger[level]));
}
if (!process.env.DEBUG) {
disableLevel('debug');
}
}
return logger;
}
initialize.enableLevel = enableLevel;
initialize.disableLevel = disableLevel;
module.exports = initialize;