FHIR: OpenMRS Strategy, Tools, FHIR API, and Help

Yes, OpenMRS supports FHIR! This page will explain in more detail the why, how, and what of OpenMRS' use of the FHIR standard, as well as some real-world production examples.


OpenMRS' FHIR Strategy

Why FHIR? 

  • Integrations between systems in healthcare are critical for exchanging important health information - e.g. between the EMR and a Lab System, or Inventory System, or a National Identify System.

  • HL7 FHIR is a standard for how information can be shared between systems. Over the last decade FHIR has been embraced by health system leaders and corporations world-wide as the standard-of-choice for health-related data sharing. 

  • In recent years, OpenMRS community members are increasingly embracing FHIR as an efficient way of achieving cross-system interoperability. 

How can OpenMRS Members use FHIR today? 

  • OpenMRS FHIR API: The community-created, community-maintained OpenMRS FHIR Module acts as a translation layer between the FHIR standard and OpenMRS' custom data model: it maps OpenMRS data model items to FHIR Resources, and provides a FHIR REST API developers can use to query data for purposes of client-side rendering (e.g. a frontend widget) or data exchange with another system. The FHIR Module allows both export and import of data in the form of FHIR Resources - a "two-way street". More guidance below on this page. 

  • OpenMRS FHIR IG: To see which FHIR resources are mapped to OpenMRS and what to query, see the OpenMRS FHIR IG documentation here. The OpenMRS FHIR Module does not (yet!) cover all possible FHIR resources nor all the data in OpenMRS, but we have aimed to cover the highest priority items. We have been building out the module with community implementers based on their pressing needs (e.g. see the Lab System, MPI, and SHR use cases below). 

“Using FHIR IGs has sped-up our average integration time of OpenMRS with OpenELIS from 6-8 months to 2-3 days.” - UW ITECH DIGI Interoperabilty Team

Note: We are forever grateful to Brown University and ITECH for their dedication in co-founding the OpenMRS FHIR Module. 

New in 2024: Publication, “FHIR-ing up OpenMRS”

See the new publication: FHIRing up OpenMRS: Architecture, Implementation and Real-World Use-Cases in Global Health


FHIR Basics

Before we cover how to use FHIR with OpenMRS, here’s a quick review of the basics of FHIR:

  • How is FHIR structured in general? 

    • The aim of FHIR is to provide the 80% base functionality that most people need to represent data in a healthcare context and exchange it across different systems

    • FHIR provides a syntax-neutral logical data model for representing objects involved in various kinds of health care transactions. For example, what information needs to be communicated about a Patient? A Provider? These logical data models are called resources (e.g. a patient resource, a provider resource).

    • These logical data models can be mapped to specific syntaxes, e.g., XML or JSON.

  • How can I navigate the world-wide HL7 FHIR online docs? 

General FHIR Resources to Bookmark

Bookmarks OpenMRS Devs have found helpful:

 


Guide & FAQs: Using FHIR with OpenMRS

How to Use the OpenMRS FHIR API

  • How do I know what FHIR resources are supported by the OpenMRS FHIR API?

  • How do I register a patient using the FHIR API?

  • Why use the OpenMRS FHIR API instead of the REST API? 

    • Reduce Cognitive Load of Integration: Eventually devs will no longer be building a custom knowledge base, but one that can be used to integrate with any system → reduce cognitive load of integration

    • Better Search Capabilities: Lots of things the FHIR API can do search-wise that can’t be retroactively implemented in REST API

    • Addresses REST Weaknesses: There are a number of deficiencies in the REST API that are not easy to fix. (e.g. impossible to list all pts) Caveats: There are some things supported more cleanly by the REST API, e.g. global properties. 

What to do if an endpoint or resource is not yet supported by the OpenMRS FHIR Module

  1. First: Check through and see how resources and profiles are being developed following a given example here https://github.com/openmrs/openmrs-contrib-fhir2-ig/commit/4184cc797d50c9acccdf967fba3770974ae14c6f.

  2. Then: File your need in the OpenMRS FHIR Module Issue tracker. Example: FM2-131: Add support for the FHIR Appointment resourceDesign  Please mention if you are interested in helping to add this resouce. (Need access to our Jira? Request here.)

  3. To Discuss: Contact the OpenMRS #fhir expert community in our FHIR Slack Channel (sign up for OpenMRS Slack at slack.openmrs.org

What to do if a resource is not clear or supported by HL7 FHIR in general?

  • Don't worry - the HL7 FHIR community is very friendly, and in fact, they are very keen to hear from folks in Lower- & Middle-Income Countries. Don't hesitate to ask your questions and share your use-cases at: https://chat.fhir.org


OpenMRS Community FHIR Contacts

  • The OpenMRS FHIR Squad works on OpenMRS solutions, including the FHIR Module, that support the ability to exchange healthcare data in a widely-used, standards-based format, easing integration with external systems and products. 

    • Key Contacts: @Ian Bacher Technical Lead (UW ITECH DIGI), @Jan Flowers Industry SME (ITECH), @Piotr Mankowski Key FHIR Module Co-Founder (ITECH), @Moses Mutesasira (ITECH)

  • Communication: Slack channel, #fhir and #fhir-development (sign up here); community Forum FHIR posts

  • Code: FHIR Board Tickets, Code on Github


Examples: Showing FHIR being used in real OpenMRS Implementations

For an exhaustive, more detailed list, please see Real-world OpenMRS FHIR Projects and Tutorials. These examples and videos should help inspire you: 

Lab Results Exchange

OpenMRS and OpenELIS Interoperability using the OpenMRS FHIR Module

MPI (National Patient Identity Index) Exchange

OpenMRS system and MPI interoperability using the OpenMRS FHIR Module

SHR (Shared Health Record)

OpenMRS system and SHR interoperability using the OpenMRS FHIR Module (specifically for CCD, Continuity of Care Document)


Tutorial Videos & More

Tutorial Video: Intro to the FHIR API in General

High-Level Explainer Slides for Non-Technical Folks

 


Other Applications of FHIR in OpenMRS

  • Using FHIR for Data Storage

    • Some community members are interested in whether a FHIR Database (e.g. HAPI FHIR / SmileCDR) could eventually be used to completely replace the custom OpenMRS backend altogether. It would be ideal to have less technical infrastructure like our custom backend model to for our implementers and community to have to maintain. However,  this would obliterate the current OpenMRS Reporting functionality, which would have an enormous impact on the many implementers who depend on OMRS for reporting purposes. There remains world-wide debate about whether FHIR should only be used for data transfer rather than data storage. We are keenly watching the experience of other global goods like Ona who recently completed this switch to a FHIR database. We are on the look out for community interest in and maintenance of the current FHIR Module to help us gauge the actual market demand for FHIR amidst OpenMRS implementers. Given limited resources we need to be clear with our focus on whether we are focused on FHIR for Integration or for Storage - so for now we are focused on Integration use cases and benefit.

  • Using FHIR for Data Analytics at scale

    • Google Health recently collaborated with the OpenMRS Analytics Squad on exactly this use case. The resulting tooling for performant fhir-based data analysis is the "fhir data pipes" project, a collection of tools for extracting FHIR resources and analytics services on top of that data. 


Additional pages on OpenMRS and FHIR

 

 

Related pages