fortinet.fortimanager.fmgr_pkg_firewall_policy – Configure IPv4 policies.

Note

This plugin is part of the fortinet.fortimanager collection (version 2.1.4).

You might already have this collection installed if you are using the ansible package. It is not included in ansible-core. To check whether it is installed, run ansible-galaxy collection list.

To install it, use: ansible-galaxy collection install fortinet.fortimanager.

To use it in a playbook, specify: fortinet.fortimanager.fmgr_pkg_firewall_policy.

New in version 2.10: of fortinet.fortimanager

Synopsis

  • This module is able to configure a FortiManager device.

  • Examples include all parameters and values which need to be adjusted to data sources before usage.

Parameters

Parameter Choices/Defaults Comments
adom
string / required
the parameter (adom) in requested url
bypass_validation
boolean
    Choices:
  • no ←
  • yes
only set to True when module schema diffs with FortiManager API structure, module continues to execute without validating parameters
enable_log
boolean
    Choices:
  • no ←
  • yes
Enable/Disable logging for task
pkg
string / required
the parameter (pkg) in requested url
pkg_firewall_policy
dictionary
the top level parameters set
action
string
    Choices:
  • deny
  • accept
  • ipsec
  • ssl-vpn
Policy action (allow/deny/ipsec).
anti-replay
string
    Choices:
  • disable
  • enable
Enable/disable anti-replay check.
app-category
string
Application category ID list.
app-group
string
Application group names.
application
integer
Application ID list.
application-list
string
Name of an existing Application list.
auth-cert
string
HTTPS server certificate for policy authentication.
auth-path
string
    Choices:
  • disable
  • enable
Enable/disable authentication-based routing.
auth-redirect-addr
string
HTTP-to-HTTPS redirect address for firewall authentication.
auto-asic-offload
string
    Choices:
  • disable
  • enable
Enable/disable offloading security profile processing to CP processors.
av-profile
string
Name of an existing Antivirus profile.
best-route
string
    Choices:
  • disable
  • enable
Enable/disable the use of best route.
block-notification
string
    Choices:
  • disable
  • enable
Enable/disable block notification.
captive-portal-exempt
string
    Choices:
  • disable
  • enable
Enable to exempt some users from the captive portal.
capture-packet
string
    Choices:
  • disable
  • enable
Enable/disable capture packets.
cifs-profile
string
Name of an existing CIFS profile.
comments
string
no description
custom-log-fields
string
Custom fields to append to log messages for this policy.
decrypted-traffic-mirror
string
Decrypted traffic mirror.
delay-tcp-npu-session
string
    Choices:
  • disable
  • enable
Enable TCP NPU session delay to guarantee packet order of 3-way handshake.
devices
string
Names of devices or device groups that can be matched by the policy.
diffserv-forward
string
    Choices:
  • disable
  • enable
Enable to change packets DiffServ values to the specified diffservcode-forward value.
diffserv-reverse
string
    Choices:
  • disable
  • enable
Enable to change packets reverse (reply) DiffServ values to the specified diffservcode-rev value.
diffservcode-forward
string
Change packets DiffServ to this value.
diffservcode-rev
string
Change packets reverse (reply) DiffServ to this value.
disclaimer
string
    Choices:
  • disable
  • enable
Enable/disable user authentication disclaimer.
dlp-sensor
string
Name of an existing DLP sensor.
dnsfilter-profile
string
Name of an existing DNS filter profile.
dscp-match
string
    Choices:
  • disable
  • enable
Enable DSCP check.
dscp-negate
string
    Choices:
  • disable
  • enable
Enable negated DSCP match.
dscp-value
string
DSCP value.
dsri
string
    Choices:
  • disable
  • enable
Enable DSRI to ignore HTTP server responses.
dstaddr
string
Destination address and address group names.
dstaddr-negate
string
    Choices:
  • disable
  • enable
When enabled dstaddr specifies what the destination address must NOT be.
dstaddr6
string
Destination IPv6 address name and address group names.
dstintf
string
Outgoing (egress) interface.
dynamic-shaping
string
    Choices:
  • disable
  • enable
Enable/disable dynamic RADIUS defined traffic shaping.
email-collect
string
    Choices:
  • disable
  • enable
Enable/disable email collection.
emailfilter-profile
string
Name of an existing email filter profile.
file-filter-profile
string
Name of an existing file-filter profile.
firewall-session-dirty
string
    Choices:
  • check-all
  • check-new
How to handle sessions if the configuration of this firewall policy changes.
fixedport
string
    Choices:
  • disable
  • enable
Enable to prevent source NAT from changing a sessions source port.
fsso
string
    Choices:
  • disable
  • enable
Enable/disable Fortinet Single Sign-On.
fsso-agent-for-ntlm
string
FSSO agent to use for NTLM authentication.
fsso-groups
string
Names of FSSO groups.
geoip-anycast
string
    Choices:
  • disable
  • enable
Enable/disable recognition of anycast IP addresses using the geography IP database.
geoip-match
string
    Choices:
  • physical-location
  • registered-location
Match geography address based either on its physical location or registered location.
global-label
string
Label for the policy that appears when the GUI is in Global View mode.
groups
string
Names of user groups that can authenticate with this policy.
gtp-profile
string
GTP profile.
http-policy-redirect
string
    Choices:
  • disable
  • enable
Redirect HTTP(S) traffic to matching transparent web proxy policy.
icap-profile
string
Name of an existing ICAP profile.
identity-based-route
string
Name of identity-based routing rule.
inbound
string
    Choices:
  • disable
  • enable
Policy-based IPsec VPN: only traffic from the remote network can initiate a VPN.
inspection-mode
string
    Choices:
  • proxy
  • flow
Policy inspection mode (Flow/proxy). Default is Flow mode.
internet-service
string
    Choices:
  • disable
  • enable
Enable/disable use of Internet Services for this policy. If enabled, destination address and service are not used.
internet-service-custom
string
Custom Internet Service Name.
internet-service-custom-group
string
Custom Internet Service group name.
internet-service-group
string
Internet Service group name.
internet-service-id
string
Internet Service ID.
internet-service-name
string
Internet Service name.
internet-service-negate
string
    Choices:
  • disable
  • enable
When enabled internet-service specifies what the service must NOT be.
internet-service-src
string
    Choices:
  • disable
  • enable
Enable/disable use of Internet Services in source for this policy. If enabled, source address is not used.
internet-service-src-custom
string
Custom Internet Service source name.
internet-service-src-custom-group
string
Custom Internet Service source group name.
internet-service-src-group
string
Internet Service source group name.
internet-service-src-id
string
Internet Service source ID.
internet-service-src-name
string
Internet Service source name.
internet-service-src-negate
string
    Choices:
  • disable
  • enable
When enabled internet-service-src specifies what the service must NOT be.
ippool
string
    Choices:
  • disable
  • enable
Enable to use IP Pools for source NAT.
ips-sensor
string
Name of an existing IPS sensor.
label
string
Label for the policy that appears when the GUI is in Section View mode.
learning-mode
string
    Choices:
  • disable
  • enable
Enable to allow everything, but log all of the meaningful data for security information gathering. A learning report will be g...
logtraffic
string
    Choices:
  • disable
  • enable
  • all
  • utm
Enable or disable logging. Log all sessions or security profile sessions.
logtraffic-start
string
    Choices:
  • disable
  • enable
Record logs when a session starts and ends.
match-vip
string
    Choices:
  • disable
  • enable
Enable to match packets that have had their destination addresses changed by a VIP.
match-vip-only
string
    Choices:
  • disable
  • enable
Enable/disable matching of only those packets that have had their destination addresses changed by a VIP.
mms-profile
string
Name of an existing MMS profile.
name
string
Policy name.
nat
string
    Choices:
  • disable
  • enable
Enable/disable source NAT.
natinbound
string
    Choices:
  • disable
  • enable
Policy-based IPsec VPN: apply destination NAT to inbound traffic.
natip
string
Policy-based IPsec VPN: source NAT IP address for outgoing traffic.
natoutbound
string
    Choices:
  • disable
  • enable
Policy-based IPsec VPN: apply source NAT to outbound traffic.
np-acceleration
string
    Choices:
  • disable
  • enable
Enable/disable UTM Network Processor acceleration.
ntlm
string
    Choices:
  • disable
  • enable
Enable/disable NTLM authentication.
ntlm-enabled-browsers
string
HTTP-User-Agent value of supported browsers.
ntlm-guest
string
    Choices:
  • disable
  • enable
Enable/disable NTLM guest user access.
object position
list / elements=string
no description
outbound
string
    Choices:
  • disable
  • enable
Policy-based IPsec VPN: only traffic from the internal network can initiate a VPN.
passive-wan-health-measurement
string
    Choices:
  • disable
  • enable
Enable/disable passive WAN health measurement. When enabled, auto-asic-offload is disabled.
per-ip-shaper
string
Per-IP traffic shaper.
permit-any-host
string
    Choices:
  • disable
  • enable
Accept UDP packets from any host.
permit-stun-host
string
    Choices:
  • disable
  • enable
Accept UDP packets from any Session Traversal Utilities for NAT (STUN) host.
policyid
integer
Policy ID.
poolname
string
IP Pool names.
poolname6
string
IPv6 pool names.
profile-group
string
Name of profile group.
profile-protocol-options
string
Name of an existing Protocol options profile.
profile-type
string
    Choices:
  • single
  • group
Determine whether the firewall policy allows security profile groups or single profiles only.
radius-mac-auth-bypass
string
    Choices:
  • disable
  • enable
Enable MAC authentication bypass. The bypassed MAC address must be received from RADIUS server.
redirect-url
string
URL users are directed to after seeing and accepting the disclaimer or authenticating.
replacemsg-override-group
string
Override the default replacement message group for this policy.
reputation-direction
string
    Choices:
  • source
  • destination
Direction of the initial traffic for reputation to take effect.
reputation-minimum
integer
Minimum Reputation to take action.
rsso
string
    Choices:
  • disable
  • enable
Enable/disable RADIUS single sign-on (RSSO).
rtp-addr
string
Address names if this is an RTP NAT policy.
rtp-nat
string
    Choices:
  • disable
  • enable
Enable Real Time Protocol (RTP) NAT.
scan-botnet-connections
string
    Choices:
  • disable
  • block
  • monitor
Block or monitor connections to Botnet servers or disable Botnet scanning.
schedule
string
Schedule name.
schedule-timeout
string
    Choices:
  • disable
  • enable
Enable to force current sessions to end when the schedule object times out. Disable allows them to end from inactivity.
send-deny-packet
string
    Choices:
  • disable
  • enable
Enable to send a reply when a session is denied or blocked by a firewall policy.
service
string
Service and service group names.
service-negate
string
    Choices:
  • disable
  • enable
When enabled service specifies what the service must NOT be.
session-ttl
integer
Session TTL in seconds for sessions accepted by this policy. 0 means use the system default session TTL.
spamfilter-profile
string
Name of an existing Spam filter profile.
src-vendor-mac
string
Vendor MAC source ID.
srcaddr
string
Source address and address group names.
srcaddr-negate
string
    Choices:
  • disable
  • enable
When enabled srcaddr specifies what the source address must NOT be.
srcaddr6
string
Source IPv6 address name and address group names.
srcintf
string
Incoming (ingress) interface.
ssh-filter-profile
string
Name of an existing SSH filter profile.
ssh-policy-redirect
string
    Choices:
  • disable
  • enable
Redirect SSH traffic to matching transparent proxy policy.
ssl-mirror
string
    Choices:
  • disable
  • enable
Enable to copy decrypted SSL traffic to a FortiGate interface (called SSL mirroring).
ssl-mirror-intf
string
SSL mirror interface name.
ssl-ssh-profile
string
Name of an existing SSL SSH profile.
status
string
    Choices:
  • disable
  • enable
Enable or disable this policy.
tags
string
Names of object-tags applied to this policy.
tcp-mss-receiver
integer
Receiver TCP maximum segment size (MSS).
tcp-mss-sender
integer
Sender TCP maximum segment size (MSS).
tcp-session-without-syn
string
    Choices:
  • all
  • data-only
  • disable
Enable/disable creation of TCP session without SYN flag.
timeout-send-rst
string
    Choices:
  • disable
  • enable
Enable/disable sending RST packets when TCP sessions expire.
tos
string
ToS (Type of Service) value used for comparison.
tos-mask
string
Non-zero bit positions are used for comparison while zero bit positions are ignored.
tos-negate
string
    Choices:
  • disable
  • enable
Enable negated TOS match.
traffic-shaper
string
Traffic shaper.
traffic-shaper-reverse
string
Reverse traffic shaper.
url-category
string
URL category ID list.
users
string
Names of individual users that can authenticate with this policy.
utm-status
string
    Choices:
  • disable
  • enable
Enable to add one or more security profiles (AV, IPS, etc.) to the firewall policy.
uuid
string
Universally Unique Identifier (UUID; automatically assigned but can be manually reset).
videofilter-profile
string
Name of an existing VideoFilter profile.
vlan-cos-fwd
integer
VLAN forward direction user priority: 255 passthrough, 0 lowest, 7 highest.
vlan-cos-rev
integer
VLAN reverse direction user priority: 255 passthrough, 0 lowest, 7 highest..
vlan-filter
string
Set VLAN filters.
voip-profile
string
Name of an existing VoIP profile.
vpn_dst_node
list / elements=string
Vpn_Dst_Node.
host
string
Host.
seq
integer
Seq.
subnet
string
Subnet.
vpn_src_node
list / elements=string
Vpn_Src_Node.
host
string
Host.
seq
integer
Seq.
subnet
string
Subnet.
vpntunnel
string
Policy-based IPsec VPN: name of the IPsec VPN Phase 1.
waf-profile
string
Name of an existing Web application firewall profile.
wanopt
string
    Choices:
  • disable
  • enable
Enable/disable WAN optimization.
wanopt-detection
string
    Choices:
  • active
  • passive
  • off
WAN optimization auto-detection mode.
wanopt-passive-opt
string
    Choices:
  • default
  • transparent
  • non-transparent
WAN optimization passive mode options. This option decides what IP address will be used to connect server.
wanopt-peer
string
WAN optimization peer.
wanopt-profile
string
WAN optimization profile.
wccp
string
    Choices:
  • disable
  • enable
Enable/disable forwarding traffic matching this policy to a configured WCCP server.
webcache
string
    Choices:
  • disable
  • enable
Enable/disable web cache.
webcache-https
string
    Choices:
  • disable
  • ssl-server
  • any
  • enable
Enable/disable web cache for HTTPS.
webfilter-profile
string
Name of an existing Web filter profile.
webproxy-forward-server
string
Webproxy forward server name.
webproxy-profile
string
Webproxy profile name.
wsso
string
    Choices:
  • disable
  • enable
Enable/disable WiFi Single Sign On (WSSO).
ztna-ems-tag
string
Source ztna-ems-tag names.
ztna-geo-tag
string
Source ztna-geo-tag names.
ztna-status
string
    Choices:
  • disable
  • enable
Enable/disable zero trust access.
proposed_method
string
    Choices:
  • update
  • set
  • add
The overridden method for the underlying Json RPC request
rc_failed
list / elements=string
the rc codes list with which the conditions to fail will be overriden
rc_succeeded
list / elements=string
the rc codes list with which the conditions to succeed will be overriden
state
string / required
    Choices:
  • present
  • absent
the directive to create, update or delete an object
workspace_locking_adom
string
the adom to lock for FortiManager running in workspace mode, the value can be global and others including root
workspace_locking_timeout
integer
Default:
300
the maximum time in seconds to wait for other user to release the workspace lock

Notes

Note

  • Running in workspace locking mode is supported in this FortiManager module, the top level parameters workspace_locking_adom and workspace_locking_timeout help do the work.

  • To create or update an object, use state present directive.

  • To delete an object, use state absent directive.

  • Normally, running one module can fail when a non-zero rc is returned. you can also override the conditions to fail or succeed with parameters rc_failed and rc_succeeded

Examples

- hosts: fortimanager00
  collections:
    - fortinet.fortimanager
  connection: httpapi
  vars:
     ansible_httpapi_use_ssl: True
     ansible_httpapi_validate_certs: False
     ansible_httpapi_port: 443
  tasks:
   - name: Configure IPv4 policies.
     fmgr_pkg_firewall_policy:
        bypass_validation: False
        adom: ansible
        pkg: ansible # package name
        state: present
        pkg_firewall_policy:
           action: accept #<value in [deny, accept, ipsec, ...]>
           comments: ansible-comment
           dstaddr: all
           dstintf: any
           #name: ansible-test-policy
           nat: disable
           policyid: 1
           schedule: always
           service: ALL
           srcaddr: all
           srcintf: any
           status: disable

- name: gathering fortimanager facts
  hosts: fortimanager00
  gather_facts: no
  connection: httpapi
  collections:
    - fortinet.fortimanager
  vars:
    ansible_httpapi_use_ssl: True
    ansible_httpapi_validate_certs: False
    ansible_httpapi_port: 443
  tasks:
   - name: retrieve all the IPv4 policies
     fmgr_fact:
       facts:
           selector: 'pkg_firewall_policy'
           params:
               adom: 'ansible'
               pkg: 'ansible' # package name
               policy: ''

Return Values

Common return values are documented here, the following are the fields unique to this module:

Key Returned Description
request_url
string
always
The full url requested

Sample:
/sys/login/user
response_code
integer
always
The status of api request

response_message
string
always
The descriptive message of the api response

Sample:
OK.


Authors

  • Link Zheng (@chillancezen)

  • Jie Xue (@JieX19)

  • Frank Shen (@fshen01)

  • Hongbin Lu (@fgtdev-hblu)