2013-11-14 07:29:55 +00:00
|
|
|
var passport = require('passport'),
|
2013-11-14 03:19:37 +00:00
|
|
|
LocalStrategy = require('passport-local').Strategy,
|
2013-11-19 00:43:45 +00:00
|
|
|
FacebookStrategy = require('passport-facebook').Strategy,
|
2013-12-03 00:16:27 +00:00
|
|
|
TwitterStrategy = require('passport-twitter').Strategy,
|
2013-12-03 22:57:54 +00:00
|
|
|
GitHubStrategy = require('passport-github').Strategy,
|
2013-11-21 19:20:38 +00:00
|
|
|
GoogleStrategy = require('passport-google-oauth').OAuth2Strategy,
|
2013-11-19 00:43:45 +00:00
|
|
|
User = require('../models/User'),
|
2013-11-19 03:31:55 +00:00
|
|
|
config = require('./config.json');
|
2013-11-19 00:43:45 +00:00
|
|
|
|
2013-11-14 07:29:55 +00:00
|
|
|
passport.serializeUser(function(user, done) {
|
|
|
|
done(null, user.id);
|
|
|
|
});
|
2013-11-14 03:19:37 +00:00
|
|
|
|
2013-11-14 07:29:55 +00:00
|
|
|
passport.deserializeUser(function(id, done) {
|
|
|
|
User.findById(id, function (err, user) {
|
|
|
|
done(err, user);
|
2013-11-14 03:19:37 +00:00
|
|
|
});
|
2013-11-14 07:29:55 +00:00
|
|
|
});
|
2013-11-14 03:19:37 +00:00
|
|
|
|
2013-11-19 00:43:45 +00:00
|
|
|
passport.use(new LocalStrategy({
|
2013-12-04 20:25:57 +00:00
|
|
|
usernameField: 'email'
|
2013-11-19 00:43:45 +00:00
|
|
|
},
|
|
|
|
function(email, password, done) {
|
2013-11-18 22:37:50 +00:00
|
|
|
User.findOne({ email: email }, function(err, user) {
|
2013-11-19 07:00:38 +00:00
|
|
|
if (err) return done(err);
|
2013-11-18 22:37:50 +00:00
|
|
|
if (!user) { return done(null, false, { message: 'Unknown user ' + email }); }
|
2013-11-14 07:29:55 +00:00
|
|
|
user.comparePassword(password, function(err, isMatch) {
|
|
|
|
if (err) return done(err);
|
|
|
|
if(isMatch) {
|
2013-11-14 03:19:37 +00:00
|
|
|
return done(null, user);
|
|
|
|
} else {
|
2013-11-14 07:29:55 +00:00
|
|
|
return done(null, false, { message: 'Invalid password' });
|
2013-11-14 03:19:37 +00:00
|
|
|
}
|
|
|
|
});
|
2013-11-14 07:29:55 +00:00
|
|
|
});
|
|
|
|
}));
|
|
|
|
|
2013-11-21 19:29:41 +00:00
|
|
|
// FACEBOOK OAUTH2 LOGIN
|
2013-11-19 00:43:45 +00:00
|
|
|
passport.use(new FacebookStrategy({
|
|
|
|
clientID: config.facebook.clientId,
|
|
|
|
clientSecret: config.facebook.clientSecret,
|
|
|
|
callbackURL: config.facebook.callbackUrl || "http://localhost:8000/auth/facebook/callback"
|
|
|
|
},
|
|
|
|
function (accessToken, refreshToken, profile, done) {
|
2013-11-19 06:57:13 +00:00
|
|
|
User.findOne({ facebook: profile.id }, function(err, existingUser) {
|
2013-12-03 00:16:27 +00:00
|
|
|
if (err) done(err);
|
2013-11-19 07:00:38 +00:00
|
|
|
|
2013-12-03 00:16:27 +00:00
|
|
|
if (existingUser) return done(null, existingUser);
|
2013-11-19 07:00:38 +00:00
|
|
|
|
2013-11-19 06:57:13 +00:00
|
|
|
var user = new User({
|
|
|
|
firstName: profile.name.givenName,
|
|
|
|
lastName: profile.name.familyName,
|
2013-11-25 16:48:47 +00:00
|
|
|
provider: profile.provider,
|
|
|
|
email: profile._json.email
|
2013-11-19 06:57:13 +00:00
|
|
|
});
|
2013-11-19 07:00:38 +00:00
|
|
|
|
2013-11-19 06:57:13 +00:00
|
|
|
user[profile.provider] = profile.id;
|
|
|
|
|
|
|
|
user.save(function(err) {
|
2013-11-19 07:00:38 +00:00
|
|
|
if (err) console.log(err);
|
2013-11-19 06:57:13 +00:00
|
|
|
done(null, user);
|
|
|
|
});
|
2013-12-03 00:16:27 +00:00
|
|
|
});
|
|
|
|
}
|
|
|
|
));
|
2013-11-19 07:00:38 +00:00
|
|
|
|
2013-12-03 22:38:14 +00:00
|
|
|
// GITHUB OAUTH2 LOGIN
|
|
|
|
passport.use(new GitHubStrategy({
|
2013-12-03 22:57:54 +00:00
|
|
|
clientID: config.github.clientId,
|
|
|
|
clientSecret: config.github.clientSecret,
|
|
|
|
callbackURL: config.github.callbackUrl
|
2013-12-03 22:38:14 +00:00
|
|
|
},
|
|
|
|
function(accessToken, refreshToken, profile, done) {
|
2013-12-03 22:57:54 +00:00
|
|
|
User.findOne({ github: profile.id }, function(err, existingUser) {
|
|
|
|
if (err) done(err);
|
|
|
|
if (existingUser) return done(null, existingUser);
|
|
|
|
console.log(profile);
|
|
|
|
var user = new User({
|
|
|
|
username: profile.username,
|
|
|
|
displayName: profile.displayName,
|
|
|
|
email: profile.emails[0].value,
|
|
|
|
provider: profile.provider
|
|
|
|
});
|
|
|
|
user[profile.provider] = profile.id;
|
|
|
|
user.save(function(err) {
|
|
|
|
if (err) console.log(err);
|
|
|
|
done(null, user);
|
|
|
|
});
|
2013-12-03 22:38:14 +00:00
|
|
|
});
|
|
|
|
}
|
|
|
|
));
|
|
|
|
|
2013-12-03 00:16:27 +00:00
|
|
|
// TWITTER OAUTH2 LOGIN
|
|
|
|
passport.use(new TwitterStrategy({
|
|
|
|
consumerKey: config.twitter.clientId,
|
|
|
|
consumerSecret: config.twitter.clientSecret,
|
|
|
|
callbackURL: '/auth/twitter/callback'
|
|
|
|
},
|
|
|
|
function(token, tokenSecret, profile, done) {
|
2013-12-03 00:20:57 +00:00
|
|
|
User.findOne({ twitter: profile.id }, function(err, existingUser) {
|
2013-12-03 00:16:27 +00:00
|
|
|
if (err) done(err);
|
|
|
|
if (existingUser) return done(null, existingUser);
|
|
|
|
console.log(profile);
|
|
|
|
var user = new User({
|
|
|
|
username: profile.username,
|
|
|
|
displayName: profile.displayName,
|
|
|
|
photo: profile.photos[0].value,
|
|
|
|
provider: profile.provider,
|
|
|
|
});
|
|
|
|
user[profile.provider] = profile.id;
|
|
|
|
user.save(function(err) {
|
|
|
|
if (err) console.log(err);
|
|
|
|
done(null, user);
|
|
|
|
});
|
2013-11-19 06:03:11 +00:00
|
|
|
});
|
2013-11-21 19:20:38 +00:00
|
|
|
}
|
|
|
|
));
|
|
|
|
|
2013-11-21 19:29:41 +00:00
|
|
|
// GOOGLE OAUTH2 LOGIN
|
2013-11-21 19:20:38 +00:00
|
|
|
passport.use(new GoogleStrategy({
|
|
|
|
clientID: config.google.clientId,
|
|
|
|
clientSecret: config.google.clientSecret,
|
|
|
|
callbackURL: config.google.callbackUrl
|
|
|
|
},
|
|
|
|
function(accessToken, refreshToken, profile, done) {
|
|
|
|
console.log(accessToken);
|
|
|
|
console.log(profile);
|
|
|
|
User.findOne({ google: profile.id }, function(err, existingUser) {
|
|
|
|
|
|
|
|
if (err) {
|
|
|
|
done(err);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (existingUser) {
|
|
|
|
return done(null, existingUser);
|
|
|
|
}
|
|
|
|
|
|
|
|
var user = new User({
|
|
|
|
firstName: profile.name.givenName,
|
|
|
|
lastName: profile.name.familyName,
|
2013-11-21 19:29:41 +00:00
|
|
|
email: profile._json.email,
|
2013-11-21 19:20:38 +00:00
|
|
|
provider: profile.provider
|
|
|
|
});
|
|
|
|
|
|
|
|
user[profile.provider] = profile.id;
|
2013-11-19 06:03:11 +00:00
|
|
|
|
2013-11-21 19:20:38 +00:00
|
|
|
user.save(function(err) {
|
|
|
|
if (err) {
|
|
|
|
if (err.code === 11000) {
|
|
|
|
// Found another user with the same email
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
done(null, user);
|
|
|
|
});
|
|
|
|
|
|
|
|
});
|
2013-11-19 06:03:11 +00:00
|
|
|
}
|
|
|
|
));
|
2013-11-19 00:43:45 +00:00
|
|
|
|
2013-11-14 07:29:55 +00:00
|
|
|
// Simple route middleware to ensure user is authenticated. Otherwise send to login page.
|
|
|
|
exports.ensureAuthenticated = function ensureAuthenticated(req, res, next) {
|
2013-12-04 12:44:07 +00:00
|
|
|
if (req.isAuthenticated()) {
|
|
|
|
return next();
|
|
|
|
}
|
2013-11-14 07:29:55 +00:00
|
|
|
res.redirect('/login');
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
// Check for admin middleware, this is unrelated to passport.js
|
|
|
|
// You can delete this if you use different method to check for admins or don't need admins
|
|
|
|
exports.ensureAdmin = function ensureAdmin(req, res, next) {
|
|
|
|
return function(req, res, next) {
|
|
|
|
console.log(req.user);
|
|
|
|
if(req.user && req.user.admin === true)
|
|
|
|
next();
|
|
|
|
else
|
|
|
|
res.send(403);
|
|
|
|
};
|
2013-11-14 03:19:37 +00:00
|
|
|
};
|