Рефакторинг

This commit is contained in:
Book Pauk
2019-10-28 22:49:02 +07:00
parent 625fd9d1a4
commit b64985349e
7 changed files with 55 additions and 47 deletions

49
server/core/AppLogger.js Normal file
View File

@@ -0,0 +1,49 @@
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;

View File

@@ -6,7 +6,7 @@ const FileDownloader = require('./FileDownloader');
const FileDecompressor = require('./FileDecompressor');
const BookConverter = require('./BookConverter');
const utils = require('./utils');
const log = require('./getLogger').getLog();
const log = new (require('./AppLogger'))().log;//singleton
let singleCleanExecute = false;

View File

@@ -1,40 +0,0 @@
const fs = require('fs-extra');
const Logger = require('./Logger');
let logger = null;
function initLogger(config) {
if (logger)
logger.close();
let loggerParams = null;
if (config.loggingEnabled) {
fs.ensureDirSync(config.logDir);
loggerParams = [
{log: 'ConsoleLog'},
{log: 'FileLog', fileName: `${config.logDir}/${config.name}.log`},
];
}
logger = new Logger(loggerParams);
return logger;
}
function getLogger() {
if (logger)
return logger;
throw new Error('getLogger error: logger not initialized');
}
function getLog() {
const l = getLogger();
return l.log.bind(l);
}
module.exports = {
initLogger,
getLogger,
getLog,
};