On this page
firewalld - Manage arbitrary ports/services with firewalld
New in version 1.4.
Synopsis
- This module allows for addition or deletion of services and ports either tcp or udp in either running or permanent firewalld rules.
Requirements (on host that executes module)
- firewalld >= 0.2.11
Options
parameter | required | default | choices | comments |
---|---|---|---|---|
immediate
(added in 1.9)
|
no |
Should this configuration be applied immediately, if set as permanent
|
||
interface
(added in 2.1)
|
no |
The interface you would like to add/remove to/from a zone in firewalld
|
||
masquerade
(added in 2.1)
|
no |
The masquerade setting you would like to enable/disable to/from zones within firewalld
|
||
permanent |
no |
Should this configuration be in the running firewalld configuration or persist across reboots. As of Ansible version 2.3, permanent operations can operate on firewalld configs when it's not running (requires firewalld >= 3.0.9). (NOTE: If this is false, immediate is assumed true.)
|
||
port |
no |
Name of a port or port range to add/remove to/from firewalld. Must be in the form PORT/PROTOCOL or PORT-PORT/PROTOCOL for port ranges.
|
||
rich_rule |
no |
Rich rule to add/remove to/from firewalld.
|
||
service |
no |
Name of a service to add/remove to/from firewalld - service must be listed in output of firewall-cmd --get-services.
|
||
source
(added in 2.0)
|
no |
The source/network you would like to add/remove to/from firewalld
|
||
state |
yes |
|
Should this port accept(enabled) or reject(disabled) connections.
|
|
timeout |
no |
The amount of time the rule should be in effect for when non-permanent.
|
||
zone |
no | system-default(public) |
|
The firewalld zone to add/remove to/from (NOTE: default zone can be configured per system but "public" is default from upstream. Available choices can be extended based on per-system configs, listed here are "out of the box" defaults).
|
Examples
- firewalld:
service: https
permanent: true
state: enabled
- firewalld:
port: 8081/tcp
permanent: true
state: disabled
- firewalld:
port: 161-162/udp
permanent: true
state: enabled
- firewalld:
zone: dmz
service: http
permanent: true
state: enabled
- firewalld:
rich_rule: 'rule service name="ftp" audit limit value="1/m" accept'
permanent: true
state: enabled
- firewalld:
source: 192.0.2.0/24
zone: internal
state: enabled
- firewalld:
zone: trusted
interface: eth2
permanent: true
state: enabled
- firewalld:
masquerade: yes
state: enabled
permanent: true
zone: dmz
Notes
Note
- Not tested on any Debian based system.
- Requires the python2 bindings of firewalld, which may not be installed by default if the distribution switched to python 3
Status
This module is flagged as preview which means that it is not guaranteed to have a backwards compatible interface.
For help in developing on modules, should you be so inclined, please read Community Information & Contributing, Testing Ansible and Developing Modules.
© 2012–2018 Michael DeHaan
© 2018–2019 Red Hat, Inc.
Licensed under the GNU General Public License version 3.
https://docs.ansible.com/ansible/2.4/firewalld_module.html