I wrote console.log in LocalStrategy callback but it never called. I use Sequelize for ORM (MySQL).
passport.js
const LocalStrategy = require('passport-local').Strategy
const passport = require('passport')
const bcrypt = require('bcrypt')
const UrunModel = require('../models/Urun')
console.log('File is Called') // If my require is wrong. But this log worked.
passport.use(new LocalStrategy({
usernameField: 'mail',
passwordField: 'pw1'
},
(username, password, done) => {
console.log('Worked!') // Never Called
UrunModel.findOne({
where : {
UrunName : 'testuser',
UrunDesc : '123456'
}
})
}
));
passport.serializeUser(function(user, done) {
done(null, user.id);
});
passport.deserializeUser(function(id, done) {
User.findById(id, function(err, user) {
done(err, user);
});
});
index.js
const session = require('express-session');
const bodyParser = require('body-parser')
const urlencoded = bodyParser.urlencoded({extended:false})
const passport = require('passport')
app.use(session({
secret: 'keyboardSecrIncKey',
resave: false,
saveUninitialized: true,
}))
app.use(passport.initialize())
app.use(passport.session())
require('./config/passport') //require my passport.js
app.post('/test',(req,res,next) => {
passport.authenticate('local',{
successRedirect: '/worked',
failureRedirect: '/notworked'
})(req,res,next)
})
It redirect me '/notworked' url. I watched 3 or 4 videos but almost same on my code.
Where i am failed ? Please explain my fault.
Solved:
LocalStrategy not called when there are empty fields(usernameField & passwordField)