FHIR Application Feature Framework Implementation Guide
1.0.0-ballot - STU1 Ballot International flag

FHIR Application Feature Framework Implementation Guide, published by HL7 International / FHIR Infrastructure. This guide is not an authorized publication; it is the continuous build for version 1.0.0-ballot built by the FHIR (HL7® FHIR® Standard) CI Build. This version is based on the current content of https://github.com/HL7/capstmt/ and changes regularly. See the Directory of published versions

Resource Profile: Feature Capability Statement

Official URL: http://hl7.org/fhir/uv/application-feature/StructureDefinition/FeatureCapabilityStatement Version: 1.0.0-ballot
Standards status: Trial-use Maturity Level: 1 Computable Name: FeatureCapabilityStatement

A profile on the CapabilityStatement resource that allows for feature negotiation.

Usage:

Formal Views of Profile Content

Description of Profiles, Differentials, Snapshots and how the different presentations work.

NameFlagsCard.TypeDescription & Constraintsdoco
.. CapabilityStatement C 0..* CapabilityStatement A statement of system capabilities
cnl-0: Name should be usable as an identifier for the module by machine processing applications such as code generation
cpb-1: A Capability Statement SHALL have at least one of REST, messaging or document element.
cpb-2: A Capability Statement SHALL have at least one of description, software, or implementation element.
cpb-3: Messaging end-point is only permitted when a capability statement is for an implementation.
cpb-4: There should only be one CapabilityStatement.rest per mode.
cpb-7: The set of documents must be unique by the combination of profile and mode.
cpb-14: If kind = instance, implementation must be present and software may be present
cpb-15: If kind = capability, implementation must be absent, software must be present
cpb-16: If kind = requirements, implementation and software must be absent
... implicitRules ?!Σ 0..1 uri A set of rules under which this content was created
ele-1: All FHIR elements must have a @value or children
... contained 0..* Resource Contained, inline Resources
... modifierExtension ?!Σ 0..* Extension Extensions that cannot be ignored
ele-1: All FHIR elements must have a @value or children
ext-1: Must have either extensions or value[x], not both
... status ?!Σ 1..1 code draft | active | retired | unknown
Binding: PublicationStatus (required): The lifecycle status of an artifact.


ele-1: All FHIR elements must have a @value or children
... date Σ 1..1 dateTime Date last changed
ele-1: All FHIR elements must have a @value or children
... kind ΣC 1..1 code instance | capability | requirements
Binding: CapabilityStatementKind (required): How a capability statement is intended to be used.


ele-1: All FHIR elements must have a @value or children
... software ΣC 0..1 BackboneElement Software that is covered by this capability statement
ele-1: All FHIR elements must have a @value or children
.... modifierExtension ?!Σ 0..* Extension Extensions that cannot be ignored even if unrecognized
ele-1: All FHIR elements must have a @value or children
ext-1: Must have either extensions or value[x], not both
.... name Σ 1..1 string A name the software is known by
ele-1: All FHIR elements must have a @value or children
... implementation ΣC 0..1 BackboneElement If this describes a specific instance
ele-1: All FHIR elements must have a @value or children
.... modifierExtension ?!Σ 0..* Extension Extensions that cannot be ignored even if unrecognized
ele-1: All FHIR elements must have a @value or children
ext-1: Must have either extensions or value[x], not both
.... description Σ 1..1 markdown Describes this specific instance
ele-1: All FHIR elements must have a @value or children
... fhirVersion Σ 1..1 code FHIR Version the system supports
Binding: FHIRVersion (required): All published FHIR Versions.


ele-1: All FHIR elements must have a @value or children
... format Σ 1..* code formats supported (xml | json | ttl | mime type)
Binding: MimeTypes (required): The mime type of an attachment. Any valid mime type is allowed.

Additional BindingsPurpose
CapabilityFormatType Starter Set

ele-1: All FHIR elements must have a @value or children
... rest ΣC 0..* BackboneElement If the endpoint is a RESTful one
cpb-9: A given resource can only be described once per RESTful mode.
ele-1: All FHIR elements must have a @value or children
.... Slices for extension 0..* Extension Extension
Slice: Unordered, Open by value:url
ele-1: All FHIR elements must have a @value or children
ext-1: Must have either extensions or value[x], not both
..... feature S 0..* (Complex) Extension
URL: http://hl7.org/fhir/uv/application-feature/StructureDefinition/feature
ele-1: All FHIR elements must have a @value or children
ext-1: Must have either extensions or value[x], not both
.... modifierExtension ?!Σ 0..* Extension Extensions that cannot be ignored even if unrecognized
ele-1: All FHIR elements must have a @value or children
ext-1: Must have either extensions or value[x], not both
.... mode ΣC 1..1 code client | server
Binding: RestfulCapabilityMode (required): The mode of a RESTful capability statement.


ele-1: All FHIR elements must have a @value or children
.... security Σ 0..1 BackboneElement Information about security of implementation
ele-1: All FHIR elements must have a @value or children
..... Slices for extension 0..* Extension Extension
Slice: Unordered, Open by value:url
ele-1: All FHIR elements must have a @value or children
ext-1: Must have either extensions or value[x], not both
...... feature S 0..* (Complex) Extension
URL: http://hl7.org/fhir/uv/application-feature/StructureDefinition/feature
ele-1: All FHIR elements must have a @value or children
ext-1: Must have either extensions or value[x], not both
..... modifierExtension ?!Σ 0..* Extension Extensions that cannot be ignored even if unrecognized
ele-1: All FHIR elements must have a @value or children
ext-1: Must have either extensions or value[x], not both
.... resource ΣC 0..* BackboneElement Resource served on the REST interface
cpb-12: Search parameter names must be unique in the context of a resource.
ele-1: All FHIR elements must have a @value or children
..... Slices for extension 0..* Extension Extension
Slice: Unordered, Open by value:url
ele-1: All FHIR elements must have a @value or children
ext-1: Must have either extensions or value[x], not both
...... feature S 0..* (Complex) Extension
URL: http://hl7.org/fhir/uv/application-feature/StructureDefinition/feature
ele-1: All FHIR elements must have a @value or children
ext-1: Must have either extensions or value[x], not both
..... modifierExtension ?!Σ 0..* Extension Extensions that cannot be ignored even if unrecognized
ele-1: All FHIR elements must have a @value or children
ext-1: Must have either extensions or value[x], not both
..... type ΣC 1..1 code A resource type that is supported
Binding: ResourceType (required): One of the resource types defined as part of this version of FHIR.


ele-1: All FHIR elements must have a @value or children
..... interaction 0..* BackboneElement What operations are supported?
ele-1: All FHIR elements must have a @value or children
...... Slices for extension 0..* Extension Extension
Slice: Unordered, Open by value:url
ele-1: All FHIR elements must have a @value or children
ext-1: Must have either extensions or value[x], not both
....... feature S 0..* (Complex) Extension
URL: http://hl7.org/fhir/uv/application-feature/StructureDefinition/feature
ele-1: All FHIR elements must have a @value or children
ext-1: Must have either extensions or value[x], not both
...... modifierExtension ?!Σ 0..* Extension Extensions that cannot be ignored even if unrecognized
ele-1: All FHIR elements must have a @value or children
ext-1: Must have either extensions or value[x], not both
...... code 1..1 code read | vread | update | patch | delete | history-instance | history-type | create | search-type
Binding: TypeRestfulInteraction (required): Operations supported by REST at the type or instance level.


ele-1: All FHIR elements must have a @value or children
..... searchParam C 0..* BackboneElement Search parameters supported by implementation
ele-1: All FHIR elements must have a @value or children
...... Slices for extension 0..* Extension Extension
Slice: Unordered, Open by value:url
ele-1: All FHIR elements must have a @value or children
ext-1: Must have either extensions or value[x], not both
....... feature S 0..* (Complex) Extension
URL: http://hl7.org/fhir/uv/application-feature/StructureDefinition/feature
ele-1: All FHIR elements must have a @value or children
ext-1: Must have either extensions or value[x], not both
...... modifierExtension ?!Σ 0..* Extension Extensions that cannot be ignored even if unrecognized
ele-1: All FHIR elements must have a @value or children
ext-1: Must have either extensions or value[x], not both
...... name C 1..1 string Name for parameter in search url
ele-1: All FHIR elements must have a @value or children
...... type 1..1 code number | date | string | token | reference | composite | quantity | uri | special
Binding: SearchParamType (required): Data types allowed to be used for search parameters.


ele-1: All FHIR elements must have a @value or children
..... operation Σ 0..* BackboneElement Definition of a resource operation
ele-1: All FHIR elements must have a @value or children
...... Slices for extension 0..* Extension Extension
Slice: Unordered, Open by value:url
ele-1: All FHIR elements must have a @value or children
ext-1: Must have either extensions or value[x], not both
....... feature S 0..* (Complex) Extension
URL: http://hl7.org/fhir/uv/application-feature/StructureDefinition/feature
ele-1: All FHIR elements must have a @value or children
ext-1: Must have either extensions or value[x], not both
...... modifierExtension ?!Σ 0..* Extension Extensions that cannot be ignored even if unrecognized
ele-1: All FHIR elements must have a @value or children
ext-1: Must have either extensions or value[x], not both
...... name Σ 1..1 string Name by which the operation/query is invoked
ele-1: All FHIR elements must have a @value or children
...... definition Σ 1..1 canonical(OperationDefinition) The defined operation/query
ele-1: All FHIR elements must have a @value or children
.... interaction 0..* BackboneElement What operations are supported?
ele-1: All FHIR elements must have a @value or children
..... Slices for extension 0..* Extension Extension
Slice: Unordered, Open by value:url
ele-1: All FHIR elements must have a @value or children
ext-1: Must have either extensions or value[x], not both
...... feature S 0..* (Complex) Extension
URL: http://hl7.org/fhir/uv/application-feature/StructureDefinition/feature
ele-1: All FHIR elements must have a @value or children
ext-1: Must have either extensions or value[x], not both
..... modifierExtension ?!Σ 0..* Extension Extensions that cannot be ignored even if unrecognized
ele-1: All FHIR elements must have a @value or children
ext-1: Must have either extensions or value[x], not both
..... code 1..1 code transaction | batch | search-system | history-system
Binding: SystemRestfulInteraction (required): Operations supported by REST at the system level.


ele-1: All FHIR elements must have a @value or children
... messaging ΣC 0..* BackboneElement If messaging is supported
ele-1: All FHIR elements must have a @value or children
.... Slices for extension 0..* Extension Extension
Slice: Unordered, Open by value:url
ele-1: All FHIR elements must have a @value or children
ext-1: Must have either extensions or value[x], not both
..... feature S 0..* (Complex) Extension
URL: http://hl7.org/fhir/uv/application-feature/StructureDefinition/feature
ele-1: All FHIR elements must have a @value or children
ext-1: Must have either extensions or value[x], not both
.... modifierExtension ?!Σ 0..* Extension Extensions that cannot be ignored even if unrecognized
ele-1: All FHIR elements must have a @value or children
ext-1: Must have either extensions or value[x], not both
... document ΣC 0..* BackboneElement Document definition
ele-1: All FHIR elements must have a @value or children
.... Slices for extension 0..* Extension Extension
Slice: Unordered, Open by value:url
ele-1: All FHIR elements must have a @value or children
ext-1: Must have either extensions or value[x], not both
..... feature S 0..* (Complex) Extension
URL: http://hl7.org/fhir/uv/application-feature/StructureDefinition/feature
ele-1: All FHIR elements must have a @value or children
ext-1: Must have either extensions or value[x], not both
.... modifierExtension ?!Σ 0..* Extension Extensions that cannot be ignored even if unrecognized
ele-1: All FHIR elements must have a @value or children
ext-1: Must have either extensions or value[x], not both
.... mode ΣC 1..1 code producer | consumer
Binding: DocumentMode (required): Whether the application produces or consumes documents.


ele-1: All FHIR elements must have a @value or children
.... profile ΣC 1..1 canonical(StructureDefinition) Constraint on the resources used in the document
ele-1: All FHIR elements must have a @value or children

doco Documentation for this format

Terminology Bindings

PathConformanceValueSetURI
CapabilityStatement.statusrequiredPublicationStatus
http://hl7.org/fhir/ValueSet/publication-status|5.0.0
from the FHIR Standard
CapabilityStatement.kindrequiredCapabilityStatementKind
http://hl7.org/fhir/ValueSet/capability-statement-kind|5.0.0
from the FHIR Standard
CapabilityStatement.fhirVersionrequiredFHIRVersion
http://hl7.org/fhir/ValueSet/FHIR-version|5.0.0
from the FHIR Standard
CapabilityStatement.formatrequiredMimeTypes (a valid code from urn:ietf:bcp:13)
http://hl7.org/fhir/ValueSet/mimetypes|5.0.0
from the FHIR Standard
CapabilityStatement.rest.moderequiredRestfulCapabilityMode
http://hl7.org/fhir/ValueSet/restful-capability-mode|5.0.0
from the FHIR Standard
CapabilityStatement.rest.resource.typerequiredResourceType
http://hl7.org/fhir/ValueSet/resource-types|5.0.0
from the FHIR Standard
CapabilityStatement.rest.resource.interaction.coderequiredTypeRestfulInteraction
http://hl7.org/fhir/ValueSet/type-restful-interaction|5.0.0
from the FHIR Standard
CapabilityStatement.rest.resource.searchParam.typerequiredSearchParamType
http://hl7.org/fhir/ValueSet/search-param-type|5.0.0
from the FHIR Standard
CapabilityStatement.rest.interaction.coderequiredSystemRestfulInteraction
http://hl7.org/fhir/ValueSet/system-restful-interaction|5.0.0
from the FHIR Standard
CapabilityStatement.document.moderequiredDocumentMode
http://hl7.org/fhir/ValueSet/document-mode|5.0.0
from the FHIR Standard

Constraints

IdGradePath(s)DetailsRequirements
cnl-0warningCapabilityStatementName should be usable as an identifier for the module by machine processing applications such as code generation
: name.exists() implies name.matches('^[A-Z]([A-Za-z0-9_]){1,254}$')
cpb-1errorCapabilityStatementA Capability Statement SHALL have at least one of REST, messaging or document element.
: rest.exists() or messaging.exists() or document.exists()
cpb-2errorCapabilityStatementA Capability Statement SHALL have at least one of description, software, or implementation element.
: (description.count() + software.count() + implementation.count()) > 0
cpb-3errorCapabilityStatementMessaging end-point is only permitted when a capability statement is for an implementation.
: messaging.endpoint.empty() or kind = 'instance'
cpb-4errorCapabilityStatementThere should only be one CapabilityStatement.rest per mode.
: rest.mode.isDistinct()
cpb-7errorCapabilityStatementThe set of documents must be unique by the combination of profile and mode.
: document.select(profile&mode).isDistinct()
cpb-9errorCapabilityStatement.restA given resource can only be described once per RESTful mode.
: resource.select(type).isDistinct()
cpb-12errorCapabilityStatement.rest.resourceSearch parameter names must be unique in the context of a resource.
: searchParam.select(name).isDistinct()
cpb-14errorCapabilityStatementIf kind = instance, implementation must be present and software may be present
: (kind != 'instance') or implementation.exists()
cpb-15errorCapabilityStatementIf kind = capability, implementation must be absent, software must be present
: (kind != 'capability') or (implementation.exists().not() and software.exists())
cpb-16errorCapabilityStatementIf kind = requirements, implementation and software must be absent
: (kind!='requirements') or (implementation.exists().not() and software.exists().not())
ele-1error**ALL** elementsAll FHIR elements must have a @value or children
: hasValue() or (children().count() > id.count())
ext-1error**ALL** extensionsMust have either extensions or value[x], not both
: extension.exists() != value.exists()

 

Other representations of profile: CSV, Excel, Schematron