Error handling via middleware in routes

This commit is contained in:
Sahat Yalkabov
2013-12-19 20:17:15 -05:00
parent 901aeb08d2
commit 010fc0c9fb
2 changed files with 11 additions and 16 deletions

4
app.js
View File

@ -1,9 +1,9 @@
var domain = require('domain').create(); var domain = require('domain').create();
var express = require('express'); var express = require('express');
var less = require('less-middleware');
var path = require('path');
var fs = require('fs'); var fs = require('fs');
var flash = require('connect-flash'); var flash = require('connect-flash');
var less = require('less-middleware');
var path = require('path');
var mongoose = require('mongoose'); var mongoose = require('mongoose');
var passport = require('passport'); var passport = require('passport');

View File

@ -20,12 +20,9 @@ exports.getAccount = function(req, res) {
/** /**
* POST /account#profile * POST /account#profile
*/ */
exports.postAccountProfileTab = function(req, res) { exports.postAccountProfileTab = function(req, res, next) {
User.findById(req.user.id, function(err, user) { User.findById(req.user.id, function(err, user) {
if (err) { if (err) return next(err);
req.flash('error', err.message);
return res.redirect('/account');
}
user.profile.name = req.body.name || ''; user.profile.name = req.body.name || '';
user.profile.email = req.body.email || ''; user.profile.email = req.body.email || '';
user.profile.gender = req.body.gender || ''; user.profile.gender = req.body.gender || '';
@ -33,10 +30,7 @@ exports.postAccountProfileTab = function(req, res) {
user.profile.website = req.body.website || ''; user.profile.website = req.body.website || '';
user.save(function(err) { user.save(function(err) {
if (err) { if (err) return next(err);
req.flash('error', err.message);
return res.redirect('/contact');
}
req.flash('success', 'Profile information updated'); req.flash('success', 'Profile information updated');
res.redirect('/account'); res.redirect('/account');
}); });
@ -78,8 +72,9 @@ exports.postAccountSettingsTab = function(req, res) {
/** /**
* POST /account/delete * POST /account/delete
*/ */
exports.postDeleteAccount = function(req, res) { exports.postDeleteAccount = function(req, res, next) {
User.remove({ _id: req.user.id }, function(err) { User.remove({ _id: req.user.id }, function(err) {
if (err) return next(err);
req.logout(); req.logout();
res.redirect('/'); res.redirect('/');
}); });
@ -131,8 +126,6 @@ exports.getSignup = function(req, res) {
* POST /signup * POST /signup
*/ */
exports.postSignup = function(req, res) { exports.postSignup = function(req, res) {
console.log(req.body.tos);
// TODO: add mongoose validation on ToS (virtual?) // TODO: add mongoose validation on ToS (virtual?)
// TODO: Mongoose virtual, move logic to model // TODO: Mongoose virtual, move logic to model
@ -153,7 +146,6 @@ exports.postSignup = function(req, res) {
}); });
user.save(function(err) { user.save(function(err) {
// TODO: Simplify
if (err) { if (err) {
if (err.name === 'ValidationError') { if (err.name === 'ValidationError') {
req.flash('messages', _.map(err.errors, function(value, key) { return value.message; })); req.flash('messages', _.map(err.errors, function(value, key) { return value.message; }));
@ -165,6 +157,7 @@ exports.postSignup = function(req, res) {
} }
req.logIn(user, function(err) { req.logIn(user, function(err) {
if (err) throw err;
res.redirect('/'); res.redirect('/');
}); });
}); });
@ -173,12 +166,14 @@ exports.postSignup = function(req, res) {
/** /**
* GET /account/unlink/:provider * GET /account/unlink/:provider
*/ */
exports.getOauthUnlink = function(req, res) { exports.getOauthUnlink = function(req, res, next) {
var provider = req.params.provider; var provider = req.params.provider;
User.findById(req.user.id, function(err, user) { User.findById(req.user.id, function(err, user) {
if (err) return next(err);
user[provider] = undefined; user[provider] = undefined;
user.tokens = _.reject(user.tokens, function(token) { return token.kind === 'google'; }); user.tokens = _.reject(user.tokens, function(token) { return token.kind === 'google'; });
user.save(function(err) { user.save(function(err) {
if (err) return next(err);
res.redirect('/account#settings'); res.redirect('/account#settings');
}); });
}); });