diff options
author | Paul Kehrer <paul.l.kehrer@gmail.com> | 2015-08-30 11:48:56 -0500 |
---|---|---|
committer | Paul Kehrer <paul.l.kehrer@gmail.com> | 2015-08-30 11:48:56 -0500 |
commit | f3e8aae5c001e643ec46ec8a55aa1c5c1ac097ae (patch) | |
tree | a1e2b24804981e93720839703152868b09ec3320 /docs/fernet.rst | |
parent | 0a2c818366d5d7fe3b69f2d79e2a27438d79bd28 (diff) | |
parent | 69382a045a1647a78ab8a6a00d95ea85c9f93147 (diff) | |
download | cryptography-f3e8aae5c001e643ec46ec8a55aa1c5c1ac097ae.tar.gz cryptography-f3e8aae5c001e643ec46ec8a55aa1c5c1ac097ae.tar.bz2 cryptography-f3e8aae5c001e643ec46ec8a55aa1c5c1ac097ae.zip |
Merge pull request #2304 from Ayrx/fernet-docs-kdf
Add some text regarding using passwords with Fernet.
Diffstat (limited to 'docs/fernet.rst')
-rw-r--r-- | docs/fernet.rst | 40 |
1 files changed, 40 insertions, 0 deletions
diff --git a/docs/fernet.rst b/docs/fernet.rst index 8ea33eef..a066ae63 100644 --- a/docs/fernet.rst +++ b/docs/fernet.rst @@ -106,6 +106,45 @@ has support for implementing key rotation via :class:`MultiFernet`. See :meth:`Fernet.decrypt` for more information. + +Using passwords with Fernet +--------------------------- + +It is possible to use passwords with Fernet. To do this, you need to run the +password through a key derivation function such as +:class:`~cryptography.hazmat.primitives.kdf.pbkdf2.PBKDF2HMAC`, bcrypt or +scrypt. + +.. code-block:: python + + import base64 + import os + + from cryptography.fernet import Fernet + from cryptography.hazmat.backends import default_backend + from cryptography.hazmat.primitives import hashes + from cryptography.hazmat.primitives.kdf.pbkdf2 import PBKDF2HMAC + + password = b"password" + salt = os.urandom(16) + + kdf = PBKDF2HMAC( + algorithm=hashes.SHA256(), + length=32, + salt=salt, + iterations=100000, + backend=default_backend + ) + key = base64.urlsafe_b64encode(kdf.derive(password)) + f = Fernet(key) + +In this scheme, the salt has to be stored in a retrievable location in order +to derive the same key from the password in the future. + +The iteration count used should be adjusted to be as high as your server can +tolerate. A good default is at least 100,000 iterations which is what Django +`recommends`_ in 2014. + Implementation -------------- @@ -125,3 +164,4 @@ For complete details consult the `specification`_. .. _`Fernet`: https://github.com/fernet/spec/ .. _`specification`: https://github.com/fernet/spec/blob/master/Spec.md +.. _`recommends`: https://github.com/django/django/blob/master/django/utils/crypto.py#L148 |