39 lines
1.0 KiB
JavaScript
39 lines
1.0 KiB
JavaScript
const LocalStrategy = require('passport-local').Strategy;
|
|
const User = require('../models/user');
|
|
const config = require('../config/database');
|
|
const bcrypt = require('bcryptjs');
|
|
|
|
module.exports = function(passport){
|
|
// Local Strategy
|
|
passport.use(new LocalStrategy(function(username, password, done){
|
|
// Match Username
|
|
let query = {username:username};
|
|
User.findOne(query, function(err, user){
|
|
if(err) throw err;
|
|
if(!user){
|
|
return done(null, false, {message: 'No user found'});
|
|
}
|
|
|
|
// Match Password
|
|
bcrypt.compare(password, user.password, function(err, isMatch){
|
|
if(err) throw err;
|
|
if(isMatch){
|
|
return done(null, user);
|
|
} else {
|
|
return done(null, false, {message: 'Wrong password'});
|
|
}
|
|
});
|
|
});
|
|
}));
|
|
|
|
passport.serializeUser(function(user, done) {
|
|
done(null, user.id);
|
|
});
|
|
|
|
passport.deserializeUser(function(id, done) {
|
|
User.findById(id, function(err, user) {
|
|
done(err, user);
|
|
});
|
|
});
|
|
}
|