fortinet.fortios.fortios_router_bgp – Configure BGP in Fortinet’s FortiOS and FortiGate.
Note
This plugin is part of the fortinet.fortios collection (version 2.1.3).
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.fortios
.
To use it in a playbook, specify: fortinet.fortios.fortios_router_bgp
.
New in version 2.10: of fortinet.fortios
Synopsis
This module is able to configure a FortiGate or FortiOS (FOS) device by allowing the user to set and modify router feature and bgp category. Examples include all parameters and values need to be adjusted to datasources before usage. Tested with FOS v6.0.0
Requirements
The below requirements are needed on the host that executes this module.
ansible>=2.9.0
Parameters
Parameter |
Comments |
---|---|
Token-based authentication. Generated from GUI of Fortigate. |
|
Enable/Disable logging for task. Choices:
|
|
Member attribute path to operate on. Delimited by a slash character if there are more than one attribute. Parameter marked with member_path is legitimate for doing member operation. |
|
Add or delete a member under specified attribute path. When member_state is specified, the state option is ignored. Choices:
|
|
Configure BGP. |
|
Enable/disable selection of BGP IPv4 additional paths. Choices:
|
|
Enable/disable selection of BGP IPv6 additional paths. Choices:
|
|
Number of additional paths to be selected for each IPv4 NLRI. |
|
Number of additional paths to be selected for each IPv6 NLRI. |
|
Administrative distance modifications. |
|
Administrative distance to apply (1 - 255). |
|
ID. |
|
Neighbor address prefix. |
|
Access list of routes to apply new distance to. Source router.access-list.name. |
|
BGP aggregate address table. |
|
Enable/disable generate AS set path information. Choices:
|
|
ID. |
|
Aggregate prefix. |
|
Enable/disable filter more specific routes from updates. Choices:
|
|
BGP IPv6 aggregate address table. |
|
Enable/disable generate AS set path information. Choices:
|
|
ID. |
|
Aggregate IPv6 prefix. |
|
Enable/disable filter more specific routes from updates. Choices:
|
|
Enable/disable always compare MED. Choices:
|
|
Router AS number, valid from 1 to 4294967295, 0 to disable BGP. |
|
Enable/disable ignore AS path. Choices:
|
|
Enable/disable compare federation AS path length. Choices:
|
|
Enable/disable compare router ID for identical EBGP paths. Choices:
|
|
Enable/disable compare MED among confederation paths. Choices:
|
|
Enable/disable treat missing MED as least preferred. Choices:
|
|
Enable/disable client-to-client route reflection. Choices:
|
|
Route reflector cluster ID. |
|
Confederation identifier. |
|
Confederation peers. |
|
Peer ID. |
|
Enable/disable route-flap dampening. Choices:
|
|
Maximum minutes a route can be suppressed. |
|
Reachability half-life time for penalty (min). |
|
Threshold to reuse routes. |
|
Criteria for dampening. Source router.route-map.name. |
|
Threshold to suppress routes. |
|
Unreachability half-life time for penalty (min). |
|
Default local preference. |
|
Enable/disable enforce deterministic comparison of MED. Choices:
|
|
Distance for routes external to the AS. |
|
Distance for routes internal to the AS. |
|
Distance for routes local to the AS. |
|
Enable/disable EBGP multi-path. Choices:
|
|
Enable/disable enforce first AS for EBGP routes. Choices:
|
|
Enable/disable reset peer BGP session if link goes down. Choices:
|
|
Enable/disable to exit graceful restart on timer only. Choices:
|
|
Enable/disable BGP graceful restart capabilities. Choices:
|
|
Time needed for neighbors to restart (sec). |
|
Time to hold stale paths of restarting neighbor (sec). |
|
Route advertisement/selection delay after restart (sec). |
|
Number of seconds to mark peer as dead. |
|
Enable/disable IBGP multi-path. Choices:
|
|
Don”t send unknown optional capability notification message Choices:
|
|
Frequency to send keep alive requests. |
|
Enable logging of BGP neighbour”s changes Choices:
|
|
Enable/disable use of recursive distance to select multipath. Choices:
|
|
BGP neighbor table. |
|
Enable/disable address family IPv4 for this neighbor. Choices:
|
|
Enable/disable address family IPv6 for this neighbor. Choices:
|
|
Enable/disable IPv4 additional-path capability. Choices:
|
|
Enable/disable IPv6 additional-path capability. Choices:
|
|
Number of IPv4 additional paths that can be advertised to this neighbor. |
|
Number of IPv6 additional paths that can be advertised to this neighbor. |
|
Minimum interval (sec) between sending updates. |
|
IPv4 The maximum number of occurrence of my AS number allowed. |
|
IPv6 The maximum number of occurrence of my AS number allowed. |
|
Enable/disable IPv4 Enable to allow my AS in AS path. Choices:
|
|
Enable/disable IPv6 Enable to allow my AS in AS path. Choices:
|
|
Enable/disable replace peer AS with own AS for IPv4. Choices:
|
|
Enable/disable replace peer AS with own AS for IPv6. Choices:
|
|
IPv4 List of attributes that should be unchanged. Choices:
|
|
IPv6 List of attributes that should be unchanged. Choices:
|
|
Enable/disable BFD for this neighbor. Choices:
|
|
Enable/disable advertise default IPv4 route to this neighbor. Choices:
|
|
Enable/disable advertise default IPv6 route to this neighbor. Choices:
|
|
Enable/disable advertise dynamic capability to this neighbor. Choices:
|
|
Enable/disable advertise IPv4 graceful restart capability to this neighbor. Choices:
|
|
Enable/disable advertise IPv6 graceful restart capability to this neighbor. Choices:
|
|
Accept/Send IPv4 ORF lists to/from this neighbor. Choices:
|
|
Accept/Send IPv6 ORF lists to/from this neighbor. Choices:
|
|
Enable/disable advertise route refresh capability to this neighbor. Choices:
|
|
Conditional advertisement. |
|
Name of advertising route map. Source router.route-map.name. |
|
Name of condition route map. Source router.route-map.name. |
|
Type of condition. Choices:
|
|
IPv6 conditional advertisement. |
|
Name of advertising route map. Source router.route-map.name. |
|
Name of condition route map. Source router.route-map.name. |
|
Type of condition. Choices:
|
|
Interval (sec) for connect timer. |
|
Route map to specify criteria to originate IPv4 default. Source router.route-map.name. |
|
Route map to specify criteria to originate IPv6 default. Source router.route-map.name. |
|
Description. |
|
Filter for IPv4 updates from this neighbor. Source router.access-list.name. |
|
Filter for IPv6 updates from this neighbor. Source router.access-list6.name. |
|
Filter for IPv4 updates to this neighbor. Source router.access-list.name. |
|
Filter for IPv6 updates to this neighbor. Source router.access-list6.name. |
|
Don”t negotiate capabilities with this neighbor Choices:
|
|
Enable/disable allow multi-hop EBGP neighbors. Choices:
|
|
EBGP multihop TTL for this peer. |
|
BGP filter for IPv4 inbound routes. Source router.aspath-list.name. |
|
BGP filter for IPv6 inbound routes. Source router.aspath-list.name. |
|
BGP filter for IPv4 outbound routes. Source router.aspath-list.name. |
|
BGP filter for IPv6 outbound routes. Source router.aspath-list.name. |
|
Interval (sec) before peer considered dead. |
|
Interface Source system.interface.name. |
|
IP/IPv6 address of neighbor. |
|
Keep alive timer interval (sec). |
|
Enable/disable failover upon link down. Choices:
|
|
Local AS number of neighbor. |
|
Do not prepend local-as to incoming updates. Choices:
|
|
Replace real AS with local-as in outgoing updates. Choices:
|
|
Maximum number of IPv4 prefixes to accept from this peer. |
|
Maximum number of IPv6 prefixes to accept from this peer. |
|
Maximum IPv4 prefix threshold value (1 - 100 percent). |
|
Maximum IPv6 prefix threshold value (1 - 100 percent). |
|
Enable/disable IPv4 Only give warning message when limit is exceeded. Choices:
|
|
Enable/disable IPv6 Only give warning message when limit is exceeded. Choices:
|
|
Enable/disable IPv4 next-hop calculation for this neighbor. Choices:
|
|
Enable/disable IPv6 next-hop calculation for this neighbor. Choices:
|
|
Enable/disable setting nexthop”s address to interface”s IPv4 address for route-reflector routes. Choices:
|
|
Enable/disable setting nexthop”s address to interface”s IPv6 address for route-reflector routes. Choices:
|
|
Enable/disable override result of capability negotiation. Choices:
|
|
Enable/disable sending of open messages to this neighbor. Choices:
|
|
Password used in MD5 authentication. |
|
IPv4 Inbound filter for updates from this neighbor. Source router.prefix-list.name. |
|
IPv6 Inbound filter for updates from this neighbor. Source router.prefix-list6.name. |
|
IPv4 Outbound filter for updates to this neighbor. Source router.prefix-list.name. |
|
IPv6 Outbound filter for updates to this neighbor. Source router.prefix-list6.name. |
|
AS number of neighbor. |
|
Enable/disable remove private AS number from IPv4 outbound updates. Choices:
|
|
Enable/disable remove private AS number from IPv6 outbound updates. Choices:
|
|
Graceful restart delay time (sec, 0 = global default). |
|
Time to retain stale routes. |
|
IPv4 Inbound route map filter. Source router.route-map.name. |
|
IPv6 Inbound route map filter. Source router.route-map.name. |
|
IPv4 Outbound route map filter. Source router.route-map.name. |
|
IPv6 Outbound route map filter. Source router.route-map.name. |
|
IPv6 outbound route map filter if the peer is preferred. Source router.route-map.name. |
|
IPv4 outbound route map filter if the peer is preferred. Source router.route-map.name. |
|
Enable/disable IPv4 AS route reflector client. Choices:
|
|
Enable/disable IPv6 AS route reflector client. Choices:
|
|
Enable/disable IPv4 AS route server client. Choices:
|
|
Enable/disable IPv6 AS route server client. Choices:
|
|
IPv4 Send community attribute to neighbor. Choices:
|
|
IPv6 Send community attribute to neighbor. Choices:
|
|
Enable/disable shutdown this neighbor. Choices:
|
|
Enable/disable allow IPv4 inbound soft reconfiguration. Choices:
|
|
Enable/disable allow IPv6 inbound soft reconfiguration. Choices:
|
|
Enable/disable stale route after neighbor down. Choices:
|
|
Enable/disable strict capability matching. Choices:
|
|
IPv4 Route map to selectively unsuppress suppressed routes. Source router.route-map.name. |
|
IPv6 Route map to selectively unsuppress suppressed routes. Source router.route-map.name. |
|
Interface to use as source IP/IPv6 address of TCP connections. Source system.interface.name. |
|
Neighbor weight. |
|
BGP neighbor group table. |
|
Enable/disable address family IPv4 for this neighbor. Choices:
|
|
Enable/disable address family IPv6 for this neighbor. Choices:
|
|
Enable/disable IPv4 additional-path capability. Choices:
|
|
Enable/disable IPv6 additional-path capability. Choices:
|
|
Number of IPv4 additional paths that can be advertised to this neighbor. |
|
Number of IPv6 additional paths that can be advertised to this neighbor. |
|
Minimum interval (sec) between sending updates. |
|
IPv4 The maximum number of occurrence of my AS number allowed. |
|
IPv6 The maximum number of occurrence of my AS number allowed. |
|
Enable/disable IPv4 Enable to allow my AS in AS path. Choices:
|
|
Enable/disable IPv6 Enable to allow my AS in AS path. Choices:
|
|
Enable/disable replace peer AS with own AS for IPv4. Choices:
|
|
Enable/disable replace peer AS with own AS for IPv6. Choices:
|
|
IPv4 List of attributes that should be unchanged. Choices:
|
|
IPv6 List of attributes that should be unchanged. Choices:
|
|
Enable/disable BFD for this neighbor. Choices:
|
|
Enable/disable advertise default IPv4 route to this neighbor. Choices:
|
|
Enable/disable advertise default IPv6 route to this neighbor. Choices:
|
|
Enable/disable advertise dynamic capability to this neighbor. Choices:
|
|
Enable/disable advertise IPv4 graceful restart capability to this neighbor. Choices:
|
|
Enable/disable advertise IPv6 graceful restart capability to this neighbor. Choices:
|
|
Accept/Send IPv4 ORF lists to/from this neighbor. Choices:
|
|
Accept/Send IPv6 ORF lists to/from this neighbor. Choices:
|
|
Enable/disable advertise route refresh capability to this neighbor. Choices:
|
|
Interval (sec) for connect timer. |
|
Route map to specify criteria to originate IPv4 default. Source router.route-map.name. |
|
Route map to specify criteria to originate IPv6 default. Source router.route-map.name. |
|
Description. |
|
Filter for IPv4 updates from this neighbor. Source router.access-list.name. |
|
Filter for IPv6 updates from this neighbor. Source router.access-list6.name. |
|
Filter for IPv4 updates to this neighbor. Source router.access-list.name. |
|
Filter for IPv6 updates to this neighbor. Source router.access-list6.name. |
|
Don”t negotiate capabilities with this neighbor Choices:
|
|
Enable/disable allow multi-hop EBGP neighbors. Choices:
|
|
EBGP multihop TTL for this peer. |
|
BGP filter for IPv4 inbound routes. Source router.aspath-list.name. |
|
BGP filter for IPv6 inbound routes. Source router.aspath-list.name. |
|
BGP filter for IPv4 outbound routes. Source router.aspath-list.name. |
|
BGP filter for IPv6 outbound routes. Source router.aspath-list.name. |
|
Interval (sec) before peer considered dead. |
|
Interface Source system.interface.name. |
|
Keep alive timer interval (sec). |
|
Enable/disable failover upon link down. Choices:
|
|
Local AS number of neighbor. |
|
Do not prepend local-as to incoming updates. Choices:
|
|
Replace real AS with local-as in outgoing updates. Choices:
|
|
Maximum number of IPv4 prefixes to accept from this peer. |
|
Maximum number of IPv6 prefixes to accept from this peer. |
|
Maximum IPv4 prefix threshold value (1 - 100 percent). |
|
Maximum IPv6 prefix threshold value (1 - 100 percent). |
|
Enable/disable IPv4 Only give warning message when limit is exceeded. Choices:
|
|
Enable/disable IPv6 Only give warning message when limit is exceeded. Choices:
|
|
Neighbor group name. |
|
Enable/disable IPv4 next-hop calculation for this neighbor. Choices:
|
|
Enable/disable IPv6 next-hop calculation for this neighbor. Choices:
|
|
Enable/disable setting nexthop”s address to interface”s IPv4 address for route-reflector routes. Choices:
|
|
Enable/disable setting nexthop”s address to interface”s IPv6 address for route-reflector routes. Choices:
|
|
Enable/disable override result of capability negotiation. Choices:
|
|
Enable/disable sending of open messages to this neighbor. Choices:
|
|
IPv4 Inbound filter for updates from this neighbor. Source router.prefix-list.name. |
|
IPv6 Inbound filter for updates from this neighbor. Source router.prefix-list6.name. |
|
IPv4 Outbound filter for updates to this neighbor. Source router.prefix-list.name. |
|
IPv6 Outbound filter for updates to this neighbor. Source router.prefix-list6.name. |
|
AS number of neighbor. |
|
Enable/disable remove private AS number from IPv4 outbound updates. Choices:
|
|
Enable/disable remove private AS number from IPv6 outbound updates. Choices:
|
|
Graceful restart delay time (sec, 0 = global default). |
|
Time to retain stale routes. |
|
IPv4 Inbound route map filter. Source router.route-map.name. |
|
IPv6 Inbound route map filter. Source router.route-map.name. |
|
IPv4 Outbound route map filter. Source router.route-map.name. |
|
IPv6 Outbound route map filter. Source router.route-map.name. |
|
IPv6 outbound route map filter if the peer is preferred. Source router.route-map.name. |
|
IPv4 outbound route map filter if the peer is preferred. Source router.route-map.name. |
|
Enable/disable IPv4 AS route reflector client. Choices:
|
|
Enable/disable IPv6 AS route reflector client. Choices:
|
|
Enable/disable IPv4 AS route server client. Choices:
|
|
Enable/disable IPv6 AS route server client. Choices:
|
|
IPv4 Send community attribute to neighbor. Choices:
|
|
IPv6 Send community attribute to neighbor. Choices:
|
|
Enable/disable shutdown this neighbor. Choices:
|
|
Enable/disable allow IPv4 inbound soft reconfiguration. Choices:
|
|
Enable/disable allow IPv6 inbound soft reconfiguration. Choices:
|
|
Enable/disable stale route after neighbor down. Choices:
|
|
Enable/disable strict capability matching. Choices:
|
|
IPv4 Route map to selectively unsuppress suppressed routes. Source router.route-map.name. |
|
IPv6 Route map to selectively unsuppress suppressed routes. Source router.route-map.name. |
|
Interface to use as source IP/IPv6 address of TCP connections. Source system.interface.name. |
|
Neighbor weight. |
|
BGP neighbor range table. |
|
Neighbor range ID. |
|
Maximum number of neighbors. |
|
Neighbor group name. Source router.bgp.neighbor-group.name. |
|
Neighbor range prefix. |
|
BGP IPv6 neighbor range table. |
|
IPv6 neighbor range ID. |
|
Maximum number of neighbors. |
|
Neighbor group name. Source router.bgp.neighbor-group.name. |
|
IPv6 prefix. |
|
BGP network table. |
|
Enable/disable route as backdoor. Choices:
|
|
ID. |
|
Network prefix. |
|
Route map to modify generated route. Source router.route-map.name. |
|
BGP IPv6 network table. |
|
Enable/disable route as backdoor. Choices:
|
|
ID. |
|
Network IPv6 prefix. |
|
Route map to modify generated route. Source router.route-map.name. |
|
Enable/disable ensure BGP network route exists in IGP. Choices:
|
|
Enable/disable recursive resolution of next-hop using BGP route. Choices:
|
|
BGP IPv4 redistribute table. |
|
Distribute list entry name. |
|
Route map name. Source router.route-map.name. |
|
Status Choices:
|
|
BGP IPv6 redistribute table. |
|
Distribute list entry name. |
|
Route map name. Source router.route-map.name. |
|
Status Choices:
|
|
Router ID. |
|
Background scanner interval (sec), 0 to disable it. |
|
Enable/disable only advertise routes from iBGP if routes present in an IGP. Choices:
|
|
BGP VRF leaking table. |
|
Target VRF table. |
|
Interface which is used to leak routes to target VRF. Source system.interface.name. |
|
Route map of VRF leaking. Source router.route-map.name. |
|
Target VRF ID <0 - 31>. |
|
Origin VRF ID <0 - 31>. |
|
BGP IPv6 VRF leaking table. |
|
Target VRF table. |
|
Interface which is used to leak routes to target VRF. Source system.interface.name. |
|
Route map of VRF leaking. Source router.route-map.name. |
|
Target VRF ID <0 - 31>. |
|
Origin VRF ID <0 - 31>. |
|
Virtual domain, among those defined previously. A vdom is a virtual instance of the FortiGate that can be configured and used as a different unit. Default: “root” |
Examples
- collections:
- fortinet.fortios
connection: httpapi
hosts: fortigate01
vars:
ansible_httpapi_port: 443
ansible_httpapi_use_ssl: true
ansible_httpapi_validate_certs: false
vdom: root
tasks:
- name: fortios_router_bgp
fortios_router_bgp:
vdom: root
router_bgp:
additional_path: disable
additional_path6: disable
additional_path_select: 2
additional_path_select6: 2
always_compare_med: disable
as: 0
bestpath_as_path_ignore: disable
bestpath_cmp_confed_aspath: disable
bestpath_cmp_routerid: disable
bestpath_med_confed: disable
bestpath_med_missing_as_worst: disable
client_to_client_reflection: enable
cluster_id: 0.0.0.0
confederation_identifier: 0
dampening: disable
dampening_max_suppress_time: 60
dampening_reachability_half_life: 15
dampening_reuse: 750
dampening_suppress: 2000
dampening_unreachability_half_life: 15
default_local_preference: 100
deterministic_med: disable
distance_external: 20
distance_internal: 200
distance_local: 200
ebgp_multipath: disable
enforce_first_as: enable
fast_external_failover: enable
graceful_end_on_timer: disable
graceful_restart: disable
graceful_restart_time: 120
graceful_stalepath_time: 360
graceful_update_delay: 120
holdtime_timer: 180
ibgp_multipath: disable
ignore_optional_capability: enable
keepalive_timer: 60
log_neighbour_changes: enable
multipath_recursive_distance: disable
network_import_check: enable
recursive_next_hop: disable
scan_time: 60
synchronization: disable
Return Values
Common return values are documented here, the following are the fields unique to this module:
Key |
Description |
---|---|
Build number of the fortigate image Returned: always Sample: “1547” |
|
Last method used to provision the content into FortiGate Returned: always Sample: “PUT” |
|
Last result given by FortiGate on last operation applied Returned: always Sample: “200” |
|
Master key (id) used in the last call to FortiGate Returned: success Sample: “id” |
|
Name of the table used to fulfill the request Returned: always Sample: “urlfilter” |
|
Path of the table used to fulfill the request Returned: always Sample: “webfilter” |
|
Internal revision number Returned: always Sample: “17.0.2.10658” |
|
Serial number of the unit Returned: always Sample: “FGVMEVYYQT3AB5352” |
|
Indication of the operation’s result Returned: always Sample: “success” |
|
Virtual domain used Returned: always Sample: “root” |
|
Version of the FortiGate Returned: always Sample: “v5.6.3” |
Authors
Link Zheng (@chillancezen)
Jie Xue (@JieX19)
Hongbin Lu (@fgtdev-hblu)
Frank Shen (@frankshen01)
Miguel Angel Munoz (@mamunozgonzalez)
Nicolas Thomas (@thomnico)