express-init.js 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106
  1. 'use strict';
  2. module.exports = function(crowi, app) {
  3. var debug = require('debug')('crowi:crowi:express-init')
  4. , express = require('express')
  5. , bodyParser = require('body-parser')
  6. , cookieParser = require('cookie-parser')
  7. , methodOverride = require('method-override')
  8. , session = require('express-session')
  9. , basicAuth = require('basic-auth-connect')
  10. , flash = require('connect-flash')
  11. , cons = require('consolidate')
  12. , swig = require('swig')
  13. , i18next = require('i18next')
  14. , i18nFsBackend = require('i18next-node-fs-backend')
  15. , i18nSprintf = require('i18next-sprintf-postprocessor')
  16. , i18nMiddleware = require('i18next-express-middleware')
  17. , i18nUserSettingDetector = require('../util/i18nUserSettingDetector')
  18. , env = crowi.node_env
  19. , middleware = require('../util/middlewares')
  20. ;
  21. var lngDetector = new i18nMiddleware.LanguageDetector();
  22. lngDetector.addDetector(i18nUserSettingDetector);
  23. i18next
  24. .use(lngDetector)
  25. .use(i18nFsBackend)
  26. .use(i18nSprintf)
  27. .init({
  28. fallbackLng: 'en',
  29. whitelist: ['en', 'ja'],
  30. backend: {
  31. loadPath: 'locales/{{lng}}/translation.json'
  32. },
  33. detection: {
  34. order: ['userSettingDetector', 'header', 'navigator'],
  35. },
  36. overloadTranslationOptionHandler: i18nSprintf.overloadTranslationOptionHandler
  37. });
  38. app.use(function(req, res, next) {
  39. var now = new Date()
  40. , baseUrl
  41. , config = crowi.getConfig()
  42. , tzoffset = -(config.crowi['app:timezone'] || 9) * 60 // for datez
  43. , Page = crowi.model('Page')
  44. , User = crowi.model('User')
  45. , Config = crowi.model('Config')
  46. ;
  47. app.set('tzoffset', tzoffset);
  48. req.config = config;
  49. req.csrfToken = null;
  50. config.crowi['app:url'] = baseUrl = (req.headers['x-forwarded-proto'] == 'https' ? 'https' : req.protocol) + '://' + req.get('host');
  51. res.locals.req = req;
  52. res.locals.baseUrl = baseUrl;
  53. res.locals.config = config;
  54. res.locals.env = env;
  55. res.locals.now = now;
  56. res.locals.tzoffset = tzoffset;
  57. res.locals.consts = {
  58. pageGrants: Page.getGrantLabels(),
  59. userStatus: User.getUserStatusLabels(),
  60. registrationMode: Config.getRegistrationModeLabels(),
  61. };
  62. next();
  63. });
  64. // Set basic auth middleware
  65. app.use(function(req, res, next) {
  66. var config = crowi.getConfig();
  67. if (config.crowi['security:basicName'] && config.crowi['security:basicSecret']) {
  68. return basicAuth(
  69. config.crowi['security:basicName'],
  70. config.crowi['security:basicSecret'])(req, res, next);
  71. } else {
  72. next();
  73. }
  74. });
  75. app.set('port', crowi.port);
  76. app.use(express.static(crowi.publicDir));
  77. app.engine('html', cons.swig);
  78. app.set('view cache', false);
  79. app.set('view engine', 'html');
  80. app.set('views', crowi.viewsDir);
  81. app.use(methodOverride());
  82. app.use(bodyParser.urlencoded({ extended: true, limit: '50mb' }));
  83. app.use(bodyParser.json({limit: '50mb'}));
  84. app.use(cookieParser());
  85. app.use(session(crowi.sessionConfig));
  86. app.use(flash());
  87. app.use(middleware.swigFilters(app, swig));
  88. app.use(middleware.swigFunctions(crowi, app));
  89. app.use(middleware.loginChecker(crowi, app));
  90. app.use(i18nMiddleware.handle(i18next));
  91. };