server.js 2.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273
  1. // modules
  2. var express = require('express'),
  3. app = express(),
  4. bodyParser = require('body-parser'),
  5. methodOverride = require('method-override'),
  6. morgan = require('morgan'),
  7. errorHandler = require('errorhandler'),
  8. FileStreamRotator = require('file-stream-rotator'),
  9. fs = require('fs'),
  10. mongoose = require('mongoose');
  11. //config
  12. var db = require('./config/db')[process.env.NODE_ENV],
  13. server = require('./config/server')[process.env.NODE_ENV],
  14. logDir = __dirname + '/logs';
  15. fs.existsSync(logDir) || fs.mkdirSync(logDir);
  16. var accessLogStream = FileStreamRotator.getStream({
  17. filename : logDir + '/access-%DATE%.log',
  18. frequency : 'daily',
  19. verbose : false,
  20. date_format: 'YYYY-MM-DD'
  21. });
  22. mongoose.connect(db.url);
  23. /** Hack to load Models before routing **/
  24. var models_path = __dirname + '/app/models'
  25. fs.readdirSync(models_path).forEach(function (file) {
  26. if (~file.indexOf('.js')) require(models_path + '/' + file)
  27. })
  28. switch(process.env.NODE_ENV) {
  29. case 'development' :
  30. app.use(morgan('dev'));
  31. break;
  32. case 'production' :
  33. app.use(morgan('combined', {stream: accessLogStream}));
  34. break;
  35. }
  36. app.use(bodyParser.json());
  37. app.use(bodyParser.json({type: 'application/vnd.api+json'}));
  38. app.use(bodyParser.urlencoded({extended: true}));
  39. app.use(methodOverride('X-HTTP-Method-Override'));
  40. app.use(express.static(__dirname + '/public'));
  41. app.use(errorHandler(server.errorHandlerOptions));
  42. app.use(function(req, res, next) {
  43. res.header("Access-Control-Allow-Origin", "*");
  44. res.header("Access-Control-Allow-Headers", "Origin, X-Requested-With, Content-Type, Accept, Authorization");
  45. res.header("Access-Control-Allow-Methods", "PUT, GET, POST, DELETE, OPTIONS");
  46. next();
  47. });
  48. require('./app/routes')(app);
  49. this.app = app;
  50. this.server = server;
  51. process.title = 'CloudBudget';
  52. exports.listen = function () {
  53. if( process.env.NODE_ENV !== 'test' ) {
  54. console.log('Server running in ' + process.env.NODE_ENV + ' mode on port ' + this.server.port );
  55. }
  56. return this.app.listen.apply(this.app, [this.server.port]);
  57. };
  58. exports.close = function (callback) {
  59. this.app.close.apply(callback);
  60. };