Error handling via middleware in routes
This commit is contained in:
4
app.js
4
app.js
@ -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');
|
||||||
|
|
||||||
|
@ -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');
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
Reference in New Issue
Block a user