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.
Last updated
Was this helpful?
This page describes C-CDA built-in module which provides API to convert C-CDA documents to FHIR documents and backward.
Last updated
Was this helpful?
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.
The list of supported sections can be found . Section aliases are used to configure C-CDA endpoints to specify sections to process.
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.
In case of error, OperationOutcome resource will be returned:
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
.
format
aidbox
fhir
Default: aidbox
reference-format
resource-id
Sets output reference format to ResourceType/id
transaction
true
Output FHIR bundle type. By default FHIR document bundle will be returned
sections
Comma-separated list of section aliases to process. By default all sections are processed.
patient-id
id
that will be inserted and propagated as uri
, id
or fullURl
in resulting FHIR Bundle.
Arbitrary string that corresponds to id.
post-process
Different useful utils that are applied after conversion
single-entry-organizer
- will remove organizers with single Observation entry
Example
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.
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:
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.
If FHIR Document format and Content-Type
header are mismached then 422 error will be returned:
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:
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
.
create-docref
true
false
Default: false
tenant-id
ID of Tenant resource Default: none
sections
Comma-separated list of section aliases to process. By default all sections are processed.
patient-id
id
that will be inserted and propagated as uri
, id
or fullURl
in persisted FHIR Bundle.
Arbitrary string that corresponds to id.
post-process
Different useful utils that are applied after conversion
single-entry-organizer
- will remove organizers with single Observation entry
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.
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:
Options are passed as query-string parameters, i.e. /ccda/validate?option1=value1&option2=value2
.
method
xsd
schematron
If conversion was successful, you'll get a as a result. Accordingly to the FHIR Documents specification, the first resource in the resulting bundle is containing document header information as well as the list of document sections.
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 section.
Proceed to the table to find all possible values. Default: all
The /ccda/v2/to-ccda
endpoint is used to convert FHIR document to C-CDA document. It accepts a , which is a specialized FHIR Bundle with 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.
There's a mechanism to streamline FHIR Document generation to use with this endpoint, please check page.
The source FHIR Document for this endpoint can be in either . 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.
In addition to the FHIR resources that are converted from C-CDA data, the /ccda/v2/persist
endpoint also creates a 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 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.
For users only. Assigns Tenant to all populated resources.
Proceed to the table to find all possible values. Default: all
On only XSD validation is performed. Uploaded XML file will be highlighted with green color if the document is valid, red otherwise.