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.

53 lines
2.3 KiB

  1. ---
  2. - name: NGINX Ingress Controller | Create addon dir
  3. file:
  4. path: "{{ kube_config_dir }}/addons/ingress_nginx"
  5. state: directory
  6. owner: root
  7. group: root
  8. mode: 0755
  9. when:
  10. - inventory_hostname == groups['kube_control_plane'][0]
  11. - name: NGINX Ingress Controller | Templates list
  12. set_fact:
  13. ingress_nginx_templates:
  14. - { name: 00-namespace, file: 00-namespace.yml, type: ns }
  15. - { name: cm-ingress-nginx, file: cm-ingress-nginx.yml, type: cm }
  16. - { name: cm-tcp-services, file: cm-tcp-services.yml, type: cm }
  17. - { name: cm-udp-services, file: cm-udp-services.yml, type: cm }
  18. - { name: sa-ingress-nginx, file: sa-ingress-nginx.yml, type: sa }
  19. - { name: clusterrole-ingress-nginx, file: clusterrole-ingress-nginx.yml, type: clusterrole }
  20. - { name: clusterrolebinding-ingress-nginx, file: clusterrolebinding-ingress-nginx.yml, type: clusterrolebinding }
  21. - { name: role-ingress-nginx, file: role-ingress-nginx.yml, type: role }
  22. - { name: rolebinding-ingress-nginx, file: rolebinding-ingress-nginx.yml, type: rolebinding }
  23. - { name: ds-ingress-nginx-controller, file: ds-ingress-nginx-controller.yml, type: ds }
  24. ingress_nginx_templates_for_psp:
  25. - { name: psp-ingress-nginx, file: psp-ingress-nginx.yml, type: podsecuritypolicy }
  26. - name: NGINX Ingress Controller | Append extra templates to NGINX Ingress Templates list for PodSecurityPolicy
  27. set_fact:
  28. ingress_nginx_templates: "{{ ingress_nginx_templates_for_psp + ingress_nginx_templates }}"
  29. when: podsecuritypolicy_enabled
  30. - name: NGINX Ingress Controller | Create manifests
  31. template:
  32. src: "{{ item.file }}.j2"
  33. dest: "{{ kube_config_dir }}/addons/ingress_nginx/{{ item.file }}"
  34. with_items: "{{ ingress_nginx_templates }}"
  35. register: ingress_nginx_manifests
  36. when:
  37. - inventory_hostname == groups['kube_control_plane'][0]
  38. - name: NGINX Ingress Controller | Apply manifests
  39. kube:
  40. name: "{{ item.item.name }}"
  41. namespace: "{{ ingress_nginx_namespace }}"
  42. kubectl: "{{ bin_dir }}/kubectl"
  43. resource: "{{ item.item.type }}"
  44. filename: "{{ kube_config_dir }}/addons/ingress_nginx/{{ item.item.file }}"
  45. state: "latest"
  46. with_items: "{{ ingress_nginx_manifests.results }}"
  47. when:
  48. - inventory_hostname == groups['kube_control_plane'][0]