diff options
author | Ben Lipton <blipton@redhat.com> | 2017-02-04 10:25:42 -0500 |
---|---|---|
committer | Jan Cholasta <jcholast@redhat.com> | 2017-02-28 09:02:49 +0000 |
commit | 4350dcdea22fd2284836315d0ae7d38733a7620e (patch) | |
tree | 24158f7dbaae47d98a96e885cbe55062b0196a26 | |
parent | 39a5d9c5aae77687f67d9be02457733bdfb99ead (diff) | |
download | freeipa-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.py | 13 |
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, |