From d01d4af212616eebb7f2bbca9350fa293735d0fa Mon Sep 17 00:00:00 2001 From: Diane Fleming Date: Wed, 26 Feb 2014 09:48:40 -0600 Subject: [PATCH] Fix XML and JSON validation errors Change-Id: Iaca924b0015739b5e12c6ca208da8458a4a84a1e author: diane fleming --- v1.0/neutron-api-guide.xml | 1585 +++++++++--------- v1.0/samples/extensions.json | 33 +- v1.0/samples/extensions.xml | 16 +- v1.0/samples/fault.xml | 13 +- v1.0/samples/network-get-res.json | 9 +- v1.0/samples/network-get-res.xml | 5 +- v1.0/samples/network-post-req.json | 7 +- v1.0/samples/network-post-req.xml | 4 +- v1.0/samples/network-post-res.json | 7 +- v1.0/samples/network-post-res.xml | 4 +- v1.0/samples/networks-post-req.json | 8 +- v1.0/samples/port-get-res.json | 9 +- v1.0/samples/port-get-res.xml | 5 +- v1.0/samples/ports-get-detail-res.json | 20 +- v1.0/samples/ports-get-detail-res.xml | 9 +- v1.0/samples/ports-get-res.json | 17 +- v1.0/samples/ports-get-res.xml | 7 +- v2.0/neutron-api-guide.xml | 2 +- v2.0/section_neutron-security-groups-ext.xml | 13 +- 19 files changed, 871 insertions(+), 902 deletions(-) diff --git a/v1.0/neutron-api-guide.xml b/v1.0/neutron-api-guide.xml index 05b414e..fe0f5f6 100644 --- a/v1.0/neutron-api-guide.xml +++ b/v1.0/neutron-api-guide.xml @@ -27,14 +27,13 @@ '> ]> + xmlns:xlink="http://www.w3.org/1999/xlink" + xmlns:xi="http://www.w3.org/2001/XInclude" + xmlns:svg="http://www.w3.org/2000/svg" + xmlns:m="http://www.w3.org/1998/Math/MathML" + xmlns:html="http://www.w3.org/1999/xhtml" + xmlns:db="http://docbook.org/ns/docbook" version="5.0" + status="final" xml:id="Quantum-api-spec"> Quantum API Guide (1.0) Quantum API 1.0 @@ -46,25 +45,41 @@ - 20112012 + 2011 + 2012 + 2013 + 2014 OpenStack Quantum API v1.0 - OpenStack Quantum (virtual network service) - 2012-04-18 + OpenStack Quantum (virtual network + service) + - Copyright details are filled in by the template. + Copyright details are filled in by the + template. - This document is intended for software developers interested in developing - applications using the OpenStack Quantum Layer-2 Networking Service + This document is intended for software developers + interested in developing applications using the + OpenStack Quantum Layer-2 Networking Service (API). - + 2014-02-26 + + + + Corrected samples to fix validation + errors. + + + + + 2012-08-08 @@ -75,7 +90,7 @@ - + 2012-04-18 @@ -90,7 +105,8 @@ - + + 2011-09-22 @@ -98,7 +114,8 @@ Initial release. - First edition of this document. + First edition of this + document. @@ -114,7 +131,8 @@ home page () and the NetStack home page (). + xlink:href="http://wiki.openstack.org/Network" + />). We welcome feedback, comments, and bug reports at bugs.launchpad.net/Quantum. @@ -128,19 +146,19 @@ (Nova), and the integration between the two. The user should also have access to a plugin providing the implementation for the API described in this document. - Two plugins are included in the Quantum distribution: + Two plugins are included in the Quantum + distribution: - Openvswitch - Implementing Quantum API with Open vSwitch + Openvswitch - Implementing Quantum API with + Open vSwitch - Cisco - Implementing Quantum API for Cisco UCS blades and - Nexus switches + Cisco - Implementing Quantum API for Cisco + UCS blades and Nexus switches - - You should also be familiar with: - + You should also be familiar with: ReSTful web services @@ -149,212 +167,165 @@ HTTP/1.1 - JSON and/or XML data serialization formats + JSON and/or XML data serialization + formats
Document Change History - This version of the document replaces and obsoletes all - previous versions. The following table describes the most - recent changes: - + This version of the document replaces and obsoletes + all previous versions. The following table describes + the most recent changes: + +
-
- Glossary - - - - Term - Description - - - - - Entity - - Any piece of hardware or + Glossary + + + + Term + Description + + + + + Entity + Any piece of hardware or software that wants to connect to the network services provided by Quantum. An entity can use Quantum network services by implementing a VIF. - - - Layer-2 network - - A - virtual Ethernet network managed by the - Quantum service. For the time being, - Quantum will manage only Ethernet - networks. - - - - Network - - A virtual network - providing connectivity between entities - such as, a collection of virtual ports - sharing network connectivity. In the - Quantum terminology, a network is always a - Layer-2 network. - - - - Plugin - - - Software component that + + + + Layer-2 + network + + A virtual Ethernet network + managed by the Quantum service. For the + time being, Quantum will manage only + Ethernet networks. + + + Network + A virtual network providing + connectivity between entities such as, a + collection of virtual ports sharing + network connectivity. In the Quantum + terminology, a network is always a Layer-2 + network. + + + + Plug-in + + Software component that provides the actual implementation for Quantum APIs. - - - - Port - - A port on the virtual - network switch represented by a Quantum - virtual Layer-2 network. - - - - - VIF - - A Virtual network InterFace plugged into a port of a - Quantum network. Typically a virtual - network interface belonging to a VM. - - - - Attachment - - The association of an + + + Port + A port on the virtual network + switch represented by a Quantum virtual + Layer-2 network. + + + + VIF + + A Virtual network InterFace + plugged into a port of a Quantum network. + Typically a virtual network interface + belonging to a VM. + + + Attachment + The association of an interface identifier to a logical port, which represents 'plugging' an interface into a port. - - - + + + +
+ +
+ Theory of Operation + This section presents the objects and semantics of + Quantum’s logical model. + Quantum abstracts the physical implementation of the + network, allowing plugins to configure and manage + physical resources. Quantum is a standalone service, + in that it requires no other project within OpenStack + to function correctly. + Further Quantum is agnostic to the entities it + allows to connect. While we anticipate Nova instances + will be a heavy user of Quantum, any entity can make + use of any Quantum created network so long as it + provides an appropriate interfaces for exposing VIFs + to Quantum itself. + Virtual Interfaces (VIF) in the logical model are + analogous to physical network interface cards (NICs). + VIFs are typically owned a managed by an external + service; for instance when Quantum is used for + building OpenStack networks, VIFs would be created, + owned, and managed in Nova. VIFs are connected to + Quantum networks via ports. A port is analogous to a + port on a network switch, and it has an administrative + state. Quantum API allows for controlling the + administrative state of the port, which can be either + 'DOWN' or 'ACTIVE'. + When a VIF is attached to a port the Quantum API + creates an attachment object, which specifies the fact + that a VIF with a given identifier is plugged into the + port. + The Quantum plugin is responsible for managing + virtual and/or physical network switches to implement + the network forwarding connectivity described by the + Quantum networks, ports, and attachments. + VIFs attached to ACTIVE ports are required to have + access to the L2 broadcast domain defined by the + network where they are attached. Each VIF shall be + capable of exchanging traffic with all other entities + attached through ACTIVE ports.
-
- Theory of Operation - This section presents the objects and semantics of - Quantum’s logical model.Quantum abstracts the physical implementation of the network, - allowing plugins to configure and manage physical - resources. Quantum is a standalone service, in that it - requires no other project within OpenStack to function - correctly. - Further Quantum is agnostic to the entities it allows to connect. - While we anticipate Nova instances will be a heavy user of - Quantum, any entity can make use of any Quantum created network - so long as it provides an appropriate interfaces for exposing VIFs - to Quantum itself. - Virtual Interfaces (VIF) in the logical model are analogous to - physical network interface cards (NICs). VIFs are - typically owned a managed by an external service; for - instance when Quantum is used for building OpenStack - networks, VIFs would be created, owned, and managed in - Nova. VIFs are connected to Quantum networks via - ports. A port is analogous to a port on a network - switch, and it has an administrative state. Quantum - API allows for controlling the administrative state of - the port, which can be either 'DOWN' or 'ACTIVE'. - When a VIF is attached to a port the Quantum API creates - an attachment object, which specifies the fact that a VIF with a - given identifier is plugged into the port. - - The Quantum plugin is responsible for managing virtual and/or - physical network switches to implement the network forwarding - connectivity described by the Quantum networks, ports, and - attachments. - - VIFs attached to ACTIVE ports are required to have access to the - L2 broadcast domain defined by the network where they are attached. - Each VIF shall be capable of exchanging traffic with all other - entities attached through ACTIVE ports. - -
- Concepts - - To use the Quantum API effectively, developers should understand - the concepts introduced in this chapter. - -
Network - - Each tenant can define one or more networks. A network is a virtual - isolated layer-2 broadcast domain reserved to the tenant. - A tenant can create several ports for a network, and plug - virtual interfaces into these ports. - + To use the Quantum API effectively, developers should + understand the concepts introduced in this chapter. +
+ Network + Each tenant can define one or more networks. A + network is a virtual isolated layer-2 broadcast domain + reserved to the tenant. A tenant can create several + ports for a network, and plug virtual interfaces into + these ports.
-
Port - - A port represents a virtual switch port on a logical - network switch where all the interfaces attached to a given - network are connected. - - A port has an administrative state which - is either 'DOWN' or 'ACTIVE'. Ports which are administratively - down will not be able to receive/send traffic. - +
+ Port + A port represents a virtual switch port on a logical + network switch where all the interfaces attached to a + given network are connected. + A port has an administrative state which is either + 'DOWN' or 'ACTIVE'. Ports which are administratively + down will not be able to receive/send traffic.
-
Attachment +
+ Attachment An attachment represents an interface plugged into a logical port. At any time at most one attachment can - be plugged into a given port.An attachment typically identified a virtual network interface. - Network interfaces are typically defined in an - external services which uses Quantum, for instance the - OpenStack Compute service, Nova. + be plugged into a given port. + An attachment typically identified a virtual network + interface. Network interfaces are typically defined in + an external services which uses Quantum, for instance + the OpenStack Compute service, Nova.
@@ -375,16 +346,17 @@ Authentication The current version of the OpenStack Quantum service does not require that each request will include the - credentials of the user submitting the request.However, Quantum deployments can support several authentication - schemes (OAuth, Basic Auth, Token). The authentication - scheme used is determined by the provider of the - Quantum service. Please contact your provider to - determine the best way to authenticate against this - API. - Ideally, middleware modules for Authentication and/or Authorization - should be inserted in the first stages of the Quantum pipeline - (available in etc/quantum.conf). - + credentials of the user submitting the request. + However, Quantum deployments can support several + authentication schemes (OAuth, Basic Auth, Token). The + authentication scheme used is determined by the + provider of the Quantum service. Please contact your + provider to determine the best way to authenticate + against this API. + Ideally, middleware modules for Authentication + and/or Authorization should be inserted in the first + stages of the Quantum pipeline (available in + etc/quantum.conf). Some authentication schemes may require that the API operate using SSL over HTTP (HTTPS). @@ -392,29 +364,24 @@
- URI structure - - Each request to the OpenStack Quantum API must refer to a - specific version of the API itself, and it must also - identify the tenant for which the request is being sent. - - - This information is specified in the URI. The URI - for each request to the OpenStack Quantum API should be - prefixed with the API version identifier and the tenant - identifier, as follows: - - - /{Quantum-version}/tenants/{tenant-id}/{Quantum-API-entity} - - - As an example, the following URI represents a request for - retrieving all the networks configured for the tenant "ABC" - using the 1.0 API. - - - /v1.0/ABC/networks - + URI structure + Each request to the OpenStack Quantum API must refer + to a specific version of the API itself, and it must + also identify the tenant for which the request is + being sent. + This information is specified in the URI. The URI + for each request to the OpenStack Quantum API should + be prefixed with the API version identifier and the + tenant identifier, as follows: + + /{Quantum-version}/tenants/{tenant-id}/{Quantum-API-entity} + + As an example, the following URI represents a + request for retrieving all the networks configured for + the tenant "ABC" using the 1.0 API. + + /v1.0/ABC/networks +
Request/Response Types @@ -424,10 +391,11 @@ using the Content-Type header, the Accept header or adding an .xml or .json extension - to the request URI.If conflicting formats are specified in headers and/or format - extensions, the latter takes precedence. XML is - currently the default format for both requests and - responses. + to the request URI. + If conflicting formats are specified in headers + and/or format extensions, the latter takes precedence. + XML is currently the default format for both requests + and responses. @@ -455,7 +423,8 @@
JSON and XML Response Formats
Request/Response with Headers: JSON - Request: + Request: + POST /v1.0/tenants/tenantX/networks HTTP/1.1 Host 127.0.0.1:9696 Accept text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8 @@ -463,7 +432,8 @@ Content-Type application/json; charset=UTF-8 Content-Length 30 - Response: + Response: + HTTP/1.1 200 Accepted Content-Type application/json Content-Length 59 @@ -479,7 +449,8 @@ Content-Length 59 example above. Request/Response with Headers: XML - Request: + Request: + POST /v1.0/tenants/tenantX/networks HTTP/1.1 Host 127.0.0.1:9696 Accept text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8 @@ -487,7 +458,8 @@ Content-Type application/xml; charset=UTF-8 Content-Length 22 - Response: + Response: + HTTP/1.1 200 Accepted Content-Type application/xml Content-Length 52 @@ -497,7 +469,8 @@ Content-Length 52 Request/Response with Extensions: JSON - Request: + Request: + POST /v1.0/tenants/tenantX/networks.json HTTP/1.1 Host 127.0.0.1:9696 Accept text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8 @@ -505,7 +478,8 @@ Content-Type application/json; charset=UTF-8 Content-Length 30 - Response: + Response: + HTTP/1.1 200 Accepted Content-Type application/json Content-Length 59 @@ -514,50 +488,51 @@ Content-Length 59
- Asynchronous Behavior by Quantum Plugins - - The Quantum API presents a logical model of network connectivity - consisting of networks, ports, and attachments. It is up to - the Quantum plugin to communicate with all managed virtual - and/or physical switches to ensure that these devices implement - packet forwarding behavior consistent with the logical model. - - The plugin's task of mapping from the logical model to the physical - world might happen asynchronously. This means that when an API - client modifies the logical model using an HTTP POST, PUT, - or DELETE, the API call may return prior to the plugin performing - any modifications to underlying virtual and/or physical switching - devices. The only guarantee an API client has is that all - subsequent API calls will properly reflect the changed logical model. - - As a concrete example, consider the case where a client uses an HTTP - PUT to set the attachment for a port. There is no guarantee that - packets sent by the interface named in the attachment will be - forwarded immediately once the HTTP call returns. - However, there is a guarantee that a subsequent HTTP GET to view - the attachment on that port would return the new attachment value. - - - Future versions of the API may expose a notion of an "operational status" - on a logical entity like a network or port. - - This would indicate whether the Quantum plugin had successfully - configured virtual and/or physical switches in order to implement - the network connectivity described by that element of the logical - model. - - For example, a port might have an operational status of "DOWN" - because the VM interface specified as an attachment was not - currently running on any physical server. - + Asynchronous Behavior by Quantum Plugins + The Quantum API presents a logical model of network + connectivity consisting of networks, ports, and + attachments. It is up to the Quantum plugin to + communicate with all managed virtual and/or physical + switches to ensure that these devices implement packet + forwarding behavior consistent with the logical + model. + The plug-in task of mapping from the logical model + to the physical world might happen asynchronously. + This means that when an API client modifies the + logical model using an HTTP POST, PUT, or DELETE, the + API call may return prior to the plugin performing any + modifications to underlying virtual and/or physical + switching devices. The only guarantee an API client + has is that all subsequent API calls will properly + reflect the changed logical model. + As a concrete example, consider the case where a + client uses an HTTP PUT to set the attachment for a + port. There is no guarantee that packets sent by the + interface named in the attachment will be forwarded + immediately once the HTTP call returns. However, there + is a guarantee that a subsequent HTTP GET to view the + attachment on that port would return the new + attachment value. + + Future versions of the API may expose a notion + of an "operational status" on a logical entity + like a network or port. + This would indicate whether the Quantum plugin + had successfully configured virtual and/or + physical switches in order to implement the + network connectivity described by that element of + the logical model. + For example, a port might have an operational + status of "DOWN" because the VM + interface specified as an attachment was not + currently running on any physical server. +
Versions - - The Quantum API uses a URI based versioning scheme. + The Quantum API uses a URI based versioning scheme. The first element of the URI path contains the target - version identifier. - + version identifier. Request with URI versioning GET /v1.0/tenants/tenantX/networks HTTP/1.1 @@ -568,12 +543,10 @@ Content-Length 22 - - Available API versions can be retrieved - by performing a &GET; on the root URL - (i.e. with the version and everything to the - right of it truncated) of the Quantum Service. - + Available API versions can be retrieved by + performing a &GET; on the root URL (i.e. with the + version and everything to the right of it truncated) + of the Quantum Service. Versions List Request/Response (XML) @@ -593,47 +566,37 @@ GET / HTTP/1.1 Host 127.0.0.1:9696 Content-Type application/json - +
Extensions - - The Quantum API is extensible. Extensions - serve several purposes: - + The Quantum API is extensible. Extensions serve + several purposes: - - They allow the introduction of new - features in the API without requiring a - version change; + They allow the introduction of new features + in the API without requiring a version change; - - They allow the introduction of vendor specific - niche functionality - + They allow the introduction of vendor + specific niche functionality - - They act as a proving ground for experimental - functionalities which might be included in a future - version of the API. + They act as a proving ground for + experimental functionalities which might be + included in a future version of the API. - - Applications can programmatically - determine what extensions are available by performing - a &GET; on the /v1.0/extensions URI. - Note that this is a versioned request — that is, - an extension available in one API version may not be - available in another. - + Applications can programmatically determine what + extensions are available by performing a &GET; on the + /v1.0/extensions URI. Note that this + is a versioned request — that is, an extension + available in one API version may not be available in + another. Extensions Response: XML @@ -641,21 +604,25 @@ Content-Type application/json Extensions Response: JSON - + - - Extensions may also be queried individually by their unique alias by performing - a &GET; on the /v1.0/extensions/alias_name. This provides the simplest - method of checking if an extension is available as an unavailable extension will issue an - itemNotFound (404) response. - + Extensions may also be queried individually by their + unique alias by performing a &GET; on the + /v1.0/extensions/alias_name. This + provides the simplest method of checking if an + extension is available as an unavailable extension + will issue an itemNotFound (404) response. - Existing core API resources can be extended with new actions or extra data in request/response of existing actions. - Further new resources can also be added as extensions. - Extensions usually have vendor specific tags that prevent clash with other extensions. - Availability of an extension will vary with deployments and the specific plugin in use. - + + Existing core API resources can be extended with + new actions or extra data in request/response of + existing actions. Further new resources can also + be added as extensions. Extensions usually have + vendor specific tags that prevent clash with other + extensions. Availability of an extension will vary + with deployments and the specific plugin in use. + + Applications should be prepared to ignore @@ -668,130 +635,144 @@ Content-Type application/json
Faults - - When an error occurs at request time, the system - will return an HTTP error response code denoting - the type of error. The system will also return - additional information about the fault in the body - of the response. - - - "Network not found" fault Response (XML) - - - - - "Network not found" fault Response (XML) - - - The error code is returned in the body of the response for convenience. The - message section returns a human-readable message that is appropriate for display to - the end user. The detail section is optional and may contain information—for example, a stack trace—to - assist in tracking down an error. - - - The root element of the fault (e.g. networkNotFound) - may change depending on the type of error. The - following is a list of possible elements along with - their associated error codes. - - - - - - - - - - - - - - - - - - - - - + + + + + + + + + + + + + +
Fault Elements and Error Codes
Fault ElementError CodeDescription
BadRequest400Malformed request body. The Quantum service is unable - to parse the contents of the request body.
Unauthorized401User has not provided + When an error occurs at request time, the system + will return an HTTP error response code denoting the + type of error. The system will also return additional + information about the fault in the body of the + response. + + "Network not found" fault Response + (XML) + + + + + "Network not found" fault Response + (XML) + + + The error code is returned in the body of the + response for convenience. The message section returns + a human-readable message that is appropriate for + display to the end user. The detail section is + optional and may contain information—for + example, a stack trace—to assist in tracking + down an error. + The root element of the fault (e.g. networkNotFound) + may change depending on the type of error. The + following is a list of possible elements along with + their associated error codes. + + + + + + + + + + + + + + + + + + + + + + + - - - - - - - - - - - - - - - - - - - - + + + + + + + + + + + + + + + + + + + + + + + + + - - - - - - - - - - + + + + + + + + + + + + - - - - - - - - - - - - -
Fault Elements and Error Codes
Fault ElementError CodeDescription
BadRequest400Malformed request body. The + Quantum service is unable to parse the + contents of the request body.
Unauthorized401User has not provided authentication credentials. If authentication is provided by the Keystone identity service, this might mean that either no authentication token has been supplied in the request, or that the token itself is either invalid or expired.
Forbidden 403 The user does not have the necessary rights to - execute the requested operation.
ItemNotFound404The requested resource - does not exist on the Quantum API server.
NetworkNotFound420 The specified network has not been created or has - been removed.
NetworkInUse421The specified network has +
Forbidden403The user does not have the + necessary rights to execute the requested + operation.
ItemNotFound404The requested resource does + not exist on the Quantum API server.
NetworkNotFound420The specified network has not + been created or has been removed.
NetworkInUse421The specified network has attachments plugged into one or more of its ports.
PortNotFound430The specified port has not been created or has been - removed.
RequestedStateInvalid431Indicates a request to - change port to an administrative state not +
PortNotFound430The specified port has not + been created or has been removed.
RequestedStateInvalid431Indicates a request to change + port to an administrative state not currently supported.
PortInUse --> 432The specified port cannot be removed as there is an - attachment plugged in it.
AlreadyAttached440Attachment is already - plugged into another port.
- - - The error codes 401 and 403 will be returned only if some - Authentication/Authorization system has been enabled in the - Quantum pipeline - - +
PortInUse --> + 432The specified port cannot be + removed as there is an attachment plugged + in it.
AlreadyAttached440Attachment is already plugged + into another port.
+ + The error codes 401 and 403 will be returned + only if some Authentication/Authorization system + has been enabled in the Quantum pipeline +
API Operations
Networks - - This section describes the operations exposed by Quantum API for - manipulating network resources. - + This section describes the operations exposed by + Quantum API for manipulating network resources.
List Networks @@ -805,7 +786,8 @@ Content-Type application/json &GET; - /tenants/tenant-id/networks + /tenants/tenant-id/networks Lists summary of networks configured in Quantum for a given tenant, identified by @@ -823,28 +805,32 @@ Content-Type application/json currently defined in Quantum for the tenant specified in the request URI. The list provides the unique identifier of each network configured - for the tenant specified in the resource URI. + for the tenant specified in the resource + URI. - TenantId is a unique tenant - identifier. The Quantum service does not directly - manages tenants. Tenant management should be - performed by the identity service - + TenantId is a unique + tenant identifier. The Quantum service does + not directly manages tenants. Tenant + management should be performed by the identity + service - This operation does not require a request body. + This operation does not require a request + body. - Networks List Request/Response (XML) + Networks List Request/Response + (XML) Request: - GET /tenants/XYZ/networks.xml + GET /tenants/XYZ/networks.xml Response: - Networks List Request/Response (JSON) + Networks List Request/Response + (JSON) Request: - GET /tenants/XYZ/networks.json + GET /tenants/XYZ/networks.json Response: @@ -862,44 +848,42 @@ Content-Type application/json &GET; - /tenants/tenant-id/networks/detail + /tenants/tenant-id/networks/detail Lists more detailed information about networks configured in Quantum for a given tenant, - identified by tenant-id. + identified by + tenant-id. - - Normal Response Code(s): - 200 + Normal Response Code(s): + 200 - - Error Response Code(s): - Unauthorized (401), - Forbidden (403) - - - This operation returns the list of all networks currently - defined in Quantum; for each network, its identifier - and name are returned. - - This operation does not require a request body. + Error Response Code(s): Unauthorized + (401), Forbidden + (403) + This operation returns the list of all networks + currently defined in Quantum; for each network, + its identifier and name are returned. + This operation does not require a request + body. Networks List Details Request/Response (XML) Request: - GET /tenants/XYZ/networks/detail.xml + GET /tenants/XYZ/networks/detail.xml Response: - + Networks List Details Request/Response (JSON) Request: - GET /tenants/XYZ/networks/detail.json + GET /tenants/XYZ/networks/detail.json Response: @@ -917,7 +901,8 @@ Content-Type application/json &GET; - /tenants/tenant-id/networks/network-id + /tenants/tenant-id/networks/network-id Lists information for a specific network, identified by network-id, @@ -926,31 +911,31 @@ Content-Type application/json - - Normal Response Code(s): - 200 + Normal Response Code(s): + 200 Error Response Code(s): Unauthorized (401), Forbidden (403), NetworkNotFound (420) - - This operation returns the identifier and the name for a - specific network configured in Quantum. - - This operation does not require a request body. + This operation returns the identifier and the + name for a specific network configured in + Quantum. + This operation does not require a request + body. Show Network Request/Response (XML) Request: - GET /tenants/XYZ/networks/8bec1293-16bd-4568-ba75-1f58bec0b4c3.xml + GET /tenants/XYZ/networks/8bec1293-16bd-4568-ba75-1f58bec0b4c3.xml Response: - + - Show Network Request/Response (JSON) + Show Network Request/Response + (JSON) Request: - GET /tenants/XYZ/networks/8bec1293-16bd-4568-ba75-1f58bec0b4c3.json + GET /tenants/XYZ/networks/8bec1293-16bd-4568-ba75-1f58bec0b4c3.json Response: @@ -968,7 +953,8 @@ Content-Type application/json &GET; - /tenants/tenant-id/networks/network-id/detail + /tenants/tenant-id/networks/network-id/detail Lists detailed information for a specific network, identified by network-id, @@ -977,41 +963,40 @@ Content-Type application/json - - Normal Response Code(s): - 200 + Normal Response Code(s): + 200 Error Response Code(s): Unauthorized (401), Forbidden (403), NetworkNotFound (420) - - This operation returns detailed information concerning the - network specified in the request URI. Returned data include - the full list of ports configured for the network - and attachments plugged into such ports. - - If no attachment is plugged into a port, the response will - not include an attachment child element for that - port. - - This operation does not require a request body. + This operation returns detailed information + concerning the network specified in the request + URI. Returned data include the full list of ports + configured for the network and attachments plugged + into such ports. + If no attachment is plugged into a port, the + response will not include an + attachment child element for that + port. + This operation does not require a request + body. Show Network Details Request/Response (XML) Request: - GET /tenants/XYZ/networks/8bec1293-16bd-4568-ba75-1f58bec0b4c3/detail.xml + GET /tenants/XYZ/networks/8bec1293-16bd-4568-ba75-1f58bec0b4c3/detail.xml Response: - + Show Network Details Request/Response (JSON) Request: - GET /tenants/XYZ/networks/8bec1293-16bd-4568-ba75-1f58bec0b4c3/detail.json + GET /tenants/XYZ/networks/8bec1293-16bd-4568-ba75-1f58bec0b4c3/detail.json Response: - +
@@ -1027,7 +1012,8 @@ Content-Type application/json &POST; - /tenants/tenant-id/networks + /tenants/tenant-id/networks Creates a new logical layer-2 network for the tenant identified by @@ -1035,62 +1021,58 @@ Content-Type application/json - - Normal Response Code(s): - 200 + Normal Response Code(s): + 200 Error Response Code(s): BadRequest (400) Unauthorized (401), Forbidden (403) - - This operation creates a Layer-2 network in - Quantum based on the information provided in the request body. - - Quantum validates the request, and dispatches it to the plugin, - and then returns the unique identifier of the network to the - caller. Although the network API entity can be immediately used - for other operations, this does not guarantee that the network - will be available when the API call returns, as this depends - on the particular plugin implementation. - - If the validation phase fails, the network object is not - created at all, and a 400 error is returned to the caller. - - - - The Quantum API v1.0 does not provide an interface - for checking the progress of asynchronous operations - performed by plugins. - - - This will be addressed in future releases of the - Quantum API. - - - - The body for this request must contain a Network object - specifying a symbolic name for the network. - + This operation creates a Layer-2 network in + Quantum based on the information provided in the + request body. + Quantum validates the request, and dispatches it + to the plugin, and then returns the unique + identifier of the network to the caller. Although + the network API entity can be immediately used for + other operations, this does not guarantee that the + network will be available when the API call + returns, as this depends on the particular plugin + implementation. + If the validation phase fails, the network + object is not created at all, and a 400 error is + returned to the caller. + + The Quantum API v1.0 does not provide an + interface for checking the progress of + asynchronous operations performed by + plugins. + This will be addressed in future releases of + the Quantum API. + + The body for this request must contain a Network + object specifying a symbolic name for the + network. - Create Network Request/Response (XML) + Create Network Request/Response + (XML) Request: - POST /tenants/XYZ/networks.xml - - + POST /tenants/XYZ/networks.xml + Response: - + - Create Network Request/Response (JSON) + Create Network Request/Response + (JSON) Request: - POST /tenants/XYZ/networks.json - + POST /tenants/XYZ/networks.json + Response: - +
-
+
Update Network @@ -1103,40 +1085,37 @@ Content-Type application/json &PUT; - /tenants/tenant-id/networks/network-id + /tenants/tenant-id/networks/network-id Renames the network identified by - network-id for - the tenant identified by + network-id + for the tenant identified by tenant-id. - - Normal Response Code(s): - 204 + Normal Response Code(s): + 204 Error Response Code(s): BadRequest (400) Unauthorized (401), Forbidden (403) NetworkNotFound (420) - - This operation renames a Quantum network using the data - provided in the request body. - - - The body for this request must contain a Network object - specifying a symbolic name for the network. The network - entity specified in the request body can contain the - network's identifier as well, even if it is not required, - as the identifier must be expressed on the URI; in this - case the identifier in the request body will be ignored. - + This operation renames a Quantum network using + the data provided in the request body. + The body for this request must contain a Network + object specifying a symbolic name for the network. + The network entity specified in the request body + can contain the network's identifier as well, even + if it is not required, as the identifier must be + expressed on the URI; in this case the identifier + in the request body will be ignored. Update Network Request (XML) Request: - PUT /tenants/XYZ/networks/158233b0-ca9a-40b4-8614-54a4a99d47d1.xml + PUT /tenants/XYZ/networks/158233b0-ca9a-40b4-8614-54a4a99d47d1.xml Response: No data is returned in the @@ -1145,12 +1124,12 @@ Content-Type application/json Update Network Request (JSON) Request: - PUT /tenants/XYZ/networks/158233b0-ca9a-40b4-8614-54a4a99d47d1.json - + PUT /tenants/XYZ/networks/158233b0-ca9a-40b4-8614-54a4a99d47d1.json + Response: No data is returned in the response body. - +
Delete Network @@ -1165,11 +1144,12 @@ Content-Type application/json &DELETE; - /tenants/tenant-id/networks/network-id + /tenants/tenant-id/networks/network-id Destroys the network identified by - network-id for - the tenant identified by + network-id + for the tenant identified by tenant-id. @@ -1189,17 +1169,20 @@ Content-Type application/json attachments plugged in it. If all ports on the networks are unattached, they will be destroyed together with the network itself. - As for the create operation there is no guarantee that the - plugin will have completely removed the network - when the call returns. Quantum forwards the - request to the plugin, which will then destroy the - network. - This operation cannot be undone. - This operation does not require a request body. + As for the create operation there is no + guarantee that the plugin will have completely + removed the network when the call returns. Quantum + forwards the request to the plugin, which will + then destroy the network. + + This operation cannot be undone. + + This operation does not require a request + body. Delete Network Request (XML) Request: - DELETE /tenants/XYZ/networks/158233b0-ca9a-40b4-8614-54a4a99d47d1.xml + DELETE /tenants/XYZ/networks/158233b0-ca9a-40b4-8614-54a4a99d47d1.xml Response: No data is returned in the response body. @@ -1207,20 +1190,18 @@ Content-Type application/json Delete Network Request (JSON) Request: - DELETE /tenants/XYZ/networks/158233b0-ca9a-40b4-8614-54a4a99d47d1.json + DELETE /tenants/XYZ/networks/158233b0-ca9a-40b4-8614-54a4a99d47d1.json Response: No data is returned in the response body. - +
Ports - - This section describes the operations exposed by Quantum API for - manipulating port resources. - -
+ This section describes the operations exposed by + Quantum API for manipulating port resources. +
List Ports @@ -1233,12 +1214,13 @@ Content-Type application/json &GET; - /tenants/tenant-id/networks/ - network-id/ports - - Lists all the ports currently defined for a Quantum network, - identified by network-id - + /tenants/tenant-id/networks/ + network-id/ports + Lists all the ports + currently defined for a Quantum + network, identified by + network-id @@ -1254,24 +1236,25 @@ Content-Type application/json response reports its unique identifier. If no ports have been created on the network an empty list will be returned. - This operation does not require a request body. + This operation does not require a request + body. Port List Request/Response (XML) Request: - GET /tenants/XYZ/networks/158233b0-ca9a-40b4-8614-54a4a99d47d1/ports.xml + GET /tenants/XYZ/networks/158233b0-ca9a-40b4-8614-54a4a99d47d1/ports.xml Response: - + Port List Request/Response (JSON) Request: - GET /tenants/XYZ/networks/158233b0-ca9a-40b4-8614-54a4a99d47d1/ports.json + GET /tenants/XYZ/networks/158233b0-ca9a-40b4-8614-54a4a99d47d1/ports.json Response: - +
-
+
List Ports Details @@ -1284,12 +1267,12 @@ Content-Type application/json &GET; - /tenants/tenant-id/networks/network-id/ports/detail + /tenants/tenant-id/networks/network-id/ports/detail Lists detailed information for all the ports currently defined for the network identified by - network-id. - + network-id. @@ -1306,25 +1289,27 @@ Content-Type application/json the current administrative state. If no ports have been created on the network an empty list will be returned. - This operation does not require a request body. + This operation does not require a request + body. - Port List Details Request/Response (XML) + Port List Details Request/Response + (XML) Request: - GET /tenants/XYZ/networks/158233b0-ca9a-40b4-8614-54a4a99d47d1/ports/detail.xml + GET /tenants/XYZ/networks/158233b0-ca9a-40b4-8614-54a4a99d47d1/ports/detail.xml Response: - + - Port List Details Request/Response (JSON) + Port List Details Request/Response + (JSON) Request: - GET /tenants/XYZ/networks/158233b0-ca9a-40b4-8614-54a4a99d47d1/ports/detail.json + GET /tenants/XYZ/networks/158233b0-ca9a-40b4-8614-54a4a99d47d1/ports/detail.json Response: - - +
-
+
Show Port @@ -1337,9 +1322,10 @@ Content-Type application/json &GET; - /tenants/tenant-id/networks/ - network-id/ports/ - port-id + /tenants/tenant-id/networks/ + network-id/ports/ + port-id Retrieves the port port-id configured for the network @@ -1361,19 +1347,20 @@ Content-Type application/json the current administrative state for a specific port configured for the network specified in the request URI. - This operation does not require a request body. + This operation does not require a request + body. Show Port Request/Response (XML) Request: - GET /tenants/33/networks/158233b0-ca9a-40b4-8614-54a4a99d47d1/ports/98017ddc-efc8-4c25-a915-774b2a633855.xml + GET /tenants/33/networks/158233b0-ca9a-40b4-8614-54a4a99d47d1/ports/98017ddc-efc8-4c25-a915-774b2a633855.xml Response: - + Show Port Request/Response (JSON) Request: - GET /tenants/33/networks/158233b0-ca9a-40b4-8614-54a4a99d47d1/ports/98017ddc-efc8-4c25-a915-774b2a633855.json + GET /tenants/33/networks/158233b0-ca9a-40b4-8614-54a4a99d47d1/ports/98017ddc-efc8-4c25-a915-774b2a633855.json Response: @@ -1391,9 +1378,10 @@ Content-Type application/json &GET; - /tenants/tenant-id/networks/ - network-id/ports/ - port-id/detail + /tenants/tenant-id/networks/ + network-id/ports/ + port-id/detail Retrieves detailed information for the port port-id @@ -1405,37 +1393,39 @@ Content-Type application/json Normal Response Code(s): - 200 - - Error Response Code(s): - Unauthorized (401), - Forbidden (403), - NetworkNotFound (420), - PortNotFound (430) + 200 + Error Response Code(s): Unauthorized + (401), Forbidden + (403), NetworkNotFound + (420), PortNotFound + (430) This operation provides at least the identifier and the current administrative state for specific - port configured for a given network.If an attachment is plugged into the port, this operation will - return the identifier of the attachment as well. - This operation does not require a request body. + port configured for a given network. + If an attachment is plugged into the port, this + operation will return the identifier of the + attachment as well. + This operation does not require a request + body. Show Port Details Request/Response (XML) Request: - GET /tenants/33/networks/158233b0-ca9a-40b4-8614-54a4a99d47d1/ports/98017ddc-efc8-4c25-a915-774b2a633855/detail.xml + GET /tenants/33/networks/158233b0-ca9a-40b4-8614-54a4a99d47d1/ports/98017ddc-efc8-4c25-a915-774b2a633855/detail.xml Response: - + Show Port Details Request/Response (JSON) Request: - GET /tenants/33/networks/158233b0-ca9a-40b4-8614-54a4a99d47d1/ports/98017ddc-efc8-4c25-a915-774b2a633855/detail.json + GET /tenants/33/networks/158233b0-ca9a-40b4-8614-54a4a99d47d1/ports/98017ddc-efc8-4c25-a915-774b2a633855/detail.json Response: - +
-
+
Create Port @@ -1448,8 +1438,9 @@ Content-Type application/json &POST; - /tenants/tenant-id/networks/ - network-id/ports + /tenants/tenant-id/networks/ + network-id/ports Creates a port on the network specified in the request URI, identified by @@ -1460,57 +1451,64 @@ Content-Type application/json Normal Response Code(s): 200 - Error Response Code(s): - BadRequest (400), - Unauthorized (401), - Forbidden (403), - NetworkNotFound (420), - RequestedStateInvalid (431) - + Error Response Code(s): BadRequest + (400), Unauthorized + (401), Forbidden + (403), NetworkNotFound + (420), + RequestedStateInvalid (431) This operation creates a port on a Quantum network based on the information provided in the request body. Quantum validates the request, and dispatches the request to the plugin, which creates the port and attaches it to the - appropriate network.This operation could not be implemented for some plugins as the - number of ports available might be fixed when the - network is created.If the validation phase fails, the port object is not created at - all, and a BadRequest error is - returned to the caller.The operation returns a port with an identifier, and set its - administrative state set to DOWN, - unless a state has been explicitly specified in - the request body. - This operation does not guarantee that the port - has been actually created when the calls returns, - as the plugin might still be performing the - necessary operations on the network - infrastructure. However, the port entity can be - immediately used for API operations. - The request body is not required for this operation, but it can - optionally contain the administrative state for - the port being created, which can be either - DOWN or ACTIVE. The - administrative state should be encapsulated into a - Port object within the request body, as shown in - the example below. + appropriate network. + This operation could not be implemented for some + plugins as the number of ports available might be + fixed when the network is created. + If the validation phase fails, the port object + is not created at all, and a + BadRequest error is returned to + the caller. + The operation returns a port with an identifier, + and set its administrative state set to + DOWN, unless a state has been + explicitly specified in the request body. + + This operation does not guarantee that the + port has been actually created when the calls + returns, as the plugin might still be + performing the necessary operations on the + network infrastructure. However, the port + entity can be immediately used for API + operations. + + The request body is not required for this + operation, but it can optionally contain the + administrative state for the port being created, + which can be either DOWN or + ACTIVE. The administrative state + should be encapsulated into a Port object within + the request body, as shown in the example + below. Create Port Request/Response (XML) Request: - POST /tenants/33/networks/158233b0-ca9a-40b4-8614-54a4a99d47d1/ports.xml - + POST /tenants/33/networks/158233b0-ca9a-40b4-8614-54a4a99d47d1/ports.xml + Response: - + Create Port Request/Response (JSON) Request: - POST /tenants/33/networks/158233b0-ca9a-40b4-8614-54a4a99d47d1/ports.json - + POST /tenants/33/networks/158233b0-ca9a-40b4-8614-54a4a99d47d1/ports.json + Response:
-
+
Update Port @@ -1533,52 +1531,48 @@ Content-Type application/json - - Normal Response Code(s): - 204 + Normal Response Code(s): + 204 - - Error Response Code(s): - BadRequest (400), - Unauthorized (401), - Forbidden (403), - NetworkNotFound (420), - PortNotFound (430), - RequestedStateInvalid (431) - - - This operation sets the administrative state for a port. - Currently Quantum recognizes two port states: - DOWN and ACTIVE. In the - DOWN state a port will not provide - connectivity to the network. - - This feature allows the tenant the ability to take entities - offline without affecting the logical topology. - - The operation will return the RequestedStateInvalid - error code if the specified administrative state is not either - DOWN or ACTIVE. - - The operation's request body must contain a Port object with - the new administrative state for the port. - + Error Response Code(s): BadRequest + (400), Unauthorized + (401), Forbidden + (403), NetworkNotFound + (420), PortNotFound + (430), + RequestedStateInvalid (431) + This operation sets the administrative state for + a port. Currently Quantum recognizes two port + states: DOWN and ACTIVE. + In the DOWN state a port will not + provide connectivity to the network. + This feature allows the tenant the ability to + take entities offline without affecting the + logical topology. + The operation will return the + RequestedStateInvalid error code + if the specified administrative state is not + either DOWN or + ACTIVE. + The operation's request body must contain a Port + object with the new administrative state for the + port. Update Port Request (XML) Request: - PUT tenants/33/networks/158233b0-ca9a-40b4-8614-54a4a99d47d1/ports/98017ddc-efc8-4c25-a915-774b2a633855.xml - + PUT tenants/33/networks/158233b0-ca9a-40b4-8614-54a4a99d47d1/ports/98017ddc-efc8-4c25-a915-774b2a633855.xml + Response: - No data is returned in the response - body. + No data is returned in the + response body. Update Port Request (JSON) Request: - PUT tenants/33/networks/158233b0-ca9a-40b4-8614-54a4a99d47d1/ports/98017ddc-efc8-4c25-a915-774b2a633855.json - - + PUT tenants/33/networks/158233b0-ca9a-40b4-8614-54a4a99d47d1/ports/98017ddc-efc8-4c25-a915-774b2a633855.json + + Response: No data is returned in the response body. @@ -1607,43 +1601,38 @@ Content-Type application/json - - Normal Response Code(s): - 204 + Normal Response Code(s): + 204 - - Error Response Code(s): - BadRequest (400), - Unauthorized (401), - Forbidden (403), - NetworkNotFound (420), - PortNotFound (430), - PortInUse (432) - - - This operation removes a port from a Quantum network. - This operation might not be available for plugins in - which the number of ports is fixed at network creation; - in this case ports should not be deleted, just as they - cannot be created. - - The operation is not recoverable and will fail if an - attachment is plugged into the port. # - - This operation does not require a request body. - + Error Response Code(s): BadRequest + (400), Unauthorized + (401), Forbidden + (403), NetworkNotFound + (420), PortNotFound + (430), PortInUse + (432) + This operation removes a port from a Quantum + network. This operation might not be available for + plugins in which the number of ports is fixed at + network creation; in this case ports should not be + deleted, just as they cannot be created. + The operation is not recoverable and will fail + if an attachment is plugged into the port. + # + This operation does not require a request + body. Delete Port Request (XML) Request: - DELETE tenants/33/networks/158233b0-ca9a-40b4-8614-54a4a99d47d1/ports/98017ddc-efc8-4c25-a915-774b2a633855.xml + DELETE tenants/33/networks/158233b0-ca9a-40b4-8614-54a4a99d47d1/ports/98017ddc-efc8-4c25-a915-774b2a633855.xml Response: - No data is returned in the response - body.. + No data is returned in the + response body.. Delete Port Request (JSON) Request: - DELETE tenants/33/networks/158233b0-ca9a-40b4-8614-54a4a99d47d1/ports/98017ddc-efc8-4c25-a915-774b2a633855.json + DELETE tenants/33/networks/158233b0-ca9a-40b4-8614-54a4a99d47d1/ports/98017ddc-efc8-4c25-a915-774b2a633855.json Response: No data is returned in the response body.. @@ -1652,15 +1641,12 @@ Content-Type application/json
Attachments - - This section describes the operations exposed by Quantum API for - manipulating port attachments. - - An attachment is typically a virtual network interface - belonging to a VM instance. Different kinds of resources - can be defined in the future. - -
+ This section describes the operations exposed by + Quantum API for manipulating port attachments. + An attachment is typically a virtual network + interface belonging to a VM instance. Different kinds + of resources can be defined in the future. +
Show Attachment for Port @@ -1693,34 +1679,36 @@ Content-Type application/json This operation returns configuration details for the attachment plugged into the port specified in the request URI. This information is a reference - to a virtual interface identifier.If no attachment is currently plugged into the port, the - operation does not return any attachment + to a virtual interface identifier. + If no attachment is currently plugged into the + port, the operation does not return any attachment identifier in the response. The response will contain an empty attachment element with no id attribute set. - This operation does not require a request body. + This operation does not require a request + body. Show Attachment Request/Response (XML) Request: - GET /tenants/XYZ/networks/158233b0-ca9a-40b4-8614-54a4a99d47d1/ports/b832be00-6553-4f69-af33-acd554e36d08/attachment.xml + GET /tenants/XYZ/networks/158233b0-ca9a-40b4-8614-54a4a99d47d1/ports/b832be00-6553-4f69-af33-acd554e36d08/attachment.xml Response (attachment set): - + Response (attachment not set): - + Show Attachment Request/Response (JSON) Request: - GET /tenants/XYZ/networks/158233b0-ca9a-40b4-8614-54a4a99d47d1/ports/b832be00-6553-4f69-af33-acd554e36d08/attachment.json + GET /tenants/XYZ/networks/158233b0-ca9a-40b4-8614-54a4a99d47d1/ports/b832be00-6553-4f69-af33-acd554e36d08/attachment.json Response (attachment set): - + Response (attachment not set): - +
@@ -1756,53 +1744,54 @@ Content-Type application/json (432), AlreadyAttached (440) This operation plugs an attachment into the port - specified in the request URL.Quantum validates the request and dispatches the request to the - plugin. It is not guaranteed that the attached - resource will be available as soon as the - operation returns. - The validation can fail if: - - - An attachment with the same identifier is - already plugged in somewhere else. - - - Another attachment is already plugged into - the specified port. - - - If validation fails, the attachment is not created at all, - and the appropriate error code is returned to the - caller. - If no attachment is currently plugged into the + specified in the request URL. + Quantum validates the request and dispatches the + request to the plugin. It is not guaranteed that + the attached resource will be available as soon as + the operation returns. + The validation can fail if: + + + An attachment with the same identifier + is already plugged in somewhere + else. + + + Another attachment is already plugged + into the specified port. + + + If validation fails, the attachment is not + created at all, and the appropriate error code is + returned to the caller. + If no attachment is currently plugged into the port, the operation does not return any attachment identifier in the response. The response will - contain an empty attachment element. - - The request body for this network should contain a reference - to the attachment to plug into the port. - + contain an empty attachment + element. + The request body for this network should contain + a reference to the attachment to plug into the + port. Plug Attachment Request (XML) Request: - PUT /tenants/XYZ/networks/158233b0-ca9a-40b4-8614-54a4a99d47d1/ports/b832be00-6553-4f69-af33-acd554e36d08/attachment.xml + PUT /tenants/XYZ/networks/158233b0-ca9a-40b4-8614-54a4a99d47d1/ports/b832be00-6553-4f69-af33-acd554e36d08/attachment.xml - Response: - No data is returned + Response: + No data is returned in the response body. Plug Attachment Request (JSON) Request: - PUT /tenants/XYZ/networks/158233b0-ca9a-40b4-8614-54a4a99d47d1/ports/b832be00-6553-4f69-af33-acd554e36d08/attachment.json - - + PUT /tenants/XYZ/networks/158233b0-ca9a-40b4-8614-54a4a99d47d1/ports/b832be00-6553-4f69-af33-acd554e36d08/attachment.json + Response: - No data is returned in the response - body. - + No data is returned + in the response body. +
-
+
Delete Attachment from Port @@ -1815,7 +1804,8 @@ Content-Type application/json &DELETE; - /tenants/tenant-id/networks/network-id/ports/port-id/attachment + /tenants/tenant-id/networks/network-id/ports/port-id/attachment Removes the attachment currently plugged into the port identified by @@ -1832,16 +1822,17 @@ Content-Type application/json (420), PortNotFound (430) This operation removes the specified attachment - from the port specified in the request URI. - If no attachment is currently plugged into the port, this - operation has no effect. - This operation does not require a request body. + from the port specified in the request URI. + If no attachment is currently plugged into the + port, this operation has no effect. + This operation does not require a request + body. Delete Attachment Request (XML) Request: - DELETE /tenants/XYZ/networks/158233b0-ca9a-40b4-8614-54a4a99d47d1/ports/b832be00-6553-4f69-af33-acd554e36d08/attachment.xml - Response: - No data is returned + DELETE /tenants/XYZ/networks/158233b0-ca9a-40b4-8614-54a4a99d47d1/ports/b832be00-6553-4f69-af33-acd554e36d08/attachment.xml + Response: + No data is returned in the response body. diff --git a/v1.0/samples/extensions.json b/v1.0/samples/extensions.json index 6fecf0e..e7aae75 100644 --- a/v1.0/samples/extensions.json +++ b/v1.0/samples/extensions.json @@ -1,19 +1,18 @@ { - "extensions": [ - { - "name": "Cisco Port Profile", - "namespace": "http://docs.ciscocloud.com/api/ext/portprofile/v1.0", - "alias": "Cisco Port Profile", - "updated": "2011-07-23T13:25:27-06:00", - "description": "Portprofile include QoS information" - }, - { - "name": "Cisco qos", - "namespace": "http://docs.ciscocloud.com/api/ext/qos/v1.0", - "alias": "Cisco qos", - "updated": "2011-07-25T13:25:27-06:00", - "description": "qos include qos_name and qos_desc" - } - - ] + "extensions":[ + { + "name":"Cisco Port Profile", + "namespace":"http://docs.ciscocloud.com/api/ext/portprofile/v1.0", + "alias":"Cisco Port Profile", + "updated":"2011-07-23T13:25:27-06:00", + "description":"Portprofile include QoS information" + }, + { + "name":"Cisco qos", + "namespace":"http://docs.ciscocloud.com/api/ext/qos/v1.0", + "alias":"Cisco qos", + "updated":"2011-07-25T13:25:27-06:00", + "description":"qos include qos_name and qos_desc" + } + ] } diff --git a/v1.0/samples/extensions.xml b/v1.0/samples/extensions.xml index 8f8c5ef..f37618f 100644 --- a/v1.0/samples/extensions.xml +++ b/v1.0/samples/extensions.xml @@ -1,21 +1,13 @@ - - - + alias="Cisco Port Profile" updated="2011-07-23T13:25:27-06:00"> Portprofile include QoS information - - + alias="Cisco qos" updated="2011-07-25T13:25:27-06:00"> qos include qos_name and qos_desc - diff --git a/v1.0/samples/fault.xml b/v1.0/samples/fault.xml index 85730ff..798607a 100644 --- a/v1.0/samples/fault.xml +++ b/v1.0/samples/fault.xml @@ -1,8 +1,7 @@ - - - Unable to find a network with the specified identifier. - - - Network 8de6af7c-ef95-4ac1-9d37-172f8df33a1f could not be found - + + + Unable to find a network with the specified identifier. + Network 8de6af7c-ef95-4ac1-9d37-172f8df33a1f could not be + found diff --git a/v1.0/samples/network-get-res.json b/v1.0/samples/network-get-res.json index 8ccffa1..04e00bd 100644 --- a/v1.0/samples/network-get-res.json +++ b/v1.0/samples/network-get-res.json @@ -1,7 +1,6 @@ { - "network": - { - "id": "8bec1293-16bd-4568-ba75-1f58bec0b4c3", - "name": "test_network" - } + "network":{ + "id":"8bec1293-16bd-4568-ba75-1f58bec0b4c3", + "name":"test_network" + } } \ No newline at end of file diff --git a/v1.0/samples/network-get-res.xml b/v1.0/samples/network-get-res.xml index 94b35bc..a748473 100644 --- a/v1.0/samples/network-get-res.xml +++ b/v1.0/samples/network-get-res.xml @@ -1,3 +1,2 @@ - \ No newline at end of file + + diff --git a/v1.0/samples/network-post-req.json b/v1.0/samples/network-post-req.json index c5186d9..e46fe94 100644 --- a/v1.0/samples/network-post-req.json +++ b/v1.0/samples/network-post-req.json @@ -1,6 +1,5 @@ { - "network": - { - "name": "test_create_network" - } + "network":{ + "name":"test_create_network" + } } \ No newline at end of file diff --git a/v1.0/samples/network-post-req.xml b/v1.0/samples/network-post-req.xml index 40608da..df9ec08 100644 --- a/v1.0/samples/network-post-req.xml +++ b/v1.0/samples/network-post-req.xml @@ -1,2 +1,2 @@ - + + diff --git a/v1.0/samples/network-post-res.json b/v1.0/samples/network-post-res.json index b66d4d9..ec1b4cd 100644 --- a/v1.0/samples/network-post-res.json +++ b/v1.0/samples/network-post-res.json @@ -1,6 +1,5 @@ { - "network": - { - "id": "158233b0-ca9a-40b4-8614-54a4a99d47d1" - } + "network":{ + "id":"158233b0-ca9a-40b4-8614-54a4a99d47d1" + } } \ No newline at end of file diff --git a/v1.0/samples/network-post-res.xml b/v1.0/samples/network-post-res.xml index 03cfe12..8f870d9 100644 --- a/v1.0/samples/network-post-res.xml +++ b/v1.0/samples/network-post-res.xml @@ -1,2 +1,2 @@ - + + diff --git a/v1.0/samples/networks-post-req.json b/v1.0/samples/networks-post-req.json index 1443a3c..cca2716 100644 --- a/v1.0/samples/networks-post-req.json +++ b/v1.0/samples/networks-post-req.json @@ -1,5 +1,5 @@ { - "network": { - "name": "test" - } -} + "network":{ + "name":"test" + } +} \ No newline at end of file diff --git a/v1.0/samples/port-get-res.json b/v1.0/samples/port-get-res.json index 8ded3d2..7ce6286 100644 --- a/v1.0/samples/port-get-res.json +++ b/v1.0/samples/port-get-res.json @@ -1,8 +1,7 @@ { - "port": - { - "state": "DOWN", - "id": "98017ddc-efc8-4c25-a915-774b2a633855" - } + "port":{ + "state":"DOWN", + "id":"98017ddc-efc8-4c25-a915-774b2a633855" + } } diff --git a/v1.0/samples/port-get-res.xml b/v1.0/samples/port-get-res.xml index 622f397..4e21968 100644 --- a/v1.0/samples/port-get-res.xml +++ b/v1.0/samples/port-get-res.xml @@ -1,3 +1,2 @@ - \ No newline at end of file + + diff --git a/v1.0/samples/ports-get-detail-res.json b/v1.0/samples/ports-get-detail-res.json index c2377de..fbb6200 100644 --- a/v1.0/samples/ports-get-detail-res.json +++ b/v1.0/samples/ports-get-detail-res.json @@ -1,12 +1,12 @@ { - "ports": [ - { - "id": "98017ddc-efc8-4c25-a915-774b2a633855", - "state": "ACTIVE" - }, - { - "id": "b832be00-6553-4f69-af33-acd554e36d08", - "state": "ACTIVE" - } + "ports":[ + { + "id":"98017ddc-efc8-4c25-a915-774b2a633855", + "state":"ACTIVE" + }, + { + "id":"b832be00-6553-4f69-af33-acd554e36d08", + "state":"ACTIVE" + } ] -} +} \ No newline at end of file diff --git a/v1.0/samples/ports-get-detail-res.xml b/v1.0/samples/ports-get-detail-res.xml index 605b98d..e0c5d6e 100644 --- a/v1.0/samples/ports-get-detail-res.xml +++ b/v1.0/samples/ports-get-detail-res.xml @@ -1,8 +1,5 @@ + - - + + diff --git a/v1.0/samples/ports-get-res.json b/v1.0/samples/ports-get-res.json index 1f49c36..0f5cb07 100644 --- a/v1.0/samples/ports-get-res.json +++ b/v1.0/samples/ports-get-res.json @@ -1,11 +1,10 @@ { - "ports": - [ - { - "id": "98017ddc-efc8-4c25-a915-774b2a633855" - }, - { - "id": "b832be00-6553-4f69-af33-acd554e36d08" - } - ] + "ports":[ + { + "id":"98017ddc-efc8-4c25-a915-774b2a633855" + }, + { + "id":"b832be00-6553-4f69-af33-acd554e36d08" + } + ] } \ No newline at end of file diff --git a/v1.0/samples/ports-get-res.xml b/v1.0/samples/ports-get-res.xml index 73ac5a3..47651eb 100644 --- a/v1.0/samples/ports-get-res.xml +++ b/v1.0/samples/ports-get-res.xml @@ -1,6 +1,5 @@ + - - + + diff --git a/v2.0/neutron-api-guide.xml b/v2.0/neutron-api-guide.xml index b28efbc..afbc597 100644 --- a/v2.0/neutron-api-guide.xml +++ b/v2.0/neutron-api-guide.xml @@ -143,5 +143,5 @@ - + diff --git a/v2.0/section_neutron-security-groups-ext.xml b/v2.0/section_neutron-security-groups-ext.xml index 38281bd..b985e92 100644 --- a/v2.0/section_neutron-security-groups-ext.xml +++ b/v2.0/section_neutron-security-groups-ext.xml @@ -34,11 +34,10 @@ xmlns:m="http://www.w3.org/1998/Math/MathML" xmlns:html="http://www.w3.org/1999/xhtml" xmlns:db="http://docbook.org/ns/docbook" version="5.0" - status="final" xml:id="security-groups-ext" - xmlns:wadl="http://wadl.dev.java.net/2009/02"> - - Security Groups and Rules - Creates, modifies, and deletes OpenStack Networking security groups and - rules. - + status="final" xmlns:wadl="http://wadl.dev.java.net/2009/02" + xml:id="security_groups"> + Security groups and rules (security-groups) +