102 lines
3.2 KiB
JavaScript
102 lines
3.2 KiB
JavaScript
const fs = require('fs-extra');
|
|
const path = require('path');
|
|
const argv = require('minimist')(process.argv.slice(2));
|
|
const express = require('express');
|
|
const compression = require('compression');
|
|
|
|
async function init() {
|
|
//config
|
|
const configManager = new (require('./config'))();//singleton
|
|
await configManager.init();
|
|
configManager.userConfigFile = argv.config;
|
|
await configManager.load();
|
|
const config = configManager.config;
|
|
|
|
//logger
|
|
const appLogger = new (require('./core/AppLogger'))();//singleton
|
|
await appLogger.init(config);
|
|
const log = appLogger.log;
|
|
|
|
//dirs
|
|
log(`${config.name} v${config.version}, Node.js ${process.version}`);
|
|
log('Initializing');
|
|
|
|
await fs.ensureDir(config.dataDir);
|
|
await fs.ensureDir(config.uploadDir);
|
|
await fs.ensureDir(config.sharedDir);
|
|
|
|
await fs.ensureDir(config.tempDir);
|
|
await fs.emptyDir(config.tempDir);
|
|
|
|
const appDir = `${config.publicDir}/app`;
|
|
const appNewDir = `${config.publicDir}/app_new`;
|
|
if (await fs.pathExists(appNewDir)) {
|
|
await fs.remove(appDir);
|
|
await fs.move(appNewDir, appDir);
|
|
}
|
|
|
|
//connections
|
|
const connManager = new (require('./db/ConnManager'))();//singleton
|
|
await connManager.init(config);
|
|
}
|
|
|
|
async function main() {
|
|
const log = new (require('./core/AppLogger'))().log;//singleton
|
|
const config = new (require('./config'))().config;//singleton
|
|
|
|
//servers
|
|
for (let server of config.servers) {
|
|
if (server.mode !== 'none') {
|
|
const app = express();
|
|
const serverConfig = Object.assign({}, config, server);
|
|
|
|
let devModule = undefined;
|
|
if (serverConfig.branch == 'development') {
|
|
const devFileName = './dev.js'; //require ignored by pkg -50Mb executable size
|
|
devModule = require(devFileName);
|
|
devModule.webpackDevMiddleware(app);
|
|
}
|
|
|
|
app.use(compression({ level: 1 }));
|
|
app.use(express.json({limit: '10mb'}));
|
|
if (devModule)
|
|
devModule.logQueries(app);
|
|
|
|
app.use(express.static(serverConfig.publicDir, {
|
|
maxAge: '30d',
|
|
setHeaders: (res, filePath) => {
|
|
if (path.basename(path.dirname(filePath)) == 'tmp') {
|
|
res.set('Content-Type', 'text/xml');
|
|
res.set('Content-Encoding', 'gzip');
|
|
}
|
|
}
|
|
}));
|
|
|
|
require('./routes').initRoutes(app, serverConfig);
|
|
|
|
if (devModule) {
|
|
devModule.logErrors(app);
|
|
} else {
|
|
app.use(function(err, req, res, next) {// eslint-disable-line no-unused-vars
|
|
log(LM_ERR, err.stack);
|
|
res.sendStatus(500);
|
|
});
|
|
}
|
|
|
|
app.listen(serverConfig.port, serverConfig.ip, function() {
|
|
log(`Server-${serverConfig.serverName} is ready on ${serverConfig.ip}:${serverConfig.port}, mode: ${serverConfig.mode}`);
|
|
});
|
|
}
|
|
}
|
|
}
|
|
|
|
|
|
(async() => {
|
|
try {
|
|
await init();
|
|
await main();
|
|
} catch (e) {
|
|
console.error(e);
|
|
process.exit(1);
|
|
}
|
|
})(); |