With a little help I\'ve arrived at the following code to promisify a passport.js login strategy.
var passport = require(\'passport\');
var LocalStrategy = r
Use:
.nodeify(done, {spread: true});
This allows multiple arguments to be passed to the 'done' callback.
More info on:
Bluebird nodeify documentation
I'm adding this answer to show how to use .nodeify(done, {spread: true})
(as mentioned in other answers/comments) with the original example.
var passport = require('passport');
var LocalStrategy = require('passport-local').Strategy;
var Promise = require('bluebird');
var bcrypt = require('bcrypt');
var db = require('./db').db; //users are stored in mongo
//I'm using bluebird.js for promises
var users = Promise.promisifyAll(db.users);
var compare = Promise.promisify(bcrypt.compare);
// This strategy is used by passport to handle logins
module.exports.localStrategy = new LocalStrategy(function(username, password, done) {
users.findOneAsync({username: username}).bind({})
.then(function(user) {
if (!user) {
return [false, { message: 'Incorrect username.' }]; <---------------
//should be equivalent to:
// return done(null, false, {message:'something'});
}
this.user = user;
return compare(password, user.password);
})
.then(function(isMatch) {
if (isMatch) {
return this.user;
//is equivalent to:
// return done(null, this.user);
}
else {
return [false, { message: 'Incorrect password.' }]; <---------------
//should be equivalent to:
// return done(null, false, {message:'something else'};
}
})
.nodeify(done, {spread: true});
});
Currently, there is no way to do it with .nodeify
, you can of course do it manually with .then
:
.then(function(result){
done(/*whatever arguments you need*/);
},function(failure){
done(/* failure argumnets */);
});