-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathlogger.js
120 lines (118 loc) · 3.59 KB
/
logger.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
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
const winston = require('winston');
const DailyRotateFile = require('winston-daily-rotate-file');
const config = require('./config');
/**
* Custom log levels for the logger.
* @typedef {Object} CustomLevels
* @property {number} error - Error level.
* @property {number} warn - Warning level.
* @property {number} info - Information level.
* @property {number} network - Custom level for network-related events.
* @property {number} verbose - Verbose level.
* @property {number} debug - Debug level.
* @property {number} silly - Silly level.
*/
const customLevels = {
error: 0,
warn: 1,
info: 2,
network: 3, // Custom level for network-related events
database: 4, // custom level for database-related events
verbose: 5,
debug: 6,
silly: 7
};
/**
* Colors associated with custom log levels for better console output.
* @typedef {Object} Colors
* @property {string} error - Red color for errors.
* @property {string} warn - Yellow color for warnings.
* @property {string} info - Green color for information.
* @property {string} network - Blue color for network-related events.
* @property {string} verbose - Cyan color for verbose messages.
* @property {string} debug - White color for debug messages.
* @property {string} silly - Magenta color for silly messages.
*/
const colors = {
error: 'red',
warn: 'yellow',
info: 'green',
network: 'blue', // Custom color for network-related events
database: 'blue', // Custom color for database-related events
verbose: 'cyan',
debug: 'grey',
silly: 'magenta'
};
/**
* Winston logger configuration.
* @type {winston.Logger}
* @namespace
* @description Configures the logger with custom levels, colors, and transports.
* @author Tarik Azzouzi
*/
const logger = winston.createLogger({
levels: customLevels,
format: winston.format.combine(
winston.format.errors({ stack: true }),
winston.format.timestamp(),
winston.format.json()
),
transports: [
/**
* Console transport for logging to the console.
* @type {winston.transports.Console}
*/
new winston.transports.Console({
levels: customLevels,
level: 'silly',
format: winston.format.combine(
winston.format.colorize({ colors }),
winston.format.timestamp({
format: 'YYYY-MM-DD hh:mm:ss.SSS A'
}),
winston.format.printf(
(info) => `[${info.timestamp}] ${info.level}: ${info.message}`
)
)
}),
/**
* DailyRotateFile transport for logging combined messages to separate files.
* @type {winston.transports.DailyRotateFile}
*/
new DailyRotateFile({
filename: 'logs/combined-%DATE%.log',
datePattern: 'YYYY-MM-DD',
zippedArchive: true,
maxSize: '300m',
maxFiles: '7d'
})
]
});
logger.debug('Debug status: ' + config.dev.DEBUG);
// If debug mode is enabled, add a DailyRotateFile transport for logging level debug-related messages.
if (config.dev.DEBUG) {
logger.debug(
'Debug mode enabled, adding DailyRotateFile transport for logging network-related messages and debug messages.'
);
/**
* DailyRotateFile transport for logging debug-related messages.
* @type {winston.transports.DailyRotateFile}
*/
logger.add(
new DailyRotateFile({
filename: 'logs/debug-%DATE%.log',
datePattern: 'YYYY-MM-DD',
level: 'debug',
zippedArchive: true,
maxSize: '300m',
maxFiles: '7d'
})
);
} else {
logger.debug("Debug mode disabled, won't add DailyRotateFile transports.");
}
/**
* Exports the configured logger for use in other modules.
* @type {winston.Logger}
*/
module.exports = logger;