forked from vincss/mcsleepingserverstarter
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathsleepingLogger.js
53 lines (44 loc) · 1.33 KB
/
sleepingLogger.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
const dateFormat = require('dateformat');
const winston = require('winston');
const fileSystem = require('fs');
const DefaultLogger = {
info: (...params) => console.info(params),
error: (...params) => console.error(params)
};
let logger = DefaultLogger;
let initialized = false;
const logFolder = 'logs/';
function getDate() {
return dateFormat(new Date(), 'yyyy-mm-dd HH:MM:ss.l');
};
function getLogger() {
try {
if(initialized) {
return logger;
}
if (!fileSystem.existsSync(logFolder)) {
fileSystem.mkdirSync(logFolder);
}
logger = new winston.Logger({
level: 'info',
transports: [new (winston.transports.Console)({
timestamp: getDate,
colorize: true
}), new (winston.transports.File)({
filename: `${logFolder}sleepingServer.log`,
timestamp: getDate,
maxsize: 2 * 1024 * 1024,
maxFiles: 3,
json: false
})]
});
} catch (error) {
logger.error('Failed to initialize logger', error);
logger = DefaultLogger;
}
initialized = true;
logger.info('.........................');
logger.info('... A new story begin ...');
return logger;
}
module.exports = { getLogger };