mirror of
https://github.com/taobataoma/meanTorrent.git
synced 2026-02-09 16:07:00 +01:00
120 lines
2.1 KiB
JavaScript
Executable File
120 lines
2.1 KiB
JavaScript
Executable File
'use strict';
|
|
|
|
/**
|
|
* Module dependencies.
|
|
*/
|
|
var mongoose = require('mongoose'),
|
|
passport = require('passport'),
|
|
User = mongoose.model('User');
|
|
|
|
/**
|
|
* Signup
|
|
*/
|
|
exports.signup = function(req, res) {
|
|
// Init Variables
|
|
var user = new User(req.body);
|
|
var message = null;
|
|
|
|
// Add missing user fields
|
|
user.provider = 'local';
|
|
user.displayName = user.firstName + ' ' + user.lastName;
|
|
|
|
user.save(function(err) {
|
|
if (err) {
|
|
switch (err.code) {
|
|
case 11000:
|
|
case 11001:
|
|
message = 'Email or username already exists';
|
|
break;
|
|
default:
|
|
message = 'Please fill all the required fields';
|
|
}
|
|
|
|
return res.send(400, {
|
|
message: message
|
|
});
|
|
}
|
|
req.logIn(user, function(err) {
|
|
if (err) {
|
|
res.send(400, err);
|
|
} else {
|
|
res.jsonp(user);
|
|
}
|
|
});
|
|
});
|
|
};
|
|
|
|
/**
|
|
* Signin after passport authentication
|
|
*/
|
|
exports.signin = function(req, res, next) {
|
|
passport.authenticate('local', function(err, user, info) {
|
|
if (err || !user) {
|
|
res.send(400, info);
|
|
} else {
|
|
req.logIn(user, function(err) {
|
|
if (err) {
|
|
res.send(400, err);
|
|
} else {
|
|
res.jsonp(user);
|
|
}
|
|
});
|
|
}
|
|
})(req, res, next);
|
|
};
|
|
|
|
/**
|
|
* Signout
|
|
*/
|
|
exports.signout = function(req, res) {
|
|
req.logout();
|
|
res.redirect('/');
|
|
};
|
|
|
|
/**
|
|
* Send User
|
|
*/
|
|
exports.me = function(req, res) {
|
|
res.jsonp(req.user || null);
|
|
};
|
|
|
|
/**
|
|
* Auth callback
|
|
*/
|
|
exports.authCallback = function(req, res) {
|
|
res.redirect('/');
|
|
};
|
|
|
|
/**
|
|
* User middleware
|
|
*/
|
|
exports.userByID = function(req, res, next, id) {
|
|
User.findOne({
|
|
_id: id
|
|
}).exec(function(err, user) {
|
|
if (err) return next(err);
|
|
if (!user) return next(new Error('Failed to load User ' + id));
|
|
req.profile = user;
|
|
next();
|
|
});
|
|
};
|
|
|
|
/**
|
|
* Require login routing middleware
|
|
*/
|
|
exports.requiresLogin = function(req, res, next) {
|
|
if (!req.isAuthenticated()) {
|
|
return res.send(401, 'User is not logged in');
|
|
}
|
|
next();
|
|
};
|
|
|
|
/**
|
|
* User authorizations routing middleware
|
|
*/
|
|
exports.hasAuthorization = function(req, res, next) {
|
|
if (req.profile.id !== req.user.id) {
|
|
return res.send(403, 'User is not authorized');
|
|
}
|
|
next();
|
|
}; |