summaryrefslogtreecommitdiffstats
path: root/ipaserver
diff options
context:
space:
mode:
authorJan Cholasta <jcholast@redhat.com>2014-02-27 15:09:10 +0100
committerPetr Viktorin <pviktori@redhat.com>2014-07-30 16:04:21 +0200
commit2c43a3d0d564b2cfc910d80c42d2ac3c55c9aeb3 (patch)
tree39ba246c8ea00d16da5070b77d16536beadfb4bf /ipaserver
parent2109d6611bafe75f352eb35cfc7b04f2fb113ce3 (diff)
downloadfreeipa-2c43a3d0d564b2cfc910d80c42d2ac3c55c9aeb3.tar.gz
freeipa-2c43a3d0d564b2cfc910d80c42d2ac3c55c9aeb3.tar.xz
freeipa-2c43a3d0d564b2cfc910d80c42d2ac3c55c9aeb3.zip
Move external cert validation from ipa-server-install to installutils.
Reviewed-By: Rob Crittenden <rcritten@redhat.com>
Diffstat (limited to 'ipaserver')
-rw-r--r--ipaserver/install/installutils.py50
1 files changed, 49 insertions, 1 deletions
diff --git a/ipaserver/install/installutils.py b/ipaserver/install/installutils.py
index 2c7479795..ab8f11d67 100644
--- a/ipaserver/install/installutils.py
+++ b/ipaserver/install/installutils.py
@@ -33,13 +33,14 @@ from contextlib import contextmanager
from dns import resolver, rdatatype
from dns.exception import DNSException
import ldap
+from nss.error import NSPRError
from ipapython import ipautil, sysrestore, admintool, dogtag
from ipapython.admintool import ScriptError
from ipapython.ipa_log_manager import *
from ipalib.util import validate_hostname
from ipapython import config
-from ipalib import errors
+from ipalib import errors, x509
from ipapython.dn import DN
from ipaserver.install import certs, service
from ipaplatform import services
@@ -865,3 +866,50 @@ def check_entropy():
except ValueError as e:
root_logger.debug("Invalid value in /proc/sys/kernel/random/entropy_avail %s" % \
e)
+
+def validate_external_cert(cert_file, ca_file, subject_base):
+ extcert = None
+ try:
+ extcert = x509.load_certificate_from_file(cert_file)
+ certsubject = DN(str(extcert.subject))
+ certissuer = DN(str(extcert.issuer))
+ except IOError, e:
+ raise ValueError("Can't load the PEM certificate: %s." % e)
+ except (TypeError, NSPRError):
+ raise ValueError(
+ "'%s' is not a valid PEM-encoded certificate." % cert_file)
+ finally:
+ del extcert
+
+ wantsubject = DN(('CN', 'Certificate Authority'), subject_base)
+ if certsubject != wantsubject:
+ raise ValueError(
+ "Subject of the external certificate is not correct (got %s, "
+ "expected %s)." % (certsubject, wantsubject))
+
+ extchain = None
+ try:
+ extchain = x509.load_certificate_chain_from_file(ca_file)
+ certdict = dict((DN(str(cert.subject)), DN(str(cert.issuer)))
+ for cert in extchain)
+ except IOError, e:
+ raise ValueError("Can't load the external CA chain: %s." % e)
+ except (TypeError, NSPRError):
+ raise ValueError(
+ "'%s' is not a valid PEM-encoded certificate chain." % ca_file)
+ finally:
+ del extchain
+
+ if certissuer not in certdict:
+ raise ValueError(
+ "The external certificate is not signed by the external CA "
+ "(unknown issuer %s)." % certissuer)
+
+ while certsubject != certissuer:
+ certsubject = certissuer
+ try:
+ certissuer = certdict[certsubject]
+ except KeyError:
+ raise ValueError(
+ "The external CA chain is incomplete (%s is missing from the "
+ "chain)." % certsubject)