main.yml 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899
  1. ---
  2. - name: Calico | Run kube proxy
  3. run_once: true
  4. import_role:
  5. name: kube_proxy_and_dns
  6. - include_tasks: certs.yml
  7. - name: Calico Master | Clean Calico etcd data
  8. when: calico_cleanup_path is defined and calico_cleanup_path != ""
  9. file:
  10. state: absent
  11. path: "{{ calico_cleanup_path }}"
  12. - name: Calico Master | oc adm policy add-scc-to-user privileged system:serviceaccount:kube-system:calico-node
  13. oc_adm_policy_user:
  14. user: system:serviceaccount:kube-system:calico-node
  15. resource_kind: scc
  16. resource_name: privileged
  17. state: present
  18. - name: Calico Master | oc adm policy add-scc-to-user privileged system:serviceaccount:kube-system:calico-kube-controllers
  19. oc_adm_policy_user:
  20. user: system:serviceaccount:kube-system:calico-kube-controllers
  21. resource_kind: scc
  22. resource_name: privileged
  23. state: present
  24. - name: Calico Master | oc adm policy add-scc-to-user privileged system:serviceaccount:kube-system:calico-upgrade-job
  25. oc_adm_policy_user:
  26. user: system:serviceaccount:kube-system:calico-upgrade-job
  27. resource_kind: scc
  28. resource_name: privileged
  29. state: present
  30. - name: Set default selector for kube-system
  31. command: >
  32. {{ openshift_client_binary }}
  33. --config={{ openshift.common.config_base }}/master/admin.kubeconfig
  34. annotate ns kube-system openshift.io/node-selector="" --overwrite
  35. - name: Calico Master | Create temp directory
  36. command: mktemp -d /tmp/openshift-ansible-XXXXXXX
  37. register: mktemp
  38. changed_when: False
  39. - name: Calico Master | Write separate Calico etcd manifest
  40. when: use_calico_etcd
  41. template:
  42. dest: "{{ mktemp.stdout }}/calico-etcd.yml"
  43. src: calico-etcd.yml.j2
  44. - name: Calico Master | Launch separate Calico etcd
  45. when: use_calico_etcd
  46. command: >
  47. {{ openshift_client_binary }} apply
  48. -f {{ mktemp.stdout }}/calico-etcd.yml
  49. --config={{ openshift.common.config_base }}/master/admin.kubeconfig
  50. register: calico_etcd_create_output
  51. failed_when: "calico_etcd_create_output.rc != 0"
  52. changed_when: "('created' in calico_etcd_create_output.stdout) or ('configured' in calico_etcd_create_output.stdout)"
  53. - name: Calico Master | Parse node version
  54. set_fact:
  55. node_version: "{{ calico_node_image | regex_replace('^.*node:v?(.*)$', '\\1') }}"
  56. cnx: "{{ calico_node_image | regex_replace('^.*/(.*)-node:.*$', '\\1') }}"
  57. - name: Calico Master | Set the correct liveness and readiness checks
  58. set_fact:
  59. calico_binary_checks: "{{ (node_version > '3.2.0' and cnx != 'cnx') or (node_version > '2.2.0' and cnx == 'cnx') | bool }}"
  60. - name: Calico Master | Write Calico v2
  61. template:
  62. dest: "{{ mktemp.stdout }}/calico.yml"
  63. src: calico.yml.j2
  64. when:
  65. - node_version | regex_search('^[0-9]\.[0-9]\.[0-9]') and node_version < '3.0.0'
  66. - cnx != "cnx"
  67. - name: Calico Master | Write Calico v3
  68. template:
  69. dest: "{{ mktemp.stdout }}/calico.yml"
  70. src: calicov3.yml.j2
  71. when: (node_version | regex_search('^[0-9]\.[0-9]\.[0-9]') and node_version >= '3.0.0') or (node_version == 'master') or (cnx == "cnx" and node_version >= '2.0.0')
  72. - name: Calico Master | Launch Calico
  73. command: >
  74. {{ openshift_client_binary }} apply
  75. -f {{ mktemp.stdout }}/calico.yml
  76. --config={{ openshift.common.config_base }}/master/admin.kubeconfig
  77. register: calico_create_output
  78. failed_when: "calico_create_output.rc != 0"
  79. changed_when: "('created' in calico_create_output.stdout) or ('configured' in calico_create_output.stdout)"
  80. - name: Calico Master | Delete temp directory
  81. file:
  82. name: "{{ mktemp.stdout }}"
  83. state: absent
  84. changed_when: False