Commit 03f9358d authored by Joshua Tauberer's avatar Joshua Tauberer

when checking SSL certs are OK, check for wildcard certificates

fixes #175 (hopefully)
parent c7a2aad0
...@@ -360,7 +360,8 @@ def check_certificate(domain, ssl_certificate, ssl_private_key): ...@@ -360,7 +360,8 @@ def check_certificate(domain, ssl_certificate, ssl_private_key):
# First check that the certificate is for the right domain. The domain # First check that the certificate is for the right domain. The domain
# must be found in the Subject Common Name (CN) or be one of the # must be found in the Subject Common Name (CN) or be one of the
# Subject Alternative Names. # Subject Alternative Names. A wildcard might also appear as the CN
# or in the SAN list, so check for that tool.
cert_dump = shell('check_output', [ cert_dump = shell('check_output', [
"openssl", "x509", "openssl", "x509",
"-in", ssl_certificate, "-in", ssl_certificate,
...@@ -389,7 +390,8 @@ def check_certificate(domain, ssl_certificate, ssl_private_key): ...@@ -389,7 +390,8 @@ def check_certificate(domain, ssl_certificate, ssl_private_key):
if m: if m:
certificate_names.add(m.group(1)) certificate_names.add(m.group(1))
if domain is not None and domain not in certificate_names: wildcard_domain = re.sub("^[^\.]+", "*", domain)
if domain is not None and domain not in certificate_names and wildcard_domain not in certificate_names:
return "This certificate is for the wrong domain names. It is for %s." % \ return "This certificate is for the wrong domain names. It is for %s." % \
", ".join(sorted(certificate_names)) ", ".join(sorted(certificate_names))
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment