An Implementation Guide (IG) is a set of rules that describe how FHIR resources should be used to solve a particular problem. Using IGs, you can make your FHIR server compliant for country-specific set of rules. IGs can also describe a proper way to represent particular content in FHIR (for example, the breast cancer medical diagnostic process).
IGs are distributed as packages similar to NPM packages
The prerequisites for FHIR IGs are same as in the FHIR installation documentation. In addition, you need the following:
- Java 8 or higher. We recommend using Amazon Corretto
- Maven
-
Download the IG packages. IG packages can be downloaded from different sources. The most common sources are the corresponding official IG website (for example, download from the US Core website or the FHIR Package Registry.
-
Copy the unzipped IG deployment packages to the
implementationGuides
directoryExample:
. └── implementationGuides/ ├── hl7.fhir.us.core └── hl7.fhir.us.carin-bb
-
Compile the IGs using the
compile-igs
command:#fhir-works-on-aws-deployment yarn run compile-igs
Note: This command needs to be invoked in the top level directory of the cloned
fhir-works-on-aws-deployment
repository -
Deploy the Hapi Validator using the following commands:
#fhir-works-on-aws-deployment/javaHapiValidatorLambda cd javaHapiValidatorLambda mvn clean install serverless deploy
Note: By default the Hapi Validator is set up with FHIR R4. If you want to use FHIR STU3, follow the comments on pom.xml to update the dependencies and deploy using the
fhirVersion
parameter:#fhir-works-on-aws-deployment/javaHapiValidatorLambda serverless deploy --fhirVersion '3.0.1'
-
Deploy the FHIR Works on AWS server using the
deploy
command (after navigating back to the top level directory of the cloned repository):#fhir-works-on-aws-deployment cd .. serverless deploy --useHapiValidator true
Note: For more information on how to set up AWS credentials or how to deploy to a specific stage or region, refer to the installation documentation
After you apply an Implementation Guide to FHIR Works on AWS, the following changes are effective:
Additional search parameters described in IGs are parsed and available on the FHIR Works on AWS server.
For example, when US Core IG is applied, the patient details are searched by ethnicity using the ethnicity search parameter GET <API_endpoint>/Patient?ethnicity=<etnicity_code>
.
Search parameters are built using the resources of type SearchParameter available in the IG package.
Input validation is enhanced to apply validation rules specific to the profiles defined on the IGs. Validation is performed using the HAPI FHIR Validator.
For example, applying the US Core IG adds the us-core-patient profile which adds validation rules for patients, such as rejecting patients with a missing gender field, or patients with ethnicity information that do not conform to the definition of the us-core-ethnicity
extension.
The following code snippet displays a valid US core patient:
{
"resourceType": "Patient",
"id": "example",
"meta": {
"profile": [
"http://hl7.org/fhir/us/core/StructureDefinition/us-core-patient"
]
},
"extension": [
{
"extension": [
{
"url": "ombCategory",
"valueCoding": {
"system": "urn:oid:2.16.840.1.113883.6.238",
"code": "2135-2",
"display": "Hispanic or Latino"
}
},
{
"url": "text",
"valueString": "Hispanic or Latino"
}
],
"url": "http://hl7.org/fhir/us/core/StructureDefinition/us-core-ethnicity"
}
],
"identifier": [
{
"use": "usual",
"type": {
"coding": [
{
"system": "http://terminology.hl7.org/CodeSystem/v2-0203",
"code": "MR",
"display": "Medical Record Number"
}
],
"text": "Medical Record Number"
},
"system": "http://hospital.smarthealthit.org",
"value": "1032702"
}
],
"name": [
{
"family": "Shaw",
"given": [
"Amy",
"V."
]
}
],
"gender": "female"
}
Input validation utilizes the resources of type StructureDefinition
, ValueSet
, and CodeSystem
available in the IG package.
Implementation Guides may contain OperationDefinition
resources. These resources describe new operations. It is not possible to automatically generate the implementation of an operation, they must be manually implemented.
Applying an Implementation Guide will enable the operations defined in it if there is a matching implementation available in FHIR Works on AWS.
At this moment The only operation available is $docref from US Core. Our $docref implementation has the limitation that it can only search for existing documents, it cannot generate documents on the fly.
The $docref source code can be found here and it is a good example of how to add new operations to FHIR Works on AWS.
The server capability statement returned by GET <API_endpoint>/metadata
is updated to reflect the above features. Specifically, the supportedProfile
field is populated and additional search parameters have a corresponding searchParam
entry.
For example, after applying the US Core IG, the fragment of the capability statement related to the patient resource is updated to include the following:
{
"type": "Patient",
"supportedProfile": [
"http://hl7.org/fhir/us/core/StructureDefinition/us-core-patient"
],
"searchParam": [
{
"name": "ethnicity",
"definition": "http://hl7.org/fhir/us/core/SearchParameter/us-core-ethnicity",
"type": "token",
"documentation": "Returns patients with an ethnicity extension matching the specified code."
},
...
],
...
}