From 2fbf2c1c5f52fcd872fa4c1140d74239cf0aaa0f Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?R=C3=A9mi=20Vanicat?= Date: Fri, 8 May 2020 17:51:40 +0200 Subject: [PATCH] decoding from base64 in a portable way --- DeDRM_plugin/ineptepub.py | 7 +++++-- 1 file changed, 5 insertions(+), 2 deletions(-) diff --git a/DeDRM_plugin/ineptepub.py b/DeDRM_plugin/ineptepub.py index 6d48905..e3815e7 100644 --- a/DeDRM_plugin/ineptepub.py +++ b/DeDRM_plugin/ineptepub.py @@ -63,6 +63,7 @@ import zipfile from zipfile import ZipInfo, ZipFile, ZIP_STORED, ZIP_DEFLATED from contextlib import closing import xml.etree.ElementTree as etree +import base64 # Wrap a stream so that output gets flushed immediately # and also make sure that any unicode strings get @@ -421,9 +422,11 @@ def decryptBook(userkey, inpath, outpath): if len(bookkey) != 172: print(u"{0:s} is not a secure Adobe Adept ePub.".format(os.path.basename(inpath))) return 1 - bookkey = rsa.decrypt(bookkey.decode('base64')) + bookkey = bookkey.encode('ascii') + bookkey = base64.b64decode(bookkey) + bookkey = rsa.decrypt(bookkey) # Padded as per RSAES-PKCS1-v1_5 - if bookkey[-17] != '\x00': + if bookkey[-17] != '\x00' and bookkey[-17] != 0: print(u"Could not decrypt {0:s}. Wrong key".format(os.path.basename(inpath))) return 2 encryption = inf.read('META-INF/encryption.xml')