Security News
Fluent Assertions Faces Backlash After Abandoning Open Source Licensing
Fluent Assertions is facing backlash after dropping the Apache license for a commercial model, leaving users blindsided and questioning contributor rights.
cbioportal-api-client
Advanced tools
cBio Portal API client. Parses tab separated responses into JSON format. Works in node and in the browser via a module loader such as Webpack.
This library can be used programatically or via the command line.
Under active development: This library is currently under active development. The module API is not finalized and is likely to change before v1.
$ npm install cbioportal-api-client --save
import CbioPortal from 'cbioportal-api-client';
const cbioPortal = CbioPortal();
cbioPortal.getCancerStudies()
.then(response => {
console.log(response); // Prints array of cancer studies returned from API
});
cbioPortal.getGeneticProfiles({ cancer_study_id: 'gbm_tcga' })
.then(response => {
console.log(response); // Prints array of genetic profiles returned from the 'gbm_tcga' study
});
Note: Requires node.
# global install to use anywhere
$ npm install -g cbioportal-api-client
# print usage info using --help
$ cbioportal-api-client --help
Usage: cbioportal-api-client [options] [command]
Commands:
getCancerStudies get cancer study meta-data
getTypesOfCancer get clinical cancer types
getGeneticProfiles [options] get genetic profile data for a cancer study.
getCaseLists [options] get case lists stored for a specific cancer study.
getProfileData [options] get genomic profile data for one or more genes.
getAlterationSummary [options] summarize alterations for the profile data.
You can get usage info for specific commands using [command] --help
Options:
-h, --help output usage information
-V, --version output the version number
-f, --format <format> response format
# example API call, sends JSON formatted response to stdout
$ cbioportal-api-client getProfileData -s gbm_tcga_cnaseq -p gbm_tcga_mutations -g TP53
# .... cut long JSON response
# summarizing alterations
$ cbioportal-api-client getAlterationSummary -s gbm_tcga_cnaseq -p gbm_tcga_mutations,gbm_tcga_gistic -g TP53,MDM2,MDM4
{"summary":{"genes":{"mdm2":{"mutated":1,"cna":9,"combined":10},"mdm4":{"mutated":0,"cna":10,"combined":10},"tp53":{"mutated":29,"cna":2,"combined":30}},"overall":47}}
cbioPortal
Creates a new cBio Portal API client
Promise
Converts tab delimited responses to JSON format
Promise
Summarizes alterations for results
cbioPortal
Creates a new cBio Portal API client
See: cbioPortal
Param | Type | Description |
---|---|---|
config | Object | Configuration options object. |
config.requestOpts | Object | Override the request congfiguration object. |
Example
Basic usage:
import CbioPortal from 'cbioportal-api-client';
const cbioPortal = CbioPortal();
cbioPortal.getCancerStudies()
.then(response => {
console.log(response); // Prints array of cancer studies returned from API
});
cbioPortal
Object
Promise
Promise
Promise
Promise
Promise
Object
cbioPortal API Object Prototype. Used as the object prototype when creating an API client object via the module factory method.
Kind: inner constant of cbioportal-api-client
See: Use CbioPortal() for object creation.
Object
Promise
Promise
Promise
Promise
Promise
Promise
Retrieves a list of all the clinical types of cancer stored on the server.
Kind: instance method of cbioPortal
Returns: Promise
- See fullfills/rejects
Fulfills: Array
response data converted from TSV to JSON
Promise
Retrieves meta-data regarding cancer studies stored on the server.
Kind: instance method of cbioPortal
Returns: Promise
- See fullfills/rejects
Fulfills: Array
response data converted from TSV to JSON
Promise
Retrieves meta-data regarding all genetic profiles, e.g. mutation or copy number profiles, stored about a specific cancer study.
Kind: instance method of cbioPortal
Returns: Promise
- See fullfills/rejects
Fulfills: Array
response data converted from TSV to JSON
Param | Type | Description |
---|---|---|
query | Object | |
query.cancer_study_id | string | Cancer study ID |
Promise
Retrieves meta-data regarding all case lists stored about a specific cancer study.
For example, a within a particular study, only some cases may have sequence data, and another subset of cases may have been sequenced and treated with a specific therapeutic protocol.
Multiple case lists may be associated with each cancer study, and this method enables you to retrieve meta-data regarding all of these case lists.
Kind: instance method of cbioPortal
Fulfill: JSON formatted response
Param | Type | Description |
---|---|---|
query | Object | |
query.cancer_study_id | string | Cancer study ID |
Promise
Retrieves genomic profile data for one or more genes.
Note: If you pass in multiple genetic profile IDs and multiple genes, the library will make multiple requests as the API does not support this type of query.
Kind: instance method of cbioPortal
Fulfill: JSON formatted response
Param | Type | Description |
---|---|---|
query | Object | |
options.case_set_id | string | A unique ID used to identify the case list ID in subsequent interface calls. This is a human readable ID. For example, "gbm_all" identifies all cases profiles in the TCGA GBM study. |
options.genetic_profile_id | Array.<string> | string | One or more genetic profile IDs |
options.gene_list | Array.<string> | string | One or more genes, specified as HUGO Gene Symbols or Entrez Gene IDs |
Promise
Converts tab delimited responses to JSON format
Returns: Promise
- Resolves with the response JSON
Param | Type | Description |
---|---|---|
response | string | TSV string |
Promise
Summarizes alterations for results
Returns: Promise
- Resolves with the summary
Fulfills: Object
Object with results, see example
Param | Type | Description |
---|---|---|
dataSets | Object | Array | Converted response dataset(s) |
Example
Basic Usage:
import CbioPortal from 'cbioportal-api-client';
import { summarizeAlterations } from 'cbioportal-api-client/dist/utils';
const cbioPortal = CbioPortal();
cbioPortal.getProfileData({
case_set_id: 'gbm_tcga_cnaseq',
genetic_profile_id: ['gbm_tcga_mutations', 'gbm_tcga_gistic'],
gene_list: ['tp53', 'mdm2', 'mdm4']
})
.then(response => summarizeAlterations(response))
.then(result => console.log(result));
// console.log output
{
summary: {
genes: {
tp53: {
mutated: 29,
cna: 2,
combined: 30
},
mdm2: {
mutated: 1,
cna: 9,
combined: 10
},
mdm4: {
mutated: 0,
cna: 10,
combined: 10
}
},
overall: 47
}
}
FAQs
cBio Portal API client with promises and response parsing
The npm package cbioportal-api-client receives a total of 25 weekly downloads. As such, cbioportal-api-client popularity was classified as not popular.
We found that cbioportal-api-client demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Fluent Assertions is facing backlash after dropping the Apache license for a commercial model, leaving users blindsided and questioning contributor rights.
Research
Security News
Socket researchers uncover the risks of a malicious Python package targeting Discord developers.
Security News
The UK is proposing a bold ban on ransomware payments by public entities to disrupt cybercrime, protect critical services, and lead global cybersecurity efforts.