Created
August 20, 2015 14:45
-
-
Save willricketts/1f45b92521a5b8fd37da to your computer and use it in GitHub Desktop.
Simple authentication system for Sails.js
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
var bcrypt = require('bcrypt'); | |
module.exports = { | |
hashPassword: hashPassword, | |
verifyPassword: verifyPassword | |
} | |
function hashPassword(prehash, callback) { | |
bcrypt.genSalt(10, function(err, salt) { | |
if(err) { | |
callback(new Error(err)); | |
} | |
else if(salt) { | |
bcrypt.hash(prehash, salt, function(err, hash) { | |
if(err) { | |
callback(new Error(err)); | |
} | |
else if(hash) { | |
callback(hash); | |
} | |
else { | |
callback(new Error('Password hashing failed somewhere, somehow')); | |
} | |
}); | |
} | |
else { | |
callback(new Error('Salt was unhandled')); | |
} | |
}); | |
} | |
function verifyPassword(email, prehash, callback) { | |
User.findOne({ email: email }, function(err, user) { | |
if(err) { | |
callback(new Error(err)); | |
} | |
else if(user) { | |
hashPassword(prehash, function(hash) { | |
bcrypt.compare(prehash, hash, function(err, authenticated) { | |
if(err) { | |
callback(new Error(err)); | |
} | |
else { | |
callback(authenticated); | |
} | |
}); | |
}); | |
} | |
else { | |
callback(new Error('Somehow a user wasn't found)); | |
} | |
}); | |
} |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment