Public API for a society manager application

index.js 2.0KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768
  1. var express = require('express');
  2. var serveIndex = require('serve-index');
  3. var https = require('https');
  4. var app = express();
  5. var route_manager = require("./utils/route-manager.js");
  6. var scheduler = require("./presenters/schedule-controller.js");
  7. var bodyParser = require('body-parser');
  8. var FileStreamRotator = require('file-stream-rotator');
  9. var morgan = require('morgan');
  10. var fs = require('fs');
  11. var logDirectory = 'log'
  12. var production = process.argv[2];
  13. scheduler.register_existing_events();
  14. // ensure log directory exists
  15. fs.existsSync(logDirectory) || fs.mkdirSync(logDirectory)
  16. // create a rotating write stream
  17. var accessLogStream = FileStreamRotator.getStream({
  18. date_format: 'YYYYMMDD',
  19. filename: logDirectory + '/access-%DATE%.log',
  20. frequency: 'daily',
  21. verbose: false
  22. })
  23. // setup the logger
  24. app.use(morgan('short', {stream: accessLogStream}))
  25. app.use(morgan('short'));
  26. app.use(function(req, res, next) {
  27. res.header("Access-Control-Allow-Origin", "*");
  28. res.header("Access-Control-Allow-Headers", "Origin, X-Requested-With, Content-Type, Accept");
  29. next();
  30. });
  31. app.use(bodyParser.json()); // for parsing application/json
  32. app.use(bodyParser.urlencoded({ extended: true })); // for parsing application/x-www-form-urlencoded
  33. app.use('/', route_manager);
  34. app.use('/source', require('magic-window')('/source', { ignore: ['config', 'redis', 'cert.pem', 'key.pem', 'dump.rdb'] }))
  35. app.use('/log', express.static('log'));
  36. app.use('/log', serveIndex('log', {'icons': true}));
  37. app.listen(3000, function () {
  38. console.log('Now accepting connections on port 3000.');
  39. });
  40. if (production === "-p") {
  41. var prkey = fs.readFileSync('key.pem');
  42. var certi = fs.readFileSync('cert.pem');
  43. app.listen(80, function() {
  44. console.log('Now accepting connections on port 80.');
  45. });
  46. https.createServer({
  47. key: prkey,
  48. cert: certi
  49. }, app).listen(443, function() {
  50. console.log("Now accepting HTTPS connections on port 443.");
  51. });
  52. }
  53. process.on('SIGINT', function() {
  54. console.log( "\nRecieved Ctrl-C, shutting down." );
  55. process.exit(0);
  56. })