40-mirror-prep.yml 5.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293
  1. ---
  2. # Download all the tools, set up registry credentials, get ready for "oc mirror".
  3. - name: Download all the tools we need on workstation, set up registry credentials.
  4. hosts: workstation.lab.example.com
  5. gather_subset: min
  6. become: no
  7. vars:
  8. downloads:
  9. - baseurl: https://mirror.openshift.com/pub/openshift-v4/clients/ocp/stable-4.18
  10. filename: oc-mirror.rhel9.tar.gz
  11. dest_dir: /usr/local/bin
  12. deploy: yes
  13. extract: yes
  14. extract_files:
  15. - oc-mirror
  16. target_filename: None
  17. completion: yes
  18. - baseurl: https://mirror.openshift.com/pub/openshift-v4/clients/ocp/stable-4.18
  19. filename: openshift-client-linux-amd64-rhel9.tar.gz
  20. dest_dir: /usr/local/bin
  21. deploy: yes
  22. extract: yes
  23. extract_files:
  24. - oc
  25. - kubectl
  26. target_filename: None
  27. completion: yes
  28. tasks:
  29. - name: Download tools, if necessary.
  30. ansible.builtin.get_url:
  31. url: "{{ item.baseurl }}/{{ item.filename }}"
  32. dest: "{{ ansible_facts['user_dir'] }}/Downloads/{{ item.filename }}"
  33. mode: 0644
  34. owner: student
  35. group: student
  36. loop: "{{ downloads }}"
  37. loop_control:
  38. label: "{{ item.filename }}"
  39. - name: Extract tools, if necessary.
  40. become: yes
  41. ansible.builtin.unarchive:
  42. src: "{{ ansible_facts['user_dir'] }}/Downloads/{{ item.filename }}"
  43. remote_src: yes
  44. dest: "{{ item.dest_dir }}"
  45. include: "{{ item.extract_files }}"
  46. creates: "{{ item.extract_files[0] }}"
  47. mode: 0755
  48. owner: root
  49. group: root
  50. loop: "{{ downloads }}"
  51. loop_control:
  52. label: "{{ item.filename }}"
  53. when:
  54. - item.deploy
  55. - item.extract
  56. - name: Create command completion files, if necessary.
  57. become: yes
  58. ansible.builtin.shell:
  59. cmd: "{{ item.extract_files[0] }} completion bash > /etc/bash_completion.d/{{ item.extract_files[0] }}.completion"
  60. creates: "/etc/bash_completion.d/{{ item.extract_files[0] }}.completion"
  61. loop: "{{ downloads }}"
  62. loop_control:
  63. label: "{{ item.extract_files[0] }}.completion"
  64. when:
  65. - item.completion is defined
  66. - item.completion
  67. - name: Ensure .docker directory exists.
  68. ansible.builtin.file:
  69. path: "{{ ansible_facts['user_dir'] }}/.docker"
  70. state: directory
  71. mode: 0750
  72. owner: student
  73. group: student
  74. - name: Ensure mirror registry auth file is active.
  75. ansible.builtin.copy:
  76. dest: "{{ ansible_facts['user_dir'] }}/.docker/config.json"
  77. mode: 0640
  78. owner: student
  79. group: student
  80. content: '{"auths":{"registry.ocp4.example.com":{"auth":"YWRtaW46cmVkaGF0MTIz"},"cloud.openshift.com":{"auth":"b3BlbnNoaWZ0LXJlbGVhc2UtZGV2K29jbV9hY2Nlc3NfNGM4ZmZhZTI5ZjUzNGJiZjgyZDhlNWE0ZmZiYjRiY2Y6N0NER083UjM4TE1KTEJTN1EzVkVKQVkyTVVCUkpXQjNWNlUxR1BLVzRaN0tGTVpaSENVVTMwMVdaTzMxTDBPNQ==","email":"glsbugs-devops@redhat.com"},"quay.io":{"auth":"b3BlbnNoaWZ0LXJlbGVhc2UtZGV2K29jbV9hY2Nlc3NfNGM4ZmZhZTI5ZjUzNGJiZjgyZDhlNWE0ZmZiYjRiY2Y6N0NER083UjM4TE1KTEJTN1EzVkVKQVkyTVVCUkpXQjNWNlUxR1BLVzRaN0tGTVpaSENVVTMwMVdaTzMxTDBPNQ==","email":"glsbugs-devops@redhat.com"},"registry.connect.redhat.com":{"auth":"fHVoYy1wb29sLTlmMDA1Mzc2LTM2YTItNDJhMS1hNTQwLTA0NzNkYzg3MzYzMzpleUpoYkdjaU9pSlNVelV4TWlKOS5leUp6ZFdJaU9pSTVPRGc1WVdFeFl6Qm1PV0kwWmpVM1lqazNObUk1WldFeU16SXdaalUwTUNKOS5zWmQ5VE1RbzBXREc2NUc5Qk1ObmtuYlBjRkIzNmhyRFhkMThfdTNLeHFaczdlOG1hQ19QeEFReGpwdVk0YVM2VERIbkxDNWpGYjRRNXFYVEpWbjJCOGE4cDFuY08tM24ySG5QdDg3NmktVUFDU3lldWtpb3k4aHI0V3d1ZkhReFVYMmxxWFhYdjN6blE3am1URUNBc25rWkNRSFU1dFNpRnNUZHhFZGZkeU42Z20xN3VqY2thZG5NbFBZcTZfU1I2bUtLaUpUdFQ3SFlDWXJBVk5zZ0tfNGFkZ2MtRXBlbEtHbGNERWkzNGhYbzFqbEIzRERyUWkxSUxCV0UwZkdXb1czZy1ZUzFGMFlEXzc0bm1XSU5mUE1jM25UOERaQWl0OEw0VlFPTnZnUE51YnVfTVVGUGhqX29VUjF3VUR0a1BRNktJdm82UWYyRkdwMndLM1B6YnRBRFFzRVZTZDlITzQ3a0RKdGFobk95YTFmRmdqZVk1bFNxLW1vT2RqUldCZ3U2XzNIX25lZExJR1lQRHRBZnp5cGJ1eHZ1cEd1M2hYWnVzeWN0aURtR203SkR5RW5KdjF1RFZmYVduU2EzSV9NcFRSVVcyZWU1RF9CanJleTdlU2I0bEpGcmp1eC1nY2JVaHFsWGJZc2l6azdXWHpvRmtrVFlMdXFDQ1FvS1J0OFdSN1UzTmh3c3Q2ckV3eEFOaWJFTlNzUVB3MGg4X0NDRm5qTHFSTl82cWpTc0tpeWRGT2tHVFliT0taTktaSVVhYkZFTjRhYVRVYmlYTVdPS2Eyak1xLUhwazBMNEowUmtOM2JkQVVqWmtERHE0ZFY1ZVFjdXNIeV9LY29nd1VKSjZ4MDNObnM4b0xBdjRJZ3RKeXlxcmE1YUJHSkxReHNjRXVSNzQwWQ==","email":"glsbugs-devops@redhat.com"},"registry.redhat.io":{"auth":"fHVoYy1wb29sLTlmMDA1Mzc2LTM2YTItNDJhMS1hNTQwLTA0NzNkYzg3MzYzMzpleUpoYkdjaU9pSlNVelV4TWlKOS5leUp6ZFdJaU9pSTVPRGc1WVdFeFl6Qm1PV0kwWmpVM1lqazNObUk1WldFeU16SXdaalUwTUNKOS5zWmQ5VE1RbzBXREc2NUc5Qk1ObmtuYlBjRkIzNmhyRFhkMThfdTNLeHFaczdlOG1hQ19QeEFReGpwdVk0YVM2VERIbkxDNWpGYjRRNXFYVEpWbjJCOGE4cDFuY08tM24ySG5QdDg3NmktVUFDU3lldWtpb3k4aHI0V3d1ZkhReFVYMmxxWFhYdjN6blE3am1URUNBc25rWkNRSFU1dFNpRnNUZHhFZGZkeU42Z20xN3VqY2thZG5NbFBZcTZfU1I2bUtLaUpUdFQ3SFlDWXJBVk5zZ0tfNGFkZ2MtRXBlbEtHbGNERWkzNGhYbzFqbEIzRERyUWkxSUxCV0UwZkdXb1czZy1ZUzFGMFlEXzc0bm1XSU5mUE1jM25UOERaQWl0OEw0VlFPTnZnUE51YnVfTVVGUGhqX29VUjF3VUR0a1BRNktJdm82UWYyRkdwMndLM1B6YnRBRFFzRVZTZDlITzQ3a0RKdGFobk95YTFmRmdqZVk1bFNxLW1vT2RqUldCZ3U2XzNIX25lZExJR1lQRHRBZnp5cGJ1eHZ1cEd1M2hYWnVzeWN0aURtR203SkR5RW5KdjF1RFZmYVduU2EzSV9NcFRSVVcyZWU1RF9CanJleTdlU2I0bEpGcmp1eC1nY2JVaHFsWGJZc2l6azdXWHpvRmtrVFlMdXFDQ1FvS1J0OFdSN1UzTmh3c3Q2ckV3eEFOaWJFTlNzUVB3MGg4X0NDRm5qTHFSTl82cWpTc0tpeWRGT2tHVFliT0taTktaSVVhYkZFTjRhYVRVYmlYTVdPS2Eyak1xLUhwazBMNEowUmtOM2JkQVVqWmtERHE0ZFY1ZVFjdXNIeV9LY29nd1VKSjZ4MDNObnM4b0xBdjRJZ3RKeXlxcmE1YUJHSkxReHNjRXVSNzQwWQ==","email":"glsbugs-devops@redhat.com"}}}'
  81. - name: Ensure installation registry auth file is on standby.
  82. ansible.builtin.copy:
  83. dest: "{{ ansible_facts['user_dir'] }}/.docker/config.json-install"
  84. mode: 0640
  85. owner: student
  86. group: student
  87. content: '{"auths":{"registry.ocp4.example.com":{"auth":"YWRtaW46cmVkaGF0MTIz"}}}'
  88. ...