mirror of
https://github.com/Leseratte10/acsm-calibre-plugin
synced 2025-01-18 10:26:34 +01:00
Add more comments, improve hashing code
This commit is contained in:
parent
f453dd7391
commit
e1c8af47eb
1 changed files with 33 additions and 6 deletions
|
@ -47,9 +47,14 @@ VAR_VER_SUPP_VERSIONS = [ "ADE WIN 9,0,1131,27", "2.0.1.78765", "3.0.1.91394", "
|
||||||
VAR_VER_HOBBES_VERSIONS = [ "9.0.1131.27", "9.3.58046", "10.0.85385", "12.0.123217", "12.5.4.186049", "12.5.4.187298" ]
|
VAR_VER_HOBBES_VERSIONS = [ "9.0.1131.27", "9.3.58046", "10.0.85385", "12.0.123217", "12.5.4.186049", "12.5.4.187298" ]
|
||||||
VAR_VER_OS_IDENTIFIERS = [ "Windows Vista", "Windows Vista", "Windows 8", "Windows 8", "Windows 8", "Windows 8" ]
|
VAR_VER_OS_IDENTIFIERS = [ "Windows Vista", "Windows Vista", "Windows 8", "Windows 8", "Windows 8", "Windows 8" ]
|
||||||
|
|
||||||
|
|
||||||
|
# "Missing" versions:
|
||||||
|
# 1.7.1, 2.0, 3.0, 4.0, 4.0.1, 4.0.2, 4.5 to 4.5.9
|
||||||
|
|
||||||
# This is a list of ALL versions we know (and can potentially use if present in a config file).
|
# This is a list of ALL versions we know (and can potentially use if present in a config file).
|
||||||
# Must have the same length / size as the four lists above.
|
# Must have the same length / size as the four lists above.
|
||||||
VAR_VER_BUILD_IDS = [ 1131, 78765, 91394, 123281, 186048, 187303 ]
|
VAR_VER_BUILD_IDS = [ 1131, 78765, 91394, 123281, 186048, 187303 ]
|
||||||
|
# Build ID 185749 also exists, that's a different (older) variant of 4.5.10.
|
||||||
|
|
||||||
# This is a list of versions that can be used for new authorizations:
|
# This is a list of versions that can be used for new authorizations:
|
||||||
VAR_VER_ALLOWED_BUILD_IDS_AUTHORIZE = [ 78765, 91394, 123281, 187303 ]
|
VAR_VER_ALLOWED_BUILD_IDS_AUTHORIZE = [ 78765, 91394, 123281, 187303 ]
|
||||||
|
@ -58,6 +63,7 @@ VAR_VER_ALLOWED_BUILD_IDS_AUTHORIZE = [ 78765, 91394, 123281, 187303 ]
|
||||||
VAR_VER_ALLOWED_BUILD_IDS_SWITCH_TO = [ 1131, 78765, 91394, 123281, 187303 ]
|
VAR_VER_ALLOWED_BUILD_IDS_SWITCH_TO = [ 1131, 78765, 91394, 123281, 187303 ]
|
||||||
|
|
||||||
# Versions >= this one are using HTTPS
|
# Versions >= this one are using HTTPS
|
||||||
|
# According to changelogs, this is implemented as of ADE 4.0.1 - no idea what build ID that is.
|
||||||
VAR_VER_NEED_HTTPS_BUILD_ID_LIMIT = 123281
|
VAR_VER_NEED_HTTPS_BUILD_ID_LIMIT = 123281
|
||||||
|
|
||||||
# Default build ID to use - ADE 2.0.1
|
# Default build ID to use - ADE 2.0.1
|
||||||
|
@ -181,6 +187,7 @@ def sendHTTPRequest_DL2FILE(URL: str, outputfile: str):
|
||||||
headers = {
|
headers = {
|
||||||
"Accept": "*/*",
|
"Accept": "*/*",
|
||||||
"User-Agent": "book2png",
|
"User-Agent": "book2png",
|
||||||
|
# MacOS uses different User-Agent. Good thing we're emulating a Windows client.
|
||||||
}
|
}
|
||||||
req = urllib.request.Request(url=URL, headers=headers)
|
req = urllib.request.Request(url=URL, headers=headers)
|
||||||
handler = urllib.request.urlopen(req)
|
handler = urllib.request.urlopen(req)
|
||||||
|
@ -216,6 +223,7 @@ def sendHTTPRequest_getSimple(URL: str):
|
||||||
headers = {
|
headers = {
|
||||||
"Accept": "*/*",
|
"Accept": "*/*",
|
||||||
"User-Agent": "book2png",
|
"User-Agent": "book2png",
|
||||||
|
# MacOS uses different User-Agent. Good thing we're emulating a Windows client.
|
||||||
}
|
}
|
||||||
|
|
||||||
# Ignore SSL:
|
# Ignore SSL:
|
||||||
|
@ -247,6 +255,7 @@ def sendPOSTHTTPRequest(URL: str, document: bytes, type: str, returnRC = False):
|
||||||
headers = {
|
headers = {
|
||||||
"Accept": "*/*",
|
"Accept": "*/*",
|
||||||
"User-Agent": "book2png",
|
"User-Agent": "book2png",
|
||||||
|
# MacOS uses different User-Agent. Good thing we're emulating a Windows client.
|
||||||
"Content-Type": type
|
"Content-Type": type
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -434,11 +443,19 @@ def hash_node_ctx(node, hash_ctx):
|
||||||
|
|
||||||
qtag = etree.QName(node.tag)
|
qtag = etree.QName(node.tag)
|
||||||
|
|
||||||
if (qtag.localname == "hmac"):
|
if (qtag.localname == "hmac" or qtag.localname == "signature"):
|
||||||
return
|
if (qtag.namespace == "http://ns.adobe.com/adept"):
|
||||||
|
# Adobe HMAC and signature are not hashed
|
||||||
|
return
|
||||||
|
else:
|
||||||
|
print("Warning: Found hmac or signature node in unexpected namespace " + qtag.namespace)
|
||||||
|
|
||||||
hash_do_append_tag(hash_ctx, ASN_NS_TAG)
|
hash_do_append_tag(hash_ctx, ASN_NS_TAG)
|
||||||
hash_do_append_string(hash_ctx, qtag.namespace)
|
|
||||||
|
if qtag.namespace is None:
|
||||||
|
hash_do_append_string(hash_ctx, "")
|
||||||
|
else:
|
||||||
|
hash_do_append_string(hash_ctx, qtag.namespace)
|
||||||
hash_do_append_string(hash_ctx, qtag.localname)
|
hash_do_append_string(hash_ctx, qtag.localname)
|
||||||
|
|
||||||
|
|
||||||
|
@ -454,10 +471,17 @@ def hash_node_ctx(node, hash_ctx):
|
||||||
for attribute in attrKeys:
|
for attribute in attrKeys:
|
||||||
# Hash all the attributes
|
# Hash all the attributes
|
||||||
hash_do_append_tag(hash_ctx, ASN_ATTRIBUTE)
|
hash_do_append_tag(hash_ctx, ASN_ATTRIBUTE)
|
||||||
hash_do_append_string(hash_ctx, "") # TODO: "Element namespace"? Whatever that means...
|
|
||||||
hash_do_append_string(hash_ctx, attribute)
|
|
||||||
hash_do_append_string(hash_ctx, node.get(attribute))
|
|
||||||
|
|
||||||
|
# Check for element namespace and hash that, if present:
|
||||||
|
q_attribute = etree.QName(attribute)
|
||||||
|
|
||||||
|
# Hash element namespace (usually "")
|
||||||
|
# If namespace is none, use "". Else, use namespace.
|
||||||
|
hash_do_append_string(hash_ctx, "" if q_attribute.namespace is None else q_attribute.namespace)
|
||||||
|
|
||||||
|
# Hash (local) name and value
|
||||||
|
hash_do_append_string(hash_ctx, q_attribute.localname)
|
||||||
|
hash_do_append_string(hash_ctx, node.get(attribute))
|
||||||
|
|
||||||
hash_do_append_tag(hash_ctx, ASN_CHILD)
|
hash_do_append_tag(hash_ctx, ASN_CHILD)
|
||||||
|
|
||||||
|
@ -480,6 +504,9 @@ def hash_node_ctx(node, hash_ctx):
|
||||||
while True:
|
while True:
|
||||||
remaining = textlen - done
|
remaining = textlen - done
|
||||||
if remaining > 0x7fff:
|
if remaining > 0x7fff:
|
||||||
|
print("Warning: Hashing text node larger than 32k.")
|
||||||
|
print("This usually doesn't happen, and I'm not sure if this is implemented correctly.")
|
||||||
|
print("If you run into issues, please open a bug report.")
|
||||||
remaining = 0x7fff
|
remaining = 0x7fff
|
||||||
|
|
||||||
hash_do_append_tag(hash_ctx, ASN_TEXT)
|
hash_do_append_tag(hash_ctx, ASN_TEXT)
|
||||||
|
|
Loading…
Reference in a new issue