51 lines
2.1 KiB
YAML
51 lines
2.1 KiB
YAML
---
|
|
# Copyright 2019 Red Hat, Inc.
|
|
# All Rights Reserved.
|
|
#
|
|
# 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.
|
|
|
|
|
|
- include_tasks: tripleo_firewall_state.yml
|
|
|
|
- name: Firewall protocol rule (ipv4)
|
|
iptables:
|
|
table: "{{ item['rule']['table'] | default(omit) }}"
|
|
chain: "{{ item['rule']['chain'] | default('INPUT') }}"
|
|
in_interface: "{{ item['rule']['interface'] | default(omit) }}"
|
|
protocol: "{{ item['rule']['proto'] }}"
|
|
source_port: "{{ item['rule']['sport'] | default(omit) | replace('-', ':') }}"
|
|
source: "{{ item['rule']['source'] | default(omit) }}"
|
|
comment: "{{ item['rule_name'] }} ipv4"
|
|
jump: "{{ item['rule']['jump'] | default('ACCEPT') }}"
|
|
ctstate: "{{ tripleo_ctstate }}"
|
|
ip_version: ipv4
|
|
state: "{{ tripleo_firewall_port_states[(item['rule']['extras'] | default({}))['ensure'] | default('enabled')] }}"
|
|
when:
|
|
- item['rule']['proto'] != 'ipv6'
|
|
|
|
- name: Firewall protocol rule (ipv6)
|
|
iptables:
|
|
table: "{{ item['rule']['table'] | default(omit) }}"
|
|
chain: "{{ item['rule']['chain'] | default('INPUT') }}"
|
|
in_interface: "{{ item['rule']['interface'] | default(omit) }}"
|
|
protocol: "{{ item['rule']['proto'] }}"
|
|
source_port: "{{ item['rule']['sport'] | default(omit) | replace('-', ':') }}"
|
|
source: "{{ item['rule']['source'] | default(omit) }}"
|
|
comment: "{{ item['rule_name'] }} ipv4"
|
|
jump: "{{ item['rule']['jump'] | default('ACCEPT') }}"
|
|
ctstate: "{{ tripleo_ctstate }}"
|
|
ip_version: ipv6
|
|
state: "{{ tripleo_firewall_port_states[(item['rule']['extras'] | default({}))['ensure'] | default('enabled')] }}"
|
|
when:
|
|
- item['rule']['proto'] != 'ipv4'
|