2016-04-30 23:41:09 +02:00
|
|
|
var express = require('express');
|
|
|
|
var bodyParser = require('body-parser');
|
|
|
|
var cookieParser = require('cookie-parser');
|
|
|
|
var log4js = require('log4js');
|
|
|
|
var logger = require('./lib/logger');
|
|
|
|
var routes = require('./lib/routes');
|
|
|
|
var validator = require('express-validator');
|
|
|
|
var app = express();
|
|
|
|
var router = express.Router(); // eslint-disable-line
|
|
|
|
var baseUriPath = process.env.BASE_URI_PATH || '';
|
2014-12-03 15:22:03 +01:00
|
|
|
|
2016-04-24 22:41:37 +02:00
|
|
|
if (app.get('env') === 'development') {
|
2014-12-03 15:22:03 +01:00
|
|
|
app.use(require('errorhandler')());
|
|
|
|
|
|
|
|
var webpack = require('webpack'),
|
|
|
|
webpackDevMiddleware = require('webpack-dev-middleware'),
|
|
|
|
webpackConfig = require('./webpack.config'),
|
|
|
|
compiler = webpack(webpackConfig),
|
|
|
|
config = {
|
|
|
|
publicPath: '/js',
|
|
|
|
noInfo: true
|
|
|
|
};
|
|
|
|
|
|
|
|
app.use(baseUriPath, webpackDevMiddleware(compiler, config));
|
|
|
|
}
|
|
|
|
|
|
|
|
app.use(validator([]));
|
|
|
|
|
|
|
|
app.set('trust proxy');
|
|
|
|
app.locals.baseUriPath = baseUriPath;
|
|
|
|
|
2015-03-10 16:30:56 +01:00
|
|
|
app.use(log4js.connectLogger(logger, {
|
|
|
|
format: ':remote-addr :status :method :url :response-timems',
|
|
|
|
level: 'auto' // 3XX=WARN, 4xx/5xx=ERROR
|
|
|
|
}));
|
|
|
|
|
2014-12-03 15:22:03 +01:00
|
|
|
app.set('port', process.env.HTTP_PORT || process.env.PORT || 4242);
|
|
|
|
|
|
|
|
app.use(baseUriPath, express.static(__dirname + '/public'));
|
2016-04-24 22:41:37 +02:00
|
|
|
app.use(bodyParser.json({ strict: false }));
|
2014-12-03 15:22:03 +01:00
|
|
|
|
2015-02-05 13:39:00 +01:00
|
|
|
app.use(cookieParser());
|
|
|
|
|
2016-04-28 16:58:59 +02:00
|
|
|
routes.create(router);
|
|
|
|
|
2014-12-03 15:22:03 +01:00
|
|
|
app.use(baseUriPath, router);
|
|
|
|
|
2015-02-05 13:39:00 +01:00
|
|
|
module.exports = app;
|