Source code for core.crypto.password

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)