passport.js - аутентифицировать пользователей из MongoDB с помощью passport-local

У меня есть простая коллекция пользователей в моем MongoDB. Я пользователь монго-родного драйвера.

{
    "email": "[email protected]",
    "password": "123456",
    "_id": {
        "$oid": "50658c835b821298d3000001"
    }
}

Когда я использую auth через пару email: pass, я переписал по умолчанию функцию passport-local find findByUsername для этого:

function findByEmail(email, fn) {
    db.collection("users", function(err, collection) {
        collection.find({}, {}, function(err, users) {
            users.each(function(err, user) {
                if (user.email === email) {
                    return fn(null, user);
                }
            });
            return fn(null, null);
        });
    });
}

Просто получите всех пользователей из БД и проверьте - если user.email == предоставил адрес электронной почты, то верните объект пользователя.

Я использую параметр _id MongoDB в качестве идентификатора для пользователей, поэтому я изменяю эти две функции:

passport.serializeUser(function(user, done) {
    done(null, user._id);
});

passport.deserializeUser(function(id, done) {
    findById(id, function(err, user) {
        done(err, user);
    });
});

И это мой код для локальной стратегии паспорта:

passport.use(new LocalStrategy( function(email, password, done) {
    process.nextTick(function() {
        console.log('initialize findByEmail() for "',email,'"');
        findByEmail(email, function(err, user) {
            if (err) {
                return done(err);
            }
            if (!user) {
                console.log('Unknown user ' + email)
                return done(null, false, {
                    message: 'Unknown user ' + email

                });
            }
            if (user.password != password) {
                console.log('Invalid password')
                return done(null, false, {
                    message: 'Invalid password'
                });
            }
            //сonsole.log('ALL VERIFIATION PASSED');
            return done(null, user);
        })
    });
}));

Я публикую данные со страницы входа в систему:

app.post('/login', passport.authenticate('local', {
    failureRedirect: '/',
    failureFlash: true
}), function(req, res) {
    res.redirect('/desk');
});

И я получаю

Error: Can't set headers after they are sent.

и после этого я получаю

TypeError: Cannot read property 'email' of null

Последняя ошибка действительно странная, так как findByEmail имеет строку console.log (user) (удалена из этого списка), в которой перечислены все данные пользователя.

Что я делаю неправильно?

Ответы на вопрос(1)

Ваш ответ на вопрос