Make bcrypt + passlib work in password_hash filter

If hashtype for the password_hash filter is 'blowfish' and passlib is
available, hashing fails as the hash function for this is named 'bcrypt'
(and not 'blowfish_crypt').  Special case this so that the correct
function is called.

(cherry picked from commit 692bfa872a)
This commit is contained in:
Matt Robinson 2016-10-18 19:50:45 +01:00 committed by Michael Scherer
parent 84485c29ee
commit 92c851a894

View file

@ -256,8 +256,12 @@ def get_encrypted_password(password, hashtype='sha512', salt=None):
raise errors.AnsibleFilterError('|password_hash requires the passlib python module to generate password hashes on Mac OS X/Darwin') raise errors.AnsibleFilterError('|password_hash requires the passlib python module to generate password hashes on Mac OS X/Darwin')
saltstring = "$%s$%s" % (cryptmethod[hashtype],salt) saltstring = "$%s$%s" % (cryptmethod[hashtype],salt)
encrypted = crypt.crypt(password, saltstring) encrypted = crypt.crypt(password, saltstring)
else:
if hashtype == 'blowfish':
cls = passlib.hash.bcrypt;
else: else:
cls = getattr(passlib.hash, '%s_crypt' % hashtype) cls = getattr(passlib.hash, '%s_crypt' % hashtype)
encrypted = cls.encrypt(password, salt=salt) encrypted = cls.encrypt(password, salt=salt)
return encrypted return encrypted