This code repository contains one of the services that is part of the Microservice Architecture for Guideline Embedding into Decision Support Systems (MAGE-DSS). In particular, this repository implements the CDS Hooks Management (CDS-HsM) microservice. The CDS HsM microservice is an agnostic service to implementations of guideline modelling languages. The service functions as the single point of entry between CDS clients (via FHIR and CDS hook specifications) and any implementation of a computable guideline enactment engine.
The CDS-HsM microservice leverages existing CDS hook specifications and computable guidelines knowledge to query the clinical workflow context, part of any CDS-Hooks-compliant CDS request call, to search, and manipulate, clinical and patient data. The result can be as simple as fetching the FHIR patient identifier from the hook context to add it to the CDS suggestion card response (later, as part of the CDS Services Manager microservice), or to identify URIs in order to trigger (parts of) implemented computable guidelines, or even to describe more complex algorithms (for instance, we have implemented the COPD severity assessment algorithm form GOLD 2017 guideline using solely the available actions which are included with this microservice functionality).
This repository is built using either Docker or NPM. In order to run the microservice locally or build this project, you will need to install Node ~12.13 and install NPM ~6.13 as well as the database MongoDb, which contains the collection of instructions loaded to the CDS-HsM service to search and manipulate the clinical workflow context. We strongly recommend using a Node version manager like nvm to install Node.js and npm. We do not recommend using a Node installer, since the Node installation process installs npm in a directory with local permissions and can cause permissions errors when you run npm packages globally.
- Clone the repository
$ git clone https://github.com/susoDominguez/cds_hooks_manager
- Install and connect to the MongoDB database with baseURL
MONGODB_HOST
and portMONGODB_HOST
. Our default values areMONGODB_HOST = localhost
andMONGODB_PORT = 27017
. Alternatively, if the docker daemon is installed, pull and run the docker official image, then follow the instructions to add both host and port values.
$ docker pull mongo
-
Install SNOWSTORM, the SNOMED CT terminology server. This services only interacts with the FHIR API of the SNOWSTORM server.
-
Create the environment
.env
text file, to be located in the main folder of the project
$ touch .env
$ open .env
- and add the following environment variables (and default values)
MONGODB_HOST=localhost
MONGODB_PORT=27017
CDS_SERVICES_MS_HOST=localhost
CDS_SERVICES_MS_PORT=3010
SNOMEDCT_BASE_URL=snowstorm-fhir.snomedtools.org
PROXY_PORT=3000
MONGODB_CIG_MODEL=tmr
MONGODB_NONCIG_DB_NAME=non-cig
LOGS=cds_hm_logs
Environment variables MONGODB_HOST
, MONGODB_PORT
, LOGS
, MONGODB_CIG_MODEL
and MONGODB_NONCIG_DB_NAME
relate to the instance of the MongoDB
where MONGODB_HOST
is the baseURL, MONGODB_PORT
is the port, LOGS
is the collection to store system errors, MONGODB_CIG_MODEL
is the identifier of the computable guideline implementation this service is working with, (could be more than one, then MONGODB_CIG_MODEL_2
,n etc.) and MONGODB_NONCIG_DB_MODEL
is collection that stores documents which do not access computable guideline knowledge (for instance, the COPD severity assessment algorithm mentioned above). PROXY_PORT
is the port used by this service.
CDS_SERVICES_MS_HOST
, CDS_SERVICES_MS_PORT
store the baseURL and port of the CDS Services Management (CDS-SsM) microservice implementation this service operates with (at least one CDS-SsM per computable guideline representation model implemented). Next, variables SNOMEDCT_BASE_URL
store the FHIR-based API endpoint of the SNOMED CT server installed (as default, we direct the service to the SNOWSTORM sandbox installation).
- Install the project dependencies
$ cat requirements.txt | xargs npm install -g
- Run the site locally in DEBUG mode
$ DEBUG=cds_hooks_manager:* npm run devstart
We offer a dockerised version of this service by building the attached docker-compose
yaml file.
$ docker-compose up -d --build