summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorBen Lipton <blipton@redhat.com>2017-02-04 10:25:42 -0500
committerJan Cholasta <jcholast@redhat.com>2017-02-28 09:02:49 +0000
commit4350dcdea22fd2284836315d0ae7d38733a7620e (patch)
tree24158f7dbaae47d98a96e885cbe55062b0196a26
parent39a5d9c5aae77687f67d9be02457733bdfb99ead (diff)
downloadfreeipa-4350dcdea22fd2284836315d0ae7d38733a7620e.tar.gz
freeipa-4350dcdea22fd2284836315d0ae7d38733a7620e.tar.xz
freeipa-4350dcdea22fd2284836315d0ae7d38733a7620e.zip
csrgen: Allow overriding the CSR generation profile
In case users want multiple CSR generation profiles that work with the same dogtag profile, or in case the profiles are not named the same, this flag allows specifying an alternative CSR generation profile. https://fedorahosted.org/freeipa/ticket/4899 Reviewed-By: Jan Cholasta <jcholast@redhat.com>
-rw-r--r--ipaclient/plugins/cert.py13
1 files changed, 12 insertions, 1 deletions
diff --git a/ipaclient/plugins/cert.py b/ipaclient/plugins/cert.py
index 5d712b516..16244e121 100644
--- a/ipaclient/plugins/cert.py
+++ b/ipaclient/plugins/cert.py
@@ -51,6 +51,11 @@ class cert_request(MethodOverride):
label=_('Path to private key file'),
doc=_('Path to PEM file containing a private key'),
),
+ Str(
+ 'csr_profile_id?',
+ label=_('Name of CSR generation profile (if not the same as'
+ ' profile_id)'),
+ ),
)
def get_args(self):
@@ -62,6 +67,7 @@ class cert_request(MethodOverride):
def forward(self, csr=None, **options):
database = options.pop('database', None)
private_key = options.pop('private_key', None)
+ csr_profile_id = options.pop('csr_profile_id', None)
if csr is None:
if database:
@@ -75,7 +81,12 @@ class cert_request(MethodOverride):
message=u"One of 'database' or 'private_key' is required")
with NTF() as scriptfile, NTF() as csrfile:
- profile_id = options.get('profile_id')
+ # If csr_profile_id is passed, that takes precedence.
+ # Otherwise, use profile_id. If neither are passed, the default
+ # in cert_get_requestdata will be used.
+ profile_id = csr_profile_id
+ if profile_id is None:
+ profile_id = options.get('profile_id')
self.api.Command.cert_get_requestdata(
profile_id=profile_id,