index.js 3.5 KB

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