router.yml 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384
  1. ---
  2. - name: Update router certificates
  3. hosts: oo_first_master
  4. vars:
  5. tasks:
  6. - name: Create temp directory for kubeconfig
  7. command: mktemp -d /tmp/openshift-ansible-XXXXXX
  8. register: mktemp
  9. changed_when: false
  10. roles:
  11. - lib_openshift
  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