Skip to content

CanDIG/CanDIGv2

Repository files navigation

CanDIG v2


Overview

The CanDIG v2 project is a collection of heterogeneous services designed to work together to facilitate end to end dataflow for genomic data.

Branches

The default develop branch is for developers. It undergoes nightly builds and integration testing, so should generally be deployable.

The stable branch is the latest stable release and is the one that you should use for production deployments.

Installation

CanDIG uses a make-based deployment process, with services containerized in Docker. To deploy CanDIGv2, follow the installation guides on our documentation website:

See Interact using Make for a guide to additional options or view all Makefile options with make help.

Project Structure

CanDIGv2/
 ├── .env                          - global variables
 ├── Makefile                      - functions for repeatable testing/deployment (Docker/Kubernetes)
 ├── tox.ini                       - functions for repeatable testing/deployment (Python Venv/Screen)
 ├── bin/                          - local binaries directory
 ├── docs/                         - documentation, installation instructions
 ├── etc/                          - contains misc files/config/scripts
 │    ├── docker/                  - docker configurations
 │    ├── env/                     - sample .env file
 │    ├── ssl/                     - ssl root-ca/site configs and certs
 |    ├── tests/                   - integration and performance tests (under development)
 │    ├── venv/                    - dependency files for virtualenvs (conda, pip, etc.)
 │    └── yml/                     - various yaml based configs (toil, traefik, etc.)
 ├── lib/                          - contains modules of services/apps
 └── tmp/                          - contains temporary files used for runtime functionality
      ├── configs/                 - config files that are added to services post-deployment
      ├── data/                    - local data for running services
      ├── federation/              - federation configuration files
      ├── tyk/                     - tyk configuration files
      ├── vault/                   - vault keys
      └── secrets/                 - directory to store randomly generated secrets for service deployment

List of Services and Components

The following table lists the individual repos for each service and helper library developed by the CanDIG team that contribute to the CanDIGv2 stack.

Service/Component Name Source Description
authx candigv2-authx Library to facilitate interacting with AuthZ/AuthN services, Keycloak, Tyk, Opa, Vault & Access to minIO S3 objects
CanDIG Data Portal candig-data-portal Front-end User interface for CanDIG Services
CanDIGv2 Ingest Service candigv2-ingest Ingests clinical and genomic data into the CanDIG infrastructure.
Clinical ETL Code clinical_ETL_code Code to convert spreadsheet format into the MoH data model in preparation for ingest into katsu
Federation Service federation-service Distributes requests across each federated node of the distributed infrastructure
HTSGet htsget_app Implementation of GA4GH htsget API which ingests and indexes VCF files and stores GA4GH DRS objects for retrieval
Katsu katsu Manages the clinical metadata in a PostgreSQL database
CanDIG OPA candig-opa Manages role-based access policies
Query service candigv2-query Manages front-end querying of services

As well as in-house developed services, the CanDIG stack relies on external software which is configured to work within the stack, configurations are found in the /lib folder for each software, these include:

Service/Component Name Role
Keycloak Authentication management
minio Object storage for genomic files
OPA Manages role-based access policies
Tyk API management and redirection
Vault Secret and password management

Adding a new service

New services can be added under lib directory. Please refer to the template for new services README for more details.