From 23a1b4c0488bd38e03a48120dfda98913f4c87d2 Mon Sep 17 00:00:00 2001 From: Richard Moore Date: Wed, 20 Sep 2017 17:08:24 -0400 Subject: [PATCH] Fixed Blockfeeder incorrectly accepted empty string as input termiations (Issue 15). --- pyaes/blockfeeder.py | 2 +- setup.py | 2 +- tests/test-blockfeeder.py | 33 +++++++++++++++++++++++++++++++++ 3 files changed, 35 insertions(+), 2 deletions(-) diff --git a/pyaes/blockfeeder.py b/pyaes/blockfeeder.py index f4113c3..b9a904d 100644 --- a/pyaes/blockfeeder.py +++ b/pyaes/blockfeeder.py @@ -165,7 +165,7 @@ def feed(self, data = None): raise ValueError('already finished feeder') # Finalize; process the spare bytes we were keeping - if not data: + if data is None: result = self._final(self._buffer, self._padding) self._buffer = None return result diff --git a/setup.py b/setup.py index 884701d..8fd556b 100644 --- a/setup.py +++ b/setup.py @@ -8,7 +8,7 @@ for API reference and details.''' setup(name = 'pyaes', - version = '1.6.0', + version = '1.6.1', description = 'Pure-Python Implementation of the AES block-cipher and common modes of operation', long_description = LONG_DESCRIPTION, author = 'Richard Moore', diff --git a/tests/test-blockfeeder.py b/tests/test-blockfeeder.py index 41bd487..f88f259 100644 --- a/tests/test-blockfeeder.py +++ b/tests/test-blockfeeder.py @@ -146,3 +146,36 @@ passed = decrypted == plaintext cipher_length = len(ciphertext) print(" cipher-length=%(cipher_length)s passed=%(passed)s" % locals()) + +# Issue #15 +# https://github.com/ricmoo/pyaes/issues/15 +# @TODO: These tests need a severe overhaul; they should use deterministic input, keys and IVs... +def TestIssue15(): + print('Issue #15') + + key = b"abcdefghijklmnop" + iv = b"0123456789012345" + encrypter = pyaes.Encrypter(pyaes.AESModeOfOperationCBC(key, iv)) + + plaintext = b"Hello World!!!!!" + + ciphertext = to_bufferable('') + + ciphertext += encrypter.feed(plaintext) + ciphertext += encrypter.feed('') + ciphertext += encrypter.feed(plaintext) + ciphertext += encrypter.feed(None) + expected = b'(Ob\xe5\xae"\xdc\xb0\x84\xc5\x04\x04GQ\xd8.\x0e4\xd2b\xc1\x15\xe5\x11M\xfc\x9a\xd2\xd5\xc8xP\x00[\xd57\x92\x01\xbb\xc42\x18\xbc\xbf\x1ay\x19P' + + decrypter = pyaes.Decrypter(pyaes.AESModeOfOperationCBC(key, iv)) + + output = to_bufferable('') + + output += decrypter.feed('') + output += decrypter.feed(ciphertext) + output += decrypter.feed('') + output += decrypter.feed(None) + + print(" passed=%(passed)s" % dict(passed = (ciphertext == expected and output == (plaintext + plaintext)))) + +TestIssue15()