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>

questionAnswers(1)

yourAnswerToTheQuestion