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.

60 lines
2.3 KiB

  1. ---
  2. - include_tasks: openstack-credential-check.yml
  3. tags: external-openstack
  4. - name: External OpenStack Cloud Controller | Write cacert file
  5. include_tasks: openstack-write-cacert.yml
  6. run_once: true
  7. loop: "{{ groups['k8s-cluster'] }}"
  8. loop_control:
  9. loop_var: delegate_host_to_write_cacert
  10. when:
  11. - inventory_hostname in groups['k8s-cluster']
  12. - external_openstack_cacert is defined
  13. - external_openstack_cacert | length > 0
  14. tags: external-openstack
  15. - name: External OpenStack Cloud Controller | Write External OpenStack cloud-config
  16. template:
  17. src: "external-openstack-cloud-config.j2"
  18. dest: "{{ kube_config_dir }}/external_openstack_cloud_config"
  19. group: "{{ kube_cert_group }}"
  20. mode: 0640
  21. when: inventory_hostname == groups['kube_control_plane'][0]
  22. tags: external-openstack
  23. - name: External OpenStack Cloud Controller | Get base64 cloud-config
  24. slurp:
  25. src: "{{ kube_config_dir }}/external_openstack_cloud_config"
  26. register: external_openstack_cloud_config_secret
  27. when: inventory_hostname == groups['kube_control_plane'][0]
  28. tags: external-openstack
  29. - name: External OpenStack Cloud Controller | Generate Manifests
  30. template:
  31. src: "{{ item.file }}.j2"
  32. dest: "{{ kube_config_dir }}/{{ item.file }}"
  33. group: "{{ kube_cert_group }}"
  34. mode: 0640
  35. with_items:
  36. - {name: external-openstack-cloud-config-secret, file: external-openstack-cloud-config-secret.yml}
  37. - {name: external-openstack-cloud-controller-manager-roles, file: external-openstack-cloud-controller-manager-roles.yml}
  38. - {name: external-openstack-cloud-controller-manager-role-bindings, file: external-openstack-cloud-controller-manager-role-bindings.yml}
  39. - {name: external-openstack-cloud-controller-manager-ds, file: external-openstack-cloud-controller-manager-ds.yml}
  40. register: external_openstack_manifests
  41. when: inventory_hostname == groups['kube_control_plane'][0]
  42. tags: external-openstack
  43. - name: External OpenStack Cloud Controller | Apply Manifests
  44. kube:
  45. kubectl: "{{ bin_dir }}/kubectl"
  46. filename: "{{ kube_config_dir }}/{{ item.item.file }}"
  47. state: "latest"
  48. with_items:
  49. - "{{ external_openstack_manifests.results }}"
  50. when:
  51. - inventory_hostname == groups['kube_control_plane'][0]
  52. - not item is skipped
  53. loop_control:
  54. label: "{{ item.item.file }}"
  55. tags: external-openstack