mirror of
https://github.com/Leseratte10/acsm-calibre-plugin
synced 2025-01-18 10:26:34 +01:00
Update some dependencies
This commit is contained in:
parent
2380177448
commit
21644b25b2
6 changed files with 82 additions and 30 deletions
1
.gitignore
vendored
1
.gitignore
vendored
|
@ -1,2 +1,3 @@
|
||||||
/calibre-plugin/*.zip
|
/calibre-plugin/*.zip
|
||||||
/calibre-plugin/keyextract/*.exe
|
/calibre-plugin/keyextract/*.exe
|
||||||
|
/calibre-plugin/module_id.txt
|
|
@ -14,6 +14,8 @@ make
|
||||||
|
|
||||||
popd
|
popd
|
||||||
|
|
||||||
|
echo -n "2021-12-15-01" > module_id.txt
|
||||||
|
|
||||||
zip -r ../calibre-plugin.zip *
|
zip -r ../calibre-plugin.zip *
|
||||||
|
|
||||||
popd
|
popd
|
||||||
|
|
|
@ -45,7 +45,7 @@ __version__ = PLUGIN_VERSION = ".".join([str(x)for x in PLUGIN_VERSION_TUPLE])
|
||||||
from calibre.utils.config import config_dir # type: ignore
|
from calibre.utils.config import config_dir # type: ignore
|
||||||
from calibre.constants import isosx, iswindows, islinux # type: ignore
|
from calibre.constants import isosx, iswindows, islinux # type: ignore
|
||||||
|
|
||||||
import os, shutil, traceback, sys, time, io
|
import os, shutil, traceback, sys, time, io, random
|
||||||
import zipfile
|
import zipfile
|
||||||
from lxml import etree
|
from lxml import etree
|
||||||
|
|
||||||
|
@ -95,32 +95,82 @@ class DeACSM(FileTypePlugin):
|
||||||
if not os.path.exists(self.moddir):
|
if not os.path.exists(self.moddir):
|
||||||
os.mkdir(self.moddir)
|
os.mkdir(self.moddir)
|
||||||
|
|
||||||
names = ["cryptography.zip", "rsa.zip", "oscrypto.zip", "asn1crypto.zip", "pyasn1.zip"]
|
# Check if we have a module id:
|
||||||
|
# Modules will only be extracted if this has changed.
|
||||||
|
# This A) saves time because we don't extract every time,
|
||||||
|
# and B) prevents a race condition.
|
||||||
|
# The compiling scripts need to be adapted to modify
|
||||||
|
# the module_id.txt in the plugin ZIP every time the
|
||||||
|
# modules change
|
||||||
|
|
||||||
lib_dict = self.load_resources(names)
|
try:
|
||||||
# print("{0} v{1}: Copying needed library files from plugin zip".format(PLUGIN_NAME, PLUGIN_VERSION))
|
ts_file = os.path.join(self.moddir, "module_id.txt")
|
||||||
|
f = open(ts_file, "r")
|
||||||
|
id = f.readline().strip()
|
||||||
|
f.close()
|
||||||
|
except:
|
||||||
|
# No timestamp found, probably upgrading from an older version.
|
||||||
|
id = None
|
||||||
|
|
||||||
for entry, data in lib_dict.items():
|
# Check ID file in the plugin ZIP
|
||||||
file_path = os.path.join(self.moddir, entry)
|
try:
|
||||||
try:
|
ts_dict = self.load_resources( ["module_id.txt"] )
|
||||||
with zipfile.ZipFile(io.BytesIO(data), 'r') as ref:
|
id_plugin = ts_dict["module_id.txt"].decode("latin-1").split('\n')[0].strip()
|
||||||
ref.extractall(self.moddir)
|
except:
|
||||||
|
# No timestamp found in the plugin ZIP?
|
||||||
|
# Assume that I made a mistake bundling the plugin, extract anyways.
|
||||||
|
id_plugin = None
|
||||||
|
|
||||||
except:
|
if id is None or id_plugin is None or id != id_plugin:
|
||||||
print("{0} v{1}: Exception when copying needed library files".format(PLUGIN_NAME, PLUGIN_VERSION))
|
print("Module update from \"{0}\" to \"{1}\", extracting ...".format(id, id_plugin))
|
||||||
traceback.print_exc()
|
# Something changed, extract modules.
|
||||||
pass
|
|
||||||
|
|
||||||
|
if os.path.exists(self.moddir):
|
||||||
|
shutil.rmtree(self.moddir, ignore_errors=True)
|
||||||
|
|
||||||
|
rand_path = self.moddir + str(random.randint(0, 1000000000))
|
||||||
|
# Generate random name so we don't get conflicts with multiple instances of the plugin running at once.
|
||||||
|
# Hack-y solution, but it should work.
|
||||||
|
|
||||||
|
os.mkdir(rand_path)
|
||||||
|
|
||||||
|
names = ["cryptography.zip", "rsa.zip", "oscrypto.zip", "asn1crypto.zip", "pyasn1.zip"]
|
||||||
|
|
||||||
if islinux:
|
|
||||||
# Also extract EXE files needed for WINE ADE key extraction
|
|
||||||
names = [ "keyextract/decrypt_win32.exe", "keyextract/decrypt_win64.exe" ]
|
|
||||||
lib_dict = self.load_resources(names)
|
lib_dict = self.load_resources(names)
|
||||||
|
|
||||||
for entry, data in lib_dict.items():
|
for entry, data in lib_dict.items():
|
||||||
file_path = os.path.join(self.moddir, entry.split('/')[1])
|
try:
|
||||||
f = open(file_path, "wb")
|
with zipfile.ZipFile(io.BytesIO(data), 'r') as ref:
|
||||||
f.write(data)
|
ref.extractall(rand_path)
|
||||||
|
|
||||||
|
except:
|
||||||
|
print("{0} v{1}: Exception when copying needed library files".format(PLUGIN_NAME, PLUGIN_VERSION))
|
||||||
|
traceback.print_exc()
|
||||||
|
pass
|
||||||
|
|
||||||
|
if islinux:
|
||||||
|
# Also extract EXE files needed for WINE ADE key extraction
|
||||||
|
names = [ "keyextract/decrypt_win32.exe", "keyextract/decrypt_win64.exe" ]
|
||||||
|
lib_dict = self.load_resources(names)
|
||||||
|
for entry, data in lib_dict.items():
|
||||||
|
file_path = os.path.join(rand_path, entry.split('/')[1])
|
||||||
|
f = open(file_path, "wb")
|
||||||
|
f.write(data)
|
||||||
|
f.close()
|
||||||
|
|
||||||
|
|
||||||
|
# Write module ID
|
||||||
|
if id_plugin is not None:
|
||||||
|
mod_file = os.path.join(rand_path, "module_id.txt")
|
||||||
|
f = open(mod_file, "w")
|
||||||
|
f.write(id_plugin)
|
||||||
f.close()
|
f.close()
|
||||||
|
|
||||||
|
|
||||||
|
# Rename temporary path to actual module path so this will be used next time.
|
||||||
|
os.rename(rand_path, self.moddir)
|
||||||
|
|
||||||
sys.path.insert(0, os.path.join(self.moddir, "cryptography"))
|
sys.path.insert(0, os.path.join(self.moddir, "cryptography"))
|
||||||
sys.path.insert(0, os.path.join(self.moddir, "rsa"))
|
sys.path.insert(0, os.path.join(self.moddir, "rsa"))
|
||||||
sys.path.insert(0, os.path.join(self.moddir, "oscrypto"))
|
sys.path.insert(0, os.path.join(self.moddir, "oscrypto"))
|
||||||
|
|
|
@ -1176,7 +1176,7 @@ class RentedBooksDialog(QDialog):
|
||||||
timestamp = datetime.datetime.strptime(book_time_stamp, "%Y-%m-%dT%H:%M:%SZ")
|
timestamp = datetime.datetime.strptime(book_time_stamp, "%Y-%m-%dT%H:%M:%SZ")
|
||||||
currenttime = datetime.datetime.utcnow()
|
currenttime = datetime.datetime.utcnow()
|
||||||
except:
|
except:
|
||||||
print("Invalid book timestamp")
|
# Invalid book timestano
|
||||||
continue
|
continue
|
||||||
|
|
||||||
|
|
||||||
|
@ -1228,8 +1228,7 @@ class RentedBooksDialog(QDialog):
|
||||||
ret, msg = tryReturnBook(Ret_book)
|
ret, msg = tryReturnBook(Ret_book)
|
||||||
|
|
||||||
if (ret):
|
if (ret):
|
||||||
print("Book successfully returned:")
|
print("Book successfully returned.")
|
||||||
print(msg)
|
|
||||||
self.delete_book_entry(nomsg=True)
|
self.delete_book_entry(nomsg=True)
|
||||||
self.populate_list()
|
self.populate_list()
|
||||||
return info_dialog(None, "Done", "Book successfully returned", show=True, show_copy_button=False)
|
return info_dialog(None, "Done", "Book successfully returned", show=True, show_copy_button=False)
|
||||||
|
|
|
@ -36,7 +36,6 @@ def download(replyData):
|
||||||
print (replyData)
|
print (replyData)
|
||||||
|
|
||||||
|
|
||||||
metadata_node = adobe_fulfill_response.find("./%s/%s/%s" % (adNS("fulfillmentResult"), adNS("resourceItemInfo"), adNS("metadata")))
|
|
||||||
download_url = adobe_fulfill_response.find("./%s/%s/%s" % (adNS("fulfillmentResult"), adNS("resourceItemInfo"), adNS("src"))).text
|
download_url = adobe_fulfill_response.find("./%s/%s/%s" % (adNS("fulfillmentResult"), adNS("resourceItemInfo"), adNS("src"))).text
|
||||||
resource_id = adobe_fulfill_response.find("./%s/%s/%s" % (adNS("fulfillmentResult"), adNS("resourceItemInfo"), adNS("resource"))).text
|
resource_id = adobe_fulfill_response.find("./%s/%s/%s" % (adNS("fulfillmentResult"), adNS("resourceItemInfo"), adNS("resource"))).text
|
||||||
license_token_node = adobe_fulfill_response.find("./%s/%s/%s" % (adNS("fulfillmentResult"), adNS("resourceItemInfo"), adNS("licenseToken")))
|
license_token_node = adobe_fulfill_response.find("./%s/%s/%s" % (adNS("fulfillmentResult"), adNS("resourceItemInfo"), adNS("licenseToken")))
|
||||||
|
@ -50,6 +49,7 @@ def download(replyData):
|
||||||
book_name = None
|
book_name = None
|
||||||
|
|
||||||
try:
|
try:
|
||||||
|
metadata_node = adobe_fulfill_response.find("./%s/%s/%s" % (adNS("fulfillmentResult"), adNS("resourceItemInfo"), adNS("metadata")))
|
||||||
book_name = metadata_node.find("./%s" % (adDC("title"))).text
|
book_name = metadata_node.find("./%s" % (adDC("title"))).text
|
||||||
except:
|
except:
|
||||||
book_name = "Book"
|
book_name = "Book"
|
||||||
|
|
|
@ -2,11 +2,11 @@
|
||||||
|
|
||||||
pushd calibre-plugin
|
pushd calibre-plugin
|
||||||
|
|
||||||
wget https://github.com/Leseratte10/acsm-calibre-plugin/releases/download/config/asn1crypto.zip -O asn1crypto.zip
|
wget https://github.com/Leseratte10/acsm-calibre-plugin/releases/download/config/asn1crypto_1.4.0.zip -O asn1crypto.zip
|
||||||
wget https://github.com/Leseratte10/acsm-calibre-plugin/releases/download/config/cryptography.zip -O cryptography.zip
|
wget https://github.com/Leseratte10/acsm-calibre-plugin/releases/download/config/cryptography_36.0.1.zip -O cryptography.zip
|
||||||
wget https://github.com/Leseratte10/acsm-calibre-plugin/releases/download/config/oscrypto.zip -O oscrypto.zip
|
wget https://github.com/Leseratte10/acsm-calibre-plugin/releases/download/config/oscrypto_1.2.1.zip -O oscrypto.zip
|
||||||
wget https://github.com/Leseratte10/acsm-calibre-plugin/releases/download/config/pyasn1.zip -O pyasn1.zip
|
wget https://github.com/Leseratte10/acsm-calibre-plugin/releases/download/config/pyasn1_0.4.8.zip -O pyasn1.zip
|
||||||
wget https://github.com/Leseratte10/acsm-calibre-plugin/releases/download/config/rsa.zip -O rsa.zip
|
wget https://github.com/Leseratte10/acsm-calibre-plugin/releases/download/config/rsa_4.8.zip -O rsa.zip
|
||||||
|
|
||||||
popd
|
popd
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue