From 54c474da99809a12e4bff581040b07bcfd25a01b Mon Sep 17 00:00:00 2001 From: Markus Hauschild Date: Mon, 11 Jan 2016 20:51:23 +0100 Subject: [PATCH] Acutally invoke acme_tiny (using the staging API) --- README.md | 2 +- acertmgr.py | 18 ++++++++++-------- 2 files changed, 11 insertions(+), 9 deletions(-) diff --git a/README.md b/README.md index 89fbe40..f6b9c73 100644 --- a/README.md +++ b/README.md @@ -13,7 +13,7 @@ Requirements * Python (2.7+ and 3.4+ should work) * PyYAML - * acme\_tiny (`acme_tiny.py` placed in `/opt/acme/acme_tiny.py`) + * acme\_tiny (`acme_tiny.py` placed next to `acertmgr.py`) Configuration ------------- diff --git a/acertmgr.py b/acertmgr.py index da159e9..4908b5b 100755 --- a/acertmgr.py +++ b/acertmgr.py @@ -5,6 +5,7 @@ # Copyright (c) Markus Hauschild, 2016. +import acme_tiny import datetime import dateutil.parser import dateutil.relativedelta @@ -17,8 +18,8 @@ import yaml ACME_DIR="/etc/acme/" ACME_CONF=ACME_DIR + "acme.conf" ACME_CONFD=ACME_DIR + "domains.d/" -ACME_TINY="/opt/acme/acme_tiny.py" - +CHALLENGE_DIR="/var/www/acme/" +LE_CA="https://acme-staging.api.letsencrypt.org" # @brief check whether existing certificate is still valid or expiring soon # @param crt_file string containing the path to the certificate file @@ -69,17 +70,18 @@ def cert_get(domain, settings): raise "The account key file (%s) is missing!" % acc_file csr_file = "/tmp/%s.csr" % domain - if os.path.lexists(csr_file): + crt_file = "/tmp/%s.crt" % domain + if os.path.lexists(csr_file) or os.path.lexists(crt_file): raise "A temporary file already exists!" - if not os.path.exists(ACME_TINY): - raise "acme_tiny (%s) is missing!" % ACME_TINY - - crt_file = "/tmp/%s.crt" % domain cr = subprocess.check_output(['openssl', 'req', '-new', '-sha256', '-key', key_file, '-out', csr_file, '-subj', '/CN=%s' % domain]) - # TODO run acme_tiny + # get certificate + crt = acme_tiny.get_crt(acc_file, csr_file, CHALLENGE_DIR, CA = LE_CA) + with open(crt_file, "w") as crt_fd: + crt_fd.write(crt) + # TODO check if resulting certificate is valid os.remove(csr_file)