--- - name: Cert Manager | Remove legacy addon dir and manifests file: path: "{{ kube_config_dir }}/addons/cert_manager" state: absent when: - inventory_hostname == groups['kube_control_plane'][0] tags: - upgrade - name: Cert Manager | Remove legacy namespace shell: | {{ bin_dir }}/kubectl delete namespace {{ cert_manager_namespace }} ignore_errors: true # noqa ignore-errors when: - inventory_hostname == groups['kube_control_plane'][0] tags: - upgrade - name: Cert Manager | Create addon dir file: path: "{{ kube_config_dir }}/addons/cert_manager" state: directory owner: root group: root mode: 0755 when: - inventory_hostname == groups['kube_control_plane'][0] - name: Cert Manager | Templates list set_fact: cert_manager_templates: - { name: 00-namespace, file: 00-namespace.yml, type: ns } - { name: sa-cert-manager, file: sa-cert-manager.yml, type: sa } - { name: crd-certificate, file: crd-certificate.yml, type: crd } - { name: crd-challenge, file: crd-challenge.yml, type: crd } - { name: crd-clusterissuer, file: crd-clusterissuer.yml, type: crd } - { name: crd-issuer, file: crd-issuer.yml, type: crd } - { name: crd-order, file: crd-order.yml, type: crd } - { name: clusterrole-cert-manager, file: clusterrole-cert-manager.yml, type: clusterrole } - { name: clusterrolebinding-cert-manager, file: clusterrolebinding-cert-manager.yml, type: clusterrolebinding } - { name: role-cert-manager, file: role-cert-manager.yml, type: role } - { name: rolebinding-cert-manager, file: rolebinding-cert-manager.yml, type: rolebinding } - { name: deploy-cert-manager, file: deploy-cert-manager.yml, type: deploy } - { name: svc-cert-manager, file: svc-cert-manager.yml, type: svc } - { name: webhook-cert-manager, file: webhook-cert-manager.yml, type: webhook } - name: Cert Manager | Create manifests template: src: "{{ item.file }}.j2" dest: "{{ kube_config_dir }}/addons/cert_manager/{{ item.file }}" with_items: "{{ cert_manager_templates }}" register: cert_manager_manifests when: - inventory_hostname == groups['kube_control_plane'][0] - name: Cert Manager | Apply manifests kube: name: "{{ item.item.name }}" kubectl: "{{ bin_dir }}/kubectl" resource: "{{ item.item.type }}" filename: "{{ kube_config_dir }}/addons/cert_manager/{{ item.item.file }}" state: "latest" with_items: "{{ cert_manager_manifests.results }}" when: - inventory_hostname == groups['kube_control_plane'][0]