app.js 4.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169
  1. /**
  2. * Crowi::app.js
  3. *
  4. * @package Crowi
  5. * @author Sotaro KARASAWA <sotarok@crocos.co.jp>
  6. */
  7. var express = require('express')
  8. , cons = require('consolidate')
  9. , swig = require('swig')
  10. , flash = require('connect-flash')
  11. , http = require('http')
  12. , facebook = require('facebook-node-sdk')
  13. , mongo = require('mongoose')
  14. , socketio = require('socket.io')
  15. , middleware = require('./lib/middlewares')
  16. , time = require('time')
  17. , async = require('async')
  18. , models
  19. , config
  20. , server
  21. ;
  22. time.tzset('Asia/Tokyo');
  23. var app = express();
  24. var env = app.get('env');
  25. // mongoUri = mongodb://user:password@host/dbname
  26. var mongoUri = process.env.MONGOLAB_URI
  27. || process.env.MONGOHQ_URL
  28. || process.env.MONGO_URI
  29. || 'mongodb://localhost/crowi';
  30. mongo.connect(mongoUri);
  31. app.set('port', process.env.PORT || 3000);
  32. app.use(express.static(__dirname + '/public'));
  33. app.use(express.logger());
  34. app.engine('html', cons.swig);
  35. app.set('view cache', false);
  36. app.set('view engine', 'html');
  37. app.set('views', __dirname + '/views');
  38. app.use(express.methodOverride());
  39. app.use(express.bodyParser());
  40. app.use(express.cookieParser());
  41. app.use(express.session({
  42. rolling: true,
  43. secret: process.env.SECRET_TOKEN || 'this is default session secret',
  44. }));
  45. app.use(flash());
  46. configModel = require('./models/config')(app);
  47. async.series([
  48. function (next) {
  49. configModel.getConfigArray(function(err, doc) {
  50. app.set('config', doc);
  51. return next();
  52. });
  53. }, function (next) {
  54. var config = app.set('config');
  55. models = require('./models')(app);
  56. models.Config = configModel;
  57. // configure application
  58. app.use(function(req, res, next) {
  59. var days = (1000*3600*24*30)
  60. , now = new Date()
  61. , fbparams = {}
  62. , config = app.set('config');
  63. tzoffset = -(config.crowi['app:timezone'] || 9) * 60; // for datez
  64. app.set('tzoffset', tzoffset);
  65. req.config = config;
  66. req.session.cookie.expires = new Date(Date.now() + days);
  67. req.session.cookie.maxAge = days;
  68. req.baseUrl = (req.headers['x-forwarded-proto'] == 'https' ? 'https' : req.protocol) + "://" + req.get('host');
  69. res.locals({
  70. req: req,
  71. baseUrl: req.baseUrl,
  72. config: config,
  73. env: app.get('env'),
  74. now: now,
  75. tzoffset: tzoffset,
  76. facebook: {appId: config.crowi['facebook:appId'] || ''},
  77. consts: {
  78. pageGrants: models.Page.getGrantLabels(),
  79. userStatus: models.User.getUserStatusLabels(),
  80. registrationMode: models.Config.getRegistrationModeLabels(),
  81. },
  82. });
  83. app.set('mailer', require('./lib/mailer')(app));
  84. next();
  85. });
  86. app.use(function(req, res, next) {
  87. if (config.crowi['security:basicName'] && config.crowi['security:basicSecret']) {
  88. return express.basicAuth(
  89. config.crowi['security:basicName'],
  90. config.crowi['security:basicSecret'])(req, res, next);
  91. } else {
  92. next();
  93. }
  94. });
  95. app.use(function(req, res, next) {
  96. var config = app.set('config');
  97. if (config.crowi['facebook:appId'] && config.crowi['facebook:secret']) {
  98. return facebook.middleware({
  99. appId: config.crowi['facebook:appId'],
  100. secret: config.crowi['facebook:secret']
  101. })(req, res, next);
  102. } else {
  103. return next();
  104. }
  105. });
  106. // register swig function
  107. app.use(middleware.swigFilters(app, swig));
  108. app.use(middleware.swigFunctions(app));
  109. app.use(middleware.loginChecker(app, models));
  110. app.use(app.router);
  111. next();
  112. }, function(next) {
  113. if (env == 'development') {
  114. swig.setDefaults({ cache: false });
  115. app.use(express.errorHandler({ dumpExceptions: true, showStack: true }));
  116. server = http.createServer(app).listen(app.get('port'), function(){
  117. console.log("[" + app.get('env') + "] Express server listening on port " + app.get('port'));
  118. });
  119. }
  120. if (env == 'production') {
  121. var oneYear = 31557600000;
  122. app.use(function (err, req, res, next) {
  123. res.status(500);
  124. res.render('500', { error: err });
  125. });
  126. server = http.createServer(app).listen(app.get('port'), function(){
  127. console.log("[" + app.get('env') + "] Express server listening on port " + app.get('port'));
  128. });
  129. }
  130. var io = socketio.listen(server);
  131. io.sockets.on('connection', function (socket) {
  132. });
  133. app.set('io', io);
  134. require('./routes')(app);
  135. next();
  136. }
  137. ]);