Cryptographic operations should use proven, standard algorithms rather than custom implementations.
Non-standard cryptographic algorithms are those that have not been publicly vetted by the security community or that implement cryptographic primitives in a custom way. Creating a custom cryptographic algorithm by subclassing standard cryptographic base classes bypasses the rigorous testing and peer review that established algorithms undergo. Custom implementations are likely to contain subtle flaws that could be exploited to break the protection the algorithm is supposed to provide.
When an attacker discovers a flaw in a custom cryptographic algorithm, they may be able to decrypt any data protected by it. Depending on the application, this could expose passwords, personal data, financial records, or other sensitive information.
This rule detects custom implementations of BasePasswordHasher subclasses for Django applications.
class CustomPasswordHasher(BasePasswordHasher): # Noncompliant
# ...
from django.contrib.auth.hashers import Argon2PasswordHasher