/open-source-fhir-server

Open source fhir server

Primary LanguageJavaScriptMIT LicenseMIT

ROQR (fhiR On Qewd and dockeR) - Open Source FHIR Server

4th June 2019, Yorkshire and Humber Care Record

Twitter: @YHCareRecord


What is the ROQR?

ROQR (pronounced 'rocker') is an open source FHIR server which is being built by the Yorkshire and Humber Care Record (YHCR) project team as part of their work with the NHS England Local Health and Care Record Exampler (LHCRE) programme. The name ROQR reflects the stack of open source software and health care interoperability standards that the server has been built upon, namely:

Fast Healthcare Interoperable Resources - FHIR Fast Healthcare Interoperability Resources is a standard describing data formats and elements and an application programming interface for exchanging electronic health records. The standard was created by the Health Level Seven International health-care standards organization.

Quick and Easy Web API Development - QEWD-Up A fast-track route to Building APIs built on top of Node.js

YottaDB YottaDB is a NoSQL database platform built upon a proven database engine that enhances simplicity, security, stability and scalability.

Docker Docker is a set of coupled software-as-a-service and platform-as-a-service products that use operating-system-level virtualization to develop and deliver software in packages called containers.

ROQR is being developed in accordance to a series of technical papers produced by the YHCR. Each design paper describes a set of "model" software components and architectures that, when realised, can enable health and social care organisations to share data using FHIR.

ROQR is very much a work in progress and will keep evolving in step with both the LHCRE and YHCR programmes. The overall aim, however, is that the server will provide an out of the box, open source solution to health and social care organisations who require the ability to share data using FHIR. It is very much hoped that the code base here will be developed by clinicians, engineers, architects and healthcare interoperability standards bodies.


Current Features

The source code available here is pre-alpha and very much under development - this is an active, working project that is subject to (hopefully) frequent change. At the time of writing, the server supports:

To see these features in action, refer to the "Getting Started" section below.


Architecture Summary

ROQR componentry and microservices are aligned to the process model as described in page 19 of the YHCR technical design paper: Design Paper 003 - A Conceptual Design for A FHIR Proxy Server. The server is currently comprised of the following services, each of which are self-contained, executes within their own Docker container and are able to run in isolation or as part of a ROQR FHIR interaction service pipeline (fisp):

  • FHIR API - this service encapsulates both the FHIR REST API and FHIR Search API. Currently supported are Create (POST), READ (GET) and a limited Search (GET). The services receives FHIR API requests and then maps those requests onto an interaction service pipeline. An interaction service pipeline configures the route that the request should navigate through the ROQR internal microservices in order to be fulfilled. The interaction pipelines are configurable so that future additional services which are required to process a request can be added, e.g. Pub/Sub, Asynchronous Query Processing etc.

  • Index - this service provides methods to create and delete searchable indices for each resource in addition to a method that affords the ability to execute index queries/lookups. Each ROQR index table maps each property within a FHIR resource onto the specified FHIR Search Parameter type.

  • Repo Adapter - this service provides a facade to the local FHIR store service. The service further transforms messages recieved by the public facing FHIR API into the message format needed by the local FHIR store.

  • Repo - this service provides database Create, Read, Update and Delete operations that interact with the local database. The service also acts a facade to the Search service.

  • Search - this services provides a series of API methods which, when executed as part of a request pipeline, provide result set caching, sorting and paging against data within the local FHIR store. The service also provides methods that include and revinclude search results.

  • Responder - this service transforms received messages forwarded to it from the server's internal services into a FHIR response (partially implemented).

  • Tests - this service makes each of the ROQR internal microservices accesible via a HTTP API that affords developers with the ability to execute requests against a single service in isolation which is very useful for testing and development (i.e. not part of any interaction service pipeline). In production, this microservice should NOT be deployed.


Getting Started

The following steps describe how to get the current version of ROQR up and running on your local development machine. Please note that although QEWD-Up supports Open Authentication and JWT out of the box, this is currently disabled in order to speed up development and testing of the services and APIs. The [QEWD-Up]](https://github.com/robtweed/qewd/tree/master/up#dockerised-qewd-microservices) documentation does describe how to enable this feature - it goes without saying that authentication SHOULD be enabled in staging/production environments.

Pre-requisites

Docker

Docker is required to run ROQR. There are lots of documents which describe the installation of Docker Desktop and this is all that is needed to run the server on your local machine.

Docker Compose (optional)

Docker Compose affords the ability to "spin up" an entire stack of Docker containers in one simple command. The ROQR repo includes a docker-compose.yml file which defines each service along with the docker command to get the container up and running.

Development Environment/Editor

The flavour of dev enviroment is of course entirely up to you... ROQR ultimately doesn't care! VS Code, Atom and Sublime, are extensible, open source and free. Each environment does have decent Docker integration which can be installed via the usual plugin/extension management features.

A note on data persistence

The docker compose file and commands listed below do not persist data. Once the containers are torn down, the data is lost - it is ephemeral to aid in the development and rapid testing of the microservices. That said, if you wish your data to be persisted then the documentation here describes what you need to do. At some point in the future an alternative docker-compose file will be provided that will enable data to be persisted.


Launching ROQR

Get the source

  1. Either navigate to your local repo directory or create one, e.g. C:\myrepos\ or ~/Repos

  2. In your command line type (followed by enter): git clone https://github.com/nhsx/open-source-fhir-server.git

  3. Open the folder in your development environment and take a few minutes to have a look at the code (if you wish).

Docker (command line)

ROQR currently consists of 8 services - each of which needs to be launched. This can be labourious using the Docker command line and subverting this process is where docker-compose comes into its own. However, the following instructions are provided for completeness:

  1. Launch the QEWD-Up Orchestrator: docker run -d --name orchestrator --rm -p8080:8080 -v <file-path-to-the-ROQR-source>:/opt/qewd/mapped -e microservice=orchestrator rtweed/qewd-server

  2. Launch the FHIR API Service: docker run -d --name fhir --rm -p8081:8080 -v <file-path-to-the-ROQR-source>:/opt/qewd/mapped -e microservice=fhir rtweed/qewd-server

  3. Launch the Repo Adapter Service: docker run -d --name repoadapter --rm -p9001:8080 -v<file-path-to-the-ROQR-source>:/opt/qewd/mapped -e microservice=repoadapter rtweed/qewd-server

  4. Launch the Repo Service: docker run -d --name repo --rm -p9002:8080 -v <file-path-to-the-ROQR-source>:/opt/qewd/mapped -e microservice=repo rtweed/qewd-server

  5. Launch the Index Service: docker run -d --name index --rm -p9003:8080 -v <file-path-to-the-ROQR-source>:/opt/qewd/mapped -e microservice=index rtweed/qewd-server

  6. Launch the Search Service: docker run -d --name search --rm -p9004:8080 -v <file-path-to-the-ROQR-source>:/opt/qewd/mapped -e microservice=search rtweed/qewd-server

  7. Launch the Responder Service: docker run -d --name responder --rm -p9005:8080 -v <file-path-to-the-ROQR-source>:/opt/qewd/mapped -e microservice=responder rtweed/qewd-server

  8. Launch the (Optional) Tests Service: docker run -d --name tests --rm -p6666:8080 -v <file-path-to-the-ROQR-source>:/opt/qewd/mapped -e microservice=tests rtweed/qewd-server

Each of the above commands will launch the services in "headless" or "daemon" mode. If you wish to run the containers in "interactive" mode then replace -d with -it (see here for more information on the Docker command line options).

Docker Compose

This process is significantly less of a pain! Before running these commands, please check that the file/directory paths in the Docker compose file match your local environment. Note steps 1 and 2 are only required to be completed once - on first run:

  1. docker run -it --name fhir --rm -p8081:8080 -v <file-path-to-the-ROQR-source>:/opt/qewd/mapped -e microservice=fhir rtweed/qewd-server to bring up the orchestrator service and ensure that the additional node packages required by ROQR are installed.

  2. Kill the container docker stop fhir

  3. Bring up ROQR: docker-compose up -d

  4. To tear the containers down, simply enter docker-compose down

Postman Collection and Environment

Once ROQR is up and running, you can try out the FHIR API by executing the following Postman collection (and environment). The process for importing collections and environments into Postman is very well documented here

  1. Postman Environment
  2. Postman Collection

Roadmap

The following outlines the current remaining development of work before the server is considered to be beta:

Short Term (June/July 2019)

  1. Although any resource can be stored in the local FHIR store (it is a NoSQL/schemaless database), it is necessary to import schemas that describe the structure of a FHIR resource to help with indexing and searching. The following resources need to be mapped: Observation, AllergyIntolerance, Procedure, Condition, Medication, MedicationStatement, Location and PractitionerRole resources.

  2. Modify the built JWT/OAUTH authentication services to support YHCR technical design paper: Design Paper 005 - Identity and Access Management

  3. Build a SQL/Database proxy adapter service so that FHIR resources can be extracted from external databases.

  4. Implement a policy and consent service that adheres to the concepts described in YHCR technical design paper: Design Paper 008 - Data Access and Consent Management.

  5. Implement FHIR capability statement API

  6. Subscription Processing - create a subscription service which is to slot into the create and update interaction service pipeline.

  7. Versioning - create a versioning service FHIR Versioning/History which will be slotted into the create and update interaction service pipeline.

  8. Validation - create a validation service which will be slotted into the create interaction service pipeline.

Medium Term (July/August 2019)

  1. Containerize an NGINX reverse proxy server to sit in front of the API.

  2. Build a proxy adapter service so that FHIR resources can be searched and read from an external FHIR data store/server.

  3. Add support to construct and transmit ITK3 Inpatient and Emergency Transfer of Care FHIR resources via MESH.