2009-11-24 15:07:44 -06:00
|
|
|
# Authors:
|
|
|
|
# Rob Crittenden <rcritten@redhat.com>
|
|
|
|
#
|
2010-07-20 13:00:43 -05:00
|
|
|
# Copyright (C) 2010 Red Hat
|
2009-11-24 15:07:44 -06:00
|
|
|
# see file 'COPYING' for use and warranty information
|
|
|
|
#
|
2010-12-09 06:59:11 -06:00
|
|
|
# This program is free software; you can redistribute it and/or modify
|
|
|
|
# it under the terms of the GNU General Public License as published by
|
|
|
|
# the Free Software Foundation, either version 3 of the License, or
|
|
|
|
# (at your option) any later version.
|
2009-11-24 15:07:44 -06:00
|
|
|
#
|
|
|
|
# This program is distributed in the hope that it will be useful,
|
|
|
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
# GNU General Public License for more details.
|
|
|
|
#
|
|
|
|
# You should have received a copy of the GNU General Public License
|
2010-12-09 06:59:11 -06:00
|
|
|
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
2009-11-24 15:07:44 -06:00
|
|
|
|
2010-07-20 13:00:43 -05:00
|
|
|
import os
|
|
|
|
import sys
|
|
|
|
import base64
|
|
|
|
import nss.nss as nss
|
|
|
|
from ipapython import ipautil
|
|
|
|
from ipalib import api
|
2009-11-24 15:07:44 -06:00
|
|
|
|
2010-07-20 13:00:43 -05:00
|
|
|
PEM = 0
|
|
|
|
DER = 1
|
2009-11-24 15:07:44 -06:00
|
|
|
|
2010-07-20 13:00:43 -05:00
|
|
|
def get_subjectaltname(request):
|
|
|
|
"""
|
|
|
|
Given a CSR return the subjectaltname value, if any.
|
2009-11-24 15:07:44 -06:00
|
|
|
|
2010-07-20 13:00:43 -05:00
|
|
|
The return value is a tuple of strings or None
|
|
|
|
"""
|
|
|
|
for extension in request.extensions:
|
|
|
|
if extension.oid_tag == nss.SEC_OID_X509_SUBJECT_ALT_NAME:
|
|
|
|
return nss.x509_alt_name(extension.value)
|
|
|
|
return None
|
2009-11-24 15:07:44 -06:00
|
|
|
|
2010-07-20 13:00:43 -05:00
|
|
|
def get_subject(request):
|
|
|
|
"""
|
|
|
|
Given a CSR return the subject value.
|
2009-11-24 15:07:44 -06:00
|
|
|
|
2010-07-20 13:00:43 -05:00
|
|
|
This returns an nss.DN object.
|
|
|
|
"""
|
|
|
|
return request.subject
|
2009-11-24 15:07:44 -06:00
|
|
|
|
|
|
|
def strip_header(csr):
|
|
|
|
"""
|
|
|
|
Remove the header and footer from a CSR.
|
|
|
|
"""
|
2010-05-03 16:38:39 -05:00
|
|
|
headerlen = 40
|
2009-11-24 15:07:44 -06:00
|
|
|
s = csr.find("-----BEGIN NEW CERTIFICATE REQUEST-----")
|
|
|
|
if s == -1:
|
2010-05-03 16:38:39 -05:00
|
|
|
headerlen = 36
|
2009-11-24 15:07:44 -06:00
|
|
|
s = csr.find("-----BEGIN CERTIFICATE REQUEST-----")
|
|
|
|
if s >= 0:
|
|
|
|
e = csr.find("-----END")
|
2010-05-03 16:38:39 -05:00
|
|
|
csr = csr[s+headerlen:e]
|
2009-11-24 15:07:44 -06:00
|
|
|
|
|
|
|
return csr
|
|
|
|
|
|
|
|
def load_certificate_request(csr):
|
|
|
|
"""
|
|
|
|
Given a base64-encoded certificate request, with or without the
|
|
|
|
header/footer, return a request object.
|
|
|
|
"""
|
|
|
|
csr = strip_header(csr)
|
|
|
|
|
|
|
|
substrate = base64.b64decode(csr)
|
|
|
|
|
2010-07-20 13:00:43 -05:00
|
|
|
# A fail-safe so we can always read a CSR. python-nss/NSS will segfault
|
|
|
|
# otherwise
|
|
|
|
if not nss.nss_is_initialized():
|
|
|
|
nss.nss_init_nodb()
|
2009-11-24 15:07:44 -06:00
|
|
|
|
2010-07-20 13:00:43 -05:00
|
|
|
return nss.CertificateRequest(substrate)
|
2009-11-24 15:07:44 -06:00
|
|
|
|
2010-07-20 13:00:43 -05:00
|
|
|
if __name__ == '__main__':
|
|
|
|
nss.nss_init_nodb()
|
2009-11-24 15:07:44 -06:00
|
|
|
|
2010-07-20 13:00:43 -05:00
|
|
|
# Read PEM request from stdin and print out its components
|
2009-11-24 15:07:44 -06:00
|
|
|
|
2010-07-20 13:00:43 -05:00
|
|
|
csrlines = sys.stdin.readlines()
|
|
|
|
csr = ''.join(csrlines)
|
2009-11-24 15:07:44 -06:00
|
|
|
|
2010-07-20 13:00:43 -05:00
|
|
|
csr = load_certificate_request(csr)
|
2009-11-24 15:07:44 -06:00
|
|
|
|
2010-07-20 13:00:43 -05:00
|
|
|
print csr
|
2009-11-24 15:07:44 -06:00
|
|
|
|
2010-07-20 13:00:43 -05:00
|
|
|
print get_subject(csr)
|
|
|
|
print get_subjectaltname(csr)
|