facebook auth strategy

This commit is contained in:
Sahat Yalkabov
2013-11-18 19:43:45 -05:00
parent 222dbc8b40
commit 2a92595517
2 changed files with 19 additions and 3 deletions

2
app.js
View File

@@ -7,7 +7,7 @@ var express = require('express'),
passport = require('passport');
// Configuration (API Keys, Database URI)
var config = require('./config.json');
var config = require('./config/config.json');
var passportConf = require('./config/passport');
// Load controllers

View File

@@ -1,6 +1,9 @@
var passport = require('passport'),
LocalStrategy = require('passport-local').Strategy,
User = require('../models/User');
FacebookStrategy = require('passport-facebook').Strategy,
User = require('../models/User'),
config = require('.config.json');
passport.serializeUser(function(user, done) {
done(null, user.id);
@@ -12,7 +15,10 @@ passport.deserializeUser(function(id, done) {
});
});
passport.use(new LocalStrategy({ usernameField: 'email' },function(email, password, done) {
passport.use(new LocalStrategy({
usernameField: 'email'
},
function(email, password, done) {
User.findOne({ email: email }, function(err, user) {
if (err) { return done(err); }
if (!user) { return done(null, false, { message: 'Unknown user ' + email }); }
@@ -27,6 +33,16 @@ passport.use(new LocalStrategy({ usernameField: 'email' },function(email, passwo
});
}));
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) {
var user = module.exports.findOrCreateOauthUser(profile.provider, profile.id);
done(null, user);
}));
// 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(); }