A command-line interface for interacting with the NCI CIDC.
Project description
NCI-CIDC-CLI
Command line tool for interfacing with the NCI CIDC API.
Environments
There are four possible environments for the CLI: dev, dev-cloudtwo, staging, and prod. As of v1.00.00, we removed extra options as part of the migration. If you are having trouble with old cached environments remove the .cidc directory in your root.
Setup
Installation
pip3 install nci-cidc-cli
Usage
To display the help message for the CLI, run:
nci-cidc
To authenticate with the CIDC API, run:
nci-cidc login [token]
Development
For local development, install the development dependencies:
pip install -r requirements.dev.txt
Admin functions
Under the (hidden) admin
are several functions meant for CIDC administators / engineers.
CSMS
nci-cidc admin test-csms
A simple API hit for a test of CSMS connection. Hits API endpoint /admin/test_csms
which in turn gets CSMS's /docs
.
This tests that the API is able to successfully make connection with the CSMS, as the /docs
endpoint requires authorization.
As the API endpoint is protected, only users with role cidc-admin
can make this request.
refresh-trial
A simple API hit to refresh the trial summary, participants.csv file, and samples.csv file.
nci-cidc refresh-trial TRIAL_ID
dbedit suite
A set of commands to list / remove data from the database, including shipments, clinical data, and assay/analysis data.
It directly uses Google's cloud SDK to make a direct connection to the postgres cloud sql database, so it requires the user has cloudsql.instances.connect
IAM permission.
Authentication
Authentication uses Application Default Credentials (ADC). Log-in is done via:
gcloud auth application-default login
Configuration
Configuration of the environment ie staging versus production is done as above using:
nci-cidc config get-env
nci-cidc config set-env ENV
Configuration of the database username is done via a pair of functions:
nci-cidc admin get-username
nci-cidc admin set-username USERNAME
The password is requested every time you issue a command so as to not store it.
Listing data
Under the list
subcommand of nci-cidc admin
, you can get descriptions of the data available in the database.
-
nci-cidc admin list clinical TRIAL_ID
- prints a table describing all shipments for the given trial
- with the following columns:
object_url
,filename
,num_participants
,created
,comment
-
nci-cidc admin list misc-data TRIAL_ID
- prints a table describing all misc_data files for the given trial
- with the following columns:
batch_id
,object_url
,filename
,created
,description
-
nci-cidc admin list shipments TRIAL_ID
- prints a table describing all shipments for the given trial
- with the following columns:
upload_type
,manifest_id
,num_samples
,created
-
nci-cidc admin list assay TRIAL_ID ASSAY_OR_ANALYSIS
- prints a table listing all samples for the given assay/analysis and trial
- any of the following values are allowed:
clinical_data
, same asnci-cidc admin list clinical TRIAL_ID
misc_data
, same asnci-cidc admin list misc-data TRIAL_ID
- analyses:
atacseq_analysis
,cytof_analysis
,rna_level1_analysis
,tcr_analysis
,wes_analysis
,wes_analysis_old
,wes_tumor_only_analysis
,wes_tumor_only_analysis_old
- assays:
atacseq
,ctdna
,cytof
,hande
,ihc
,elisa
,microbiome
,mif
,nanostring
,olink
,rna
,tcr
,wes
Removing data
Under the remove
subcommand of nci-cidc admin
, you can remove a wide variety of data from the JSON blobs.
NOTE: Remove commands only affect the database.
Use the refresh-trial
command to refresh the trial summary, participants.csv, and samples.csv
-
nci-cidc admin remove clinical TRIAL_ID TARGET_ID
- removes a given clinical data file from a given trial's metadata as well as the file itself from the portal
TARGET_ID
is thefilename
of the clinical data to remove, as fromnci-cidc admin list clinical TRIAL_ID
- special value
'*'
for all files for this trial
- special value
-
nci-cidc admin remove shipment TRIAL_ID TARGET_ID
- removes a given shipment from a given trial's metadata
TARGET_ID
is themanifest_id
of the shipment to remove, as fromnci-cidc admin list shipments TRIAL_ID
-
nci-cidc admin remove assay TRIAL_ID ASSAY_OR_ANALYSIS TARGET_ID
- removes a given clinical data file from a given trial's metadata as well as the associated files themselves from the portal
- for
ASSAY_OR_ANALYSIS=clinical_data
, same asnci-cidc admin remove clinical TRIAL_ID TARGET_ID
TARGET_ID
is a tuple of the ids to find the data to remove, as fromnci-cidc admin list assay TRIAL_ID ASSAY_OR_ANALYSIS
.- It cannot go past where is divisible in the data, but can end early to remove the whole section.
- Namely:
elisa
: requires onlyassay_run_id
misc_data
,olink
: requirebatch_id
with an optionalfilename
nanostring
: requiresbatch_id
and optionalrun_id
rna_level1_analysis
,wes_tumor_only_analysis
,wes_tumor_only_analysis_old
: requires onlycimac_id
wes_analysis
,wes_analysis_old
: requires onlyrun_id
- otherwise: requires
batch_id
and optionalcimac_id
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file nci_cidc_cli-1.0.0.tar.gz
.
File metadata
- Download URL: nci_cidc_cli-1.0.0.tar.gz
- Upload date:
- Size: 43.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.12.7
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 100ea87418e53b2c3f9202ae6ca078e69d309224d0476b2356aebe89d77dcdc8 |
|
MD5 | 4ea31b25994578f19fbf034daf00e78d |
|
BLAKE2b-256 | b77108edf2dba2f163e829154cb7602dede27dea754d208c5136442d1699b4fe |
File details
Details for the file nci_cidc_cli-1.0.0-py3-none-any.whl
.
File metadata
- Download URL: nci_cidc_cli-1.0.0-py3-none-any.whl
- Upload date:
- Size: 51.3 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.12.7
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | e2f4124d6aa4b16eb69b06cc38d66368bf27c3143715ccc46a93eec8209fa1f9 |
|
MD5 | 84ada807ec95160a614e370073551a36 |
|
BLAKE2b-256 | e44301b8dbb30b556f3adfda12d1bedd8ab76577b98c7a7af01b328459c332c4 |