This page is part of the FHIR Specification (v1.0.2: DSTU 2). The current version which supercedes this version is 5.0.0.  For a full list of available versions, see the Directory of published versions  . Page versions: R5 R4B R4 R3 R2
. Page versions: R5 R4B R4 R3 R2

| FHIR Infrastructure  Work Group | Maturity Level: 3 | Ballot Status: DSTU 2 | 
This page documents how the content of the resources are described. In actual exchange, resources can be represented in the following formats: XML and JSON. Other representations are allowed, but are not described by this specification.

The resources are described in several different ways:
In addition to this descriptive syntax, other definitional forms are available, including W3C schema and Schematron, and the StructureDefinition syntax defined internally.

The Logical View shows the resources as a tree structure with the following columns:
| Column | Content | 
| Name | The name of the element in the resource (manifests as XML element name, or JSON property name. Some names finish with [x]- the meaning of this is discussed below. In addition, this column contains an icon that denotes the underlying type of the content. The icons are described below | 
| Flags | A set of information about the element that impacts how implementers handle them. The flags are described below | 
| Card. | The lower and upper bounds on how many times this element is allowed to appear in the resource | 
| Type | The type of the element (hyperlinked to the definition of the type) | 
| Description & Constraints | A description of the element, and details about constraints that are applied to it. Particularly, for coded elements, information about which codes can be used | 
Here's an example:
| Name | Flags | Card. | Type | Description & Constraints | 
|---|---|---|---|---|
|   Resource Name | Base Type | Definition | ||
|    nameA | Σ | 1..1 | type | description of content | 
|    nameB[x] | ?! Σ | 0..1 | description SHALL at least have a value | |
|     nameBType1 | 0..1 | type1 | ||
|     nameBType2 | I | 0..1 | type2 | |
|    nameC | 1..* | Element | Definition | |
|     nameD | 1..1 | type | Relevant Records | 
Key to Type Icons and Flags
 : The base element for a resource (see Resources)
: The base element for a resource (see Resources) : An element that is part of the resource and has elements within it defined in the same resource or profile
: An element that is part of the resource and has elements within it defined in the same resource or profile : An element which can have one of a several different types (see below)
: An element which can have one of a several different types (see below) : A data type which describes an element that has a
: A data type which describes an element that has a value attribute/property : A data type which describes an element that has other elements
: A data type which describes an element that has other elements : A element that contains a reference to another resource (see references)
: A element that contains a reference to another resource (see references) : This element has the same content as another element defined within this resource or profile
: This element has the same content as another element defined within this resource or profile : Introduction of a set of slices (see Slicing)
: Introduction of a set of slices (see Slicing) : An extension (see Extensibility)
: An extension (see Extensibility) : A complex extension - one with nested extensions (see Extensibility)
: A complex extension - one with nested extensions (see Extensibility) : An extension that has a value and no nested extensions (see Extensibility)
: An extension that has a value and no nested extensions (see Extensibility) : The root of a logical profile
: The root of a logical profile?!: This element is a modifying element - see Modifier ElementsS: This element is an element that must be supported - see Must-Support ElementsΣ: This element is an element that is part of the summary set - see Summary SearchesI: This element defines or is affected by constraints - see ConstraintsNE: This element cannot have extensions (some infrastructural elements only)Notes:
value attribute/property to contain the actual value of the elementvalue attribute/property can never be empty. Either it is absent, or it is present with at least one character of non-whitespace contentid attribute to serve as the target of an internal reference. The id attribute is not shown in this format. Extensions are not always shown, but may appear except where the flag NE appears
A few elements have a choice of more than one data type for their content. All such elements have a name that 
takes the form nnn[x]. The "nnn" part of the name is constant, and the "[x]" is replaced with the title-cased 
name of the type that is actually used. The table view shows each of these names explicitly.
Elements that have a choice of data type cannot repeat. I.e. They must have a maximum cardinality of 1. When constructing an instance of an element with a choice of types, the authoring system must create a single element with a data type chosen from among the list of permitted data types.
Note: In object-orientated based implementations, this is naturally represented as a polymorphic property. However this is not necessary and the correct implementation varies according to the particular features of the language. In XML schema, these become an xs:choice of element.

The UML diagrams represent the same content as a series of classes that represent the elements of a resource.
The elements and the data types are hyperlinks to the formal definitions of the parts. The UML diagrams also show the vocabulary bindings. These are hyperlinks to the value set details.
Where an element can have a choice of data types, or is a Reference these are 
represented by showing the common type (Reference or Type), and then showing the applicable data type names or 
resource types in a stereotype, separated by the | character. Type is not formally otherwise defined by
this specification, but is a super type of all the data types. 
The actual order of the elements in XML cannot be determined from the diagram, nor whether a UML property becomes an element or an attribute in the XML representation.

This specification defines the following ways to represent resources when they are exchanged:
Clients and servers can choose what syntax(s) to implement. In 
the interests of interoperability, servers SHOULD support all formats (though support for RDF
should best wait until it is more fully developed).
Systems SHALL declare which format(s) they support in their Conformance Statement. 
If a server receives a request for its conformance statement in
a format it does not otherwise support, it SHALL return a 415 Unsupported Media Type.