--- # NOTE: raw install is required to support cloud images which do not have python installed - name: "Install python2 and python-simplejson" become: True raw: "yum install -y python python-simplejson || (apt-get update && apt-get install -y python2.7 python-simplejson)" - name: Gather facts setup: - name: Ensure localhost in /etc/hosts lineinfile: dest: /etc/hosts regexp: "^127.0.0.1.*" line: "127.0.0.1 localhost" state: present become: True when: customize_etc_hosts | bool - name: Generate /etc/hosts for all of the nodes blockinfile: dest: /etc/hosts marker: "# {mark} ANSIBLE GENERATED HOSTS" block: | {% for host in groups['baremetal'] %} {% set api_interface = hostvars[host]['api_interface'] %} {% if host not in groups['bifrost'] or 'ansible_' + api_interface in hostvars[host] %} {{ hostvars[host]['ansible_' + api_interface]['ipv4']['address'] }} {{ hostvars[host]['ansible_hostname'] }} {% endif %} {% endfor %} become: True when: - customize_etc_hosts | bool # Skip hosts in the bifrost group that do not have a valid api_interface. - inventory_hostname not in groups['bifrost'] or 'ansible_' + hostvars[inventory_hostname]['api_interface'] in hostvars[inventory_hostname] - name: Ensure sudo group is present group: name: sudo state: present become: True - name: Ensure kolla group is present group: name: "{{ kolla_group }}" state: present become: True when: create_kolla_user | bool - name: Install apt packages apt: update_cache: yes become: True when: ansible_os_family == 'Debian' - name: Install ca certs package: name: "{{ item }}" state: latest become: True with_items: - ca-certificates - apt-transport-https when: - ansible_os_family == 'Debian' - name: Ensure apt sources list directory exists file: path: /etc/apt/sources.list.d state: directory recurse: yes become: True when: ansible_os_family == 'Debian' - name: Enable docker repo apt template: src: docker_apt_repo.j2 dest: /etc/apt/sources.list.d/docker.list become: True when: ansible_os_family == 'Debian' - name: Install docker apt gpg key apt_key: url: "{{ docker_apt_url }}/{{ docker_apt_key_file }}" id: "{{ docker_apt_key_id }}" state: present become: True when: ansible_os_family == 'Debian' - name: Ensure yum repos directory exists file: path: /etc/yum.repos.d/ state: directory recurse: yes become: True when: ansible_os_family == 'RedHat' - name: Enable docker repo yum become: True template: src: docker_yum_repo.j2 dest: /etc/yum.repos.d/docker.repo when: ansible_os_family == 'RedHat' - name: Install docker rpm gpg key rpm_key: state: present key: "{{ docker_yum_url }}/gpg" become: True when: ansible_os_family == 'RedHat'