Konstantin Kalinin
Konstantin Kalinin
Head of Content
March 11, 2024

A clinic decides to build an AI app to detect a rare disease at its early stages by analyzing patient data. They develop the app and connect it to their healthcare systems (including an EHR) to feed patient data into the AI engine. They also loop the AI-processed data back into an EHR.

They’ll soon add an iPhone app that combines the AI output with on-device ML-powered photo recognition to improve disease detection accuracy. How do they manage all of that? They use SMART on FHIR.

SMART on FHIR logo

So if you think it’s time to get creative with your patient data and start using it to advance to value-based healthcare, you need to know the basics about SMART on FHIR and how it’s used to build advanced healthcare solutions. Welcome to our guide! Let’s learn how to build a SMART on FHIR app.

 

Table of Contents:
1. What is FHIR, and Why Does It Matter in Healthcare?
2. What is SMART?
3. What is SMART on FHIR?
4. The Role of SMART on FHIR in Health App Development
5. Benefits of SMART on FHIR
6. How Does SMART on FHIR Work?
7. Challenges with Building Health Apps Using SMART on FHIR
8. Steps to Build a SMART on FHIR App

9. Features of Apps Developed with SMART on FHIR
10. Top 3 SMART on FHIR Apps Examples
11. Our Experience Creating SMART on FHIR Apps
12. Case Study: SMART on FHIR App that launches within Epic Hyperspace

What is FHIR, and Why Does It Matter in Healthcare?

Today, siloed healthcare applications don’t cut it anymore unless they integrate with other clinical software, e.g., electronic health record systems or clinical decision support solutions.

Health data needs to flow freely and securely between different digital products to enable better outcomes for patients. That’s where FHIR comes in.

FHIR is a data standard for healthcare data exchange. It defines the type of health data and its format for apps that want to share this data.

For example, when an application needs to fetch patient vitals from an EHR, it needs to know:

  • what kind of data is available
  • what command it should send to “ask” the EHR for this data
  • what responses the app can receive to process them correctly

All of that is handled by the FHIR API, developed under the guidance of HL7, a non-profit organization working on standards for healthcare data interoperability.

Read more on HL7 Integration in our blog.

Oh, and by the way, FHIR stands for Fast Healthcare Interoperability Resources, if that tells you anything extra, and you pronounce it as “fire.”

HL7 FHIR logo

What is SMART?

SMART was a similar initiative by healthcare data interoperability advocates who at some point decided to join their efforts with FHIR/HL7.

SMART stands for Substitutable Medical Applications, Reusable Technologies — a specifications framework that lays down the standards for health data interoperability.

The idea sprung in 2010 on the heels of smartphone innovations and presumed there should be a common API for exchanging health data. As a result, healthcare providers could easily swap out different applications by independent vendors to see what’s working best for them. 

Before SMART on FHIR, their only option was to turn to their EHR vendors to build necessary applications that could access EHR data because of closed APIs.

What is SMART on FHIR?

The magic really happens when both standards meet together. Smart relies on FHIR data standardization while also providing an additional security layer for authorization and a set of “profiles” that help developers effectively work with clinical data.

Close up of Doctor is showing medical analytics data, Medical technology concept

In plain English, SMART on FHIR makes it easier for developers to build health apps that integrate with EHR systems and other clinical software:

  • developers deal with concrete data objects (like allergy or prescription) as opposed to using abstract data layers (read simpler and faster coding)
  • data is always shared in a digestible, predictable format, and there are fewer bugs related to data processing
  • widely applicable data-type templates win over interface-specific definitions

If someone asks you, “So what’s this SMART on FHIR thing, again?” tell them it’s a health technology standard we need in our products to enable secure and reliable medical data sharing.

Many healthcare vendors already support SMART on FHIR (through the Argonaut Project initiative):

HL7 FHIR Argonaut project

The Role of SMART on FHIR in Health App Development

When do you need SMART on FHIR? This technology standard comes into play when you develop a health app that uses protected health information (PHI), pulling or sharing it with other external systems. In 99% of cases, that’s a health app integrated with an EHR/EMR system, or a patient app / portal, or a clinical data warehouse.

Building your app using SMART on FHIR, you’re making your health app future-proof as it will be much easier to integrate it with other applications. Let’s briefly review other advantages of SMART on FHIR integration.

Benefits of SMART on FHIR

We already kind of get the main upside of the technology (improved interoperability), but what are some other SMART on FHIR benefits?

Ease of integration for developers

There are hundreds of licensed EHR systems in the U.S., and all of them used to have their own standards (most still do) of exporting and importing PHI data.

EHR concept with FHIR API support and smart API

With SMART on FHIR, developers no longer need to worry about learning particularities of integrating their health apps with various EHR/EMR systems. Correspondingly, the cost of developing EHR-compliant health apps comes down.

Related: How to Develop EHR/EMR System

Interchangeable apps for providers and patients

If adding interoperability becomes easier and more apps become available as a result, providers and patients find themselves in a situation when they can start trying different apps. Health apps built on the SMART on FHIR principles are easier to switch. So healthcare providers can quickly find an app with the optimal user experience.

Security

How do you ensure that each clinician gets access precisely to what they need, without giving them overly broad access to all patient data in the system? SMART on FHIR gracefully takes care of this issue by adding the authorization and authentication layers to a health app.

SMART on FHIR banner 1

In addition, the technology provides support for single sign-on so that users can log in once and then switch between different health apps that share PHI data without signing in individually into every single app.

UX integration

Finally, some clinicians are reluctant to use a separate standalone app that pulls patient data from their EHR. Ideally, they’d like to access this other health app’s UI right inside their EHR or another clinical system. SMART on FHIR works perfectly for this purpose.

How Does SMART on FHIR Work?

SMART on FHIR developers would need to implement a few industry standards according to the specifications, using the REST-based APIs:

  • OAuth
  • OpenID

Using one of these authentication mechanisms is essential when you implement SMART on FHIR healthcare apps.

The technology presents two variants of working with health apps that need to integrate with EHR systems:

  • standalone apps that launch independently from the EHR
  • apps that run right inside the EHR’s interface

Of course, to launch a health app from inside an EHR system, it needs to support SMART on FHIR.

SMART on FHIR API enables the development of various applications:

  • iOS, iPadOS, and WatchOS apps
  • Android apps
  • Epic, Cerner, Allscripts, and other EHR vendors
  • Google and Microsoft provide SMART on FHIR-ready cloud services

medical healthcare system protection shield background design

Challenges with Building Health Apps Using SMART on FHIR

Despite all the SMART on FHIR benefits, developing SMART on FHIR apps poses certain challenges to healthcare app developers.

Not all vendors support the technology

Only a handful of EHR vendors officially support SMART on FHIR. These include Epic, Cerner, Allscripts, Intersystems, and Meditech, although it’s a major request from all major players. Documentation is also somewhat scarce at the moment, and there are not many app developer forums to find answers.

Implementation discrepancies

The reality is you can’t write an app once and then integrate it with thousands of EHRs out-of-the-box. Again, not all vendors provide support for this technology, and those few that do, still have specifics about how you should integrate a health app with them.

Steps to Build a SMART on FHIR App

The development process to build a SMART on FHIR app involves a step-by-step approach, ensuring interoperability, security, and functionality tailored to healthcare needs.

StepDescription
1. Choose the Type of the AppDecide on app type (provider-facing, patient-facing), platform (mobile, web), and integration level (embedded or standalone). Use SMART on FHIR libraries and cloud solutions like Azure or Google Cloud for efficiency.
2. Implement SecurityIncorporate OAuth 2.0 and OpenID for secure authentication. Ensure HIPAA compliance with encrypted connections and robust data protection measures.
3. Build the FeaturesDevelop the app’s core features with regular meetings to update progress and align with customer requirements.
4. Test Using SMART SandboxesUse SMART sandboxes, synthetic datasets, and vendor-specific testing environments like Epic’s sandbox to ensure functionality and data accuracy.
5. Deploy and Add to an App GalleryDeploy the app to a production server or mobile store. Optionally, list it in app galleries to allow healthcare organizations to discover and test the app.

Step 1: Choose the type of the app

The first step when you create a SMART on FHIR app is to define what type of app you’re building:

  • provider- or patient-facing apps
  • mobile app or web application
  • if web app, will it work inside an existing clinical application or as a standalone app

SMART on FHIR offers free tools to speed up SMART on FHIR app development. We can use their libraries for JavaScript, Swift, Python, Ruby, and other popular programming languages.

SMART on FHIR developer libraries

That means we don’t necessarily need to code all interoperability functionality from scratch and instead take a shortcut while focusing on core application features instead.

On the server side, we can pick from Azure and Google cloud services that are SMART on FHIR-ready, but other cloud providers like AWS will work too, maybe requiring slightly more effort. [AWS is actively working on enabling a SMART on FHIR turn-key cloud solution].

Related: HIPAA Compliant Video Conferencing and Messaging

Step 2: Implement security

SMART on FHIR handles security by using OAuth 2.0 and OpenID specifications. This approach ensures that providers can switch between integrated apps without entering their credentials each time. They also don’t need to enter their password into third-party solutions because authorization happens via their EHR systems. System owners can define in the EHR system permissions and access levels for different users.

oAuth OpenID in SMART in FHIR apps are part of HIPAA

Of course, regular HIPAA compliant app development procedures that include data encryption, use of secure connections, etc., apply here as well.

Step 3: Build the features

The next obvious step is to develop all the required features. When we build a SMART on FHIR app, we pay special attention to daily and weekly meetings to keep our customers on track about current progress.

Related: Should I buy or build a telehealth solution?

Step 4: Test using SMART sandboxes

As you can imagine, testing healthcare applications is quite challenging because of the nature of data that they use. For SMART on FHIR implementation, it’s recommended to use a SMART sandbox for testing your app’s features.

EHR vendors like Epic also provide their separate sandboxes for testing your product with their EHR systems.

Besides sandboxes that effectively emulate a working EHR interacting with your health app using SMART on FHIR interfaces, you can use synthetic patient datasets for testing. Synthetic means the data is not real but still realistic. You can also make use of anonymized patient data.

smart on fhir public sandboxes for testing

It’s also worth noting that besides SMART on FHIR API, EHR vendors such as Epic try out other FHIR-enabled data sharing models, for example, Epic USCDI API. But that’s an entirely separate topic, and we’ve covered the subject at length in a separate blog.

Step 5: Deploy and add to an app gallery

After you’ve tested the app, it’s time to deploy it to a production server or make it available for your staff and patients via a mobile store. One nuance with SMART on FHIR-enabled applications is that you can also add them to a specialized app gallery where healthcare organizations can discover them.

The app gallery is similar to a mobile store in terms of providing info about the app description, requirements, and the opportunity to test the application. That’s pretty much it about how you can develop an app on FHIR on SMART.

We also discuss medical app development costs in our dedicated blog.

Features of Apps Developed with SMART on FHIR

When venturing into the realm of healthcare technology, the decision to develop SMART on FHIR apps can significantly elevate the capabilities and efficiency of your digital health solutions. These apps are designed with a keen eye on interoperability, security, and user convenience, making them an indispensable tool for healthcare professionals and patients alike. Here’s a closer look at the standout features that define these innovative applications.

SMART on FHIR Specific Features of Health Apps:

  • Seamless Integration with EHR Systems: Apps developed with SMART on FHIR effortlessly integrate with existing EHR systems, enabling a unified and efficient workflow for healthcare providers.
  • Secure and Reliable Medical Data Sharing: These apps prioritize the confidentiality and integrity of medical data, ensuring secure and reliable sharing between various stakeholders in the healthcare ecosystem.
  • Improved Interoperability with Various EHR/EMR Systems: Interoperability is at the core, allowing these apps to communicate seamlessly across different EHR and EMR systems, thus facilitating a cohesive healthcare experience.
  • Enhanced Authorization and Authentication Layers: With robust authorization and authentication layers, these apps guarantee that access to sensitive health information is strictly regulated and secure. The implementation of advanced security protocols like OAuth 2.0 and OpenID protects against unauthorized access, safeguarding patient data and privacy.
  • Single Sign-On Functionality: The convenience of single sign-on functionality streamlines the login process, making it easier for users to access multiple healthcare services and platforms. Users can effortlessly switch between different health apps within the same ecosystem, enhancing the user experience and accessibility of varied health services.
  • Streamlined Workflows for Healthcare Professionals: Designed to simplify daily tasks, these apps streamline workflows, enabling healthcare professionals to focus more on patient care and less on administrative duties.
  • Easy Integration with Other Clinical Software: The ability to easily integrate with a wide range of clinical software amplifies the versatility and utility of SMART on FHIR apps within the healthcare setting.
  • Future-Proofing for Easier Integration with New Applications: These apps are built with future developments in mind, ensuring easy integration with new applications and technologies as they emerge in the healthcare sector.
  • Access to App UI Within EHR Systems: The integration allows users to access the app’s user interface directly within EHR systems, promoting a seamless and intuitive navigation experience.
  • Reliable and Secure Data Exchange Between EHR and App: Ensuring reliable and secure data exchange, these apps maintain the integrity and confidentiality of health information transferred between EHR systems and the application.
  • Support for Various App Architectures: SMART on FHIR healthcare apps support diverse app architectures, offering flexibility in design and functionality to meet specific healthcare needs and preferences.
  • Integration with Cloud Services for Hosting: Leveraging cloud services for hosting not only enhances scalability and reliability but also ensures that the apps are accessible from anywhere, at any time.

Popular Features in Health SMART on FHIR Apps

  • Healthcare Team Collaboration: These apps provide solutions for healthcare teams, including those specializing in cancer care, memory care facilities, hospice care, and support for conditions like Alzheimer’s and dementia. They enhance team communication, streamline task management, monitor patient health, and keep track of medications.
  • Clinical Study Support: Designed to expedite and simplify clinical trials, these applications offer functionalities for gathering and organizing study data, managing participant surveys online, and overseeing trial progress with real-time data capture.
  • Health Data Interpretation: Applications in this category transform complex health information into understandable formats, such as graphs, interactive visuals, and tables, facilitating deeper insights into patient care strategies and outcomes.
  • Chronic Condition Oversight: Aimed at aiding individuals with chronic illnesses, these tools offer features for self-care guidance, health tracking, and symptom monitoring. They cover a wide range of conditions, including but not limited to, diabetes, respiratory ailments, cardiovascular diseases, cancer, and mental health challenges.
  • Personalized Health Insights: Utilizing genetic data, these applications provide personalized health assessments, medication response predictions, and contribute to research on genetic predispositions within broader populations.
  • Medication Management: These tools help users adhere to their medication regimens through reminders, scheduling assistance, and progress tracking.
  • Engagement and Virtual Care Platforms: Enabling direct communication between patients and healthcare providers, these apps support virtual consultations, easy access to medical records, and enhanced patient involvement in healthcare decisions.
  • Health Trend Analysis: By examining extensive patient data, these applications aim to forecast and mitigate disease spread. They include platforms for analyzing health trends across populations and tools for data-driven healthcare strategy development.
  • Disease Risk Estimation: These tools calculate the likelihood of developing specific health conditions, such as heart disease, type II diabetes, and various cancers, using personal health information.
  • Immunization and Health Documentation: Offering users the ability to organize vaccination histories and essential health documents, these apps simplify the management of health records for travel and personal care purposes.

By choosing to build SMART on FHIR apps, healthcare organizations can harness these features to improve care delivery, enhance operational efficiency, and ensure data security.

Top 3 SMART on FHIR Apps Examples

In the ever-evolving landscape of healthcare technology, staying ahead means leveraging the latest advancements to improve patient outcomes and streamline operations. This makes SMART on FHIR development a game-changer for clinical executives and health app founders.

By integrating SMART on FHIR apps into their digital health strategies, organizations can significantly enhance data visualization, medication management, and population health monitoring. Below, we highlight five exemplary SMART on FHIR apps that showcase the potential of this technology to transform healthcare delivery.

Abstractive Health

Abstractive Health acts as a digital physician assistant, enhancing clinical documentation through the power of AI. It automates the creation of essential clinical notes—ranging from SOAP notes to discharge summaries—for various care settings. Leveraging generative AI and Large Language Models (LLMs), it condenses extensive medical documentation, freeing up time for patient-centered care.

  • Category: Data Visualization
  • EHR Support: Allscripts, Athena Health, Cerner, Epic
  • Specialty: General Healthcare
  • Licensing & Pricing: Site-Based, Per User

Health Chart App

The Patient Chart app redefines access to medical records by employing AI to deliver a comprehensive health data overview. Beyond standard records, it aggregates diverse health information, providing a complete picture of a patient’s health journey. Its AI engine processes this data to offer insightful health summaries and risk assessments, optimizing both time and care quality.

  • Category: Care Coordination, Disease Management
  • EHR Support: Cerner, Epic
  • Specialty: General Healthcare

Cardiac Risk by Boston Children’s Hospital

Cardiac Risk introduces a more accessible approach to cardiovascular risk assessment using the Reynolds Risk Score. Inspired by a Creative Commons design, it presents vital stats, lab measurements, and risk scores in an easy-to-understand format. Additionally, it features a simulation tool, allowing for hypothetical changes to see potential improvements in the risk score.

  • Category: Population Health, Risk Calculation
  • Platform: Web
  • EHR Support: Cerner
  • Specialty: Cardiology
  • Pricing: Opensource, free

Each of these apps represents a step forward in the quest to harness technology for better healthcare outcomes. By integrating such tools into their practices, health professionals can ensure they’re not just keeping up with the times but are poised to lead the charge in innovation. We recommend taking a closer look at these apps to learn how to do SMART on FHIR apps.

Our Experience in Creating SMART on FHIR Applications

One of the most exciting experiences Topflight had with the technology is when we were building a practice management solution integrated with EHRs. Our engineers opted for SmartJS, a JavaScript client for FHIR integrations, which saved us a ton of development time as we were able to integrate the practice management system with Epic and AllScripts EHRs in a matter of weeks (rather than months).

Read about Allscripts EHR integration on our blog.

This project also provided us with the opportunity to hone our cyber-security skills while we implemented EHR OAuth2 authentication server to secure the solution.

Case Study: How to Build and Launch a SMART on FHIR App within Epic Hyperspace/Hyperdrive

Let’s say an Epic-equipped clinic decides to implement a remote patient management program for their elderly patients to prevent falls.

The setup background

A possible setup for implementing this solution may include:

  • Patient mobile app with on-device AI/ML data processing

The mobile app gathers from phone sensors all sorts of data, including walking speed, step length, double support time, and walking asymmetry – to measure walking steadiness. We want to keep all this data securely (and quickly) analyzed on the phone so we can calculate a score and send it to a cloud app together with a patient ID.

  • Cloud application for providers with aggregated patient health data, dashboard, alerts, and all the data analysis/visualization goodies

Providers access this cloud app via a web browser to view all patients, classified according to their fall risk, data trends, etc. Additionally, they receive notifications about patients with rapidly deteriorating conditions.

What are we solving here?

The only issue is that now providers need to jump between the Epic EHR and this standalone web software. Healthcare app developers would have to set up provisioning and access rights in this application. Providers would need to keep another instance of credentials to log in. This may sound simple to an outsider, but clinicians know it can quickly become a mess.

That’s where SMART on FHIR (and a little bit of digital magic on the Epic side) comes to the rescue. Using this technology, we can seamlessly integrate the web app with the Epic EHR’s main interface called Hyperspace (or Hyperdrive in newer versions) so that it opens the web application right inside Epic – no need to switch the working environments for providers anymore. And the best part? No need for a separate login – because providers are already logged in with the EHR and can rely on single sign-on (SSO) architecture.

Why are we doing this?

SMART on FHIR offers significant advantages by enhancing providers’ workflows within the familiar EHR system. This technology empowers healthcare professionals to seamlessly integrate new functionalities, streamlining their processes and ultimately improving patient care:

  • An application opens directly within the EHR and can share patient context so you know what chart the provider is in.
  • The application can navigate within the EHR, open a new chart, and link the user to other Epic activities. This adds tremendous benefit to clinicians and allows them to use the app as a “main dashboard” for their work.
  • Backend integrations made available by the app can grab fresh data from the EHR on-demand and analyze/display it in the app.

The building part

SMART on FHIR uses the OAuth 2.0 authorization framework at the backbone, which has become the industry standard for implementing authorization/authentication. So, when we are developing a SMART on the FHIR app, we build on top of OAuth 2.0, but with the addition of an FHIR server for defining the data exchange format when syncing medical data between the EHR and our web software.

The SMART App Launch Framework allows us to connect the clinic’s web app to EHR data, supporting the app’s launch from inside or outside Epic Hyperspace/Hyperdrive. The framework provides a reliable, secure authorization protocol for various app architectures:

  • apps running on a local machine/device
  • apps running in the cloud on a secure server

This is extensively covered in HL7’s FHIR guidelines.

In addition, some configuration within Epic is required, for example, the integration with a standalone app must be enabled and a button must be created and made available to the right users. Fortunately, this button looks and works completely native to the Epic EHR.

Deploying a SMART on FHIR App

Besides configuring Epic to launch an external app inside the EHR and adding the secure authentication layer (with SMART on FHIR), we can also add the app to Epic’s app gallery – what used to be Epic App Orchard and has become Connection Hub.

This is done through a developer account over at fhir.epic.com. That’s also where you “build” SMART on FHIR apps, or rather define the parameters (such as API endpoints, app URL, CDS hooks, etc.) for interconnecting an already built (hosted and running) app with Epic.

However, please note that adding an app to Epic’s Connection Hub is not required. Many application vendors believe they need to pay fees to Epic in order to get their app working with the EHR. This is not actually the case. You can set up an application on fhir.epic.com at no cost, and you do not need to list it in Epic’s Connection Hub in order to integrate with a health system. The hub is where Epic customers and developers can discover your app.

Keep in mind there’s also a listing fee to take care of before finalizing your listing in Connection Hub.

Time to Build Your App

If you’d like to discuss how SMART on FHIR can help you set up interoperability in your family of healthcare apps, reach out today. We’ll be happy to elaborate on how this technology can help you put patient data to use and transition to value-based healthcare.

Related Articles:

  1. How to create a telehealth application
  2. Hospital Management System Development
  3. Build a doctor appointment application
  4. Patient Portal App Development Guide
  5. Medical Website Development Guide
  6. Healthcare App Development Guide
  7. Healthcare Mobile App Design Guide

Frequently Asked Questions

 

What is the difference between HL7, SMART on FHIR, and FHIR?

FHIR is a standardized API for sharing health data, SMART on FHIR is one of the implementations of FHIR, which is rapidly becoming the standard, and HL7 is the organization that oversees the FHIR standard development. Therefore, SMART and FHIR are standards, while HL7 is an organization.

Do I need to stick with particular EHR systems if I want to build a SMART HL7 backed app?

Epic, Cerner, and Allscripts provide official support for SMART on FHIR. You may need to check with your vendor if they work with SMART on FHIR, but those three — you can count on and use their documentations and sandboxes for testing.

Do all apps need to be added to the SMART on FHIR applications store (apps.smarthealthit.org) at the SMART site?

No it’s not required.

How do you implement a SMART on FHIR authentication protocol if you're adding it to an existing medical system that already uses OAuth 2.0?

You will need to make a couple of tweaks, adding SMART on FHIR specific parameters, and they cover that here in detail.

What EHR and other clinical systems support SMART on FHIR?

Platforms that fully support the API include Epic, Cerner, Allscripts, Athena Health, and Meditech. There are also a few provider organizations like Mayo Clinic and Intermountain Health.

Written in co-authorship with Scott Rossignol, EHR Integration Lead.

Konstantin Kalinin

Head of Content
Konstantin has worked with mobile apps since 2005 (pre-iPhone era). Helping startups and Fortune 100 companies deliver innovative apps while wearing multiple hats (consultant, delivery director, mobile agency owner, and app analyst), Konstantin has developed a deep appreciation of mobile and web technologies. He’s happy to share his knowledge with Topflight partners.
Learn how to build winning apps.

Privacy Policy: We hate spam and promise to keep your email address safe

Copy link