Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/ubernostrum/pwned-passwords-django

Utilities for working with the Pwned Passwords database from Django.
https://github.com/ubernostrum/pwned-passwords-django

django password-strength passwords pwned-passwords python security

Last synced: 5 days ago
JSON representation

Utilities for working with the Pwned Passwords database from Django.

Awesome Lists containing this project

README

        

.. -*-restructuredtext-*-

.. image:: https://github.com/ubernostrum/pwned-passwords-django/workflows/CI/badge.svg
:alt: CI status image
:target: https://github.com/ubernostrum/pwned-passwords-django/actions?query=workflow%3ACI

``pwned-passwords-django`` provides helpers for working with the
`Pwned Passwords database from Have I Been Pwned
`_ in `Django
`_ powered sites. Pwned Passwords is
an extremely large database of passwords known to have been
compromised through data breaches, and is useful as a tool for
rejecting common or weak passwords.

There are three main components to this application:

* `A password validator
`_
which integrates with `Django's password-validation tools
`_
and checks the Pwned Passwords database.

* `A Django middleware
`_
(supporting both sync and async requests) which automatically checks
certain request payloads against the Pwned Passwords database.

* `An API client
`_
providing direct access (both sync and async) to the Pwned Passwords
database.

All three use a secure, anonymized API which `never transmits any
password or its full hash to any third party
`_.

Usage
-----

The recommended configuration is to enable both the validator and the
automatic password-checking middleware. To do this, make the following
changes to your Django settings.

First, add the validator to your AUTH_PASSWORD_VALIDATORS list:

.. code-block:: python

AUTH_PASSWORD_VALIDATORS = [
# ... other password validators ...
{
"NAME": "pwned_passwords_django.validators.PwnedPasswordsValidator",
},
]

Then, add the middleware to your MIDDLEWARE list:

.. code-block:: python

MIDDLEWARE = [
# .. other middlewares ...
"pwned_passwords_django.middleware.pwned_passwords_middleware",
]

For more details, consult `the full documentation
`_.