acsm-calibre-plugin/calibre-plugin/get_key_from_Adobe.py

111 lines
3.0 KiB
Python
Raw Normal View History

#!/usr/bin/env python3
# -*- coding: utf-8 -*-
2023-02-24 19:11:15 +06:00
'''
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()