freeCodeCamp/controllers/user.js

71 lines
1.6 KiB
JavaScript

var mongoose = require('mongoose'),
passport = require('passport');
// Import models
var User = require('../models/user');
exports.account = function(req, res) {
res.render('account', { user: req.user });
};
exports.getLogin = function(req, res) {
res.render('login', {
title: 'Login',
user: req.user,
message: req.session.messages
});
};
exports.getSignup = function(req, res) {
res.render('signup', {
title: 'Create Account',
user: req.user,
message: req.session.messages
});
};
exports.postSignup = function(req, res) {
var user = new User({
firstName: req.body.firstName,
lastName: req.body.lastName,
email: req.body.email,
password: req.body.password
});
console.log(req.body);
// TODO: add User.schema.path validation
// TODO: check if user already exists in user.save() by catching that error
user.save(function(err) {
if (err) throw err;
console.log('New user created');
req.login(user, function(err) {
if (err) throw err;
res.redirect('/');
});
});
};
exports.admin = function(req, res) {
res.send('access granted admin!');
};
exports.postlogin = function(req, res, next) {
passport.authenticate('local', function(err, user, info) {
if (err) return next(err);
if (!user) {
req.session.messages = [info.message];
return res.redirect('/login');
}
req.logIn(user, function(err) {
if (err) { return next(err); }
return res.redirect('/');
});
})(req, res, next);
};
exports.logout = function(req, res) {
req.logout();
res.redirect('/');
};