From d53332b7cfabbbddd2b5d507cb723c73d80b9466 Mon Sep 17 00:00:00 2001 From: Joshua Tauberer Date: Sat, 26 Dec 2015 11:48:23 -0500 Subject: [PATCH] drop the CSR_COUNTRY setting and ask within the control panel --- CHANGELOG.md | 1 + Vagrantfile | 1 - {setup => management}/csr_country_codes.tsv | 36 ++++++++++----------- management/daemon.py | 13 +++++++- management/ssl_certificates.py | 4 +-- management/templates/ssl.html | 10 ++++++ setup/questions.sh | 29 ----------------- setup/ssl.sh | 2 +- setup/start.sh | 3 +- tools/readable_bash.py | 1 - 10 files changed, 45 insertions(+), 55 deletions(-) rename {setup => management}/csr_country_codes.tsv (98%) diff --git a/CHANGELOG.md b/CHANGELOG.md index b6b96f5..0519c47 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -18,6 +18,7 @@ Control panel: * Better messages if external DNS is used and, weirdly, custom secondary nameservers are set. * Add POP to the mail client settings documentation. * The box's IP address is added to the fail2ban whitelist so that the status checks don't trigger the machine banning itself, which results in the status checks showing services down even though they are running. +* For SSL certificates, rather than asking you what country you are in during setup, ask at the time a CSR is generated. The default system self-signed certificate now omits a country in the subject (it was never needed). The CSR_COUNTRY Mail-in-a-Box setting is dropped entirely. System: diff --git a/Vagrantfile b/Vagrantfile index 2a21dd0..c6ef0ab 100644 --- a/Vagrantfile +++ b/Vagrantfile @@ -22,7 +22,6 @@ Vagrant.configure("2") do |config| export PUBLIC_IP=auto export PUBLIC_IPV6=auto export PRIMARY_HOSTNAME=auto-easy - export CSR_COUNTRY=US #export SKIP_NETWORK_CHECKS=1 # Start the setup script. diff --git a/setup/csr_country_codes.tsv b/management/csr_country_codes.tsv similarity index 98% rename from setup/csr_country_codes.tsv rename to management/csr_country_codes.tsv index 3f8f658..21fde99 100644 --- a/setup/csr_country_codes.tsv +++ b/management/csr_country_codes.tsv @@ -1,27 +1,28 @@ # This list is derived from https://en.wikipedia.org/wiki/ISO_3166-1_alpha-2. # The columns are ISO_3166-1_alpha-2 code, display name, Wikipedia page name. -# The top 20 countries by number of Internet users are grouped first, see +# The top 21 countries by number of Internet users are grouped first, see # https://en.wikipedia.org/wiki/List_of_countries_by_number_of_Internet_users. -BR Brazil -CA Canada CN China -EG Egypt -FR France -DE Germany IN India -ID Indonesia -IT Italy -JP Japan -MX Mexico -NG Nigeria -PH Philippines -RU Russian Federation Russia -ES Spain -KR South Korea -TR Turkey -GB United Kingdom US United States +JP Japan +BR Brazil +RU Russian Federation Russia +DE Germany +NG Nigeria +GB United Kingdom +FR France +MX Mexico +EG Egypt +KR South Korea VN Vietnam +ID Indonesia +PH Philippines +TR Turkey +IT Italy +PK Pakistan +ES Spain +CA Canada AD Andorra AE United Arab Emirates AF Afghanistan @@ -183,7 +184,6 @@ PA Panama PE Peru PF French Polynesia PG Papua New Guinea -PK Pakistan PL Poland PM Saint Pierre and Miquelon PN Pitcairn Pitcairn Islands diff --git a/management/daemon.py b/management/daemon.py index 4f56a76..27e18e8 100755 --- a/management/daemon.py +++ b/management/daemon.py @@ -28,6 +28,14 @@ try: except OSError: pass +# for generating CSRs we need a list of country codes +csr_country_codes = [] +with open(os.path.join(os.path.dirname(me), "csr_country_codes.tsv")) as f: + for line in f: + if line.strip() == "" or line.startswith("#"): continue + code, name = line.strip().split("\t")[0:2] + csr_country_codes.append((code, name)) + app = Flask(__name__, template_folder=os.path.abspath(os.path.join(os.path.dirname(me), "templates"))) # Decorator to protect views that require a user with 'admin' privileges. @@ -101,9 +109,12 @@ def index(): return render_template('index.html', hostname=env['PRIMARY_HOSTNAME'], storage_root=env['STORAGE_ROOT'], + no_users_exist=no_users_exist, no_admins_exist=no_admins_exist, + backup_s3_hosts=backup_s3_hosts, + csr_country_codes=csr_country_codes, ) @app.route('/me') @@ -321,7 +332,7 @@ def dns_get_dump(): def ssl_get_csr(domain): from ssl_certificates import create_csr ssl_private_key = os.path.join(os.path.join(env["STORAGE_ROOT"], 'ssl', 'ssl_private_key.pem')) - return create_csr(domain, ssl_private_key, env) + return create_csr(domain, ssl_private_key, request.form.get('countrycode', ''), env) @app.route('/ssl/install', methods=['POST']) @authorized_personnel_only diff --git a/management/ssl_certificates.py b/management/ssl_certificates.py index 93275a1..1e9a9ca 100644 --- a/management/ssl_certificates.py +++ b/management/ssl_certificates.py @@ -137,12 +137,12 @@ def get_domain_ssl_files(domain, ssl_certificates, env, allow_missing_cert=False return cert_info['private-key'], cert_info['certificate'], via -def create_csr(domain, ssl_key, env): +def create_csr(domain, ssl_key, country_code, env): return shell("check_output", [ "openssl", "req", "-new", "-key", ssl_key, "-sha256", - "-subj", "/C=%s/ST=/L=/O=/CN=%s" % (env["CSR_COUNTRY"], domain)]) + "-subj", "/C=%s/ST=/L=/O=/CN=%s" % (country_code, domain)]) def install_cert(domain, ssl_cert, ssl_chain, env): # Write the combined cert+chain to a temporary path and validate that it is OK. diff --git a/management/templates/ssl.html b/management/templates/ssl.html index 060bd44..d411098 100644 --- a/management/templates/ssl.html +++ b/management/templates/ssl.html @@ -28,6 +28,15 @@

+

What country are you in? This is required by some SSL certificate providers. You may leave this blank if you know your SSL certificate provider doesn't require it.

+ +

+