summaryrefslogtreecommitdiffstats
path: root/roles/etcd_certificates/tasks/client.yml
blob: 7bf95809fc0c7821108cbdcc8a1418e2e8559322 (plain)
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
---
- name: Ensure generated_certs directory present
  file:
    path: "{{ etcd_generated_certs_dir }}/{{ item.etcd_cert_subdir }}"
    state: directory
    mode: 0700
  with_items: etcd_needing_client_certs

- name: Create the client csr
  command: >
    openssl req -new -keyout {{ item.etcd_cert_prefix }}client.key
    -config {{ etcd_openssl_conf }}
    -out {{ item.etcd_cert_prefix }}client.csr
    -reqexts {{ etcd_req_ext }} -batch -nodes
    -subj /CN={{ item.etcd_hostname }}
  args:
    chdir: "{{ etcd_generated_certs_dir }}/{{ item.etcd_cert_subdir }}"
    creates: "{{ etcd_generated_certs_dir ~ '/' ~  item.etcd_cert_subdir ~ '/'
                 ~ item.etcd_cert_prefix ~ 'client.csr' }}"
  environment:
    SAN: "IP:{{ item.etcd_ip }}"
  with_items: etcd_needing_client_certs

- name: Sign and create the client crt
  command: >
    openssl ca -name {{ etcd_ca_name }} -config {{ etcd_openssl_conf }}
    -out {{ item.etcd_cert_prefix }}client.crt
    -in {{ item.etcd_cert_prefix }}client.csr
    -batch
  args:
    chdir: "{{ etcd_generated_certs_dir }}/{{ item.etcd_cert_subdir }}"
    creates: "{{ etcd_generated_certs_dir ~ '/' ~  item.etcd_cert_subdir ~ '/'
                 ~ item.etcd_cert_prefix ~ 'client.crt' }}"
  environment:
    SAN: "IP:{{ item.etcd_ip }}"
  with_items: etcd_needing_client_certs

- file:
    src: "{{ etcd_ca_cert }}"
    dest: "{{ etcd_generated_certs_dir}}/{{ item.etcd_cert_subdir }}/{{ item.etcd_cert_prefix }}ca.crt"
    state: hard
  with_items: etcd_needing_client_certs