app.js 4.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168
  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. , nodemailer = require("nodemailer")
  19. , models
  20. , config
  21. , server
  22. ;
  23. time.tzset('Asia/Tokyo');
  24. var app = express();
  25. var env = app.get('env');
  26. // mongoUri = mongodb://user:password@host/dbname
  27. var mongoUri = process.env.MONGOLAB_URI
  28. || process.env.MONGOHQ_URL
  29. || process.env.MONGO_URI
  30. || 'mongodb://localhost/crowi';
  31. mongo.connect(mongoUri);
  32. app.set('port', process.env.PORT || 3000);
  33. app.use(express.static(__dirname + '/public'));
  34. app.use(express.logger());
  35. app.engine('html', cons.swig);
  36. app.set('view cache', false);
  37. app.set('view engine', 'html');
  38. app.set('views', __dirname + '/views');
  39. app.use(express.methodOverride());
  40. app.use(express.bodyParser());
  41. app.use(express.cookieParser());
  42. app.use(express.session({
  43. rolling: true,
  44. secret: process.env.SECRET_TOKEN || 'this is default session secret',
  45. }));
  46. app.use(flash());
  47. configModel = require('./models/config')(app);
  48. async.series([
  49. function (next) {
  50. configModel.getConfigArray(function(err, doc) {
  51. app.set('config', doc);
  52. return next();
  53. });
  54. }, function (next) {
  55. var config = app.set('config');
  56. models = require('./models')(app);
  57. models.Config = configModel;
  58. // configure application
  59. app.use(function(req, res, next) {
  60. var days = (1000*3600*24*30)
  61. , now = new Date()
  62. , fbparams = {}
  63. , config = app.set('config');
  64. tzoffset = -(config.crowi['app:timezone'] || 9) * 60; // for datez
  65. app.set('tzoffset', tzoffset);
  66. req.config = config;
  67. req.session.cookie.expires = new Date(Date.now() + days);
  68. req.session.cookie.maxAge = days;
  69. req.baseUrl = (req.headers['x-forwarded-proto'] == 'https' ? 'https' : req.protocol) + "://" + req.get('host');
  70. res.locals({
  71. req: req,
  72. baseUrl: req.baseUrl,
  73. config: config,
  74. env: app.get('env'),
  75. now: now,
  76. tzoffset: tzoffset,
  77. facebook: {appId: config.crowi['facebook:appId'] || ''},
  78. consts: {
  79. pageGrants: models.Page.getGrantLabels(),
  80. userStatus: models.User.getUserStatusLabels(),
  81. registrationMode: models.Config.getRegistrationModeLabels(),
  82. },
  83. });
  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. ]);