1
0
mirror of https://github.com/moepman/acertmgr.git synced 2025-01-04 03:45:23 +01:00

Replace openssl call with pyopenssl

The last remaining call to openssl is replaced by an equivalent
call to pyopenssl, which returns a similar string.
The regular expressions are changed to deal with the difference
in the string returned.
This commit is contained in:
David Klaftenegger 2016-04-07 02:24:35 +02:00 committed by Markus Hauschild
parent c4e1152ed4
commit c8a72094d1

View File

@ -67,14 +67,11 @@ def read_key(path):
# @param key the account key # @param key the account key
# @return the header for ACME # @return the header for ACME
def acme_header(key): def acme_header(key):
proc = subprocess.Popen(['openssl', 'rsa', '-modulus', '-noout', '-text'], txt = crypto.dump_privatekey(crypto.FILETYPE_TEXT, key)
stdin=subprocess.PIPE, stdout=subprocess.PIPE, stderr=subprocess.PIPE) pub_mod, pub_exp = re.search(
out, err = proc.communicate(crypto.dump_privatekey(crypto.FILETYPE_PEM, key)) r"modulus:\n\s+00:([0-9a-f:\s]+)\npublicExponent: [0-9]+ \(0x([0-9A-F]+)\)",
if proc.returncode != 0: txt.decode('utf8'), re.DOTALL).groups()
raise IOError("OpenSSL Error: {0}".format(err)) pub_mod = re.sub('[:\s]', '', pub_mod)
pub_exp, pub_mod = re.search(
r"publicExponent: [0-9]+ \(0x([0-9A-F]+)\).+Modulus=([0-9A-F]+)",
out.decode('utf8'), re.DOTALL).groups()
pub_exp = "0{0}".format(pub_exp) if len(pub_exp) % 2 else pub_exp pub_exp = "0{0}".format(pub_exp) if len(pub_exp) % 2 else pub_exp
header = { header = {
"alg": "RS256", "alg": "RS256",