Files
meanTorrent/modules/users/server/controllers/users/users.authentication.server.controller.js

242 lines
6.6 KiB
JavaScript
Raw Normal View History

2014-07-31 11:27:14 +03:00
'use strict';
/**
* Module dependencies.
*/
2015-04-23 17:51:58 +01:00
var path = require('path'),
2014-11-10 23:12:33 +02:00
errorHandler = require(path.resolve('./modules/core/server/controllers/errors.server.controller')),
2014-07-31 11:27:14 +03:00
mongoose = require('mongoose'),
passport = require('passport'),
User = mongoose.model('User');
// URLs for which user can't be redirected on signin
var noReturnUrls = [
'/authentication/signin',
'/authentication/signup'
];
2014-07-31 11:27:14 +03:00
/**
* Signup
*/
2015-07-09 13:49:48 -04:00
exports.signup = function (req, res) {
2014-07-31 11:27:14 +03:00
// For security measurement we remove the roles from the req.body object
delete req.body.roles;
// Init Variables
var user = new User(req.body);
var message = null;
// Add missing user fields
user.provider = 'local';
user.displayName = user.firstName + ' ' + user.lastName;
2015-02-07 12:31:07 -08:00
// Then save the user
2015-07-09 13:49:48 -04:00
user.save(function (err) {
2014-07-31 11:27:14 +03:00
if (err) {
2014-08-02 21:29:38 +03:00
return res.status(400).send({
2014-07-31 11:27:14 +03:00
message: errorHandler.getErrorMessage(err)
});
} else {
// Remove sensitive data before login
user.password = undefined;
user.salt = undefined;
2015-07-09 13:49:48 -04:00
req.login(user, function (err) {
2014-07-31 11:27:14 +03:00
if (err) {
2014-08-02 21:29:38 +03:00
res.status(400).send(err);
2014-07-31 11:27:14 +03:00
} else {
res.json(user);
2014-07-31 11:27:14 +03:00
}
});
}
});
};
/**
* Signin after passport authentication
*/
2015-07-09 13:49:48 -04:00
exports.signin = function (req, res, next) {
passport.authenticate('local', function (err, user, info) {
2014-07-31 11:27:14 +03:00
if (err || !user) {
2014-08-02 21:29:38 +03:00
res.status(400).send(info);
2014-07-31 11:27:14 +03:00
} else {
// Remove sensitive data before login
user.password = undefined;
user.salt = undefined;
2015-07-09 13:49:48 -04:00
req.login(user, function (err) {
2014-07-31 11:27:14 +03:00
if (err) {
2014-08-02 21:29:38 +03:00
res.status(400).send(err);
2014-07-31 11:27:14 +03:00
} else {
res.json(user);
2014-07-31 11:27:14 +03:00
}
});
}
})(req, res, next);
};
/**
* Signout
*/
2015-07-09 13:49:48 -04:00
exports.signout = function (req, res) {
2014-07-31 11:27:14 +03:00
req.logout();
res.redirect('/');
};
/**
* OAuth provider call
*/
exports.oauthCall = function(strategy, scope) {
return function(req, res, next) {
// Set redirection path on session.
// Do not redirect to a signin or signup page
if (noReturnUrls.indexOf(req.query.redirect_to) === -1) {
req.session.redirect_to = req.query.redirect_to;
}
// Authenticate
passport.authenticate(strategy, scope)(req, res, next);
};
};
2014-07-31 11:27:14 +03:00
/**
* OAuth callback
*/
2015-07-09 13:49:48 -04:00
exports.oauthCallback = function (strategy) {
return function (req, res, next) {
// Pop redirect URL from session
var sessionRedirectURL = req.session.redirect_to;
delete req.session.redirect_to;
2015-07-09 13:49:48 -04:00
passport.authenticate(strategy, function (err, user, redirectURL) {
if (err) {
return res.redirect('/authentication/signin?err=' + encodeURIComponent(errorHandler.getErrorMessage(err)));
}
if (!user) {
return res.redirect('/authentication/signin');
2014-07-31 11:27:14 +03:00
}
2015-07-09 13:49:48 -04:00
req.login(user, function (err) {
2014-07-31 11:27:14 +03:00
if (err) {
return res.redirect('/authentication/signin');
2014-07-31 11:27:14 +03:00
}
return res.redirect(redirectURL || sessionRedirectURL || '/');
2014-07-31 11:27:14 +03:00
});
})(req, res, next);
};
2014-08-05 15:35:49 +03:00
};
/**
* Helper function to save or update a OAuth user profile
*/
2015-07-09 13:49:48 -04:00
exports.saveOAuthUserProfile = function (req, providerUserProfile, done) {
2014-08-05 15:35:49 +03:00
if (!req.user) {
// Define a search query fields
var searchMainProviderIdentifierField = 'providerData.' + providerUserProfile.providerIdentifierField;
var searchAdditionalProviderIdentifierField = 'additionalProvidersData.' + providerUserProfile.provider + '.' + providerUserProfile.providerIdentifierField;
// Define main provider search query
var mainProviderSearchQuery = {};
mainProviderSearchQuery.provider = providerUserProfile.provider;
mainProviderSearchQuery[searchMainProviderIdentifierField] = providerUserProfile.providerData[providerUserProfile.providerIdentifierField];
// Define additional provider search query
var additionalProviderSearchQuery = {};
additionalProviderSearchQuery[searchAdditionalProviderIdentifierField] = providerUserProfile.providerData[providerUserProfile.providerIdentifierField];
// Define a search query to find existing user with current provider profile
var searchQuery = {
$or: [mainProviderSearchQuery, additionalProviderSearchQuery]
};
2015-07-09 13:49:48 -04:00
User.findOne(searchQuery, function (err, user) {
2014-08-05 15:35:49 +03:00
if (err) {
return done(err);
} else {
if (!user) {
var possibleUsername = providerUserProfile.username || ((providerUserProfile.email) ? providerUserProfile.email.split('@')[0] : '');
2015-07-09 13:49:48 -04:00
User.findUniqueUsername(possibleUsername, null, function (availableUsername) {
2014-08-05 15:35:49 +03:00
user = new User({
firstName: providerUserProfile.firstName,
lastName: providerUserProfile.lastName,
username: availableUsername,
displayName: providerUserProfile.displayName,
email: providerUserProfile.email,
2014-11-10 23:12:33 +02:00
profileImageURL: providerUserProfile.profileImageURL,
2014-08-05 15:35:49 +03:00
provider: providerUserProfile.provider,
providerData: providerUserProfile.providerData
});
// And save the user
2015-07-09 13:49:48 -04:00
user.save(function (err) {
2014-08-05 15:35:49 +03:00
return done(err, user);
});
});
} else {
return done(err, user);
}
}
});
} else {
// User is already logged in, join the provider data to the existing user
var user = req.user;
// Check if user exists, is not signed in using this provider, and doesn't have that provider data already configured
if (user.provider !== providerUserProfile.provider && (!user.additionalProvidersData || !user.additionalProvidersData[providerUserProfile.provider])) {
// Add the provider data to the additional provider data field
if (!user.additionalProvidersData) user.additionalProvidersData = {};
user.additionalProvidersData[providerUserProfile.provider] = providerUserProfile.providerData;
// Then tell mongoose that we've updated the additionalProvidersData field
user.markModified('additionalProvidersData');
// And save the user
2015-07-09 13:49:48 -04:00
user.save(function (err) {
return done(err, user, '/settings/accounts');
2014-08-05 15:35:49 +03:00
});
} else {
return done(new Error('User is already connected using this provider'), user);
}
}
};
/**
* Remove OAuth provider
*/
2015-07-09 13:49:48 -04:00
exports.removeOAuthProvider = function (req, res, next) {
2014-08-05 15:35:49 +03:00
var user = req.user;
2015-07-09 13:49:48 -04:00
var provider = req.query.provider;
2014-08-05 15:35:49 +03:00
2015-07-09 13:49:48 -04:00
if (!user) {
return res.status(401).json({
message: 'User is not authenticated'
});
} else if (!provider) {
return res.status(400).send();
}
2014-08-05 15:35:49 +03:00
2015-07-09 13:49:48 -04:00
// Delete the additional provider
if (user.additionalProvidersData[provider]) {
delete user.additionalProvidersData[provider];
2014-08-05 15:35:49 +03:00
2015-07-09 13:49:48 -04:00
// Then tell mongoose that we've updated the additionalProvidersData field
user.markModified('additionalProvidersData');
2014-08-05 15:35:49 +03:00
}
2015-07-09 13:49:48 -04:00
user.save(function (err) {
if (err) {
return res.status(400).send({
message: errorHandler.getErrorMessage(err)
});
} else {
req.login(user, function (err) {
if (err) {
return res.status(400).send(err);
} else {
return res.json(user);
}
});
}
});
};