e52a9372f7
API additions for [1]. * Added a new router attribute: external_gateways; * Added new API definitions for: PUT add_external_gateways PUT update_external_gateways PUT remove_external_gateways * Added extensions for each of the new router-level attributes: * enable_default_route_ecmp * enable_default_route_bfd * Combined the validation logic for the external_gateway_info type across extensions (l3_ext_gw_mode, qos_gateway_ip and the new extension called l3_ext_gw_multihoming). [1] https://review.opendev.org/c/openstack/neutron-specs/+/870030/ Change-Id: I2618475636b2bb9bfd743a62f5d4859d4f68a547 Related-Bug: #2002687
1047 lines
32 KiB
ReStructuredText
1047 lines
32 KiB
ReStructuredText
.. -*- rst -*-
|
|
|
|
=================
|
|
Routers (routers)
|
|
=================
|
|
|
|
A ``router`` is a logical entity for forwarding packets across
|
|
internal subnets and NATting them on external networks through an
|
|
appropriate external gateway.
|
|
|
|
This resource is provided when ``router`` extension is enabled.
|
|
|
|
Distributed virtual router extension
|
|
====================================
|
|
|
|
The ``dvr`` extension enables the functionality of configuring a router as a
|
|
distributed virtual router, adding ``distributed`` parameter.
|
|
|
|
Extra routes extension
|
|
======================
|
|
|
|
The extra route extension (``extraroute``) extends ``router`` resources adding
|
|
a ``routes`` attribute that contains an array of route objects. Each route
|
|
object has a ``destination`` and ``nexthop`` attribute representing the route.
|
|
When the ``extraroute-atomic`` extension is also available you can add
|
|
or remove a set of extra routes atomically on the server side. For details
|
|
please see below.
|
|
|
|
.. warning::
|
|
|
|
By default in a router there is one route for each attached subnet. If you
|
|
add an extra route that matches one of the default routes for a subnet,
|
|
the existing subnet route will be overwritten.
|
|
If the Neutron route is removed, the corresponding route will be removed
|
|
as well. The affected subnet will subsequently lose connectivity to this
|
|
router.
|
|
|
|
Extra routes (atomic) extension
|
|
===============================
|
|
|
|
The extra route atomic extension (``extraroute-atomic``) extends the
|
|
``router`` resource by adding two member actions (``add_extraroutes`` /
|
|
``remove_extraroutes``) to edit the set of extra routes atomically on
|
|
the server side.
|
|
|
|
.. warning::
|
|
|
|
By default in a router there is one route for each attached subnet. If you
|
|
add an extra route that matches one of the default routes for a subnet,
|
|
the existing subnet route will be overwritten.
|
|
If the Neutron route is removed, the corresponding route will be removed
|
|
as well. The affected subnet will subsequently lose connectivity to this
|
|
router.
|
|
|
|
HA capability for router extension (``l3-ha``)
|
|
=======================================================
|
|
|
|
The L3 HA extension ``l3-ha``, adds the ``ha`` attribute which enables
|
|
HA capability to routers when set to ``true``.
|
|
|
|
L3 external gateway mode extension (``ext-gw-mode``)
|
|
=======================================================
|
|
|
|
The ``ext-gw-mode`` extension of the router abstraction for specifying whether
|
|
SNAT should occur on the external gateway.
|
|
The ``ext-gw-mode`` extension allows enabling configurable external gateway
|
|
modes, adds the ``external_gateway_info`` attribute to ``routers``
|
|
and allows definitions for ``network_id``, ``enable_snat`` and
|
|
``external_fixed_ips``.
|
|
|
|
L3 external gateway multihoming extension (``external-gateway-multihoming``)
|
|
============================================================================
|
|
|
|
The ``external-gateway-multihoming`` extension allows a router to have
|
|
multiple external gateway ports and to have a policy specified on how
|
|
to handle ECMP and BFD for default routes inferred from the subnets
|
|
associated with gateway ports.
|
|
|
|
L3 flavors extension (``l3-flavors``)
|
|
=====================================
|
|
|
|
The router flavor extension (``l3-flavors``) adds the ``flavor_id`` attribute
|
|
to routers, allowing requests to be dispatched to different drivers depending
|
|
on the flavor associated with a given router.
|
|
|
|
Resource timestamps
|
|
===================
|
|
|
|
The ``standard-attr-timestamp`` extension adds the ``created_at`` and
|
|
``updated_at`` attributes to all resources that have standard attributes.
|
|
|
|
Router admin state down before update extension
|
|
===============================================
|
|
|
|
The ``router-admin-state-down-before-update`` extension adds the requirement
|
|
that the administrative state of a distributed virtual router (DVR) be set to
|
|
DOWN (``admin_state_up=False``) prior to modifying the ``distributed``
|
|
parameter of the router. The API will return an error response code of 400 if
|
|
the router's ``distributed`` attribute is modified without first setting the
|
|
router's ``admin_state_up=False``.
|
|
This extension requires the ``dvr`` extension.
|
|
|
|
Router availability zone extension
|
|
==================================
|
|
|
|
The ``router_availability_zone`` extension adds the ``availability_zones``
|
|
and ``availability_zone_hints`` attributes to ``routers``, allowing scheduling
|
|
based on availability zones and hints.
|
|
This extension requires ``router`` and ``availability_zone`` extensions.
|
|
|
|
Router service type extension (``router-service-type``)
|
|
=======================================================
|
|
|
|
The ``router-service-type`` extension enables associating a service type with a
|
|
router by introducing the ``service_type_id`` parameter that can be
|
|
used to associate the router with an existing ``service-provider``,
|
|
see `Service providers`_.
|
|
|
|
Tag extension
|
|
=============
|
|
|
|
The ``standard-attr-tag`` adds Tag support for resources with
|
|
standard attributes by adding the ``tags`` attribute
|
|
allowing consumers to associate tags with resources.
|
|
|
|
L3 conntrack helpers extension (``expose-l3-conntrack-helper``)
|
|
===============================================================
|
|
|
|
The router conntrack helper extension (``expose-l3-conntrack-helper``) adds the
|
|
``conntrack_helpers`` field to routers, allowing configurable netfilter CT
|
|
target rules for ``routers``.
|
|
|
|
Router enable ndp proxy extension (router-extend-ndp-proxy)
|
|
===========================================================
|
|
|
|
The ``router-extend-ndp-proxy`` extension adds a ``enable_ndp_proxy`` parameter
|
|
to router. If this parameter is set as ``false``, the router don't support
|
|
``ndp_proxy``.
|
|
|
|
Router gateway IP QoS (qos-gateway-ip)
|
|
======================================
|
|
|
|
The ``qos-gateway-ip`` extension adds ``qos_policy_id`` to the
|
|
``external_gateway_info`` field of routers.
|
|
|
|
Router enable default route ECMP extension (``enable-default-route-ecmp``)
|
|
==========================================================================
|
|
|
|
The ``enable-default-route-ecmp`` extension adds a parameter called
|
|
``enable_default_route_ecmp`` to the router resource which can be used to
|
|
enable or disable automatic configuration of ECMP default routes based on the
|
|
default gateways of subnets accessible from a router's gateway ports (see
|
|
the ``external-gateway-multihoming`` extension).
|
|
|
|
Router enable default route BFD extension (``enable-default-route-bfd``)
|
|
========================================================================
|
|
|
|
The ``enable-default-route-bfd`` extension adds a parameter called
|
|
``enable_default_route_bfd`` to the router resource which can be used to
|
|
enable or disable automatic configuration of BFD for default routes of a router
|
|
created based on the default gateways of subnets accessible from a router's
|
|
gateway ports (see ``enable-default-route-ecmp`` extension).
|
|
|
|
List routers
|
|
============
|
|
|
|
.. rest_method:: GET /v2.0/routers
|
|
|
|
Lists logical routers that the project who submits the request can access.
|
|
|
|
Default policy settings return only those routers that the project
|
|
who submits the request owns, unless an administrative user submits
|
|
the request.
|
|
|
|
Use the ``fields`` query parameter to control which fields are
|
|
returned in the response body. Additionally, you can filter results
|
|
by using query string parameters. For information, see `Filtering
|
|
and Column Selection <https://wiki.openstack.org/wiki/Neutron/APIv2
|
|
-specification#Filtering_and_Column_Selection>`__.
|
|
|
|
Normal response codes: 200
|
|
|
|
Error response codes: 401
|
|
|
|
Request
|
|
-------
|
|
|
|
.. rest_parameters:: parameters.yaml
|
|
|
|
- id: id-query
|
|
- tenant_id: project_id-query
|
|
- project_id: project_id-query
|
|
- name: name-query
|
|
- description: description-query
|
|
- admin_state_up: admin_state_up-query
|
|
- revision_number: revision_number-query
|
|
- sort_dir: sort_dir
|
|
- sort_key: router-sort_key
|
|
- tags: tags-query
|
|
- tags-any: tags-any-query
|
|
- not-tags: not-tags-query
|
|
- not-tags-any: not-tags-any-query
|
|
- fields: fields
|
|
|
|
Response Parameters
|
|
-------------------
|
|
|
|
.. rest_parameters:: parameters.yaml
|
|
|
|
- routers: routers
|
|
- id: router-id-body
|
|
- tenant_id: project_id
|
|
- project_id: project_id
|
|
- name: name
|
|
- description: description
|
|
- admin_state_up: admin_state_up
|
|
- status: router-status
|
|
- external_gateway_info: router-external_gateway_info
|
|
- external_gateways: router-external_gateways
|
|
- revision_number: revision_number
|
|
- routes: router-routes
|
|
- destination: router-destination
|
|
- nexthop: router-nexthop
|
|
- distributed: router-distributed
|
|
- ha: router-ha
|
|
- availability_zone_hints: router-availability_zone_hints
|
|
- availability_zones: router-availability_zones
|
|
- service_type_id: router-service_type_id
|
|
- flavor_id: router-flavor_id
|
|
- created_at: created_at_resource
|
|
- updated_at: updated_at_resource
|
|
- tags: tags
|
|
- conntrack_helpers: router-conntrack_helpers
|
|
- enable_ndp_proxy: router-enable_ndp_proxy
|
|
- enable_default_route_bfd: router-enable_default_route_bfd
|
|
- enable_default_route_ecmp: router-enable_default_route_ecmp
|
|
|
|
Response Example
|
|
----------------
|
|
|
|
.. literalinclude:: samples/routers/routers-list-response.json
|
|
:language: javascript
|
|
|
|
Create router
|
|
=============
|
|
|
|
.. rest_method:: POST /v2.0/routers
|
|
|
|
Creates a logical router.
|
|
|
|
This operation creates a logical router. The logical router does
|
|
not have any internal interface and it is not associated with any
|
|
subnet. You can optionally specify an external gateway for a router
|
|
at create time. The external gateway for the router must be plugged
|
|
into an external network. An external network has its
|
|
``router:external`` extended field set to ``true``. To specify an
|
|
external gateway, the ID of the external network must be passed
|
|
in the ``network_id`` parameter of the ``external_gateway_info``
|
|
attribute in the request body.
|
|
|
|
Normal response codes: 201
|
|
|
|
Error response codes: 400, 401
|
|
|
|
Request
|
|
-------
|
|
|
|
.. rest_parameters:: parameters.yaml
|
|
|
|
- router: router
|
|
- tenant_id: project_id-request
|
|
- project_id: project_id-request
|
|
- name: name-request
|
|
- description: description-request
|
|
- admin_state_up: admin_state_up-request
|
|
- external_gateway_info: router-external_gateway_info-request
|
|
- distributed: router-distributed-request
|
|
- ha: router-ha-request
|
|
- availability_zone_hints: router-availability_zone_hints-request
|
|
- service_type_id: router-service_type_id-request
|
|
- flavor_id: router-flavor_id-optional
|
|
- enable_ndp_proxy: router-enable_ndp_proxy-request
|
|
- enable_default_route_bfd: router-enable_default_route_bfd
|
|
- enable_default_route_ecmp: router-enable_default_route_ecmp
|
|
|
|
Request Example
|
|
---------------
|
|
|
|
.. literalinclude:: samples/routers/router-create-request.json
|
|
:language: javascript
|
|
|
|
Response Parameters
|
|
-------------------
|
|
|
|
.. rest_parameters:: parameters.yaml
|
|
|
|
- router: router
|
|
- id: router-id-body
|
|
- tenant_id: project_id
|
|
- project_id: project_id
|
|
- name: name
|
|
- description: description
|
|
- admin_state_up: admin_state_up
|
|
- status: router-status
|
|
- external_gateway_info: router-external_gateway_info
|
|
- external_gateways: router-external_gateways
|
|
- revision_number: revision_number
|
|
- routes: router-routes
|
|
- destination: router-destination
|
|
- nexthop: router-nexthop
|
|
- distributed: router-distributed
|
|
- ha: router-ha
|
|
- availability_zone_hints: router-availability_zone_hints
|
|
- availability_zones: router-availability_zones
|
|
- service_type_id: router-service_type_id
|
|
- flavor_id: router-flavor_id
|
|
- created_at: created_at_resource
|
|
- updated_at: updated_at_resource
|
|
- tags: tags
|
|
- conntrack_helpers: router-conntrack_helpers
|
|
- enable_ndp_proxy: router-enable_ndp_proxy
|
|
- enable_default_route_bfd: router-enable_default_route_bfd
|
|
- enable_default_route_ecmp: router-enable_default_route_ecmp
|
|
|
|
Response Example
|
|
----------------
|
|
|
|
.. literalinclude:: samples/routers/router-create-response.json
|
|
:language: javascript
|
|
|
|
Show router details
|
|
===================
|
|
|
|
.. rest_method:: GET /v2.0/routers/{router_id}
|
|
|
|
Shows details for a router.
|
|
|
|
Use the ``fields`` query parameter to control which fields are
|
|
returned in the response body. For information, see `Filtering and
|
|
Column Selection <http://specs.openstack.org/openstack/neutron-
|
|
specs/specs/api/networking_general_api_information.html#filtering-
|
|
and-column-selection>`__.
|
|
|
|
Normal response codes: 200
|
|
|
|
Error response codes: 401, 403, 404
|
|
|
|
Request
|
|
-------
|
|
|
|
.. rest_parameters:: parameters.yaml
|
|
|
|
- router_id: router_id
|
|
- fields: fields
|
|
|
|
Response Parameters
|
|
-------------------
|
|
|
|
.. rest_parameters:: parameters.yaml
|
|
|
|
- router: router
|
|
- id: router-id-body
|
|
- tenant_id: project_id
|
|
- project_id: project_id
|
|
- name: name
|
|
- description: description
|
|
- admin_state_up: admin_state_up
|
|
- status: router-status
|
|
- external_gateway_info: router-external_gateway_info
|
|
- external_gateways: router-external_gateways
|
|
- revision_number: revision_number
|
|
- routes: router-routes
|
|
- destination: router-destination
|
|
- nexthop: router-nexthop
|
|
- distributed: router-distributed
|
|
- ha: router-ha
|
|
- availability_zone_hints: router-availability_zone_hints
|
|
- availability_zones: router-availability_zones
|
|
- service_type_id: router-service_type_id
|
|
- flavor_id: router-flavor_id
|
|
- created_at: created_at_resource
|
|
- updated_at: updated_at_resource
|
|
- tags: tags
|
|
- conntrack_helpers: router-conntrack_helpers
|
|
- enable_ndp_proxy: router-enable_ndp_proxy
|
|
- enable_default_route_bfd: router-enable_default_route_bfd
|
|
- enable_default_route_ecmp: router-enable_default_route_ecmp
|
|
|
|
Response Example
|
|
----------------
|
|
|
|
.. literalinclude:: samples/routers/router-show-response.json
|
|
:language: javascript
|
|
|
|
Update router
|
|
=============
|
|
|
|
.. rest_method:: PUT /v2.0/routers/{router_id}
|
|
|
|
Updates a logical router.
|
|
|
|
This operation does not enable the update of router interfaces.
|
|
To update a router interface, use the add router interface and
|
|
remove router interface operations.
|
|
|
|
Normal response codes: 200
|
|
|
|
Error response codes: 400, 401, 404, 412
|
|
|
|
Request
|
|
-------
|
|
|
|
.. rest_parameters:: parameters.yaml
|
|
|
|
- router: router
|
|
- external_gateway_info: router-external_gateway_info-request
|
|
- ha: router-ha-request
|
|
- name: name
|
|
- admin_state_up: admin_state_up
|
|
- router_id: router_id
|
|
- description: description-request
|
|
- routes: router-routes-request
|
|
- distributed: router-distributed-request
|
|
- enable_ndp_proxy: router-enable_ndp_proxy-request
|
|
- enable_default_route_bfd: router-enable_default_route_bfd
|
|
- enable_default_route_ecmp: router-enable_default_route_ecmp
|
|
|
|
Request Example
|
|
---------------
|
|
|
|
.. literalinclude:: samples/routers/router-update-request.json
|
|
:language: javascript
|
|
|
|
Response Parameters
|
|
-------------------
|
|
|
|
.. rest_parameters:: parameters.yaml
|
|
|
|
- router: router
|
|
- id: router-id-body
|
|
- tenant_id: project_id
|
|
- project_id: project_id
|
|
- name: name
|
|
- description: description
|
|
- admin_state_up: admin_state_up
|
|
- status: router-status
|
|
- external_gateway_info: router-external_gateway_info
|
|
- external_gateways: router-external_gateways
|
|
- revision_number: revision_number
|
|
- routes: router-routes
|
|
- destination: router-destination
|
|
- nexthop: router-nexthop
|
|
- distributed: router-distributed
|
|
- ha: router-ha
|
|
- availability_zone_hints: router-availability_zone_hints
|
|
- availability_zones: router-availability_zones
|
|
- service_type_id: router-service_type_id
|
|
- flavor_id: router-flavor_id
|
|
- created_at: created_at_resource
|
|
- updated_at: updated_at_resource
|
|
- tags: tags
|
|
- conntrack_helpers: router-conntrack_helpers
|
|
- enable_ndp_proxy: router-enable_ndp_proxy
|
|
- enable_default_route_bfd: router-enable_default_route_bfd
|
|
- enable_default_route_ecmp: router-enable_default_route_ecmp
|
|
|
|
Response Example
|
|
----------------
|
|
|
|
.. literalinclude:: samples/routers/router-update-response.json
|
|
:language: javascript
|
|
|
|
Delete router
|
|
=============
|
|
|
|
.. rest_method:: DELETE /v2.0/routers/{router_id}
|
|
|
|
Deletes a logical router and, if present, its external gateway interface.
|
|
|
|
This operation fails if the router has attached interfaces.
|
|
Use the remove router interface operation to remove all router
|
|
interfaces before you delete the router.
|
|
|
|
Normal response codes: 204
|
|
|
|
Error response codes: 401, 404, 409, 412
|
|
|
|
Request
|
|
-------
|
|
|
|
.. rest_parameters:: parameters.yaml
|
|
|
|
- router_id: router_id
|
|
|
|
Response
|
|
--------
|
|
|
|
There is no body content for the response of a successful DELETE request.
|
|
|
|
Add interface to router
|
|
=======================
|
|
|
|
.. rest_method:: PUT /v2.0/routers/{router_id}/add_router_interface
|
|
|
|
Adds an internal interface to a logical router.
|
|
This means a specified subnet is attached to a router
|
|
as an internal router interface.
|
|
|
|
Specify the ID of a subnet or port in the request body:
|
|
|
|
- Subnet ID. The gateway IP address for the subnet is used as
|
|
an IP address of the created router interface.
|
|
|
|
- Port ID. The IP address associated with the port is used as
|
|
an IP address of the created router interface.
|
|
|
|
When you specify an IPv6 subnet, this operation adds the subnet to
|
|
an existing internal port with same network ID, on the router. If
|
|
a port with the same network ID does not exist, this operation
|
|
creates a port on the router for that subnet.
|
|
|
|
The limitation of one IPv4 subnet per router port remains, though a
|
|
port can contain any number of IPv6 subnets that belong to the same
|
|
network ID.
|
|
|
|
When you use the ``port-create`` command to add a port and then
|
|
call ``router-interface-add`` with this port ID, this operation
|
|
adds the port to the router if the following conditions are met:
|
|
|
|
- The port has no more than one IPv4 subnet.
|
|
- The IPv6 subnets, if any, on the port do not have same network
|
|
ID as the network ID of IPv6 subnets on any other ports.
|
|
|
|
If you specify both subnet ID and port ID,
|
|
this operation returns the ``Bad Request (400)`` response code.
|
|
|
|
If the port is already in use, this operation returns the
|
|
``Conflict (409)`` response code.
|
|
|
|
This operation returns a port ID that is either:
|
|
|
|
- The same ID that is passed in the request body
|
|
when a port is specified.
|
|
- The ID of a port that this operation creates to attach the
|
|
subnet to the router.
|
|
|
|
After you run this operation, the operation sets:
|
|
|
|
- The ``device_id`` attribute of this port to the router ID
|
|
- The ``device_owner`` attribute to ``network:router_interface``
|
|
|
|
Normal response codes: 200
|
|
|
|
Error response codes: 400, 401, 404, 409
|
|
|
|
Request
|
|
-------
|
|
|
|
.. rest_parameters:: parameters.yaml
|
|
|
|
- router_id: router_id
|
|
- subnet_id: router-subnet_id-request
|
|
- port_id: router-port_id-request
|
|
|
|
Request Example
|
|
---------------
|
|
|
|
.. literalinclude:: samples/routers/router-add-interface-request.json
|
|
:language: javascript
|
|
|
|
or
|
|
|
|
.. literalinclude:: samples/routers/router-add-interface-request-with-port.json
|
|
:language: javascript
|
|
|
|
Response Parameters
|
|
-------------------
|
|
|
|
.. rest_parameters:: parameters.yaml
|
|
|
|
- id: router-id-body
|
|
- subnet_id: router-subnet_id
|
|
- subnet_ids: router-subnet_ids
|
|
- tenant_id: router-project_id-interface
|
|
- project_id: router-project_id-interface
|
|
- port_id: router-port_id
|
|
- network_id: router-network_id-interface
|
|
- tags: tags
|
|
|
|
Response Example
|
|
----------------
|
|
|
|
.. literalinclude:: samples/routers/router-add-interface-response.json
|
|
:language: javascript
|
|
|
|
Remove interface from router
|
|
============================
|
|
|
|
.. rest_method:: PUT /v2.0/routers/{router_id}/remove_router_interface
|
|
|
|
Deletes an internal interface from a logical router.
|
|
|
|
This operation deletes an internal router interface, which detaches
|
|
a subnet from the router. If this subnet ID is the last subnet on
|
|
the port, this operation deletes the port itself. You must specify
|
|
either a subnet ID or port ID in the request body; the
|
|
operation uses this value to identify which router interface to
|
|
deletes.
|
|
|
|
You can also specify both a subnet ID and port ID. If you
|
|
specify both IDs, the subnet ID must correspond to the subnet
|
|
ID of the first IP address on the port. Otherwise, this operation
|
|
returns the ``Conflict (409)`` response code with information about
|
|
the affected router and interface.
|
|
|
|
If you try to delete the router interface for subnets that are used
|
|
by one or more ``routes``, this operation returns the ``Conflict (409)``
|
|
response. In this case, you first need to delete such routes from
|
|
the router.
|
|
|
|
If the router or the subnet and port do not exist or are not
|
|
visible to you, this operation returns the ``Not Found (404)``
|
|
response code. As a consequence of this operation, the operation
|
|
removes the port connecting the router with the subnet from the
|
|
subnet for the network.
|
|
|
|
Normal response codes: 200
|
|
|
|
Error response codes: 400, 401, 404, 409
|
|
|
|
Request
|
|
-------
|
|
|
|
.. rest_parameters:: parameters.yaml
|
|
|
|
- router_id: router_id
|
|
- subnet_id: router-subnet_id-request
|
|
- port_id: router-port_id-request
|
|
|
|
Request Example
|
|
---------------
|
|
|
|
.. literalinclude:: samples/routers/router-remove-interface-request.json
|
|
:language: javascript
|
|
|
|
or
|
|
|
|
.. literalinclude:: samples/routers/router-remove-interface-request-with-port.json
|
|
:language: javascript
|
|
|
|
Response Parameters
|
|
-------------------
|
|
|
|
.. rest_parameters:: parameters.yaml
|
|
|
|
- id: router-id-body
|
|
- subnet_id: router-subnet_id
|
|
- subnet_ids: router-subnet_ids
|
|
- tenant_id: router-project_id-interface
|
|
- project_id: router-project_id-interface
|
|
- port_id: router-port_id
|
|
- network_id: router-network_id-interface
|
|
- tags: tags
|
|
|
|
Response Example
|
|
----------------
|
|
|
|
.. literalinclude:: samples/routers/router-remove-interface-response.json
|
|
:language: javascript
|
|
|
|
Add extra routes to router
|
|
==========================
|
|
|
|
.. rest_method:: PUT /v2.0/routers/{router_id}/add_extraroutes
|
|
|
|
Atomically adds a set of extra routes to the router's already existing
|
|
extra routes.
|
|
|
|
This operation is a variation on updating the router's ``routes``
|
|
parameter. In all ways it works the same, except the extra routes sent
|
|
in the request body do not replace the existing set of extra routes.
|
|
Instead the extra routes sent are added to the existing set of
|
|
extra routes.
|
|
|
|
The use of the add_extraroutes/remove_extraroutes member actions
|
|
is preferred to updating the ``routes`` attribute in all cases when
|
|
concurrent updates to the set of extra routes are possible.
|
|
|
|
The addition's corner cases behave the following way:
|
|
|
|
* When (destinationA, nexthopA) is to be added but it is already present
|
|
that is accepted and the request succeeds.
|
|
|
|
* Two or more routes with the same destination but with different
|
|
nexthops are all accepted.
|
|
|
|
* A route whose destination overlaps the destination of existing routes
|
|
(e.g. ``192.168.1.0/24`` and ``192.168.1.0/22``) can be added and
|
|
existing routes are left untouched.
|
|
|
|
The format of the request body is the same as the format of a PUT
|
|
request to the router changing the ``routes`` parameter only.
|
|
|
|
The response codes and response body are the same as to the update of
|
|
the ``routes`` parameter. That is the whole router object is returned
|
|
including the ``routes`` parameter which represents the result of the
|
|
addition.
|
|
|
|
Normal response codes: 200
|
|
|
|
Error response codes: 400, 401, 404, 412
|
|
|
|
Request
|
|
-------
|
|
|
|
.. rest_parameters:: parameters.yaml
|
|
|
|
- router_id: router_id
|
|
- routes: router-routes
|
|
|
|
Request Example
|
|
---------------
|
|
|
|
.. literalinclude:: samples/routers/router-add-extraroutes-request.json
|
|
:language: javascript
|
|
|
|
Response Parameters
|
|
-------------------
|
|
|
|
.. rest_parameters:: parameters.yaml
|
|
|
|
- id: router-id-body
|
|
- name: router_name
|
|
- routes: router-routes
|
|
|
|
Response Example
|
|
----------------
|
|
|
|
.. literalinclude:: samples/routers/router-add-extraroutes-response.json
|
|
:language: javascript
|
|
|
|
Remove extra routes from router
|
|
===============================
|
|
|
|
.. rest_method:: PUT /v2.0/routers/{router_id}/remove_extraroutes
|
|
|
|
Atomically removes a set of extra routes from the router's already
|
|
existing extra routes.
|
|
|
|
This operation is a variation on updating the router's ``routes``
|
|
parameter. In all ways it works the same, except the extra routes sent
|
|
in the request body do not replace the existing set of extra routes.
|
|
Instead the the extra routes sent are removed from the existing set of
|
|
extra routes.
|
|
|
|
The use of the add_extraroutes/remove_extraroutes member actions
|
|
is preferred to updating the ``routes`` attribute in all cases when
|
|
concurrent updates to the set of extra routes are possible.
|
|
|
|
The removal's corner cases behave the following way:
|
|
|
|
* An extra route is only removed if there is an exact match (including the
|
|
``destination`` and ``nexthop``) between the route sent and the route
|
|
already present.
|
|
|
|
* When (destinationA, nexthopA) is to be removed but it is already missing
|
|
that is accepted and the request succeeds.
|
|
|
|
The format of the request body is the same as the format of a PUT
|
|
request to the router changing the ``routes`` parameter only. However
|
|
the routes sent are not meant to overwrite the whole ``routes``
|
|
parameter, but they are meant to be removed from the existing set.
|
|
|
|
The response codes and response body are the same as to the update of
|
|
the ``routes`` parameter. That is the whole router object is returned
|
|
including the ``routes`` parameter which represents the result of the
|
|
removal.
|
|
|
|
Normal response codes: 200
|
|
|
|
Error response codes: 400, 401, 404, 412
|
|
|
|
Request
|
|
-------
|
|
|
|
.. rest_parameters:: parameters.yaml
|
|
|
|
- router_id: router_id
|
|
- routes: router-routes
|
|
|
|
Request Example
|
|
---------------
|
|
|
|
.. literalinclude:: samples/routers/router-remove-extraroutes-request.json
|
|
:language: javascript
|
|
|
|
Response Parameters
|
|
-------------------
|
|
|
|
.. rest_parameters:: parameters.yaml
|
|
|
|
- id: router-id-body
|
|
- name: router_name
|
|
- routes: router-routes
|
|
|
|
Response Example
|
|
----------------
|
|
|
|
.. literalinclude:: samples/routers/router-remove-extraroutes-response.json
|
|
:language: javascript
|
|
|
|
Add external gateways to router
|
|
===============================
|
|
|
|
.. rest_method:: PUT /v2.0/routers/{router_id}/add_external_gateways
|
|
|
|
Add external gateways to a router in addition to the ones it already
|
|
has.
|
|
|
|
Multiple gateways attached to the same network can be added to the
|
|
same router.
|
|
|
|
The add/update/remove external gateways operations extend the use of
|
|
``router.external_gateway_info`` to manage multiple external gateways.
|
|
The full set of external gateways is exposed in the read-only
|
|
``router.external_gateways`` parameter. ``router.external_gateways``
|
|
contains a list of ``external_gateway_info`` structures like:
|
|
|
|
::
|
|
|
|
[
|
|
{"network_id": ...,
|
|
"external_fixed_ips": [{"ip_address": ..., "subnet_id": ...}, ...],
|
|
"enable_snat": ...},
|
|
...
|
|
]
|
|
|
|
The first item (index 0) of the ``external_gateways`` list is special if a
|
|
router does not have any gateway ports yet:
|
|
|
|
* It will provide data for the compatibility ``router.external_gateway_info``
|
|
field of a router;
|
|
|
|
* This first item sets a router's default route. If ECMP is enabled for
|
|
default routes inferred from gateway port subnets, then all of those
|
|
default routes are used for load-sharing;
|
|
|
|
* The first item is just another extra gateway if the add operation is
|
|
performed when a router already has one or more gateways.
|
|
|
|
The order of the the rest of the list (indexes 1, 2, ...) is irrelevant
|
|
and ignored.
|
|
|
|
The first external gateway can be managed in two
|
|
ways: via ``router.external_gateway_info`` or via
|
|
``add/update/remove_external_gateways``. The other external gateways
|
|
can only be managed via ``add/update/remove_external_gateways``.
|
|
|
|
The format of the request body is the same as the format of the read-only
|
|
``router.external_gateways`` parameter, but wrapped as follows:
|
|
|
|
::
|
|
|
|
{"router": {"external_gateways": EXTERNAL-GATEWAY-LIST}}
|
|
|
|
The response codes and response body are the same as to the update of
|
|
the router. That is the whole router object is returned including the
|
|
``external_gateway_info`` and ``external_gateways`` parameters which
|
|
represents the result of the operation.
|
|
|
|
Changes in ``router.external_gateway_info`` are reflected
|
|
in ``router.external_gateways`` and vice versa. Updating
|
|
``external_gateway_info`` also updates the first element of
|
|
``external_gateways`` and it leaves the rest of ``external_gateways``
|
|
unchanged. Setting ``external_gateway_info`` to an empty value removes
|
|
a single gateway and one of the extra gateways takes its place instead.
|
|
|
|
Normal response codes: 200
|
|
|
|
Error response codes: 400, 401, 404, 412
|
|
|
|
Request Parameters
|
|
------------------
|
|
|
|
.. rest_parameters:: parameters.yaml
|
|
|
|
- router_id: router_id
|
|
- external_gateways: router-external_gateways
|
|
|
|
Request Example
|
|
---------------
|
|
|
|
.. literalinclude:: samples/routers/router-add-external-gateways-request.json
|
|
:language: javascript
|
|
|
|
Response Parameters
|
|
-------------------
|
|
|
|
.. rest_parameters:: parameters.yaml
|
|
|
|
- id: router-id-body
|
|
- name: router_name
|
|
- external_gateways: router-external_gateways
|
|
|
|
Response Example
|
|
----------------
|
|
|
|
.. literalinclude:: samples/routers/router-add-external-gateways-response.json
|
|
:language: javascript
|
|
|
|
Update external gateways of router
|
|
==================================
|
|
|
|
.. rest_method:: PUT /v2.0/routers/{router_id}/update_external_gateways
|
|
|
|
Update some external gateways of router.
|
|
|
|
For general information on the add/update/remove external gateways
|
|
operations see ``add_external_gateways`` above.
|
|
|
|
The external gateways to be updated are identified by the ``network_ids``
|
|
found in the PUT request. The ``external_fixed_ips``, ``enable_snat``,
|
|
fields can be updated. The ``network_id`` field cannot be updated - any
|
|
changes will cause a gateway port to be removed and recreated.
|
|
|
|
The format of the request body is the same as the format of the read-only
|
|
``router.external_gateways`` parameter, but wrapped as follows:
|
|
|
|
::
|
|
|
|
{"router": {"external_gateways": EXTERNAL-GATEWAY-LIST}}
|
|
|
|
The ``enable_snat`` field does not have any effect for extra gateways except
|
|
for the first external gateway in the list.
|
|
|
|
The ``network_id`` field is used to identify a particular gateway port along
|
|
with the ``external_fixed_ips`` field. Specifying just the ``network_id`` field
|
|
is ambiguous: Neutron will attempt to find the matching gateway port but if
|
|
there are multiple matches it will return an error response code.
|
|
|
|
The ``enable_snat`` field can be omitted from the request. Specifying
|
|
``external_fixed_ips`` will result in matching ports based on those
|
|
fixed IPs. If a gateway port has a subset of the specified fixed IPs,
|
|
then the set of IPs will be updated to match the ones in the request.
|
|
Alternatively, if a gateway port has a superset of fixed IPs from the
|
|
request the IPs will be removed from the gateway port.
|
|
|
|
The response codes and response body are the same as to the update of
|
|
the router. That is the whole router object is returned including the
|
|
``external_gateway_info`` and ``external_gateways`` parameters which
|
|
represents the result of the operation.
|
|
|
|
Please note that updating ``external_gateway_info`` also updates
|
|
the first element of ``external_gateways`` and it leaves the rest of
|
|
``external_gateways`` unchanged.
|
|
|
|
Normal response codes: 200
|
|
|
|
Error response codes: 400, 401, 404, 412
|
|
|
|
Request Parameters
|
|
------------------
|
|
|
|
.. rest_parameters:: parameters.yaml
|
|
|
|
- router_id: router_id
|
|
- external_gateways: router-external_gateways
|
|
|
|
Request Example
|
|
---------------
|
|
|
|
.. literalinclude:: samples/routers/router-update-external-gateways-request.json
|
|
:language: javascript
|
|
|
|
Response Parameters
|
|
-------------------
|
|
|
|
.. rest_parameters:: parameters.yaml
|
|
|
|
- id: router-id-body
|
|
- name: router_name
|
|
- external_gateways: router-external_gateways
|
|
|
|
Response Example
|
|
----------------
|
|
|
|
.. literalinclude:: samples/routers/router-update-external-gateways-response.json
|
|
:language: javascript
|
|
|
|
Remove external gateways from router
|
|
====================================
|
|
|
|
.. rest_method:: PUT /v2.0/routers/{router_id}/remove_external_gateways
|
|
|
|
Remove some external gateways from router.
|
|
|
|
For general information on the add/update/remove external gateways
|
|
operations see ``add_external_gateways`` above.
|
|
|
|
The format of the request body is the same as the format of the read-only
|
|
``router.external_gateways`` parameter, but wrapped as follows:
|
|
|
|
::
|
|
|
|
{"router": {"external_gateways": EXTERNAL-GATEWAY-LIST}}
|
|
|
|
However the request body can be partial. Only the ``network_id``
|
|
and ``external_fixed_ips`` fields from the ``external_gateway_info``
|
|
structure is used in order to match the specific gateway ports.
|
|
The ``enable_snat`` key can be present but its value is ignored.
|
|
|
|
Please note that setting ``external_gateway_info`` to an empty value
|
|
also resets ``external_gateways`` to the empty list.
|
|
|
|
Normal response codes: 200
|
|
|
|
Error response codes: 400, 401, 404, 412
|
|
|
|
Request Parameters
|
|
------------------
|
|
|
|
.. rest_parameters:: parameters.yaml
|
|
|
|
- router_id: router_id
|
|
- external_gateways: router-external_gateways
|
|
|
|
Request Example
|
|
---------------
|
|
|
|
.. literalinclude:: samples/routers/router-remove-external-gateways-request.json
|
|
:language: javascript
|
|
|
|
Response Parameters
|
|
-------------------
|
|
|
|
.. rest_parameters:: parameters.yaml
|
|
|
|
- id: router-id-body
|
|
- name: router_name
|
|
- external_gateways: router-external_gateways
|
|
|
|
Response Example
|
|
----------------
|
|
|
|
.. literalinclude:: samples/routers/router-remove-external-gateways-response.json
|
|
:language: javascript
|