Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Demo rfc80 working #11299

Open
wants to merge 146 commits into
base: master
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
146 commits
Select commit Hold shift + click to select a range
bd2918f
:heavy_plus_sign: Add infra to support multi db and Columnar DataSour…
haynescd Apr 8, 2024
86bd2cc
Add Columnar support for Mybatis
haynescd Apr 8, 2024
9db2295
Add Columnar Study View Controller /api/column-store
haynescd Apr 8, 2024
b4a8a38
Feature/ch/update poc base branch (#10776)
haynescd May 3, 2024
6485aa3
:white_check_mark: Add Unit test for StudyViewMapper Clickhouse
haynescd May 10, 2024
12b7b07
use regular views instead of materialized views (#10793)
onursumer May 14, 2024
83f2743
Feature/mutated genes AlterationFilter and Fix unit test (#10803)
haynescd May 21, 2024
63858cf
Add missing POC clinical data binning function (#10778)
onursumer May 23, 2024
b5fb29e
Create sample materialized view and use it (#10822)
alisman Jun 10, 2024
f566075
Feature/mutated genes total profiled counts and gene panels (#10824)
haynescd Jun 12, 2024
a03ec54
RFC80:density plot endpoint(#10837)
uklineale Jun 18, 2024
1051dea
Fix clinical data counts query/filter using new derived table (#10833)
alisman Jun 20, 2024
ed26ca7
Molecular-profile-counts service implementation (#10840)
alisman Jun 20, 2024
2015f69
Fix clinical data scatterplot (point at new derived cd table) (#10846)
alisman Jun 20, 2024
6e8e6c7
Rfc80/add cna genes endpoint (#10845)
haynescd Jun 20, 2024
5b0f2bd
:sparkles: Add StructuralVariant-genes endpoint (#10854)
haynescd Jun 24, 2024
3cac3a2
Implement study view sample-lists-counts endpoint in Clickhouse (#10849)
alisman Jun 24, 2024
3dd1e2a
Fix class import (#10856)
alisman Jun 24, 2024
a7af899
Move ClinicalCategoricalFilter to repository (#10847)
onursumer Jun 24, 2024
ab3000a
Rfc80/fix patient level filtering for alteration counts endpoints (#1…
haynescd Jun 24, 2024
fc03406
:bug: Fix totalCount calculation when WES not available (#10858)
haynescd Jun 25, 2024
604568f
Consolidate SQL files used to create CH Tables (#10867)
haynescd Jun 26, 2024
a569ec6
Demo rfc80 poc violin plot (#10863)
uklineale Jul 2, 2024
783b608
replace sample_mv references with sample_derived (#10880)
onursumer Jul 3, 2024
fc2f99d
:wrench: Update Sonar Cloud Token (#10888)
haynescd Jul 10, 2024
d50433d
Simplify clinical data binning related SQL (#10823)
onursumer Jul 11, 2024
0961680
Fix patient_derived table population (patient stable id was getting b…
alisman Jul 18, 2024
0a28546
Always load frontend over https (localdev mode) (#10901)
alisman Jul 18, 2024
827d587
Rfc80/clinical event timeline endpoint (#10899)
haynescd Jul 19, 2024
8ab5f25
Fix alteration count services (#10911)
haynescd Jul 29, 2024
94b431c
Rfc80/treatments patients endpoint (#10903)
haynescd Jul 29, 2024
dbaa897
Hide replacement clickhouse endpoints from swagger (except new treatm…
alisman Aug 2, 2024
89847e6
Rfc80/sample treatment endpoint (#10927)
haynescd Aug 5, 2024
71cf574
Rfc80/update open api annotation for sampleTreatment Endpoint (#10929)
haynescd Aug 6, 2024
d622c4e
Molecular-profile-counts-service (#10934)
alisman Aug 13, 2024
44e7c55
Add entrez_id to alteration Count endpoints (#10936)
haynescd Aug 13, 2024
21afb8b
Demo rfc80 poc mutation data counts & genomic data counts (#10807)
fuzhaoyuan Aug 13, 2024
0307a90
Add tests for case list sample counts endpoint (#10935)
alisman Aug 19, 2024
6ff724d
add unit tests for clinical data counts sql (#10933)
onursumer Aug 20, 2024
ff7ecbc
Implement custom-data-bin-counts endpoint (#10827)
gblaih Aug 21, 2024
3a975aa
normalize clinical data (#10943)
onursumer Aug 23, 2024
c34c28e
improve numerical clinical data filter (#10951)
onursumer Aug 27, 2024
c57362d
Update Treatment Endpoint to handle event_type TREATMENT, previously …
haynescd Aug 27, 2024
c83fc86
Remove need to filter via Patient-IDs, All filters utilize sample-ids…
haynescd Sep 5, 2024
8cb4ec7
add api test specs to backend (#10979)
alisman Sep 5, 2024
8712aed
fix api test merge writer (#10980)
alisman Sep 9, 2024
2b8499d
Genomic and Generic Assay bin counts endpoints (#10964)
dippindots Sep 11, 2024
cb7fb2d
Fix clinical data NA counts for multiple studies (#10978)
onursumer Sep 11, 2024
3c95157
Demo rfc80 poc mutation data count unit tests (#10981)
fuzhaoyuan Sep 12, 2024
b9afc4a
Delete custom specs (#10987)
alisman Sep 12, 2024
2900e6f
Fix GenomicDataFilterTest
dippindots Sep 12, 2024
8c6b5ae
Rfc80/add tests mutated-genes,cna-genes,structural-variants filters (…
haynescd Sep 13, 2024
c290bcd
Set custom http header with elapsed time on all api endpoints (#10994)
alisman Sep 16, 2024
64d263f
fix clinical data NA count logic (#10991)
onursumer Sep 17, 2024
beb1ade
Remove Sample Treatments with no counts (#10995)
haynescd Sep 17, 2024
a46d7e6
All custom header elapsed-time on CORS headers (#10999)
alisman Sep 18, 2024
0c22ed3
Remove caching from cd-bin-counts (#11001)
alisman Sep 18, 2024
65a97d3
We have to cast all numbers to floats in Clickhouse SQL in order to c…
alisman Sep 27, 2024
69d712a
Merge Alteration Counts that have conflicting HugoSymbols for Study V…
haynescd Sep 27, 2024
aec32c0
Add clickhouse custom data endpoints (#10963)
gblaih Oct 1, 2024
da299c5
Add samples field to custom filters to allow fetching samples without…
gblaih Oct 2, 2024
ed1165f
Add support for NA in genomic-data-bin-counts (#11006)
alisman Oct 2, 2024
218bf61
Update to add QValue for Alteration Count Services (#11034)
haynescd Oct 2, 2024
c9bd23b
Demo rfc80 poc na count for generic assay (#11039)
fuzhaoyuan Oct 2, 2024
70fb74f
Normalize data counts in a generic case-insensitive way (#11037)
onursumer Oct 4, 2024
2f48ea7
filter out null labels when counting sample lists (#11045)
onursumer Oct 8, 2024
29be4af
Rfc80/add na clinical data filtering (#11050)
haynescd Oct 8, 2024
a396f71
Add generic-assay-data-counts endpoint (#11059)
haynescd Oct 9, 2024
bd40799
Update SQL to remove duplicate Reference Genome entry (#11060)
haynescd Oct 11, 2024
e8ee142
Add checks to prevent null pointer on alterations in geneFilterQuery …
haynescd Oct 14, 2024
f88d85e
remove duplicate attributes when calculating missing NA (#11076)
onursumer Oct 14, 2024
e24a413
Re-apply caching to all study view service methods (#11091)
alisman Oct 18, 2024
1dd6462
fetch missing patient clinical data for violin plot (#11092)
onursumer Oct 18, 2024
3fc8001
Update to allow Qvalue when filtered cohort returns samples from a si…
haynescd Oct 18, 2024
fc691d0
Add new property for clickhouse cache enabling (#11109)
gblaih Oct 23, 2024
09e0917
Fix trim trailing error (#11085)
fuzhaoyuan Oct 24, 2024
928f5b1
SQL variable format clean up (#11110)
fuzhaoyuan Oct 24, 2024
302fdb4
ClinicalViolinPlot Serializable (#11124)
fuzhaoyuan Oct 28, 2024
b888b7f
Add isUnfiltered condition to cacheable clickhouse methods (#11120)
gblaih Oct 28, 2024
30b45c4
Fix violin plot sample filtering and counting issues (#11122)
onursumer Oct 28, 2024
1cfd84d
fetch missing patient clinical data for the density plot (#11132)
onursumer Oct 28, 2024
4efde5b
Fix profiling count issues in legacy (#11105)
alisman Oct 29, 2024
1934161
add internal id to sample and clinical data SQL queries (#11139)
onursumer Oct 30, 2024
aa04102
use case-insensitive ILIKE instead of case-sensitive LIKE when lookin…
onursumer Oct 30, 2024
5b6f136
ignore non-numeric values for violin plot to prevent number format ex…
onursumer Oct 30, 2024
6e2371f
Rfc80/clinical data counts refactor (#11084)
haynescd Nov 6, 2024
eff0c23
Filter out Mutations with Status UnCalled for Counts (#11166)
haynescd Nov 6, 2024
1b6d814
Update Profiled counts to use WES count when gene panel is not available
haynescd Nov 6, 2024
136dac2
Update to handle use case when sampleProfileWithoutGenePanel is 0 the…
haynescd Nov 7, 2024
bfab365
add custom driver filtering unit tests
Nov 7, 2024
076ecf6
add missing study filter param to clickhouse method for caching condi…
Nov 1, 2024
e00f084
CNA profile counts should only count samples once
alisman Nov 8, 2024
14b6a65
Add back NA counts when corresponding samples are filtered out of stu…
alisman Nov 14, 2024
5804a71
Update generic assay table schema (#11189)
fuzhaoyuan Nov 14, 2024
c56d3ea
Do not used prepared statements for the studyid lists (#11191)
alisman Nov 15, 2024
a4ced11
Api Tests Config for CircleCI (#11188)
zainasir Nov 15, 2024
74209d4
Revert "add custom driver filtering unit tests" (#11203)
alisman Nov 17, 2024
85329b6
Update Total profile Count to filter on genetic profile (#11198)
haynescd Nov 18, 2024
01b72a9
Add tests for profiled counts (#11190)
gblaih Nov 18, 2024
543f115
Remove test failing due to legacy miscount (#11205)
alisman Nov 18, 2024
4e3dc8f
cast all data filter start and end values to float (#11207)
onursumer Nov 18, 2024
242ca4d
Split clickhouse integration tests into separate files for each metho…
gblaih Nov 19, 2024
cad5ab8
Adding option for extracting study ids from sample identifiers for cl…
dippindots Nov 19, 2024
3174391
Add missing DROP TABLE statements (#11211)
sheridancbio Nov 19, 2024
db43621
Use PR-specific image for circleci api tests (#11217)
zainasir Nov 21, 2024
1e95a1c
Pretty print portal info in api-test logs
zainasir Nov 21, 2024
ce3354d
Add a frontend prop for clickhouse mode (#11219)
alisman Nov 21, 2024
a6ace50
require approval for restricted tests
zainasir Nov 22, 2024
ef25b13
rename approval job for circleci tests
zainasir Nov 22, 2024
53c7126
add integration tests for cna-genes and sv-genes (#11221)
gblaih Nov 22, 2024
2b45019
Fix Rebase issues with master
Nov 25, 2024
64fe5d0
Merge branch 'master' into demo-rfc80-poc
haynescd Nov 25, 2024
b44eb6e
Use upstream repo for api-tests
zainasir Nov 25, 2024
b780409
Fix swagger decorators for rfc80 clickhouse controller (#11230)
alisman Nov 25, 2024
2aac75e
check for non-numerical values in numerical clinical data count filter
onursumer Nov 20, 2024
9075f37
unify numerical data filters in one sql
onursumer Nov 21, 2024
17a5dad
do not normalize attribute value if not NA
onursumer Nov 22, 2024
c97fc06
add unit tests
onursumer Nov 22, 2024
97c5c5e
Add TransactionManager to handle lazy loading of data from db (cursor…
haynescd Dec 2, 2024
219c111
add unit tests for logic in service and repository methods
Nov 27, 2024
cc16f2c
fix error with case list counts method
Dec 2, 2024
b72ddaa
Add categorical patient level filtering for generic-assay-data-counts…
fuzhaoyuan Dec 3, 2024
04c9b42
Fix unfiltered method call in cacheable condition (#11250)
alisman Dec 3, 2024
68dfdaf
skip web-and-data image build for api tests (#11255)
zainasir Dec 4, 2024
955f85e
run cbioportal instance in clickhouse mode for apitests
zainasir Dec 5, 2024
8828759
pass env var to circleci environment
zainasir Dec 5, 2024
a2cc213
Merge pull request #11257 from cBioPortal/fix/circleci-clickhouse
zainasir Dec 6, 2024
a8d1e95
Update cBioPortal to dynamically load ch Components only when propert…
haynescd Dec 6, 2024
b31fe9e
Optimize bins filtering by merging bins (#11248)
fuzhaoyuan Dec 7, 2024
94e6381
Fix CNA query (#11265)
onursumer Dec 10, 2024
9c109f6
make CaseListDataCount serializable (#11267)
onursumer Dec 11, 2024
1107607
Fix CH primary keying of genetic-alteration-derived (#11268)
alisman Dec 11, 2024
4f04525
Make sure study ids exist before using them in filter SQL (#11272)
onursumer Dec 11, 2024
a0b4cd2
automate connection checks
zainasir Dec 12, 2024
fa1e4f3
Merge pull request #11276 from cBioPortal/fix/circleci-test-script
zainasir Dec 12, 2024
d761c96
skip build step if image exists
zainasir Dec 12, 2024
7390662
streamline shell checks
zainasir Dec 12, 2024
1bcd1c9
fix docker tags
zainasir Dec 12, 2024
5128ae5
use double quotes
zainasir Dec 12, 2024
5008d5f
Merge pull request #11277 from cBioPortal/fix/apitest-docker-build
zainasir Dec 12, 2024
540b57d
Add more unit tests for clickhouse service related methods (#11262)
gblaih Dec 13, 2024
fca2f1f
rollback gene panel mapper changes from profiling counts fix (#11292)
gblaih Dec 16, 2024
7ea2fe3
Custom sample filtering performance and security improvement (#11274)
dippindots Dec 18, 2024
07ef648
Revert "Custom sample filtering performance and security improvement …
alisman Dec 18, 2024
dfa4740
Merge branch 'master' into demo-rfc80-poc
alisman Dec 18, 2024
5cce667
add a comment for elapsed-time header intercept
alisman Dec 18, 2024
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
Update cBioPortal to dynamically load ch Components only when propert…
…y clickhouse_enabled is set (#11256)

* Update cBioPortal to dynamically load ch Components only when property clickhouse_enabled is set
* Update env var for circleCi
  • Loading branch information
haynescd authored Dec 6, 2024
commit a8d1e957b19b3bdc5367d17dca255d9d05cc481d
2 changes: 1 addition & 1 deletion .circleci/config.yml
Original file line number Diff line number Diff line change
Expand Up @@ -299,7 +299,7 @@ jobs:
name: Instantiate a cbioportal instance
environment:
DOCKER_REPO: cbioportal/cbioportal-dev
CLICKHOUSE_MODE: true
APP_CLICKHOUSE_MODE: "true"
command: |
cd cbioportal-test
export DOCKER_IMAGE_CBIOPORTAL=$DOCKER_REPO:$CIRCLE_SHA1-web-shenandoah
Expand Down
6 changes: 3 additions & 3 deletions .github/workflows/integration-test.yml
Original file line number Diff line number Diff line change
Expand Up @@ -42,9 +42,9 @@ jobs:
run: |
cd ./data && ./init.sh && rm -rf ./studies/* && cd ../config && \
cat $PORTAL_SOURCE_DIR/src/main/resources/application.properties | \
sed 's|spring.datasource.mysql.url=.*|spring.datasource.mysql.url=jdbc:mysql://cbioportal-database:3306/cbioportal?useSSL=false|' | \
sed 's|spring.datasource.mysql.username=.*|spring.datasource.mysql.username=cbio_user|' | \
sed 's|spring.datasource.mysql.password=.*|spring.datasource.mysql.password=somepassword|' \
sed 's|spring.datasource.url=.*|spring.datasource.url=jdbc:mysql://cbioportal-database:3306/cbioportal?useSSL=false|' | \
sed 's|spring.datasource.username=.*|spring.datasource.username=cbio_user|' | \
sed 's|spring.datasource.password=.*|spring.datasource.password=somepassword|' \
> application.properties
- name: 'Copy cgds.sql file into Docker Compose'
run: cp ./cbioportal/src/main/resources/db-scripts/cgds.sql ./cbioportal-docker-compose/data/.
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,198 @@
package org.cbioportal.persistence.mybatis;

import org.cbioportal.model.AlterationCountByGene;
import org.cbioportal.model.CaseListDataCount;
import org.cbioportal.model.ClinicalAttribute;
import org.cbioportal.model.ClinicalData;
import org.cbioportal.model.ClinicalDataCount;
import org.cbioportal.model.ClinicalDataCountItem;
import org.cbioportal.model.ClinicalEventTypeCount;
import org.cbioportal.model.CopyNumberCountByGene;
import org.cbioportal.model.GenericAssayDataCountItem;
import org.cbioportal.model.GenomicDataCount;
import org.cbioportal.model.GenomicDataCountItem;
import org.cbioportal.model.MolecularProfile;
import org.cbioportal.model.PatientTreatment;
import org.cbioportal.model.Sample;
import org.cbioportal.model.SampleTreatment;
import org.cbioportal.model.StudyViewFilterContext;
import org.cbioportal.persistence.StudyViewRepository;
import org.cbioportal.utils.config.annotation.ConditionalOnProperty;
import org.cbioportal.web.parameter.ClinicalDataType;
import org.cbioportal.web.parameter.GenericAssayDataBinFilter;
import org.cbioportal.web.parameter.GenericAssayDataFilter;
import org.cbioportal.web.parameter.GenomicDataBinFilter;
import org.cbioportal.web.parameter.GenomicDataFilter;
import org.springframework.stereotype.Repository;

import java.util.List;
import java.util.Map;
import java.util.Set;

@Repository
@ConditionalOnProperty(name = "clickhouse_mode", havingValue = "false", matchIfMissing = true)
public class UnImplementedStudyViewMyBatisRepository implements StudyViewRepository {

private static final String UNSUPPORTED_OPERATION = "StudyViewRepository Feature Not supported... Contact cbio admin.";

@Override
public List<Sample> getFilteredSamples(StudyViewFilterContext studyViewFilterContext) {
throw new UnsupportedOperationException(UNSUPPORTED_OPERATION);
}

@Override
public List<String> getFilteredStudyIds(StudyViewFilterContext studyViewFilterContext) {
throw new UnsupportedOperationException(UNSUPPORTED_OPERATION);
}

@Override
public List<ClinicalData> getSampleClinicalData(StudyViewFilterContext studyViewFilterContext, List<String> attributeIds) {
throw new UnsupportedOperationException(UNSUPPORTED_OPERATION);
}

@Override
public List<ClinicalData> getPatientClinicalData(StudyViewFilterContext studyViewFilterContext, List<String> attributeIds) {
throw new UnsupportedOperationException(UNSUPPORTED_OPERATION);

}

@Override
public List<AlterationCountByGene> getMutatedGenes(StudyViewFilterContext studyViewFilterContext) {
throw new UnsupportedOperationException(UNSUPPORTED_OPERATION);
}

@Override
public List<AlterationCountByGene> getStructuralVariantGenes(StudyViewFilterContext studyViewFilterContext) {
throw new UnsupportedOperationException(UNSUPPORTED_OPERATION);
}

@Override
public List<CopyNumberCountByGene> getCnaGenes(StudyViewFilterContext studyViewFilterContext) {
throw new UnsupportedOperationException(UNSUPPORTED_OPERATION);
}

@Override
public List<ClinicalDataCountItem> getClinicalDataCounts(StudyViewFilterContext studyViewFilterContext, List<String> filteredAttributes) {
throw new UnsupportedOperationException(UNSUPPORTED_OPERATION);
}

@Override
public List<GenomicDataCount> getMolecularProfileSampleCounts(StudyViewFilterContext studyViewFilterContext) {
throw new UnsupportedOperationException(UNSUPPORTED_OPERATION);
}

@Override
public Map<String, ClinicalDataType> getClinicalAttributeDatatypeMap() {
throw new UnsupportedOperationException(UNSUPPORTED_OPERATION);
}

@Override
public List<CaseListDataCount> getCaseListDataCountsPerStudy(StudyViewFilterContext studyViewFilterContext) {
throw new UnsupportedOperationException(UNSUPPORTED_OPERATION);
}

@Override
public Map<String, Integer> getTotalProfiledCounts(StudyViewFilterContext studyViewFilterContext, String alterationType, List<MolecularProfile> molecularProfiles) {
throw new UnsupportedOperationException(UNSUPPORTED_OPERATION);
}

@Override
public List<ClinicalAttribute> getClinicalAttributes() {
throw new UnsupportedOperationException(UNSUPPORTED_OPERATION);
}

@Override
public List<ClinicalAttribute> getClinicalAttributesForStudies(List<String> studyIds) {
throw new UnsupportedOperationException(UNSUPPORTED_OPERATION);
}

@Override
public int getFilteredSamplesCount(StudyViewFilterContext studyViewFilterContext) {
throw new UnsupportedOperationException(UNSUPPORTED_OPERATION);
}

@Override
public int getFilteredPatientCount(StudyViewFilterContext studyViewFilterContext) {
throw new UnsupportedOperationException(UNSUPPORTED_OPERATION);
}

@Override
public Map<String, Set<String>> getMatchingGenePanelIds(StudyViewFilterContext studyViewFilterContext, String alterationType) {
throw new UnsupportedOperationException(UNSUPPORTED_OPERATION);
}

@Override
public int getTotalProfiledCountsByAlterationType(StudyViewFilterContext studyViewFilterContext, String alterationType) {
throw new UnsupportedOperationException(UNSUPPORTED_OPERATION);
}

@Override
public int getSampleProfileCountWithoutPanelData(StudyViewFilterContext studyViewFilterContext, String alterationType) {
throw new UnsupportedOperationException(UNSUPPORTED_OPERATION);
}

@Override
public List<ClinicalEventTypeCount> getClinicalEventTypeCounts(StudyViewFilterContext studyViewFilterContext) {
throw new UnsupportedOperationException(UNSUPPORTED_OPERATION);
}

@Override
public List<PatientTreatment> getPatientTreatments(StudyViewFilterContext studyViewFilterContext) {
throw new UnsupportedOperationException(UNSUPPORTED_OPERATION);
}

@Override
public int getTotalPatientTreatmentCount(StudyViewFilterContext studyViewFilterContext) {
throw new UnsupportedOperationException(UNSUPPORTED_OPERATION);
}

@Override
public List<SampleTreatment> getSampleTreatments(StudyViewFilterContext studyViewFilterContext) {
throw new UnsupportedOperationException(UNSUPPORTED_OPERATION);
}

@Override
public int getTotalSampleTreatmentCount(StudyViewFilterContext studyViewFilterContext) {
throw new UnsupportedOperationException(UNSUPPORTED_OPERATION);
}

@Override
public List<GenomicDataCountItem> getCNACounts(StudyViewFilterContext studyViewFilterContext, List<GenomicDataFilter> genomicDataFilters) {
throw new UnsupportedOperationException(UNSUPPORTED_OPERATION);
}

@Override
public List<GenericAssayDataCountItem> getGenericAssayDataCounts(StudyViewFilterContext studyViewFilterContext, List<GenericAssayDataFilter> genericAssayDataFilters) {
throw new UnsupportedOperationException(UNSUPPORTED_OPERATION);
}

@Override
public Map<String, Integer> getMutationCounts(StudyViewFilterContext studyViewFilterContext, GenomicDataFilter genomicDataFilter) {
throw new UnsupportedOperationException(UNSUPPORTED_OPERATION);
}

@Override
public List<GenomicDataCountItem> getMutationCountsByType(StudyViewFilterContext studyViewFilterContext, List<GenomicDataFilter> genomicDataFilters) {
return List.of();
}

@Override
public List<ClinicalDataCount> getGenomicDataBinCounts(StudyViewFilterContext studyViewFilterContext, List<GenomicDataBinFilter> genomicDataBinFilters) {
return List.of();
}

@Override
public List<ClinicalDataCount> getGenericAssayDataBinCounts(StudyViewFilterContext studyViewFilterContext, List<GenericAssayDataBinFilter> genericAssayDataBinFilters) {
return List.of();
}

@Override
public List<MolecularProfile> getGenericAssayProfiles() {
return List.of();
}

@Override
public List<MolecularProfile> getFilteredMolecularProfilesByAlterationType(StudyViewFilterContext studyViewFilterContext, String alterationType) {
return List.of();
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@

import org.cbioportal.model.Sample;
import org.cbioportal.persistence.mybatis.typehandler.SampleTypeTypeHandler;
import org.cbioportal.utils.config.annotation.ConditionalOnProperty;
import org.mybatis.spring.SqlSessionFactoryBean;
import org.mybatis.spring.annotation.MapperScan;
import org.mybatis.spring.boot.autoconfigure.ConfigurationCustomizer;
Expand Down Expand Up @@ -33,7 +34,19 @@ public void customize(org.apache.ibatis.session.Configuration configuration) {
}

@Bean("sqlSessionFactory")
public SqlSessionFactoryBean sqlSessionFactory(@Qualifier("mysqlDataSource") DataSource dataSource, ApplicationContext applicationContext) throws IOException {
@ConditionalOnProperty(name = "clickhouse_mode", havingValue = "true")
public SqlSessionFactoryBean sqlSessionFactorySpecifyDataSource(@Qualifier("mysqlDataSource") DataSource dataSource, ApplicationContext applicationContext) throws IOException {
return sqlSessionFactory(dataSource, applicationContext);
}

@Bean("sqlSessionFactory")
@ConditionalOnProperty(name = "clickhouse_mode", havingValue = "false", matchIfMissing = true)
public SqlSessionFactoryBean sqlSessionFactoryDefault(DataSource dataSource, ApplicationContext applicationContext) throws IOException {
return sqlSessionFactory(dataSource, applicationContext);
}


private SqlSessionFactoryBean sqlSessionFactory(DataSource dataSource, ApplicationContext applicationContext) throws IOException {
SqlSessionFactoryBean sessionFactory = new SqlSessionFactoryBean();
sessionFactory.setDataSource(dataSource);
sessionFactory.setMapperLocations(
Expand All @@ -43,8 +56,9 @@ public SqlSessionFactoryBean sqlSessionFactory(@Qualifier("mysqlDataSource") Dat
return sessionFactory;
}

@Bean
public DataSourceTransactionManager transactionManager(@Qualifier("mysqlDataSource") DataSource dataSource) {
return new DataSourceTransactionManager(dataSource);
}
@Bean
@ConditionalOnProperty(name = "clickhouse_mode", havingValue = "true")
public DataSourceTransactionManager transactionManager(@Qualifier("mysqlDataSource") DataSource dataSource) {
return new DataSourceTransactionManager(dataSource);
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -21,6 +21,7 @@
import org.cbioportal.persistence.helper.AlterationFilterHelper;
import org.cbioportal.persistence.helper.StudyViewFilterHelper;
import org.cbioportal.service.util.StudyViewColumnarServiceUtil;
import org.cbioportal.utils.config.annotation.ConditionalOnProperty;
import org.cbioportal.web.parameter.ClinicalDataType;
import org.cbioportal.web.parameter.GenericAssayDataBinFilter;
import org.cbioportal.web.parameter.GenericAssayDataFilter;
Expand All @@ -38,6 +39,7 @@
import java.util.stream.Collectors;

@Repository
@ConditionalOnProperty(name = "clickhouse_mode", havingValue = "true")
public class StudyViewMyBatisRepository implements StudyViewRepository {

private final StudyViewMapper studyViewMapper;
Expand Down
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
package org.cbioportal.persistence.mybatisclickhouse.config;

import org.cbioportal.persistence.mybatis.typehandler.SampleTypeTypeHandler;
import org.cbioportal.utils.config.annotation.ConditionalOnProperty;
import org.mybatis.spring.SqlSessionFactoryBean;
import org.mybatis.spring.annotation.MapperScan;
import org.springframework.beans.factory.annotation.Qualifier;
Expand All @@ -13,6 +14,7 @@


@Configuration
@ConditionalOnProperty(name = "clickhouse_mode", havingValue = "true")
@MapperScan(value= "org.cbioportal.persistence.mybatisclickhouse", sqlSessionFactoryRef ="sqlColumnarSessionFactory")
public class PersistenceColumnarConfig {

Expand Down
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
package org.cbioportal.properties;

import org.springframework.beans.factory.annotation.Qualifier;
import org.cbioportal.utils.config.annotation.ConditionalOnProperty;
import org.springframework.boot.autoconfigure.jdbc.DataSourceProperties;
import org.springframework.boot.context.properties.ConfigurationProperties;
import org.springframework.context.annotation.Bean;
Expand All @@ -9,6 +9,7 @@
import javax.sql.DataSource;

@Configuration
@ConditionalOnProperty(name = "clickhouse_mode", havingValue = "true")
public class CustomDataSourceConfiguration {
@Bean
@ConfigurationProperties("spring.datasource.mysql")
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -21,6 +21,7 @@
import org.cbioportal.service.exception.StudyNotFoundException;
import org.cbioportal.service.treatment.TreatmentCountReportService;
import org.cbioportal.service.util.StudyViewColumnarServiceUtil;
import org.cbioportal.utils.config.annotation.ConditionalOnProperty;
import org.cbioportal.web.parameter.ClinicalDataType;
import org.cbioportal.web.parameter.CustomSampleIdentifier;
import org.cbioportal.web.parameter.GenericAssayDataBinFilter;
Expand All @@ -38,6 +39,7 @@
import java.util.stream.Collectors;

@Service
@ConditionalOnProperty(name = "clickhouse_mode", havingValue = "true")
public class StudyViewColumnarServiceImpl implements StudyViewColumnarService {


Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -6,13 +6,15 @@
import org.cbioportal.model.StudyViewFilterContext;
import org.cbioportal.model.TemporalRelation;
import org.cbioportal.persistence.StudyViewRepository;
import org.cbioportal.utils.config.annotation.ConditionalOnProperty;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;

import java.util.Set;
import java.util.stream.Stream;

@Service
@ConditionalOnProperty(name = "clickhouse_mode", havingValue = "true")
public class TreatmentCountReportServiceImpl implements TreatmentCountReportService {

private final StudyViewRepository studyViewRepository;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@
import org.cbioportal.service.CustomDataService;
import org.cbioportal.service.StudyViewColumnarService;
import org.cbioportal.service.util.CustomDataSession;
import org.cbioportal.utils.config.annotation.ConditionalOnProperty;
import org.cbioportal.web.columnar.util.CustomDataFilterUtil;
import org.cbioportal.web.columnar.util.NewClinicalDataBinUtil;
import org.cbioportal.web.parameter.*;
Expand All @@ -25,6 +26,7 @@
// but BasicDataBinner can support clinical data counts too
// after we switched clinical data counts to use this, then We can remove ClinicalDataBinner
@Component
@ConditionalOnProperty(name = "clickhouse_mode", havingValue = "true")
public class BasicDataBinner {
private final StudyViewColumnarService studyViewColumnarService;
private final DataBinner dataBinner;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,7 @@
import org.cbioportal.model.ClinicalDataCount;
import org.cbioportal.model.ClinicalDataCountItem;
import org.cbioportal.service.StudyViewColumnarService;
import org.cbioportal.utils.config.annotation.ConditionalOnProperty;
import org.cbioportal.web.columnar.util.NewClinicalDataBinUtil;
import org.cbioportal.web.parameter.ClinicalDataBinCountFilter;
import org.cbioportal.web.parameter.ClinicalDataBinFilter;
Expand All @@ -21,6 +22,7 @@
import java.util.stream.Collectors;

@Component
@ConditionalOnProperty(name = "clickhouse_mode", havingValue = "true")
public class ClinicalDataBinner {
private final StudyViewColumnarService studyViewColumnarService;
private final DataBinner dataBinner;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -33,6 +33,7 @@
import org.cbioportal.service.ViolinPlotService;
import org.cbioportal.service.exception.StudyNotFoundException;
import org.cbioportal.service.util.CustomDataSession;
import org.cbioportal.utils.config.annotation.ConditionalOnProperty;
import org.cbioportal.web.columnar.util.CustomDataFilterUtil;
import org.cbioportal.web.columnar.util.NewStudyViewFilterUtil;
import org.cbioportal.web.config.annotation.InternalApi;
Expand Down Expand Up @@ -78,6 +79,7 @@
@RestController()
@RequestMapping("/api")
@Validated
@ConditionalOnProperty(name = "clickhouse_mode", havingValue = "true")
public class StudyViewColumnStoreController {

private final StudyViewColumnarService studyViewColumnarService;
Expand Down
Loading
Loading