Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.

Introduction

Excerpt

This guide is a high-level introduction to the process of building and publishing HSPC applications.

Step 1: Get your app started quickly using an HSPC starter project

HSPC uses the SMART on FHIR specification for authorization, launch, context, and scope.  The best way to get your app off the ground quickly is to use an HSPC starter project.  Starter projects are available for JavaScript, Java, and mobile.  We recommend app developers use a starter project to quickly connect to and launch from an EHR (such as the HSPC Sandbox).  App developers can then add business logic and user interfaces easily.  Alternatively, starter project artifacts can be merged into an existing codebase but this process is not recommended for first time users.

Choose a starter project that matches the architecture style of your app:

...

MOBILE

...

WEB

...

OTHER

...

PROVIDER FACING

...

JavaScript

Java Spring MVC

Java Standalone MVC

...

PATIENT/FAMILY FACING

...

BACKEND SYSTEM

...

Java Spring IOC

(not vendor supported)

Step 2: Launch your app from the HSPC Sandbox

Typically a SMART on FHIR app is hosted on your server; however, with SMART on FHIR, your app is launched from within an EHR (Cerner, Epic, HSPC Sandbox, SMART on FHIR Sandbox, etc).  Throughout the development cycle, you will launch your app many times.  See Launch Your App from the HSPC Sandbox for detailed instructions.

Step 3: Register your app with the HSPC Sandbox

You can register your app with the HSPC Sandbox at any time during development.  When you register your app, you will get a client_id for your app within the HSPC Sandbox.  Use this new client_id when launching from the HSPC Sandbox.  See Register Your App in the HSPC Sandbox for detailed instructions.

Step 4: Publish your app in the HSPC Gallery

...

helps SMART App developers follow best practice guidelines to create marketable "about" pages, interchangeable manifest files, and social media link previews.

Index.html Page

You now have an app that launches great from within the HSPC sandbox or EHR system. But what happens when the your app is loaded outside of these authorization spaces? What does the user see? Usually it's either a garbage page or your app with no loaded data. We suggest to take advantage of these instances by advertising your app's capabilities by creating a marketing page for your index.html page. Here's an example of the index.html rendering of the HSPC Patient Data Manager app (https://patient-data-manager.hspconsortium.org).

Image Added









We recommend including at least 3 different features:

  1. A description of what the app does and why the user should use/purchase it.
  2. A screenshot of the app
  3. Provide a link where they can open the app in a test environment as a demo

Manifest Files

IdDescription
software_id

unique identifier for your app. The HSPC apps use the Maven Coordinates (https://maven.apache.org/pom.html#Maven_Coordinates)

client_namename of the application
client_urithe marketing index.html address
logo_urilink to screenshot of your app
launch_urlthe html page that handles the Oauth process
redirect_urisList of possible urls that the sandbox/EHR will redirect to after authorization
scope

a space delimited list of scopes (http://docs.smarthealthit.org/authorization/scopes-and-launch-context)

token_endpoint_auth_method
grant_typesthe type of Oauth grant model your app uses: authorization_code or client_credentials are the two choices (http://docs.smarthealthit.org/authorization/best-practices)
fhir_versionsList of FHIR versions that the app can handle

Here's an example of the manifest.prod.json file from the Patient Data Manager app:

Image Added

Social Media Link Previews

To properly market your app, you'll want to be able to control what is rendered when someone shares your app url on social media. This is done by integrating metadata in your index.html page. The code is placed in the <head> section of the html file.

Social media platforms uses Open Graph markup as a minimum framework for providing metadata.

Here's the metadata found in the Patient Data Manager app:

Image Added



Here's what the rendering looks like in Google+. Similar renderings are done in Facebook, Twitter, and Pinterest

Image Added














If you've made any changes to your metadata since you or anyone else has posted on Facebook, you'll need to clear the cache through the Facebook debugger tool (https://developers.facebook.com/tools/debug). Plug in the app url, click "Debug", then click "Scrape Again" in the new page. Twitter has a similar process (https://cards-dev.twitter.com/validator).