[Python-checkins] r53159 - python/trunk/Lib/hmac.py

andrew.kuchling python-checkins at python.org
Wed Dec 27 04:25:32 CET 2006


Author: andrew.kuchling
Date: Wed Dec 27 04:25:31 2006
New Revision: 53159

Modified:
   python/trunk/Lib/hmac.py
Log:
[Part of patch #1182394] Move the HMAC blocksize to be a class-level 
constant; this allows changing it in a subclass.  To accommodate this,
copy() now uses __class__.  Also add some text to a comment.


Modified: python/trunk/Lib/hmac.py
==============================================================================
--- python/trunk/Lib/hmac.py	(original)
+++ python/trunk/Lib/hmac.py	Wed Dec 27 04:25:31 2006
@@ -7,7 +7,7 @@
 trans_36 = "".join ([chr (x ^ 0x36) for x in xrange(256)])
 
 # The size of the digests returned by HMAC depends on the underlying
-# hashing module used.
+# hashing module used.  Use digest_size from the instance of HMAC instead.
 digest_size = None
 
 # A unique object passed by HMAC.copy() to the HMAC constructor, in order
@@ -20,6 +20,7 @@
 
     This supports the API for Cryptographic Hash Functions (PEP 247).
     """
+    blocksize = 64  # 512-bit HMAC; can be changed in subclasses.
 
     def __init__(self, key, msg = None, digestmod = None):
         """Create a new HMAC object.
@@ -47,7 +48,7 @@
         self.inner = self.digest_cons()
         self.digest_size = self.inner.digest_size
 
-        blocksize = 64
+        blocksize = self.blocksize
         if len(key) > blocksize:
             key = self.digest_cons(key).digest()
 
@@ -70,7 +71,7 @@
 
         An update to this copy won't affect the original object.
         """
-        other = HMAC(_secret_backdoor_key)
+        other = self.__class__(_secret_backdoor_key)
         other.digest_cons = self.digest_cons
         other.digest_size = self.digest_size
         other.inner = self.inner.copy()


More information about the Python-checkins mailing list