neutron/roles/nftables/tasks/main.yaml
Rodolfo Alonso Hernandez 66a55a2844 Restore the tempest nftables jobs in experimental and periodic queues
The job names were changed but not replaced in the
"neutron-periodic-jobs" template.

This patch is also adding new binaries to the nftables installation
role, that includes all the "-save" and "-restore" ones.

Closes-Bug: #2039027

Change-Id: Ia4c140af74db29f4e40299648f1b5091b4801b51
(cherry picked from commit daa0d1c5a2)
(cherry picked from commit 591cf6c35c)
Conflicts:
	zuul.d/job-templates.yaml
2023-11-07 19:25:30 +05:30

52 lines
1.8 KiB
YAML

- name: Ensure nftables is installed
package:
name: 'nftables'
state: latest
become: yes
- name: Switch to nftables binaries
shell:
cmd: |
/usr/bin/update-alternatives --set iptables /usr/sbin/iptables-nft
/usr/bin/update-alternatives --set iptables-save /usr/sbin/iptables-nft-save
/usr/bin/update-alternatives --set iptables-restore /usr/sbin/iptables-nft-restore
/usr/bin/update-alternatives --set ip6tables /usr/sbin/ip6tables-nft
/usr/bin/update-alternatives --set ip6tables-save /usr/sbin/ip6tables-nft-save
/usr/bin/update-alternatives --set ip6tables-restore /usr/sbin/ip6tables-nft-restore
/usr/bin/update-alternatives --set ebtables /usr/sbin/ebtables-nft
/usr/bin/update-alternatives --set ebtables-save /usr/sbin/ebtables-nft-save
/usr/bin/update-alternatives --set ebtables-restore /usr/sbin/ebtables-nft-restore
/usr/bin/update-alternatives --set arptables /usr/sbin/arptables-nft
executable: /bin/bash
become: yes
- name: Restart nftables service, that will replace iptables(4,6), ebtables and arptables
ansible.builtin.systemd:
state: restarted
name: nftables.service
become: yes
- name: Check ipv4 rules, stored by iptables-persistent
stat:
path: '/etc/iptables/rules.v4'
register: ipv4_rules_file
- name: Check ipv6 rules, stored by iptables-persistent
stat:
path: '/etc/iptables/rules.v6'
register: ipv6_rules_file
- name: Restore saved IPv4 iptables rules, stored by iptables-persistent
shell:
cmd: |
iptables-restore '{{ ipv4_rules_file.stat.path }}'
become: yes
when: ipv4_rules_file.stat.exists
- name: Restore saved IPv6 iptables rules, stored by iptables-persistent
shell:
cmd: |
ip6tables-restore '{{ ipv6_rules_file.stat.path }}'
become: yes
when: ipv6_rules_file.stat.exists