From 87630e2bd40371c68a21c632162d255d32fc1c20 Mon Sep 17 00:00:00 2001 From: Paul Durrant Date: Sat, 26 Jul 2008 07:30:20 +0100 Subject: [PATCH] More attempted fixes from Paul --- Kindle_Mobi_Tools/lib/mobidedrm.py | 19 ++++++++++++------- 1 file changed, 12 insertions(+), 7 deletions(-) diff --git a/Kindle_Mobi_Tools/lib/mobidedrm.py b/Kindle_Mobi_Tools/lib/mobidedrm.py index 8660bce..3f46e77 100644 --- a/Kindle_Mobi_Tools/lib/mobidedrm.py +++ b/Kindle_Mobi_Tools/lib/mobidedrm.py @@ -5,6 +5,7 @@ # 0.01 - Initial version # 0.02 - Huffdic compressed books were not properly decrypted # 0.03 - fix 0.02 to work with all Mobipocket eBooks +# 0.04 - Wasn't checking MOBI header length import sys,struct,binascii @@ -72,10 +73,10 @@ def getSizeOfTrailingDataEntries(ptr, size, flags): return result num = 0 flags >>= 1 -# while flags: - if flags & 1: - num += getSizeOfTrailingDataEntry(ptr, size - num) - flags >>= 1 + while flags: + if flags & 1: + num += getSizeOfTrailingDataEntry(ptr, size - num) + flags >>= 1 return num @@ -136,7 +137,11 @@ class DrmStripper: sect = self.loadSection(0) records, = struct.unpack('>H', sect[0x8:0x8+2]) - extra_data_flags, = struct.unpack('>L', sect[0xF0:0xF4]) + mobi_length, = struct.unpack('>L',sect[0x14:0x18]) + extra_data_flags = 0 + if mobi_length >= 0xE4: + extra_data_flags, = struct.unpack('>L', sect[0xF0:0xF4]) + crypto_type, = struct.unpack('>H', sect[0xC:0xC+2]) if crypto_type != 2: @@ -165,7 +170,7 @@ class DrmStripper: def getResult(self): return self.data_file -print "MobiDeDrm v0.03. Copyright (c) 2008 The Dark Reverser" +print "MobiDeDrm v0.04. Copyright (c) 2008 The Dark Reverser" if len(sys.argv)<4: print "Removes protection from Mobipocket books" print "Usage:" @@ -178,4 +183,4 @@ else: try: file(outfile, 'wb').write(DrmStripper(data_file, pid).getResult()) except DrmException, e: - print "Error: %s" % e + print "Error: %s" % e \ No newline at end of file