Wie übergibt man mit PassportJS zusätzliche Formularfelder an die lokale Authentifizierungsstrategie?

Ich benutze passportJS und möchte mehr als nur liefernreq.body.username undreq.body.password zu meiner Authentifizierungsstrategie (passport-local).

Ich habe 3 Formularfelder:username, password, &foo

Wie gehe ich vor?req.body.foo von meiner lokalen Strategie, die aussieht wie:

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' });
        }
        if (password != 1212) {
          return done(null, false, { message: 'Invalid password' });
        }
        console.log('I just wanna see foo! ' + req.body.foo); // this fails!
        return done(null, user, aToken);

      });
    }
));

Ich rufe dies auf meiner Route (nicht als Route Middleware) folgendermaßen auf:

  app.post('/api/auth', function(req, res, next) {
    passport.authenticate('local', {session:false}, function(err, user, token_record) {
      if (err) { return next(err) }
      res.json({access_token:token_record.access_token});
   })(req, res, next);

  });

Antworten auf die Frage(1)

Ihre Antwort auf die Frage