Usando PassportJS, ¿cómo se pasan campos de formulario adicionales a la estrategia de autenticación local?

Estoy usando pasaporteJS y estoy queriendo proporcionar más que solo req.body.username y req.body.password a mi estrategia de autenticación (pasaporte-local).

Tengo 3 campos de formulario: username , password y foo

¿Cómo hago para acceder a req.body.foo desde mi estrategia local que se ve así:

 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); }); } )); 

Estoy llamando esto dentro de mi ruta (no como middleware de ruta) así:

  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); }); 

Hay una opción passReqToCallback que puedes habilitar, de esta forma:

 passport.use(new LocalStrategy( {usernameField: 'email', passReqToCallback: true}, function(req, email, password, done) { // now you can check req.body.foo } )); 

Cuando, establecer req convierte en el primer argumento para verificar la callback, y puede inspeccionarlo como lo desee.