aboutsummaryrefslogtreecommitdiffstats
path: root/docs/hazmat
diff options
context:
space:
mode:
authorAlex Gaynor <alex.gaynor@gmail.com>2014-01-27 11:05:29 -0800
committerAlex Gaynor <alex.gaynor@gmail.com>2014-01-27 11:05:29 -0800
commitb2774f53bc5840ae7c414ee78bef654a2ae89f01 (patch)
tree6fdba6fac20984321a0269d3edb165f076bfbf1f /docs/hazmat
parent6b4f32311e038a60ed496e2f44558b8803f9e033 (diff)
downloadcryptography-b2774f53bc5840ae7c414ee78bef654a2ae89f01.tar.gz
cryptography-b2774f53bc5840ae7c414ee78bef654a2ae89f01.tar.bz2
cryptography-b2774f53bc5840ae7c414ee78bef654a2ae89f01.zip
Begin designing the KDF interfaces. Fixes #511
Diffstat (limited to 'docs/hazmat')
-rw-r--r--docs/hazmat/primitives/interfaces.rst30
1 files changed, 30 insertions, 0 deletions
diff --git a/docs/hazmat/primitives/interfaces.rst b/docs/hazmat/primitives/interfaces.rst
index bf78e367..ac48dd2c 100644
--- a/docs/hazmat/primitives/interfaces.rst
+++ b/docs/hazmat/primitives/interfaces.rst
@@ -204,4 +204,34 @@ Asymmetric Interfaces
The public exponent. Alias for :attr:`public_exponent`.
+Key Derivation Functions
+~~~~~~~~~~~~~~~~~~~~~~~~
+
+.. class:: KeyDerivationFunction
+
+ .. method:: derive(key_material)
+
+ :param key_material bytes: The raw key material. Depending on what key
+ derivation function you are using this could
+ be either random material, or a user
+ supplied password.
+ :return: The resulting key.
+
+ The generates and returns a new key from the supplied key material.
+
+ .. method:: verify(key_material, expected_key)
+
+ :param key_material bytes: The raw key material. This is the same as
+ ``key_material`` in :meth:`derive`.
+ :param expected_key bytes: What the expected result of deriving a new
+ key is.
+ :raises cryptography.exceptions.InvalidKey: This is raised when the
+ derived key does not match
+ the expected key.
+
+ This checks whether deriving a key from the supplied ``key_material``
+ generates the same key as the ``expected_key``, and raises an exception
+ if they do not match. This can be used for something like checking
+ whether a user's password attempt matches the stored derived key.
+
.. _`RSA`: http://en.wikipedia.org/wiki/RSA_(cryptosystem)