Role - tripleo-firewall¶
Role Documentation¶
Welcome to the “tripleo_firewall” role documentation.
Role Defaults¶
This section highlights all of the defaults and variables set within the “tripleo_firewall” role.
# All variables intended for modification should be placed in this file.
# All variables within this role should have a prefix of "tripleo_firewall"
# Example rule definition
#
# '003 accept ssh from all':
# proto: 'tcp'
# dport: 22
# '002 remove ssh from all':
# proto: 'tcp'
# dport: 22
# extras:
# ensure: 'absent'
tripleo_firewall_engine: iptables
tripleo_firewall_rules: {}
tripleo_firewall_frontend_enabled: false
tripleo_firewall_frontend_rules: {}
tripleo_firewall_ssl_frontend_enabled: false
tripleo_firewall_ssl_frontend_rules: {}
tripleo_firewall_edge_frontend_enabled: false
tripleo_firewall_edge_frontend_rules: {}
tripleo_firewall_edge_ssl_frontend_rules: {}
tripleo_firewall_default_rules:
000 accept related established rules:
proto: all
state:
- RELATED
- ESTABLISHED
001 accept all icmp:
ipversion: ipv4
proto: icmp
001 accept all ipv6-icmp:
ipversion: ipv6
proto: ipv6-icmp
002 accept all to lo interface:
proto: all
interface: lo
004 accept ipv6 dhcpv6:
ipversion: ipv6
dport: 546
proto: udp
state:
- NEW
destination: fe80::/64
998 log all:
proto: all
jump: LOG
limit: 20/min
limit_burst: 15
999 drop all:
proto: all
action: drop
Role Variables: main.yml¶
# All variables within this role should have a prefix of "tripleo_firewall"
# Converts the expected state options to functional states when
# interacting with ports.
tripleo_firewall_port_states:
enabled: present
present: present
absent: absent
disabled: absent
Role Variables: redhat.yml¶
# While options found within the vars/ path can be overridden using extra
# vars, items within this path are considered part of the role and not
# intended to be modified.
tripleo_firewall_packages:
- iptables-services
Molecule Scenarios¶
Molecule is being used to test the “tripleo_firewall” role. The following section highlights the drivers in service and provides an example playbook showing how the role is leveraged.
Scenario: nftables¶
Molecule Inventory¶
hosts:
all:
hosts:
instance:
ansible_host: localhost
Example nftables playbook¶
- name: Converge
hosts: all
roles:
- role: tripleo_firewall
tripleo_firewall_engine: nftables
Scenario: default¶
Molecule Inventory¶
hosts:
all:
hosts:
instance:
ansible_host: localhost
Example default playbook¶
- name: Converge
hosts: all
roles:
- role: tripleo_firewall
Scenario: firewall-add-complex¶
Molecule Inventory¶
hosts:
all:
hosts:
instance:
ansible_host: localhost
Example firewall-add-complex playbook¶
- name: Converge
hosts: all
roles:
- role: tripleo_firewall
tripleo_firewall_rules:
003 accept ftp from all:
proto: tcp
dport: '21'
003 accept custom from all:
proto: udp
dport:
- '2121'
- 2122
- 2123
- 2200-2210
chain: OUTPUT
003 accept custom tcp from all:
proto: tcp
dport:
- 12121
- 12122
- 12123
- 12200-12210
chain: test-chain
004 gre networks:
proto: gre
005 vrrp networks:
proto: vrrp
006 neutron-test:
dport: 2211
006 ironic-inspector:
dport: 2212
124 snmp:
dport: 2212
source: 192.168.24.1/24
chain: test-chain2
125 snmp:
dport: 2212
destination: '::'
chain: test-chain2
Scenario: firewall-add¶
Molecule Inventory¶
hosts:
all:
hosts:
instance:
ansible_host: localhost
Example firewall-add playbook¶
- name: Converge
hosts: all
roles:
- role: tripleo_firewall
tripleo_firewall_rules:
003 accept ftp from all:
proto: tcp
dport: 21
Scenario: firewall-masquerade¶
Molecule Inventory¶
hosts:
all:
hosts:
instance:
ansible_host: localhost
Example firewall-masquerade playbook¶
- name: Converge
hosts: all
vars:
tripleo_masquerade_networks:
10.10.0.0/24:
- 10.10.0.0/24
- 10.10.1.0/24
roles:
- role: tripleo_firewall
Scenario: firewall-remove-complex¶
Molecule Inventory¶
hosts:
all:
hosts:
instance:
ansible_host: localhost
Example firewall-remove-complex playbook¶
- name: Converge
hosts: all
roles:
- role: tripleo_firewall
tripleo_firewall_rules:
003 accept ftp from all:
proto: tcp
dport: '21'
extras:
ensure: absent
003 accept custom from all:
proto: udp
dport:
- '2121'
- 2122
- 2123
- 2200-2210
extras:
ensure: absent
chain: OUTPUT
003 accept custom tcp from all:
proto: tcp
dport:
- 12121
- 12122
- 12123
- 12200-12210
extras:
ensure: absent
chain: test-chain
004 gre networks:
proto: gre
extras:
ensure: absent
005 vrrp networks:
proto: vrrp
extras:
ensure: absent
006 neutron-test:
dport: 2211
extras:
ensure: absent
006 ironic-inspector:
dport: 2212
extras:
ensure: absent
124 snmp:
dport: 2212
source: 192.168.24.1/24
extras:
ensure: absent
125 snmp:
dport: 2212
destination: '::'
extras:
ensure: absent
Scenario: firewall-remove¶
Molecule Inventory¶
hosts:
all:
hosts:
instance:
ansible_host: localhost
Example firewall-remove playbook¶
- name: Converge
hosts: all
roles:
- role: tripleo_firewall
tripleo_firewall_rules:
003 accept ftp from all:
proto: tcp
dport: 21
extras:
ensure: absent