Files
liberama/server/core/AppLogger.js
2019-10-28 22:49:02 +07:00

50 lines
1000 B
JavaScript

const fs = require('fs-extra');
const Logger = require('./Logger');
let instance = null;
//singleton
class AppLogger {
constructor() {
if (!instance) {
instance = this;
}
this.inited = false;
return instance;
}
init(config) {
if (this.inited)
throw new Error('already inited');
let loggerParams = null;
if (config.loggingEnabled) {
fs.ensureDirSync(config.logDir);
loggerParams = [
{log: 'ConsoleLog'},
{log: 'FileLog', fileName: `${config.logDir}/${config.name}.log`},
];
}
this._logger = new Logger(loggerParams);
this.inited = true;
return this.logger;
}
get logger() {
if (this.inited)
return this._logger;
throw new Error('not inited');
}
get log() {
const l = this.logger;
return l.log.bind(l);
}
}
module.exports = AppLogger;