You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

56 lines
1.6 KiB

  1. ---
  2. - name: Cert Manager | Remove legacy addon dir and manifests
  3. file:
  4. path: "{{ kube_config_dir }}/addons/cert_manager"
  5. state: absent
  6. when:
  7. - inventory_hostname == groups['kube_control_plane'][0]
  8. tags:
  9. - upgrade
  10. - name: Cert Manager | Remove legacy namespace
  11. command: >
  12. {{ kubectl }} delete namespace {{ cert_manager_namespace }}
  13. ignore_errors: true # noqa ignore-errors
  14. when:
  15. - inventory_hostname == groups['kube_control_plane'][0]
  16. tags:
  17. - upgrade
  18. - name: Cert Manager | Create addon dir
  19. file:
  20. path: "{{ kube_config_dir }}/addons/cert_manager"
  21. state: directory
  22. owner: root
  23. group: root
  24. mode: "0755"
  25. when:
  26. - inventory_hostname == groups['kube_control_plane'][0]
  27. - name: Cert Manager | Templates list
  28. set_fact:
  29. cert_manager_templates:
  30. - { name: cert-manager, file: cert-manager.yml, type: all }
  31. - { name: cert-manager.crds, file: cert-manager.crds.yml, type: crd }
  32. - name: Cert Manager | Create manifests
  33. template:
  34. src: "{{ item.file }}.j2"
  35. dest: "{{ kube_config_dir }}/addons/cert_manager/{{ item.file }}"
  36. mode: "0644"
  37. with_items: "{{ cert_manager_templates }}"
  38. register: cert_manager_manifests
  39. when:
  40. - inventory_hostname == groups['kube_control_plane'][0]
  41. - name: Cert Manager | Apply manifests
  42. kube:
  43. name: "{{ item.item.name }}"
  44. kubectl: "{{ bin_dir }}/kubectl"
  45. resource: "{{ item.item.type }}"
  46. filename: "{{ kube_config_dir }}/addons/cert_manager/{{ item.item.file }}"
  47. state: "latest"
  48. with_items: "{{ cert_manager_manifests.results }}"
  49. when:
  50. - inventory_hostname == groups['kube_control_plane'][0]