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');
|
2013-11-14 07:29:55 +00:00
|
|
|
|
2013-12-06 04:53:14 +00:00
|
|
|
exports.getAccount = function(req, res) {
|
2013-11-19 18:20:50 +00:00
|
|
|
res.render('account', {
|
|
|
|
title: 'Account Management',
|
|
|
|
user: req.user,
|
|
|
|
messages: req.flash('messages')
|
|
|
|
});
|
2013-11-14 07:29:55 +00:00
|
|
|
};
|
|
|
|
|
2013-12-06 04:53:14 +00:00
|
|
|
exports.postAccountProfile = function(req, res) {
|
2013-12-06 05:25:49 +00:00
|
|
|
console.log(req.body.gender);
|
2013-12-06 04:53:14 +00:00
|
|
|
User.findById(req.user.id, function(err, user) {
|
|
|
|
user.profile.name = req.body.name || '';
|
|
|
|
user.profile.email = req.body.email || '';
|
2013-12-06 05:25:49 +00:00
|
|
|
user.profile.gender = req.body.gender || '';
|
2013-12-06 04:53:14 +00:00
|
|
|
user.profile.location = req.body.location || '';
|
|
|
|
user.profile.website = req.body.website || '';
|
|
|
|
|
|
|
|
user.save(function(err) {
|
|
|
|
res.redirect('/account');
|
|
|
|
});
|
|
|
|
});
|
|
|
|
};
|
|
|
|
|
2013-12-12 19:01:19 +00:00
|
|
|
// todo: change to change postPassword
|
2013-12-06 04:53:14 +00:00
|
|
|
exports.postAccountSettings = function(req, res) {
|
|
|
|
console.log('okay!!');
|
2013-12-13 02:47:34 +00:00
|
|
|
// TODO: change url on tab change in account.jade
|
|
|
|
// Check if password matches confirm password
|
|
|
|
|
|
|
|
if (req.body.password !== req.body.confirmPassword) {
|
|
|
|
req.flash('messages', 'Passwords do not match');
|
|
|
|
return res.redirect('/account');
|
|
|
|
}
|
|
|
|
|
|
|
|
User.findById(req.user.id, function(err, user) {
|
|
|
|
user.password = req.body.password;
|
|
|
|
user.save(function(err) {
|
|
|
|
console.log('Password has been changed.');
|
|
|
|
//TODO: change messages to success/errors
|
|
|
|
req.flash('messages', 'Password has been successfully changed!');
|
|
|
|
res.redirect('/account');
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
|
2013-12-13 01:57:47 +00:00
|
|
|
// TODO: add new field "Existing password"
|
|
|
|
// TODO: validate if all passwords are matching
|
|
|
|
//TODO: change user's password
|
2013-12-06 04:53:14 +00:00
|
|
|
};
|
|
|
|
|
2013-12-12 17:41:29 +00:00
|
|
|
exports.deleteAccount = function(req, res) {
|
|
|
|
User.remove({ _id: req.user.id }, function(err) {
|
|
|
|
req.logout();
|
|
|
|
res.redirect('/');
|
|
|
|
});
|
|
|
|
};
|
|
|
|
|
2013-11-18 22:37:50 +00:00
|
|
|
/**
|
|
|
|
* GET /login
|
|
|
|
*/
|
2013-11-16 18:24:06 +00:00
|
|
|
exports.getLogin = function(req, res) {
|
2013-12-07 08:17:48 +00:00
|
|
|
if (req.user) return res.redirect('back');
|
2013-11-18 06:13:52 +00:00
|
|
|
res.render('login', {
|
|
|
|
title: 'Login',
|
|
|
|
user: req.user,
|
2013-11-18 23:00:05 +00:00
|
|
|
messages: req.flash('messages')
|
2013-11-18 06:13:52 +00:00
|
|
|
});
|
2013-11-16 18:24:06 +00:00
|
|
|
};
|
|
|
|
|
2013-11-18 22:37:50 +00:00
|
|
|
/**
|
|
|
|
* POST /login
|
|
|
|
*/
|
|
|
|
exports.postLogin = function(req, res, next) {
|
|
|
|
passport.authenticate('local', function(err, user, info) {
|
2013-12-04 12:58:17 +00:00
|
|
|
if (err) return next(err);
|
2013-11-18 22:37:50 +00:00
|
|
|
if (!user) {
|
2013-11-18 23:00:05 +00:00
|
|
|
req.flash('messages', info.message);
|
2013-11-18 22:37:50 +00:00
|
|
|
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-12-07 08:17:48 +00:00
|
|
|
if (req.user) return res.redirect('back');
|
2013-12-04 12:44:07 +00:00
|
|
|
|
2013-11-17 20:15:05 +00:00
|
|
|
res.render('signup', {
|
2013-11-18 06:13:52 +00:00
|
|
|
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
|
|
|
};
|
|
|
|
|
2013-11-18 22:37:50 +00:00
|
|
|
/**
|
|
|
|
* POST /signup
|
|
|
|
*/
|
2013-11-16 18:24:06 +00:00
|
|
|
exports.postSignup = function(req, res) {
|
2013-11-20 07:38:03 +00:00
|
|
|
|
2013-12-12 05:26:57 +00:00
|
|
|
console.log(req.body.tos);
|
|
|
|
// TODO: add mongoose validation on ToS (virtual?)
|
2013-12-07 08:17:48 +00:00
|
|
|
// TODO: Mongoose virtual, move logic to model
|
2013-12-12 05:26:57 +00:00
|
|
|
|
2013-11-20 07:38:03 +00:00
|
|
|
if (req.body.password !== req.body.confirmPassword) {
|
|
|
|
req.flash('messages', 'Passwords do not match');
|
|
|
|
return res.redirect('/signup');
|
|
|
|
}
|
|
|
|
|
2013-12-13 01:57:47 +00:00
|
|
|
if (!req.body.tos) {
|
|
|
|
req.flash('messages', 'You must agree to terms and conditions');
|
|
|
|
return res.redirect('/signup');
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2013-12-06 04:12:43 +00:00
|
|
|
var user = new User({
|
2013-12-13 01:57:47 +00:00
|
|
|
username: req.body.username,
|
|
|
|
password: req.body.password
|
2013-12-06 04:12:43 +00:00
|
|
|
});
|
|
|
|
|
2013-11-17 20:15:05 +00:00
|
|
|
user.save(function(err) {
|
2013-12-07 08:17:48 +00:00
|
|
|
// TODO: Simplify
|
2013-11-18 19:07:59 +00:00
|
|
|
if (err) {
|
2013-11-20 07:38:03 +00:00
|
|
|
if (err.name === 'ValidationError') {
|
|
|
|
req.flash('messages', _.map(err.errors, function(value, key) { return value.message; }));
|
|
|
|
}
|
2013-11-18 19:07:59 +00:00
|
|
|
if (err.code === 11000) {
|
2013-11-19 00:27:35 +00:00
|
|
|
req.flash('messages', 'User already exists');
|
2013-11-18 19:07:59 +00:00
|
|
|
}
|
2013-11-20 07:38:03 +00:00
|
|
|
return res.redirect('/signup');
|
2013-11-18 19:07:59 +00:00
|
|
|
}
|
2013-12-06 04:12:43 +00:00
|
|
|
|
2013-11-18 19:26:25 +00:00
|
|
|
req.logIn(user, function(err) {
|
2013-11-17 20:15:05 +00:00
|
|
|
res.redirect('/');
|
|
|
|
});
|
|
|
|
});
|
2013-11-14 07:29:55 +00:00
|
|
|
};
|
|
|
|
|
2013-12-12 19:05:35 +00:00
|
|
|
|
|
|
|
/**
|
2013-12-13 05:49:46 +00:00
|
|
|
* GET /account/unlink/:provider
|
2013-12-12 19:05:35 +00:00
|
|
|
*/
|
2013-12-13 05:49:46 +00:00
|
|
|
exports.getOauthUnlink = function(req, res) {
|
2013-12-12 19:05:35 +00:00
|
|
|
console.log('unlinking oauth2');
|
2013-12-13 05:49:46 +00:00
|
|
|
var provider = req.params.provider;
|
2013-12-13 05:27:51 +00:00
|
|
|
User.findById(req.user.id, function(err, user) {
|
|
|
|
delete user[provider];
|
2013-12-13 05:49:46 +00:00
|
|
|
user.tokens = _.reject(x.tokens, function(tok) { return tok.kind === 'google'; });
|
2013-12-13 05:27:51 +00:00
|
|
|
user.save(function(err) {
|
|
|
|
console.log('Successfully unlinked:', provider);
|
2013-12-13 05:49:46 +00:00
|
|
|
res.redirect('/account#settings');
|
2013-12-13 05:27:51 +00:00
|
|
|
});
|
|
|
|
});
|
2013-11-14 07:29:55 +00:00
|
|
|
};
|
|
|
|
|
2013-11-18 22:37:50 +00:00
|
|
|
/**
|
|
|
|
* GET /logout
|
|
|
|
*/
|
2013-11-14 07:29:55 +00:00
|
|
|
exports.logout = function(req, res) {
|
|
|
|
req.logout();
|
|
|
|
res.redirect('/');
|
|
|
|
};
|