all files / src/middleware/ index.js

12.5% Statements 4/32
0% Branches 0/12
0% Functions 0/2
12.5% Lines 4/32
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80                                                                                                                                                       
"use strict";
 
var meta = require('../meta'),
	db = require('../database'),
	file = require('../file'),
	auth = require('../routes/authentication'),
 
	path = require('path'),
	nconf = require('nconf'),
	flash = require('connect-flash'),
	templates = require('templates.js'),
	bodyParser = require('body-parser'),
	cookieParser = require('cookie-parser'),
	compression = require('compression'),
	favicon = require('serve-favicon'),
	session = require('express-session'),
	useragent = require('express-useragent');
 
 
var middleware = {};
 
function setupFavicon(app) {
	var faviconPath = path.join(__dirname, '../../', 'public', meta.config['brand:favicon'] ? meta.config['brand:favicon'] : 'favicon.ico');
	if (file.existsSync(faviconPath)) {
		app.use(nconf.get('relative_path'), favicon(faviconPath));
	}
}
 
module.exports = function(app) {
	var relativePath = nconf.get('relative_path');
 
	middleware = require('./middleware')(app);
 
	app.engine('tpl', templates.__express);
	app.set('view engine', 'tpl');
	app.set('views', nconf.get('views_dir'));
	app.set('json spaces', process.env.NODE_ENV === 'development' ? 4 : 0);
	app.use(flash());
 
	app.enable('view cache');
 
	app.use(compression());
 
	setupFavicon(app);
 
	app.use(relativePath + '/apple-touch-icon', middleware.routeTouchIcon);
 
	app.use(bodyParser.urlencoded({extended: true}));
	app.use(bodyParser.json());
	app.use(cookieParser());
	app.use(useragent.express());
 
	var cookie = {
		maxAge: 1000 * 60 * 60 * 24 * (parseInt(meta.config.loginDays, 10) || 14)
	};
 
	if (meta.config.cookieDomain) {
		cookie.domain = meta.config.cookieDomain;
	}
 
	if (nconf.get('secure')) {
		cookie.secure = true;
	}
 
	app.use(session({
		store: db.sessionStore,
		secret: nconf.get('secret'),
		key: 'express.sid',
		cookie: cookie,
		resave: true,
		saveUninitialized: true
	}));
 
	app.use(middleware.addHeaders);
	app.use(middleware.processRender);
	auth.initialize(app, middleware);
 
	return middleware;
};