-
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathplaybook_single_cert.yml
72 lines (58 loc) · 2.2 KB
/
playbook_single_cert.yml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
---
# ansible-playbook -K -D -i inventory/hosts.yml playbook.yml
- name: PKI Single Certificate
hosts: all # should be limited
become: true
gather_facts: false
vars_prompt:
- name: pki_name
prompt: 'Provide the name of the Root-CA to use!'
private: false
- name: pki_name_subca
prompt: 'Provide the name of the Sub-CA to use!'
private: false
- name: pki_subca_pwd
prompt: "Provide the Sub-CA password if not using 'save_password' mode!"
private: true
- name: pki_cert_action
prompt: 'Provide an action to perform! (create,renew,revoke)'
private: false
- name: pki_cert_name
prompt: 'Provide a certificate name!'
private: false
- name: pki_cert_type
prompt: 'Provide a certificate type! (client,server,serverClient,email,code-signing)'
private: false
- name: cert_raw_cn
prompt: "Provide a certificate common-name! [IF NOT REVOKE]"
private: false
- name: cert_raw_san
prompt: "Provide comma-separated subject-alternative-names!
(dns,ip,uri,email,other,dir; per example: 'ip:192.168.0.1,dns:ag.net')
[IF NOT REVOKE]"
private: false
- name: cert_raw_formats
prompt: "Provide comma-separated formats to export additionally!
(unencrypted,chain,p1,p7,p8,p12)
[IF NOT REVOKE]"
private: false
- name: cert_raw_pwd
prompt: "Provide a password for the certificate! (default: from config) [IF NOT REVOKE]"
private: true
vars:
pki_cert_cnf:
cn: "{{ cert_raw_cn }}"
pwd: "{{ cert_raw_pwd }}"
export:
unencrypted: "{{ true if 'unencrypted' in cert_raw_formats else false }}"
chain: "{{ true if 'chain' in cert_raw_formats else false }}"
pkcs1: "{{ true if 'p1' in cert_raw_formats else false }}"
pkcs7: "{{ true if 'p7' in cert_raw_formats else false }}"
pkcs8: "{{ true if 'p8' in cert_raw_formats else false }}"
pkcs12: "{{ true if 'p12' in cert_raw_formats else false }}"
san: "{{ cert_raw_san | san_cs_dict }}"
tasks:
- name: PKI | Managing single certificate
ansible.builtin.import_role:
name: ansibleguy.infra_pki
tasks_from: single_cert.yml