python-peps/pep-0247.txt

103 lines
3.0 KiB
Plaintext
Raw Normal View History

2001-03-27 12:42:59 -05:00
PEP: 247
Title: API for Cryptographic Hash Functions
Version: $Revision$
2001-03-28 15:18:03 -05:00
Author: amk1@bigfoot.com (A.M. Kuchling)
Status: Draft
2001-03-27 12:42:59 -05:00
Type: Informational
Created: 23-Mar-2001
Post-History:
Abstract
2001-03-28 15:18:03 -05:00
There are several different modules available that implement
cryptographic hashing algorithms such as MD5 or SHA. This
document specifies a standard API for such algorithms, to make it
easier to switch between different implementations.
2001-03-27 12:42:59 -05:00
Specification
2001-03-28 15:18:03 -05:00
All hashing modules should present the same interface. Additional
methods or variables can be added, but those described in this
document should always be present.
2001-03-27 12:42:59 -05:00
2001-03-28 15:18:03 -05:00
Hash function modules define one function:
2001-03-27 12:42:59 -05:00
2001-03-28 15:18:03 -05:00
new([string], [key])
2001-03-27 12:42:59 -05:00
2001-03-28 15:18:03 -05:00
Create a new hashing object and return it. You can now feed
arbitrary strings into the object using its update() method,
and can ask for the hash value at any time by calling its
digest() method.
2001-03-27 12:42:59 -05:00
2001-03-28 15:18:03 -05:00
The 'string' parameter, if supplied, will be immediately hashed
into the object's starting state. For keyed hashes such as
HMAC, 'key' is a string containing the starting key.
2001-03-27 12:42:59 -05:00
2001-03-28 15:18:03 -05:00
Hash function modules define one variable:
2001-03-27 12:42:59 -05:00
2001-03-28 15:18:03 -05:00
digest_size
2001-03-27 12:42:59 -05:00
2001-03-28 15:18:03 -05:00
An integer value; the size of the digest produced by the
hashing objects, measured in bytes. You could also obtain
this value by creating a sample object, and taking the length
of the digest string it returns, but using digest_size is
faster.
2001-03-27 12:42:59 -05:00
2001-03-28 15:18:03 -05:00
The methods for hashing objects are always the following:
2001-03-27 12:42:59 -05:00
2001-03-28 15:18:03 -05:00
clear()
2001-03-27 12:42:59 -05:00
2001-03-28 15:18:03 -05:00
Reset this hashing object to its initial state, as if the
object was created from new(key=<initially specified key>)
(XXX what should this do for a keyed hash? A proposed
semantic follows:). There is no way to supply a starting
string as there is for the new() function, and there's no way
to change the key specified for a keyed hash.
2001-03-27 12:42:59 -05:00
2001-03-28 15:18:03 -05:00
copy()
2001-03-27 12:42:59 -05:00
2001-03-28 15:18:03 -05:00
Return a separate copy of this hashing object. An update to
this copy won't affect the original object.
2001-03-27 12:42:59 -05:00
2001-03-28 15:18:03 -05:00
digest()
2001-03-27 12:42:59 -05:00
2001-03-28 15:18:03 -05:00
Return the hash value of this hashing object, as a string
containing 8-bit data. The object is not altered in any way
by this function; you can continue updating the object after
calling this function.
2001-03-27 12:42:59 -05:00
2001-03-28 15:18:03 -05:00
update(arg)
2001-03-27 12:42:59 -05:00
2001-03-28 15:18:03 -05:00
Update this hashing object with the string arg.
2001-03-27 12:42:59 -05:00
2001-03-28 15:18:03 -05:00
For convenience, hashing objects also have a digest_size
attribute, measuring the size of the resulting digest in bytes.
This is identical to the module-level digest_size variable.
2001-03-27 12:42:59 -05:00
2001-03-28 15:18:03 -05:00
Here's an example, using a module named 'MD5':
2001-03-27 12:42:59 -05:00
2001-03-28 15:18:03 -05:00
>>> from Crypto.Hash import MD5
>>> m = MD5.new()
>>> m.update('abc')
>>> m.digest()
'\220\001P\230<\322O\260\326\226?@}(\341\177r'
2001-03-27 12:42:59 -05:00
2001-03-28 15:18:03 -05:00
Or, more compactly:
>>> MD5.new('abc').digest()
'\220\001P\230<\322O\260\326\226?@}(\341\177r'
2001-03-27 12:42:59 -05:00
Copyright
This document has been placed in the public domain.
Local Variables:
mode: indented-text
indent-tabs-mode: nil
End: