Health Connect Australia Provider Directory FHIR Implementation Guide, published by Australian Digital Health Agency. This guide is not an authorized publication; it is the continuous build for version 0.1.0-preview built by the FHIR (HL7® FHIR® Standard) CI Build. This version is based on the current content of https://github.com/AuDigitalHealth/HealthConnect/ and changes regularly. See the Directory of published versions
| Official URL: http://ns.electronichealth.net.au/hc/StructureDefinition/hc-location | Version: 0.1.0-preview | |||
| Standards status: Draft | Computable Name: HCLocation | |||
Usage:Jurisdiction: Australia |
||||
Copyright/Legal: Copyright © 2025 Australian Digital Health Agency - All rights reserved. This content is licensed under a Creative Commons Attribution 4.0 International License. See https://creativecommons.org/licenses/by/4.0/ |
||||
This profile defines a healthcare location (can also be referred as 'location') reflects the place, a site of care i.e. a practice, clinic, hospital, or facility at which healthcare services are provided by the healthcare organisation. The healthcare location can be a physical, mobile, or virtual location. In certain cases, a healthcare location can also represent a site of care within the hospital or building premises such as consulting room, operating room, outpatient room, unit, ward (e.g. maternity ward), department (e.g. emergency department) etc.
No data is entered directly into Health Connect; all directory content is sourced from authoritative systems including PCA, HI-Service, and NHSD.
Note: All elements defined within this profile are expected to be supported by implementing systems unless explicitly stated otherwise. The following sections provide additional guidance and exceptions for specific elements.
Extensions introduced in this profile:
Publishing guidance:
A HC Location resource may also have additional identifiers specific to other business partners, and their identifier systems may or may not match other identifier slices defined in AU Core Location.
The usage notes of the AU Base Location profile provide guidance for Locations that may form part of defining a mobile or remotely delivered service. The HC Location profile formalises this guidance as mandatory requirements (via invariants). The requirements are summarised below:
A HC Location for a mobile service shall have:
A HC Location for a virtually delivered service shall have:
When a Location is to be represented as a physical type, the physicalType element is used to carry an applicable code from the Location Type (Physical) - AU Extended ValueSet.
The physicalType element can be used to express more specific details about the physical nature of a Location (for example: ward, building, dwelling).
The managingOrganization element must contain a relative reference to an existing HC Organization.
Description: If the preferred postal address extension is present on an address then that address must be of type 'postal'.
Implementation note: The profile enforces this rule so that the hc-preferred-postal-address extension is only used to carry postal/mailing addresses (for example PO Boxes). Publishing systems SHOULD only set the extension on addresses whose type is postal.
Description: If a location's type is VI or MOBL then an address does not need to be present. For all other location types an address MUST be present.
Implementation note: This invariant ensures that physical locations provide a postal/physical address, while virtual or mobile services (for example telehealth, mobile clinics, ambulance services) may omit a fixed address.
Description: If a location's type includes the MOBL code then it is recommended that an additional modifier coding is provided to describe the mobile service (either PTRES, SCHOOL, WORK, COMM, AMB) but not VI.
Implementation note: This rule is a warning — it does not block publishing but encourages publishers to provide additional context about where the mobile service operates. Implementers should supply a secondary type.coding entry when describing mobile services to improve discoverability.
Description: If a location's type includes the VI code then no additional modifier codings should be present.
Implementation note: This rule is a warning — virtual locations should be clearly identified as virtual-only and not include additional modifiers that suggest physical or mobile subtypes. If a virtual service also has a physical component, model those as separate Location resources.
Description: A Location resource MUST include either a type or a physicalType element.
Implementation note: This rule is enforced as an error — every Location must be classified either by type (logical role such as MOBL, VI, etc.) or by physicalType (when the Location represents a specific physical characteristic). Implementers MUST populate at least one of these elements when creating Location resources.
Usages:
You can also check for usages in the FHIR IG Statistics
Description of Profiles, Differentials, Snapshots and how the different presentations work.
| Name | Flags | Card. | Type | Description & Constraints Filter: ![]() ![]() |
|---|---|---|---|---|
![]() |
C | 0..* | AUCoreLocation | Australian Location Directory Entry Constraints: au-core-loc-01, preferred-postal-address, address-requirement |
![]() ![]() |
Σ | 0..1 | Meta | Metadata on Location |
![]() ![]() |
?!Σ | 0..1 | uri | A set of rules under which this content was created |
![]() ![]() |
0..* | Extension | Extension Slice: Unordered, Open by value:url | |
![]() ![]() ![]() |
S | 0..* | CodeableConcept | Amenities or facilities available at or near the location. URL: http://ns.electronichealth.net.au/hc/StructureDefinition/hc-amenity Binding: HC Amenity ValueSet (required) |
![]() ![]() ![]() |
S | 0..* | Address | Preferred postal address URL: http://ns.electronichealth.net.au/hc/StructureDefinition/hc-preferred-postal-address |
![]() ![]() |
?! | 0..* | Extension | Extensions that cannot be ignored |
![]() ![]() |
?!Σ | 0..1 | code | active | suspended | inactive Binding: LocationStatus (required): Indicates whether the location is still in use. |
![]() ![]() |
SOΣ | 1..1 | string | Name of the location as used by humans |
![]() ![]() |
S | 0..* | string | Alternative names for the location |
![]() ![]() |
SOΣC | 0..* | CodeableConcept | Indicates whether the location is a virtual location or mobile service. Binding: HC Service Delivery Location Role Type ValueSet (extensible) |
![]() ![]() |
S | 2..* | ContactPoint | Contact details of the location Slice: Unordered, Open by value:system |
![]() ![]() ![]() |
S | 1..* | ContactPoint | Phone number for the location. |
![]() ![]() ![]() ![]() |
ΣC | 1..1 | code | phone | fax | email | pager | url | sms | other Binding: ContactPointSystem (required): Telecommunications form for contact point. Required Pattern: phone |
![]() ![]() ![]() ![]() |
?!Σ | 0..1 | code | home | work | temp | old | mobile - purpose of this contact point Binding: ContactPointUse (required): Use of contact point. |
![]() ![]() ![]() |
S | 1..* | ContactPoint | Email address for the location. |
![]() ![]() ![]() ![]() |
ΣC | 1..1 | code | phone | fax | email | pager | url | sms | other Binding: ContactPointSystem (required): Telecommunications form for contact point. Required Pattern: email |
![]() ![]() ![]() ![]() |
?!Σ | 0..1 | code | home | work | temp | old | mobile - purpose of this contact point Binding: ContactPointUse (required): Use of contact point. |
![]() ![]() |
SOC | 0..1 | Address, AustralianAddress | Address where the service or practitioner role is located. Virtual and mobile locations may not have a fixed address. |
![]() ![]() |
SOΣ | 0..1 | CodeableConcept | Physical form of the location Binding: Location Type (Physical) - AU Extended (preferred) |
![]() ![]() |
SOΣ | 1..1 | Reference(HC Organization) | Reference to managing organisation with HPI-O. |
![]() ![]() |
0..1 | Reference(HC Location) | Another Location this one is physically a part of | |
![]() ![]() |
S | 0..1 | Reference(HC Endpoint) | Technical endpoints providing access to services operated for the location |
Documentation for this format | ||||
| Path | Status | Usage | ValueSet | Version | Source |
| Location.status | Base | required | LocationStatus | 📍4.0.1 | FHIR Std. |
| Location.type | Base | extensible | HC Service Delivery Location Role Type ValueSet | 📦0.1.0-preview | This IG |
| Location.telecom:phone.system | Base | required | ContactPointSystem | 📍4.0.1 | FHIR Std. |
| Location.telecom:phone.use | Base | required | ContactPointUse | 📍4.0.1 | FHIR Std. |
| Location.telecom:email.system | Base | required | ContactPointSystem | 📍4.0.1 | FHIR Std. |
| Location.telecom:email.use | Base | required | ContactPointUse | 📍4.0.1 | FHIR Std. |
| Location.physicalType | Base | preferred | Location Type (Physical) - AU Extended | 📦6.0.0-ballot | AU Base Implementation Guide v6.0 |
| Id | Grade | Path(s) | Description | Expression |
| address-requirement | error | Location | If location type is VI or MOBL then an address does not need to be present. For all other location types an address must be present. |
type.coding.where(code = 'VI' or code = 'MOBL').exists().not() implies address.exists()
|
| au-core-loc-01 | error | Location | The location shall at least have a valid identifier or address or type |
address.exists() or type.exists() or identifier.where(system.count() + value.count() >1).exists()
|
| dom-2 | error | Location | If the resource is contained in another resource, it SHALL NOT contain nested Resources |
contained.contained.empty()
|
| dom-3 | error | Location | If the resource is contained in another resource, it SHALL be referred to from elsewhere in the resource or SHALL refer to the containing resource |
contained.where((('#'+id in (%resource.descendants().reference | %resource.descendants().as(canonical) | %resource.descendants().as(uri) | %resource.descendants().as(url))) or descendants().where(reference = '#').exists() or descendants().where(as(canonical) = '#').exists() or descendants().where(as(canonical) = '#').exists()).not()).trace('unmatched', id).empty()
|
| dom-4 | error | Location | If a resource is contained in another resource, it SHALL NOT have a meta.versionId or a meta.lastUpdated |
contained.meta.versionId.empty() and contained.meta.lastUpdated.empty()
|
| dom-5 | error | Location | If a resource is contained in another resource, it SHALL NOT have a security label |
contained.meta.security.empty()
|
| dom-6 | best practice | Location | A resource should have narrative for robust management |
text.`div`.exists()
|
| ele-1 | error | **ALL** elements | All FHIR elements must have a @value or children |
hasValue() or (children().count() > id.count())
|
| ext-1 | error | **ALL** extensions | Must have either extensions or value[x], not both |
extension.exists() != value.exists()
|
| preferred-postal-address | error | Location | If the preferred postal address extension is present on an address then that address must be of type 'postal' |
address.exists() and address.extension.where(url='http://ns.electronichealth.net.au/hc/StructureDefinition/hc-preferred-postal-address').exists() implies address.where(type='postal').exists()
|
This structure is derived from AUCoreLocation
| Name | Flags | Card. | Type | Description & Constraints Filter: ![]() ![]() |
|---|---|---|---|---|
![]() |
C | 0..* | AUCoreLocation | Australian Location Directory Entry Constraints: preferred-postal-address, address-requirement |
![]() ![]() |
0..1 | Meta | Metadata on Location | |
![]() ![]() |
0..* | Extension | Extension Slice: Unordered, Open by value:url | |
![]() ![]() ![]() |
S | 0..* | CodeableConcept | Amenities or facilities available at or near the location. URL: http://ns.electronichealth.net.au/hc/StructureDefinition/hc-amenity Binding: HC Amenity ValueSet (required) |
![]() ![]() ![]() |
S | 0..* | Address | Preferred postal address URL: http://ns.electronichealth.net.au/hc/StructureDefinition/hc-preferred-postal-address |
![]() ![]() |
1..1 | string | Name of the location as used by humans | |
![]() ![]() |
S | 0..* | string | Alternative names for the location |
![]() ![]() |
0..* | CodeableConcept | Indicates whether the location is a virtual location or mobile service. Binding: HC Service Delivery Location Role Type ValueSet (extensible) | |
![]() ![]() |
S | 2..* | ContactPoint | Contact details of the location Slice: Unordered, Open by value:system |
![]() ![]() ![]() |
S | 1..* | ContactPoint | Phone number for the location. |
![]() ![]() ![]() ![]() |
1..1 | code | phone | fax | email | pager | url | sms | other Required Pattern: phone | |
![]() ![]() ![]() |
S | 1..* | ContactPoint | Email address for the location. |
![]() ![]() ![]() ![]() |
1..1 | code | phone | fax | email | pager | url | sms | other Required Pattern: email | |
![]() ![]() |
0..1 | Address, AustralianAddress | Address where the service or practitioner role is located. Virtual and mobile locations may not have a fixed address. | |
![]() ![]() |
1..1 | Reference(HC Organization) | Reference to managing organisation with HPI-O. | |
![]() ![]() |
0..1 | Reference(HC Location) | Another Location this one is physically a part of | |
![]() ![]() |
S | 0..1 | Reference(HC Endpoint) | Technical endpoints providing access to services operated for the location |
Documentation for this format | ||||
| Path | Status | Usage | ValueSet | Version | Source |
| Location.type | Base | extensible | HC Service Delivery Location Role Type ValueSet | 📦0.1.0-preview | This IG |
| Id | Grade | Path(s) | Description | Expression |
| address-requirement | error | Location | If location type is VI or MOBL then an address does not need to be present. For all other location types an address must be present. |
type.coding.where(code = 'VI' or code = 'MOBL').exists().not() implies address.exists()
|
| preferred-postal-address | error | Location | If the preferred postal address extension is present on an address then that address must be of type 'postal' |
address.exists() and address.extension.where(url='http://ns.electronichealth.net.au/hc/StructureDefinition/hc-preferred-postal-address').exists() implies address.where(type='postal').exists()
|
| Name | Flags | Card. | Type | Description & Constraints Filter: ![]() ![]() | ||||
|---|---|---|---|---|---|---|---|---|
![]() |
C | 0..* | AUCoreLocation | Australian Location Directory Entry Constraints: au-core-loc-01, preferred-postal-address, address-requirement | ||||
![]() ![]() |
Σ | 0..1 | id | Logical id of this artifact | ||||
![]() ![]() |
Σ | 0..1 | Meta | Metadata on Location | ||||
![]() ![]() |
?!Σ | 0..1 | uri | A set of rules under which this content was created | ||||
![]() ![]() |
0..1 | code | Language of the resource content Binding: CommonLanguages (preferred): A human language.
| |||||
![]() ![]() |
0..1 | Narrative | Text summary of the resource, for human interpretation This profile does not constrain the narrative in regard to content, language, or traceability to data elements | |||||
![]() ![]() |
0..* | Resource | Contained, inline Resources | |||||
![]() ![]() |
0..* | Extension | Extension Slice: Unordered, Open by value:url | |||||
![]() ![]() ![]() |
S | 0..* | CodeableConcept | Amenities or facilities available at or near the location. URL: http://ns.electronichealth.net.au/hc/StructureDefinition/hc-amenity Binding: HC Amenity ValueSet (required) | ||||
![]() ![]() ![]() |
S | 0..* | Address | Preferred postal address URL: http://ns.electronichealth.net.au/hc/StructureDefinition/hc-preferred-postal-address | ||||
![]() ![]() |
?! | 0..* | Extension | Extensions that cannot be ignored | ||||
![]() ![]() |
ΣC | 0..* | Identifier, AULocationSpecificPracticeNumber, AUNATASiteNumber | Unique code or number identifying the location to its users | ||||
![]() ![]() |
?!Σ | 0..1 | code | active | suspended | inactive Binding: LocationStatus (required): Indicates whether the location is still in use. | ||||
![]() ![]() |
Σ | 0..1 | Coding | The operational status of the location (typically only for a bed/room) Binding: hl7VS-bedStatus (preferred): The operational status if the location (where typically a bed/room). | ||||
![]() ![]() |
SOΣ | 1..1 | string | Name of the location as used by humans | ||||
![]() ![]() |
S | 0..* | string | Alternative names for the location | ||||
![]() ![]() |
Σ | 0..1 | string | Additional details about the location that could be displayed as further information to identify the location beyond its name | ||||
![]() ![]() |
Σ | 0..1 | code | instance | kind Binding: LocationMode (required): Indicates whether a resource instance represents a specific location or a class of locations. | ||||
![]() ![]() |
SOΣC | 0..* | CodeableConcept | Indicates whether the location is a virtual location or mobile service. Binding: HC Service Delivery Location Role Type ValueSet (extensible) | ||||
![]() ![]() |
S | 2..* | ContactPoint | Contact details of the location Slice: Unordered, Open by value:system | ||||
![]() ![]() ![]() |
S | 1..* | ContactPoint | Phone number for the location. | ||||
![]() ![]() ![]() ![]() |
0..1 | string | Unique id for inter-element referencing | |||||
![]() ![]() ![]() ![]() |
0..* | Extension | Additional content defined by implementations Slice: Unordered, Open by value:url | |||||
![]() ![]() ![]() ![]() |
ΣC | 1..1 | code | phone | fax | email | pager | url | sms | other Binding: ContactPointSystem (required): Telecommunications form for contact point. Required Pattern: phone | ||||
![]() ![]() ![]() ![]() |
Σ | 0..1 | string | The actual contact point details | ||||
![]() ![]() ![]() ![]() |
?!Σ | 0..1 | code | home | work | temp | old | mobile - purpose of this contact point Binding: ContactPointUse (required): Use of contact point. | ||||
![]() ![]() ![]() ![]() |
Σ | 0..1 | positiveInt | Specify preferred order of use (1 = highest) | ||||
![]() ![]() ![]() ![]() |
Σ | 0..1 | Period | Time period when the contact point was/is in use | ||||
![]() ![]() ![]() |
S | 1..* | ContactPoint | Email address for the location. | ||||
![]() ![]() ![]() ![]() |
0..1 | string | Unique id for inter-element referencing | |||||
![]() ![]() ![]() ![]() |
0..* | Extension | Additional content defined by implementations Slice: Unordered, Open by value:url | |||||
![]() ![]() ![]() ![]() |
ΣC | 1..1 | code | phone | fax | email | pager | url | sms | other Binding: ContactPointSystem (required): Telecommunications form for contact point. Required Pattern: email | ||||
![]() ![]() ![]() ![]() |
Σ | 0..1 | string | The actual contact point details | ||||
![]() ![]() ![]() ![]() |
?!Σ | 0..1 | code | home | work | temp | old | mobile - purpose of this contact point Binding: ContactPointUse (required): Use of contact point. | ||||
![]() ![]() ![]() ![]() |
Σ | 0..1 | positiveInt | Specify preferred order of use (1 = highest) | ||||
![]() ![]() ![]() ![]() |
Σ | 0..1 | Period | Time period when the contact point was/is in use | ||||
![]() ![]() |
SOC | 0..1 | Address, AustralianAddress | Address where the service or practitioner role is located. Virtual and mobile locations may not have a fixed address. | ||||
![]() ![]() |
SOΣ | 0..1 | CodeableConcept | Physical form of the location Binding: Location Type (Physical) - AU Extended (preferred) | ||||
![]() ![]() |
0..1 | BackboneElement | The absolute geographic location | |||||
![]() ![]() ![]() |
0..1 | string | Unique id for inter-element referencing | |||||
![]() ![]() ![]() |
0..* | Extension | Additional content defined by implementations | |||||
![]() ![]() ![]() |
?!Σ | 0..* | Extension | Extensions that cannot be ignored even if unrecognized | ||||
![]() ![]() ![]() |
1..1 | decimal | Longitude with WGS84 datum | |||||
![]() ![]() ![]() |
1..1 | decimal | Latitude with WGS84 datum | |||||
![]() ![]() ![]() |
0..1 | decimal | Altitude with WGS84 datum | |||||
![]() ![]() |
SOΣ | 1..1 | Reference(HC Organization) | Reference to managing organisation with HPI-O. | ||||
![]() ![]() |
0..1 | Reference(HC Location) | Another Location this one is physically a part of | |||||
![]() ![]() |
0..* | BackboneElement | What days/times during a week is this location usually open | |||||
![]() ![]() ![]() |
0..1 | string | Unique id for inter-element referencing | |||||
![]() ![]() ![]() |
0..* | Extension | Additional content defined by implementations | |||||
![]() ![]() ![]() |
?!Σ | 0..* | Extension | Extensions that cannot be ignored even if unrecognized | ||||
![]() ![]() ![]() |
0..* | code | mon | tue | wed | thu | fri | sat | sun Binding: DaysOfWeek (required): The days of the week. | |||||
![]() ![]() ![]() |
0..1 | boolean | The Location is open all day | |||||
![]() ![]() ![]() |
0..1 | time | Time that the Location opens | |||||
![]() ![]() ![]() |
0..1 | time | Time that the Location closes | |||||
![]() ![]() |
0..1 | string | Description of availability exceptions | |||||
![]() ![]() |
S | 0..1 | Reference(HC Endpoint) | Technical endpoints providing access to services operated for the location | ||||
Documentation for this format | ||||||||
| Path | Status | Usage | ValueSet | Version | Source |
| Location.language | Base | preferred | Common Languages | 📦4.0.1 | FHIR Std. |
| Location.status | Base | required | LocationStatus | 📍4.0.1 | FHIR Std. |
| Location.operationalStatus | Base | preferred | hl7VS-bedStatus | 📦2.0.0 | THO v7.0 |
| Location.mode | Base | required | LocationMode | 📍4.0.1 | FHIR Std. |
| Location.type | Base | extensible | HC Service Delivery Location Role Type ValueSet | 📦0.1.0-preview | This IG |
| Location.telecom:phone.system | Base | required | ContactPointSystem | 📍4.0.1 | FHIR Std. |
| Location.telecom:phone.use | Base | required | ContactPointUse | 📍4.0.1 | FHIR Std. |
| Location.telecom:email.system | Base | required | ContactPointSystem | 📍4.0.1 | FHIR Std. |
| Location.telecom:email.use | Base | required | ContactPointUse | 📍4.0.1 | FHIR Std. |
| Location.physicalType | Base | preferred | Location Type (Physical) - AU Extended | 📦6.0.0-ballot | AU Base Implementation Guide v6.0 |
| Location.hoursOfOperation.daysOfWeek | Base | required | DaysOfWeek | 📍4.0.1 | FHIR Std. |
| Id | Grade | Path(s) | Description | Expression |
| address-requirement | error | Location | If location type is VI or MOBL then an address does not need to be present. For all other location types an address must be present. |
type.coding.where(code = 'VI' or code = 'MOBL').exists().not() implies address.exists()
|
| au-core-loc-01 | error | Location | The location shall at least have a valid identifier or address or type |
address.exists() or type.exists() or identifier.where(system.count() + value.count() >1).exists()
|
| dom-2 | error | Location | If the resource is contained in another resource, it SHALL NOT contain nested Resources |
contained.contained.empty()
|
| dom-3 | error | Location | If the resource is contained in another resource, it SHALL be referred to from elsewhere in the resource or SHALL refer to the containing resource |
contained.where((('#'+id in (%resource.descendants().reference | %resource.descendants().as(canonical) | %resource.descendants().as(uri) | %resource.descendants().as(url))) or descendants().where(reference = '#').exists() or descendants().where(as(canonical) = '#').exists() or descendants().where(as(canonical) = '#').exists()).not()).trace('unmatched', id).empty()
|
| dom-4 | error | Location | If a resource is contained in another resource, it SHALL NOT have a meta.versionId or a meta.lastUpdated |
contained.meta.versionId.empty() and contained.meta.lastUpdated.empty()
|
| dom-5 | error | Location | If a resource is contained in another resource, it SHALL NOT have a security label |
contained.meta.security.empty()
|
| dom-6 | best practice | Location | A resource should have narrative for robust management |
text.`div`.exists()
|
| ele-1 | error | **ALL** elements | All FHIR elements must have a @value or children |
hasValue() or (children().count() > id.count())
|
| ext-1 | error | **ALL** extensions | Must have either extensions or value[x], not both |
extension.exists() != value.exists()
|
| preferred-postal-address | error | Location | If the preferred postal address extension is present on an address then that address must be of type 'postal' |
address.exists() and address.extension.where(url='http://ns.electronichealth.net.au/hc/StructureDefinition/hc-preferred-postal-address').exists() implies address.where(type='postal').exists()
|
This structure is derived from AUCoreLocation
Summary
Mandatory: 6 elements
Must-Support: 7 elements
Structures
This structure refers to these other structures:
Extensions
This structure refers to these extensions:
Slices
This structure defines the following Slices:
Key Elements View
| Name | Flags | Card. | Type | Description & Constraints Filter: ![]() ![]() |
|---|---|---|---|---|
![]() |
C | 0..* | AUCoreLocation | Australian Location Directory Entry Constraints: au-core-loc-01, preferred-postal-address, address-requirement |
![]() ![]() |
Σ | 0..1 | Meta | Metadata on Location |
![]() ![]() |
?!Σ | 0..1 | uri | A set of rules under which this content was created |
![]() ![]() |
0..* | Extension | Extension Slice: Unordered, Open by value:url | |
![]() ![]() ![]() |
S | 0..* | CodeableConcept | Amenities or facilities available at or near the location. URL: http://ns.electronichealth.net.au/hc/StructureDefinition/hc-amenity Binding: HC Amenity ValueSet (required) |
![]() ![]() ![]() |
S | 0..* | Address | Preferred postal address URL: http://ns.electronichealth.net.au/hc/StructureDefinition/hc-preferred-postal-address |
![]() ![]() |
?! | 0..* | Extension | Extensions that cannot be ignored |
![]() ![]() |
?!Σ | 0..1 | code | active | suspended | inactive Binding: LocationStatus (required): Indicates whether the location is still in use. |
![]() ![]() |
SOΣ | 1..1 | string | Name of the location as used by humans |
![]() ![]() |
S | 0..* | string | Alternative names for the location |
![]() ![]() |
SOΣC | 0..* | CodeableConcept | Indicates whether the location is a virtual location or mobile service. Binding: HC Service Delivery Location Role Type ValueSet (extensible) |
![]() ![]() |
S | 2..* | ContactPoint | Contact details of the location Slice: Unordered, Open by value:system |
![]() ![]() ![]() |
S | 1..* | ContactPoint | Phone number for the location. |
![]() ![]() ![]() ![]() |
ΣC | 1..1 | code | phone | fax | email | pager | url | sms | other Binding: ContactPointSystem (required): Telecommunications form for contact point. Required Pattern: phone |
![]() ![]() ![]() ![]() |
?!Σ | 0..1 | code | home | work | temp | old | mobile - purpose of this contact point Binding: ContactPointUse (required): Use of contact point. |
![]() ![]() ![]() |
S | 1..* | ContactPoint | Email address for the location. |
![]() ![]() ![]() ![]() |
ΣC | 1..1 | code | phone | fax | email | pager | url | sms | other Binding: ContactPointSystem (required): Telecommunications form for contact point. Required Pattern: email |
![]() ![]() ![]() ![]() |
?!Σ | 0..1 | code | home | work | temp | old | mobile - purpose of this contact point Binding: ContactPointUse (required): Use of contact point. |
![]() ![]() |
SOC | 0..1 | Address, AustralianAddress | Address where the service or practitioner role is located. Virtual and mobile locations may not have a fixed address. |
![]() ![]() |
SOΣ | 0..1 | CodeableConcept | Physical form of the location Binding: Location Type (Physical) - AU Extended (preferred) |
![]() ![]() |
SOΣ | 1..1 | Reference(HC Organization) | Reference to managing organisation with HPI-O. |
![]() ![]() |
0..1 | Reference(HC Location) | Another Location this one is physically a part of | |
![]() ![]() |
S | 0..1 | Reference(HC Endpoint) | Technical endpoints providing access to services operated for the location |
Documentation for this format | ||||
| Path | Status | Usage | ValueSet | Version | Source |
| Location.status | Base | required | LocationStatus | 📍4.0.1 | FHIR Std. |
| Location.type | Base | extensible | HC Service Delivery Location Role Type ValueSet | 📦0.1.0-preview | This IG |
| Location.telecom:phone.system | Base | required | ContactPointSystem | 📍4.0.1 | FHIR Std. |
| Location.telecom:phone.use | Base | required | ContactPointUse | 📍4.0.1 | FHIR Std. |
| Location.telecom:email.system | Base | required | ContactPointSystem | 📍4.0.1 | FHIR Std. |
| Location.telecom:email.use | Base | required | ContactPointUse | 📍4.0.1 | FHIR Std. |
| Location.physicalType | Base | preferred | Location Type (Physical) - AU Extended | 📦6.0.0-ballot | AU Base Implementation Guide v6.0 |
| Id | Grade | Path(s) | Description | Expression |
| address-requirement | error | Location | If location type is VI or MOBL then an address does not need to be present. For all other location types an address must be present. |
type.coding.where(code = 'VI' or code = 'MOBL').exists().not() implies address.exists()
|
| au-core-loc-01 | error | Location | The location shall at least have a valid identifier or address or type |
address.exists() or type.exists() or identifier.where(system.count() + value.count() >1).exists()
|
| dom-2 | error | Location | If the resource is contained in another resource, it SHALL NOT contain nested Resources |
contained.contained.empty()
|
| dom-3 | error | Location | If the resource is contained in another resource, it SHALL be referred to from elsewhere in the resource or SHALL refer to the containing resource |
contained.where((('#'+id in (%resource.descendants().reference | %resource.descendants().as(canonical) | %resource.descendants().as(uri) | %resource.descendants().as(url))) or descendants().where(reference = '#').exists() or descendants().where(as(canonical) = '#').exists() or descendants().where(as(canonical) = '#').exists()).not()).trace('unmatched', id).empty()
|
| dom-4 | error | Location | If a resource is contained in another resource, it SHALL NOT have a meta.versionId or a meta.lastUpdated |
contained.meta.versionId.empty() and contained.meta.lastUpdated.empty()
|
| dom-5 | error | Location | If a resource is contained in another resource, it SHALL NOT have a security label |
contained.meta.security.empty()
|
| dom-6 | best practice | Location | A resource should have narrative for robust management |
text.`div`.exists()
|
| ele-1 | error | **ALL** elements | All FHIR elements must have a @value or children |
hasValue() or (children().count() > id.count())
|
| ext-1 | error | **ALL** extensions | Must have either extensions or value[x], not both |
extension.exists() != value.exists()
|
| preferred-postal-address | error | Location | If the preferred postal address extension is present on an address then that address must be of type 'postal' |
address.exists() and address.extension.where(url='http://ns.electronichealth.net.au/hc/StructureDefinition/hc-preferred-postal-address').exists() implies address.where(type='postal').exists()
|
Differential View
This structure is derived from AUCoreLocation
| Name | Flags | Card. | Type | Description & Constraints Filter: ![]() ![]() |
|---|---|---|---|---|
![]() |
C | 0..* | AUCoreLocation | Australian Location Directory Entry Constraints: preferred-postal-address, address-requirement |
![]() ![]() |
0..1 | Meta | Metadata on Location | |
![]() ![]() |
0..* | Extension | Extension Slice: Unordered, Open by value:url | |
![]() ![]() ![]() |
S | 0..* | CodeableConcept | Amenities or facilities available at or near the location. URL: http://ns.electronichealth.net.au/hc/StructureDefinition/hc-amenity Binding: HC Amenity ValueSet (required) |
![]() ![]() ![]() |
S | 0..* | Address | Preferred postal address URL: http://ns.electronichealth.net.au/hc/StructureDefinition/hc-preferred-postal-address |
![]() ![]() |
1..1 | string | Name of the location as used by humans | |
![]() ![]() |
S | 0..* | string | Alternative names for the location |
![]() ![]() |
0..* | CodeableConcept | Indicates whether the location is a virtual location or mobile service. Binding: HC Service Delivery Location Role Type ValueSet (extensible) | |
![]() ![]() |
S | 2..* | ContactPoint | Contact details of the location Slice: Unordered, Open by value:system |
![]() ![]() ![]() |
S | 1..* | ContactPoint | Phone number for the location. |
![]() ![]() ![]() ![]() |
1..1 | code | phone | fax | email | pager | url | sms | other Required Pattern: phone | |
![]() ![]() ![]() |
S | 1..* | ContactPoint | Email address for the location. |
![]() ![]() ![]() ![]() |
1..1 | code | phone | fax | email | pager | url | sms | other Required Pattern: email | |
![]() ![]() |
0..1 | Address, AustralianAddress | Address where the service or practitioner role is located. Virtual and mobile locations may not have a fixed address. | |
![]() ![]() |
1..1 | Reference(HC Organization) | Reference to managing organisation with HPI-O. | |
![]() ![]() |
0..1 | Reference(HC Location) | Another Location this one is physically a part of | |
![]() ![]() |
S | 0..1 | Reference(HC Endpoint) | Technical endpoints providing access to services operated for the location |
Documentation for this format | ||||
| Path | Status | Usage | ValueSet | Version | Source |
| Location.type | Base | extensible | HC Service Delivery Location Role Type ValueSet | 📦0.1.0-preview | This IG |
| Id | Grade | Path(s) | Description | Expression |
| address-requirement | error | Location | If location type is VI or MOBL then an address does not need to be present. For all other location types an address must be present. |
type.coding.where(code = 'VI' or code = 'MOBL').exists().not() implies address.exists()
|
| preferred-postal-address | error | Location | If the preferred postal address extension is present on an address then that address must be of type 'postal' |
address.exists() and address.extension.where(url='http://ns.electronichealth.net.au/hc/StructureDefinition/hc-preferred-postal-address').exists() implies address.where(type='postal').exists()
|
Snapshot View
| Name | Flags | Card. | Type | Description & Constraints Filter: ![]() ![]() | ||||
|---|---|---|---|---|---|---|---|---|
![]() |
C | 0..* | AUCoreLocation | Australian Location Directory Entry Constraints: au-core-loc-01, preferred-postal-address, address-requirement | ||||
![]() ![]() |
Σ | 0..1 | id | Logical id of this artifact | ||||
![]() ![]() |
Σ | 0..1 | Meta | Metadata on Location | ||||
![]() ![]() |
?!Σ | 0..1 | uri | A set of rules under which this content was created | ||||
![]() ![]() |
0..1 | code | Language of the resource content Binding: CommonLanguages (preferred): A human language.
| |||||
![]() ![]() |
0..1 | Narrative | Text summary of the resource, for human interpretation This profile does not constrain the narrative in regard to content, language, or traceability to data elements | |||||
![]() ![]() |
0..* | Resource | Contained, inline Resources | |||||
![]() ![]() |
0..* | Extension | Extension Slice: Unordered, Open by value:url | |||||
![]() ![]() ![]() |
S | 0..* | CodeableConcept | Amenities or facilities available at or near the location. URL: http://ns.electronichealth.net.au/hc/StructureDefinition/hc-amenity Binding: HC Amenity ValueSet (required) | ||||
![]() ![]() ![]() |
S | 0..* | Address | Preferred postal address URL: http://ns.electronichealth.net.au/hc/StructureDefinition/hc-preferred-postal-address | ||||
![]() ![]() |
?! | 0..* | Extension | Extensions that cannot be ignored | ||||
![]() ![]() |
ΣC | 0..* | Identifier, AULocationSpecificPracticeNumber, AUNATASiteNumber | Unique code or number identifying the location to its users | ||||
![]() ![]() |
?!Σ | 0..1 | code | active | suspended | inactive Binding: LocationStatus (required): Indicates whether the location is still in use. | ||||
![]() ![]() |
Σ | 0..1 | Coding | The operational status of the location (typically only for a bed/room) Binding: hl7VS-bedStatus (preferred): The operational status if the location (where typically a bed/room). | ||||
![]() ![]() |
SOΣ | 1..1 | string | Name of the location as used by humans | ||||
![]() ![]() |
S | 0..* | string | Alternative names for the location | ||||
![]() ![]() |
Σ | 0..1 | string | Additional details about the location that could be displayed as further information to identify the location beyond its name | ||||
![]() ![]() |
Σ | 0..1 | code | instance | kind Binding: LocationMode (required): Indicates whether a resource instance represents a specific location or a class of locations. | ||||
![]() ![]() |
SOΣC | 0..* | CodeableConcept | Indicates whether the location is a virtual location or mobile service. Binding: HC Service Delivery Location Role Type ValueSet (extensible) | ||||
![]() ![]() |
S | 2..* | ContactPoint | Contact details of the location Slice: Unordered, Open by value:system | ||||
![]() ![]() ![]() |
S | 1..* | ContactPoint | Phone number for the location. | ||||
![]() ![]() ![]() ![]() |
0..1 | string | Unique id for inter-element referencing | |||||
![]() ![]() ![]() ![]() |
0..* | Extension | Additional content defined by implementations Slice: Unordered, Open by value:url | |||||
![]() ![]() ![]() ![]() |
ΣC | 1..1 | code | phone | fax | email | pager | url | sms | other Binding: ContactPointSystem (required): Telecommunications form for contact point. Required Pattern: phone | ||||
![]() ![]() ![]() ![]() |
Σ | 0..1 | string | The actual contact point details | ||||
![]() ![]() ![]() ![]() |
?!Σ | 0..1 | code | home | work | temp | old | mobile - purpose of this contact point Binding: ContactPointUse (required): Use of contact point. | ||||
![]() ![]() ![]() ![]() |
Σ | 0..1 | positiveInt | Specify preferred order of use (1 = highest) | ||||
![]() ![]() ![]() ![]() |
Σ | 0..1 | Period | Time period when the contact point was/is in use | ||||
![]() ![]() ![]() |
S | 1..* | ContactPoint | Email address for the location. | ||||
![]() ![]() ![]() ![]() |
0..1 | string | Unique id for inter-element referencing | |||||
![]() ![]() ![]() ![]() |
0..* | Extension | Additional content defined by implementations Slice: Unordered, Open by value:url | |||||
![]() ![]() ![]() ![]() |
ΣC | 1..1 | code | phone | fax | email | pager | url | sms | other Binding: ContactPointSystem (required): Telecommunications form for contact point. Required Pattern: email | ||||
![]() ![]() ![]() ![]() |
Σ | 0..1 | string | The actual contact point details | ||||
![]() ![]() ![]() ![]() |
?!Σ | 0..1 | code | home | work | temp | old | mobile - purpose of this contact point Binding: ContactPointUse (required): Use of contact point. | ||||
![]() ![]() ![]() ![]() |
Σ | 0..1 | positiveInt | Specify preferred order of use (1 = highest) | ||||
![]() ![]() ![]() ![]() |
Σ | 0..1 | Period | Time period when the contact point was/is in use | ||||
![]() ![]() |
SOC | 0..1 | Address, AustralianAddress | Address where the service or practitioner role is located. Virtual and mobile locations may not have a fixed address. | ||||
![]() ![]() |
SOΣ | 0..1 | CodeableConcept | Physical form of the location Binding: Location Type (Physical) - AU Extended (preferred) | ||||
![]() ![]() |
0..1 | BackboneElement | The absolute geographic location | |||||
![]() ![]() ![]() |
0..1 | string | Unique id for inter-element referencing | |||||
![]() ![]() ![]() |
0..* | Extension | Additional content defined by implementations | |||||
![]() ![]() ![]() |
?!Σ | 0..* | Extension | Extensions that cannot be ignored even if unrecognized | ||||
![]() ![]() ![]() |
1..1 | decimal | Longitude with WGS84 datum | |||||
![]() ![]() ![]() |
1..1 | decimal | Latitude with WGS84 datum | |||||
![]() ![]() ![]() |
0..1 | decimal | Altitude with WGS84 datum | |||||
![]() ![]() |
SOΣ | 1..1 | Reference(HC Organization) | Reference to managing organisation with HPI-O. | ||||
![]() ![]() |
0..1 | Reference(HC Location) | Another Location this one is physically a part of | |||||
![]() ![]() |
0..* | BackboneElement | What days/times during a week is this location usually open | |||||
![]() ![]() ![]() |
0..1 | string | Unique id for inter-element referencing | |||||
![]() ![]() ![]() |
0..* | Extension | Additional content defined by implementations | |||||
![]() ![]() ![]() |
?!Σ | 0..* | Extension | Extensions that cannot be ignored even if unrecognized | ||||
![]() ![]() ![]() |
0..* | code | mon | tue | wed | thu | fri | sat | sun Binding: DaysOfWeek (required): The days of the week. | |||||
![]() ![]() ![]() |
0..1 | boolean | The Location is open all day | |||||
![]() ![]() ![]() |
0..1 | time | Time that the Location opens | |||||
![]() ![]() ![]() |
0..1 | time | Time that the Location closes | |||||
![]() ![]() |
0..1 | string | Description of availability exceptions | |||||
![]() ![]() |
S | 0..1 | Reference(HC Endpoint) | Technical endpoints providing access to services operated for the location | ||||
Documentation for this format | ||||||||
| Path | Status | Usage | ValueSet | Version | Source |
| Location.language | Base | preferred | Common Languages | 📦4.0.1 | FHIR Std. |
| Location.status | Base | required | LocationStatus | 📍4.0.1 | FHIR Std. |
| Location.operationalStatus | Base | preferred | hl7VS-bedStatus | 📦2.0.0 | THO v7.0 |
| Location.mode | Base | required | LocationMode | 📍4.0.1 | FHIR Std. |
| Location.type | Base | extensible | HC Service Delivery Location Role Type ValueSet | 📦0.1.0-preview | This IG |
| Location.telecom:phone.system | Base | required | ContactPointSystem | 📍4.0.1 | FHIR Std. |
| Location.telecom:phone.use | Base | required | ContactPointUse | 📍4.0.1 | FHIR Std. |
| Location.telecom:email.system | Base | required | ContactPointSystem | 📍4.0.1 | FHIR Std. |
| Location.telecom:email.use | Base | required | ContactPointUse | 📍4.0.1 | FHIR Std. |
| Location.physicalType | Base | preferred | Location Type (Physical) - AU Extended | 📦6.0.0-ballot | AU Base Implementation Guide v6.0 |
| Location.hoursOfOperation.daysOfWeek | Base | required | DaysOfWeek | 📍4.0.1 | FHIR Std. |
| Id | Grade | Path(s) | Description | Expression |
| address-requirement | error | Location | If location type is VI or MOBL then an address does not need to be present. For all other location types an address must be present. |
type.coding.where(code = 'VI' or code = 'MOBL').exists().not() implies address.exists()
|
| au-core-loc-01 | error | Location | The location shall at least have a valid identifier or address or type |
address.exists() or type.exists() or identifier.where(system.count() + value.count() >1).exists()
|
| dom-2 | error | Location | If the resource is contained in another resource, it SHALL NOT contain nested Resources |
contained.contained.empty()
|
| dom-3 | error | Location | If the resource is contained in another resource, it SHALL be referred to from elsewhere in the resource or SHALL refer to the containing resource |
contained.where((('#'+id in (%resource.descendants().reference | %resource.descendants().as(canonical) | %resource.descendants().as(uri) | %resource.descendants().as(url))) or descendants().where(reference = '#').exists() or descendants().where(as(canonical) = '#').exists() or descendants().where(as(canonical) = '#').exists()).not()).trace('unmatched', id).empty()
|
| dom-4 | error | Location | If a resource is contained in another resource, it SHALL NOT have a meta.versionId or a meta.lastUpdated |
contained.meta.versionId.empty() and contained.meta.lastUpdated.empty()
|
| dom-5 | error | Location | If a resource is contained in another resource, it SHALL NOT have a security label |
contained.meta.security.empty()
|
| dom-6 | best practice | Location | A resource should have narrative for robust management |
text.`div`.exists()
|
| ele-1 | error | **ALL** elements | All FHIR elements must have a @value or children |
hasValue() or (children().count() > id.count())
|
| ext-1 | error | **ALL** extensions | Must have either extensions or value[x], not both |
extension.exists() != value.exists()
|
| preferred-postal-address | error | Location | If the preferred postal address extension is present on an address then that address must be of type 'postal' |
address.exists() and address.extension.where(url='http://ns.electronichealth.net.au/hc/StructureDefinition/hc-preferred-postal-address').exists() implies address.where(type='postal').exists()
|
This structure is derived from AUCoreLocation
Summary
Mandatory: 6 elements
Must-Support: 7 elements
Structures
This structure refers to these other structures:
Extensions
This structure refers to these extensions:
Slices
This structure defines the following Slices:
Other representations of profile: CSV, Excel, Schematron
This IG defines and introduces several search parameters in addition to those inherited from R4, that make it easier to find and filter HC Location resources in Health Connect implementations.
The following search parameters are defined by this IG and SHALL be supported:
postaladdress (Location.extension where url = HC preferred postal address extension)
- Search locations by the HC-preferred postal address stored in the location's HC-specific extension.
- Example (string-only): GET /Location?postaladdress=PO%20Box%20123
locationamenities (Location.extension where url = HC amenity extension)
GET /Location?locationamenities=Wheelchair%20accessThe following search parameters are inherited from FHIR R4 and have been deemed useful for implementation within this IG. They SHALL be supported:
name (Location.name and Location.alias)
GET /Location?name:contains=Telehealthaddress (Location.address)
GET /Location?address=147-153%20Castlereagh%20Streettype (Location.type.coding)
GET /Location?type=MOBL
Note: Support for _id is mandatory for a responder and optional for a requester. Where the expectation for a search parameter differs between actors, the table below will reflect the stronger conformance requirement.
| Parameter(s) | Conformance | Type(s) | Requirements (when used alone or in combination) |
|---|---|---|---|
| _id | SHALL | token |
|
| name (R4) | SHOULD | string |
|
| address (R4) | SHOULD | string |
|
| postaladdress | SHOULD | string |
|
| locationamenities | SHOULD | token |
|
| type (R4) | SHALL | token |
|
| name+type | SHOULD | string+token |
|
| name+locationamenities | SHOULD | string+token |
|
| address+type | SHOULD | string+token |
|
| address+locationamenities | SHOULD | string+token |
|
| postaladdress+type | SHOULD | string+token |
|
| postaladdress+locationamenities | SHOULD | string+token |
This implementation supports the following _include parameters when searching for Location resources:
_include=Location:endpoint - Include endpoint resources referenced by the endpoint element_include=Location:managingOrganization - Include organization resources referenced by the managingOrganization elementThis implementation supports the following _revinclude parameters when searching for Location resources:
_revinclude=HealthcareService:location - Include HealthcareService resources that reference this Location_revinclude=Provenance:target - Include Provenance resources that track changes to this LocationGET /Location/456?_include=Location:endpoint&_revinclude=HealthcareService:location
This query returns the Location resource, its associated Endpoints, and all HealthcareServices at this Location.