The intent of the project is to leverage the collective knowledge of the disparate existing resources of the VICC to improve the comprehensiveness of clinical interpretation of genomic variation. An ongoing goal will be to provide and improve upon standards and guidelines by which other groups with clinical interpretation data may make it accessible and visible to the public. We have released a preprint discussing our initial harmonization effort and observed disparities in the structure and content of variant interpretations.
These instructions will get you a copy of the project up and running on your local machine for development and testing purposes. See deployment for notes on how to deploy the project on a live system.
- A newer version of Python 3, preferably 3.10 or greater. To confirm on your system, run:
python3 --version
- Pipenv, for package management.
pip3 install --user pipenv
Once Pipenv is installed, clone the repo and install the package requirements into a Pipenv environment:
git clone https://github.com/cancervariants/metakb
cd metakb
pipenv lock && pipenv sync
If you intend to provide development support, install the development dependencies:
pipenv lock --dev && pipenv sync
The MetaKB uses Neo4j for its database backend. To run a local MetaKB instance, you'll need to run a Neo4j database instance as well. The easiest way to do this is from Neo4j Desktop.
First, follow the desktop setup instructions to download, install, and open Neo4j Desktop for the first time.
Once you have opened Neo4j desktop, use the New
button in the upper-left region of the window to create a new project. Within that project, click the Add
button in the upper-right region of the window and select Local DBMS
. The name of the DBMS doesn't matter, but the password will be used later to connect the database to MetaKB (we have been using password
by default). Select version 5.14.0
(other versions have not been tested). Click Create
. Then, click the row within the project screen corresponding to your newly-created DBMS, and click the green Start
button to start the database service.
The graph will initially be empty, but once you have successfully loaded data, Neo4j Desktop provides an interface for exploring and visualizing relationships within the graph. To access it, click the blue "Open" button. The prompt at the top of this window processes Cypher queries; to start, try MATCH (n:Statement {id:"civic.eid:1409"}) RETURN n
. Buttons on the left-hand edge of the results pane let you select graph, tabular, or textual output.
The MetaKB calls a number of normalizer libraries to transform resource data and resolve incoming search queries. These will be installed as part of the package requirements, but require additional setup.
First, follow these instructions for deploying DynamoDB locally on your computer. Once setup, in a separate terminal instance, navigate to its source directory and run the following to start the database instance:
java -Djava.library.path=./DynamoDBLocal_lib -jar DynamoDBLocal.jar -sharedDb
Next, navigate to the site-packages
directory of your virtual environment. Assuming Pipenv is installed to your user directory, this should be something like:
cd ~/.local/share/virtualenvs/metakb-<various characters>/lib/python<python-version>/site-packages/ # replace <various characters> and <python-version>
Next, initialize the Variation Normalizer by following the instructions in the README. When setting up the UTA database, these docs may be helpful.
The MetaKB can acquire all other needed normalizer data, except for that of OMIM, which must be manually placed:
cp ~/YOUR/PATH/TO/mimTitles.txt ~/.local/share/wags_tails/omim/omim_<date>.tsv # replace <date> with date of data acquisition formatted as YYYYMMDD
MetaKB relies on environment variables to set in order to work.
-
Always Required:
-
UTA_DB_URL
- Used in Variation Normalizer which relies on UTA Tools
- Format:
driver://user:pass@host/database/schema
- More info can be found here
Example:
export UTA_DB_URL=postgresql://uta_admin:password@localhost:5432/uta/uta_20210129
-
-
Required when using the
--load_normalizers_db
or--force_load_normalizers_db
arguments in CLI commands-
UMLS_API_KEY
- Used in Therapy Normalizer to retrieve RxNorm data
- RxNorm requires a UMLS license, which you can register for one here. You must set the
UMLS_API_KEY
environment variable to your API key. This can be found in the UTS 'My Profile' area after singing in.
Example:
export UMLS_API_KEY={rxnorm_api_key}
-
HARVARD_DATAVERSE_API_KEY
- Used in Therapy Normalizer to retrieve HemOnc data
- HemOnc.org data requires a Harvard Dataverse API key. After creating a user account on the Harvard Dataverse website, you can follow these instructions to generate a key. You will create or login to your account at this site. You must set the
HARVARD_DATAVERSE_API_KEY
environment variable to your API key.
Example:
export HARVARD_DATAVERSE_API_KEY={dataverse_api_key}
-
Once all service and data dependencies are available, clear the graph, load normalizer data, and initiate harvest, transform, and data loading operations:
pipenv shell
metakb metakb load-normalizers
metakb update --refresh_source_caches
The --help
flag can be provided to any CLI command to bring up additional documentation.
Once data has been loaded successfully, use the following to start service on localhost port 8000:
uvicorn metakb.main:app --reload
Ensure that both the MetaKB Neo4j and Normalizers databases are running.
Navigate to http://localhost:8000/api/v2 in your browser to enter queries.
Explain how to run the automated tests for this system
python3 -m pytest
Code style is managed by ruff and checked prior to commit.
python3 -m ruff check --fix . && python3 -m ruff format .
Please read CONTRIBUTING.md for details on our code of conduct, and the process for submitting pull requests to us.
We use pre-commit to run conformance tests.
This ensures:
- Check code style
- Check for added large files
- Detect AWS Credentials
- Detect Private Key
Before first commit run:
pre-commit install
We use SemVer for versioning. For the versions available, see the tags on this repository.
This project is licensed under the MIT License - see the LICENSE file for details