webServer.js 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115
  1. /*
  2. The MIT License (MIT)
  3. Copyright (c) 2014-2018 Nikolai Suslov and the Krestianstvo.org project contributors. (https://github.com/NikolaySuslov/livecodingspace/blob/master/LICENSE.md)
  4. */
  5. var express = require('express'),
  6. compression = require('compression'),
  7. serveStatic = require('serve-static'),
  8. cors = require('cors'),
  9. morgan = require('morgan'),
  10. path = require('path'),
  11. fs = require('fs'),
  12. http = require('http'),
  13. https = require('https'),
  14. //logger = require('./server/logger'),
  15. config = require('./server/readConfig')
  16. var app = express();
  17. // var privateKey = fs.readFileSync('sslcert/server.key', 'utf8');
  18. // var certificate = fs.readFileSync('sslcert/server.crt', 'utf8');
  19. function registerReflector(srv) {
  20. if (global.configuration.reflector === undefined)
  21. global.configuration.reflector = false;
  22. if (global.configuration.reflector) {
  23. //logger.info('register reflector server...\n');
  24. console.log('register reflector server...\n');
  25. var reflectorServer = require('lcs-reflector'),
  26. sio = require('socket.io')(srv);
  27. sio.set('transports', ['websocket']);
  28. sio.sockets.on('connection', reflectorServer.OnConnection);
  29. global.instances = {};
  30. }
  31. }
  32. function startServer() {
  33. //logger.info('Welcome to LiveCoding.space App server!\n');
  34. console.log('Welcome to LiveCoding.space App server!\n');
  35. config.readConfigFile();
  36. app.use(compression());
  37. app.use(serveStatic(__dirname + '/public'));
  38. app.use(cors());
  39. // app.use(function(req, res, next) {
  40. // res.header("Access-Control-Allow-Origin", "*");
  41. // res.header("Access-Control-Allow-Headers", "Origin, X-Requested-With, Content-Type, Accept, Authorization");
  42. // next();
  43. // });
  44. app.use(morgan('combined'));
  45. /*=====Site specific paths=====*/
  46. // optional functions to load defaults (not required if DB is already bootstrapped)
  47. function readDirR(dir) {
  48. if (fs.statSync(dir).isDirectory()) {
  49. return Array.prototype.concat(...fs.readdirSync(dir).map(f => readDirR(path.join(dir, f))
  50. ))
  51. } else {
  52. if ((dir.indexOf('.yaml') !== -1) || (dir.indexOf('.js') !== -1) || (dir.indexOf('.html') !== -1)
  53. || (dir.indexOf('.json') !== -1))
  54. // a little hack to resolve serving file paths under PC/Windows file system...
  55. return dir.replace(__dirname, '').replace(/\\/g, '/').replace('/public/', "/");
  56. }
  57. }
  58. app.get('/proxy-files', function (req, res) {
  59. // console.log(allFilesSync(__dirname + '/public/proxy/'));
  60. res.writeHead(200, { "Content-Type": "application/json" });
  61. let json = JSON.stringify(readDirR(__dirname + '/public/defaults/proxy/'));
  62. res.end(json);
  63. });
  64. app.get('/world-files', function (req, res) {
  65. // console.log(allFilesSync(__dirname + '/public/defaults/templates/'));
  66. res.writeHead(200, { "Content-Type": "application/json" });
  67. let json = JSON.stringify(readDirR(__dirname + '/public/defaults/worlds/'));
  68. res.end(json);
  69. });
  70. // send all requests to index.html so browserHistory in React Router works
  71. app.get('*', function (req, res) {
  72. res.sendFile(path.join(__dirname + '/public/', 'index.html'))
  73. })
  74. //=========end of specific===========
  75. // app.listen(port);
  76. // console.log('Web server is started on port: '+ port);
  77. var conf = config.parseConfigOptions();
  78. var srv = conf.ssl ? https.createServer(conf.sslOptions, app).listen(conf.port) : http.createServer(app).listen(conf.port);
  79. console.log('Serving on port ' + conf.port);
  80. registerReflector(srv);
  81. }
  82. exports.start = startServer;