From 7ae1fbc3cfbe9ce5939fb068f71af8318d8c9dd7 Mon Sep 17 00:00:00 2001 From: Dennis Eriksen Date: Wed, 15 May 2013 13:17:23 +0200 Subject: added registerEmail so it works.. also, now it checks to see if email exists already --- controllers/users.js | 39 ++++++++++++++++++++++++++++++++++++++- 1 file changed, 38 insertions(+), 1 deletion(-) diff --git a/controllers/users.js b/controllers/users.js index 477a85a..fe47cac 100644 --- a/controllers/users.js +++ b/controllers/users.js @@ -84,12 +84,49 @@ exports.create = function(req, res) { exports.authCallback = function(req, res, next) { // if the user hasn't registered an email, we need to do so - if (!req.user.email || req.user.email === 'undefined') return res.redirect('/registerEmail'); + if (!req.user.email || req.user.email === undefined) return res.redirect('/registerEmail'); res.redirect('/dashboard'); } +/** + * registerEmail + * Will register the users email if they don't have already + */ + +exports.registerEmail = function(req, res) { + // in case some user who has alreadu registered an email gets on this page + if (req.user.email !== undefined) return res.redirect('/dashboard'); + res.render('registerEmail', { title: 'Registrer din e-post' }); +} + + +/** + * postRegisterEmail + */ + +exports.postRegisterEmail = function(req, res) { + + v.check(req.body.email, 'You need to supply a proper email').isEmail(); + var errors = v.getErrors(); + if (errors.length !== 0) return res.status(500).render('error', { title: '500', text: 'Det oppstod en valideringsfeil
' + errors, error: errors }); + + // first we need to check if the email is already in use + User.findOne({ email: req.body.email }, function(err, user) { + if (err) return res.status(500).render('error', { title: '500', text: 'En serverfeil oppstod', error: err.stack }); + + // if mail is in use.. + if (user) return res.render('registerEmail', { title: 'Den e-posten er allerede i bruk. Vennligs registrer en annen.' }); + + User.update({ _id: req.user._id }, { email: req.body.email }, function(err) { + if (err) return res.status(500).render('error', { title: '500', text: 'En serverfeil oppstod', error: err.stack }); + return res.redirect('/dashboard'); + }); + }); +} + + /** * postProjectParticipants * This callback is in this file because it treats users. -- cgit v1.2.3