2013-01-01 2 views

risposta

3

Io uso questa soluzione, è abbastanza facile. Salvo l'ultimo URL nella sessione e lo raccolgo in seguito. Se si passa l'url di richiamata a fb direttamente è necessario consentire tutte le diverse rotte che è piuttosto una chicca.

app.get '/auth/facebook/', routesService.clean, (req, res, next) -> 
    req.session.redirect = req.query.redirect if req.session? && req.query.redirect? 
    passport.authenticate('facebook', { scope: ['user_friends'] }) req, res, next 
    return 

    app.get '/auth/facebook/callback', passport.authenticate('facebook', failureRedirect: '/login'), (req, res) -> 
     # Successful authentication, redirect home. 
     if req.session?.redirect? 
      rediredUrl = req.session.redirect 
      delete req.session.redirect 
      res.redirect '/#!'+ rediredUrl 
     else 
      res.redirect '/' 
     return 
1

Basta dare seguito alla risposta del Gal, ecco che la soluzione combinata:.

app.get('/auth/facebook', (req, res, next) => { 
    passport.authenticate('facebook')(req, res, next) 
}) 

app.get("/auth/facebook/callback", (req, res, next) => { 
    passport.authenticate('facebook', (err, user, info) => { 
    if (err) { return next(err); } 
    if (!user) { return res.redirect('/login')} 
    req.logIn(user, function(err) { 
     if (err) { return next(err); } 
     return res.redirect('/users/' + user.uid) 
    }); 
    })(req, res, next) 
}) 

Nota che devi loggarti specificamente l'utente in