2014-09-23 14:54:05 -04:00
|
|
|
"use strict";
|
2014-09-18 15:35:58 -04:00
|
|
|
|
2014-09-23 14:54:05 -04:00
|
|
|
// ------------ Basic Dependencies -------------------------------------------
|
|
|
|
var express = require('express'),
|
|
|
|
session = require('express-session'),
|
2014-09-24 17:58:53 -04:00
|
|
|
csrf = require('csurf'),
|
2014-09-23 14:54:05 -04:00
|
|
|
path = require('path'),
|
|
|
|
favicon = require('serve-favicon'),
|
|
|
|
logger = require('morgan'),
|
|
|
|
cookieParser = require('cookie-parser'),
|
|
|
|
bodyParser = require('body-parser'),
|
|
|
|
requireDir = require('require-dir'),
|
|
|
|
connection = require('express-myconnection'),
|
|
|
|
bcrypt = require('bcrypt-nodejs'),
|
2014-09-24 17:58:53 -04:00
|
|
|
mysql = require('mysql2');
|
2014-09-23 14:54:05 -04:00
|
|
|
// ----------------------------------------------------------------------------
|
2014-09-18 15:35:58 -04:00
|
|
|
var app = express();
|
|
|
|
|
2014-09-22 09:59:44 -04:00
|
|
|
// General config
|
|
|
|
app.set('trust proxy', true); // Trust X-Forwarded-* headers
|
|
|
|
|
2014-09-23 14:54:05 -04:00
|
|
|
// Database connection
|
|
|
|
app.use(
|
2014-09-24 17:58:53 -04:00
|
|
|
connection(mysql, {
|
2014-09-23 14:54:05 -04:00
|
|
|
host: 'localhost',
|
|
|
|
user: 'node',
|
|
|
|
password: 'node',
|
|
|
|
port: 3306,
|
|
|
|
database: 'node'
|
2014-09-24 17:58:53 -04:00
|
|
|
}, 'pool')
|
2014-09-23 14:54:05 -04:00
|
|
|
);
|
2014-09-22 09:59:44 -04:00
|
|
|
|
2014-09-18 15:35:58 -04:00
|
|
|
// view engine setup
|
2014-09-18 16:17:29 -04:00
|
|
|
var consolidate = require('consolidate');
|
|
|
|
var dust = require('dustjs-linkedin');
|
|
|
|
app.engine('dust', consolidate.dust);
|
2014-09-18 15:35:58 -04:00
|
|
|
app.set('views', path.join(__dirname, 'views'));
|
|
|
|
app.set('view engine', 'dust');
|
|
|
|
|
2014-09-23 14:54:05 -04:00
|
|
|
// General app setup
|
|
|
|
app.use(favicon(__dirname + '/public/favicon.ico'));
|
2014-09-18 15:35:58 -04:00
|
|
|
app.use(logger('dev'));
|
|
|
|
app.use(bodyParser.json());
|
|
|
|
app.use(bodyParser.urlencoded({ extended: false }));
|
|
|
|
app.use(cookieParser());
|
2014-09-24 17:58:53 -04:00
|
|
|
app.use(session({
|
|
|
|
resave: true,
|
|
|
|
saveUninitialized: true,
|
|
|
|
secret: 'j2uyc0hjh2;clkjang1ddojj'
|
|
|
|
}));
|
2014-09-18 16:17:29 -04:00
|
|
|
app.use(express.static(path.join(__dirname, 'public'), {redirect:false}));
|
2014-09-24 17:58:53 -04:00
|
|
|
app.use(csrf({
|
|
|
|
ignoreMethods: ['GET', 'HEAD', 'OPTIONS']
|
|
|
|
}));
|
|
|
|
|
|
|
|
//Check session for any pages that require authentication
|
|
|
|
app.use(function(err, req, res, next) {
|
|
|
|
if ( ! req.session.uid)
|
|
|
|
{
|
|
|
|
console.log("This should redirect to index!")
|
|
|
|
|
|
|
|
['/', '/login', '/logout'].forEach(function(item) {
|
|
|
|
if (req.path.match(item)) return next();
|
|
|
|
});
|
|
|
|
res.redirect(303, '/');
|
|
|
|
}
|
|
|
|
});
|
2014-09-18 15:35:58 -04:00
|
|
|
|
2014-09-18 16:17:29 -04:00
|
|
|
// Route mapping
|
2014-09-23 14:54:05 -04:00
|
|
|
// Routes are prefixed by the filename,
|
|
|
|
// unless the filename is index.
|
|
|
|
//
|
|
|
|
// A '/' route in the users file becomes the '/users/' route.
|
2014-09-22 09:59:44 -04:00
|
|
|
var routes = requireDir('routes');
|
|
|
|
Object.keys(routes).forEach(function(route) {
|
|
|
|
var path = (route != 'index')
|
|
|
|
? '/' + route
|
|
|
|
: '/';
|
2014-09-24 17:58:53 -04:00
|
|
|
|
2014-09-22 09:59:44 -04:00
|
|
|
app.use(path, routes[route]);
|
|
|
|
});
|
2014-09-18 15:35:58 -04:00
|
|
|
|
|
|
|
// catch 404 and forward to error handler
|
|
|
|
app.use(function(req, res, next) {
|
2014-09-18 16:17:29 -04:00
|
|
|
var err = new Error('Not Found');
|
|
|
|
err.status = 404;
|
|
|
|
next(err);
|
2014-09-18 15:35:58 -04:00
|
|
|
});
|
|
|
|
|
|
|
|
// error handlers
|
|
|
|
|
2014-09-24 17:58:53 -04:00
|
|
|
// csrf error handler
|
|
|
|
app.use(function(err, req, res, next) {
|
|
|
|
if (err.code !== 'EBADCSRFTOKEN') return next(err);
|
|
|
|
|
|
|
|
// Bad CSRF Token
|
|
|
|
res.status(403);
|
|
|
|
res.send('Session has expired, or has been tampered with.');
|
|
|
|
});
|
|
|
|
|
2014-09-18 15:35:58 -04:00
|
|
|
// development error handler
|
|
|
|
// will print stacktrace
|
|
|
|
if (app.get('env') === 'development') {
|
2014-09-18 16:17:29 -04:00
|
|
|
app.use(function(err, req, res, next) {
|
|
|
|
res.status(err.status || 500);
|
|
|
|
res.render('error', {
|
|
|
|
message: err.message,
|
|
|
|
error: err
|
|
|
|
});
|
|
|
|
});
|
2014-09-18 15:35:58 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
// production error handler
|
|
|
|
// no stacktraces leaked to user
|
|
|
|
app.use(function(err, req, res, next) {
|
2014-09-18 16:17:29 -04:00
|
|
|
res.status(err.status || 500);
|
|
|
|
res.render('error', {
|
|
|
|
message: err.message,
|
|
|
|
error: {}
|
|
|
|
});
|
2014-09-18 15:35:58 -04:00
|
|
|
});
|
|
|
|
|
|
|
|
|
2014-09-22 09:59:44 -04:00
|
|
|
module.exports = app;
|