|
|
|
|
|
""" |
|
Legacy mid-level functions. |
|
""" |
|
|
|
from __future__ import annotations |
|
|
|
import os |
|
import warnings |
|
|
|
from ._password_hasher import ( |
|
DEFAULT_HASH_LENGTH, |
|
DEFAULT_MEMORY_COST, |
|
DEFAULT_PARALLELISM, |
|
DEFAULT_RANDOM_SALT_LENGTH, |
|
DEFAULT_TIME_COST, |
|
) |
|
from ._typing import Literal |
|
from .low_level import Type, hash_secret, hash_secret_raw, verify_secret |
|
|
|
|
|
_INSTEAD = " is deprecated, use argon2.PasswordHasher instead" |
|
|
|
|
|
def hash_password( |
|
password: bytes, |
|
salt: bytes | None = None, |
|
time_cost: int = DEFAULT_TIME_COST, |
|
memory_cost: int = DEFAULT_MEMORY_COST, |
|
parallelism: int = DEFAULT_PARALLELISM, |
|
hash_len: int = DEFAULT_HASH_LENGTH, |
|
type: Type = Type.I, |
|
) -> bytes: |
|
""" |
|
Legacy alias for :func:`argon2.low_level.hash_secret` with default |
|
parameters. |
|
|
|
.. deprecated:: 16.0.0 |
|
Use :class:`argon2.PasswordHasher` for passwords. |
|
""" |
|
warnings.warn( |
|
"argon2.hash_password" + _INSTEAD, DeprecationWarning, stacklevel=2 |
|
) |
|
if salt is None: |
|
salt = os.urandom(DEFAULT_RANDOM_SALT_LENGTH) |
|
return hash_secret( |
|
password, salt, time_cost, memory_cost, parallelism, hash_len, type |
|
) |
|
|
|
|
|
def hash_password_raw( |
|
password: bytes, |
|
salt: bytes | None = None, |
|
time_cost: int = DEFAULT_TIME_COST, |
|
memory_cost: int = DEFAULT_MEMORY_COST, |
|
parallelism: int = DEFAULT_PARALLELISM, |
|
hash_len: int = DEFAULT_HASH_LENGTH, |
|
type: Type = Type.I, |
|
) -> bytes: |
|
""" |
|
Legacy alias for :func:`argon2.low_level.hash_secret_raw` with default |
|
parameters. |
|
|
|
.. deprecated:: 16.0.0 |
|
Use :class:`argon2.PasswordHasher` for passwords. |
|
""" |
|
warnings.warn( |
|
"argon2.hash_password_raw" + _INSTEAD, DeprecationWarning, stacklevel=2 |
|
) |
|
if salt is None: |
|
salt = os.urandom(DEFAULT_RANDOM_SALT_LENGTH) |
|
return hash_secret_raw( |
|
password, salt, time_cost, memory_cost, parallelism, hash_len, type |
|
) |
|
|
|
|
|
def verify_password( |
|
hash: bytes, password: bytes, type: Type = Type.I |
|
) -> Literal[True]: |
|
""" |
|
Legacy alias for :func:`argon2.low_level.verify_secret` with default |
|
parameters. |
|
|
|
.. deprecated:: 16.0.0 |
|
Use :class:`argon2.PasswordHasher` for passwords. |
|
""" |
|
warnings.warn( |
|
"argon2.verify_password" + _INSTEAD, DeprecationWarning, stacklevel=2 |
|
) |
|
return verify_secret(hash, password, type) |
|
|