index.js 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103
  1. require('tls').DEFAULT_MIN_VERSION = 'TLSv1';
  2. const fs = require('fs-extra');
  3. const path = require('path');
  4. const argv = require('minimist')(process.argv.slice(2));
  5. const express = require('express');
  6. const compression = require('compression');
  7. async function init() {
  8. //config
  9. const configManager = new (require('./config'))();//singleton
  10. await configManager.init();
  11. configManager.userConfigFile = argv.config;
  12. await configManager.load();
  13. const config = configManager.config;
  14. //logger
  15. const appLogger = new (require('./core/AppLogger'))();//singleton
  16. await appLogger.init(config);
  17. const log = appLogger.log;
  18. //dirs
  19. log(`${config.name} v${config.version}, Node.js ${process.version}`);
  20. log('Initializing');
  21. await fs.ensureDir(config.dataDir);
  22. await fs.ensureDir(config.uploadDir);
  23. await fs.ensureDir(config.sharedDir);
  24. await fs.ensureDir(config.tempDir);
  25. await fs.emptyDir(config.tempDir);
  26. const appDir = `${config.publicDir}/app`;
  27. const appNewDir = `${config.publicDir}/app_new`;
  28. if (await fs.pathExists(appNewDir)) {
  29. await fs.remove(appDir);
  30. await fs.move(appNewDir, appDir);
  31. }
  32. //connections
  33. const connManager = new (require('./db/ConnManager'))();//singleton
  34. await connManager.init(config);
  35. }
  36. async function main() {
  37. const log = new (require('./core/AppLogger'))().log;//singleton
  38. const config = new (require('./config'))().config;//singleton
  39. //servers
  40. for (let server of config.servers) {
  41. if (server.mode !== 'none') {
  42. const app = express();
  43. const serverConfig = Object.assign({}, config, server);
  44. let devModule = undefined;
  45. if (serverConfig.branch == 'development') {
  46. const devFileName = './dev.js'; //require ignored by pkg -50Mb executable size
  47. devModule = require(devFileName);
  48. devModule.webpackDevMiddleware(app);
  49. }
  50. app.use(compression({ level: 1 }));
  51. app.use(express.json({limit: '10mb'}));
  52. if (devModule)
  53. devModule.logQueries(app);
  54. app.use(express.static(serverConfig.publicDir, {
  55. maxAge: '30d',
  56. setHeaders: (res, filePath) => {
  57. if (path.basename(path.dirname(filePath)) == 'tmp') {
  58. res.set('Content-Type', 'text/xml');
  59. res.set('Content-Encoding', 'gzip');
  60. }
  61. }
  62. }));
  63. require('./routes').initRoutes(app, serverConfig);
  64. if (devModule) {
  65. devModule.logErrors(app);
  66. } else {
  67. app.use(function(err, req, res, next) {// eslint-disable-line no-unused-vars
  68. log(LM_ERR, err.stack);
  69. res.sendStatus(500);
  70. });
  71. }
  72. app.listen(serverConfig.port, serverConfig.ip, function() {
  73. log(`Server-${serverConfig.serverName} is ready on ${serverConfig.ip}:${serverConfig.port}, mode: ${serverConfig.mode}`);
  74. });
  75. }
  76. }
  77. }
  78. (async() => {
  79. try {
  80. await init();
  81. await main();
  82. } catch (e) {
  83. console.error(e);
  84. process.exit(1);
  85. }
  86. })();