From f02848f2d0ebcfe6ddbb695e8bc0bd8697c2e6d1 Mon Sep 17 00:00:00 2001 From: Rob Austein Date: Wed, 19 Sep 2007 20:42:31 +0000 Subject: Checkpoint svn path=/docs/left-right-xml; revision=995 --- scripts/rpki/pkcs10.py | 35 +++++++++++++++++++++++++++++++++++ 1 file changed, 35 insertions(+) create mode 100644 scripts/rpki/pkcs10.py (limited to 'scripts/rpki/pkcs10.py') diff --git a/scripts/rpki/pkcs10.py b/scripts/rpki/pkcs10.py new file mode 100644 index 00000000..4d6a024a --- /dev/null +++ b/scripts/rpki/pkcs10.py @@ -0,0 +1,35 @@ +# $Id$ + +import POW, rpki.x509, os, rpki.exceptions, binascii + +req_fmt = ''' +[ req ] +distinguished_name = req_dn +prompt = no + +[ req_dn ] +CN = %s +''' + +def make_request(keypair): + + digest = POW.Digest(POW.SHA1_DIGEST) + digest.update(keypair.get_POW().derWrite(POW.RSA_PUBLIC_KEY)) + commonName = "0x" + binascii.hexify(digest.digest()) + + try: + config_filename = "req.tmp.conf" + f = open(config_filename, "w") + f.write(req_fmt % commonName) + f.close() + + i,o = os.popen2(["openssl", "req", "-config", config_filename, "-new", "-key", "/dev/stdin", "-outform", "DER"]) + i.write(keypair.get_PEM()) + i.close() + pkcs10 = o.read() + o.close() + + finally: + os.unlink(config_filename) + + return pkcs10 -- cgit v1.2.3