freeCodeCamp/config/passport.js

129 lines
3.4 KiB
JavaScript
Raw Normal View History

var passport = require('passport'),
LocalStrategy = require('passport-local').Strategy,
2013-11-19 00:43:45 +00:00
FacebookStrategy = require('passport-facebook').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
// TODO: Request email permission from Oauth
// TODO: if email matches, users are the same, merge accounts
passport.serializeUser(function(user, done) {
done(null, user.id);
});
passport.deserializeUser(function(id, done) {
User.findById(id, function (err, user) {
done(err, user);
});
});
2013-11-19 00:43:45 +00:00
passport.use(new LocalStrategy({
usernameField: 'email'
},
function(email, password, done) {
User.findOne({ email: email }, function(err, user) {
2013-11-19 07:00:38 +00:00
if (err) return done(err);
if (!user) { return done(null, false, { message: 'Unknown user ' + email }); }
user.comparePassword(password, function(err, isMatch) {
if (err) return done(err);
if(isMatch) {
return done(null, user);
} else {
return done(null, false, { message: 'Invalid password' });
}
});
});
}));
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) {
User.findOne({ facebook: profile.id }, function(err, existingUser) {
2013-11-19 07:00:38 +00:00
if (err) {
done(err);
}
if (existingUser) {
return done(null, existingUser);
}
var user = new User({
firstName: profile.name.givenName,
lastName: profile.name.familyName,
provider: profile.provider
});
2013-11-19 07:00:38 +00:00
user[profile.provider] = profile.id;
user.save(function(err) {
2013-11-19 07:00:38 +00:00
if (err) console.log(err);
done(null, user);
});
2013-11-19 07:00:38 +00:00
});
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,
provider: profile.provider
});
user[profile.provider] = profile.id;
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 00:43:45 +00:00
// Simple route middleware to ensure user is authenticated. Otherwise send to login page.
exports.ensureAuthenticated = function ensureAuthenticated(req, res, next) {
if (req.isAuthenticated()) { return next(); }
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);
};
};