486b223e01
This replaces kube-master with kube_control_plane because of [1]: The Kubernetes project is moving away from wording that is considered offensive. A new working group WG Naming was created to track this work, and the word "master" was declared as offensive. A proposal was formalized for replacing the word "master" with "control plane". This means it should be removed from source code, documentation, and user-facing configuration from Kubernetes and its sub-projects. NOTE: The reason why this changes it to kube_control_plane not kube-control-plane is for valid group names on ansible. [1]: https://github.com/kubernetes/enhancements/blob/master/keps/sig-cluster-lifecycle/kubeadm/2067-rename-master-label-taint/README.md#motivation
60 lines
2.3 KiB
YAML
60 lines
2.3 KiB
YAML
---
|
|
- include_tasks: openstack-credential-check.yml
|
|
tags: external-openstack
|
|
|
|
- name: External OpenStack Cloud Controller | Write cacert file
|
|
include_tasks: openstack-write-cacert.yml
|
|
run_once: true
|
|
loop: "{{ groups['k8s-cluster'] }}"
|
|
loop_control:
|
|
loop_var: delegate_host_to_write_cacert
|
|
when:
|
|
- inventory_hostname in groups['k8s-cluster']
|
|
- external_openstack_cacert is defined
|
|
- external_openstack_cacert | length > 0
|
|
tags: external-openstack
|
|
|
|
- name: External OpenStack Cloud Controller | Write External OpenStack cloud-config
|
|
template:
|
|
src: "external-openstack-cloud-config.j2"
|
|
dest: "{{ kube_config_dir }}/external_openstack_cloud_config"
|
|
group: "{{ kube_cert_group }}"
|
|
mode: 0640
|
|
when: inventory_hostname == groups['kube_control_plane'][0]
|
|
tags: external-openstack
|
|
|
|
- name: External OpenStack Cloud Controller | Get base64 cloud-config
|
|
slurp:
|
|
src: "{{ kube_config_dir }}/external_openstack_cloud_config"
|
|
register: external_openstack_cloud_config_secret
|
|
when: inventory_hostname == groups['kube_control_plane'][0]
|
|
tags: external-openstack
|
|
|
|
- name: External OpenStack Cloud Controller | Generate Manifests
|
|
template:
|
|
src: "{{ item.file }}.j2"
|
|
dest: "{{ kube_config_dir }}/{{ item.file }}"
|
|
group: "{{ kube_cert_group }}"
|
|
mode: 0640
|
|
with_items:
|
|
- {name: external-openstack-cloud-config-secret, file: external-openstack-cloud-config-secret.yml}
|
|
- {name: external-openstack-cloud-controller-manager-roles, file: external-openstack-cloud-controller-manager-roles.yml}
|
|
- {name: external-openstack-cloud-controller-manager-role-bindings, file: external-openstack-cloud-controller-manager-role-bindings.yml}
|
|
- {name: external-openstack-cloud-controller-manager-ds, file: external-openstack-cloud-controller-manager-ds.yml}
|
|
register: external_openstack_manifests
|
|
when: inventory_hostname == groups['kube_control_plane'][0]
|
|
tags: external-openstack
|
|
|
|
- name: External OpenStack Cloud Controller | Apply Manifests
|
|
kube:
|
|
kubectl: "{{ bin_dir }}/kubectl"
|
|
filename: "{{ kube_config_dir }}/{{ item.item.file }}"
|
|
state: "latest"
|
|
with_items:
|
|
- "{{ external_openstack_manifests.results }}"
|
|
when:
|
|
- inventory_hostname == groups['kube_control_plane'][0]
|
|
- not item is skipped
|
|
loop_control:
|
|
label: "{{ item.item.file }}"
|
|
tags: external-openstack
|