paszport: inne przekierowanie do logowania i rejestracji konta
Używam modułu paszportowego (uwierzytelnianie github) w mojej aplikacji i chcę przekierować w zależności od akcji ... sprawdzam, czy to zwykły login lub czy użytkownik loguje się po raz pierwszy.
<code>passport.use(new GitHubStrategy({ clientID: conf.github.app_id, clientSecret: conf.github.app_secret, callbackURL: conf.github.callback_url }, function(accessToken, refreshToken, profile, done) { // asynchronous verification, for effect... process.nextTick(function () { // To keep the example simple, the user's GitHub profile is returned to // represent the logged-in user. In a typical application, you would want // to associate the GitHub account with a user record in your database, // and return that user instead. Models_User.findOrCreateUser(profile, function(msg){ console.log("auth type:" + msg); }); return done(null, profile); }); } )); </code>
w mojej funkcji findOrCreateUser sprawdzam, czy jest to nowy użytkownik i wykonuję całą akcję db ... do testowania pozwalam funkcji zwracać zmienną msg, która jest tylko łańcuchem, który mówi „login” lub „new_registration”.
więc moje pytanie brzmi, jak „przetransportować” tę zmienną, którą otrzymuję od findOrCreateUser, aby móc odpowiednio przekierować („/ welcome” lub „/ back_again”) po zakończeniu autoryzacji paszportu.
inny kod paszportu w mojej aplikacji:
<code>// GET /auth/github // Use passport.authenticate() as route middleware to authenticate the // request. The first step in GitHub authentication will involve redirecting // the user to github.com. After authorization, GitHubwill redirect the user // back to this application at /auth/github/callback app.get('/auth/github', passport.authenticate('github'), //passport.authenticate('github', { scope: ['user', 'public_repo', 'gist'] }), function(req, res){ // The request will be redirected to GitHub for authentication, so this // function will not be called. }); // GET /auth/github/callback // Use passport.authenticate() as route middleware to authenticate the // request. If authentication fails, the user will be redirected back to the // login page. Otherwise, the primary route function function will be called, // which, in this example, will redirect the user to the home page. app.get('/auth/github/callback', passport.authenticate('github', { successRedirect: '/', failureRedirect: '/login' }), function(req, res) { res.redirect('/'); }); </code>