freeCodeCamp/controllers/user.js

97 lines
1.9 KiB
JavaScript
Raw Normal View History

2013-11-14 07:37:37 +00:00
var mongoose = require('mongoose'),
2013-11-18 23:21:42 +00:00
passport = require('passport'),
_ = require('underscore');
2013-11-15 16:13:21 +00:00
// Import models
2013-11-18 23:21:42 +00:00
var User = require('../models/User');
exports.account = function(req, res) {
res.render('account', { user: req.user });
};
/**
* GET /login
*/
2013-11-16 18:24:06 +00:00
exports.getLogin = function(req, res) {
res.render('login', {
title: 'Login',
user: req.user,
messages: req.flash('messages')
});
2013-11-16 18:24:06 +00:00
};
/**
* POST /login
*/
exports.postLogin = function(req, res, next) {
passport.authenticate('local', function(err, user, info) {
if (err) {
console.log(err);
return next(err);
}
if (!user) {
req.flash('messages', info.message);
return res.redirect('/login');
}
req.logIn(user, function(err) {
if (err) return next(err);
return res.redirect('/');
});
})(req, res, next);
};
/**
* GET /signup
*/
2013-11-16 18:24:06 +00:00
exports.getSignup = function(req, res) {
2013-11-17 20:15:05 +00:00
res.render('signup', {
title: 'Create Account',
2013-11-17 20:15:05 +00:00
user: req.user,
2013-11-18 23:21:42 +00:00
messages: req.flash('messages')
2013-11-17 20:15:05 +00:00
});
2013-11-16 18:24:06 +00:00
};
/**
* POST /signup
*/
2013-11-16 18:24:06 +00:00
exports.postSignup = function(req, res) {
2013-11-17 20:15:05 +00:00
var user = new User({
firstName: req.body.firstName,
lastName: req.body.lastName,
email: req.body.email,
password: req.body.password
});
user.save(function(err) {
if (err) {
if (err.code === 11000) {
2013-11-18 23:21:42 +00:00
req.flash('messages', 'Duplicate user detected');
return res.redirect('/signup');
} else if (err.name === 'ValidationError') {
2013-11-18 23:21:42 +00:00
console.log();
req.flash('messages', _.toArray(err.errors));
//console.log(err);
return res.redirect('/signup');
}
}
req.logIn(user, function(err) {
2013-11-17 20:15:05 +00:00
if (err) throw err;
res.redirect('/');
});
});
};
/**
* GET /admin
*/
exports.admin = function(req, res) {
res.send('access granted admin!');
};
/**
* GET /logout
*/
exports.logout = function(req, res) {
req.logout();
res.redirect('/');
};