1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677 |
- ---
- - oc_project:
- name: openshift-template-service-broker
- state: present
- node_selector:
- - ""
- - command: mktemp -d /tmp/tsb-ansible-XXXXXX
- register: mktemp
- changed_when: False
- - name: Copy admin client config
- command: >
- cp {{ openshift.common.config_base }}/master//admin.kubeconfig {{ mktemp.stdout }}/admin.kubeconfig
- changed_when: false
- - copy:
- src: "{{ item }}"
- dest: "{{ mktemp.stdout }}/{{ item }}"
- with_items:
- - "{{ __tsb_template_file }}"
- - "{{ __tsb_rbac_file }}"
- - "{{ __tsb_broker_file }}"
- - "{{ __tsb_config_file }}"
- - yedit:
- src: "{{ mktemp.stdout }}/{{ __tsb_config_file }}"
- key: templateNamespaces
- value: "{{ openshift_template_service_broker_namespaces }}"
- value_type: list
- - slurp:
- src: "{{ mktemp.stdout }}/{{ __tsb_config_file }}"
- register: config
- - name: Apply template file
- shell: >
- {{ openshift_client_binary }} process --config={{ mktemp.stdout }}/admin.kubeconfig
- -f "{{ mktemp.stdout }}/{{ __tsb_template_file }}"
- --param API_SERVER_CONFIG="{{ config['content'] | b64decode }}"
- --param IMAGE="{{ template_service_broker_prefix }}{{ template_service_broker_image_name }}:{{ template_service_broker_version }}"
- --param NODE_SELECTOR={{ template_service_broker_selector | to_json | quote }}
- | {{ openshift_client_binary }} apply --config={{ mktemp.stdout }}/admin.kubeconfig -f -
- # reconcile with rbac
- - name: Reconcile with RBAC file
- shell: >
- {{ openshift_client_binary }} process --config={{ mktemp.stdout }}/admin.kubeconfig -f "{{ mktemp.stdout }}/{{ __tsb_rbac_file }}"
- | {{ openshift_client_binary }} auth reconcile --config={{ mktemp.stdout }}/admin.kubeconfig -f -
- # Check that the TSB is running
- - name: Verify that TSB is running
- command: >
- curl -k https://apiserver.openshift-template-service-broker.svc/healthz
- args:
- # Disables the following warning:
- # Consider using get_url or uri module rather than running curl
- warn: no
- register: api_health
- until: api_health.stdout == 'ok'
- retries: 60
- delay: 10
- changed_when: false
- - slurp:
- src: "{{ openshift_master_config_dir }}/service-signer.crt"
- register: __ca_bundle
- # Register with broker
- - name: Register TSB with broker
- shell: >
- {{ openshift_client_binary }} process --config={{ mktemp.stdout }}/admin.kubeconfig -f "{{ mktemp.stdout }}/{{ __tsb_broker_file }}" --param CA_BUNDLE="{{ __ca_bundle.content }}" | {{ openshift_client_binary }} apply --config={{ mktemp.stdout }}/admin.kubeconfig -f -
- - file:
- state: absent
- name: "{{ mktemp.stdout }}"
- changed_when: False
|