app.js 5.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193
  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. , session = require('express-session')
  19. , models
  20. , config
  21. , server
  22. , sessionConfig
  23. , RedisStore
  24. ;
  25. time.tzset('Asia/Tokyo');
  26. var app = express();
  27. var env = app.get('env');
  28. var days = (1000*3600*24*30);
  29. // mongoUri = mongodb://user:password@host/dbname
  30. var mongoUri = process.env.MONGOLAB_URI
  31. || process.env.MONGOHQ_URL
  32. || process.env.MONGO_URI
  33. || 'mongodb://localhost/crowi';
  34. mongo.connect(mongoUri);
  35. sessionConfig = {
  36. rolling: true,
  37. secret: process.env.SECRET_TOKEN || 'this is default session secret',
  38. resave: false,
  39. saveUninitialized: true,
  40. cookie: {
  41. maxAge: days,
  42. },
  43. };
  44. var redisUrl = process.env.REDISTOGO_URL
  45. || process.env.REDIS_URL
  46. || null;
  47. if (redisUrl) {
  48. var ru = require("url").parse(redisUrl);
  49. var redis = require("redis");
  50. var redisClient = redis.createClient(ru.port, ru.hostname);
  51. if (ru.auth) {
  52. redisClient.auth(ru.auth.split(":")[1]);
  53. }
  54. RedisStore = require('connect-redis')(session);
  55. sessionConfig.store = new RedisStore({
  56. prefix: 'crowi:sess:',
  57. client: redisClient,
  58. });
  59. }
  60. app.set('port', process.env.PORT || 3000);
  61. app.use(express.static(__dirname + '/public'));
  62. app.use(express.logger());
  63. app.engine('html', cons.swig);
  64. app.set('view cache', false);
  65. app.set('view engine', 'html');
  66. app.set('views', __dirname + '/views');
  67. app.use(express.methodOverride());
  68. app.use(express.bodyParser());
  69. app.use(express.cookieParser());
  70. app.use(session(sessionConfig));
  71. app.use(flash());
  72. configModel = require('./models/config')(app);
  73. async.series([
  74. function (next) {
  75. configModel.getConfigArray(function(err, doc) {
  76. app.set('config', doc);
  77. return next();
  78. });
  79. }, function (next) {
  80. var config = app.set('config');
  81. app.set('mailer', require('./lib/mailer')(app));
  82. models = require('./models')(app);
  83. models.Config = configModel;
  84. // configure application
  85. app.use(function(req, res, next) {
  86. var now = new Date()
  87. , fbparams = {}
  88. , config = app.set('config');
  89. tzoffset = -(config.crowi['app:timezone'] || 9) * 60; // for datez
  90. app.set('tzoffset', tzoffset);
  91. req.config = config;
  92. config.crowi['app:url'] = req.baseUrl = (req.headers['x-forwarded-proto'] == 'https' ? 'https' : req.protocol) + "://" + req.get('host');
  93. res.locals({
  94. req: req,
  95. baseUrl: req.baseUrl,
  96. config: config,
  97. env: app.get('env'),
  98. now: now,
  99. tzoffset: tzoffset,
  100. facebook: {appId: config.crowi['facebook:appId'] || ''},
  101. consts: {
  102. pageGrants: models.Page.getGrantLabels(),
  103. userStatus: models.User.getUserStatusLabels(),
  104. registrationMode: models.Config.getRegistrationModeLabels(),
  105. },
  106. });
  107. next();
  108. });
  109. app.use(function(req, res, next) {
  110. if (config.crowi['security:basicName'] && config.crowi['security:basicSecret']) {
  111. return express.basicAuth(
  112. config.crowi['security:basicName'],
  113. config.crowi['security:basicSecret'])(req, res, next);
  114. } else {
  115. next();
  116. }
  117. });
  118. app.use(function(req, res, next) {
  119. var config = app.set('config');
  120. if (config.crowi['facebook:appId'] && config.crowi['facebook:secret']) {
  121. return facebook.middleware({
  122. appId: config.crowi['facebook:appId'],
  123. secret: config.crowi['facebook:secret']
  124. })(req, res, next);
  125. } else {
  126. return next();
  127. }
  128. });
  129. // register swig function
  130. app.use(middleware.swigFilters(app, swig));
  131. app.use(middleware.swigFunctions(app));
  132. app.use(middleware.loginChecker(app, models));
  133. app.use(app.router);
  134. next();
  135. }, function(next) {
  136. if (env == 'development') {
  137. swig.setDefaults({ cache: false });
  138. app.use(express.errorHandler({ dumpExceptions: true, showStack: true }));
  139. server = http.createServer(app).listen(app.get('port'), function(){
  140. console.log("[" + app.get('env') + "] Express server listening on port " + app.get('port'));
  141. });
  142. }
  143. if (env == 'production') {
  144. var oneYear = 31557600000;
  145. app.use(function (err, req, res, next) {
  146. res.status(500);
  147. res.render('500', { error: err });
  148. });
  149. server = http.createServer(app).listen(app.get('port'), function(){
  150. console.log("[" + app.get('env') + "] Express server listening on port " + app.get('port'));
  151. });
  152. }
  153. var io = socketio.listen(server);
  154. io.sockets.on('connection', function (socket) {
  155. });
  156. app.set('io', io);
  157. require('./routes')(app);
  158. next();
  159. }
  160. ]);