I'm trying to implement a passport-local strategy using passport.js
I would like it so that when a user tries to sign up with an email that is already taken, it flashes a message 'That email is already taken'.
I've added the line failureFlash: true
but how do I get access to the flash message so I can actually get it to appear on the screen?
I'm quite new to this all so any help would be awesome.
passport.js:
const passport = require('passport');
const LocalStrategy = require('passport-local').Strategy;
const mongoose = require('mongoose');
const User = mongoose.model('users');
passport.serializeUser((user, done) => {
console.log('serialize:', user.id);
done(null, user.id);
});
passport.deserializeUser((id, done) => {
User.findById(id).then(user => {
console.log('deserialize:', user);
done(null, user);
});
});
// Local signup strategy
passport.use('local-signup', new LocalStrategy(
{
usernameField: 'email',
passwordField: 'password',
passReqToCallback: true
},
(req, email, password, done) => {
User.findOne({ 'local.email': email }, (err, user) => {
if (err) { return done(err); }
if (user) {
console.log('user error:', user);
return done(null, false, req.flash('signUpMessage', 'That email is already taken.'));
} else {
new User({
'local.email': email,
'local.password': password
})
.save()
.then(user => {
done(null, user)
})
.catch(err => {
console.log('error:', err);
done(err);
});
}
});
}
));
authRoutes.js:
const passport = require('passport');
module.exports = app => {
app.post(
'/api/signup',
passport.authenticate('local-signup', {
failureFlash: true
}),
(req, res) => {
console.log('request:', req);
console.log('flash msg:', req.flash('signUpMessage'));
res.send(req.user);
}
);
app.get('/api/current_user', (req, res) => {
console.log('current_user:', req.user);
res.send(req.user);
});
app.get('/api/logout', (req, res) => {
req.logout();
res.redirect('/');
});
};