--- # Copyright 2017, Rackspace US, Inc. # # Licensed under the Apache License, Version 2.0 (the "License"); # you may not use this file except in compliance with the License. # You may obtain a copy of the License at # # http://www.apache.org/licenses/LICENSE-2.0 # # Unless required by applicable law or agreed to in writing, software # distributed under the License is distributed on an "AS IS" BASIS, # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. # See the License for the specific language governing permissions and # limitations under the License. # APT configuration tasks that apply on all nodes. - name: Ensure /etc/apt/sources.list.d exists file: path: /etc/apt/sources.list.d state: directory owner: root group: root mode: "0755" - name: Validate repo config is deb822 format vars: _repo_check: "{{ openstack_hosts_package_repos | selectattr('repo', 'defined') | map(attribute='repo') }}" ansible.builtin.assert: that: _repo_check | length == 0 fail_msg: "The following repository definitions must be updated to deb822 format {{ _repo_check }}" # NOTE(jrosser) remove this task for the 2025.2 release - name: Clean up legacy repository config not in deb822 format vars: openstack_hosts_apt_repo_cleanup: - uca.list - osbpo.list file: path: "/etc/apt/sources.list.d/{{ item }}" state: absent register: _cleanup_apt_repositories with_items: "{{ openstack_hosts_apt_repo_cleanup }}" - name: Add requirement packages (repositories gpg keys, toolkits...) apt: name: "{{ openstack_hosts_package_list | rejectattr('state', 'equalto', 'absent') | map(attribute='name') | list }}" state: "{{ openstack_hosts_package_state }}" update_cache: true cache_valid_time: "{{ cache_timeout }}" register: _install_packages until: _install_packages is success retries: 5 delay: 2 - name: Manage apt repositories ansible.builtin.deb822_repository: allow_downgrade_to_insecure: "{{ item.allow_downgrade_to_insecure | default(omit) }}" allow_insecure: "{{ item.allow_insecure | default(omit) }}" allow_weak: "{{ item.allow_weak | default(omit) }}" architectures: "{{ item.architectures | default(omit) }}" by_hash: "{{ item.by_hash | default(omit) }}" check_date: "{{ item.check_date | default(omit) }}" check_valid_until: "{{ item.check_valid_until | default(omit) }}" components: "{{ item.components | default(omit) }}" date_max_future: "{{ item.date_max_future | default(omit) }}" enabled: "{{ item.enabled | default(omit) }}" inrelease_path: "{{ item.inrelease_path | default(omit) }}" languages: "{{ item.languages | default(omit) }}" mode: "{{ item.mode | default(omit) }}" name: "{{ item.name }}" pdiffs: "{{ item.pdiffs | default(omit) }}" signed_by: "{{ item.signed_by | default(omit) }}" state: "{{ item.state | default(omit) }}" suites: "{{ item.suites | default(omit) }}" targets: "{{ item.targets | default(omit) }}" trusted: "{{ item.trusted | default(omit) }}" types: "{{ item.types | default(omit) }}" uris: "{{ item.uris | default(omit) }}" with_items: "{{ openstack_hosts_package_repos }}" register: _manage_apt_repositories - name: Add apt extra conf copy: content: "{{ openstack_hosts_package_manager_default_conf + openstack_hosts_package_manager_extra_conf }}" dest: /etc/apt/apt.conf.d/99openstack-ansible mode: "0644" when: - openstack_hosts_package_manager_extra_conf | length > 0 or openstack_hosts_package_manager_default_conf | length > 0 - name: Update Apt cache apt: update_cache: true when: - (_manage_apt_repositories is changed) or (_cleanup_apt_repositories is changed) register: _update_apt_cache until: _update_apt_cache is success changed_when: false retries: 5 delay: 2