C-CDA / FHIR Converter
This page describes C-CDA built-in module which provides API to convert C-CDA documents to FHIR documents and backward.
Introduction
C-CDA (Consolidated Clinical Document Architecture) is a standard that has been widely adopted in the healthcare industry for exchanging clinical documents. Based on the HL7 Clinical Document Architecture (CDA) standard, it provides a structured approach to capturing and sharing patient information in a consistent manner. However, with the healthcare industry moving towards the more modern FHIR standard, there is now a growing need to convert data between C-CDA and FHIR. Furthermore, the ยง 170.315(g)(9) ONC criterion mandates that EHR systems must import and export patient data in C-CDA format.
To meet these data exchange requirements, Aidbox offers a module that performs C-CDA to FHIR and FHIR to C-CDA conversions. This module applies a set of rules consistently in both directions, ensuring a robust and reliable conversion process. In addition to data conversion, the module also provides endpoints for validating C-CDA documents and for persisting FHIR data extracted from C-CDA documents.
C-CDA / FHIR Converter provides bidirectional mapping for all data elements from the USCDI v1 list.
You can quickly evaluate C-CDA to FHIR Converter on our C-CDA to FHIR Demo page.
List of supported sections
The list of supported sections can be found on the separate page. Section aliases are used to configure C-CDA endpoints to specify sections to process.
Converting a C-CDA document to FHIR
To perform C-CDA to FHIR conversion without storing FHIR resources in the Aidbox database, use the /ccda/v2/to-fhir
endpoint. Simply POST
C-CDA XML document in request body as in the following example:
Please note theContent-Type: application/cda+xml
header. Any other MIME type will be rejected by this endpoint.
If conversion was successful, you'll get a FHIR Document as a result. Accordingly to the FHIR Documents specification, the first resource in the resulting bundle is Composition resource containing document header information as well as the list of document sections.
In case of error, OperationOutcome resource will be returned:
Please note that this endpoint doesn't persist any populated FHIR data to Aidbox database. This endpoint is read-only and it performs a stateless conversion of the document from one format to another. To persist FHIR data extracted from a C-DDA document proceed to the Persisting a result of C-CDA to FHIR conversion section.
Endpoint options
There are several options you may pass to the /ccda/v2/to-fhir
endpoint. Options are passed as query string parameters, i.e. /ccda/v2/to-fhir?option1=value1&option2=value2
.
Option | Values | Description |
---|---|---|
|
| Default: |
|
| Sets output reference format to ResourceType/id |
|
| Output FHIR bundle type. By default FHIR document bundle will be returned |
| Proceed to the Section Aliases table to find all possible values. Default: all | Comma-separated list of section aliases to process. By default all sections are processed. |
Example
Converting a FHIR Document to C-CDA
The /ccda/v2/to-ccda
endpoint is used to convert FHIR document to C-CDA document. It accepts a FHIR Document, which is a specialized FHIR Bundle with Composition resource as its first element. It is the user's responsibility to compose this bundle. The resulting C-CDA document will contain all sections from the provided Composition.
Because of technical limitation you have to make sure that provided FHIR Document doesn't contain circular references between resources.
Circular references occur when two or more resources in the bundle reference each other in a loop, such as resource A references resource B, which in turn references resource C, which then references resource A again.
Validation of FHIR Bundle for Conversion Purposes
Incoming FHIR Bundle can be validated for the conversion purposes via using /ccda/fhir-validate
endpoint. Validator will check if it is possible to create valid C-CCDA document. If something is wrong with dataset - all potential errors will be aggregated and explained:
There's a mechanism to streamline FHIR Document generation to use with this endpoint, please check Producing C-CDA documents page.
To convert a FHIR document to C-CDA, make a POST request to the /ccda/v2/to-ccda
endpoint with the FHIR document in the request body. The endpoint will return the C-CDA document in XML format.
The source FHIR Document for this endpoint can be in either FHIR or Aidbox format. Endpoint uses Content-Type
header to understand which format is used. Content-Type: application/json
means Aidbox format and Content-Type: application/fhir+json
means FHIR format. So in the example above Aidbox format is used.
If FHIR Document format and Content-Type
header are mismached then 422 error will be returned:
Persisting result of C-CDA to FHIR conversion
To store C-CDA to FHIR conversion results in the Aidbox database, you can use the /ccda/v2/persist
endpoint. This endpoint converts the C-CDA document to a FHIR document and creates or updates resources using a FHIR Transaction bundle. As this process is transactional, any failure in the bundle will cause the entire transaction to be rolled back, and nothing will be saved. Here is an example of how to use the /ccda/v2/persist
endpoint:
Persisting is heavily based on C-CDA's <id root="...">
element. If some entity in C-CDA document contains this element (identifier), this identifier will be used (in hashed form) as an ID for resulting FHIR resource. This means that resubmitting the same document several times will not produce duplicate resources in the database for C-CDA entities which contains <id>
elements.
In addition to the FHIR resources that are converted from C-CDA data, the /ccda/v2/persist
endpoint also creates a Provenance resource that contains references to all of the resources that are created or updated during a single call. This list is useful for identifying all FHIR resources that are related to a specific C-CDA document, such as for deleting them from the database.
If the create-docref
option is provided, this endpoint will also create a DocumentReference resource that contains a base64-encoded copy of the original C-CDA XML document in its content
attribute. This feature is useful if you want to store the original document in the Aidbox database for rare use cases. By default, the create-docref
option is set to false, so no DocumentReference resource is created.
Endpoint Options
Options are passed as query-string parameters, i.e. /ccda/v2/persist?create-docref=true&option2=value2
. sections
are passed separated by commas, i.e. /ccda/v2/persist?section=dicom,goals,findings
.
Option | Values | Description |
---|---|---|
|
| false
Default: |
| ID of Tenant resource Default: none | For Smartbox users only. Assigns Tenant to all populated resources. |
| Proceed to the Section Aliases table to find all possible values. Default: all | Comma-separated list of section aliases to process. By default all sections are processed. |
Validating a C-CDA document
Aidbox provides an endpoint to check correctness of C-CDA document. Despite the fact that C-CDA to FHIR conversion can be performed even on invalid C-CDA document (with undefined result), there are some use cases when you want to validate C-CDA document first. For instance, you can use this endpoint to check user-submitted document and reject if it's not valid.
There are two stages of C-CDA validation:
Structural validation (XSD) which checks that XML tree is properly formed
Schematron validation that checks the presence of data elements required by C-CDA specification
By default both stages are performed.
On C-CDA Converter Demo page only XSD validation is performed. Uploaded XML file will be highlighted with green color if the document is valid, red otherwise.
The following example demonstrates how to use validation endpoint:
If validation was successful, you will get the following response:
In case of failed validation endpoint will return a list of errors and warnings:
Endpoint options
Options are passed as query-string parameters, i.e. /ccda/validate?option1=value1&option2=value2
.
Option | Values | Description |
---|---|---|
|
| schematron |
Last updated