Network IP BGP peer-groups endpoint overview
Overview
The following operations are supported:
-
Creation: POST network/ip/bgp/peer-groups
-
Collection Get: GET network/ip/bgp/peer-groups
-
Instance Get: GET network/ip/bgp/peer-groups/{uuid}
-
Instance Patch: PATCH network/ip/bgp/peer-groups/{uuid}
-
Instance Delete: DELETE network/ip/bgp/peer-groups/{uuid}
Retrieving network BGP sessions information
The IP BGP peer-groups GET API retrieves and displays relevant information pertaining to the BGP peer-groups configured in the cluster. The response can contain a list of multiple BGP peer-groups or a specific peer-group. Each BGP peer-group represents a BGP session configured between a local interface and a peer router.
Examples
Retrieving all BGP peer-groups in the cluster
The following example shows the list of all BGP peer-groups configured in a cluster.
# The API: /api/network/ip/bgp/peer-groups # The call: curl -X GET "https://<mgmt-ip>/api/network/ip/bgp/peer-groups" -H "accept: application/hal+json" # The response: { "records": [ { "uuid": "5f22ae9d-87b2-11e9-a3a6-005056bb81a4", "name": "pg1", "_links": { "self": { "href": "/api/network/ip/bgp/peer-groups/5f22ae9d-87b2-11e9-a3a6-005056bb81a4" } } }, { "uuid": "5fd08be3-87b2-11e9-952f-005056bb2170", "name": "pg2", "_links": { "self": { "href": "/api/network/ip/bgp/peer-groups/5fd08be3-87b2-11e9-952f-005056bb2170" } } } ], "num_records": 2, "_links": { "self": { "href": "/api/network/ip/bgp/peer-groups" } } }
Retrieving a specific BGP peer-group
The following example shows the response when a specific BGP peer-group is requested. The system returns an error when there is no peer-group with the requested UUID.
# The API: /api/network/ip/bgp/peer-groups/{uuid} # The call: curl -X GET "https://<mgmt-ip>/api/network/ip/bgp/peer-groups/5fd08be3-87b2-11e9-952f-005056bb2170" -H "accept: application/hal+json" # The response: { "uuid": "5fd08be3-87b2-11e9-952f-005056bb2170", "name": "pg2", "ipspace": { "uuid": "84fd3375-879a-11e9-a3a6-005056bb81a4", "name": "Default", "_links": { "self": { "href": "/api/network/ipspaces/84fd3375-879a-11e9-a3a6-005056bb81a4" } } }, "local": { "interface": { "uuid": "5e76a305-87b2-11e9-952f-005056bb2170", "name": "bgp2", "ip": { "address": "10.10.10.2" } }, "port": { "uuid": "f8ff73de-879a-11e9-952f-005056bb2170", "name": "e0h", "node": { "name": "node1" } } }, "peer": { "address": "10.10.10.1", "asn": 65501 }, "state": "up", "_links": { "self": { "href": "/api/network/ip/bgp/peer-groups/5fd08be3-87b2-11e9-952f-005056bb2170" } } }
Retrieving specific fields and limiting the output using filters
The following example shows the response when a filter is applied (location.port.node.name=node1) and only certain fields are requested. Filtered fields are in the output in addition to the default fields and requested fields.
# The API: /api/network/ip/bgp/peer-groups # The call: curl -X GET "https://<mgmt-ip>/api/network/ip/bgp/peer-groups?local.port.node.name=node1&fields=local.interface.ip,peer" -H "accept: application/hal+json" # The response: { "records": [ { "uuid": "5f22ae9d-87b2-11e9-a3a6-005056bb81a4", "name": "pg1", "local": { "interface": { "ip": { "address": "10.10.10.1" } }, "port": { "node": { "name": "node1" } } }, "peer": { "address": "10.10.10.2", "asn": 65501 }, "_links": { "self": { "href": "/api/network/ip/bgp/peer-groups/5f22ae9d-87b2-11e9-a3a6-005056bb81a4" } } } ], "num_records": 1, "_links": { "self": { "href": "/api/network/ip/bgp/peer-groups?local.port.node.name=node1&fields=local.interface.ip,peer" } } }
Creating a BGP peer-group
The BGP peer-group POST API is used to create a peer-group as shown in the following examples.
Examples
Creating a BGP peer-group with an existing interface
The following example shows how to create a BGP peer-group between an existing interface "bgp1" and peer router with the address "10.10.10.10". The local interface "bgp1" needs to support the management-bgp service, otherwise the system returns an error.
# The API: /api/network/ip/bgp/peer-groups # The call: curl -X POST "https://<mgmt-ip>/api/network/bgp/peer-groups?return_records=true" -d'{"name": "newPg", "ipspace.name":"Default", "local.interface.name": "bgp1", "peer.address":"10.10.10.10"}' # The response: { "num_records": 1, "records": [ { "uuid": "e3faacc6-87cb-11e9-a3a6-005056bb81a4", "name": "newPg", "ipspace": { "name": "Default" }, "local": { "interface": { "name": "bgp1" } }, "peer": { "address": "10.10.10.10" }, "_links": { "self": { "href": "/api/network/ip/bgp/peer-groups/e3faacc6-87cb-11e9-a3a6-005056bb81a4" } } } ] }
Creating a BGP peer-group and provisioning a new local interface
The following example shows how to create a BGP peer-group with any local interface. If the local interface doesn't exist, the system will create it first before creating the peer-group.
# The API: /api/network/ip/bgp/peer-groups # The call: curl -X POST "https://<mgmt-ip>/api/network/bgp/peer-groups?return_records=true" -d'{"name": "newPg1", "ippace.name":"Default", "local": {"interface": {"name": "newlif"}, "ip": {"address": "9.9.9.9", "netmask": "24"}, "port": {"name": "e0f", "node": {"name": "node1"}}}, "peer.address":"10.10.10.10"}' # The response: { "num_records": 1, "records": [ { "uuid": "c292f069-8872-11e9-a3a6-005056bb81a4", "name": "newPg1", "ipspace": { "name": "Default" }, "local": { "interface": { "name": "newlif" }, "port": { "name": "e0f", "node": { "name": "node1" } } }, "peer": { "address": "10.10.10.10" }, "_links": { "self": { "href": "/api/network/ip/bgp/peer-groups/c292f069-8872-11e9-a3a6-005056bb81a4" } } } ] }
Updating BGP peer-groups
The BGP peer-groups PATCH API is used to update attributes of a peer-group.
Examples
Updating the peer router address
The following example shows how the PATCH request changes the peer router IP address.
# The API: /api/network/ip/bgp/peer-groups/{uuid} # The call: curl -X PATCH "https://<mgmt-ip>/api/network/bgp/peer-groups/80d271c9-1f43-11e9-803e-005056a7646a" -H "accept: application/hal+json" -d '{"peer.address": "10.10.10.20" }' { }
Updating the peer-group to a new name
The following example shows how the PATCH request renames the peer-group.
# The API: /api/network/ip/bgp/peer-groups/{uuid} # The call: curl -X PATCH "https://<mgmt-ip>/api/network/bgp/peer-groups/80d271c9-1f43-11e9-803e-005056a7646a" -H "accept: application/hal+json" -d '{"name": "NewName"}' { }
Deleting BGP peer-groups
The BGP peer-groups DELETE API is used to delete an BGP peer-group.
Example
Deleting a BGP peer-group
The following DELETE request deletes a BGP peer-group.
# The API: /api/network/ip/bgp/peer-group/{uuid} # The call: curl -X DELETE "https://<mgmt-ip>/api/network/ip/bgp/peer-groups/80d271c9-1f43-11e9-803e-005056a7646a" { }