FHIR Utilities
The fhir
module provides a set of helper functions to make it easier for you to work with FHIR resources.
Resource Creation
FHIR is the modern de facto standard for storing and exchanging healthcare data, but working with FHIR resources can often involve complex and nested JSON structures with required and optional fields that vary between contexts.
Creating FHIR resources can involve a lot of boilerplate code, validation errors and manual comparison of FHIR specifications with the resource you're trying to create.
For example, as an ML practitioner, you may only care about extracting and inserting certain codes and texts within a FHIR resource. If you want locate the SNOMED CT code for a medication, you may have to do something headache-inducing like this:
medication_statement = {
"resourceType": "MedicationStatement",
"status": "active", # required
"medication": { # required
"concept": {
"coding": [
{
"system": "http://www.nlm.nih.gov/research/umls/rxnorm",
"code": "1049221",
"display": "Acetaminophen 325 MG Oral Tablet",
}
]
}
},
"subject": { # required
"reference": "Patient/example"
},
}
medication_statement["medication"]["concept"]["coding"][0]["code"]
medication_statement["medication"]["concept"]["coding"][0]["display"]
The fhir
create_*
functions create FHIR resources with sensible defaults, automatically creating a reference ID prefixed by "hc-
", a status of "active
" (or equivalent) and adding a creation date where necessary.
Internally, HealthChain uses fhir.resources to validate FHIR resources, which is in turn powered by Pydantic V2. You can modify and manipulate the FHIR resources as you would any other Pydantic object after its creation.
Please exercise caution when using these functions, as they are only meant to create minimal valid FHIR resources to make it easier to get started. Always check the sensible defaults serve your needs, and validate the resource to ensure it is correct!
Overview
Resource Type | Required Fields | Sensible Defaults | Common Use Cases |
---|---|---|---|
Condition | • clinicalStatus • subject |
• clinicalStatus : "active"• id : auto-generated with "hc-" prefix |
• Recording diagnoses • Problem list items • Active conditions |
MedicationStatement | • subject • status • medication |
• status : "recorded"• id : auto-generated with "hc-" prefix |
• Current medications • Medication history • Prescribed medications |
AllergyIntolerance | • patient |
• id : auto-generated with "hc-" prefix |
• Allergies • Intolerances • Adverse reactions |
DocumentReference | • type |
• status : "current"• date : current UTC time• description : default text• content.attachment.title : default text |
• Clinical notes • Lab reports • Imaging reports |
create_condition()
Creates a new Condition resource.
Required fields:
Sensible defaults:
clinicalStatus
is set to "active
"
from healthchain.fhir import create_condition
# Create a condition representing hypertension
condition = create_condition(
subject="Patient/123",
code="38341003",
display="Hypertension",
system="http://snomed.info/sct",
)
# Output the created resource
print(condition.model_dump())
View output JSON
{
"resourceType": "Condition",
"id": "hc-3117bdce-bfab-4d71-968b-1ded900882ca",
// Clinical status indicating this is an active condition
"clinicalStatus": {
"coding": [{
"system": "http://terminology.hl7.org/CodeSystem/condition-clinical",
"code": "active",
"display": "Active"
}]
},
// SNOMED CT code for Hypertension
"code": {
"coding": [{
"system": "http://snomed.info/sct",
"code": "38341003",
"display": "Hypertension"
}]
},
// Reference to the patient this condition belongs to
"subject": {
"reference": "Patient/123"
}
}
create_medication_statement()
Creates a new MedicationStatement resource.
Required fields:
Sensible defaults:
status
is set to "recorded
"
from healthchain.fhir import create_medication_statement
# Create a medication statement for Acetaminophen
medication = create_medication_statement(
subject="Patient/123",
code="1049221",
display="Acetaminophen 325 MG Oral Tablet",
system="http://www.nlm.nih.gov/research/umls/rxnorm",
)
# Output the created resource
print(medication.model_dump())
View output JSON
{
"resourceType": "MedicationStatement",
"id": "hc-86a26eba-63f9-4017-b7b2-5b36f9bad5f1",
// Required fields are highlighted
"status": "recorded", // [Required] Status of the medication statement
// Required medication details using RxNorm coding
"medication": { // [Required] Details about the medication
"concept": {
"coding": [{
"system": "http://www.nlm.nih.gov/research/umls/rxnorm",
"code": "1049221",
"display": "Acetaminophen 325 MG Oral Tablet"
}]
}
},
// Required reference to the patient
"subject": { // [Required] Reference to the patient this medication belongs to
"reference": "Patient/123"
}
}
create_allergy_intolerance()
Creates a new AllergyIntolerance resource.
Required fields:
Sensible defaults:
- None
from healthchain.fhir import create_allergy_intolerance
# Create an allergy intolerance record
allergy = create_allergy_intolerance(
patient="Patient/123",
code="418038007",
display="Propensity to adverse reactions to substance",
system="http://snomed.info/sct"
)
# Output the created resource
print(allergy.model_dump())
View output JSON
{
"resourceType": "AllergyIntolerance",
"id": "hc-65edab39-d90b-477b-bdb5-a173b21efd44",
// SNOMED CT code for the allergy
"code": {
"coding": [{
"system": "http://snomed.info/sct",
"code": "418038007",
"display": "Propensity to adverse reactions to substance"
}]
},
// Required reference to the patient
"patient": { // [Required] Reference to the patient this allergy belongs to
"reference": "Patient/123"
}
}
create_document_reference()
Creates a new DocumentReference resource. Handles base64 encoding of the attachment data.
Required fields:
Sensible defaults:
type
is set to "collection
"status
is set to "current
"date
is set to the current UTC timestampdescription
is set to "DocumentReference created by HealthChain
"content[0].attachment.title
is set to "Attachment created by HealthChain
"
from healthchain.fhir import create_document_reference
# Create a document reference with a simple text attachment
doc_ref = create_document_reference(
data="Hello World",
content_type="text/plain",
description="A simple text document"
)
# Output the created resource
print(doc_ref.model_dump())
View output JSON
{
"resourceType": "DocumentReference",
"id": "hc-60fcfdad-9617-4557-88d8-8c8db9b9fe70",
// Document metadata
"status": "current",
"date": "2025-02-28T14:55:33+00:00", // UTC timestamp
"description": "A simple text document",
// Document content with base64 encoded data
"content": [{
"attachment": {
"contentType": "text/plain",
"data": "SGVsbG8gV29ybGQ=", // "Hello World" in base64
"title": "Attachment created by HealthChain",
"creation": "2025-02-28T14:55:33+00:00" // UTC timestamp
}
}]
}
Utilities
set_problem_list_item_category()
Sets the category of a Condition resource to "problem-list-item
".
from healthchain.fhir import set_problem_list_item_category, create_condition
# Create a condition and set it as a problem list item
problem_list_item = create_condition(
subject="Patient/123",
code="38341003",
display="Hypertension"
)
set_problem_list_item_category(problem_list_item)
# Output the modified resource
print(problem_list_item.model_dump())
View output JSON
{
"resourceType": "Condition",
"id": "hc-3d5f62e7-729b-4da1-936c-e8e16e5a9358",
// Required fields are highlighted
"clinicalStatus": { // [Required] Clinical status of the condition
"coding": [{
"system": "http://terminology.hl7.org/CodeSystem/condition-clinical",
"code": "active",
"display": "Active"
}]
},
// Category added by set_problem_list_item_category
"category": [{
"coding": [{
"system": "http://terminology.hl7.org/CodeSystem/condition-category",
"code": "problem-list-item",
"display": "Problem List Item"
}]
}],
// SNOMED CT code for the condition
"code": {
"coding": [{
"system": "http://snomed.info/sct",
"code": "38341003",
"display": "Hypertension"
}]
},
// Required reference to the patient
"subject": { // [Required] Reference to the patient this condition belongs to
"reference": "Patient/123"
}
}
read_content_attachment()
Reads attachments from a DocumentReference in a human-readable format.
from healthchain.fhir import read_content_attachment
attachments = read_content_attachment(document_reference)
# Returns a list of dictionaries containing:
# [
# {
# "data": "Hello World",
# "metadata": {
# "content_type": "text/plain",
# "title": "My Document",
# "creation": datetime.datetime(2025, 2, 28, 15, 27, 55, tzinfo=TzInfo(UTC)),
# },
# }
# ]
Bundle Operations
FHIR Bundles are containers that can hold multiple FHIR resources together. They are commonly used to group related resources or to send/receive multiple resources in a single request.
The bundle operations make it easy to:
- Create and manage bundles
- Add or update resources within bundles
- Retrieve specific resource types from bundles
- Work with multiple resource types in a single bundle
create_bundle()
Creates a new Bundle resource.
Required fields:
Sensible defaults:
type
is set to "collection
"
from healthchain.fhir import create_bundle
# Create an empty bundle
bundle = create_bundle(bundle_type="collection")
# Output the created resource
print(bundle.model_dump())
View output JSON
add_resource()
Adds a single resource to a Bundle.
from healthchain.fhir import add_resource, create_condition, create_bundle
# Create a condition to add to the bundle
condition = create_condition(
subject="Patient/123",
code="38341003",
display="Hypertension"
)
# Create a bundle and add the condition
bundle = create_bundle()
add_resource(bundle, condition)
# Output the modified bundle
print(bundle.model_dump())
View output JSON
{
"resourceType": "Bundle",
"type": "collection",
// List of resources in the bundle
"entry": [{
"resource": {
"resourceType": "Condition",
"id": "hc-3117bdce-bfab-4d71-968b-1ded900882ca",
// Required fields from the condition
"clinicalStatus": { // [Required]
"coding": [{
"system": "http://terminology.hl7.org/CodeSystem/condition-clinical",
"code": "active",
"display": "Active"
}]
},
"code": {
"coding": [{
"system": "http://snomed.info/sct",
"code": "38341003",
"display": "Hypertension"
}]
},
"subject": { // [Required]
"reference": "Patient/123"
}
}
}]
}
View field descriptions
| Field | Required | Description | |-------|:--------:|-------------| | `entry` | - | Array of resources in the bundle | | `entry[].resource` | ✓ | The FHIR resource being added | | `entry[].fullUrl` | - | Optional full URL for the resource |get_resources()
Retrieves all resources of a specific type from a Bundle.
from healthchain.fhir import get_resources
# Get all conditions in the bundle
conditions = get_resources(bundle, "Condition")
# Or using the resource type directly
from fhir.resources.condition import Condition
conditions = get_resources(bundle, Condition)
# Each resource in the returned list will be a full FHIR resource
for condition in conditions:
print(f"Found condition: {condition.code.coding[0].display}")
set_resources()
Sets or updates resources of a specific type in a Bundle.
from healthchain.fhir import set_resources, create_condition
# Create some conditions
conditions = [
create_condition(
subject="Patient/123",
code="38341003",
display="Hypertension"
),
create_condition(
subject="Patient/123",
code="44054006",
display="Diabetes"
)
]
# Replace all existing conditions with new ones
set_resources(bundle, conditions, "Condition", replace=True)
# Or append new conditions to existing ones
set_resources(bundle, conditions, "Condition", replace=False)
View example bundle with multiple conditions
{
"resourceType": "Bundle",
"type": "collection",
"entry": [
{
"resource": {
"resourceType": "Condition",
"id": "hc-3117bdce-bfab-4d71-968b-1ded900882ca",
"clinicalStatus": {
"coding": [{
"system": "http://terminology.hl7.org/CodeSystem/condition-clinical",
"code": "active",
"display": "Active"
}]
},
"code": {
"coding": [{
"system": "http://snomed.info/sct",
"code": "38341003",
"display": "Hypertension"
}]
},
"subject": {"reference": "Patient/123"}
}
},
{
"resource": {
"resourceType": "Condition",
"id": "hc-9876fedc-ba98-7654-3210-fedcba987654",
"clinicalStatus": {
"coding": [{
"system": "http://terminology.hl7.org/CodeSystem/condition-clinical",
"code": "active",
"display": "Active"
}]
},
"code": {
"coding": [{
"system": "http://snomed.info/sct",
"code": "44054006",
"display": "Diabetes"
}]
},
"subject": {"reference": "Patient/123"}
}
}
]
}
Common Patterns
Working with Multiple Resource Types
This example shows how to work with multiple types of FHIR resources in a single bundle.
from healthchain.fhir import (
create_bundle,
create_condition,
create_medication_statement,
create_allergy_intolerance,
get_resources,
set_resources,
)
# Create a bundle to hold patient data
bundle = create_bundle()
# Add conditions (diagnoses)
conditions = [
create_condition(
subject="Patient/123",
code="38341003",
display="Hypertension"
),
create_condition(
subject="Patient/123",
code="44054006",
display="Diabetes"
)
]
set_resources(bundle, conditions, "Condition")
# Add medications
medications = [
create_medication_statement(
subject="Patient/123",
code="1049221",
display="Acetaminophen 325 MG"
)
]
set_resources(bundle, medications, "MedicationStatement")
# Add allergies
allergies = [
create_allergy_intolerance(
patient="Patient/123",
code="418038007",
display="Penicillin allergy"
)
]
set_resources(bundle, allergies, "AllergyIntolerance")
# Later, retrieve resources by type
conditions = get_resources(bundle, "Condition")
medications = get_resources(bundle, "MedicationStatement")
allergies = get_resources(bundle, "AllergyIntolerance")
View complete bundle JSON
{
"resourceType": "Bundle",
"type": "collection",
"entry": [
{
"resource": {
"resourceType": "Condition",
"id": "hc-3117bdce-bfab-4d71-968b-1ded900882ca",
"clinicalStatus": {
"coding": [{
"system": "http://terminology.hl7.org/CodeSystem/condition-clinical",
"code": "active",
"display": "Active"
}]
},
"code": {
"coding": [{
"system": "http://snomed.info/sct",
"code": "38341003",
"display": "Hypertension"
}]
},
"subject": {"reference": "Patient/123"}
}
},
{
"resource": {
"resourceType": "Condition",
"id": "hc-9876fedc-ba98-7654-3210-fedcba987654",
"clinicalStatus": {
"coding": [{
"system": "http://terminology.hl7.org/CodeSystem/condition-clinical",
"code": "active",
"display": "Active"
}]
},
"code": {
"coding": [{
"system": "http://snomed.info/sct",
"code": "44054006",
"display": "Diabetes"
}]
},
"subject": {"reference": "Patient/123"}
}
},
{
"resource": {
"resourceType": "MedicationStatement",
"id": "hc-86a26eba-63f9-4017-b7b2-5b36f9bad5f1",
"status": "recorded",
"medication": {
"concept": {
"coding": [{
"system": "http://www.nlm.nih.gov/research/umls/rxnorm",
"code": "1049221",
"display": "Acetaminophen 325 MG"
}]
}
},
"subject": {"reference": "Patient/123"}
}
},
{
"resource": {
"resourceType": "AllergyIntolerance",
"id": "hc-65edab39-d90b-477b-bdb5-a173b21efd44",
"code": {
"coding": [{
"system": "http://snomed.info/sct",
"code": "418038007",
"display": "Penicillin allergy"
}]
},
"patient": {"reference": "Patient/123"}
}
}
]
}