Skip to content

Latest commit

 

History

History
115 lines (71 loc) · 3.47 KB

README.md

File metadata and controls

115 lines (71 loc) · 3.47 KB

🏪 Consent Manager

A Health Data Consent Manager (HDCM) is a new type of entity proposed here whose task is to provide health information aggregation services to customers of health care services. It enables customers to fetch their health information from one or more Health Information Providers (e.g., Hospitals, Diagnostic Labs, Medical Device Companies), based on their explicit Consent and to share such aggregated information with Health Information Users i.e. entities in need of such data (e.g., Insurers, Doctors, Medical Researchers).

Components

components

System Architecture

Architecture

Consent Manager Architecture

Import the project

When using IntelliJ Idea, open this project by importing the gradle file and check Auto Import option to resolve all the dependencies automatically.

💪 Motivation

Consent Manager must provide its customers an interface using which they can view and manage consent artefacts associated with them and, optionally, an interface for the customers to view their aggregated health information.

Build Status

ci/cd

👍 Code Style

JAVA Naming Conventions

🎉 Language/Frameworks

🏁 Requirements

Setting up local machine

🚀 Running From Source

To run

./gradlew :consent:bootRun

or if you want to run in dev environment setup

./gradlew bootRun --args='--spring.profiles.active=dev'

Running The Tests

To run the tests

./grdlew test

Features

  1. Consent Management
  2. Aggregate Health Information

API Contract

Once ran the application, navigate to

{HOST}/index.html

Commands to Know

Generates PNGs for all *.puml files located in docs/diagrams and <project>/docs/diagrams.

make png

Create a keypair in keystore (Also initializes keystore)

keytool -genkeypair -alias ${keypair_alias} -keyalg RSA -keysize 2048 -storetype PKCS12 -keystore ${keystore_filepath} -validity ${validity_in_days} -storepass ${password}

keyalg: the cryptographic algorithm to generate the key pair.

keysize: the size of the key. We have used 2048 bits, but 4096 can be used for production.

storetype: the type of keystore - it's either PKCS12 or JKS.

When running the previous command, we will be asked to input some information, but we are free to skip all of it (just press Return to skip an option). When asked if the information is correct, we should type yes. Finally, we hit return to use the keystore password as key password as well.

Verify keystore content

in JKS format - keytool -list -v -keystore ${filepath}

in PKCS12 format - keytool -list -v -storetype pkcs12 -keystore ${filepath}