diff options
author | Alex Gaynor <alex.gaynor@gmail.com> | 2013-11-01 13:52:44 -0700 |
---|---|---|
committer | Alex Gaynor <alex.gaynor@gmail.com> | 2013-11-01 13:52:44 -0700 |
commit | ce46b89eed2d3a35043910c62f711690cb69c393 (patch) | |
tree | d882be5299a64554c7e64644d5c40560c3e72c67 /docs | |
parent | c94cdbca7f48095ddbaf15612c7b119b3ca26f73 (diff) | |
parent | 5560298b42f071db0bf7ea46c63ff52603370b38 (diff) | |
download | cryptography-ce46b89eed2d3a35043910c62f711690cb69c393.tar.gz cryptography-ce46b89eed2d3a35043910c62f711690cb69c393.tar.bz2 cryptography-ce46b89eed2d3a35043910c62f711690cb69c393.zip |
Merge pull request #200 from dreid/primitive-hashes
[WIP] Reduce the surface of the primitive hash interface.
Diffstat (limited to 'docs')
-rw-r--r-- | docs/hazmat/primitives/cryptographic-hashes.rst | 28 |
1 files changed, 17 insertions, 11 deletions
diff --git a/docs/hazmat/primitives/cryptographic-hashes.rst b/docs/hazmat/primitives/cryptographic-hashes.rst index c780dcb0..a939998d 100644 --- a/docs/hazmat/primitives/cryptographic-hashes.rst +++ b/docs/hazmat/primitives/cryptographic-hashes.rst @@ -5,21 +5,27 @@ Message Digests .. currentmodule:: cryptography.hazmat.primitives.hashes -.. class:: BaseHash(data=None) +.. class:: Hash(algorithm) - Abstract base class that implements a common interface for all hash - algorithms that follow here. + A cryptographic hash function takes an arbitrary block of data and + calculates a fixed-size bit string (a digest), such that different data + results (with a high probability) in different digests. - If ``data`` is provided ``update(data)`` is called upon construction. + This is an implementation of + :class:`cryptography.hazmat.primitives.interfaces.HashContext` meant to + be used with + :class:`cryptography.hazmat.primitives.interfaces.HashAlgorithm` + implementations to provide an incremental interface to calculating + various message digests. .. doctest:: >>> from cryptography.hazmat.primitives import hashes - >>> digest = hashes.SHA256() + >>> digest = hashes.Hash(hashes.SHA256()) >>> digest.update(b"abc") >>> digest.update(b"123") - >>> digest.hexdigest() - '6ca13d52ca70c883e0f0bb101e425a89e8624de51db2d2392593af6a84118090' + >>> digest.finalize() + 'l\xa1=R\xcap\xc8\x83\xe0\xf0\xbb\x10\x1eBZ\x89\xe8bM\xe5\x1d\xb2\xd29%\x93\xafj\x84\x11\x80\x90' .. method:: update(data) @@ -29,13 +35,13 @@ Message Digests :return: a new instance of this object with a copied internal state. - .. method:: digest() + .. method:: finalize() + Finalize the current context and return the message digest as bytes. - :return bytes: The message digest as bytes. + Once ``finalize`` is called this object can no longer be used. - .. method:: hexdigest() + :return bytes: The message digest as bytes. - :return str: The message digest as hex. SHA-1 ~~~~~ |