-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathMultiLogger.js
More file actions
58 lines (48 loc) · 1.67 KB
/
MultiLogger.js
File metadata and controls
58 lines (48 loc) · 1.67 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
/* eslint-disable import/extensions */
import Logger from './Logger.js';
import LoggerLevel from './LoggerLevel.js';
export default class MultiLogger extends Logger {
constructor(loggers, category, level, levels, meta) {
super(category, level, levels, meta);
this.loggers = loggers || [];
this.meta = meta || {};
MultiLogger.prototype.isLevelEnabled = Logger.prototype.isLevelEnabled;
MultiLogger.prototype.isDebugEnabled = Logger.prototype.isDebugEnabled;
MultiLogger.prototype.isVerboseEnabled = Logger.prototype.isVerboseEnabled;
MultiLogger.prototype.isInfoEnabled = Logger.prototype.isInfoEnabled;
MultiLogger.prototype.isWarnEnabled = Logger.prototype.isWarnEnabled;
MultiLogger.prototype.isErrorEnabled = Logger.prototype.isErrorEnabled;
MultiLogger.prototype.isFatalEnabled = Logger.prototype.isFatalEnabled;
}
setLevel(level) {
for (let i = 0; i < this.loggers.length; i++) {
this.loggers[i].setLevel(level);
}
this.level = this.levels[level || LoggerLevel.INFO];
}
log(level, message, meta) {
if (this.levels[level] <= this.level) {
for (let i = 0; i < this.loggers.length; i++) {
this.loggers[i].log(level, message, meta);
}
}
}
debug(message, meta) {
this.log(LoggerLevel.DEBUG, message, meta);
}
verbose(message, meta) {
this.log(LoggerLevel.VERBOSE, message, meta);
}
info(message, meta) {
this.log(LoggerLevel.INFO, message, meta);
}
warn(message, meta) {
this.log(LoggerLevel.WARN, message, meta);
}
error(message, meta) {
this.log(LoggerLevel.ERROR, message, meta);
}
fatal(message, meta) {
this.log(LoggerLevel.FATAL, message, meta);
}
}