XML Object in OpenAPI
The XML Object allows us to add details about how the schema should be represented as XML.
This is useful because XML has different data types and structures compared to JSON.
For example, in JSON, an array is a list of values only, while in XML, array values are represented as elements with names.
Field
Type
String
Description
The name of the element when the property is represented in XML. When used in
, the name applies to each element in the XML array.
Required
Type
String
Description
The absolute URL of the XML namespace.
Required
Type
String
Description
A prefix for the element's name.
Required
Type
Boolean
Description
Whether the property should be represented as an XML attribute (
) instead of an XML element (
). Defaults to
, so each property is represented as an element by default.
Required
Type
Boolean
Description
Whether array elements should be wrapped in a container element. Defaults to
, so array elements are not wrapped by default. Only applies to arrays.
Required
Type
Description
Any number of extension fields can be added to the XML object that can be used by tooling and vendors.
Required
The examples below illustrate how XML Objects can be used:
components:
schemas:
Drink:
type: object
properties:
name:
type: string
xml:
name: drinkName
namespace: http://speakeasy.bar/schemas
prefix: se
ingredients:
type: array
items:
$ref: "#/components/schemas/Ingredient"
xml:
name: ingredients
wrapped: true
namespace: http://speakeasy.bar/schemas
prefix: se
Ingredient:
type: object
properties:
id:
type: number
xml:
name: ingredientId
namespace: http://speakeasy.bar/schemas
prefix: se
attribute: true
name:
type: string
xml:
name: ingredientName
namespace: http://speakeasy.bar/schemas
prefix: seThe example above translates to the following XML example:
<se:drink xmlns:se="http://speakeasy.bar/schemas">
<se:drinkName>Mojito</se:drinkName>
<se:ingredients>
<se:ingredient se:id="1">
<se:ingredientName>Sugar</se:ingredientName>
</se:ingredient>
<se:ingredient se:id="2">
<se:ingredientName>Lime</se:ingredientName>
</se:ingredient>
<se:ingredient se:id="3">
<se:ingredientName>Mint</se:ingredientName>
</se:ingredient>
</se:ingredients>
</se:drink>Last updated on