Files
NodeBB/src/middleware/index.js

90 lines
2.1 KiB
JavaScript
Raw Normal View History

2014-03-02 14:45:57 -05:00
"use strict";
2014-11-19 17:48:43 -05:00
var meta = require('../meta'),
db = require('../database'),
auth = require('../routes/authentication'),
path = require('path'),
fs = require('fs'),
nconf = require('nconf'),
winston = require('winston'),
flash = require('connect-flash'),
2014-06-25 18:55:22 -04:00
templates = require('templates.js'),
2014-07-02 14:07:08 -04:00
bodyParser = require('body-parser'),
cookieParser = require('cookie-parser'),
compression = require('compression'),
favicon = require('serve-favicon'),
2014-11-19 17:48:43 -05:00
session = require('express-session');
var middleware = {};
2014-10-17 19:38:49 -04:00
function setupFavicon(app) {
2014-10-17 19:37:09 -04:00
var faviconPath = path.join(__dirname, '../../', 'public', meta.config['brand:favicon'] ? meta.config['brand:favicon'] : 'favicon.ico');
if (fs.existsSync(faviconPath)) {
app.use(nconf.get('relative_path'), favicon(faviconPath));
2014-10-17 19:37:09 -04:00
}
}
module.exports = function(app) {
var relativePath = nconf.get('relative_path');
2014-11-19 17:48:43 -05:00
middleware = require('./middleware')(app);
2014-07-02 14:07:08 -04:00
app.engine('tpl', templates.__express);
app.set('view engine', 'tpl');
app.set('views', nconf.get('views_dir'));
2014-07-02 14:59:48 -04:00
app.set('json spaces', process.env.NODE_ENV === 'development' ? 4 : 0);
2014-07-02 14:07:08 -04:00
app.use(flash());
2014-07-02 14:07:08 -04:00
app.enable('view cache');
2014-07-02 14:07:08 -04:00
app.use(compression());
2014-10-17 19:38:49 -04:00
setupFavicon(app);
2014-07-02 14:07:08 -04:00
app.use(relativePath + '/apple-touch-icon', middleware.routeTouchIcon);
2014-07-02 14:59:48 -04:00
app.use(bodyParser.urlencoded({extended: true}));
app.use(bodyParser.json());
2014-07-02 14:07:08 -04:00
app.use(cookieParser());
var cookie = {
2014-09-29 19:29:13 -04:00
maxAge: 1000 * 60 * 60 * 24 * parseInt(meta.config.loginDays || 14, 10)
};
2014-11-19 17:48:43 -05:00
if (meta.config.cookieDomain) {
cookie.domain = meta.config.cookieDomain;
}
2014-08-13 16:03:33 -04:00
2015-08-17 14:53:37 -04:00
if (nconf.get('secure')) {
cookie.secure = true;
}
2014-07-02 14:07:08 -04:00
app.use(session({
store: db.sessionStore,
secret: nconf.get('secret'),
key: 'express.sid',
cookie: cookie,
2014-07-02 14:59:48 -04:00
resave: true,
saveUninitialized: true
2014-07-02 14:07:08 -04:00
}));
2014-07-02 14:07:08 -04:00
app.use(function (req, res, next) {
res.setHeader('X-Powered-By', 'NodeBB');
2014-11-19 17:48:43 -05:00
2014-07-02 14:07:08 -04:00
if (meta.config['allow-from-uri']) {
2015-01-12 18:28:47 -05:00
res.setHeader('X-Frame-Options', 'ALLOW-FROM ' + meta.config['allow-from-uri']);
} else {
res.setHeader('X-Frame-Options', 'SAMEORIGIN');
2014-07-02 14:07:08 -04:00
}
2014-07-02 14:07:08 -04:00
next();
});
2014-07-02 14:07:08 -04:00
app.use(middleware.processRender);
auth.initialize(app, middleware);
return middleware;
2014-04-10 20:31:57 +01:00
};