Skip to content

nmdp-bioinformatics/hml-fhir-app

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

63 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

hml-fhir-app

HML to FHIR Conversion Application

Accomplishments

ToDo

  • Implement and use community FHIR models in place of NMDP models generated by swagger
  • Implement a pipeline / data-flow to take HML sequence data and run it through the Gene Feature Enumeration Service hosted by NMDP to tag sequence with allele resolution
  • Add mapping and infrastructure to support different FHIR draft / revision standards
  • Provide support to institutions and enities that have use-cases for this tool
  • Place a public facing conversion system in the Cloud (AWS)
  • Place a public facing bulk-conversion system in the Cloud (AWS)

Preface

We have developed a computational infrastructure to handle converting high volumes of raw Histoimmunogenetics Markup Language (HML) documents to a hierarchical collection of Fast Health Interoperability Resources (FHIR) based resources. This infrastructure is an ecosystem built around open source principals and currently implemented in Java and Python. It is theoretically possible to implement this project in any modern-day object-oriented language or framework; however, for the purpose of this implementation, the following prerequisites must be installed on a bash-capable operating system. To aid in the adoption of this implementation, we are currently writing build scripts that will execute in a Windows environment through PowerShell. Please check for release updates regularly as the development of this source code is an active effort, we strongly recommend staying up to date with current code releases.

Docker

EASY IMAGE PULL

At the root of this directory, there is a docker-compose.yml file. Simply execute the following after installing Docker:

"docker-compose up"

This will pull published images from the Docker Hub, this will build and launch the application on your local machine. Navigate to: 0.0.0.0:9005 to use the application.

Prerequisites:

Docker

LOCAL BUILDS

Prerequisites:

(** = Only needed if compling code from source)

To easily build this application via Docker-Compose, please simply execute:

"sh intsall.sh"

Running this script assumes you have Maven 3.+ installed, if you do not have Maven, or do not with to install Maven, there are .jar files included at the 'local' directory. Simply modify the Dockerfile's of their parent project to point to these jars. This will handle building docker images and start docker-compose via the up command with all necessary container linkage. You will then need to create databases and collections in MongoDb. To accomplish this, there is a script located in the "mongo" directory. Simply run:

"python CreateDatabse.py"

You are now ready to import hml files that will be convered, and/or submitted to a FHIR conformance server.

Naviage to:

"0.0.0.0:9005" 

Environment Setup

This conversion infrastructure is designed to run in an environment consisting of a high-throughput message bus system, a map-reduce capable schemaless database, and a series of RESTful Application Programming Interfaces (APIs). We have chosen the following open-sourced projects to satisfy environmental requirements:

Kafka Setup:

  1. Download Kafka v0.10.2.1 (https://kafka.apache.org/downloads)

  2. Unzip, and copy the contents (3 files) of 'kafka-setup' directory included in this repository to 'kafka_2.12-0.10.2.1/config' located in the kafka distribution downloaded in step 1

  3. Start a single instance of zookeeper: 'bin/zookeeper-server-start.sh config/zookeeper.properties'

  4. Start a cluster of Kafka message brokers: 'bin/kafka-server-start.sh config/server.properties & bin/kafka-server-start.sh config/server-1.properties & bin/kafka-server-start.sh config/server-2.properties'

  5. This project depends on the creation of 3 topics: 1) hml-fhir-conversion 2) fhir-hml-conversion 3) fhir-submission

  6. We strongly recommend the following replication schema for the creation of topics in step 5: 3 partitions, 3 replicates

  7. Kafka Tool is an excellent GUI based administrative tool for managing your Kafka cluster, we recommend the creation of topics by this mechanism rather than the command line based approach (http://www.kafkatool.com)

MongoDB Setup:

  1. Download MongoDB v3.4.6 binary distribution (https://www.mongodb.com/download-center?jmp=nav#community)

  2. Extract files from download in step 1

  3. Copy files to desired target directory

  4. Create a directory to house Mongo databases (recommend: /Database/Mongo)

  5. Execute 'mongodb ---dbpath={PATH_TO_DIRECTORY_IN_STEP_4}' from the target directory where binaries were copied

  6. Execute the script (mongodb-setup/create_databases.js) included in this release

  7. We recommend the using MongoChef (https://studio3t.com) as a GUI to administer and manage your mongo database

Building and Running RESTful APIs

Currently, there are 3 RESTful APIs that require building, installing, and running to support the implementation of this conversion system. The procedure to build, install, and run each of these APIs is identical and can be executed independently of one another to support ongoing development efforts, or built in a batch. To execute a batch build and install, simply download the repository marked '*parent' below.

API Repositories:

"Parent"-Install Process:

  1. From service-hml-fhir-converter-parent directory, execute: 'python Setup.py [options]'

       2.  Options are not required for building, 'python Setup.py' is adequate
       to begin process
       
       3.  Please see documentation for detailed explanation of optional build
       parameters
       (<https://github.com/nmdp-bioinformatics/service-hml-fhir-converter-parent)>
       
       Individual Module Install Process:
       ----------------------------------
       
       1.  From directory of module source, execute: 'sh install.sh'
       
       2.  To only execute build action, execute: 'sh build.sh'
       
       After installing, the executable Java Archive (JAR, .jar)
       (/target/\[repository-name-version.jar\] file can be run simply by
       executing 'java --jar \[PATH\_TO\_JAR\]'. Optionally, the '-r' flag can
       be passed, telling the install scripts to begin running the API server
       after install successfully completes.
       
       Building and Running Graphical User Interface (GUI) Tools:
       ==========================================================
       
       ### web-hml-fhir-converter
       
       In an effort to both aid in the correct input of HML and FHIR data
       structures, we have created a GUI tool that currently supports the
       inputting of data through web forms. This data has machine-learning
       capability for auto-completion of structured data contained in various
       properties of an HML document. As the database grows in size and
       diversity, predictions to commonly populated discreet values can be
       obtained by entering the first few characters of its value. This future
       goal of this tool is support both the structured input of FHIR and HML
       as an entry point to creating mock data for use in the conversion
       ecosystem.
       
       ### web-hml-fhir-conversion-dashboard
       
       In an effort to guide non-developer users of this conversion ecosystem,
       we have created a GUI tool that is capable of submitting files
       containing HML or FHIR data for conversion. This allows for the
       submission of FHIR or HML data into a conversion queue and tracks its
       status. Status results are returned as successful, processing, or error.
       Should an error be encountered, specific data on what caused the
       exception to fail the message is recorded and will be available to the
       user. After the conversion process has successfully completed, a file is
       available to download as either an HML document in XML or JSON format or
       FHIR a structured FHIR object that contains relational data for
       subsequent submission to a FHIR conformance server (XML or JSON). It is
       important to note at the time of writing this document, the FHIR
       conformance submission is an ongoing development effort and has not
       reached release status.
       
       Prerequisites:
       ---------------
       
       -   Node package manager
       (https://docs.npmjs.com/getting-started/installing-node)
       
       -   Bower package manager (install by: 'npm install --g bower')
       
       -   Ruby (<https://www.ruby-lang.org/en/downloads)>
       
       Repositories:
       --------------
       
       -   web-hml-fhir-converter
       (<https://github.com/nmdp-bioinformatics/web-hml-fhir-converter.git)>
       
       -   web-hml-fhir-conversion-dashboard
       (<https://github.com/nmdp-bioinformatics/web-hml-fhir-conversion-dashboard.git)>
       
       Building and Deploying (from root directory of repository):
       -----------------------------------------------------------
       
       1.  'gem install compass'
       
       2.  'npm install --g grunt grunt-cli'
       
       3.  'npm install'
       
       4.  'bower-install'
       
       5.  'grunt-serve'
       
       Building and Running Kafka Consumer Processes
       =============================================
       
       Currently, there are 3 Kafka consumer APIs that require building,
       installing, and running to support the implementation of this conversion
       system. The procedure to build, install, and run each of these APIs is
       identical and can be executed independently of one another to support
       ongoing development efforts, or built in a batch. To execute a batch
       build and install, simply download the repository marked '\*parent'
       below.
       
       Consumer Repositories:
       -----------------------
       
       -   process-kafka-hml-fhir-parent (\*parent)
       (<https://github.com/nmdp-bioinformatics/process-kafka-hml-fhir-parent.git)>
       
       -   process-kafka-fhir-hml-conversion-consumer
       (<https://github.com/nmdp-bioinformatics/process-kafka-fhir-hml-conversion-consumer.git)>
       
       -   process-kafka-hml-fhir-conversion-consumer
       (<https://github.com/nmdp-bioinformatics/process-kafka-hml-fhir-conversion-consumer.git)>
       
       -   process-kafka-fhir-submission-consumer
       (<https://github.com/nmdp-bioinformatics/process-kafka-fhir-submission-consumer.git)>
       
       "Parent"-Install Process:
       -------------------------
       
       1.  From service-hml-fhir-converter-parent directory, execute: 'python
       Setup.py \[options\]'
       
       2.  Options are not required for building, 'python Setup.py' is adequate
       to begin process
       
       3.  Please see documentation for detailed explanation of optional build
       parameters
       (<https://github.com/nmdp-bioinformatics/service-hml-fhir-converter-parent)>
       
       Individual Module Install Process:
       ----------------------------------
       
       1.  From directory of module source, execute: 'sh install.sh'
       
       2.  To only execute build action, execute: 'sh build.sh'
       
       After installing, the executable Java Archive (JAR, .jar)
       (/target/\[repository-name-version.jar\] file can be run simply by
       executing 'java --jar \[PATH\_TO\_JAR\]'. Optionally, the '-r' flag can
       be passed, telling the install scripts to begin running the API server
       after install successfully completes.
       
       Supplemental
       ============
       
       ### GUI Conversion Tool (web-hml-fhir-conversion-dashboard)
       
       This is a single page application (SPA), you will be taken to the
       initial upload page
       
       ![../../Desktop/Presentation1/Slide1.jpg](media/image1.jpeg){width="6.5in"
    

height="3.657638888888889in"}

From the upload page, begin by uploading an HML file by clicking 'Choose File' button (#1)

../../Desktop/Presentation1/Slide1.jpg{width="6.5in" height="3.657638888888889in"}

Select a valid file and click 'Open' button (#2)

../../Desktop/Presentation1/Slide2.jpg{width="6.5in" height="3.657638888888889in"}

Upload file by clicking 'Upload' button (#3)

../../Desktop/Presentation1/Presentation1/Slide3.jpg{width="6.5in" height="4.879861111111111in"}

The page will automatically refresh and show the current status of the conversion process

../../Desktop/Presentation1/Presentation1/Slide4.jpg{width="6.5in" height="3.657638888888889in"}

Clicking the 'Refresh' (#4) button will update the status of the converted message

../../Desktop/Presentation1/Presentation1/Slide4.jpg{width="6.5in" height="3.657638888888889in"}

../../Desktop/Presentation1/Presentation1/Slide5.jpg{width="6.5in" height="3.657638888888889in"}

To download files as JSON, click in the desired layout's 'Json' button (#6), to download as XML, click in the desired layout's 'Xml' button (#7). An upcoming feature will allow visualization without the need of downloading files ('View' buttons).

../../Desktop/Presentation1/Presentation1/Slide5.jpg{width="6.5in" height="3.657638888888889in"}