mirror of
https://github.com/Leseratte10/acsm-calibre-plugin.git
synced 2024-12-23 01:34:36 +06:00
111 lines
3.0 KiB
Python
111 lines
3.0 KiB
Python
#!/usr/bin/env python3
|
|
# -*- coding: utf-8 -*-
|
|
|
|
'''
|
|
Copyright (c) 2021-2023 Leseratte10
|
|
This file is part of the ACSM Input Plugin by Leseratte10
|
|
ACSM Input Plugin for Calibre / acsm-calibre-plugin
|
|
|
|
For more information, see:
|
|
https://github.com/Leseratte10/acsm-calibre-plugin
|
|
'''
|
|
|
|
'''
|
|
Run this tool to download the eBook DER encryption key
|
|
for a given ADE account from the Adobe server.
|
|
|
|
I am not responsible if Adobe does ban your Account for using
|
|
nonstandard software, though in all my previous tests that has
|
|
never happened.
|
|
|
|
Though I would suggest not running this script multiple times -
|
|
just run it once and then make enough backups of the key file.
|
|
|
|
'''
|
|
|
|
import sys, getpass, tempfile
|
|
|
|
if sys.version_info[0] < 3:
|
|
print("This script requires Python 3.")
|
|
exit(1)
|
|
|
|
from libadobe import createDeviceKeyFile, update_account_path, VAR_VER_SUPP_CONFIG_NAMES
|
|
from libadobeAccount import createDeviceFile, createUser, signIn, exportAccountEncryptionKeyDER, getAccountUUID
|
|
|
|
# These are the only two variables you'll need to change
|
|
# The mail address and password of your Adobe account
|
|
|
|
VAR_MAIL = ""
|
|
VAR_PASS = ""
|
|
VAR_VER = None # 1 for ADE2.0.1, 2 for ADE3.0.1
|
|
|
|
#################################################################
|
|
|
|
def main():
|
|
global VAR_MAIL
|
|
global VAR_PASS
|
|
global VAR_VER
|
|
|
|
if (VAR_MAIL == ""):
|
|
VAR_MAIL = input("Please enter your AdobeID: ")
|
|
|
|
if (VAR_PASS == ""):
|
|
VAR_PASS = getpass.getpass("Please enter the password for your AdobeID: ")
|
|
|
|
if (VAR_VER is None):
|
|
VAR_VER = int(input("Please enter '1' for ADE 2.0 or '2' for ADE 3.0: "))
|
|
|
|
if VAR_VER >= len(VAR_VER_SUPP_CONFIG_NAMES):
|
|
print("Invalid version")
|
|
exit(1)
|
|
|
|
if (VAR_MAIL == "" or VAR_PASS == ""):
|
|
print("Empty credential, aborting")
|
|
exit(1)
|
|
|
|
filename = "adobekey_" + VAR_MAIL + ".der"
|
|
|
|
with tempfile.TemporaryDirectory() as temp_dir:
|
|
update_account_path(temp_dir)
|
|
|
|
print ("Preparing keys ...")
|
|
|
|
createDeviceKeyFile()
|
|
success = createDeviceFile(True, VAR_VER)
|
|
if (success is False):
|
|
print("Error, couldn't create device file.")
|
|
exit(1)
|
|
|
|
|
|
success, resp = createUser(VAR_VER, None)
|
|
if (success is False):
|
|
print("Error, couldn't create user: %s" % resp)
|
|
exit(1)
|
|
|
|
print("Logging in ...")
|
|
|
|
success, resp = signIn("AdobeID", VAR_MAIL, VAR_PASS)
|
|
if (success is False):
|
|
print("Login unsuccessful: " + resp)
|
|
exit(1)
|
|
|
|
print("Exporting keys ...")
|
|
|
|
try:
|
|
account_uuid = getAccountUUID()
|
|
if (account_uuid is not None):
|
|
filename = "adobekey_" + VAR_MAIL + "_uuid_" + account_uuid + ".der"
|
|
except:
|
|
pass
|
|
|
|
success = exportAccountEncryptionKeyDER(filename)
|
|
if (success is False):
|
|
print("Couldn't export key.")
|
|
exit(1)
|
|
|
|
|
|
print("Successfully exported key for account " + VAR_MAIL + " to file " + filename)
|
|
|
|
|
|
if __name__ == "__main__":
|
|
main() |