mirror of
https://github.com/Leseratte10/acsm-calibre-plugin
synced 2025-01-15 03:41:15 +01:00
Fix signature in Python version
This commit is contained in:
parent
6177bdf67a
commit
fa3a336d5e
1 changed files with 8 additions and 14 deletions
|
@ -3,8 +3,8 @@
|
||||||
|
|
||||||
'''
|
'''
|
||||||
This is an experimental Python version of libgourou. Right now it only supports part of the authorization
|
This is an experimental Python version of libgourou. Right now it only supports part of the authorization
|
||||||
(and doesn't support fulfillment at all). All the encryption / decryption stuff works, the node hashing
|
(and doesn't support fulfillment at all). All the encryption / decryption stuff works, but once I send
|
||||||
also works, only thing I'm stuck at is the signature. Right now the Adobe server responds with "BadPadding".
|
the final request to the Adobe server, it responds with E_AUTH_USER_AUTH, and I have no idea what that means.
|
||||||
|
|
||||||
Who knows, maybe there will someday be a full Python version of libgourou so it can be used in
|
Who knows, maybe there will someday be a full Python version of libgourou so it can be used in
|
||||||
Calibre on all operating systems without additional dependencies.
|
Calibre on all operating systems without additional dependencies.
|
||||||
|
@ -19,6 +19,8 @@ from OpenSSL import crypto
|
||||||
from Crypto import Random
|
from Crypto import Random
|
||||||
from Crypto.PublicKey import RSA
|
from Crypto.PublicKey import RSA
|
||||||
from Crypto.Util.asn1 import DerSequence
|
from Crypto.Util.asn1 import DerSequence
|
||||||
|
from Crypto.Signature import PKCS1_v1_5 as pkcssign
|
||||||
|
from Crypto.Hash import SHA
|
||||||
from Crypto.Cipher import AES
|
from Crypto.Cipher import AES
|
||||||
from Crypto.Cipher import PKCS1_v1_5
|
from Crypto.Cipher import PKCS1_v1_5
|
||||||
from uuid import getnode
|
from uuid import getnode
|
||||||
|
@ -584,36 +586,28 @@ def sign_node(node):
|
||||||
|
|
||||||
sha_hash = hash_node(node)
|
sha_hash = hash_node(node)
|
||||||
|
|
||||||
print("SHA1 HASH is " + sha_hash.hex())
|
|
||||||
|
|
||||||
global devkey_bytes
|
global devkey_bytes
|
||||||
global pkcs12
|
global pkcs12
|
||||||
|
|
||||||
print("pkcs12 is")
|
|
||||||
print(pkcs12)
|
|
||||||
|
|
||||||
my_pkcs12 = base64.b64decode(pkcs12)
|
my_pkcs12 = base64.b64decode(pkcs12)
|
||||||
|
|
||||||
pkcs_data = crypto.load_pkcs12(my_pkcs12, base64.b64encode(devkey_bytes))
|
pkcs_data = crypto.load_pkcs12(my_pkcs12, base64.b64encode(devkey_bytes))
|
||||||
|
|
||||||
my_priv_key = crypto.dump_privatekey(crypto.FILETYPE_ASN1, pkcs_data.get_privatekey())
|
my_priv_key = crypto.dump_privatekey(crypto.FILETYPE_ASN1, pkcs_data.get_privatekey())
|
||||||
|
|
||||||
print(my_priv_key)
|
|
||||||
|
|
||||||
key = RSA.importKey(my_priv_key)
|
key = RSA.importKey(my_priv_key)
|
||||||
cipherAC = PKCS1_v1_5.new(key)
|
cipherAC = pkcssign.new(key)
|
||||||
crypted_msg = cipherAC.encrypt(bytes(sha_hash))
|
crypted_msg = cipherAC.sign(sha_hash)
|
||||||
|
|
||||||
print("Encrypted SHA hash: " + str(crypted_msg))
|
|
||||||
return base64.b64encode(crypted_msg)
|
return base64.b64encode(crypted_msg)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
def hash_node(node):
|
def hash_node(node):
|
||||||
|
|
||||||
hash_ctx = hashlib.sha1()
|
hash_ctx = SHA.new()
|
||||||
hash_node_ctx(node, hash_ctx)
|
hash_node_ctx(node, hash_ctx)
|
||||||
return hash_ctx.digest()
|
return hash_ctx
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue