URI: 
       tcrypto: fix pkcs7 padding check - electrum - Electrum Bitcoin wallet
  HTML git clone https://git.parazyd.org/electrum
   DIR Log
   DIR Files
   DIR Refs
   DIR Submodules
       ---
   DIR commit f04e5fbed6a572bb68482f757d76332918df2070
   DIR parent a8e6eaa247a7a21cba1d23bf72ae9799cbc0cd73
  HTML Author: SomberNight <somber.night@protonmail.com>
       Date:   Thu, 22 Nov 2018 18:21:19 +0100
       
       crypto: fix pkcs7 padding check
       
       related: ricmoo/pyaes#22
       
       in practice, the only strings we would incorrectly accept are
       (certain length of) all zero bytes
       
       Diffstat:
         M electrum/crypto.py                  |       4 ++--
       
       1 file changed, 2 insertions(+), 2 deletions(-)
       ---
   DIR diff --git a/electrum/crypto.py b/electrum/crypto.py
       t@@ -55,8 +55,8 @@ def strip_PKCS7_padding(data: bytes) -> bytes:
            if len(data) % 16 != 0 or len(data) == 0:
                raise InvalidPadding("invalid length")
            padlen = data[-1]
       -    if padlen > 16:
       -        raise InvalidPadding("invalid padding byte (large)")
       +    if not (0 < padlen <= 16):
       +        raise InvalidPadding("invalid padding byte (out of range)")
            for i in data[-padlen:]:
                if i != padlen:
                    raise InvalidPadding("invalid padding byte (inconsistent)")