summaryrefslogtreecommitdiffstats
path: root/ipalib/plugins/cert.py
diff options
context:
space:
mode:
authorRob Crittenden <rcritten@redhat.com>2010-12-10 10:53:20 -0500
committerRob Crittenden <rcritten@redhat.com>2010-12-13 09:58:26 -0500
commit5f8a9b9849ea81d0400d915dee055968d8c680e6 (patch)
tree82c89b477165a06b1905c4ae70cf272ba214c296 /ipalib/plugins/cert.py
parentc9807f4b252055107118493b7d6b66309e3e0d27 (diff)
downloadfreeipa-5f8a9b9849ea81d0400d915dee055968d8c680e6.tar.gz
freeipa-5f8a9b9849ea81d0400d915dee055968d8c680e6.tar.xz
freeipa-5f8a9b9849ea81d0400d915dee055968d8c680e6.zip
Add --out option to service, host and cert-show to save the cert to a file.
Override forward() to grab the result and if a certificate is in the entry and the file is writable then dump the certificate in PEM format. ticket 473
Diffstat (limited to 'ipalib/plugins/cert.py')
-rw-r--r--ipalib/plugins/cert.py22
1 files changed, 22 insertions, 0 deletions
diff --git a/ipalib/plugins/cert.py b/ipalib/plugins/cert.py
index 60161cf1c..9dafe702a 100644
--- a/ipalib/plugins/cert.py
+++ b/ipalib/plugins/cert.py
@@ -71,6 +71,8 @@ from ipalib import pkcs10
from ipalib import x509
from ipalib.plugins.virtual import *
from ipalib.plugins.service import split_principal
+from ipalib.plugins.service import make_pem, check_writable_file
+from ipalib.plugins.service import write_certificate
import base64
import logging
import traceback
@@ -414,6 +416,12 @@ class cert_show(VirtualCommand):
),
)
+ takes_options = (
+ Str('out?',
+ doc=_('file to store certificate in'),
+ ),
+ )
+
operation="retrieve certificate"
def execute(self, serial_number):
@@ -443,6 +451,20 @@ class cert_show(VirtualCommand):
return dict(result=result)
+ def forward(self, *keys, **options):
+ if 'out' in options:
+ check_writable_file(options['out'])
+ result = super(cert_show, self).forward(*keys, **options)
+ if 'usercertificate' in result['result']:
+ write_certificate(result['result']['usercertificate'][0], options['out'])
+ result['summary'] = _('Certificate stored in file \'%(file)s\'') % dict(file=options['out'])
+ return result
+ else:
+ raise errors.NoCertificateError(entry=keys[-1])
+ else:
+ return super(cert_show, self).forward(*keys, **options)
+
+
api.register(cert_show)