--- # Copyright 2020, VEXXHOST, 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. - name: Validate repo config is deb822 format vars: _repo_check: "{{ frr_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 file: path: "/etc/apt/sources.list.d/frr.list" state: absent register: _cleanup_apt_repositories - name: Ensure python3-debian package is available apt: name: python3-debian - 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: "{{ frr_repos }}" register: _manage_apt_repositories - name: Update Apt cache # noqa: no-handler 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