-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathindex.js
60 lines (53 loc) · 1.32 KB
/
index.js
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
const winston = require('winston')
require('winston-daily-rotate-file')
const consoleLogger = new winston.transports.Console()
class Logger {
constructor(name, logFile, logToConsole = false) {
this.name = name
this.logFile = logFile
this.logger = null
this.logger = winston.createLogger({
transports: []
})
const rtransport = new winston.transports.DailyRotateFile({
filename: logFile,
datePattern: 'YYYY-MM-DD',
zippedArchive: false,
maxSize: '10m',
maxFiles: '7d',
symlinkName: logFile,
})
if (logFile !== null) {
this.logger.add(
winston.createLogger({
transports: [rtransport],
})
)
}
if (logToConsole) {
this.logger.add(consoleLogger)
}
}
error(message, details = {}, tag = null) {
let msg = message
if (Object.keys(details).length > 0) {
msg = { message, details }
}
this.logger.error(msg)
}
info(message, details = {}, tag = null) {
let msg = message
if (Object.keys(details).length > 0) {
msg = { message, details }
}
this.logger.info(msg)
}
warn(message, details = {}, tag = null) {
let msg = message
if (Object.keys(details).length > 0) {
msg = { message, details }
}
this.logger.warn(msg)
}
}
module.exports = Logger