Module health.fhir.templates.international401.patient

ballerinax/health.fhir.templates.international401.patient Ballerina library

3.0.0
FHIR Patient API Template

This Ballerina-based template implementation provides a RESTful FHIR API for managing Patient resources, adhering to the FHIR R4 specification. The API is designed to support CRUD operations International FHIR R4 Patient FHIR API.

Module/ElementVersion
FHIR versionr4
Implementation Guidehttp://hl7.org/fhir
Profile URLhttp://hl7.org/fhir/StructureDefinition/Patient

Note: If you are having FHIR profiles from regional or custom implementation guides, you can use the Ballerina Health tool to generate the FHIR API templates for the FHIR profiles. For more information, see the Ballerina Health tool.

Copy
bal new -t healthcare/health.fhir.r4.international401.patient PatientAPI

Run the Ballerina project created by the service template by executing:

Copy
bal run

Once successfully executed, the listener will be started at port 9090. Then, you can invoke the service using the following curl command:

Copy
curl http://localhost:9090/fhir/r4/Patient

Now, the service will be invoked and return an OperationOutcome, until the code template is implemented completely.

Note: This template is designed to be used as a starting point for implementing the FHIR API. The template is not complete and will return an OperationOutcome until the code is implemented.

Copy
GET /fhir/r4/Patient/{id}
  • Response: Returns a Patient resource or an OperationOutcome if not found.
Copy
GET /fhir/r4/Patient/{id}/_history/{vid}
  • Response: Returns a specific historical version of a Patient resource.
Copy
GET /fhir/r4/Patient
  • Response: Returns a Bundle containing matching Patient resources.
Copy
POST /fhir/r4/Patient
  • Request Body: Patient resource.
  • Response: Returns the created Patient resource.
Copy
PUT /fhir/r4/Patient/{id}
  • Request Body: Updated Patient resource.
  • Response: Returns the updated Patient resource.
Copy
PATCH /fhir/r4/Patient/{id}
  • Request Body: JSON Patch object.
  • Response: Returns the updated Patient resource.
Copy
DELETE /fhir/r4/Patient/{id}
  • Response: Returns an OperationOutcome indicating success or failure.
Copy
GET /fhir/r4/Patient/{id}/_history
  • Response: Returns a Bundle of historical versions of the Patient resource.
Copy
GET /fhir/r4/Patient/_history
  • Response: Returns a Bundle of historical versions of all Patient resources.

The template is designed to work as a Facade API to expose your data as in FHIR. The following are the key steps which you can follow to implement the business logic:

  • Handle business logic to work with search parameters.
  • Implement the source system backend connection logic to fetch data.
  • Perform data mapping inside the service to align with the FHIR models.

Modify apiConfig in the fhirr4:Listener initialization if needed to adjust service settings.

The apiConfig object is used to configure the FHIR API. By default, it consists of the search parameters for the FHIR API defined for the Implementation Guide. If there are custom search parameters, they can be defined in the apiConfig object. Following is an example of how to add a custom search parameter:

Copy
searchParameters: [
  ....
  {
      name: "custom-search-parameter", // Custom search parameter name
      active: true // Whether the search parameter is active
      information: { // Optional information about the search parameter
          description: "Custom search parameter description",
          builtin: false,
      }
  }
]

Following are the steps to add a custom operation to the FHIR API template:

  1. The apiConfig object is used to configure the FHIR API. By default, it consists of the operations for the FHIR API defined for the Implementation Guide. If there are custom operations, they can be defined in the apiConfig object. Following is an example of how to add a custom operation:
Copy
operations: [
  ....
  {
      name: "custom-operation", // Custom operation name
      active: true // Whether the operation is active
      information: { // Optional information about the operation
          description: "Custom operation description",
          builtin: false,
      }
  }
]
  1. Add the context related to the custom operation in the service.bal file. Following is an example of how to add a custom operation:
Copy
isolated resource function post fhir/r4/Patient/\$custom\-operation(r4:FHIRContext fhirContext, Patient procedure) returns r4:OperationOutcome|r4:FHIRError {
    return r4:createFHIRError("Not implemented", r4:ERROR, r4:INFORMATIONAL, httpStatusCode = http:STATUS_NOT_IMPLEMENTED);
}

Additionally, If you want to have a custom profile or a combination of profiles served from this same API template, you can add them to this FHIR API template. To add a custom profile, follow the steps below:

  • Add the profile type to the aggregated resource type.
    • Example: public type Patient r4:Patient|<Other_Patient_Profile>;
  • Add the new profile URL in api_config.bal file. You need to add it as a string inside the profiles array.
    • Example:
      Copy
      profiles: ["http://hl7.org/fhir/StructureDefinition/Patient", "new_profile_url"]

This project is subject to the WSO2 Software License.

Import

import ballerinax/health.fhir.templates.international401.patient;Copy

Other versions

3.0.0

2.0.0

Metadata

Released date: 7 months ago

Version: 3.0.0


Compatibility

Platform: any

Ballerina version: 2201.10.2

GraalVM compatible: Yes


Pull count

Total: 18

Current verison: 8


Weekly downloads



Keywords

Healthcare

FHIR

Patient

r4

health.fhir.r4.international401


Contributors