from __future__ import annotations
from passlib.hash import bcrypt_sha256
[docs]
def hash_password(password: str) -> str:
""" The default password hashing algorithm used by onegov.
Over time the underlying algorithm may change, at which point
:meth:`verify_password` must issue a deprecation warning when using
the old algorithm.
Note that no salt is being passed, because the algorithm we use now
(bcrypt), as well as the algorithm that we might use in the future
(scrypt), generate their own salt automatically by default.
The salt is then stored in the resulting hash. That means that we do
not pass or store a salt ourselves.
"""
# be sure not to have this issue (some crypt bindings will):
# blog.ircmaxell.com/2015/03/security-issue-combining-bcrypt-with.html
assert '\0' not in password
# like bcrypt, but with the ability to support any password length
return bcrypt_sha256.hash(password)
[docs]
def verify_password(password: str, hash: str) -> bool:
""" Compares a password to a hash and returns true if they match according
to the hashing algorithm used.
"""
# be sure not to have this issue (some crypt bindings will):
# blog.ircmaxell.com/2015/03/security-issue-combining-bcrypt-with.html
assert '\0' not in password
return bcrypt_sha256.verify(password, hash)