mirror of
https://github.com/noDRM/DeDRM_tools
synced 2024-11-16 19:48:10 +01:00
DeDRM ion: Correctly throw last exception if decrypt fails
This commit is contained in:
parent
195ea69537
commit
34c4c067e8
1 changed files with 4 additions and 2 deletions
|
@ -13,6 +13,7 @@ Revision history:
|
|||
|
||||
Copyright © 2013-2020 Apprentice Harper et al.
|
||||
"""
|
||||
from __future__ import annotations
|
||||
|
||||
import collections
|
||||
import hashlib
|
||||
|
@ -1345,7 +1346,7 @@ class DrmIonVoucher(object):
|
|||
process_V4648(shared), process_V5683(shared)]
|
||||
|
||||
decrypted=False
|
||||
ex=None
|
||||
lastexception: Exception | None = None
|
||||
for sharedsecret in sharedsecrets:
|
||||
key = hmac.new(sharedsecret, b"PIDv3", digestmod=hashlib.sha256).digest()
|
||||
aes = AES.new(key[:32], AES.MODE_CBC, self.cipheriv[:16])
|
||||
|
@ -1362,9 +1363,10 @@ class DrmIonVoucher(object):
|
|||
print("Decryption succeeded")
|
||||
break
|
||||
except Exception as ex:
|
||||
lastexception = ex
|
||||
print("Decryption failed, trying next fallback ")
|
||||
if not decrypted:
|
||||
raise ex
|
||||
raise lastexception
|
||||
|
||||
self.drmkey.stepin()
|
||||
while self.drmkey.hasnext():
|
||||
|
|
Loading…
Reference in a new issue