router.yml 3.0 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283
  1. ---
  2. - name: Update router certificates
  3. hosts: oo_first_master
  4. vars:
  5. roles:
  6. - lib_openshift
  7. tasks:
  8. - name: Create temp directory for kubeconfig
  9. command: mktemp -d /tmp/openshift-ansible-XXXXXX
  10. register: mktemp
  11. changed_when: false
  12. - name: Copy admin client config(s)
  13. command: >
  14. cp {{ openshift.common.config_base }}/master//admin.kubeconfig {{ mktemp.stdout }}/admin.kubeconfig
  15. changed_when: false
  16. - name: Determine if router exists
  17. command: >
  18. {{ openshift.common.client_binary }} get dc/router -o json
  19. --config={{ mktemp.stdout }}/admin.kubeconfig
  20. -n default
  21. register: l_router_dc
  22. failed_when: false
  23. changed_when: false
  24. - set_fact:
  25. router_env_vars: "{{ ((l_router_dc.stdout | from_json)['spec']['template']['spec']['containers'][0]['env']
  26. | oo_collect('name'))
  27. | default([]) }}"
  28. router_secrets: "{{ ((l_router_dc.stdout | from_json)['spec']['template']['spec']['volumes']
  29. | oo_collect('secret')
  30. | oo_collect('secretName'))
  31. | default([]) }}"
  32. changed_when: false
  33. when: l_router_dc.rc == 0
  34. - name: Update router environment variables
  35. shell: >
  36. {{ openshift.common.client_binary }} env dc/router
  37. OPENSHIFT_CA_DATA="$(cat /etc/origin/master/ca.crt)"
  38. OPENSHIFT_CERT_DATA="$(cat /etc/origin/master/openshift-router.crt)"
  39. OPENSHIFT_KEY_DATA="$(cat /etc/origin/master/openshift-router.key)"
  40. --config={{ mktemp.stdout }}/admin.kubeconfig
  41. -n default
  42. when: l_router_dc.rc == 0 and 'OPENSHIFT_CA_DATA' in router_env_vars and 'OPENSHIFT_CERT_DATA' in router_env_vars and 'OPENSHIFT_KEY_DATA' in router_env_vars
  43. - block:
  44. - name: Delete existing router certificate secret
  45. oc_secret:
  46. kubeconfig: "{{ mktemp.stdout }}/admin.kubeconfig"
  47. name: router-certs
  48. namespace: default
  49. state: absent
  50. run_once: true
  51. - name: Remove router service annotations
  52. command: >
  53. {{ openshift.common.client_binary }} annotate service/router
  54. service.alpha.openshift.io/serving-cert-secret-name-
  55. service.alpha.openshift.io/serving-cert-signed-by-
  56. --config={{ mktemp.stdout }}/admin.kubeconfig
  57. -n default
  58. - name: Add serving-cert-secret annotation to router service
  59. command: >
  60. {{ openshift.common.client_binary }} annotate service/router
  61. service.alpha.openshift.io/serving-cert-secret-name=router-certs
  62. --config={{ mktemp.stdout }}/admin.kubeconfig
  63. -n default
  64. when: l_router_dc.rc == 0 and 'router-certs' in router_secrets
  65. - name: Redeploy router
  66. command: >
  67. {{ openshift.common.client_binary }} deploy dc/router
  68. --latest
  69. --config={{ mktemp.stdout }}/admin.kubeconfig
  70. -n default
  71. - name: Delete temp directory
  72. file:
  73. name: "{{ mktemp.stdout }}"
  74. state: absent
  75. changed_when: False