2020-02-28 20:37:50 -08:00
|
|
|
- name: Enable
|
|
|
|
ufw:
|
|
|
|
state: enabled
|
|
|
|
|
|
|
|
- name: Route with interface in and out
|
|
|
|
ufw:
|
|
|
|
rule: allow
|
|
|
|
route: yes
|
|
|
|
interface_in: foo
|
|
|
|
interface_out: bar
|
|
|
|
proto: tcp
|
2020-07-14 17:19:59 +02:00
|
|
|
from_ip: 10.1.1.1
|
|
|
|
to_ip: 10.8.8.8
|
2020-02-28 20:37:50 -08:00
|
|
|
from_port: 1111
|
|
|
|
to_port: 2222
|
|
|
|
|
|
|
|
- name: Route with interface in
|
|
|
|
ufw:
|
|
|
|
rule: allow
|
|
|
|
route: yes
|
|
|
|
interface_in: foo
|
|
|
|
proto: tcp
|
2020-07-14 17:19:59 +02:00
|
|
|
from_ip: 10.1.1.1
|
2020-02-28 20:37:50 -08:00
|
|
|
from_port: 1111
|
|
|
|
|
|
|
|
- name: Route with interface out
|
|
|
|
ufw:
|
|
|
|
rule: allow
|
|
|
|
route: yes
|
|
|
|
interface_out: bar
|
|
|
|
proto: tcp
|
2020-07-14 17:19:59 +02:00
|
|
|
from_ip: 10.1.1.1
|
2020-02-28 20:37:50 -08:00
|
|
|
from_port: 1111
|
|
|
|
|
|
|
|
- name: Non-route with interface in
|
|
|
|
ufw:
|
|
|
|
rule: allow
|
|
|
|
interface_in: foo
|
|
|
|
proto: tcp
|
2020-07-14 17:19:59 +02:00
|
|
|
from_ip: 10.1.1.1
|
2020-02-28 20:37:50 -08:00
|
|
|
from_port: 3333
|
|
|
|
|
|
|
|
- name: Non-route with interface out
|
|
|
|
ufw:
|
|
|
|
rule: allow
|
|
|
|
interface_out: bar
|
|
|
|
proto: tcp
|
2020-07-14 17:19:59 +02:00
|
|
|
from_ip: 10.1.1.1
|
2020-02-28 20:37:50 -08:00
|
|
|
from_port: 4444
|
|
|
|
|
|
|
|
- name: Check result
|
|
|
|
shell: ufw status |grep -E '(ALLOW|DENY|REJECT|LIMIT)' |sed -E 's/[ \t]+/ /g'
|
|
|
|
register: ufw_status
|
|
|
|
|
|
|
|
- assert:
|
|
|
|
that:
|
2020-07-14 17:19:59 +02:00
|
|
|
- '"10.8.8.8 2222/tcp on bar ALLOW FWD 10.1.1.1 1111/tcp on foo " in stdout'
|
|
|
|
- '"Anywhere ALLOW FWD 10.1.1.1 1111/tcp on foo " in stdout'
|
|
|
|
- '"Anywhere on bar ALLOW FWD 10.1.1.1 1111/tcp " in stdout'
|
|
|
|
- '"Anywhere on foo ALLOW 10.1.1.1 3333/tcp " in stdout'
|
|
|
|
- '"Anywhere ALLOW OUT 10.1.1.1 4444/tcp on bar " in stdout'
|
2020-02-28 20:37:50 -08:00
|
|
|
vars:
|
|
|
|
stdout: '{{ ufw_status.stdout_lines }}'
|
|
|
|
|
|
|
|
- name: Non-route with interface_in and interface_out
|
|
|
|
ufw:
|
|
|
|
rule: allow
|
|
|
|
interface_in: foo
|
|
|
|
interface_out: bar
|
|
|
|
proto: tcp
|
2020-07-14 17:19:59 +02:00
|
|
|
from_ip: 10.1.1.1
|
2020-02-28 20:37:50 -08:00
|
|
|
from_port: 1111
|
2020-07-14 17:19:59 +02:00
|
|
|
to_ip: 10.8.8.8
|
2020-02-28 20:37:50 -08:00
|
|
|
to_port: 2222
|
|
|
|
ignore_errors: yes
|
|
|
|
register: ufw_non_route_iface
|
|
|
|
|
|
|
|
- assert:
|
|
|
|
that:
|
|
|
|
- ufw_non_route_iface is failed
|
|
|
|
- '"Only route rules" in ufw_non_route_iface.msg'
|