var express = require('express'); var http = require('http'); var path = require('path'); var favicon = require('static-favicon'); var logger = require('morgan'); var bodyParser = require('body-parser'); var routes = require('./routes'); var users = require('./routes/user'); var db = require('./models'); var app = express(); app.use(favicon()); app.use(logger('dev')); app.use(bodyParser.json()); app.use(bodyParser.urlencoded()); // app.use(cookieParser()); app.use(app.router); /// catch 404 and forwarding to error handler app.use(function(req, res, next) { var err = new Error('Not Found'); err.status = 404; next(err); }); /// error handlers // development error handler // will print stacktrace if (app.get('env') === 'development') { app.use(function(err, req, res, next) { res.render('error', { message: err.message, error: err }); }); } // production error handler // no stacktraces leaked to user app.use(function(err, req, res, next) { res.render('error', { message: err.message, error: {} }); }); module.exports = app; // routes app.get('/', routes.index); // database and start up db .sequelize .sync({ force: true }) .complete(function (err) { if (err) { throw err; } port = app.get('port') || 3000; http.createServer(app).listen(port, function () { console.log('Express server listening on port ' + port); }); });