This page is part of the US Core (v3.0.1: STU3 Ballot 3) based on FHIR R4. The current version which supercedes this version is 5.0.1. For a full list of available versions, see the Directory of published versions
StructureDefinition-us-core-location
This profile sets minimum expectations for the Location resource for recording, searching for and fetching a Location associated with a patient, provider or organization. It identifies which core elements, extensions, vocabularies and value sets SHALL be present in the resource when using this profile.
Mandatory and Must Support Data Elements
The following data-elements are mandatory (i.e data MUST be present) or must be supported if the data is present in the sending system (Must Support definition). They are presented below in a simple human-readable explanation. Profile specific guidance and examples are provided as well. The Formal Profile Definition below provides the formal summary, definitions, and terminology requirements.
Each Location must have:
- A name
Each Location must support:
- Location.status
- Location.name
- Location.telecom
- Location.address
- managingOrganization
Additional Profile specific implementation guidance:
- none
Examples
Formal Views of Profile Content
Description of Profiles, Differentials, and Snapshots.
The official URL for this profile is:
http://hl7.org/fhir/us/core/StructureDefinition/us-core-location
Published on Tue May 21 00:00:00 EDT 2019 as active by the HL7 US Realm Steering Committee.
This profile builds on Location
Location
Summary of the Mandatory Requirements
- A string in
Location.name
Summary of the Must Support Requirements
- A code in
Location.status
with a required binding to LocationStatus - One or more ContactPoints in
Location.telecom
- A Address in
Location.address
- which should have one or more string values in
Location.address.line
- which should have a string value in
Location.address.city
- which should have a string value in
Location.address.state
with an extensible binding to USPS Two Letter Alphabetic Codes - which should have a string value in
Location.address.postalCode
- which should have one or more string values in
- A Managingorganization Reference in
Location.managingOrganization
Name | Flags | Card. | Type | Description & Constraints |
---|---|---|---|---|
Location | 0..* | |||
status | S | 0..1 | code | |
name | S | 1..1 | string | |
telecom | S | 0..* | ContactPoint | |
address | S | 0..1 | Address | |
line | S | 0..* | string | |
city | S | 0..1 | string | |
state | S | 0..1 | string | Binding: USPS Two Letter Alphabetic Codes (extensible) |
postalCode | S | 0..1 | string | US Zip Codes |
managingOrganization | S | 0..1 | Reference(US Core Organization Profile) | |
Documentation for this format |
Name | Flags | Card. | Type | Description & Constraints |
---|---|---|---|---|
Location | I | 0..* | Details and position information for a physical place | |
id | Σ | 0..1 | id | Logical id of this artifact |
meta | Σ | 0..1 | Meta | Metadata about the resource |
implicitRules | ?!Σ | 0..1 | uri | A set of rules under which this content was created |
language | 0..1 | code | Language of the resource content Binding: CommonLanguages (preferred) Max Binding: AllLanguages | |
text | 0..1 | Narrative | Text summary of the resource, for human interpretation | |
contained | 0..* | Resource | Contained, inline Resources | |
extension | 0..* | Extension | Additional content defined by implementations | |
modifierExtension | ?! | 0..* | Extension | Extensions that cannot be ignored |
identifier | Σ | 0..* | Identifier | Unique code or number identifying the location to its users |
status | ?!SΣ | 0..1 | code | active | suspended | inactive Binding: LocationStatus (required) |
operationalStatus | Σ | 0..1 | Coding | The operational status of the location (typically only for a bed/room) Binding: v2 BED STATUS (preferred) |
name | SΣ | 1..1 | string | Name of the location as used by humans |
alias | 0..* | string | A list of alternate names that the location is known as, or was known as, in the past | |
description | Σ | 0..1 | string | Additional details about the location that could be displayed as further information to identify the location beyond its name |
mode | Σ | 0..1 | code | instance | kind Binding: LocationMode (required) |
type | Σ | 0..* | CodeableConcept | Type of function performed Binding: V3 Value SetServiceDeliveryLocationRoleType (extensible) |
telecom | S | 0..* | ContactPoint | Contact details of the location |
address | S | 0..1 | Address | Physical location |
id | 0..1 | string | Unique id for inter-element referencing | |
extension | 0..* | Extension | Additional content defined by implementations Slice: Unordered, Open by value:url | |
use | ?!Σ | 0..1 | code | home | work | temp | old | billing - purpose of this address Binding: AddressUse (required) Example General': home |
type | Σ | 0..1 | code | postal | physical | both Binding: AddressType (required) Example General': both |
text | Σ | 0..1 | string | Text representation of the address Example General': 137 Nowhere Street, Erewhon 9132 |
line | SΣ | 0..* | string | Street name, number, direction & P.O. Box etc. This repeating element order: The order in which lines should appear in an address label Example General': 137 Nowhere Street |
city | SΣ | 0..1 | string | Name of city, town etc. Example General': Erewhon |
district | Σ | 0..1 | string | District name (aka county) Example General': Madison |
state | SΣ | 0..1 | string | Sub-unit of country (abbreviations ok) Binding: USPS Two Letter Alphabetic Codes (extensible) |
postalCode | SΣ | 0..1 | string | US Zip Codes Example General': 9132 |
country | Σ | 0..1 | string | Country (e.g. can be ISO 3166 2 or 3 letter code) |
period | Σ | 0..1 | Period | Time period when address was/is in use Example General': {"start":"2010-03-23T00:00:00-04:00","end":"2010-07-01T00:00:00-04:00"} |
physicalType | Σ | 0..1 | CodeableConcept | Physical form of the location Binding: LocationType (example) |
position | I | 0..1 | BackboneElement | The absolute geographic location |
id | 0..1 | string | Unique id for inter-element referencing | |
extension | 0..* | Extension | Additional content defined by implementations | |
modifierExtension | ?!Σ | 0..* | Extension | Extensions that cannot be ignored even if unrecognized |
longitude | 1..1 | decimal | Longitude with WGS84 datum | |
latitude | 1..1 | decimal | Latitude with WGS84 datum | |
altitude | 0..1 | decimal | Altitude with WGS84 datum | |
managingOrganization | SΣ | 0..1 | Reference(US Core Organization Profile) | Organization responsible for provisioning and upkeep |
partOf | 0..1 | Reference(Location) | Another Location this one is physically a part of | |
hoursOfOperation | I | 0..* | BackboneElement | What days/times during a week is this location usually open |
id | 0..1 | string | Unique id for inter-element referencing | |
extension | 0..* | Extension | Additional content defined by implementations | |
modifierExtension | ?!Σ | 0..* | Extension | Extensions that cannot be ignored even if unrecognized |
daysOfWeek | 0..* | code | mon | tue | wed | thu | fri | sat | sun Binding: DaysOfWeek (required) | |
allDay | 0..1 | boolean | The Location is open all day | |
openingTime | 0..1 | time | Time that the Location opens | |
closingTime | 0..1 | time | Time that the Location closes | |
availabilityExceptions | 0..1 | string | Description of availability exceptions | |
endpoint | 0..* | Reference(Endpoint) | Technical endpoints providing access to services operated for the location | |
Documentation for this format |
Location
Summary of the Mandatory Requirements
- A string in
Location.name
Summary of the Must Support Requirements
- A code in
Location.status
with a required binding to LocationStatus - One or more ContactPoints in
Location.telecom
- A Address in
Location.address
- which should have one or more string values in
Location.address.line
- which should have a string value in
Location.address.city
- which should have a string value in
Location.address.state
with an extensible binding to USPS Two Letter Alphabetic Codes - which should have a string value in
Location.address.postalCode
- which should have one or more string values in
- A Managingorganization Reference in
Location.managingOrganization
Differential View
Name | Flags | Card. | Type | Description & Constraints |
---|---|---|---|---|
Location | 0..* | |||
status | S | 0..1 | code | |
name | S | 1..1 | string | |
telecom | S | 0..* | ContactPoint | |
address | S | 0..1 | Address | |
line | S | 0..* | string | |
city | S | 0..1 | string | |
state | S | 0..1 | string | Binding: USPS Two Letter Alphabetic Codes (extensible) |
postalCode | S | 0..1 | string | US Zip Codes |
managingOrganization | S | 0..1 | Reference(US Core Organization Profile) | |
Documentation for this format |
Snapshot View
Name | Flags | Card. | Type | Description & Constraints |
---|---|---|---|---|
Location | I | 0..* | Details and position information for a physical place | |
id | Σ | 0..1 | id | Logical id of this artifact |
meta | Σ | 0..1 | Meta | Metadata about the resource |
implicitRules | ?!Σ | 0..1 | uri | A set of rules under which this content was created |
language | 0..1 | code | Language of the resource content Binding: CommonLanguages (preferred) Max Binding: AllLanguages | |
text | 0..1 | Narrative | Text summary of the resource, for human interpretation | |
contained | 0..* | Resource | Contained, inline Resources | |
extension | 0..* | Extension | Additional content defined by implementations | |
modifierExtension | ?! | 0..* | Extension | Extensions that cannot be ignored |
identifier | Σ | 0..* | Identifier | Unique code or number identifying the location to its users |
status | ?!SΣ | 0..1 | code | active | suspended | inactive Binding: LocationStatus (required) |
operationalStatus | Σ | 0..1 | Coding | The operational status of the location (typically only for a bed/room) Binding: v2 BED STATUS (preferred) |
name | SΣ | 1..1 | string | Name of the location as used by humans |
alias | 0..* | string | A list of alternate names that the location is known as, or was known as, in the past | |
description | Σ | 0..1 | string | Additional details about the location that could be displayed as further information to identify the location beyond its name |
mode | Σ | 0..1 | code | instance | kind Binding: LocationMode (required) |
type | Σ | 0..* | CodeableConcept | Type of function performed Binding: V3 Value SetServiceDeliveryLocationRoleType (extensible) |
telecom | S | 0..* | ContactPoint | Contact details of the location |
address | S | 0..1 | Address | Physical location |
id | 0..1 | string | Unique id for inter-element referencing | |
extension | 0..* | Extension | Additional content defined by implementations Slice: Unordered, Open by value:url | |
use | ?!Σ | 0..1 | code | home | work | temp | old | billing - purpose of this address Binding: AddressUse (required) Example General': home |
type | Σ | 0..1 | code | postal | physical | both Binding: AddressType (required) Example General': both |
text | Σ | 0..1 | string | Text representation of the address Example General': 137 Nowhere Street, Erewhon 9132 |
line | SΣ | 0..* | string | Street name, number, direction & P.O. Box etc. This repeating element order: The order in which lines should appear in an address label Example General': 137 Nowhere Street |
city | SΣ | 0..1 | string | Name of city, town etc. Example General': Erewhon |
district | Σ | 0..1 | string | District name (aka county) Example General': Madison |
state | SΣ | 0..1 | string | Sub-unit of country (abbreviations ok) Binding: USPS Two Letter Alphabetic Codes (extensible) |
postalCode | SΣ | 0..1 | string | US Zip Codes Example General': 9132 |
country | Σ | 0..1 | string | Country (e.g. can be ISO 3166 2 or 3 letter code) |
period | Σ | 0..1 | Period | Time period when address was/is in use Example General': {"start":"2010-03-23T00:00:00-04:00","end":"2010-07-01T00:00:00-04:00"} |
physicalType | Σ | 0..1 | CodeableConcept | Physical form of the location Binding: LocationType (example) |
position | I | 0..1 | BackboneElement | The absolute geographic location |
id | 0..1 | string | Unique id for inter-element referencing | |
extension | 0..* | Extension | Additional content defined by implementations | |
modifierExtension | ?!Σ | 0..* | Extension | Extensions that cannot be ignored even if unrecognized |
longitude | 1..1 | decimal | Longitude with WGS84 datum | |
latitude | 1..1 | decimal | Latitude with WGS84 datum | |
altitude | 0..1 | decimal | Altitude with WGS84 datum | |
managingOrganization | SΣ | 0..1 | Reference(US Core Organization Profile) | Organization responsible for provisioning and upkeep |
partOf | 0..1 | Reference(Location) | Another Location this one is physically a part of | |
hoursOfOperation | I | 0..* | BackboneElement | What days/times during a week is this location usually open |
id | 0..1 | string | Unique id for inter-element referencing | |
extension | 0..* | Extension | Additional content defined by implementations | |
modifierExtension | ?!Σ | 0..* | Extension | Extensions that cannot be ignored even if unrecognized |
daysOfWeek | 0..* | code | mon | tue | wed | thu | fri | sat | sun Binding: DaysOfWeek (required) | |
allDay | 0..1 | boolean | The Location is open all day | |
openingTime | 0..1 | time | Time that the Location opens | |
closingTime | 0..1 | time | Time that the Location closes | |
availabilityExceptions | 0..1 | string | Description of availability exceptions | |
endpoint | 0..* | Reference(Endpoint) | Technical endpoints providing access to services operated for the location | |
Documentation for this format |
Downloads: StructureDefinition: (XML, JSON), Schema: XML Schematron
Quick Start
Below is an overview of the required set of RESTful FHIR interactions - for example, search and read operations - for this profile. See the Conformance requirements for a complete list of supported RESTful interactions for this IG.
- See the General Guidance section for additional rules and expectations when a server requires status parameters.
- See the General Guidance section for additional guidance on searching for multiple patients.
Mandatory Search Parameters:
The following search parameters, search parameter combinations SHALL be supported. Any listed search parameter modifiers, comparators, chains and composites SHALL also be supported UNLESS they are listed as “optional” in which case they SHOULD be supported.:
-
SHALL support searching by location name using the
name
search parameter:GET [base]/Location?name=[string]
Example:
- GET [base]/Location?name=Health
Implementation Notes: Fetches a bundle of all Location resources that match the name (how to search by string)
-
SHALL support searching location based on text address using the
address
search parameter:GET [base]/Location?address=[string]
Example:
- GET [base]/Location?address=Arbor
Implementation Notes: Fetches a bundle of all Location resources that match the address string (how to search by string)
Optional Search Parameters:
The following search parameters, search parameter combinations and search parameter modifiers, comparators, chains and composites SHOULD be supported.
-
SHOULD support searching using the
address-city
search parameter:GET [base]/Location?address-city=[string]
Example:
- GET [base]/Location?address-city=Ann Arbor
Implementation Notes: Fetches a bundle of all Location resources for the city (how to search by string)
-
SHOULD support searching using the
address-state
search parameter:GET [base]/Location?address-state=[string]
Example:
- GET [base]/Location?address-state=MI
Implementation Notes: Fetches a bundle of all Location resources for the state (how to search by string)
-
SHOULD support searching using the
address-postalcode
search parameter:GET [base]/Location?address-postalcode=[string]
Example:
- GET [base]/Location?address-postalcode=48104
Implementation Notes: Fetches a bundle of all Location resources for the ZIP code (how to search by string)